You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

134 lines
6.2 KiB

# -*- coding: utf-8 -*-
#############################################################################
#
# Cybrosys Technologies Pvt. Ltd.
#
# Copyright (C) 2024-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
# Author: Cybrosys Techno Solutions(<https://www.cybrosys.com>)
#
# You can modify it under the terms of the GNU LESSER
# GENERAL PUBLIC LICENSE (LGPL v3), Version 3.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details.
#
# You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE
# (LGPL v3) along with this program.
# If not, see <http://www.gnu.org/licenses/>.
#
#############################################################################
from odoo import api, fields, models, _
class CustomReport(models.Model):
"""Custom report model for creating pivot view and adding required
fields for the model"""
_name = 'custom.report'
_description = 'Custom Report'
name = fields.Char(string='Name', help="Name of the pivot report")
model_id = fields.Many2one('ir.model', string='Model',
required=True,
domain="[('transient', '=', False),]",
ondelete='cascade',
help="Select the model for the report")
fields_ids = fields.One2many('custom.report.fields',
'report_id', string='Fields',
required=True,
help="Select the field that is added to the custom report.")
menu_id = fields.Many2one('ir.ui.menu', string='Menu',
required=True, ondelete='cascade',
help="The menu where you want to create a new menu item.")
menu_group_id = fields.Many2many('res.groups',
string='Menu Group', required=True,
ondelete='cascade',
help="Set the user group who hav access to the report menu")
view_type = fields.Selection([('pivot', 'Pivot'),
('graph', 'Graph')], string='View Type',
help="Select the type of report")
def unlink(self):
"""Customized unlink method to clean up related records."""
for rec in self:
# Searching the view
view = self.env['ir.ui.view'].search(
[('custom_report', '=', str(rec.id) + '_' + rec.model_id.model + '_' + rec.menu_id.complete_name)])
# search the action
action = self.env['ir.actions.act_window'].search(
[('custom_report', '=', str(rec.id) + '_' + 'pivot' + '_' + '_' + 'current',)])
# search the menu
menu = self.env['ir.ui.menu'].search(
[('custom_report', '=', str(rec.id) + '_' + rec.menu_id.complete_name + '_' + rec.model_id.model)])
view.sudo().unlink()
action.sudo().unlink()
menu.sudo().unlink()
return super().unlink()
@api.constrains('menu_id', 'fields_ids', 'model_id', 'name', 'menu_group_id')
def _create_menu_id(self):
"""Customized constraint method to create or update menu, action, and
view"""
view_id = self.env['ir.ui.view'].search(
[('custom_report', '=', str(self.id) + '_' + self.model_id.model + '_' + self.menu_id.complete_name)])
arch_base = '''<pivot string="%s" sample="1">\n''' % (self.name)
for rec in self.fields_ids:
if rec.row:
arch_base += '''
<field name="%s" type="row" string="%s"/>\n''' % (rec.custom_field_id.name, rec.label)
elif rec.measure:
arch_base += '''
<field name="%s" type="measure" string="%s"/>\n''' % (rec.custom_field_id.name, rec.label)
else:
arch_base += '''<field name="%s" string="%s" />\n''' % (rec.custom_field_id.name, rec.label)
arch_base += '''</pivot>\n'''
view_value = {
'name': _(self.name),
'type': 'pivot',
'custom_report': str(self.id) + '_' + self.model_id.model + '_' + self.menu_id.complete_name,
'model': self.model_id.model,
'mode': 'primary',
'active': True,
'arch_base': arch_base,
'groups_id': [(6, 0, [self.menu_group_id.id])],
}
if not view_id:
# Creating the view
view_obj = self.env['ir.ui.view'].create(view_value)
else:
view_id.sudo().write(view_value)
view_obj = view_id
value = {
'type': 'ir.actions.act_window',
'name': _(self.name),
'res_model': self.model_id.model,
'custom_report': str(self.id) + '_' + 'pivot' + '_' + '_' + 'current',
'view_mode': 'pivot',
'view_id': view_obj.id,
'target': 'current',
}
action_id = self.env['ir.actions.act_window'].search(
[('custom_report', '=', str(self.id) + '_' + 'pivot' + '_' + '_' + 'current')])
if not action_id:
# Creating the action
action = self.env['ir.actions.act_window'].create(value)
else:
action_id.sudo().write(value)
action = action_id
value = {
'name': self.name,
'complete_name': self.menu_id.complete_name + '/' + self.name,
'action': 'ir.actions.act_window,%s' % (action.id),
'parent_id': self.menu_id.id,
'custom_report': str(self.id) + '_' + self.menu_id.complete_name + '_' + self.model_id.model,
'groups_id': [(6, 0, [self.menu_group_id.id])],
}
menu_id = self.env['ir.ui.menu'].search(
[('custom_report', '=', str(self.id) + '_' + self.menu_id.complete_name + '_' + self.model_id.model)])
if not menu_id:
# Creating the menu
menu = self.env['ir.ui.menu'].create(value)
else:
menu_id.sudo().write(value)