summaryrefslogtreecommitdiff
path: root/addons/sale_purchase/models/purchase_order.py
diff options
context:
space:
mode:
authorstephanchrst <stephanchrst@gmail.com>2022-05-10 21:51:50 +0700
committerstephanchrst <stephanchrst@gmail.com>2022-05-10 21:51:50 +0700
commit3751379f1e9a4c215fb6eb898b4ccc67659b9ace (patch)
treea44932296ef4a9b71d5f010906253d8c53727726 /addons/sale_purchase/models/purchase_order.py
parent0a15094050bfde69a06d6eff798e9a8ddf2b8c21 (diff)
initial commit 2
Diffstat (limited to 'addons/sale_purchase/models/purchase_order.py')
-rw-r--r--addons/sale_purchase/models/purchase_order.py74
1 files changed, 74 insertions, 0 deletions
diff --git a/addons/sale_purchase/models/purchase_order.py b/addons/sale_purchase/models/purchase_order.py
new file mode 100644
index 00000000..e4bd496b
--- /dev/null
+++ b/addons/sale_purchase/models/purchase_order.py
@@ -0,0 +1,74 @@
+# -*- coding: utf-8 -*-
+# Part of Odoo. See LICENSE file for full copyright and licensing details.
+
+from odoo import api, fields, models, _
+
+
+class PurchaseOrder(models.Model):
+ _inherit = "purchase.order"
+
+ sale_order_count = fields.Integer(
+ "Number of Source Sale",
+ compute='_compute_sale_order_count',
+ groups='sales_team.group_sale_salesman')
+
+ @api.depends('order_line.sale_order_id')
+ def _compute_sale_order_count(self):
+ for purchase in self:
+ purchase.sale_order_count = len(purchase._get_sale_orders())
+
+ def action_view_sale_orders(self):
+ self.ensure_one()
+ sale_order_ids = self._get_sale_orders().ids
+ action = {
+ 'res_model': 'sale.order',
+ 'type': 'ir.actions.act_window',
+ }
+ if len(sale_order_ids) == 1:
+ action.update({
+ 'view_mode': 'form',
+ 'res_id': sale_order_ids[0],
+ })
+ else:
+ action.update({
+ 'name': _('Sources Sale Orders %s', self.name),
+ 'domain': [('id', 'in', sale_order_ids)],
+ 'view_mode': 'tree,form',
+ })
+ return action
+
+ def button_cancel(self):
+ result = super(PurchaseOrder, self).button_cancel()
+ self.sudo()._activity_cancel_on_sale()
+ return result
+
+ def _get_sale_orders(self):
+ return self.order_line.sale_order_id
+
+ def _activity_cancel_on_sale(self):
+ """ If some PO are cancelled, we need to put an activity on their origin SO (only the open ones). Since a PO can have
+ been modified by several SO, when cancelling one PO, many next activities can be schedulded on different SO.
+ """
+ sale_to_notify_map = {} # map SO -> recordset of PO as {sale.order: set(purchase.order.line)}
+ for order in self:
+ for purchase_line in order.order_line:
+ if purchase_line.sale_line_id:
+ sale_order = purchase_line.sale_line_id.order_id
+ sale_to_notify_map.setdefault(sale_order, self.env['purchase.order.line'])
+ sale_to_notify_map[sale_order] |= purchase_line
+
+ for sale_order, purchase_order_lines in sale_to_notify_map.items():
+ sale_order._activity_schedule_with_view('mail.mail_activity_data_warning',
+ user_id=sale_order.user_id.id or self.env.uid,
+ views_or_xmlid='sale_purchase.exception_sale_on_purchase_cancellation',
+ render_context={
+ 'purchase_orders': purchase_order_lines.mapped('order_id'),
+ 'purchase_order_lines': purchase_order_lines,
+ })
+
+
+class PurchaseOrderLine(models.Model):
+ _inherit = 'purchase.order.line'
+
+ sale_order_id = fields.Many2one(related='sale_line_id.order_id', string="Sale Order", store=True, readonly=True)
+ sale_line_id = fields.Many2one('sale.order.line', string="Origin Sale Item", index=True)