2018-05-28 11:49:08 +05:30
|
|
|
import frappe
|
|
|
|
|
|
|
|
def execute():
|
|
|
|
frappe.reload_doc('buying', 'doctype', 'purchase_order')
|
|
|
|
frappe.reload_doc('buying', 'doctype', 'supplier_quotation')
|
|
|
|
frappe.reload_doc('selling', 'doctype', 'sales_order')
|
|
|
|
frappe.reload_doc('selling', 'doctype', 'quotation')
|
|
|
|
frappe.reload_doc('stock', 'doctype', 'delivery_note')
|
|
|
|
frappe.reload_doc('stock', 'doctype', 'purchase_receipt')
|
|
|
|
frappe.reload_doc('accounts', 'doctype', 'sales_invoice')
|
|
|
|
frappe.reload_doc('accounts', 'doctype', 'purchase_invoice')
|
2018-09-21 10:20:52 +05:30
|
|
|
|
2018-05-28 11:49:08 +05:30
|
|
|
doctypes = ["Sales Order", "Sales Invoice", "Delivery Note",\
|
|
|
|
"Purchase Order", "Purchase Invoice", "Purchase Receipt", "Quotation", "Supplier Quotation"]
|
|
|
|
|
|
|
|
for doctype in doctypes:
|
2018-06-11 17:32:17 +05:30
|
|
|
total_qty = frappe.db.sql('''
|
|
|
|
SELECT
|
|
|
|
parent, SUM(qty) as qty
|
|
|
|
FROM
|
|
|
|
`tab%s Item`
|
|
|
|
GROUP BY parent
|
|
|
|
''' % (doctype), as_dict = True)
|
|
|
|
|
|
|
|
when_then = []
|
|
|
|
for d in total_qty:
|
|
|
|
when_then.append("""
|
2018-09-21 10:20:52 +05:30
|
|
|
when dt.name = {0} then {1}
|
2018-06-11 17:32:17 +05:30
|
|
|
""".format(frappe.db.escape(d.get("parent")), d.get("qty")))
|
|
|
|
|
2018-06-12 01:16:28 +05:30
|
|
|
if when_then:
|
|
|
|
frappe.db.sql('''
|
|
|
|
UPDATE
|
2018-08-27 16:59:46 +05:30
|
|
|
`tab%s` dt SET dt.total_qty = CASE %s ELSE 0.0 END
|
2018-06-12 01:16:28 +05:30
|
|
|
''' % (doctype, " ".join(when_then)))
|