diff --git a/product_brand_stock/README.rst b/product_brand_stock/README.rst new file mode 100644 index 000000000..1764d5c1c --- /dev/null +++ b/product_brand_stock/README.rst @@ -0,0 +1,79 @@ +=================== +Product Brand Stock +=================== + +.. + !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + !! This file is generated by oca-gen-addon-readme !! + !! changes will be overwritten. !! + !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + !! source digest: sha256:9535914a3601b18268ce5e492244bfd5c7acc5f9de0d4c64387343a36803df09 + !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + +.. |badge1| image:: https://img.shields.io/badge/maturity-Beta-yellow.png + :target: https://odoo-community.org/page/development-status + :alt: Beta +.. |badge2| image:: https://img.shields.io/badge/licence-AGPL--3-blue.png + :target: http://www.gnu.org/licenses/agpl-3.0-standalone.html + :alt: License: AGPL-3 +.. |badge3| image:: https://img.shields.io/badge/github-OCA%2Fbrand-lightgray.png?logo=github + :target: https://github.com/OCA/brand/tree/17.0/product_brand_stock + :alt: OCA/brand +.. |badge4| image:: https://img.shields.io/badge/weblate-Translate%20me-F47D42.png + :target: https://translation.odoo-community.org/projects/brand-17-0/brand-17-0-product_brand_stock + :alt: Translate me on Weblate +.. |badge5| image:: https://img.shields.io/badge/runboat-Try%20me-875A7B.png + :target: https://runboat.odoo-community.org/builds?repo=OCA/brand&target_branch=17.0 + :alt: Try me on Runboat + +|badge1| |badge2| |badge3| |badge4| |badge5| + +This module allows to work with product_brand in Stock reports. + +**Table of contents** + +.. contents:: + :local: + +Usage +===== + +1. "Brand" group and filter is now available in Stock search views + +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 to smash it by providing a detailed and welcomed +`feedback `_. + +Do not contact contributors directly about support or help with technical issues. + +Credits +======= + +Contributors +------------ + +- Francesco Apruzzese +- `Heliconia Solutions Pvt. Ltd. `__ + + - Bhavesh Heliconia + +Maintainers +----------- + +This module is maintained by the OCA. + +.. image:: https://odoo-community.org/logo.png + :alt: Odoo Community Association + :target: https://odoo-community.org + +OCA, or the Odoo Community Association, is a nonprofit organization whose +mission is to support the collaborative development of Odoo features and +promote its widespread use. + +This module is part of the `OCA/brand `_ project on GitHub. + +You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute. diff --git a/product_brand_stock/__init__.py b/product_brand_stock/__init__.py new file mode 100644 index 000000000..87db78229 --- /dev/null +++ b/product_brand_stock/__init__.py @@ -0,0 +1,26 @@ +# Copyright 2023 Francesco Apruzzese +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). + +from psycopg2 import sql + +from . import models + + +def pre_init_hook(env): + to_init_tables = ( + "stock_move", + "stock_move_line", + "stock_quant", + ) + for to_init_table in to_init_tables: + query_alter = sql.SQL( + "ALTER TABLE {} ADD COLUMN IF NOT EXISTS product_brand_id integer" + ).format(sql.Identifier(to_init_table)) + query_update = sql.SQL( + "UPDATE {} x SET product_brand_id=t.product_brand_id " + "FROM product_product p " + "INNER JOIN product_template t ON t.id = p.product_tmpl_id " + "WHERE x.product_id=p.id" + ).format(sql.Identifier(to_init_table)) + env.cr.execute(query_alter) + env.cr.execute(query_update) diff --git a/product_brand_stock/__manifest__.py b/product_brand_stock/__manifest__.py new file mode 100644 index 000000000..101e0daf5 --- /dev/null +++ b/product_brand_stock/__manifest__.py @@ -0,0 +1,19 @@ +# Copyright 2023 Francesco Apruzzese +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). + +{ + "name": "Product Brand Stock", + "summary": """ + This module allows to work with product_brand in Stock.""", + "version": "17.0.1.0.0", + "license": "AGPL-3", + "author": "Odoo Community Association (OCA)", + "website": "https://github.com/OCA/brand", + "depends": ["product_brand", "stock"], + "data": [ + "views/stock_quant_views.xml", + "views/stock_move_views.xml", + "views/stock_move_line_views.xml", + ], + "pre_init_hook": "pre_init_hook", +} diff --git a/product_brand_stock/i18n/es.po b/product_brand_stock/i18n/es.po new file mode 100644 index 000000000..a5d15ba50 --- /dev/null +++ b/product_brand_stock/i18n/es.po @@ -0,0 +1,49 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * product_brand_stock +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 16.0\n" +"Report-Msgid-Bugs-To: \n" +"PO-Revision-Date: 2023-12-28 20:34+0000\n" +"Last-Translator: Ivorra78 \n" +"Language-Team: none\n" +"Language: es\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: nplurals=2; plural=n != 1;\n" +"X-Generator: Weblate 4.17\n" + +#. module: product_brand_stock +#: model:ir.model.fields,field_description:product_brand_stock.field_stock_move__product_brand_id +#: model:ir.model.fields,field_description:product_brand_stock.field_stock_move_line__product_brand_id +#: model:ir.model.fields,field_description:product_brand_stock.field_stock_quant__product_brand_id +#: model_terms:ir.ui.view,arch_db:product_brand_stock.quant_search_view +#: model_terms:ir.ui.view,arch_db:product_brand_stock.stock_move_line_view_search +#: model_terms:ir.ui.view,arch_db:product_brand_stock.view_move_search +msgid "Brand" +msgstr "Marca" + +#. module: product_brand_stock +#: model:ir.model,name:product_brand_stock.model_stock_move_line +msgid "Product Moves (Stock Move Line)" +msgstr "Movimientos de Producto (Línea de Movimiento de Existencias)" + +#. module: product_brand_stock +#: model:ir.model,name:product_brand_stock.model_stock_quant +msgid "Quants" +msgstr "Cantds" + +#. module: product_brand_stock +#: model:ir.model.fields,help:product_brand_stock.field_stock_move__product_brand_id +#: model:ir.model.fields,help:product_brand_stock.field_stock_move_line__product_brand_id +#: model:ir.model.fields,help:product_brand_stock.field_stock_quant__product_brand_id +msgid "Select a brand for this product" +msgstr "Seleccione una marca para este producto" + +#. module: product_brand_stock +#: model:ir.model,name:product_brand_stock.model_stock_move +msgid "Stock Move" +msgstr "Movimiento de Existencias" diff --git a/product_brand_stock/i18n/it.po b/product_brand_stock/i18n/it.po new file mode 100644 index 000000000..08cfc43e7 --- /dev/null +++ b/product_brand_stock/i18n/it.po @@ -0,0 +1,49 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * product_brand_stock +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 16.0\n" +"Report-Msgid-Bugs-To: \n" +"PO-Revision-Date: 2024-05-03 16:34+0000\n" +"Last-Translator: mymage \n" +"Language-Team: none\n" +"Language: it\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: nplurals=2; plural=n != 1;\n" +"X-Generator: Weblate 4.17\n" + +#. module: product_brand_stock +#: model:ir.model.fields,field_description:product_brand_stock.field_stock_move__product_brand_id +#: model:ir.model.fields,field_description:product_brand_stock.field_stock_move_line__product_brand_id +#: model:ir.model.fields,field_description:product_brand_stock.field_stock_quant__product_brand_id +#: model_terms:ir.ui.view,arch_db:product_brand_stock.quant_search_view +#: model_terms:ir.ui.view,arch_db:product_brand_stock.stock_move_line_view_search +#: model_terms:ir.ui.view,arch_db:product_brand_stock.view_move_search +msgid "Brand" +msgstr "Marca" + +#. module: product_brand_stock +#: model:ir.model,name:product_brand_stock.model_stock_move_line +msgid "Product Moves (Stock Move Line)" +msgstr "Movimenti prodotto (riga movimento di magazzino)" + +#. module: product_brand_stock +#: model:ir.model,name:product_brand_stock.model_stock_quant +msgid "Quants" +msgstr "Quanti" + +#. module: product_brand_stock +#: model:ir.model.fields,help:product_brand_stock.field_stock_move__product_brand_id +#: model:ir.model.fields,help:product_brand_stock.field_stock_move_line__product_brand_id +#: model:ir.model.fields,help:product_brand_stock.field_stock_quant__product_brand_id +msgid "Select a brand for this product" +msgstr "Scegliere una marca per questo prodotto" + +#. module: product_brand_stock +#: model:ir.model,name:product_brand_stock.model_stock_move +msgid "Stock Move" +msgstr "Movimento di magazzino" diff --git a/product_brand_stock/i18n/product_brand_stock.pot b/product_brand_stock/i18n/product_brand_stock.pot new file mode 100644 index 000000000..f61d8118d --- /dev/null +++ b/product_brand_stock/i18n/product_brand_stock.pot @@ -0,0 +1,46 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * product_brand_stock +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 16.0\n" +"Report-Msgid-Bugs-To: \n" +"Last-Translator: \n" +"Language-Team: \n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: \n" + +#. module: product_brand_stock +#: model:ir.model.fields,field_description:product_brand_stock.field_stock_move__product_brand_id +#: model:ir.model.fields,field_description:product_brand_stock.field_stock_move_line__product_brand_id +#: model:ir.model.fields,field_description:product_brand_stock.field_stock_quant__product_brand_id +#: model_terms:ir.ui.view,arch_db:product_brand_stock.quant_search_view +#: model_terms:ir.ui.view,arch_db:product_brand_stock.stock_move_line_view_search +#: model_terms:ir.ui.view,arch_db:product_brand_stock.view_move_search +msgid "Brand" +msgstr "" + +#. module: product_brand_stock +#: model:ir.model,name:product_brand_stock.model_stock_move_line +msgid "Product Moves (Stock Move Line)" +msgstr "" + +#. module: product_brand_stock +#: model:ir.model,name:product_brand_stock.model_stock_quant +msgid "Quants" +msgstr "" + +#. module: product_brand_stock +#: model:ir.model.fields,help:product_brand_stock.field_stock_move__product_brand_id +#: model:ir.model.fields,help:product_brand_stock.field_stock_move_line__product_brand_id +#: model:ir.model.fields,help:product_brand_stock.field_stock_quant__product_brand_id +msgid "Select a brand for this product" +msgstr "" + +#. module: product_brand_stock +#: model:ir.model,name:product_brand_stock.model_stock_move +msgid "Stock Move" +msgstr "" diff --git a/product_brand_stock/models/__init__.py b/product_brand_stock/models/__init__.py new file mode 100644 index 000000000..026b2813e --- /dev/null +++ b/product_brand_stock/models/__init__.py @@ -0,0 +1,6 @@ +# Copyright 2023 Francesco Apruzzese +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). + +from . import stock_quant +from . import stock_move +from . import stock_move_line diff --git a/product_brand_stock/models/stock_move.py b/product_brand_stock/models/stock_move.py new file mode 100644 index 000000000..9a558d932 --- /dev/null +++ b/product_brand_stock/models/stock_move.py @@ -0,0 +1,15 @@ +# Copyright 2023 Francesco Apruzzese +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). + +from odoo import fields, models + + +class StockMove(models.Model): + _inherit = "stock.move" + + product_brand_id = fields.Many2one( + comodel_name="product.brand", + related="product_id.product_brand_id", + string="Brand", + store=True, + ) diff --git a/product_brand_stock/models/stock_move_line.py b/product_brand_stock/models/stock_move_line.py new file mode 100644 index 000000000..acb9f8928 --- /dev/null +++ b/product_brand_stock/models/stock_move_line.py @@ -0,0 +1,15 @@ +# Copyright 2023 Francesco Apruzzese +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). + +from odoo import fields, models + + +class StockMoveLine(models.Model): + _inherit = "stock.move.line" + + product_brand_id = fields.Many2one( + comodel_name="product.brand", + related="product_id.product_brand_id", + string="Brand", + store=True, + ) diff --git a/product_brand_stock/models/stock_quant.py b/product_brand_stock/models/stock_quant.py new file mode 100644 index 000000000..055a40729 --- /dev/null +++ b/product_brand_stock/models/stock_quant.py @@ -0,0 +1,15 @@ +# Copyright 2023 Francesco Apruzzese +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). + +from odoo import fields, models + + +class StockQuant(models.Model): + _inherit = "stock.quant" + + product_brand_id = fields.Many2one( + comodel_name="product.brand", + related="product_id.product_brand_id", + string="Brand", + store=True, + ) diff --git a/product_brand_stock/pyproject.toml b/product_brand_stock/pyproject.toml new file mode 100644 index 000000000..4231d0ccc --- /dev/null +++ b/product_brand_stock/pyproject.toml @@ -0,0 +1,3 @@ +[build-system] +requires = ["whool"] +build-backend = "whool.buildapi" diff --git a/product_brand_stock/readme/CONTRIBUTORS.md b/product_brand_stock/readme/CONTRIBUTORS.md new file mode 100644 index 000000000..3491cb7cb --- /dev/null +++ b/product_brand_stock/readme/CONTRIBUTORS.md @@ -0,0 +1,3 @@ +- Francesco Apruzzese \<\> +- [Heliconia Solutions Pvt. Ltd.](https://www.heliconia.io) + - Bhavesh Heliconia diff --git a/product_brand_stock/readme/DESCRIPTION.md b/product_brand_stock/readme/DESCRIPTION.md new file mode 100644 index 000000000..81145d7d7 --- /dev/null +++ b/product_brand_stock/readme/DESCRIPTION.md @@ -0,0 +1 @@ +This module allows to work with product_brand in Stock reports. diff --git a/product_brand_stock/readme/USAGE.md b/product_brand_stock/readme/USAGE.md new file mode 100644 index 000000000..58920f41c --- /dev/null +++ b/product_brand_stock/readme/USAGE.md @@ -0,0 +1 @@ +1. "Brand" group and filter is now available in Stock search views diff --git a/product_brand_stock/static/description/icon.png b/product_brand_stock/static/description/icon.png new file mode 100644 index 000000000..3a0328b51 Binary files /dev/null and b/product_brand_stock/static/description/icon.png differ diff --git a/product_brand_stock/static/description/index.html b/product_brand_stock/static/description/index.html new file mode 100644 index 000000000..daf8a92b7 --- /dev/null +++ b/product_brand_stock/static/description/index.html @@ -0,0 +1,427 @@ + + + + + +Product Brand Stock + + + +
+

Product Brand Stock

+ + +

Beta License: AGPL-3 OCA/brand Translate me on Weblate Try me on Runboat

+

This module allows to work with product_brand in Stock reports.

+

Table of contents

+ +
+

Usage

+
    +
  1. “Brand” group and filter is now available in Stock search views
  2. +
+
+
+

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 to smash it by providing a detailed and welcomed +feedback.

+

Do not contact contributors directly about support or help with technical issues.

+
+
+

Credits

+
+

Contributors

+ +
+
+

Maintainers

+

This module is maintained by the OCA.

+ +Odoo Community Association + +

OCA, or the Odoo Community Association, is a nonprofit organization whose +mission is to support the collaborative development of Odoo features and +promote its widespread use.

+

This module is part of the OCA/brand project on GitHub.

+

You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute.

+
+
+
+ + diff --git a/product_brand_stock/tests/__init__.py b/product_brand_stock/tests/__init__.py new file mode 100644 index 000000000..af14dd348 --- /dev/null +++ b/product_brand_stock/tests/__init__.py @@ -0,0 +1 @@ +from . import test_product_brand_stock diff --git a/product_brand_stock/tests/test_product_brand_stock.py b/product_brand_stock/tests/test_product_brand_stock.py new file mode 100644 index 000000000..a3fab9025 --- /dev/null +++ b/product_brand_stock/tests/test_product_brand_stock.py @@ -0,0 +1,80 @@ +# Copyright 2023 Francesco Apruzzese +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). + +from odoo.addons.base.tests.common import BaseCommon + + +class TestStockMove(BaseCommon): + @classmethod + def setUpClass(self): + super().setUpClass() + + # Create product brand + self.product_brand = self.env["product.brand"].create({"name": "Test Brand"}) + + # Create a product with a brand + self.product = self.env["product.product"].create( + { + "name": "Test Product", + "type": "product", + "product_brand_id": self.product_brand.id, + } + ) + + # Create a stock.move record + self.stock_move = self.env["stock.move"].create( + { + "name": "Test Move", + "product_id": self.product.id, + "product_uom_qty": 10, + "product_uom": self.product.uom_id.id, + "location_id": self.env.ref("stock.stock_location_stock").id, + "location_dest_id": self.env.ref("stock.stock_location_customers").id, + } + ) + + def test_product_brand_on_stock_move(self): + # Check if the 'product_brand_id' field is + # correctly set on the stock.move record + self.assertEqual( + self.stock_move.product_brand_id, + self.product_brand, + "The product brand on the stock move should match the product's brand.", + ) + + def test_product_brand_on_stock_move_line(self): + # Create a stock move line linked to the stock move + stock_move_line = self.env["stock.move.line"].create( + { + "move_id": self.stock_move.id, + "product_id": self.product.id, + "product_uom_id": self.product.uom_id.id, + "location_id": self.env.ref("stock.stock_location_stock").id, + "location_dest_id": self.env.ref("stock.stock_location_customers").id, + } + ) + + # Check if the 'product_brand_id' is correctly set on the stock move line + self.assertEqual( + stock_move_line.product_brand_id, + self.product_brand, + "The product brand on the stock move line " + "should match the product's brand.", + ) + + def test_product_brand_on_stock_quant(self): + # Create a stock quant for the product + stock_quant = self.env["stock.quant"].create( + { + "product_id": self.product.id, + "location_id": self.env.ref("stock.stock_location_stock").id, + "quantity": 10, + } + ) + + # Check if the 'product_brand_id' is correctly set on the stock quant + self.assertEqual( + stock_quant.product_brand_id, + self.product_brand, + "The product brand on the stock quant should match the product's brand.", + ) diff --git a/product_brand_stock/views/stock_move_line_views.xml b/product_brand_stock/views/stock_move_line_views.xml new file mode 100644 index 000000000..0e5bd4da8 --- /dev/null +++ b/product_brand_stock/views/stock_move_line_views.xml @@ -0,0 +1,33 @@ + + + + + stock.move.line.search + stock.move.line + + + + + + + + + + + + + stock.move.line.tree + stock.move.line + + + + + + + + + diff --git a/product_brand_stock/views/stock_move_views.xml b/product_brand_stock/views/stock_move_views.xml new file mode 100644 index 000000000..836c340df --- /dev/null +++ b/product_brand_stock/views/stock_move_views.xml @@ -0,0 +1,33 @@ + + + + + stock.move.search + stock.move + + + + + + + + + + + + + stock.move.tree + stock.move + + + + + + + + + diff --git a/product_brand_stock/views/stock_quant_views.xml b/product_brand_stock/views/stock_quant_views.xml new file mode 100644 index 000000000..814cd349c --- /dev/null +++ b/product_brand_stock/views/stock_quant_views.xml @@ -0,0 +1,33 @@ + + + + + stock.quant.search + stock.quant + + + + + + + + + + + + + stock.quant.tree.editable + stock.quant + + + + + + + + +