-
-
Notifications
You must be signed in to change notification settings - Fork 1k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Signed-off-by rafaelbn
- Loading branch information
Showing
19 changed files
with
1,142 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,141 @@ | ||
============================================ | ||
Sale Order Line all Product Attribute Values | ||
============================================ | ||
|
||
.. | ||
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! | ||
!! This file is generated by oca-gen-addon-readme !! | ||
!! changes will be overwritten. !! | ||
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! | ||
!! source digest: sha256:fd1a8b3869250cb1081d3ece9f69491e9fed0668c696bf90d2cff21c5aa82756 | ||
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! | ||
.. |badge1| image:: https://img.shields.io/badge/maturity-Alpha-red.png | ||
:target: https://odoo-community.org/page/development-status | ||
:alt: Alpha | ||
.. |badge2| image:: https://img.shields.io/badge/licence-LGPL--3-blue.png | ||
:target: http://www.gnu.org/licenses/lgpl-3.0-standalone.html | ||
:alt: License: LGPL-3 | ||
.. |badge3| image:: https://img.shields.io/badge/github-OCA%2Fsale--workflow-lightgray.png?logo=github | ||
:target: https://github.com/OCA/sale-workflow/tree/16.0/sale_order_line_product_attribute_values | ||
:alt: OCA/sale-workflow | ||
.. |badge4| image:: https://img.shields.io/badge/weblate-Translate%20me-F47D42.png | ||
:target: https://translation.odoo-community.org/projects/sale-workflow-16-0/sale-workflow-16-0-sale_order_line_product_attribute_values | ||
: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/sale-workflow&target_branch=16.0 | ||
:alt: Try me on Runboat | ||
|
||
|badge1| |badge2| |badge3| |badge4| |badge5| | ||
|
||
This module extends the functionality of Sale Order Lines to support | ||
view and filter by Product Attribute Values used. | ||
|
||
.. IMPORTANT:: | ||
This is an alpha version, the data model and design can change at any time without warning. | ||
Only for development or testing purpose, do not use in production. | ||
`More details on development status <https://odoo-community.org/page/development-status>`_ | ||
|
||
**Table of contents** | ||
|
||
.. contents:: | ||
:local: | ||
|
||
Use Cases / Context | ||
=================== | ||
|
||
This module was developed because there is no way to know what Product | ||
Attribute Values has been used on a product if there is only one | ||
attribute configured in the product with "Never create variants" mode. | ||
|
||
It will be useful for you if you want to know which Product Attribute | ||
Values has been used in which Sale Order Lines. | ||
|
||
If you need this module for those reasons, these might interest you too: | ||
|
||
- sale_order_line_menu | ||
|
||
Configuration | ||
============= | ||
|
||
This module will not trigger the recomputation of the lines attributes | ||
when installing only this module. This will avoid the installation | ||
timeout. | ||
|
||
If you later want to recompute the lines, you can use a scheduled action | ||
similar to this one: | ||
|
||
.. code:: python | ||
env["sale.order.line"].search([ | ||
("product_template_id.attribute_line_ids", "!=", []), | ||
])._compute_all_product_template_attribute_value_ids() | ||
Usage | ||
===== | ||
|
||
To use this module, you need to: | ||
|
||
1. Create an Attribute called "Trademark" (for example) with Display | ||
Type "Pills", Variants Creation Mode "Never" and add an Attribute | ||
Value called "Adidas" | ||
2. Create a product called "Shoe Adidas REF 123" and "Show Adidas REF | ||
456" | ||
3. Add "Trademark: Adidas" on Attributes & Variants tab on both products | ||
and configure (you can set an incremented price if you want) | ||
4. Sell both products in a Sale Order | ||
5. Created Sale Order Lines has Product Template Attribute Values and | ||
Attribute Values its lines. | ||
6. If you has installed ``sale_order_line_menu``, you can check those | ||
values on Sale > Orders > Order Lines. | ||
|
||
Bug Tracker | ||
=========== | ||
|
||
Bugs are tracked on `GitHub Issues <https://github.com/OCA/sale-workflow/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 <https://github.com/OCA/sale-workflow/issues/new?body=module:%20sale_order_line_product_attribute_values%0Aversion:%2016.0%0A%0A**Steps%20to%20reproduce**%0A-%20...%0A%0A**Current%20behavior**%0A%0A**Expected%20behavior**>`_. | ||
|
||
Do not contact contributors directly about support or help with technical issues. | ||
|
||
Credits | ||
======= | ||
|
||
Authors | ||
------- | ||
|
||
* Moduon | ||
|
||
Contributors | ||
------------ | ||
|
||
- Eduardo de Miguel (`Moduon <https://www.moduon.team/>`__) | ||
|
||
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. | ||
|
||
.. |maintainer-Shide| image:: https://github.com/Shide.png?size=40px | ||
:target: https://github.com/Shide | ||
:alt: Shide | ||
.. |maintainer-rafaelbn| image:: https://github.com/rafaelbn.png?size=40px | ||
:target: https://github.com/rafaelbn | ||
:alt: rafaelbn | ||
|
||
Current `maintainers <https://odoo-community.org/page/maintainer-role>`__: | ||
|
||
|maintainer-Shide| |maintainer-rafaelbn| | ||
|
||
This module is part of the `OCA/sale-workflow <https://github.com/OCA/sale-workflow/tree/16.0/sale_order_line_product_attribute_values>`_ project on GitHub. | ||
|
||
You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
from . import models |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,22 @@ | ||
# Copyright 2024 Moduon Team S.L. | ||
# License LGPL-3.0 or later (https://www.gnu.org/licenses/lgpl-3.0) | ||
|
||
{ | ||
"name": "Sale Order Line all Product Attribute Values", | ||
"summary": "Store Product Attribute Values in Sale Order Lines", | ||
"version": "16.0.1.0.0", | ||
"development_status": "Alpha", | ||
"category": "Sales/Sales", | ||
"website": "https://github.com/OCA/sale-workflow", | ||
"author": "Moduon, Odoo Community Association (OCA)", | ||
"maintainers": ["Shide", "rafaelbn"], | ||
"license": "LGPL-3", | ||
"application": False, | ||
"installable": True, | ||
"depends": [ | ||
"sale", | ||
], | ||
"data": [ | ||
"views/sale_order_line_view.xml", | ||
], | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,63 @@ | ||
# Translation of Odoo Server. | ||
# This file contains the translation of the following modules: | ||
# * sale_order_line_product_attribute_values | ||
# | ||
msgid "" | ||
msgstr "" | ||
"Project-Id-Version: Odoo Server 16.0\n" | ||
"Report-Msgid-Bugs-To: \n" | ||
"POT-Creation-Date: 2024-11-26 09:09+0000\n" | ||
"PO-Revision-Date: 2024-11-26 10:11+0100\n" | ||
"Last-Translator: \n" | ||
"Language-Team: \n" | ||
"Language: es\n" | ||
"MIME-Version: 1.0\n" | ||
"Content-Type: text/plain; charset=UTF-8\n" | ||
"Content-Transfer-Encoding: 8bit\n" | ||
"Plural-Forms: nplurals=2; plural=(n != 1);\n" | ||
"X-Generator: Poedit 3.4.4\n" | ||
|
||
#. module: sale_order_line_product_attribute_values | ||
#: model:ir.model.fields,help:sale_order_line_product_attribute_values.field_sale_order_line__all_product_attribute_value_ids | ||
msgid "" | ||
"All Product Attribute Values used directly or indirecly for this line.\n" | ||
"Contains information about increased price, html color, etc." | ||
msgstr "" | ||
"Todos los Valores de Atributos del Producto utilizados directa o " | ||
"indirectamente para esta línea.\n" | ||
"Contiene información sobre el incremento de precio, color html, etc." | ||
|
||
#. module: sale_order_line_product_attribute_values | ||
#: model:ir.model.fields,help:sale_order_line_product_attribute_values.field_sale_order_line__all_product_template_attribute_value_ids | ||
msgid "" | ||
"All Product Template Attribute Values used directly or indirecly for this " | ||
"line." | ||
msgstr "" | ||
"Todos los Valores de Atributo de la Plantilla de Producto utilizados " | ||
"directa o indirectamente para esta línea." | ||
|
||
#. module: sale_order_line_product_attribute_values | ||
#: model:ir.model.fields,field_description:sale_order_line_product_attribute_values.field_sale_order_line__all_product_attribute_value_ids | ||
#: model_terms:ir.ui.view,arch_db:sale_order_line_product_attribute_values.view_sales_order_line_filter | ||
msgid "Attribute Values" | ||
msgstr "Valores de atributo" | ||
|
||
#. module: sale_order_line_product_attribute_values | ||
#: model_terms:ir.ui.view,arch_db:sale_order_line_product_attribute_values.sale_order_line_view_form_readonly | ||
msgid "Attributes" | ||
msgstr "Atributos" | ||
|
||
#. module: sale_order_line_product_attribute_values | ||
#: model:ir.model.fields,field_description:sale_order_line_product_attribute_values.field_sale_order_line__all_product_template_attribute_value_ids | ||
msgid "Product Template Attribute Values" | ||
msgstr "Valores de Atributo de la Plantilla de producto" | ||
|
||
#. module: sale_order_line_product_attribute_values | ||
#: model:ir.model,name:sale_order_line_product_attribute_values.model_sale_order_line | ||
msgid "Sales Order Line" | ||
msgstr "Línea de Orden de Venta" | ||
|
||
#. module: sale_order_line_product_attribute_values | ||
#: model_terms:ir.ui.view,arch_db:sale_order_line_product_attribute_values.sale_order_line_view_form_readonly | ||
msgid "Total" | ||
msgstr "Total" |
56 changes: 56 additions & 0 deletions
56
sale_order_line_product_attribute_values/i18n/sale_order_line_product_attribute_values.pot
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,56 @@ | ||
# Translation of Odoo Server. | ||
# This file contains the translation of the following modules: | ||
# * sale_order_line_product_attribute_values | ||
# | ||
msgid "" | ||
msgstr "" | ||
"Project-Id-Version: Odoo Server 16.0\n" | ||
"Report-Msgid-Bugs-To: \n" | ||
"POT-Creation-Date: 2024-11-26 09:09+0000\n" | ||
"PO-Revision-Date: 2024-11-26 09:09+0000\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: sale_order_line_product_attribute_values | ||
#: model:ir.model.fields,help:sale_order_line_product_attribute_values.field_sale_order_line__all_product_attribute_value_ids | ||
msgid "" | ||
"All Product Attribute Values used directly or indirecly for this line.\n" | ||
"Contains information about increased price, html color, etc." | ||
msgstr "" | ||
|
||
#. module: sale_order_line_product_attribute_values | ||
#: model:ir.model.fields,help:sale_order_line_product_attribute_values.field_sale_order_line__all_product_template_attribute_value_ids | ||
msgid "" | ||
"All Product Template Attribute Values used directly or indirecly for this " | ||
"line." | ||
msgstr "" | ||
|
||
#. module: sale_order_line_product_attribute_values | ||
#: model:ir.model.fields,field_description:sale_order_line_product_attribute_values.field_sale_order_line__all_product_attribute_value_ids | ||
#: model_terms:ir.ui.view,arch_db:sale_order_line_product_attribute_values.view_sales_order_line_filter | ||
msgid "Attribute Values" | ||
msgstr "" | ||
|
||
#. module: sale_order_line_product_attribute_values | ||
#: model_terms:ir.ui.view,arch_db:sale_order_line_product_attribute_values.sale_order_line_view_form_readonly | ||
msgid "Attributes" | ||
msgstr "" | ||
|
||
#. module: sale_order_line_product_attribute_values | ||
#: model:ir.model.fields,field_description:sale_order_line_product_attribute_values.field_sale_order_line__all_product_template_attribute_value_ids | ||
msgid "Product Template Attribute Values" | ||
msgstr "" | ||
|
||
#. module: sale_order_line_product_attribute_values | ||
#: model:ir.model,name:sale_order_line_product_attribute_values.model_sale_order_line | ||
msgid "Sales Order Line" | ||
msgstr "" | ||
|
||
#. module: sale_order_line_product_attribute_values | ||
#: model_terms:ir.ui.view,arch_db:sale_order_line_product_attribute_values.sale_order_line_view_form_readonly | ||
msgid "Total" | ||
msgstr "" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
from . import sale_order_line |
70 changes: 70 additions & 0 deletions
70
sale_order_line_product_attribute_values/models/sale_order_line.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,70 @@ | ||
# Copyright 2024 Moduon Team S.L. | ||
# License LGPL-3.0 or later (https://www.gnu.org/licenses/lgpl-3.0) | ||
|
||
from odoo import api, fields, models | ||
|
||
|
||
class SaleOrderLine(models.Model): | ||
_inherit = "sale.order.line" | ||
|
||
all_product_template_attribute_value_ids = fields.Many2many( | ||
string="Product Template Attribute Values", | ||
comodel_name="product.template.attribute.value", | ||
relation="sale_order_line_all_product_template_attribute_value_rel", | ||
compute="_compute_all_product_template_attribute_value_ids", | ||
help="All Product Template Attribute Values used directly or indirecly " | ||
"for this line.", | ||
store=True, | ||
readonly=True, | ||
) | ||
all_product_attribute_value_ids = fields.Many2many( | ||
string="Attribute Values", | ||
comodel_name="product.attribute.value", | ||
relation="sale_order_line_all_product_attribute_value_rel", | ||
compute="_compute_all_product_template_attribute_value_ids", | ||
help="All Product Attribute Values used directly or indirecly " | ||
"for this line.\n" | ||
"Contains information about increased price, html color, etc.", | ||
store=True, | ||
readonly=True, | ||
) | ||
|
||
@api.depends( | ||
"product_id", | ||
"product_custom_attribute_value_ids", | ||
"product_no_variant_attribute_value_ids", | ||
) | ||
def _compute_all_product_template_attribute_value_ids(self): | ||
"""Compute all Product Template Attribute Values used directly or indirecly""" | ||
if self.env.context.get("module") == "sale_order_line_product_attribute_values": | ||
# Do not trigger computation when module is installed alone | ||
# due to the large amount of records to compute | ||
return | ||
for record in self: | ||
product = record.product_id | ||
# Attribute values from the line | ||
pt_attr_values = record.product_no_variant_attribute_value_ids | ||
# Attribute values from the custom attributes | ||
pt_attr_values |= record.product_custom_attribute_value_ids.mapped( | ||
"custom_product_template_attribute_value_id" | ||
) | ||
# Attribute values from the product | ||
pt_attr_values |= product.product_template_variant_value_ids | ||
# Attribute values that doesn't need to be chosen from the product | ||
# because the variant is created with its values | ||
pt_attr_values |= product.product_template_attribute_value_ids | ||
# Attribute values from the product that doesn't need to be chosen | ||
# because doesn't create variant and has only one option | ||
for attr_l in product.valid_product_template_attribute_line_ids: | ||
if ( | ||
len(attr_l.value_ids) == 1 | ||
and attr_l.attribute_id.create_variant == "no_variant" | ||
): | ||
pt_attr_values |= attr_l.product_template_value_ids.filtered( | ||
lambda ptav: ptav.ptav_active | ||
and ptav.product_attribute_value_id in attr_l.value_ids | ||
) | ||
record.all_product_template_attribute_value_ids = pt_attr_values | ||
record.all_product_attribute_value_ids = pt_attr_values.mapped( | ||
"product_attribute_value_id" | ||
) |
10 changes: 10 additions & 0 deletions
10
sale_order_line_product_attribute_values/readme/CONFIGURE.md
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,10 @@ | ||
This module will not trigger the recomputation of the lines attributes when installing only this module. | ||
This will avoid the installation timeout. | ||
|
||
If you later want to recompute the lines, you can use a scheduled action similar to this one: | ||
|
||
```python | ||
env["sale.order.line"].search([ | ||
("product_template_id.attribute_line_ids", "!=", []), | ||
])._compute_all_product_template_attribute_value_ids() | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,7 @@ | ||
This module was developed because there is no way to know what Product Attribute Values has been used on a product if there is only one attribute configured in the product with "Never create variants" mode. | ||
|
||
It will be useful for you if you want to know which Product Attribute Values has been used in which Sale Order Lines. | ||
|
||
If you need this module for those reasons, these might interest you too: | ||
|
||
- sale_order_line_menu |
1 change: 1 addition & 0 deletions
1
sale_order_line_product_attribute_values/readme/CONTRIBUTORS.md
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
- Eduardo de Miguel ([Moduon](https://www.moduon.team/)) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
This module extends the functionality of Sale Order Lines to support view and filter by Product Attribute Values used. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,8 @@ | ||
To use this module, you need to: | ||
|
||
1. Create an Attribute called "Trademark" (for example) with Display Type "Pills", Variants Creation Mode "Never" and add an Attribute Value called "Adidas" | ||
2. Create a product called "Shoe Adidas REF 123" and "Show Adidas REF 456" | ||
3. Add "Trademark: Adidas" on Attributes & Variants tab on both products and configure (you can set an incremented price if you want) | ||
4. Sell both products in a Sale Order | ||
5. Created Sale Order Lines has Product Template Attribute Values and Attribute Values its lines. | ||
6. If you has installed `sale_order_line_menu`, you can check those values on Sale > Orders > Order Lines. |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Oops, something went wrong.