Skip to content

Commit

Permalink
[ADD] sale_order_line_product_attribute_values
Browse files Browse the repository at this point in the history
  • Loading branch information
Shide committed Nov 29, 2024
1 parent e427667 commit 6c91fb7
Show file tree
Hide file tree
Showing 19 changed files with 1,142 additions and 0 deletions.
141 changes: 141 additions & 0 deletions sale_order_line_product_attribute_values/README.rst
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.
1 change: 1 addition & 0 deletions sale_order_line_product_attribute_values/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
from . import models
22 changes: 22 additions & 0 deletions sale_order_line_product_attribute_values/__manifest__.py
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",
],
}
63 changes: 63 additions & 0 deletions sale_order_line_product_attribute_values/i18n/es.po
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"
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 ""
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
from . import sale_order_line
70 changes: 70 additions & 0 deletions sale_order_line_product_attribute_values/models/sale_order_line.py
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 sale_order_line_product_attribute_values/readme/CONFIGURE.md
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()
```
7 changes: 7 additions & 0 deletions sale_order_line_product_attribute_values/readme/CONTEXT.md
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
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
- Eduardo de Miguel ([Moduon](https://www.moduon.team/))
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.
8 changes: 8 additions & 0 deletions sale_order_line_product_attribute_values/readme/USAGE.md
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.
Loading

0 comments on commit 6c91fb7

Please sign in to comment.