diff --git a/rma_repair_follow_lot_location/README.rst b/rma_repair_follow_lot_location/README.rst new file mode 100644 index 000000000..cd8227c70 --- /dev/null +++ b/rma_repair_follow_lot_location/README.rst @@ -0,0 +1,95 @@ +============================== +Rma Repair Follow Lot Location +============================== + +.. + !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + !! This file is generated by oca-gen-addon-readme !! + !! changes will be overwritten. !! + !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + !! source digest: sha256:3e79482c07f61af0b74fe47282302adb06cf40b336708aced4e1de11b0868c15 + !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + +.. |badge1| image:: https://img.shields.io/badge/maturity-Beta-yellow.png + :target: https://odoo-community.org/page/development-status + :alt: Beta +.. |badge2| image:: https://img.shields.io/badge/licence-AGPL--3-blue.png + :target: http://www.gnu.org/licenses/agpl-3.0-standalone.html + :alt: License: AGPL-3 +.. |badge3| image:: https://img.shields.io/badge/github-OCA%2Frma-lightgray.png?logo=github + :target: https://github.com/OCA/rma/tree/16.0/rma_repair_follow_lot_location + :alt: OCA/rma +.. |badge4| image:: https://img.shields.io/badge/weblate-Translate%20me-F47D42.png + :target: https://translation.odoo-community.org/projects/rma-16-0/rma-16-0-rma_repair_follow_lot_location + :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/rma&target_branch=16.0 + :alt: Try me on Runboat + +|badge1| |badge2| |badge3| |badge4| |badge5| + +This glue module bridges ``rma_repair`` and +``repair_follow_lot_location`` to a set a default value for repair order +field **Follow Lot Location** at rma operation level. + +**Table of contents** + +.. contents:: + :local: + +Configuration +============= + +1. Go to **RMA / Configuration / Operations** (open the relevant + operation) +2. Select when and how the repair order is created via the field + **Repair Action** +3. Enable **Follow Repair Location from Lot** + +Bug Tracker +=========== + +Bugs are tracked on `GitHub Issues `_. +In case of trouble, please check there if your issue has already been reported. +If you spotted it first, help us to smash it by providing a detailed and welcomed +`feedback `_. + +Do not contact contributors directly about support or help with technical issues. + +Credits +======= + +Authors +------- + +* ACSONE SA/NV + +Contributors +------------ + +- Souheil Bejaoui + +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-sbejaoui| image:: https://github.com/sbejaoui.png?size=40px + :target: https://github.com/sbejaoui + :alt: sbejaoui + +Current `maintainer `__: + +|maintainer-sbejaoui| + +This module is part of the `OCA/rma `_ project on GitHub. + +You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute. diff --git a/rma_repair_follow_lot_location/__init__.py b/rma_repair_follow_lot_location/__init__.py new file mode 100644 index 000000000..0650744f6 --- /dev/null +++ b/rma_repair_follow_lot_location/__init__.py @@ -0,0 +1 @@ +from . import models diff --git a/rma_repair_follow_lot_location/__manifest__.py b/rma_repair_follow_lot_location/__manifest__.py new file mode 100644 index 000000000..a57a35190 --- /dev/null +++ b/rma_repair_follow_lot_location/__manifest__.py @@ -0,0 +1,16 @@ +# Copyright 2025 ACSONE SA/NV +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl). + +{ + "name": "Rma Repair Follow Lot Location", + "summary": """This addon define default value for repair order follow_lot_location + field from rma reason""", + "version": "16.0.1.0.0", + "license": "AGPL-3", + "author": "ACSONE SA/NV,Odoo Community Association (OCA)", + "website": "https://github.com/OCA/rma", + "maintainers": ["sbejaoui"], + "depends": ["repair_follow_lot_location", "rma_repair"], + "data": ["views/rma_operation.xml"], + "demo": [], +} diff --git a/rma_repair_follow_lot_location/models/__init__.py b/rma_repair_follow_lot_location/models/__init__.py new file mode 100644 index 000000000..57a964469 --- /dev/null +++ b/rma_repair_follow_lot_location/models/__init__.py @@ -0,0 +1,2 @@ +from . import rma_operation +from . import rma diff --git a/rma_repair_follow_lot_location/models/rma.py b/rma_repair_follow_lot_location/models/rma.py new file mode 100644 index 000000000..1aa07a0c8 --- /dev/null +++ b/rma_repair_follow_lot_location/models/rma.py @@ -0,0 +1,17 @@ +# Copyright 2025 ACSONE SA/NV +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl). + +from odoo import models + + +class Rma(models.Model): + + _inherit = "rma" + + def _get_repair_order_default_vals(self): + self.ensure_one() + vals = super()._get_repair_order_default_vals() + vals[ + "default_follow_lot_location" + ] = self.operation_id.repair_follow_lot_location + return vals diff --git a/rma_repair_follow_lot_location/models/rma_operation.py b/rma_repair_follow_lot_location/models/rma_operation.py new file mode 100644 index 000000000..c209561f0 --- /dev/null +++ b/rma_repair_follow_lot_location/models/rma_operation.py @@ -0,0 +1,16 @@ +# Copyright 2025 ACSONE SA/NV +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl). + +from odoo import fields, models + + +class RmaOperation(models.Model): + + _inherit = "rma.operation" + + repair_follow_lot_location = fields.Boolean( + help="When enabled, the repair's location is kept in sync with the " + "current internal location of the linked lot/serial.", + default=False, + index=True, + ) diff --git a/rma_repair_follow_lot_location/readme/CONFIGURE.md b/rma_repair_follow_lot_location/readme/CONFIGURE.md new file mode 100644 index 000000000..94fd4e956 --- /dev/null +++ b/rma_repair_follow_lot_location/readme/CONFIGURE.md @@ -0,0 +1,3 @@ +1. Go to **RMA / Configuration / Operations** (open the relevant operation) +2. Select when and how the repair order is created via the field **Repair Action** +3. Enable **Follow Repair Location from Lot** diff --git a/rma_repair_follow_lot_location/readme/CONTRIBUTORS.md b/rma_repair_follow_lot_location/readme/CONTRIBUTORS.md new file mode 100644 index 000000000..41a3b8b9f --- /dev/null +++ b/rma_repair_follow_lot_location/readme/CONTRIBUTORS.md @@ -0,0 +1,2 @@ +- Souheil Bejaoui \<\> + diff --git a/rma_repair_follow_lot_location/readme/DESCRIPTION.md b/rma_repair_follow_lot_location/readme/DESCRIPTION.md new file mode 100644 index 000000000..aa5793f72 --- /dev/null +++ b/rma_repair_follow_lot_location/readme/DESCRIPTION.md @@ -0,0 +1,3 @@ +This glue module bridges `rma_repair` and `repair_follow_lot_location` to a set +a default value for repair order field **Follow Lot Location** at rma operation +level. diff --git a/rma_repair_follow_lot_location/static/description/icon.png b/rma_repair_follow_lot_location/static/description/icon.png new file mode 100644 index 000000000..3a0328b51 Binary files /dev/null and b/rma_repair_follow_lot_location/static/description/icon.png differ diff --git a/rma_repair_follow_lot_location/static/description/index.html b/rma_repair_follow_lot_location/static/description/index.html new file mode 100644 index 000000000..f0b388fcc --- /dev/null +++ b/rma_repair_follow_lot_location/static/description/index.html @@ -0,0 +1,438 @@ + + + + + +Rma Repair Follow Lot Location + + + +
+

Rma Repair Follow Lot Location

+ + +

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

+

This glue module bridges rma_repair and +repair_follow_lot_location to a set a default value for repair order +field Follow Lot Location at rma operation level.

+

Table of contents

+ +
+

Configuration

+
    +
  1. Go to RMA / Configuration / Operations (open the relevant +operation)
  2. +
  3. Select when and how the repair order is created via the field +Repair Action
  4. +
  5. Enable Follow Repair Location from Lot
  6. +
+
+
+

Bug Tracker

+

Bugs are tracked on GitHub Issues. +In case of trouble, please check there if your issue has already been reported. +If you spotted it first, help us to smash it by providing a detailed and welcomed +feedback.

+

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

+
+
+

Credits

+
+

Authors

+
    +
  • ACSONE SA/NV
  • +
+
+
+

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.

+

Current maintainer:

+

sbejaoui

+

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

+

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

+
+
+
+ + diff --git a/rma_repair_follow_lot_location/tests/__init__.py b/rma_repair_follow_lot_location/tests/__init__.py new file mode 100644 index 000000000..047d42fb7 --- /dev/null +++ b/rma_repair_follow_lot_location/tests/__init__.py @@ -0,0 +1 @@ +from . import test_rma_repair_follow_lot_location diff --git a/rma_repair_follow_lot_location/tests/test_rma_repair_follow_lot_location.py b/rma_repair_follow_lot_location/tests/test_rma_repair_follow_lot_location.py new file mode 100644 index 000000000..436a710f3 --- /dev/null +++ b/rma_repair_follow_lot_location/tests/test_rma_repair_follow_lot_location.py @@ -0,0 +1,32 @@ +# Copyright 2025 ACSONE SA/NV +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl). + +from odoo.addons.rma_repair.tests.test_rma_repair_order import RMARepairOrderTest + + +class TestRmaRepairFollowLotLocation(RMARepairOrderTest): + def test_action_create_repair_order_follow_lot_location(self): + self.operation.repair_follow_lot_location = True + action_result = self.rma.action_create_repair_order() + ctx = action_result.get("context", {}) + key = "default_follow_lot_location" + self.assertIn(key, ctx) + self.assertTrue(ctx[key]) + + def test_action_create_repair_order_no_follow_lot_location(self): + self.operation.repair_follow_lot_location = False + action_result = self.rma.action_create_repair_order() + ctx = action_result.get("context", {}) + key = "default_follow_lot_location" + self.assertIn(key, ctx) + self.assertFalse(ctx[key]) + + def test_create_repair_order_repair_follow_lot_location(self): + self.operation.repair_follow_lot_location = True + repair = self.rma_without_repair._create_repair() + self.assertTrue(repair.follow_lot_location) + + def test_create_repair_order_repair_no_follow_lot_location(self): + self.operation.repair_follow_lot_location = False + repair = self.rma_without_repair._create_repair() + self.assertFalse(repair.follow_lot_location) diff --git a/rma_repair_follow_lot_location/views/rma_operation.xml b/rma_repair_follow_lot_location/views/rma_operation.xml new file mode 100644 index 000000000..0b69f47f4 --- /dev/null +++ b/rma_repair_follow_lot_location/views/rma_operation.xml @@ -0,0 +1,24 @@ + + + + + + rma.operation + + + + + + + + + + + diff --git a/setup/rma_repair_follow_lot_location/odoo/addons/rma_repair_follow_lot_location b/setup/rma_repair_follow_lot_location/odoo/addons/rma_repair_follow_lot_location new file mode 120000 index 000000000..bbb2ccb4e --- /dev/null +++ b/setup/rma_repair_follow_lot_location/odoo/addons/rma_repair_follow_lot_location @@ -0,0 +1 @@ +../../../../rma_repair_follow_lot_location \ No newline at end of file diff --git a/setup/rma_repair_follow_lot_location/setup.py b/setup/rma_repair_follow_lot_location/setup.py new file mode 100644 index 000000000..28c57bb64 --- /dev/null +++ b/setup/rma_repair_follow_lot_location/setup.py @@ -0,0 +1,6 @@ +import setuptools + +setuptools.setup( + setup_requires=['setuptools-odoo'], + odoo_addon=True, +)