2020-04-23 15:15:52 +05:30
|
|
|
import frappe
|
|
|
|
|
|
|
|
def execute():
|
|
|
|
# fixes status of quotations which have status 'Expired' despite having valid sales order created
|
|
|
|
|
|
|
|
# filter out submitted expired quotations which has sales order created
|
|
|
|
cond = "qo.docstatus = 1 and qo.status = 'Expired'"
|
|
|
|
invalid_so_against_quo = """
|
|
|
|
SELECT
|
|
|
|
so.name FROM `tabSales Order` so, `tabSales Order Item` so_item
|
|
|
|
WHERE
|
|
|
|
so_item.docstatus = 1 and so.docstatus = 1
|
|
|
|
and so_item.parent = so.name
|
|
|
|
and so_item.prevdoc_docname = qo.name
|
|
|
|
and qo.valid_till < so.transaction_date""" # check if SO was created after quotation expired
|
2021-08-19 13:41:10 +05:30
|
|
|
|
2020-04-23 15:15:52 +05:30
|
|
|
frappe.db.sql(
|
2020-04-26 17:30:23 +05:30
|
|
|
"""UPDATE `tabQuotation` qo SET qo.status = 'Expired' WHERE {cond} and exists({invalid_so_against_quo})"""
|
2020-04-24 13:47:44 +05:30
|
|
|
.format(cond=cond, invalid_so_against_quo=invalid_so_against_quo)
|
2020-04-23 15:15:52 +05:30
|
|
|
)
|
2021-08-19 13:41:10 +05:30
|
|
|
|
2020-04-23 15:15:52 +05:30
|
|
|
valid_so_against_quo = """
|
|
|
|
SELECT
|
|
|
|
so.name FROM `tabSales Order` so, `tabSales Order Item` so_item
|
|
|
|
WHERE
|
|
|
|
so_item.docstatus = 1 and so.docstatus = 1
|
|
|
|
and so_item.parent = so.name
|
|
|
|
and so_item.prevdoc_docname = qo.name
|
|
|
|
and qo.valid_till >= so.transaction_date""" # check if SO was created before quotation expired
|
|
|
|
|
|
|
|
frappe.db.sql(
|
2020-04-26 17:30:23 +05:30
|
|
|
"""UPDATE `tabQuotation` qo SET qo.status = 'Closed' WHERE {cond} and exists({valid_so_against_quo})"""
|
2020-04-24 13:47:44 +05:30
|
|
|
.format(cond=cond, valid_so_against_quo=valid_so_against_quo)
|
2020-04-23 15:15:52 +05:30
|
|
|
)
|