From e9a25b3e53f772908249c8f2eacfc6f73d24d872 Mon Sep 17 00:00:00 2001 From: JordiMForgeFlow Date: Wed, 22 Jun 2022 17:21:39 +0200 Subject: [PATCH] [IMP] storage_image_product: add navigation from image tag to products and categories --- storage_image_product/models/image_tag.py | 60 ++++++++++++++++++++++- storage_image_product/views/image_tag.xml | 44 ++++++++++++++++- 2 files changed, 101 insertions(+), 3 deletions(-) diff --git a/storage_image_product/models/image_tag.py b/storage_image_product/models/image_tag.py index 4704b63e7c..248ad4d670 100644 --- a/storage_image_product/models/image_tag.py +++ b/storage_image_product/models/image_tag.py @@ -3,7 +3,7 @@ # License LGPL-3.0 or later (http://www.gnu.org/licenses/lgpl). -from odoo import api, fields, models +from odoo import _, api, fields, models class ImageTag(models.Model): @@ -27,3 +27,61 @@ def _get_default_apply_on(self): selection=[("product", "Product"), ("category", "Category")], default=lambda self: self._get_default_apply_on(), ) + product_img_rel_ids = fields.One2many( + comodel_name="product.image.relation", + inverse_name="tag_id", + string="Product Image Relations", + readonly=True, + ) + categ_img_rel_ids = fields.One2many( + comodel_name="category.image.relation", + inverse_name="tag_id", + string="Category Image Relations", + readonly=True, + ) + product_tmpl_count = fields.Integer( + string="# of Products", compute="_compute_product_tmpl_count" + ) + product_categ_count = fields.Integer( + string="# of Categories", compute="_compute_product_categ_count" + ) + + @api.depends("product_img_rel_ids") + def _compute_product_tmpl_count(self): + for rec in self: + rec.product_tmpl_count = len( + rec.product_img_rel_ids.mapped("product_tmpl_id") + ) + + @api.depends("categ_img_rel_ids") + def _compute_product_categ_count(self): + for rec in self: + rec.product_categ_count = len(rec.categ_img_rel_ids.mapped("category_id")) + + def action_open_product_templates(self): + self.ensure_one() + product_templates = self.product_img_rel_ids.mapped("product_tmpl_id") + if len(product_templates) >= 1: + result = { + "name": _("Products"), + "domain": [("id", "in", product_templates.ids)], + "res_model": "product.template", + "type": "ir.actions.act_window", + "view_mode": "list,form", + } + return result + return {"type": "ir.actions.act_window_close"} + + def action_open_product_categories(self): + self.ensure_one() + product_categories = self.categ_img_rel_ids.mapped("category_id") + if len(product_categories) >= 1: + result = { + "name": _("Product Categories"), + "domain": [("id", "in", product_categories.ids)], + "res_model": "product.category", + "type": "ir.actions.act_window", + "view_mode": "list,form", + } + return result + return {"type": "ir.actions.act_window_close"} diff --git a/storage_image_product/views/image_tag.xml b/storage_image_product/views/image_tag.xml index 0b7beaa2ed..d133ab7da0 100644 --- a/storage_image_product/views/image_tag.xml +++ b/storage_image_product/views/image_tag.xml @@ -3,7 +3,7 @@ image.tag - + @@ -19,11 +19,51 @@ + + image.tag + +
+ +
+ + +
+ + + + + +
+
+
+
Image Tag ir.actions.act_window image.tag - tree + tree,form [] {}