from odoo import models, fields, api, _ from urllib.parse import urlencode class SFMessagePurchase(models.Model): _name = 'purchase.order' _inherit = ['purchase.order', 'jikimo.message.dispatch'] def _get_message(self, message_queue_ids): contents = [] process_outsourcing = set() for message_queue_id in message_queue_ids: if message_queue_id.message_template_id.name in ( '坯料采购提醒', '委外加工采购单提醒', '外购订单采购单提醒'): content = message_queue_id.message_template_id.content url = self.request_url(int(message_queue_id.res_id)) purchase_order_line = self.env['purchase.order'].search([('id', '=', int(message_queue_id.res_id))]) content = content.replace('{{name}}', purchase_order_line.name).replace( '{{request_url}}', url) contents.append(content) if message_queue_id.message_template_id.name == '工序外协采购单通知': content = message_queue_id.message_template_id.content purchase_order_line = self.env['purchase.order'].sudo().search( [('id', '=', int(message_queue_id.res_id))]) mrp_production = self.env['mrp.production'].sudo().search([('name', '=', purchase_order_line.origin)]) process_outsourcing.add(mrp_production.product_id.id) if message_queue_id.message_template_id.name in ('采购订单预警提醒', '采购单已逾期提醒'): content = message_queue_id.message_template_id.content if message_queue_id.message_template_id.name == '采购订单预警提醒': domain = [('delivery_warning', '=', 'warning')] action_id = self.env.ref("sf_message.purchase_form_warning_action").id else: domain = [('delivery_warning', '=', 'overdue')] action_id = self.env.ref("sf_message.purchase_form_overdue_action").id purchase_order_num = self.env['purchase.order'].sudo().search_count(domain) if purchase_order_num >= 1: url = self.env['ir.config_parameter'].sudo().get_param('web.base.url') menu_id = self.env.ref('purchase.menu_purchase_form_action').id url_with_id = f"{url}/web#view_type=list&action={action_id}&menu_id={menu_id}" content = content.replace('{{url}}', url_with_id).replace('{{num}}', str(purchase_order_num)) contents.append(content) if process_outsourcing: content_info = content for products_id in process_outsourcing: production_num = 0 product_name = self.env['product.product'].sudo().search([('id', '=', products_id)]).name production_list = self.env['mrp.production'].sudo().search( [('product_id', '=', products_id), ('state', '=', 'confirmed')]) for production_info in production_list: workorder_ids = len(production_info.workorder_ids.filtered( lambda p: p.routing_type == '表面工艺' and p.state != 'cancel')) production_num += workorder_ids if production_num >= 1: url = self.env['ir.config_parameter'].sudo().get_param('web.base.url') action_id = self.env.ref('purchase.purchase_form_action').id url_with_id = f"{url}/web#view_type=list&action={action_id}" new_content = (content_info.replace('{{name}}', product_name) .replace('{{url}}', url_with_id) .replace('{{num}}', str(production_num))) contents.append(new_content) return contents, message_queue_ids def request_url(self, id): url = self.env['ir.config_parameter'].get_param('web.base.url') action_id = self.env.ref('purchase.purchase_form_action').id menu_id = self.env.ref('purchase.menu_purchase_form_action').id # 查询参数 params = {'id': id, 'menu_id': menu_id, 'action': action_id, 'model': 'purchase.order', 'view_type': 'form'} # 拼接查询参数 query_string = urlencode(params) # 拼接URL full_url = url + "/web#" + query_string return full_url def _overdue_or_warning_func(self): last_overdue_order, last_warning_order = super(SFMessagePurchase, self)._overdue_or_warning_func() if last_overdue_order: business_node_id = self.env.ref('sf_message.template_purchase_order_overdue').id purchase_order_has = self._get_message_queue(business_node_id) if not purchase_order_has: last_overdue_order.add_queue("采购单已逾期提醒") if last_warning_order: business_node_id = self.env.ref('sf_message.template_purchase_order_warning').id purchase_order_has = self._get_message_queue(business_node_id) if not purchase_order_has: last_warning_order.add_queue("采购订单预警提醒") def _get_message_queue(self, business_node_id): message_template = self.env["jikimo.message.template"].sudo().search([ ("model", "=", self._name), ("bussiness_node_id", "=", business_node_id) ], limit=1) purchase_order_has = self.env['jikimo.message.queue'].sudo().search([ ('message_status', '=', 'pending'), ('message_template_id', '=', message_template.id) ]) return purchase_order_has