From ed21e4cbaa12f47bea7287037f2dd1e81b47dee7 Mon Sep 17 00:00:00 2001 From: ps-tubtim Date: Sun, 24 Oct 2021 00:15:12 +0700 Subject: [PATCH 01/20] [14.0][ADD] stock_picking_tier_validation --- stock_picking_tier_validation/README.rst | 111 +++++ stock_picking_tier_validation/__init__.py | 3 + stock_picking_tier_validation/__manifest__.py | 17 + .../models/__init__.py | 4 + .../models/stock_picking.py | 33 ++ .../models/tier_definition.py | 14 + .../readme/CONFIGURE.rst | 4 + .../readme/CONTRIBUTORS.rst | 3 + .../readme/DESCRIPTION.rst | 1 + .../readme/INSTALL.rst | 2 + .../readme/USAGE.rst | 13 + .../static/description/icon.png | Bin 0 -> 9455 bytes .../static/description/index.html | 461 ++++++++++++++++++ .../tests/__init__.py | 4 + stock_picking_tier_validation/tests/common.py | 20 + .../tests/test_tier_validation.py | 65 +++ .../tests/tier_validation_tester.py | 24 + .../views/stock_picking_views.xml | 25 + 18 files changed, 804 insertions(+) create mode 100644 stock_picking_tier_validation/README.rst create mode 100644 stock_picking_tier_validation/__init__.py create mode 100644 stock_picking_tier_validation/__manifest__.py create mode 100644 stock_picking_tier_validation/models/__init__.py create mode 100644 stock_picking_tier_validation/models/stock_picking.py create mode 100644 stock_picking_tier_validation/models/tier_definition.py create mode 100644 stock_picking_tier_validation/readme/CONFIGURE.rst create mode 100644 stock_picking_tier_validation/readme/CONTRIBUTORS.rst create mode 100644 stock_picking_tier_validation/readme/DESCRIPTION.rst create mode 100644 stock_picking_tier_validation/readme/INSTALL.rst create mode 100644 stock_picking_tier_validation/readme/USAGE.rst create mode 100644 stock_picking_tier_validation/static/description/icon.png create mode 100644 stock_picking_tier_validation/static/description/index.html create mode 100644 stock_picking_tier_validation/tests/__init__.py create mode 100644 stock_picking_tier_validation/tests/common.py create mode 100644 stock_picking_tier_validation/tests/test_tier_validation.py create mode 100644 stock_picking_tier_validation/tests/tier_validation_tester.py create mode 100644 stock_picking_tier_validation/views/stock_picking_views.xml diff --git a/stock_picking_tier_validation/README.rst b/stock_picking_tier_validation/README.rst new file mode 100644 index 0000000..6e5a7c4 --- /dev/null +++ b/stock_picking_tier_validation/README.rst @@ -0,0 +1,111 @@ +============================= +Stock Picking Tier Validation +============================= + +.. !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + !! This file is generated by oca-gen-addon-readme !! + !! changes will be overwritten. !! + !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + +.. |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-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%2Fstock--logistics--workflow-lightgray.png?logo=github + :target: https://github.com/OCA/stock-logistics-workflow/tree/14.0/stock_picking_tier_validation + :alt: OCA/stock-logistics-workflow +.. |badge4| image:: https://img.shields.io/badge/weblate-Translate%20me-F47D42.png + :target: https://translation.odoo-community.org/projects/stock-logistics-workflow-14-0/stock-logistics-workflow-14-0-stock_picking_tier_validation + :alt: Translate me on Weblate +.. |badge5| image:: https://img.shields.io/badge/runbot-Try%20me-875A7B.png + :target: https://runbot.odoo-community.org/runbot/154/14.0 + :alt: Try me on Runbot + +|badge1| |badge2| |badge3| |badge4| |badge5| + +This module extends the functionality of Transfers to support a tier validation process. + +.. 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 `_ + +**Table of contents** + +.. contents:: + :local: + +Installation +============ + +This module depends on ``base_tier_validation``. You can find it at +`OCA/server-ux `_ + +Configuration +============= + +To configure this module, you need to: + +#. Go to *Settings > Technical > Tier Validations > Tier Definition*. +#. Create as many tiers as you want for Transfer model. + +Usage +===== + +To use this module, you need to: + +#. Create a Transfer triggering at least one "Tier Definition". +#. Click on *Request Validation* button. +#. Under the tab *Reviews* have a look to pending reviews and their statuses. +#. Once all reviews are validated click on *Validate*. + +Additional features: + +* You can filter the Transfers requesting your review through the filter *Needs my Review*. +* User with rights to validate the Transfer (validate all tiers that would + be generated) can directly do the operation, this is, there is no need for + her/him to request a validation. + +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 `_. + +Do not contact contributors directly about support or help with technical issues. + +Credits +======= + +Authors +~~~~~~~ + +* Ecosoft + +Contributors +~~~~~~~~~~~~ + +* `Ecosoft `__: + + * Pimolnat Suntian + +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/stock-logistics-workflow `_ project on GitHub. + +You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute. diff --git a/stock_picking_tier_validation/__init__.py b/stock_picking_tier_validation/__init__.py new file mode 100644 index 0000000..31660d6 --- /dev/null +++ b/stock_picking_tier_validation/__init__.py @@ -0,0 +1,3 @@ +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl). + +from . import models diff --git a/stock_picking_tier_validation/__manifest__.py b/stock_picking_tier_validation/__manifest__.py new file mode 100644 index 0000000..b9320ac --- /dev/null +++ b/stock_picking_tier_validation/__manifest__.py @@ -0,0 +1,17 @@ +# Copyright 2021 Ecosoft Co., Ltd. (http://ecosoft.co.th) +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl). + +{ + "name": "Stock Picking Tier Validation", + "summary": "Extends the functionality of Transfers to " + "support a tier validation process.", + "version": "14.0.1.0.0", + "category": "Warehouse Management", + "website": "https://github.com/OCA/stock-logistics-workflow", + "author": "Ecosoft, Odoo Community Association (OCA)", + "license": "AGPL-3", + "depends": ["stock", "base_tier_validation"], + "data": ["views/stock_picking_views.xml"], + "installable": True, + "development_status": "Alpha", +} diff --git a/stock_picking_tier_validation/models/__init__.py b/stock_picking_tier_validation/models/__init__.py new file mode 100644 index 0000000..ef70a17 --- /dev/null +++ b/stock_picking_tier_validation/models/__init__.py @@ -0,0 +1,4 @@ +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl). + +from . import stock_picking +from . import tier_definition diff --git a/stock_picking_tier_validation/models/stock_picking.py b/stock_picking_tier_validation/models/stock_picking.py new file mode 100644 index 0000000..713a7d9 --- /dev/null +++ b/stock_picking_tier_validation/models/stock_picking.py @@ -0,0 +1,33 @@ +# Copyright 2021 Ecosoft Co., Ltd. (http://ecosoft.co.th) +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl). + +from odoo import _, models +from odoo.exceptions import ValidationError + + +class StockPicking(models.Model): + _name = "stock.picking" + _inherit = ["stock.picking", "tier.validation"] + _state_from = ["draft", "waiting", "confirmed", "assigned"] + _state_to = ["done", "approved"] + + _tier_validation_manual_config = False + + def button_validate(self): + for rec in self: + if rec.need_validation: + # try to validate operation + reviews = rec.request_validation() + rec._validate_tier(reviews) + if not self._calc_reviews_validated(reviews): + raise ValidationError( + _( + "This action needs to be validated for at least " + "one record. \nPlease request a validation." + ) + ) + if rec.review_ids and not rec.validated: + raise ValidationError( + _("A validation process is still open for at least one record.") + ) + return super().button_validate() diff --git a/stock_picking_tier_validation/models/tier_definition.py b/stock_picking_tier_validation/models/tier_definition.py new file mode 100644 index 0000000..b2ea390 --- /dev/null +++ b/stock_picking_tier_validation/models/tier_definition.py @@ -0,0 +1,14 @@ +# Copyright 2021 Ecosoft Co., Ltd. (http://ecosoft.co.th) +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl). + +from odoo import api, models + + +class TierDefinition(models.Model): + _inherit = "tier.definition" + + @api.model + def _get_tier_validation_model_names(self): + res = super()._get_tier_validation_model_names() + res.append("stock.picking") + return res diff --git a/stock_picking_tier_validation/readme/CONFIGURE.rst b/stock_picking_tier_validation/readme/CONFIGURE.rst new file mode 100644 index 0000000..3d78df8 --- /dev/null +++ b/stock_picking_tier_validation/readme/CONFIGURE.rst @@ -0,0 +1,4 @@ +To configure this module, you need to: + +#. Go to *Settings > Technical > Tier Validations > Tier Definition*. +#. Create as many tiers as you want for Transfer model. diff --git a/stock_picking_tier_validation/readme/CONTRIBUTORS.rst b/stock_picking_tier_validation/readme/CONTRIBUTORS.rst new file mode 100644 index 0000000..ea63aa7 --- /dev/null +++ b/stock_picking_tier_validation/readme/CONTRIBUTORS.rst @@ -0,0 +1,3 @@ +* `Ecosoft `__: + + * Pimolnat Suntian diff --git a/stock_picking_tier_validation/readme/DESCRIPTION.rst b/stock_picking_tier_validation/readme/DESCRIPTION.rst new file mode 100644 index 0000000..9da1386 --- /dev/null +++ b/stock_picking_tier_validation/readme/DESCRIPTION.rst @@ -0,0 +1 @@ +This module extends the functionality of Transfers to support a tier validation process. diff --git a/stock_picking_tier_validation/readme/INSTALL.rst b/stock_picking_tier_validation/readme/INSTALL.rst new file mode 100644 index 0000000..638fbd2 --- /dev/null +++ b/stock_picking_tier_validation/readme/INSTALL.rst @@ -0,0 +1,2 @@ +This module depends on ``base_tier_validation``. You can find it at +`OCA/server-ux `_ diff --git a/stock_picking_tier_validation/readme/USAGE.rst b/stock_picking_tier_validation/readme/USAGE.rst new file mode 100644 index 0000000..af07587 --- /dev/null +++ b/stock_picking_tier_validation/readme/USAGE.rst @@ -0,0 +1,13 @@ +To use this module, you need to: + +#. Create a Transfer triggering at least one "Tier Definition". +#. Click on *Request Validation* button. +#. Under the tab *Reviews* have a look to pending reviews and their statuses. +#. Once all reviews are validated click on *Validate*. + +Additional features: + +* You can filter the Transfers requesting your review through the filter *Needs my Review*. +* User with rights to validate the Transfer (validate all tiers that would + be generated) can directly do the operation, this is, there is no need for + her/him to request a validation. diff --git a/stock_picking_tier_validation/static/description/icon.png b/stock_picking_tier_validation/static/description/icon.png new file mode 100644 index 0000000000000000000000000000000000000000..3a0328b516c4980e8e44cdb63fd945757ddd132d GIT binary patch literal 9455 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 z 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 Xviia!U7SGha1wx#SCgwmn*{w2TRX*I literal 0 HcmV?d00001 diff --git a/stock_picking_tier_validation/static/description/index.html b/stock_picking_tier_validation/static/description/index.html new file mode 100644 index 0000000..fabcc03 --- /dev/null +++ b/stock_picking_tier_validation/static/description/index.html @@ -0,0 +1,461 @@ + + + + + + +Stock Picking Tier Validation + + + +
+

Stock Picking Tier Validation

+ + +

Alpha License: AGPL-3 OCA/stock-logistics-workflow Translate me on Weblate Try me on Runbot

+

This module extends the functionality of Transfers to support a tier validation process.

+
+

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

+
+

Table of contents

+ +
+

Installation

+

This module depends on base_tier_validation. You can find it at +OCA/server-ux

+
+
+

Configuration

+

To configure this module, you need to:

+
    +
  1. Go to Settings > Technical > Tier Validations > Tier Definition.
  2. +
  3. Create as many tiers as you want for Transfer model.
  4. +
+
+
+

Usage

+

To use this module, you need to:

+
    +
  1. Create a Transfer triggering at least one “Tier Definition”.
  2. +
  3. Click on Request Validation button.
  4. +
  5. Under the tab Reviews have a look to pending reviews and their statuses.
  6. +
  7. Once all reviews are validated click on Validate.
  8. +
+

Additional features:

+
    +
  • You can filter the Transfers requesting your review through the filter Needs my Review.
  • +
  • User with rights to validate the Transfer (validate all tiers that would +be generated) can directly do the operation, this is, there is no need for +her/him to request a validation.
  • +
+
+
+

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.

+

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

+
+
+

Credits

+
+

Authors

+
    +
  • Ecosoft
  • +
+
+
+

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/stock-logistics-workflow project on GitHub.

+

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

+
+
+
+ + diff --git a/stock_picking_tier_validation/tests/__init__.py b/stock_picking_tier_validation/tests/__init__.py new file mode 100644 index 0000000..c5d19b1 --- /dev/null +++ b/stock_picking_tier_validation/tests/__init__.py @@ -0,0 +1,4 @@ +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl). + +from . import common +from . import test_tier_validation diff --git a/stock_picking_tier_validation/tests/common.py b/stock_picking_tier_validation/tests/common.py new file mode 100644 index 0000000..bdc1c68 --- /dev/null +++ b/stock_picking_tier_validation/tests/common.py @@ -0,0 +1,20 @@ +# Copyright 2021 Ecosoft Co., Ltd. (http://ecosoft.co.th) +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl). + + +def setup_test_model(env, model_clses): + for model_cls in model_clses: + model_cls._build_model(env.registry, env.cr) + + env.registry.setup_models(env.cr) + env.registry.init_models( + env.cr, + [model_cls._name for model_cls in model_clses], + dict(env.context, update_custom_fields=True), + ) + + +def teardown_test_model(env, model_clses): + for model_cls in model_clses: + del env.registry.models[model_cls._name] + env.registry.setup_models(env.cr) diff --git a/stock_picking_tier_validation/tests/test_tier_validation.py b/stock_picking_tier_validation/tests/test_tier_validation.py new file mode 100644 index 0000000..06843c8 --- /dev/null +++ b/stock_picking_tier_validation/tests/test_tier_validation.py @@ -0,0 +1,65 @@ +# Copyright 2021 Ecosoft Co., Ltd. (http://ecosoft.co.th) +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl). + +from odoo.tests import common +from odoo.tests.common import tagged + +from .common import setup_test_model, teardown_test_model +from .tier_validation_tester import TierValidationTester + + +@tagged("post_install", "-at_install") +class TestStockPickingTierValidation(common.SavepointCase): + @classmethod + def setUpClass(cls): + super(TestStockPickingTierValidation, cls).setUpClass() + + setup_test_model(cls.env, [TierValidationTester]) + + cls.test_model = cls.env[TierValidationTester._name] + + cls.tester_model = cls.env["ir.model"].search( + [("model", "=", "tier.validation.tester")] + ) + + # Access record: + cls.env["ir.model.access"].create( + { + "name": "access.tester", + "model_id": cls.tester_model.id, + "perm_read": 1, + "perm_write": 1, + "perm_create": 1, + "perm_unlink": 1, + } + ) + + # Create users: + group_ids = cls.env.ref("base.group_system").ids + cls.test_user_1 = cls.env["res.users"].create( + {"name": "John", "login": "test1", "groups_id": [(6, 0, group_ids)]} + ) + + # Create tier definitions: + cls.tier_def_obj = cls.env["tier.definition"] + cls.tier_def_obj.create( + { + "model_id": cls.tester_model.id, + "review_type": "individual", + "reviewer_id": cls.test_user_1.id, + "definition_domain": "[('test_field', '>', 1.0)]", + } + ) + + cls.test_record = cls.test_model.create({"test_field": 2.5}) + + @classmethod + def tearDownClass(cls): + teardown_test_model(cls.env, [TierValidationTester]) + super(TestStockPickingTierValidation, cls).tearDownClass() + + def test_01_tier_definition_models(self): + """When the user can validate all future reviews, it is not needed + to request a validation, the action can be done straight forward.""" + res = self.tier_def_obj._get_tier_validation_model_names() + self.assertIn("stock.picking", res) diff --git a/stock_picking_tier_validation/tests/tier_validation_tester.py b/stock_picking_tier_validation/tests/tier_validation_tester.py new file mode 100644 index 0000000..1f39ba7 --- /dev/null +++ b/stock_picking_tier_validation/tests/tier_validation_tester.py @@ -0,0 +1,24 @@ +# Copyright 2021 Ecosoft Co., Ltd. (http://ecosoft.co.th) +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl). + +from odoo import fields, models + + +class TierValidationTester(models.Model): + _name = "tier.validation.tester" + _description = "Tier Validation Tester" + _inherit = ["tier.validation"] + + state = fields.Selection( + selection=[ + ("draft", "Draft"), + ("confirmed", "Confirmed"), + ("cancel", "Cancel"), + ], + default="draft", + ) + test_field = fields.Float() + user_id = fields.Many2one(string="Assigned to:", comodel_name="res.users") + + def action_confirm(self): + self.write({"state": "confirmed"}) diff --git a/stock_picking_tier_validation/views/stock_picking_views.xml b/stock_picking_tier_validation/views/stock_picking_views.xml new file mode 100644 index 0000000..017d82e --- /dev/null +++ b/stock_picking_tier_validation/views/stock_picking_views.xml @@ -0,0 +1,25 @@ + + + + stock.picking.internal.search + stock.picking + + + + + + + + + + From 9c3577ff4073edda7202a5b0f62d35571ca99f4f Mon Sep 17 00:00:00 2001 From: oca-ci Date: Wed, 10 Aug 2022 21:59:46 +0000 Subject: [PATCH 02/20] [UPD] Update stock_picking_tier_validation.pot --- .../i18n/stock_picking_tier_validation.pot | 127 ++++++++++++++++++ 1 file changed, 127 insertions(+) create mode 100644 stock_picking_tier_validation/i18n/stock_picking_tier_validation.pot diff --git a/stock_picking_tier_validation/i18n/stock_picking_tier_validation.pot b/stock_picking_tier_validation/i18n/stock_picking_tier_validation.pot new file mode 100644 index 0000000..c77fa9e --- /dev/null +++ b/stock_picking_tier_validation/i18n/stock_picking_tier_validation.pot @@ -0,0 +1,127 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * stock_picking_tier_validation +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 14.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: stock_picking_tier_validation +#: code:addons/stock_picking_tier_validation/models/stock_picking.py:0 +#, python-format +msgid "A validation process is still open for at least one record." +msgstr "" + +#. module: stock_picking_tier_validation +#: model:ir.model.fields,field_description:stock_picking_tier_validation.field_stock_picking__can_review +msgid "Can Review" +msgstr "" + +#. module: stock_picking_tier_validation +#: model:ir.model.fields,field_description:stock_picking_tier_validation.field_stock_picking__display_name +#: model:ir.model.fields,field_description:stock_picking_tier_validation.field_tier_definition__display_name +msgid "Display Name" +msgstr "" + +#. module: stock_picking_tier_validation +#: model:ir.model.fields,field_description:stock_picking_tier_validation.field_stock_picking__has_comment +msgid "Has Comment" +msgstr "" + +#. module: stock_picking_tier_validation +#: model:ir.model.fields,field_description:stock_picking_tier_validation.field_stock_picking__id +#: model:ir.model.fields,field_description:stock_picking_tier_validation.field_tier_definition__id +msgid "ID" +msgstr "" + +#. module: stock_picking_tier_validation +#: model:ir.model.fields,field_description:stock_picking_tier_validation.field_stock_picking____last_update +#: model:ir.model.fields,field_description:stock_picking_tier_validation.field_tier_definition____last_update +msgid "Last Modified on" +msgstr "" + +#. module: stock_picking_tier_validation +#: model:ir.model.fields,field_description:stock_picking_tier_validation.field_stock_picking__need_validation +msgid "Need Validation" +msgstr "" + +#. module: stock_picking_tier_validation +#: model_terms:ir.ui.view,arch_db:stock_picking_tier_validation.view_picking_internal_search +msgid "Needs my Review" +msgstr "" + +#. module: stock_picking_tier_validation +#: model:ir.model.fields,field_description:stock_picking_tier_validation.field_stock_picking__next_review +msgid "Next Review" +msgstr "" + +#. module: stock_picking_tier_validation +#: model:ir.model.fields,field_description:stock_picking_tier_validation.field_stock_picking__rejected +msgid "Rejected" +msgstr "" + +#. module: stock_picking_tier_validation +#: model:ir.model.fields,field_description:stock_picking_tier_validation.field_stock_picking__rejected_message +msgid "Rejected Message" +msgstr "" + +#. module: stock_picking_tier_validation +#: model:ir.model.fields,field_description:stock_picking_tier_validation.field_stock_picking__reviewer_ids +msgid "Reviewers" +msgstr "" + +#. module: stock_picking_tier_validation +#: code:addons/stock_picking_tier_validation/models/stock_picking.py:0 +#, python-format +msgid "" +"This action needs to be validated for at least one record. \n" +"Please request a validation." +msgstr "" + +#. module: stock_picking_tier_validation +#: model:ir.model,name:stock_picking_tier_validation.model_tier_definition +msgid "Tier Definition" +msgstr "" + +#. module: stock_picking_tier_validation +#: model:ir.model.fields,field_description:stock_picking_tier_validation.field_stock_picking__to_validate_message +msgid "To Validate Message" +msgstr "" + +#. module: stock_picking_tier_validation +#: model:ir.model,name:stock_picking_tier_validation.model_stock_picking +msgid "Transfer" +msgstr "" + +#. module: stock_picking_tier_validation +#: model_terms:ir.ui.view,arch_db:stock_picking_tier_validation.view_picking_internal_search +msgid "Transfers to review" +msgstr "" + +#. module: stock_picking_tier_validation +#: model_terms:ir.ui.view,arch_db:stock_picking_tier_validation.view_picking_internal_search +msgid "Transfers validated and ready to be done" +msgstr "" + +#. module: stock_picking_tier_validation +#: model:ir.model.fields,field_description:stock_picking_tier_validation.field_stock_picking__validated +#: model_terms:ir.ui.view,arch_db:stock_picking_tier_validation.view_picking_internal_search +msgid "Validated" +msgstr "" + +#. module: stock_picking_tier_validation +#: model:ir.model.fields,field_description:stock_picking_tier_validation.field_stock_picking__validated_message +msgid "Validated Message" +msgstr "" + +#. module: stock_picking_tier_validation +#: model:ir.model.fields,field_description:stock_picking_tier_validation.field_stock_picking__review_ids +msgid "Validations" +msgstr "" From 238f9e71a6dbda1df8fa6dc45bb2184afb579cc5 Mon Sep 17 00:00:00 2001 From: OCA-git-bot Date: Wed, 10 Aug 2022 22:05:22 +0000 Subject: [PATCH 03/20] [UPD] README.rst --- stock_picking_tier_validation/static/description/index.html | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/stock_picking_tier_validation/static/description/index.html b/stock_picking_tier_validation/static/description/index.html index fabcc03..ede12c2 100644 --- a/stock_picking_tier_validation/static/description/index.html +++ b/stock_picking_tier_validation/static/description/index.html @@ -3,7 +3,7 @@ - + Stock Picking Tier Validation -
-

Stock Picking Tier Validation

+
+ + +Odoo Community Association + +
+

Stock Picking Tier Validation

-

Alpha License: AGPL-3 OCA/stock-logistics-workflow Translate me on Weblate Try me on Runboat

+

Alpha License: AGPL-3 OCA/stock-logistics-workflow Translate me on Weblate Try me on Runboat

This module extends the functionality of Transfers to support a tier validation process.

@@ -394,12 +399,12 @@

Stock Picking Tier Validation

-

Installation

+

Installation

This module depends on base_tier_validation. You can find it at OCA/server-ux

-

Configuration

+

Configuration

To configure this module, you need to:

  1. Go to Settings > Technical > Tier Validations > Tier Definition.
  2. @@ -407,7 +412,7 @@

    Configuration

-

Usage

+

Usage

To use this module, you need to:

  1. Create a Transfer triggering at least one “Tier Definition”.
  2. @@ -426,7 +431,7 @@

    Usage

-

Bug Tracker

+

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 @@ -434,15 +439,15 @@

Bug Tracker

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

-

Credits

+

Credits

-

Authors

+

Authors

  • Ecosoft
-

Contributors

+

Contributors

-

Maintainers

+

Maintainers

This module is maintained by the OCA.

Odoo Community Association @@ -464,5 +469,6 @@

Maintainers

+
From 142f6b716826554b645915385753816915fdaf6b Mon Sep 17 00:00:00 2001 From: Weblate Date: Mon, 23 Jun 2025 06:55:07 +0000 Subject: [PATCH 14/20] Update translation files Updated by "Update PO files to match POT (msgmerge)" hook in Weblate. Translation: stock-logistics-workflow-18.0/stock-logistics-workflow-18.0-stock_picking_tier_validation Translate-URL: https://translation.odoo-community.org/projects/stock-logistics-workflow-18-0/stock-logistics-workflow-18-0-stock_picking_tier_validation/ --- stock_picking_tier_validation/i18n/it.po | 25 ++++++------------------ 1 file changed, 6 insertions(+), 19 deletions(-) diff --git a/stock_picking_tier_validation/i18n/it.po b/stock_picking_tier_validation/i18n/it.po index c4f75e3..2f2ed16 100644 --- a/stock_picking_tier_validation/i18n/it.po +++ b/stock_picking_tier_validation/i18n/it.po @@ -15,8 +15,8 @@ msgstr "" "Plural-Forms: nplurals=2; plural=n != 1;\n" #. module: stock_picking_tier_validation +#. odoo-python #: code:addons/stock_picking_tier_validation/models/stock_picking.py:0 -#, python-format msgid "A validation process is still open for at least one record." msgstr "" @@ -25,27 +25,19 @@ msgstr "" msgid "Can Review" msgstr "" -#. module: stock_picking_tier_validation -#: model:ir.model.fields,field_description:stock_picking_tier_validation.field_stock_picking__display_name -#: model:ir.model.fields,field_description:stock_picking_tier_validation.field_tier_definition__display_name -msgid "Display Name" -msgstr "" - #. module: stock_picking_tier_validation #: model:ir.model.fields,field_description:stock_picking_tier_validation.field_stock_picking__has_comment msgid "Has Comment" msgstr "" #. module: stock_picking_tier_validation -#: model:ir.model.fields,field_description:stock_picking_tier_validation.field_stock_picking__id -#: model:ir.model.fields,field_description:stock_picking_tier_validation.field_tier_definition__id -msgid "ID" +#: model:ir.model.fields,field_description:stock_picking_tier_validation.field_stock_picking__hide_reviews +msgid "Hide Reviews" msgstr "" #. module: stock_picking_tier_validation -#: model:ir.model.fields,field_description:stock_picking_tier_validation.field_stock_picking____last_update -#: model:ir.model.fields,field_description:stock_picking_tier_validation.field_tier_definition____last_update -msgid "Last Modified on" +#: model:ir.model.fields,help:stock_picking_tier_validation.field_stock_picking__has_comment +msgid "If set, Allow the reviewer to leave a comment on the review." msgstr "" #. module: stock_picking_tier_validation @@ -79,8 +71,8 @@ msgid "Reviewers" msgstr "" #. module: stock_picking_tier_validation +#. odoo-python #: code:addons/stock_picking_tier_validation/models/stock_picking.py:0 -#, python-format msgid "" "This action needs to be validated for at least one record. \n" "Please request a validation." @@ -91,11 +83,6 @@ msgstr "" msgid "Tier Definition" msgstr "" -#. module: stock_picking_tier_validation -#: model:ir.model.fields,field_description:stock_picking_tier_validation.field_stock_picking__tier_validation_before_write -msgid "Tier Validation Before Write" -msgstr "" - #. module: stock_picking_tier_validation #: model:ir.model.fields,field_description:stock_picking_tier_validation.field_stock_picking__to_validate_message msgid "To Validate Message" From dbf5d955753c321b4305b59616a1044b40512f87 Mon Sep 17 00:00:00 2001 From: mymage Date: Tue, 24 Jun 2025 07:05:18 +0000 Subject: [PATCH 15/20] Translated using Weblate (Italian) Currently translated at 100.0% (21 of 21 strings) Translation: stock-logistics-workflow-18.0/stock-logistics-workflow-18.0-stock_picking_tier_validation Translate-URL: https://translation.odoo-community.org/projects/stock-logistics-workflow-18-0/stock-logistics-workflow-18-0-stock_picking_tier_validation/it/ --- stock_picking_tier_validation/i18n/it.po | 45 +++++++++++++----------- 1 file changed, 25 insertions(+), 20 deletions(-) diff --git a/stock_picking_tier_validation/i18n/it.po b/stock_picking_tier_validation/i18n/it.po index 2f2ed16..9d71d34 100644 --- a/stock_picking_tier_validation/i18n/it.po +++ b/stock_picking_tier_validation/i18n/it.po @@ -6,69 +6,72 @@ msgid "" msgstr "" "Project-Id-Version: Odoo Server 14.0\n" "Report-Msgid-Bugs-To: \n" -"Last-Translator: Automatically generated\n" +"PO-Revision-Date: 2025-06-24 09:25+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 5.10.4\n" #. module: stock_picking_tier_validation #. odoo-python #: code:addons/stock_picking_tier_validation/models/stock_picking.py:0 msgid "A validation process is still open for at least one record." -msgstr "" +msgstr "Un processo di approvazione è ancora aperto per almeno un record." #. module: stock_picking_tier_validation #: model:ir.model.fields,field_description:stock_picking_tier_validation.field_stock_picking__can_review msgid "Can Review" -msgstr "" +msgstr "Può revisionare" #. module: stock_picking_tier_validation #: model:ir.model.fields,field_description:stock_picking_tier_validation.field_stock_picking__has_comment msgid "Has Comment" -msgstr "" +msgstr "Ha commenti" #. module: stock_picking_tier_validation #: model:ir.model.fields,field_description:stock_picking_tier_validation.field_stock_picking__hide_reviews msgid "Hide Reviews" -msgstr "" +msgstr "Nascondi revisioni" #. module: stock_picking_tier_validation #: model:ir.model.fields,help:stock_picking_tier_validation.field_stock_picking__has_comment msgid "If set, Allow the reviewer to leave a comment on the review." msgstr "" +"Se attivata, consente al revisore di lasciare un commento nella revisione." #. module: stock_picking_tier_validation #: model:ir.model.fields,field_description:stock_picking_tier_validation.field_stock_picking__need_validation msgid "Need Validation" -msgstr "" +msgstr "Richiede conferma" #. module: stock_picking_tier_validation #: model_terms:ir.ui.view,arch_db:stock_picking_tier_validation.view_picking_internal_search msgid "Needs my Review" -msgstr "" +msgstr "Richiede la mia revisione" #. module: stock_picking_tier_validation #: model:ir.model.fields,field_description:stock_picking_tier_validation.field_stock_picking__next_review msgid "Next Review" -msgstr "" +msgstr "Prossima revisione" #. module: stock_picking_tier_validation #: model:ir.model.fields,field_description:stock_picking_tier_validation.field_stock_picking__rejected msgid "Rejected" -msgstr "" +msgstr "Respinto" #. module: stock_picking_tier_validation #: model:ir.model.fields,field_description:stock_picking_tier_validation.field_stock_picking__rejected_message msgid "Rejected Message" -msgstr "" +msgstr "Messaggio di rifiuto" #. module: stock_picking_tier_validation #: model:ir.model.fields,field_description:stock_picking_tier_validation.field_stock_picking__reviewer_ids msgid "Reviewers" -msgstr "" +msgstr "Revisori" #. module: stock_picking_tier_validation #. odoo-python @@ -77,49 +80,51 @@ msgid "" "This action needs to be validated for at least one record. \n" "Please request a validation." msgstr "" +"Questa azione richiede di essere approvata per almeno un record.\n" +"Prego richiedere un'approvazione." #. module: stock_picking_tier_validation #: model:ir.model,name:stock_picking_tier_validation.model_tier_definition msgid "Tier Definition" -msgstr "" +msgstr "Definizione livello" #. module: stock_picking_tier_validation #: model:ir.model.fields,field_description:stock_picking_tier_validation.field_stock_picking__to_validate_message msgid "To Validate Message" -msgstr "" +msgstr "Messaggio per 'Da validare'" #. module: stock_picking_tier_validation #: model:ir.model,name:stock_picking_tier_validation.model_stock_picking msgid "Transfer" -msgstr "" +msgstr "Trasferimento" #. module: stock_picking_tier_validation #: model_terms:ir.ui.view,arch_db:stock_picking_tier_validation.view_picking_internal_search msgid "Transfers to review" -msgstr "" +msgstr "Trasferimenti da revisionare" #. module: stock_picking_tier_validation #: model_terms:ir.ui.view,arch_db:stock_picking_tier_validation.view_picking_internal_search msgid "Transfers validated and ready to be done" -msgstr "" +msgstr "Trasferimenti validati e pronti per essere eseguiti" #. module: stock_picking_tier_validation #: model:ir.model.fields,field_description:stock_picking_tier_validation.field_stock_picking__validated #: model_terms:ir.ui.view,arch_db:stock_picking_tier_validation.view_picking_internal_search msgid "Validated" -msgstr "" +msgstr "Validato" #. module: stock_picking_tier_validation #: model:ir.model.fields,field_description:stock_picking_tier_validation.field_stock_picking__validated_message msgid "Validated Message" -msgstr "" +msgstr "Messaggio per 'Validato'" #. module: stock_picking_tier_validation #: model:ir.model.fields,field_description:stock_picking_tier_validation.field_stock_picking__validation_status msgid "Validation Status" -msgstr "" +msgstr "Stato validazione" #. module: stock_picking_tier_validation #: model:ir.model.fields,field_description:stock_picking_tier_validation.field_stock_picking__review_ids msgid "Validations" -msgstr "" +msgstr "Validazioni" From 1d6b73cc7373aef46b778233a2df17956ac4446f Mon Sep 17 00:00:00 2001 From: "Pedro M. Baeza" Date: Tue, 12 Aug 2025 12:04:44 +0200 Subject: [PATCH 16/20] [FIX] stock_picking_tier_validation: Adapt to base change Method `_calc_reviews_validated` has been removed in OCA/server-ux#1138, so this commit adapts the needed changes to it. Fixes #2064 --- stock_picking_tier_validation/models/stock_picking.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/stock_picking_tier_validation/models/stock_picking.py b/stock_picking_tier_validation/models/stock_picking.py index 713a7d9..dbab5a8 100644 --- a/stock_picking_tier_validation/models/stock_picking.py +++ b/stock_picking_tier_validation/models/stock_picking.py @@ -19,7 +19,7 @@ def button_validate(self): # try to validate operation reviews = rec.request_validation() rec._validate_tier(reviews) - if not self._calc_reviews_validated(reviews): + if self.validation_status != "validated": raise ValidationError( _( "This action needs to be validated for at least " From d9c9dcd9862b9cb6c27022ed8280189a0ea72385 Mon Sep 17 00:00:00 2001 From: OCA-git-bot Date: Tue, 12 Aug 2025 10:19:37 +0000 Subject: [PATCH 17/20] [BOT] post-merge updates --- stock_picking_tier_validation/README.rst | 2 +- stock_picking_tier_validation/__manifest__.py | 2 +- stock_picking_tier_validation/static/description/index.html | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/stock_picking_tier_validation/README.rst b/stock_picking_tier_validation/README.rst index 5167aff..07d24a6 100644 --- a/stock_picking_tier_validation/README.rst +++ b/stock_picking_tier_validation/README.rst @@ -11,7 +11,7 @@ Stock Picking Tier Validation !! This file is generated by oca-gen-addon-readme !! !! changes will be overwritten. !! !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! - !! source digest: sha256:880227d58bee0630ee142da54295e417d273497fadf7978b1e6ef1d84b734f3d + !! source digest: sha256:86a2a6215a68dccd1eda785a2d54cd93e5981d549b82be6fbbf6879a84e9ecde !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! .. |badge1| image:: https://img.shields.io/badge/maturity-Alpha-red.png diff --git a/stock_picking_tier_validation/__manifest__.py b/stock_picking_tier_validation/__manifest__.py index 4f9da0f..f6a680c 100644 --- a/stock_picking_tier_validation/__manifest__.py +++ b/stock_picking_tier_validation/__manifest__.py @@ -5,7 +5,7 @@ "name": "Stock Picking Tier Validation", "summary": "Extends the functionality of Transfers to " "support a tier validation process.", - "version": "18.0.1.0.0", + "version": "18.0.1.0.1", "category": "Warehouse Management", "website": "https://github.com/OCA/stock-logistics-workflow", "author": "Ecosoft, Odoo Community Association (OCA)", diff --git a/stock_picking_tier_validation/static/description/index.html b/stock_picking_tier_validation/static/description/index.html index dfd0d13..84d5e25 100644 --- a/stock_picking_tier_validation/static/description/index.html +++ b/stock_picking_tier_validation/static/description/index.html @@ -372,7 +372,7 @@

Stock Picking Tier Validation

!! This file is generated by oca-gen-addon-readme !! !! changes will be overwritten. !! !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! -!! source digest: sha256:880227d58bee0630ee142da54295e417d273497fadf7978b1e6ef1d84b734f3d +!! source digest: sha256:86a2a6215a68dccd1eda785a2d54cd93e5981d549b82be6fbbf6879a84e9ecde !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! -->

Alpha License: AGPL-3 OCA/stock-logistics-workflow Translate me on Weblate Try me on Runboat

This module extends the functionality of Transfers to support a tier From 6dc77614576b5b36e0fe53e07ebad95e00e961fa Mon Sep 17 00:00:00 2001 From: Eugene Molotov Date: Wed, 10 Dec 2025 16:53:23 +0500 Subject: [PATCH 18/20] [IMP] stock_picking_tier_validation: pre-commit auto fixes --- stock_picking_tier_validation/README.rst | 30 +++++++++---------- stock_picking_tier_validation/__manifest__.py | 4 +-- .../static/description/index.html | 12 ++++---- 3 files changed, 23 insertions(+), 23 deletions(-) diff --git a/stock_picking_tier_validation/README.rst b/stock_picking_tier_validation/README.rst index 07d24a6..49cac4c 100644 --- a/stock_picking_tier_validation/README.rst +++ b/stock_picking_tier_validation/README.rst @@ -20,14 +20,14 @@ Stock Picking Tier Validation .. |badge2| image:: https://img.shields.io/badge/license-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%2Fstock--logistics--workflow-lightgray.png?logo=github - :target: https://github.com/OCA/stock-logistics-workflow/tree/18.0/stock_picking_tier_validation - :alt: OCA/stock-logistics-workflow +.. |badge3| image:: https://img.shields.io/badge/github-OCA%2Ftier--validation-lightgray.png?logo=github + :target: https://github.com/OCA/tier-validation/tree/19.0/stock_picking_tier_validation + :alt: OCA/tier-validation .. |badge4| image:: https://img.shields.io/badge/weblate-Translate%20me-F47D42.png - :target: https://translation.odoo-community.org/projects/stock-logistics-workflow-18-0/stock-logistics-workflow-18-0-stock_picking_tier_validation + :target: https://translation.odoo-community.org/projects/tier-validation-19-0/tier-validation-19-0-stock_picking_tier_validation :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/stock-logistics-workflow&target_branch=18.0 + :target: https://runboat.odoo-community.org/builds?repo=OCA/tier-validation&target_branch=19.0 :alt: Try me on Runboat |badge1| |badge2| |badge3| |badge4| |badge5| @@ -72,19 +72,19 @@ To use this module, you need to: Additional features: -- You can filter the Transfers requesting your review through the filter - *Needs my Review*. -- User with rights to validate the Transfer (validate all tiers that - would be generated) can directly do the operation, this is, there is - no need for her/him to request a validation. +- You can filter the Transfers requesting your review through the + filter *Needs my Review*. +- User with rights to validate the Transfer (validate all tiers that + would be generated) can directly do the operation, this is, there is + no need for her/him to request a validation. Bug Tracker =========== -Bugs are tracked on `GitHub Issues `_. +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 `_. +`feedback `_. Do not contact contributors directly about support or help with technical issues. @@ -99,9 +99,9 @@ Authors Contributors ------------ -- `Ecosoft `__: +- `Ecosoft `__: - - Pimolnat Suntian + - Pimolnat Suntian Maintainers ----------- @@ -116,6 +116,6 @@ 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/stock-logistics-workflow `_ project on GitHub. +This module is part of the `OCA/tier-validation `_ project on GitHub. You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute. diff --git a/stock_picking_tier_validation/__manifest__.py b/stock_picking_tier_validation/__manifest__.py index f6a680c..a2efc7a 100644 --- a/stock_picking_tier_validation/__manifest__.py +++ b/stock_picking_tier_validation/__manifest__.py @@ -5,9 +5,9 @@ "name": "Stock Picking Tier Validation", "summary": "Extends the functionality of Transfers to " "support a tier validation process.", - "version": "18.0.1.0.1", + "version": "19.0.1.0.0", "category": "Warehouse Management", - "website": "https://github.com/OCA/stock-logistics-workflow", + "website": "https://github.com/OCA/tier-validation", "author": "Ecosoft, Odoo Community Association (OCA)", "license": "AGPL-3", "depends": ["stock", "base_tier_validation"], diff --git a/stock_picking_tier_validation/static/description/index.html b/stock_picking_tier_validation/static/description/index.html index 84d5e25..56b0e81 100644 --- a/stock_picking_tier_validation/static/description/index.html +++ b/stock_picking_tier_validation/static/description/index.html @@ -374,7 +374,7 @@

Stock Picking Tier Validation

!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! !! source digest: sha256:86a2a6215a68dccd1eda785a2d54cd93e5981d549b82be6fbbf6879a84e9ecde !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! --> -

Alpha License: AGPL-3 OCA/stock-logistics-workflow Translate me on Weblate Try me on Runboat

+

Alpha License: AGPL-3 OCA/tier-validation Translate me on Weblate Try me on Runboat

This module extends the functionality of Transfers to support a tier validation process.

@@ -423,8 +423,8 @@

Usage

Additional features:

    -
  • You can filter the Transfers requesting your review through the filter -Needs my Review.
  • +
  • You can filter the Transfers requesting your review through the +filter Needs my Review.
  • User with rights to validate the Transfer (validate all tiers that would be generated) can directly do the operation, this is, there is no need for her/him to request a validation.
  • @@ -432,10 +432,10 @@

    Usage

Bug Tracker

-

Bugs are tracked on GitHub Issues. +

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.

+feedback.

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

@@ -464,7 +464,7 @@

Maintainers

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/stock-logistics-workflow project on GitHub.

+

This module is part of the OCA/tier-validation project on GitHub.

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

From bb4a4491b9dab6bf21d5eb6c37019784b4f2b56e Mon Sep 17 00:00:00 2001 From: Eugene Molotov Date: Wed, 10 Dec 2025 17:05:59 +0500 Subject: [PATCH 19/20] [MIG] stock_picking_tier_validation: migration to 19.0 --- stock_picking_tier_validation/models/stock_picking.py | 8 +++++--- .../tests/test_tier_validation.py | 2 -- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/stock_picking_tier_validation/models/stock_picking.py b/stock_picking_tier_validation/models/stock_picking.py index dbab5a8..5695221 100644 --- a/stock_picking_tier_validation/models/stock_picking.py +++ b/stock_picking_tier_validation/models/stock_picking.py @@ -1,7 +1,7 @@ # Copyright 2021 Ecosoft Co., Ltd. (http://ecosoft.co.th) # License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl). -from odoo import _, models +from odoo import models from odoo.exceptions import ValidationError @@ -21,13 +21,15 @@ def button_validate(self): rec._validate_tier(reviews) if self.validation_status != "validated": raise ValidationError( - _( + self.env._( "This action needs to be validated for at least " "one record. \nPlease request a validation." ) ) if rec.review_ids and not rec.validated: raise ValidationError( - _("A validation process is still open for at least one record.") + self.env._( + "A validation process is still open for at least one record." + ) ) return super().button_validate() diff --git a/stock_picking_tier_validation/tests/test_tier_validation.py b/stock_picking_tier_validation/tests/test_tier_validation.py index 186a6bb..2f153c8 100644 --- a/stock_picking_tier_validation/tests/test_tier_validation.py +++ b/stock_picking_tier_validation/tests/test_tier_validation.py @@ -40,7 +40,6 @@ def setUpClass(cls): cls.product = cls.product_model.create( { "name": "test_product", - "categ_id": cls.env.ref("product.product_category_all").id, "type": "consu", "is_storable": True, "standard_price": 1.0, @@ -64,7 +63,6 @@ def _create_picking(self, picking_type, location, location_dest): "move_ids": [ Command.create( { - "name": "Test move", "product_id": self.product.id, "product_uom": self.product.uom_id.id, "product_uom_qty": 3, From d2cf5ace1a0bdb3bd09e2c410cadc094a8459ee5 Mon Sep 17 00:00:00 2001 From: Eugene Molotov Date: Wed, 10 Dec 2025 17:08:45 +0500 Subject: [PATCH 20/20] temp commit --- test-requirements.txt | 1 + 1 file changed, 1 insertion(+) create mode 100644 test-requirements.txt diff --git a/test-requirements.txt b/test-requirements.txt new file mode 100644 index 0000000..6e70d1e --- /dev/null +++ b/test-requirements.txt @@ -0,0 +1 @@ +git+https://github.com/em230418/tier-validation@19.0-mig-base_tier_validation#subdirectory=base_tier_validation