Merge branch 'master' into edge

This commit is contained in:
Anand Doshi 2013-03-04 17:51:33 +05:30
commit 071a1f548a
3 changed files with 22 additions and 6 deletions

View File

@ -34,11 +34,11 @@ class DocType:
for d in getlist(self.doclist, 'invoice_details'): for d in getlist(self.doclist, 'invoice_details'):
if d.invoice_no: if d.invoice_no:
inv = webnotes.conn.sql("""select c_form_applicable, c_form_no from inv = webnotes.conn.sql("""select c_form_applicable, c_form_no from
`tabSales Invoice` where name = %s""", d.invoice_no) `tabSales Invoice` where name = %s and docstatus = 1""", d.invoice_no)
if not inv: if not inv:
webnotes.msgprint("Invoice: %s is not exists in the system, please check." % webnotes.msgprint("""Invoice: %s is not exists in the system or
d.invoice_no, raise_exception=1) is not submitted, please check.""" % d.invoice_no, raise_exception=1)
elif inv[0][0] != 'Yes': elif inv[0][0] != 'Yes':
webnotes.msgprint("C-form is not applicable for Invoice: %s" % webnotes.msgprint("C-form is not applicable for Invoice: %s" %
@ -52,21 +52,30 @@ class DocType:
def on_update(self): def on_update(self):
""" Update C-Form No on invoices""" """ Update C-Form No on invoices"""
self.set_total_invoiced_amount()
def on_submit(self):
self.set_cform_in_sales_invoices()
def before_cancel(self):
# remove cform reference
webnotes.conn.sql("""update `tabSales Invoice` set c_form_no=null
where c_form_no=%s""", self.doc.name)
def set_cform_in_sales_invoices(self):
inv = [d.invoice_no for d in getlist(self.doclist, 'invoice_details')] inv = [d.invoice_no for d in getlist(self.doclist, 'invoice_details')]
if inv: if inv:
webnotes.conn.sql("""update `tabSales Invoice` set c_form_no=%s, modified=%s webnotes.conn.sql("""update `tabSales Invoice` set c_form_no=%s, modified=%s
where name in (%s)""" % ('%s', '%s', ', '.join(['%s'] * len(inv))), where name in (%s)""" % ('%s', '%s', ', '.join(['%s'] * len(inv))),
tuple([self.doc.name, self.doc.modified] + inv)) tuple([self.doc.name, self.doc.modified] + inv))
webnotes.conn.sql("""update `tabSales Invoice` set c_form_no = '', modified = %s webnotes.conn.sql("""update `tabSales Invoice` set c_form_no = null, modified = %s
where name not in (%s) and ifnull(c_form_no, '') = %s""" % where name not in (%s) and ifnull(c_form_no, '') = %s""" %
('%s', ', '.join(['%s']*len(inv)), '%s'), ('%s', ', '.join(['%s']*len(inv)), '%s'),
tuple([self.doc.modified] + inv + [self.doc.name])) tuple([self.doc.modified] + inv + [self.doc.name]))
else: else:
webnotes.msgprint("Please enter atleast 1 invoice in the table", raise_exception=1) webnotes.msgprint("Please enter atleast 1 invoice in the table", raise_exception=1)
self.set_total_invoiced_amount()
def set_total_invoiced_amount(self): def set_total_invoiced_amount(self):
total = sum([flt(d.grand_total) for d in getlist(self.doclist, 'invoice_details')]) total = sum([flt(d.grand_total) for d in getlist(self.doclist, 'invoice_details')])
webnotes.conn.set(self.doc, 'total_invoiced_amount', total) webnotes.conn.set(self.doc, 'total_invoiced_amount', total)

View File

@ -0,0 +1,6 @@
import webnotes
def execute():
for cform in webnotes.conn.sql("""select name from `tabC-Form` where docstatus=2"""):
webnotes.conn.sql("""update `tabSales Invoice` set c_form_no=null
where c_form_no=%s""", cform[0])

View File

@ -204,4 +204,5 @@ patch_list = [
"patches.march_2013.update_po_prevdoc_doctype", "patches.march_2013.update_po_prevdoc_doctype",
"patches.february_2013.p09_timesheets", "patches.february_2013.p09_timesheets",
"execute:(not webnotes.conn.exists('UOM', 'Hour')) and webnotes.doc({'uom_name': 'Hour', 'doctype': 'UOM', 'name': 'Hour'}).insert()", "execute:(not webnotes.conn.exists('UOM', 'Hour')) and webnotes.doc({'uom_name': 'Hour', 'doctype': 'UOM', 'name': 'Hour'}).insert()",
"patches.march_2013.p01_c_form"
] ]