diff --git a/maintenance_request_repair/README.rst b/maintenance_request_repair/README.rst new file mode 100644 index 000000000..80e4bdf74 --- /dev/null +++ b/maintenance_request_repair/README.rst @@ -0,0 +1,91 @@ +========================== +Maintenance Request Repair +========================== + +.. !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + !! This file is generated by oca-gen-addon-readme !! + !! changes will be overwritten. !! + !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + +.. |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%2Fmaintenance-lightgray.png?logo=github + :target: https://github.com/OCA/maintenance/tree/15.0/maintenance_request_repair + :alt: OCA/maintenance +.. |badge4| image:: https://img.shields.io/badge/weblate-Translate%20me-F47D42.png + :target: https://translation.odoo-community.org/projects/maintenance-15-0/maintenance-15-0-maintenance_request_repair + :alt: Translate me on Weblate +.. |badge5| image:: https://img.shields.io/badge/runbot-Try%20me-875A7B.png + :target: https://runbot.odoo-community.org/runbot/240/15.0 + :alt: Try me on Runbot + +|badge1| |badge2| |badge3| |badge4| |badge5| + +This is a bridge module between Maintenance and Repair + +This module contains some new features for Maintenance modules. + +Maintenance Request + +- Repair Order: add a field to link a specific repair order. + +**Table of contents** + +.. contents:: + :local: + +Usage +===== + +Maintenance Request Repair + +* Go to Repair → create a new one +* Go to Maintenance → Maintenance Requests +* Edit a Maintenance Request +* Select a Repair Order on the list + +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 +~~~~~~~ + +* Escodoo + +Contributors +~~~~~~~~~~~~ + +* `Escodoo `_: + + * Marcel Savegnago + +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/maintenance `_ project on GitHub. + +You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute. diff --git a/maintenance_request_repair/__init__.py b/maintenance_request_repair/__init__.py new file mode 100644 index 000000000..0650744f6 --- /dev/null +++ b/maintenance_request_repair/__init__.py @@ -0,0 +1 @@ +from . import models diff --git a/maintenance_request_repair/__manifest__.py b/maintenance_request_repair/__manifest__.py new file mode 100644 index 000000000..03da66cb2 --- /dev/null +++ b/maintenance_request_repair/__manifest__.py @@ -0,0 +1,21 @@ +# Copyright 2020 - TODAY, Escodoo +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). + +{ + "name": "Maintenance Request Repair", + "summary": """ + This is a bridge module between Maintenance and Repair""", + "version": "16.0.1.0.0", + "license": "AGPL-3", + "category": "Maintenance", + "author": "Escodoo,Odoo Community Association (OCA)", + "website": "https://github.com/OCA/maintenance", + "depends": [ + "maintenance", + "repair", + ], + "data": [ + "views/maintenance_request.xml", + "views/repair_order.xml", + ], +} diff --git a/maintenance_request_repair/i18n/it.po b/maintenance_request_repair/i18n/it.po new file mode 100644 index 000000000..77d3f35b0 --- /dev/null +++ b/maintenance_request_repair/i18n/it.po @@ -0,0 +1,43 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * maintenance_request_repair +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 12.0\n" +"Report-Msgid-Bugs-To: \n" +"PO-Revision-Date: 2021-07-23 15:49+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 4.3.2\n" + +#. module: maintenance_request_repair +#: model:ir.model.fields,field_description:maintenance_request_repair.field_repair_order__maintenance_request_count +msgid "# Maintenances" +msgstr "N° manutenzioni" + +#. module: maintenance_request_repair +#: model:ir.model,name:maintenance_request_repair.model_maintenance_request +msgid "Maintenance Request" +msgstr "Richiesta manutenzione" + +#. module: maintenance_request_repair +#: model:ir.model.fields,field_description:maintenance_request_repair.field_repair_order__maintenance_request_ids +msgid "Maintenance Requests" +msgstr "Richieste manutenzione" + +#. module: maintenance_request_repair +#: model_terms:ir.ui.view,arch_db:maintenance_request_repair.repair_order_form_view +msgid "Maintenances" +msgstr "Manutenzioni" + +#. module: maintenance_request_repair +#: model:ir.model,name:maintenance_request_repair.model_repair_order +#: model:ir.model.fields,field_description:maintenance_request_repair.field_maintenance_request__repair_order_id +msgid "Repair Order" +msgstr "Oridine di riparazione" diff --git a/maintenance_request_repair/i18n/maintenance_request_repair.pot b/maintenance_request_repair/i18n/maintenance_request_repair.pot new file mode 100644 index 000000000..551fac82f --- /dev/null +++ b/maintenance_request_repair/i18n/maintenance_request_repair.pot @@ -0,0 +1,40 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * maintenance_request_repair +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 15.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: maintenance_request_repair +#: model:ir.model.fields,field_description:maintenance_request_repair.field_repair_order__maintenance_request_count +msgid "# Maintenances" +msgstr "" + +#. module: maintenance_request_repair +#: model:ir.model,name:maintenance_request_repair.model_maintenance_request +msgid "Maintenance Request" +msgstr "" + +#. module: maintenance_request_repair +#: model:ir.model.fields,field_description:maintenance_request_repair.field_repair_order__maintenance_request_ids +msgid "Maintenance Requests" +msgstr "" + +#. module: maintenance_request_repair +#: model_terms:ir.ui.view,arch_db:maintenance_request_repair.repair_order_form_view +msgid "Maintenances" +msgstr "" + +#. module: maintenance_request_repair +#: model:ir.model,name:maintenance_request_repair.model_repair_order +#: model:ir.model.fields,field_description:maintenance_request_repair.field_maintenance_request__repair_order_id +msgid "Repair Order" +msgstr "" diff --git a/maintenance_request_repair/i18n/pt_BR.po b/maintenance_request_repair/i18n/pt_BR.po new file mode 100644 index 000000000..34c978c39 --- /dev/null +++ b/maintenance_request_repair/i18n/pt_BR.po @@ -0,0 +1,44 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * maintenance_request_repair +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 12.0\n" +"Report-Msgid-Bugs-To: \n" +"POT-Creation-Date: 2020-08-07 22:44+0000\n" +"PO-Revision-Date: 2021-03-15 06:45+0000\n" +"Last-Translator: Marcel Savegnago \n" +"Language-Team: \n" +"Language: pt_BR\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: Weblate 4.3.2\n" + +#. module: maintenance_request_repair +#: model:ir.model.fields,field_description:maintenance_request_repair.field_repair_order__maintenance_request_count +msgid "# Maintenances" +msgstr "# Manutenções" + +#. module: maintenance_request_repair +#: model:ir.model,name:maintenance_request_repair.model_maintenance_request +msgid "Maintenance Request" +msgstr "Solicitação de Manutenção" + +#. module: maintenance_request_repair +#: model:ir.model.fields,field_description:maintenance_request_repair.field_repair_order__maintenance_request_ids +msgid "Maintenance Requests" +msgstr "Solicitações de Manutenção" + +#. module: maintenance_request_repair +#: model_terms:ir.ui.view,arch_db:maintenance_request_repair.repair_order_form_view +msgid "Maintenances" +msgstr "Manutenções" + +#. module: maintenance_request_repair +#: model:ir.model,name:maintenance_request_repair.model_repair_order +#: model:ir.model.fields,field_description:maintenance_request_repair.field_maintenance_request__repair_order_id +msgid "Repair Order" +msgstr "Ordem de Reparo" diff --git a/maintenance_request_repair/models/__init__.py b/maintenance_request_repair/models/__init__.py new file mode 100644 index 000000000..410324b1b --- /dev/null +++ b/maintenance_request_repair/models/__init__.py @@ -0,0 +1,2 @@ +from . import maintenance_request +from . import repair_order diff --git a/maintenance_request_repair/models/maintenance_request.py b/maintenance_request_repair/models/maintenance_request.py new file mode 100644 index 000000000..dcce737ed --- /dev/null +++ b/maintenance_request_repair/models/maintenance_request.py @@ -0,0 +1,11 @@ +# Copyright 2020 - TODAY, Marcel Savegnago - Escodoo +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). + +from odoo import fields, models + + +class MaintenanceRequest(models.Model): + + _inherit = "maintenance.request" + + repair_order_id = fields.Many2one("repair.order", "Repair Order") diff --git a/maintenance_request_repair/models/repair_order.py b/maintenance_request_repair/models/repair_order.py new file mode 100644 index 000000000..b954d85ab --- /dev/null +++ b/maintenance_request_repair/models/repair_order.py @@ -0,0 +1,47 @@ +# Copyright 2020 - TODAY, Marcel Savegnago - Escodoo +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). + +from odoo import api, fields, models + + +class RepairOrder(models.Model): + + _inherit = "repair.order" + + maintenance_request_ids = fields.One2many( + "maintenance.request", "repair_order_id", string="Maintenance Requests" + ) + + maintenance_request_count = fields.Integer( + compute="_compute_maintenance_request_count", string="# Maintenances" + ) + + @api.depends("maintenance_request_ids") + def _compute_maintenance_request_count(self): + for repair in self: + repair.maintenance_request_count = len(repair.maintenance_request_ids) + + def action_view_maintenance_request(self): + """This function returns an action that display existing maintenance requests + of given repair order ids. When only one found, show the maintenance request + immediately. + """ + action = self.env.ref("maintenance.hr_equipment_request_action") + result = action.read()[0] + # override the context to get rid of the default filtering on repair order + result["context"] = {"default_repair_order_id": self.id} + maintenance_request_ids = self.mapped("maintenance_request_ids") + # choose the view_mode accordingly + if not maintenance_request_ids or len(maintenance_request_ids) > 1: + result["domain"] = "[('id','in',%s)]" % (maintenance_request_ids.ids) + elif len(maintenance_request_ids) == 1: + res = self.env.ref("maintenance.hr_equipment_request_view_form", False) + form_view = [(res and res.id or False, "form")] + if "views" in result: + result["views"] = form_view + [ + (state, view) for state, view in result["views"] if view != "form" + ] + else: + result["views"] = form_view + result["res_id"] = maintenance_request_ids.id + return result diff --git a/maintenance_request_repair/readme/CONTRIBUTORS.rst b/maintenance_request_repair/readme/CONTRIBUTORS.rst new file mode 100644 index 000000000..c7fe69086 --- /dev/null +++ b/maintenance_request_repair/readme/CONTRIBUTORS.rst @@ -0,0 +1,4 @@ +* `Escodoo `_: + + * Marcel Savegnago + * Kaynnan Lemes diff --git a/maintenance_request_repair/readme/DESCRIPTION.rst b/maintenance_request_repair/readme/DESCRIPTION.rst new file mode 100644 index 000000000..d193a470a --- /dev/null +++ b/maintenance_request_repair/readme/DESCRIPTION.rst @@ -0,0 +1,7 @@ +This is a bridge module between Maintenance and Repair + +This module contains some new features for Maintenance modules. + +Maintenance Request + +- Repair Order: add a field to link a specific repair order. diff --git a/maintenance_request_repair/readme/USAGE.rst b/maintenance_request_repair/readme/USAGE.rst new file mode 100644 index 000000000..d3ea13852 --- /dev/null +++ b/maintenance_request_repair/readme/USAGE.rst @@ -0,0 +1,6 @@ +Maintenance Request Repair + +* Go to Repair → create a new one +* Go to Maintenance → Maintenance Requests +* Edit a Maintenance Request +* Select a Repair Order on the list diff --git a/maintenance_request_repair/static/description/icon.png b/maintenance_request_repair/static/description/icon.png new file mode 100644 index 000000000..3a0328b51 Binary files /dev/null and b/maintenance_request_repair/static/description/icon.png differ diff --git a/maintenance_request_repair/static/description/index.html b/maintenance_request_repair/static/description/index.html new file mode 100644 index 000000000..9c84f121a --- /dev/null +++ b/maintenance_request_repair/static/description/index.html @@ -0,0 +1,438 @@ + + + + + + +Maintenance Request Repair + + + +
+

Maintenance Request Repair

+ + +

Beta License: AGPL-3 OCA/maintenance Translate me on Weblate Try me on Runbot

+

This is a bridge module between Maintenance and Repair

+

This module contains some new features for Maintenance modules.

+

Maintenance Request

+
    +
  • Repair Order: add a field to link a specific repair order.
  • +
+

Table of contents

+ +
+

Usage

+

Maintenance Request Repair

+
    +
  • Go to Repair → create a new one
  • +
  • Go to Maintenance → Maintenance Requests
  • +
  • Edit a Maintenance Request
  • +
  • Select a Repair Order on the list
  • +
+
+
+

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

+
    +
  • Escodoo
  • +
+
+
+

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/maintenance project on GitHub.

+

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

+
+
+
+ + diff --git a/maintenance_request_repair/tests/__init__.py b/maintenance_request_repair/tests/__init__.py new file mode 100644 index 000000000..bf6f8ef58 --- /dev/null +++ b/maintenance_request_repair/tests/__init__.py @@ -0,0 +1 @@ +from . import test_repair_order diff --git a/maintenance_request_repair/tests/test_repair_order.py b/maintenance_request_repair/tests/test_repair_order.py new file mode 100644 index 000000000..09d0404a2 --- /dev/null +++ b/maintenance_request_repair/tests/test_repair_order.py @@ -0,0 +1,197 @@ +# Copyright 2023 - TODAY, Kaynnan Lemes +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl). + +from odoo.tests import common + + +class TestRepairOrder(common.TransactionCase): + def setUp(self): + super(TestRepairOrder, self).setUp() + + self.product = self.env["product.product"].create( + { + "name": "Product Test", + "uom_id": self.env.ref("uom.product_uom_unit").id, + "uom_po_id": self.env.ref("uom.product_uom_unit").id, + } + ) + + self.location_id = self.env["stock.location"].create( + { + "name": "Test Location", + "usage": "internal", + "location_id": self.env.ref("stock.stock_location_stock").id, + } + ) + + self.repair_order = self.env["repair.order"].create( + { + "name": "Test Repair Order", + "product_id": self.product.id, + "product_uom": self.product.uom_id.id, + "location_id": self.location_id.id, + } + ) + + self.request1 = self.env["maintenance.request"].create( + { + "name": "Request 1", + "repair_order_id": self.repair_order.id, + } + ) + self.request2 = self.env["maintenance.request"].create( + { + "name": "Request 2", + "repair_order_id": self.repair_order.id, + } + ) + + self.equipment = self.env["maintenance.equipment"].create( + {"name": "Equipment 1"} + ) + self.partner = self.env["res.partner"].create({"name": "Test Partner"}) + + def test_compute_maintenance_request_count(self): + self.repair_order.write( + {"maintenance_request_ids": [(4, self.request1.id), (4, self.request2.id)]} + ) + self.repair_order._compute_maintenance_request_count() + assert self.repair_order.maintenance_request_count == 2 + + def test_action_view_maintenance_request(self): + + self.result = self.repair_order.with_user( + self.env.user + ).action_view_maintenance_request() + self.repair_order.write( + {"maintenance_request_ids": [(4, self.request1.id), (4, self.request2.id)]} + ) + self.assertEqual( + self.result["context"], {"default_repair_order_id": self.repair_order.id} + ) + self.maintenance_request_ids = self.repair_order.mapped( + "maintenance_request_ids" + ) + with self.subTest("Choose the view_mode accordingly"): + + with self.subTest( + "Check maintenance_request_ids > 1 OR not self.maintenance_request_ids" + ): + self.assertTrue( + len(self.repair_order.maintenance_request_ids) > 1 + or not self.repair_order.maintenance_request_ids + ) + self.result["domain"] = "[('id','in',%s)]" % ( + self.maintenance_request_ids.ids + ) + self.assertEqual( + self.result["domain"], + "[('id','in',%s)]" % (self.maintenance_request_ids.ids), + ) + + self.repair_order.write( + {"maintenance_request_ids": [(6, 0, self.request1.id)]} + ) + self.maintenance_request_ids = self.repair_order.maintenance_request_ids + self.result = self.repair_order.action_view_maintenance_request() + + with self.subTest("Check maintenance_request_ids == 1"): + + self.assertEqual(len(self.maintenance_request_ids), 1) + res = self.env.ref("maintenance.hr_equipment_request_view_form", False) + form_view = [(res and res.id or False, "form")] + + with self.subTest("Check view in result"): + + self.assertIn("views", self.result) + self.result["views"] = form_view + [ + (state, view) + for state, view in self.result["views"] + if view != "form" + ] + self.assertEqual( + self.result["views"], + ( + form_view + + [ + (state, view) + for state, view in self.result["views"] + if view != "form" + ] + ), + ) + + self.assertNotEqual(self.result["views"], form_view) + del self.result["views"] + + self.repair_order.write( + {"maintenance_request_ids": [(2, self.request1.id)]} + ) + self.maintenance_request_ids = self.repair_order.maintenance_request_ids + + with self.subTest("Check view not in result"): + self.assertNotIn("views", self.result) + self.result["views"] = form_view + self.assertEqual(self.result["views"], form_view) + + self.result["res_id"] = self.maintenance_request_ids.id + self.assertEqual(self.result["res_id"], self.maintenance_request_ids.id) + + def test_create_repair_order(self): + self.repair_order = self.env["repair.order"].create( + { + "partner_id": self.partner.id, + "product_id": self.product.id, + } + ) + self.repair_order.name = "Repair Order Test 2" + self.assertEqual(self.repair_order.name, "Repair Order Test 2") + self.assertEqual(self.repair_order.partner_id, self.partner) + self.assertEqual(self.repair_order.product_id, self.product) + + def test_simple_view_maintenance_request(self): + self.repair_order = self.env["repair.order"].create( + { + "name": "Repair Order Test", + "partner_id": self.partner.id, + "product_id": self.product.id, + } + ) + self.maintenance_request = self.env["maintenance.request"].create( + { + "name": "Maintenance Request Test", + "repair_order_id": self.repair_order.id, + } + ) + self.action = self.repair_order.action_view_maintenance_request() + self.assertEqual(self.action["type"], "ir.actions.act_window") + self.assertEqual(self.action["res_model"], "maintenance.request") + self.assertEqual( + self.action["view_mode"], "kanban,tree,form,pivot,graph,calendar" + ) + self.assertEqual(self.action["target"], "current") + self.assertEqual(self.action["res_id"], self.maintenance_request.id) + + def test_maintenance_request_count(self): + self.env["maintenance.request"].create( + { + "name": "Maintenance Request Test", + "repair_order_id": self.repair_order.id, + } + ) + self.assertEqual(self.repair_order.maintenance_request_count, 3) + + def test_clear_maintenance_request(self): + self.action = self.repair_order.action_view_maintenance_request() + self.assertEqual(self.action["type"], "ir.actions.act_window") + self.assertEqual(self.action["name"], "Maintenance Requests") + self.assertEqual( + self.action["context"], {"default_repair_order_id": self.repair_order.id} + ) + self.assertEqual(self.action["views"][0][1], "kanban") + self.assertEqual(self.action["views"][1][1], "tree") + self.assertEqual(self.action["views"][2][1], "form") + self.assertEqual(self.action["views"][3][1], "pivot") + self.assertEqual(self.action["views"][4][1], "graph") + self.assertEqual(self.action["views"][5][1], "calendar") + self.assertEqual(len(self.action["views"]), 6) diff --git a/maintenance_request_repair/views/maintenance_request.xml b/maintenance_request_repair/views/maintenance_request.xml new file mode 100644 index 000000000..aee368f61 --- /dev/null +++ b/maintenance_request_repair/views/maintenance_request.xml @@ -0,0 +1,33 @@ + + + + + + maintenance.request.form (in maintenance_request_repair) + maintenance.request + + + + + + + + + + + maintenance.request.tree (in maintenance_request_repair) + maintenance.request + + + + + + + + + diff --git a/maintenance_request_repair/views/repair_order.xml b/maintenance_request_repair/views/repair_order.xml new file mode 100644 index 000000000..62de8a773 --- /dev/null +++ b/maintenance_request_repair/views/repair_order.xml @@ -0,0 +1,30 @@ + + + + + repair.order.form (in maintenance_request_repair) + repair.order + + + +
+ + +
+
+
+ + +
diff --git a/setup/maintenance_request_repair/odoo/addons/maintenance_request_repair b/setup/maintenance_request_repair/odoo/addons/maintenance_request_repair new file mode 120000 index 000000000..e69518883 --- /dev/null +++ b/setup/maintenance_request_repair/odoo/addons/maintenance_request_repair @@ -0,0 +1 @@ +../../../../maintenance_request_repair \ No newline at end of file diff --git a/setup/maintenance_request_repair/setup.py b/setup/maintenance_request_repair/setup.py new file mode 100644 index 000000000..28c57bb64 --- /dev/null +++ b/setup/maintenance_request_repair/setup.py @@ -0,0 +1,6 @@ +import setuptools + +setuptools.setup( + setup_requires=['setuptools-odoo'], + odoo_addon=True, +)