Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
78 changes: 78 additions & 0 deletions repair_preparation_purchase/README.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,78 @@
===========================
Repair Preparation Purchase
===========================

..
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
!! This file is generated by oca-gen-addon-readme !!
!! changes will be overwritten. !!
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
!! source digest: sha256:7de56899985844b5e7af07db24664b0ad319d0b844b2d285a2afcd11fa26a331
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

.. |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%2Frepair-lightgray.png?logo=github
:target: https://github.com/OCA/repair/tree/16.0/repair_preparation_purchase
:alt: OCA/repair
.. |badge4| image:: https://img.shields.io/badge/weblate-Translate%20me-F47D42.png
:target: https://translation.odoo-community.org/projects/repair-16-0/repair-16-0-repair_preparation_purchase
: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/repair&target_branch=16.0
:alt: Try me on Runboat

|badge1| |badge2| |badge3| |badge4| |badge5|

This addon extends **``repair_preparation``** by adding a direct link
between a **Repair Order** and the **Purchase Orders** created by
procurement during the preparation stage (e.g., MTO+Buy flows).

**Table of contents**

.. contents::
:local:

Bug Tracker
===========

Bugs are tracked on `GitHub Issues <https://github.com/OCA/repair/issues>`_.
In case of trouble, please check there if your issue has already been reported.
If you spotted it first, help us to smash it by providing a detailed and welcomed
`feedback <https://github.com/OCA/repair/issues/new?body=module:%20repair_preparation_purchase%0Aversion:%2016.0%0A%0A**Steps%20to%20reproduce**%0A-%20...%0A%0A**Current%20behavior**%0A%0A**Expected%20behavior**>`_.

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

Credits
=======

Authors
-------

* ACSONE SA/NV

Contributors
------------

- Souheil Bejaoui [email protected]

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/repair <https://github.com/OCA/repair/tree/16.0/repair_preparation_purchase>`_ project on GitHub.

You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute.
1 change: 1 addition & 0 deletions repair_preparation_purchase/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
from . import models
17 changes: 17 additions & 0 deletions repair_preparation_purchase/__manifest__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
# Copyright 2025 ACSONE SA/NV
# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl).

{
"name": "Repair Preparation Purchase",
"summary": """This addon add link""",
"version": "16.0.1.0.0",
"license": "AGPL-3",
"author": "ACSONE SA/NV,Odoo Community Association (OCA)",
"website": "https://github.com/OCA/repair",
"depends": ["repair_preparation", "purchase_stock"],
"data": [
"views/purchase_order.xml",
"views/repair_order.xml",
],
"demo": [],
}
3 changes: 3 additions & 0 deletions repair_preparation_purchase/models/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
from . import repair_order
from . import purchase_order_line
from . import purchase_order
30 changes: 30 additions & 0 deletions repair_preparation_purchase/models/purchase_order.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
# Copyright 2025 ACSONE SA/NV
# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl).

from odoo import _, api, fields, models


class PurchaseOrder(models.Model):

_inherit = "purchase.order"

repair_ids = fields.Many2many(
comodel_name="repair.order", compute="_compute_repair_ids"
)
count_repair = fields.Integer(compute="_compute_repair_ids")

@api.depends("order_line.repair_line_id")
def _compute_repair_ids(self):
for rec in self:
rec.repair_ids = rec.order_line.repair_line_id.repair_id
rec.count_repair = len(rec.repair_ids)

def action_view_repair_order(self):
return {
"type": "ir.actions.act_window",
"name": _("Repair Order(s)"),
"res_model": self.repair_ids._name,
"domain": [("id", "in", self.repair_ids.ids)],
"view_mode": "tree,form",
"context": self.env.context,
}
23 changes: 23 additions & 0 deletions repair_preparation_purchase/models/purchase_order_line.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
# Copyright 2025 ACSONE SA/NV
# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl).

from odoo import api, fields, models


class PurchaseOrderLine(models.Model):

_inherit = "purchase.order.line"

repair_line_id = fields.Many2one(
comodel_name="repair.line", ondelete="cascade", readonly=True
)

@api.model
def _prepare_purchase_order_line_from_procurement(
self, product_id, product_qty, product_uom, company_id, values, po
):
po_line_vals = super()._prepare_purchase_order_line_from_procurement(
product_id, product_qty, product_uom, company_id, values, po
)
po_line_vals["repair_line_id"] = values.get("repair_line_id")
return po_line_vals
30 changes: 30 additions & 0 deletions repair_preparation_purchase/models/repair_order.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
# Copyright 2025 ACSONE SA/NV
# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl).

from odoo import _, api, fields, models


class RepairOrder(models.Model):

_inherit = "repair.order"

preparation_purchase_ids = fields.Many2many(
comodel_name="purchase.order", compute="_compute_preparation_purchase_ids"
)

@api.depends("operations")
def _compute_preparation_purchase_ids(self):
for rec in self:
rec.preparation_purchase_ids = self.env["purchase.order"].search(
[("order_line.repair_line_id", "in", rec.operations.ids)]
)

def action_view_preparation_purchase_order(self):
return {
"type": "ir.actions.act_window",
"name": _("Preparation Purchase Order(s)"),
"res_model": self.preparation_purchase_ids._name,
"domain": [("id", "in", self.preparation_purchase_ids.ids)],
"view_mode": "tree,form",
"context": self.env.context,
}
1 change: 1 addition & 0 deletions repair_preparation_purchase/readme/CONTRIBUTORS.md
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
- Souheil Bejaoui <[email protected]>
3 changes: 3 additions & 0 deletions repair_preparation_purchase/readme/DESCRIPTION.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
This addon extends **`repair_preparation`** by adding a direct link between
a **Repair Order** and the **Purchase Orders** created by procurement during
the preparation stage (e.g., MTO+Buy flows).
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Loading