Accept Merge Request #1627: (feature/消息提醒优化 -> develop)
Merge Request: 消息提醒 Created By: @管欢 Reviewed By: @胡尧 Approved By: @胡尧 Accepted By: @管欢 URL: https://jikimo-hn.coding.net/p/jikimo_sfs/d/jikimo_sf/git/merge/1627
This commit is contained in:
@@ -318,6 +318,10 @@ class RePurchaseOrder(models.Model):
|
||||
continue
|
||||
purchase.origin_sale_id = False
|
||||
|
||||
delivery_warning = fields.Selection([('normal', '正常'), ('warning', '预警'), ('overdue', '已逾期')],
|
||||
string='交期状态',
|
||||
tracking=True)
|
||||
|
||||
@api.depends('partner_id')
|
||||
def _compute_user_id(self):
|
||||
if not self.user_id:
|
||||
@@ -399,6 +403,27 @@ class RePurchaseOrder(models.Model):
|
||||
|
||||
return result
|
||||
|
||||
# # 采购订单逾期预警和已逾期
|
||||
def _overdue_or_warning_func(self):
|
||||
purchase_order = self.sudo().search(
|
||||
[('state', 'in', ['purchase']), ('date_planned', '!=', False),
|
||||
('receipt_status', 'in', ('partial', 'pending'))])
|
||||
last_overdue_order = None
|
||||
last_warning_order = None
|
||||
for item in purchase_order:
|
||||
current_time = datetime.now()
|
||||
if item.date_planned <= current_time: # 已逾期
|
||||
item.delivery_warning = 'overdue'
|
||||
last_overdue_order = item
|
||||
elif (item.date_planned - current_time).total_seconds() < 48 * 3600: # 预警
|
||||
item.delivery_warning = 'warning'
|
||||
last_warning_order = item
|
||||
purchase_order_done = self.sudo().search([('state', 'in', ['purchase']), ('receipt_status', '=', 'full')])
|
||||
purchase_order_overdue = purchase_order_done.filtered(lambda x: x.delivery_warning in ['overdue', 'warning'])
|
||||
if purchase_order_overdue:
|
||||
purchase_order_overdue.write({'delivery_warning': 'normal'})
|
||||
return last_overdue_order, last_warning_order
|
||||
|
||||
|
||||
class PurchaseOrderLine(models.Model):
|
||||
_inherit = 'purchase.order.line'
|
||||
|
||||
Reference in New Issue
Block a user