añadido product_secuence y product_code_unique para crear secuencias de productos por categoría
related 6
This commit is contained in:
parent
46d66821ec
commit
4fe2e3d368
73 changed files with 5643 additions and 0 deletions
64
product_code_unique/README.rst
Normal file
64
product_code_unique/README.rst
Normal file
|
@ -0,0 +1,64 @@
|
|||
.. image:: https://img.shields.io/badge/licence-AGPL--3-blue.svg
|
||||
:target: http://www.gnu.org/licenses/agpl-3.0-standalone.html
|
||||
:alt: License: AGPL-3
|
||||
|
||||
=================================
|
||||
Unique Product Internal Reference
|
||||
=================================
|
||||
|
||||
This module adds a constraint on the internal reference of the product
|
||||
to make it unique across the database.
|
||||
|
||||
Usage
|
||||
=====
|
||||
* Unable to save a product when a new internal reference or default_code value is
|
||||
the same with an existing record.
|
||||
* A pre_init_hook process is initiated when there exist records without an internal reference(default_code).
|
||||
A default value is generated to populate empty field as a temporary value.
|
||||
|
||||
.. image:: https://odoo-community.org/website/image/ir.attachment/5784_f2813bd/datas
|
||||
:alt: Try me on Runbot
|
||||
:target: https://runbot.odoo-community.org/runbot/135/11.0
|
||||
|
||||
Bug Tracker
|
||||
===========
|
||||
|
||||
Bugs are tracked on `GitHub Issues
|
||||
<https://github.com/OCA/product-attribute/issues>`_. In case of trouble, please
|
||||
check there if your issue has already been reported. If you spotted it first,
|
||||
help us smash it by providing detailed and welcomed feedback.
|
||||
|
||||
Credits
|
||||
=======
|
||||
|
||||
Images
|
||||
------
|
||||
|
||||
* Odoo Community Association: `Icon <https://github.com/OCA/maintainer-tools/blob/master/template/module/static/description/icon.svg>`_.
|
||||
|
||||
Contributors
|
||||
------------
|
||||
|
||||
* Antonio Yamuta <ayamuta@opensourceintegrators.com>
|
||||
|
||||
Funders
|
||||
-------
|
||||
|
||||
The development of this module has been financially supported by:
|
||||
|
||||
* Open Source Integrators <http://www.opensourceintegrators.com>
|
||||
|
||||
Maintainer
|
||||
----------
|
||||
|
||||
.. image:: https://odoo-community.org/logo.png
|
||||
:alt: Odoo Community Association
|
||||
:target: https://odoo-community.org
|
||||
|
||||
This module is maintained by the OCA.
|
||||
|
||||
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.
|
||||
|
||||
To contribute to this module, please visit https://odoo-community.org.
|
5
product_code_unique/__init__.py
Normal file
5
product_code_unique/__init__.py
Normal file
|
@ -0,0 +1,5 @@
|
|||
# Copyright (C) 2018 - TODAY, Open Source Integrators
|
||||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
||||
|
||||
from . import models
|
||||
from .hook import pre_init_product_code
|
15
product_code_unique/__manifest__.py
Normal file
15
product_code_unique/__manifest__.py
Normal file
|
@ -0,0 +1,15 @@
|
|||
# Copyright (C) 2018 - TODAY, Open Source Integrators
|
||||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
||||
|
||||
{
|
||||
"name": "Unique Product Internal Reference",
|
||||
"summary": "Set Product Internal Reference as Unique",
|
||||
"version": "12.0.1.0.0",
|
||||
"license": "AGPL-3",
|
||||
"author": "Open Source Integrators, Odoo Community Association (OCA)",
|
||||
"category": "Product",
|
||||
"website": "https://github.com/OCA/product-attribute",
|
||||
"depends": ["product"],
|
||||
"pre_init_hook": 'pre_init_product_code',
|
||||
"installable": True,
|
||||
}
|
17
product_code_unique/hook.py
Normal file
17
product_code_unique/hook.py
Normal file
|
@ -0,0 +1,17 @@
|
|||
# Copyright (C) 2019 - TODAY, Open Source Integrators
|
||||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
||||
|
||||
|
||||
def pre_init_product_code(cr):
|
||||
cr.execute("""UPDATE product_product
|
||||
SET default_code = 'DEFAULT' || nextval('ir_default_id_seq')
|
||||
WHERE id in (SELECT distinct(pp.id)
|
||||
FROM product_product pp
|
||||
INNER JOIN (SELECT default_code, COUNT(*)
|
||||
FROM product_product
|
||||
GROUP BY default_code
|
||||
HAVING COUNT(*)>1
|
||||
)pp1 on pp.default_code=pp1.default_code
|
||||
or pp.default_code is NULL
|
||||
or LENGTH(pp.default_code) = 0)""")
|
||||
return True
|
27
product_code_unique/i18n/ca.po
Normal file
27
product_code_unique/i18n/ca.po
Normal file
|
@ -0,0 +1,27 @@
|
|||
# Translation of Odoo Server.
|
||||
# This file contains the translation of the following modules:
|
||||
# * product_code_unique
|
||||
#
|
||||
msgid ""
|
||||
msgstr ""
|
||||
"Project-Id-Version: Odoo Server 12.0\n"
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"PO-Revision-Date: 2021-01-26 10:44+0000\n"
|
||||
"Last-Translator: claudiagn <claudia.gargallo@qubiq.es>\n"
|
||||
"Language-Team: none\n"
|
||||
"Language: ca\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.3.2\n"
|
||||
|
||||
#. module: product_code_unique
|
||||
#: sql_constraint:product.product:0
|
||||
msgid "Internal Reference must be unique across the database!"
|
||||
msgstr "La referència interna ha de ser única a tota la base de dades!"
|
||||
|
||||
#. module: product_code_unique
|
||||
#: model:ir.model,name:product_code_unique.model_product_product
|
||||
msgid "Product"
|
||||
msgstr "Producte"
|
27
product_code_unique/i18n/es.po
Normal file
27
product_code_unique/i18n/es.po
Normal file
|
@ -0,0 +1,27 @@
|
|||
# Translation of Odoo Server.
|
||||
# This file contains the translation of the following modules:
|
||||
# * product_code_unique
|
||||
#
|
||||
msgid ""
|
||||
msgstr ""
|
||||
"Project-Id-Version: Odoo Server 12.0\n"
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"PO-Revision-Date: 2020-10-13 13:08+0000\n"
|
||||
"Last-Translator: claudiagn <claudia.gargallo@qubiq.es>\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 3.10\n"
|
||||
|
||||
#. module: product_code_unique
|
||||
#: sql_constraint:product.product:0
|
||||
msgid "Internal Reference must be unique across the database!"
|
||||
msgstr "La referencia interna debe ser única por base de datos!"
|
||||
|
||||
#. module: product_code_unique
|
||||
#: model:ir.model,name:product_code_unique.model_product_product
|
||||
msgid "Product"
|
||||
msgstr "Producto"
|
27
product_code_unique/i18n/it.po
Normal file
27
product_code_unique/i18n/it.po
Normal file
|
@ -0,0 +1,27 @@
|
|||
# Translation of Odoo Server.
|
||||
# This file contains the translation of the following modules:
|
||||
# * product_code_unique
|
||||
#
|
||||
msgid ""
|
||||
msgstr ""
|
||||
"Project-Id-Version: Odoo Server 12.0\n"
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"PO-Revision-Date: 2020-02-20 14:13+0000\n"
|
||||
"Last-Translator: Lorenzo Battistini <lb@takobi.online>\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 3.10\n"
|
||||
|
||||
#. module: product_code_unique
|
||||
#: sql_constraint:product.product:0
|
||||
msgid "Internal Reference must be unique across the database!"
|
||||
msgstr "Il riferimento interno deve essere unico all'interno del database!"
|
||||
|
||||
#. module: product_code_unique
|
||||
#: model:ir.model,name:product_code_unique.model_product_product
|
||||
msgid "Product"
|
||||
msgstr "Prodotto"
|
27
product_code_unique/i18n/pt.po
Normal file
27
product_code_unique/i18n/pt.po
Normal file
|
@ -0,0 +1,27 @@
|
|||
# Translation of Odoo Server.
|
||||
# This file contains the translation of the following modules:
|
||||
# * product_code_unique
|
||||
#
|
||||
msgid ""
|
||||
msgstr ""
|
||||
"Project-Id-Version: Odoo Server 12.0\n"
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"PO-Revision-Date: 2020-10-18 21:08+0000\n"
|
||||
"Last-Translator: Pedro Castro Silva <pedrocs@exo.pt>\n"
|
||||
"Language-Team: none\n"
|
||||
"Language: pt\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 3.10\n"
|
||||
|
||||
#. module: product_code_unique
|
||||
#: sql_constraint:product.product:0
|
||||
msgid "Internal Reference must be unique across the database!"
|
||||
msgstr "A Referência Interna deve ser única em toda a base de dados!"
|
||||
|
||||
#. module: product_code_unique
|
||||
#: model:ir.model,name:product_code_unique.model_product_product
|
||||
msgid "Product"
|
||||
msgstr "Produto"
|
27
product_code_unique/i18n/pt_BR.po
Normal file
27
product_code_unique/i18n/pt_BR.po
Normal file
|
@ -0,0 +1,27 @@
|
|||
# Translation of Odoo Server.
|
||||
# This file contains the translation of the following modules:
|
||||
# * product_code_unique
|
||||
#
|
||||
msgid ""
|
||||
msgstr ""
|
||||
"Project-Id-Version: Odoo Server 12.0\n"
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"PO-Revision-Date: 2020-06-16 13:19+0000\n"
|
||||
"Last-Translator: Maurício Liell <mauricio@liell.com.br>\n"
|
||||
"Language-Team: none\n"
|
||||
"Language: pt_BR\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 3.10\n"
|
||||
|
||||
#. module: product_code_unique
|
||||
#: sql_constraint:product.product:0
|
||||
msgid "Internal Reference must be unique across the database!"
|
||||
msgstr "A Referência Interna deve ser única no banco de dados!"
|
||||
|
||||
#. module: product_code_unique
|
||||
#: model:ir.model,name:product_code_unique.model_product_product
|
||||
msgid "Product"
|
||||
msgstr "Produto"
|
27
product_code_unique/i18n/sk.po
Normal file
27
product_code_unique/i18n/sk.po
Normal file
|
@ -0,0 +1,27 @@
|
|||
# Translation of Odoo Server.
|
||||
# This file contains the translation of the following modules:
|
||||
# * product_code_unique
|
||||
#
|
||||
msgid ""
|
||||
msgstr ""
|
||||
"Project-Id-Version: Odoo Server 12.0\n"
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"PO-Revision-Date: 2020-07-03 21:19+0000\n"
|
||||
"Last-Translator: Jan Prokop <jprokop@jackie.sk>\n"
|
||||
"Language-Team: none\n"
|
||||
"Language: sk\n"
|
||||
"MIME-Version: 1.0\n"
|
||||
"Content-Type: text/plain; charset=UTF-8\n"
|
||||
"Content-Transfer-Encoding: \n"
|
||||
"Plural-Forms: nplurals=3; plural=(n==1) ? 0 : (n>=2 && n<=4) ? 1 : 2;\n"
|
||||
"X-Generator: Weblate 3.10\n"
|
||||
|
||||
#. module: product_code_unique
|
||||
#: sql_constraint:product.product:0
|
||||
msgid "Internal Reference must be unique across the database!"
|
||||
msgstr "Interná referencia musí byť jedinečná v celej databáze!"
|
||||
|
||||
#. module: product_code_unique
|
||||
#: model:ir.model,name:product_code_unique.model_product_product
|
||||
msgid "Product"
|
||||
msgstr "Produkt"
|
27
product_code_unique/i18n/sk_SK.po
Normal file
27
product_code_unique/i18n/sk_SK.po
Normal file
|
@ -0,0 +1,27 @@
|
|||
# Translation of Odoo Server.
|
||||
# This file contains the translation of the following modules:
|
||||
# * product_code_unique
|
||||
#
|
||||
msgid ""
|
||||
msgstr ""
|
||||
"Project-Id-Version: Odoo Server 12.0\n"
|
||||
"Report-Msgid-Bugs-To: \n"
|
||||
"PO-Revision-Date: 2020-07-02 14:19+0000\n"
|
||||
"Last-Translator: Jan Prokop <jprokop@jackie.sk>\n"
|
||||
"Language-Team: none\n"
|
||||
"Language: sk_SK\n"
|
||||
"MIME-Version: 1.0\n"
|
||||
"Content-Type: text/plain; charset=UTF-8\n"
|
||||
"Content-Transfer-Encoding: \n"
|
||||
"Plural-Forms: nplurals=3; plural=(n==1) ? 0 : (n>=2 && n<=4) ? 1 : 2;\n"
|
||||
"X-Generator: Weblate 3.10\n"
|
||||
|
||||
#. module: product_code_unique
|
||||
#: sql_constraint:product.product:0
|
||||
msgid "Internal Reference must be unique across the database!"
|
||||
msgstr "Interná referencia musí byť jedinečná v celej databáze!"
|
||||
|
||||
#. module: product_code_unique
|
||||
#: model:ir.model,name:product_code_unique.model_product_product
|
||||
msgid "Product"
|
||||
msgstr "Produkt"
|
4
product_code_unique/models/__init__.py
Normal file
4
product_code_unique/models/__init__.py
Normal file
|
@ -0,0 +1,4 @@
|
|||
# Copyright (C) 2018 - TODAY, Open Source Integrators
|
||||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
||||
|
||||
from . import product
|
12
product_code_unique/models/product.py
Normal file
12
product_code_unique/models/product.py
Normal file
|
@ -0,0 +1,12 @@
|
|||
# Copyright (C) 2018 - TODAY, Open Source Integrators
|
||||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
|
||||
|
||||
from odoo import models
|
||||
|
||||
|
||||
class ProductProduct(models.Model):
|
||||
_inherit = 'product.product'
|
||||
|
||||
_sql_constraints = [
|
||||
('default_code_uniq', 'unique(default_code)',
|
||||
'Internal Reference must be unique across the database!'), ]
|
BIN
product_code_unique/static/description/icon.png
Normal file
BIN
product_code_unique/static/description/icon.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 9.2 KiB |
Loading…
Add table
Add a link
Reference in a new issue