From 3fe9795020c42f5db2fa4937eed0b4d43b855d14 Mon Sep 17 00:00:00 2001 From: Anand Doshi Date: Wed, 14 Dec 2011 20:00:55 +0530 Subject: [PATCH 1/2] Resolved bug: if account of type 'Bank or Cash' does not exists, then it shows error in the email digest email but does not raise exception --- .../doctype/email_digest/email_digest.py | 64 ++++++++++--------- 1 file changed, 35 insertions(+), 29 deletions(-) diff --git a/erpnext/setup/doctype/email_digest/email_digest.py b/erpnext/setup/doctype/email_digest/email_digest.py index 53304cf6a3..4e5a27b1a7 100644 --- a/erpnext/setup/doctype/email_digest/email_digest.py +++ b/erpnext/setup/doctype/email_digest/email_digest.py @@ -110,19 +110,19 @@ class DocType: for query in query_dict.keys(): if self.doc.fields[query]: - #webnotes.msgprint(query) - res = webnotes.conn.sql(query_dict[query], as_dict=1) - if query == 'income': - for r in res: - r['value'] = float(r['credit'] - r['debit']) - elif query in ['expenses_booked', 'bank_balance']: - for r in res: - r['value'] = float(r['debit'] - r['credit']) - #webnotes.msgprint(query) - #webnotes.msgprint(res) - result[query] = (res and len(res)==1) and res[0] or (res and res or None) + if query_dict[query]: + #webnotes.msgprint(query) + res = webnotes.conn.sql(query_dict[query], as_dict=1) + if query == 'income': + for r in res: + r['value'] = float(r['credit'] - r['debit']) + elif query in ['expenses_booked', 'bank_balance']: + for r in res: + r['value'] = float(r['debit'] - r['credit']) + #webnotes.msgprint(query) + #webnotes.msgprint(res) + result[query] = (res and len(res)==1) and res[0] or (res and res or None) - #webnotes.msgprint(result) return result @@ -149,18 +149,19 @@ class DocType: elif args['type'] in ['collections', 'payments']: args['bc_accounts_regex'] = self.get_bc_accounts_regex() - query = """ - SELECT - IFNULL(SUM(IFNULL(gle.%(field)s, 0)), 0) AS '%(field)s', - %(common_select)s - FROM - %(common_from)s - WHERE - %(common_where)s AND - ac.master_type = '%(master_type)s' AND - gle.against REGEXP '%(bc_accounts_regex)s' AND - %(start_date_condition)s AND - %(end_date_condition)s""" % args + if args['bc_accounts_regex']: + query = """ + SELECT + IFNULL(SUM(IFNULL(gle.%(field)s, 0)), 0) AS '%(field)s', + %(common_select)s + FROM + %(common_from)s + WHERE + %(common_where)s AND + ac.master_type = '%(master_type)s' AND + gle.against REGEXP '%(bc_accounts_regex)s' AND + %(start_date_condition)s AND + %(end_date_condition)s""" % args elif args['type'] in ['income', 'expenses_booked']: query = """ @@ -307,7 +308,8 @@ class DocType: FROM `tabAccount` WHERE account_type = 'Bank or Cash'""", as_list=1) - return '(' + '|'.join([ac[0] for ac in bc_account_list]) + ')' + if bc_account_list: + return '(' + '|'.join([ac[0] for ac in bc_account_list]) + ')' def get(self): @@ -653,13 +655,17 @@ class DocType: # Sort these keys depending on idx value bd_keys = sorted(body_dict, key=lambda x: body_dict[x]['idx']) - for k in bd_keys: if self.doc.fields[k]: - table_list.append(body_dict[k]['table']) + if k in result: + table_list.append(body_dict[k]['table']) + elif k in ['collections', 'payments']: + table_list.append(\ + "
[" + \ + k.capitalize() + \ + "]
Missing: Ledger of type 'Bank or Cash'\ +
") - result = [] - i = 0 result = [] op_len = len(table_list) From ddf4c2655d9ec779a2c22603e465c17708b68fe8 Mon Sep 17 00:00:00 2001 From: Anand Doshi Date: Wed, 14 Dec 2011 20:00:55 +0530 Subject: [PATCH 2/2] Resolved bug: if account of type 'Bank or Cash' does not exists, then it shows error in the email digest email but does not raise exception --- .../doctype/email_digest/email_digest.py | 43 +++++++++++-------- 1 file changed, 24 insertions(+), 19 deletions(-) diff --git a/erpnext/setup/doctype/email_digest/email_digest.py b/erpnext/setup/doctype/email_digest/email_digest.py index 53304cf6a3..7ba3a90d54 100644 --- a/erpnext/setup/doctype/email_digest/email_digest.py +++ b/erpnext/setup/doctype/email_digest/email_digest.py @@ -109,7 +109,7 @@ class DocType: result = {} for query in query_dict.keys(): - if self.doc.fields[query]: + if self.doc.fields[query] and query_dict[query]: #webnotes.msgprint(query) res = webnotes.conn.sql(query_dict[query], as_dict=1) if query == 'income': @@ -122,7 +122,6 @@ class DocType: #webnotes.msgprint(res) result[query] = (res and len(res)==1) and res[0] or (res and res or None) - #webnotes.msgprint(result) return result @@ -149,18 +148,19 @@ class DocType: elif args['type'] in ['collections', 'payments']: args['bc_accounts_regex'] = self.get_bc_accounts_regex() - query = """ - SELECT - IFNULL(SUM(IFNULL(gle.%(field)s, 0)), 0) AS '%(field)s', - %(common_select)s - FROM - %(common_from)s - WHERE - %(common_where)s AND - ac.master_type = '%(master_type)s' AND - gle.against REGEXP '%(bc_accounts_regex)s' AND - %(start_date_condition)s AND - %(end_date_condition)s""" % args + if args['bc_accounts_regex']: + query = """ + SELECT + IFNULL(SUM(IFNULL(gle.%(field)s, 0)), 0) AS '%(field)s', + %(common_select)s + FROM + %(common_from)s + WHERE + %(common_where)s AND + ac.master_type = '%(master_type)s' AND + gle.against REGEXP '%(bc_accounts_regex)s' AND + %(start_date_condition)s AND + %(end_date_condition)s""" % args elif args['type'] in ['income', 'expenses_booked']: query = """ @@ -307,7 +307,8 @@ class DocType: FROM `tabAccount` WHERE account_type = 'Bank or Cash'""", as_list=1) - return '(' + '|'.join([ac[0] for ac in bc_account_list]) + ')' + if bc_account_list: + return '(' + '|'.join([ac[0] for ac in bc_account_list]) + ')' def get(self): @@ -653,13 +654,17 @@ class DocType: # Sort these keys depending on idx value bd_keys = sorted(body_dict, key=lambda x: body_dict[x]['idx']) - for k in bd_keys: if self.doc.fields[k]: - table_list.append(body_dict[k]['table']) + if k in result: + table_list.append(body_dict[k]['table']) + elif k in ['collections', 'payments']: + table_list.append(\ + "
[" + \ + k.capitalize() + \ + "]
Missing: Ledger of type 'Bank or Cash'\ +
") - result = [] - i = 0 result = [] op_len = len(table_list)