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
134 lines
6.2 KiB
# -*- coding: utf-8 -*-
|
|
#############################################################################
|
|
#
|
|
# Cybrosys Technologies Pvt. Ltd.
|
|
#
|
|
# Copyright (C) 2025-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)
|
|
|