From a16b061dd9a80e22b9668241a120b7b21a2df3c0 Mon Sep 17 00:00:00 2001 From: Eric Antones Date: Tue, 7 Feb 2023 22:47:30 +0100 Subject: [PATCH 1/5] [ADD] product_supplier_ref: new module --- product_supplier_ref/README.rst | 27 ++++++++++++++++++ product_supplier_ref/__init__.py | 1 + product_supplier_ref/__manifest__.py | 17 +++++++++++ product_supplier_ref/models/__init__.py | 1 + product_supplier_ref/models/product.py | 22 ++++++++++++++ .../static/description/icon.png | Bin 0 -> 6342 bytes 6 files changed, 68 insertions(+) create mode 100644 product_supplier_ref/README.rst create mode 100644 product_supplier_ref/__init__.py create mode 100644 product_supplier_ref/__manifest__.py create mode 100644 product_supplier_ref/models/__init__.py create mode 100644 product_supplier_ref/models/product.py create mode 100644 product_supplier_ref/static/description/icon.png diff --git a/product_supplier_ref/README.rst b/product_supplier_ref/README.rst new file mode 100644 index 000000000..cf77e262b --- /dev/null +++ b/product_supplier_ref/README.rst @@ -0,0 +1,27 @@ +.. image:: https://img.shields.io/badge/license-AGPL--3-blue.png + :target: https://www.gnu.org/licenses/agpl + :alt: License: AGPL-3 + +==================== +Product Supplier Ref +==================== + +* Use the product name if the supplier product name is empty instead + of the product default_code. + +Bug Tracker +=========== + +Bugs are tracked on `GitHub Issues +`_. In case of trouble, please +check there if your issue has already been reported. If you spotted it first, +help us smashing it by providing a detailed and welcomed feedback. + +Credits +======= + +Contributors +------------ + +* `NuoBiT Solutions, S.L.`: + * Eric Antones diff --git a/product_supplier_ref/__init__.py b/product_supplier_ref/__init__.py new file mode 100644 index 000000000..0650744f6 --- /dev/null +++ b/product_supplier_ref/__init__.py @@ -0,0 +1 @@ +from . import models diff --git a/product_supplier_ref/__manifest__.py b/product_supplier_ref/__manifest__.py new file mode 100644 index 000000000..1aef7aff4 --- /dev/null +++ b/product_supplier_ref/__manifest__.py @@ -0,0 +1,17 @@ +# Copyright NuoBiT Solutions, S.L. () +# Eric Antones +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl) + +{ + "name": "Product Supplier Ref", + "summary": "Use the product name if the supplier product name is " + "empty instead of the product default_code.", + "version": "14.0.1.0.0", + "category": "Purchase", + "author": "NuoBiT Solutions,S.L.", + "website": "https://github.com/nuobit/odoo-addons", + "license": "AGPL-3", + "depends": [ + "product", + ], +} diff --git a/product_supplier_ref/models/__init__.py b/product_supplier_ref/models/__init__.py new file mode 100644 index 000000000..9649db77a --- /dev/null +++ b/product_supplier_ref/models/__init__.py @@ -0,0 +1 @@ +from . import product diff --git a/product_supplier_ref/models/product.py b/product_supplier_ref/models/product.py new file mode 100644 index 000000000..624dbea88 --- /dev/null +++ b/product_supplier_ref/models/product.py @@ -0,0 +1,22 @@ +# Copyright NuoBiT Solutions, S.L. () +# Eric Antones +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl) + +from odoo import api, models + + +class ProductProduct(models.Model): + _inherit = "product.product" + + @api.depends_context("partner_id") + def _compute_partner_ref(self): + super()._compute_partner_ref() + for product in self: + for supplier_info in product.seller_ids: + if supplier_info.name.id == product._context.get("partner_id"): + product_name = supplier_info.product_name or product.name + partner_ref_l = [product_name] + if product.code: + partner_ref_l.insert(0, "[%s] " % product.code) + product.partner_ref = " ".join(partner_ref_l) + break diff --git a/product_supplier_ref/static/description/icon.png b/product_supplier_ref/static/description/icon.png new file mode 100644 index 0000000000000000000000000000000000000000..1cd641e792c30455187ca30940bc0f329ce8bbb0 GIT binary patch literal 6342 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 literal 0 HcmV?d00001 From 97af6d44ce07f2af93b0ac0aae0e7ac1cbd477fc Mon Sep 17 00:00:00 2001 From: bijaya Date: Wed, 19 Feb 2025 10:40:58 +0000 Subject: [PATCH 2/5] [IMP] product_supplier_ref: pre-commit stuff --- partner_lang_required/README.rst | 4 ++-- partner_lang_required/static/description/index.html | 4 ++-- product_supplier_ref/__manifest__.py | 9 +++++---- product_supplier_ref/models/product.py | 1 + product_supplier_ref/pyproject.toml | 3 +++ 5 files changed, 13 insertions(+), 8 deletions(-) create mode 100644 product_supplier_ref/pyproject.toml diff --git a/partner_lang_required/README.rst b/partner_lang_required/README.rst index 1a70c3072..29c59d4ea 100644 --- a/partner_lang_required/README.rst +++ b/partner_lang_required/README.rst @@ -22,8 +22,8 @@ Partner language required |badge1| |badge2| |badge3| -This module convert the lang partner attribute to required by adding -arestriction to it +This module convert the lang partner attribute to required by adding a +restriction to it **Table of contents** diff --git a/partner_lang_required/static/description/index.html b/partner_lang_required/static/description/index.html index 4a4b7fcfe..a1060d612 100644 --- a/partner_lang_required/static/description/index.html +++ b/partner_lang_required/static/description/index.html @@ -370,8 +370,8 @@

Partner language required

!! source digest: sha256:bad01f3c88a6cffe5a9db6fb5cbbeb1188bd600f8c28504b4547c3dd74ccce4d !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! -->

Beta License: AGPL-3 NuoBiT/odoo-addons

-

This module convert the lang partner attribute to required by adding -arestriction to it

+

This module convert the lang partner attribute to required by adding a +restriction to it

Table of contents

    diff --git a/product_supplier_ref/__manifest__.py b/product_supplier_ref/__manifest__.py index 1aef7aff4..ef3c10112 100644 --- a/product_supplier_ref/__manifest__.py +++ b/product_supplier_ref/__manifest__.py @@ -1,15 +1,16 @@ # Copyright NuoBiT Solutions, S.L. () -# Eric Antones +# Eric Antones # License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl) { "name": "Product Supplier Ref", "summary": "Use the product name if the supplier product name is " "empty instead of the product default_code.", - "version": "14.0.1.0.0", + "version": "17.0.1.0.0", "category": "Purchase", - "author": "NuoBiT Solutions,S.L.", - "website": "https://github.com/nuobit/odoo-addons", + "author": "NuoBiT Solutions SL, Eric Antones", + "website": "https://github.com/NuoBiT/odoo-addons", "license": "AGPL-3", "depends": [ "product", diff --git a/product_supplier_ref/models/product.py b/product_supplier_ref/models/product.py index 624dbea88..7d28988a4 100644 --- a/product_supplier_ref/models/product.py +++ b/product_supplier_ref/models/product.py @@ -20,3 +20,4 @@ def _compute_partner_ref(self): partner_ref_l.insert(0, "[%s] " % product.code) product.partner_ref = " ".join(partner_ref_l) break + return diff --git a/product_supplier_ref/pyproject.toml b/product_supplier_ref/pyproject.toml new file mode 100644 index 000000000..4231d0ccc --- /dev/null +++ b/product_supplier_ref/pyproject.toml @@ -0,0 +1,3 @@ +[build-system] +requires = ["whool"] +build-backend = "whool.buildapi" From 6cab5134d32b2dc245fe0aff9d039321940b845e Mon Sep 17 00:00:00 2001 From: bijaya Date: Wed, 19 Feb 2025 10:51:40 +0000 Subject: [PATCH 3/5] [MIG] product_supplier_ref: Migration to 17.0 --- product_supplier_ref/__manifest__.py | 7 ++++- .../views/product_supplier_ref_views.xml | 26 +++++++++++++++++++ 2 files changed, 32 insertions(+), 1 deletion(-) create mode 100644 product_supplier_ref/views/product_supplier_ref_views.xml diff --git a/product_supplier_ref/__manifest__.py b/product_supplier_ref/__manifest__.py index ef3c10112..097e18d5f 100644 --- a/product_supplier_ref/__manifest__.py +++ b/product_supplier_ref/__manifest__.py @@ -9,10 +9,15 @@ "empty instead of the product default_code.", "version": "17.0.1.0.0", "category": "Purchase", - "author": "NuoBiT Solutions SL, Eric Antones", + "author": "NuoBiT Solutions SL", "website": "https://github.com/NuoBiT/odoo-addons", "license": "AGPL-3", "depends": [ "product", ], + "data": [ + "views/product_supplier_ref_views.xml", + ], + "installable": True, + "application": False, } diff --git a/product_supplier_ref/views/product_supplier_ref_views.xml b/product_supplier_ref/views/product_supplier_ref_views.xml new file mode 100644 index 000000000..bc036ecc5 --- /dev/null +++ b/product_supplier_ref/views/product_supplier_ref_views.xml @@ -0,0 +1,26 @@ + + + + + product.product.form.supplier.ref + product.product + + + + + + + + + + + product.product.tree.supplier.ref + product.product + + + + + + + + \ No newline at end of file From bd9ad59ab733848515664693e718d52fef2a52c9 Mon Sep 17 00:00:00 2001 From: bijaya Date: Wed, 19 Feb 2025 10:55:18 +0000 Subject: [PATCH 4/5] [IMP] product_supplier_ref: pre-commit stuff --- product_supplier_ref/__manifest__.py | 5 ---- .../views/product_supplier_ref_views.xml | 26 ------------------- 2 files changed, 31 deletions(-) delete mode 100644 product_supplier_ref/views/product_supplier_ref_views.xml diff --git a/product_supplier_ref/__manifest__.py b/product_supplier_ref/__manifest__.py index 097e18d5f..a865bd0cd 100644 --- a/product_supplier_ref/__manifest__.py +++ b/product_supplier_ref/__manifest__.py @@ -15,9 +15,4 @@ "depends": [ "product", ], - "data": [ - "views/product_supplier_ref_views.xml", - ], - "installable": True, - "application": False, } diff --git a/product_supplier_ref/views/product_supplier_ref_views.xml b/product_supplier_ref/views/product_supplier_ref_views.xml deleted file mode 100644 index bc036ecc5..000000000 --- a/product_supplier_ref/views/product_supplier_ref_views.xml +++ /dev/null @@ -1,26 +0,0 @@ - - - - - product.product.form.supplier.ref - product.product - - - - - - - - - - - product.product.tree.supplier.ref - product.product - - - - - - - - \ No newline at end of file From d8e3f45b55bb84a72a5e6e44bcc15ab1d47a53b1 Mon Sep 17 00:00:00 2001 From: bijaya Date: Wed, 19 Feb 2025 10:56:30 +0000 Subject: [PATCH 5/5] [MIG] product_supplier_ref: Migration to 17.0 --- product_supplier_ref/__manifest__.py | 5 ++++ .../views/product_supplier_ref_views.xml | 24 +++++++++++++++++++ 2 files changed, 29 insertions(+) create mode 100644 product_supplier_ref/views/product_supplier_ref_views.xml diff --git a/product_supplier_ref/__manifest__.py b/product_supplier_ref/__manifest__.py index a865bd0cd..097e18d5f 100644 --- a/product_supplier_ref/__manifest__.py +++ b/product_supplier_ref/__manifest__.py @@ -15,4 +15,9 @@ "depends": [ "product", ], + "data": [ + "views/product_supplier_ref_views.xml", + ], + "installable": True, + "application": False, } diff --git a/product_supplier_ref/views/product_supplier_ref_views.xml b/product_supplier_ref/views/product_supplier_ref_views.xml new file mode 100644 index 000000000..7f111a486 --- /dev/null +++ b/product_supplier_ref/views/product_supplier_ref_views.xml @@ -0,0 +1,24 @@ + + + + product.product.form.supplier.ref + product.product + + + + + + + + + + product.product.tree.supplier.ref + product.product + + + + + + + + \ No newline at end of file