From 3751379f1e9a4c215fb6eb898b4ccc67659b9ace Mon Sep 17 00:00:00 2001 From: stephanchrst Date: Tue, 10 May 2022 21:51:50 +0700 Subject: initial commit 2 --- addons/base_import_module/models/ir_ui_view.py | 28 ++++++++++++++++++++++++++ 1 file changed, 28 insertions(+) create mode 100644 addons/base_import_module/models/ir_ui_view.py (limited to 'addons/base_import_module/models/ir_ui_view.py') diff --git a/addons/base_import_module/models/ir_ui_view.py b/addons/base_import_module/models/ir_ui_view.py new file mode 100644 index 00000000..adaa6651 --- /dev/null +++ b/addons/base_import_module/models/ir_ui_view.py @@ -0,0 +1,28 @@ +# -*- coding: utf-8 -*- +# Part of Odoo. See LICENSE file for full copyright and licensing details. + +from operator import itemgetter +from odoo import api, models + +class IrUiView(models.Model): + _inherit = 'ir.ui.view' + + @api.model + def _validate_custom_views(self, model): + # views from imported modules should be considered as custom views + result = super(IrUiView, self)._validate_custom_views(model) + + self._cr.execute(""" + SELECT max(v.id) + FROM ir_ui_view v + LEFT JOIN ir_model_data md ON (md.model = 'ir.ui.view' AND md.res_id = v.id) + LEFT JOIN ir_module_module m ON (m.name = md.module) + WHERE m.imported = true + AND v.model = %s + AND v.active = true + GROUP BY coalesce(v.inherit_id, v.id) + """, [model]) + + ids = (row[0] for row in self._cr.fetchall()) + views = self.with_context(load_all_views=True).browse(ids) + return views._check_xml() and result -- cgit v1.2.3