|
7 | 7 | class StockRule(models.Model): |
8 | 8 | _inherit = "stock.rule" |
9 | 9 |
|
| 10 | + def _make_po_get_domain(self, company_id, values, partner): |
| 11 | + domain = super()._make_po_get_domain(company_id, values, partner) |
| 12 | + move_dest_recs = values.get("move_dest_ids") |
| 13 | + if move_dest_recs: |
| 14 | + origin_move = move_dest_recs[0] |
| 15 | + if origin_move.restrict_partner_id: |
| 16 | + domain += (("owner_id", "=", origin_move.restrict_partner_id.id),) |
| 17 | + return domain |
| 18 | + |
10 | 19 | def _prepare_purchase_order(self, company_id, origins, values): |
11 | 20 | vals = super(StockRule, self)._prepare_purchase_order( |
12 | 21 | company_id, origins, values |
13 | 22 | ) |
14 | 23 | values = values[0] |
15 | 24 | move_dest = values.get("move_dest_ids") |
16 | | - origin_move = self._find_origin_move(move_dest[0]) |
17 | | - if origin_move: |
18 | | - if origin_move.picking_id.owner_id: |
19 | | - vals["owner_id"] = origin_move.picking_id.owner_id.id |
20 | | - else: |
21 | | - # Handle the case where mrp_production_ids exists |
22 | | - mrp_productions = getattr( |
23 | | - origin_move.group_id, "mrp_production_ids", None |
24 | | - ) |
25 | | - if mrp_productions: |
26 | | - vals["owner_id"] = mrp_productions[0].owner_id.id |
| 25 | + if move_dest: |
| 26 | + # TODO: Should we simply get restrict_partner_id from move_dest? |
| 27 | + origin_move = self._find_origin_move(move_dest[0]) |
| 28 | + if origin_move: |
| 29 | + if origin_move.picking_id.owner_id: |
| 30 | + vals["owner_id"] = origin_move.picking_id.owner_id.id |
| 31 | + else: |
| 32 | + # Handle the case where mrp_production_ids exists |
| 33 | + mrp_productions = getattr( |
| 34 | + origin_move.group_id, "mrp_production_ids", None |
| 35 | + ) |
| 36 | + if mrp_productions: |
| 37 | + vals["owner_id"] = mrp_productions[0].owner_id.id |
27 | 38 | return vals |
28 | 39 |
|
29 | 40 | def _find_origin_move(self, move): |
|
0 commit comments