100 lines
5.7 KiB
Python
100 lines
5.7 KiB
Python
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
|