2012-02-23 12:35:32 +05:30
|
|
|
# ERPNext - web based ERP (http://erpnext.com)
|
|
|
|
# Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
|
|
#
|
|
|
|
# This program is free software: you can redistribute it and/or modify
|
|
|
|
# it under the terms of the GNU General Public License as published by
|
|
|
|
# the Free Software Foundation, either version 3 of the License, or
|
|
|
|
# (at your option) any later version.
|
|
|
|
#
|
|
|
|
# This program is distributed in the hope that it will be useful,
|
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
2012-09-28 16:03:11 +05:30
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
2012-02-23 12:35:32 +05:30
|
|
|
# GNU General Public License for more details.
|
|
|
|
#
|
|
|
|
# You should have received a copy of the GNU General Public License
|
2012-09-28 16:03:11 +05:30
|
|
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
2012-02-23 12:35:32 +05:30
|
|
|
|
2011-06-08 14:37:15 +05:30
|
|
|
#get company letter head
|
2011-09-15 14:03:16 +05:30
|
|
|
#---------------------------------------------------------------------
|
2012-07-19 13:40:31 +05:30
|
|
|
from __future__ import unicode_literals
|
2011-06-08 14:37:15 +05:30
|
|
|
l_head = sql("select content from `tabLetter Head` where ifnull(is_default, 0) = 1 and ifnull(disabled, 0) = 0")
|
|
|
|
l_head = l_head and l_head[0][0] or ''
|
|
|
|
|
2011-09-15 14:03:16 +05:30
|
|
|
|
2011-06-08 14:37:15 +05:30
|
|
|
# Posting date, fiscal year and year start date
|
2011-09-15 14:03:16 +05:30
|
|
|
#---------------------------------------------------------------------
|
2011-06-08 14:37:15 +05:30
|
|
|
if not filter_values.get('posting_date') or not filter_values.get('posting_date1'):
|
2012-09-28 16:03:11 +05:30
|
|
|
msgprint("Please enter From Date and To Date")
|
|
|
|
raise Exception
|
2011-06-08 14:37:15 +05:30
|
|
|
else:
|
2012-09-28 16:03:11 +05:30
|
|
|
from_date = filter_values['posting_date']
|
|
|
|
to_date = filter_values['posting_date1']
|
2011-06-08 14:37:15 +05:30
|
|
|
|
|
|
|
# define columns
|
2011-09-15 14:03:16 +05:30
|
|
|
#---------------------------------------------------------------------
|
2011-06-08 14:37:15 +05:30
|
|
|
col = []
|
|
|
|
col.append(['Date','Date','80px',''])
|
|
|
|
col.append(['Detail','Text','475px',''])
|
|
|
|
col.append(['Debit','Currency','75px',''])
|
|
|
|
col.append(['Credit','Currency','75px',''])
|
|
|
|
|
|
|
|
for c in col:
|
2012-09-28 16:03:11 +05:30
|
|
|
colnames.append(c[0])
|
|
|
|
coltypes.append(c[1])
|
|
|
|
colwidths.append(c[2])
|
|
|
|
coloptions.append(c[3])
|
|
|
|
col_idx[c[0]] = len(colnames)
|
2011-06-08 14:37:15 +05:30
|
|
|
|
|
|
|
|
|
|
|
#total query
|
2011-09-15 14:03:16 +05:30
|
|
|
#---------------------------------------------------------------------
|
|
|
|
total_debit, total_credit, total_opening, total_diff = 0,0,0,0
|
2011-06-08 14:37:15 +05:30
|
|
|
q = query.split('WHERE')[1].split('LIMIT')
|
|
|
|
if len(q) > 2:
|
2012-09-28 16:03:11 +05:30
|
|
|
query_where_clause = 'LIMIT'.join(q[:-1])
|
2011-06-08 14:37:15 +05:30
|
|
|
else:
|
2012-09-28 16:03:11 +05:30
|
|
|
query_where_clause = q[0]
|
2011-06-08 14:37:15 +05:30
|
|
|
|
|
|
|
tot = sql('select sum(debit),sum(credit) from `tabGL Entry` where %s' % query_where_clause)
|
|
|
|
|
|
|
|
for t in tot:
|
2012-09-28 16:03:11 +05:30
|
|
|
total_debit += t and flt(t[0]) or 0
|
|
|
|
total_credit += t and flt(t[1]) or 0
|
2011-06-08 14:37:15 +05:30
|
|
|
|
|
|
|
total_diff = total_debit - total_credit
|
|
|
|
|
|
|
|
out = []
|
2011-09-02 16:55:03 +05:30
|
|
|
|
|
|
|
|
2011-09-15 14:03:16 +05:30
|
|
|
# If account mentioned, show opening and closing
|
|
|
|
#---------------------------------------------------------------------
|
|
|
|
account = filter_values.get('account')
|
|
|
|
|
|
|
|
if account and (total_debit != 0 or total_credit != 0):
|
|
|
|
acc_det = sql("select debit_or_credit, is_pl_account, lft, rgt, group_or_ledger from tabAccount where name = '%s'" % account)
|
|
|
|
|
2012-09-28 16:03:11 +05:30
|
|
|
from accounts.utils import get_balance_on
|
|
|
|
opening_bal = get_balance_on(account, add_days(from_date, -1))
|
|
|
|
closing_bal = get_balance_on(account, to_date)
|
2011-09-15 14:03:16 +05:30
|
|
|
|
|
|
|
if acc_det[0][0] == 'Credit':
|
2012-09-28 16:03:11 +05:30
|
|
|
closing_bal = -1*closing_bal
|
|
|
|
opening_bal = -1*opening_bal
|
2011-09-15 14:03:16 +05:30
|
|
|
|
|
|
|
# add opening row
|
|
|
|
t_row = ['' for i in range(len(colnames))]
|
|
|
|
t_row[1] = 'Opening as on '+formatdate(from_date)
|
|
|
|
t_row[col_idx['Debit']-1] = opening_bal
|
|
|
|
out.append(t_row)
|
|
|
|
|
|
|
|
|
|
|
|
# table output
|
|
|
|
#---------------------------------------------------------------------
|
2011-06-08 14:37:15 +05:30
|
|
|
count = 0
|
|
|
|
for r in res:
|
2012-09-28 16:03:11 +05:30
|
|
|
count +=1
|
|
|
|
det = r[1].split('~~~')
|
|
|
|
if from_export == 1:
|
|
|
|
a = "Account: " + det[0] + NEWLINE + det[1] + NEWLINE + "Against: " + det[2] + NEWLINE + "Voucher No: " + det[4]
|
|
|
|
else:
|
|
|
|
a = "Account: <b>" + det[0]+ "</b>" + NEWLINE + "<div class='comment'>" +det[1]+ "</div><div class = 'comment' style='padding-left:12px'>Against: <b>" + det[2] + "</b></div><div class = 'comment' style='padding-left:12px'>Voucher No: <span class='link_type' onclick='loaddoc(" + '"' + det[3] +'", ' + '"' + det[4] +'"' + ")'>" + det[4] + "</span></div>"
|
|
|
|
r[1] = a
|
|
|
|
out.append(r)
|
2011-06-08 14:37:15 +05:30
|
|
|
|
2011-09-15 14:03:16 +05:30
|
|
|
|
|
|
|
# Total, Difference and closing balance
|
|
|
|
#---------------------------------------------------------------------
|
2011-06-08 14:37:15 +05:30
|
|
|
if total_debit != 0 or total_credit != 0:
|
2012-09-28 16:03:11 +05:30
|
|
|
# Total debit/credit
|
|
|
|
t_row = ['' for i in range(len(colnames))]
|
|
|
|
t_row[1] = 'Total'
|
|
|
|
t_row[col_idx['Debit']-1] = total_debit
|
|
|
|
t_row[col_idx['Credit']-1] = total_credit
|
|
|
|
out.append(t_row)
|
|
|
|
|
|
|
|
# diffrence (dr-cr)
|
|
|
|
t_row = ['' for i in range(len(colnames))]
|
|
|
|
t_row[1] = 'Total(Dr-Cr)'
|
|
|
|
t_row[col_idx['Debit']-1] = total_diff
|
|
|
|
out.append(t_row)
|
|
|
|
|
|
|
|
# closing
|
|
|
|
if account:
|
|
|
|
t_row = ['' for i in range(len(colnames))]
|
|
|
|
t_row[1] = 'Closing Balance on ' + formatdate(to_date)
|
|
|
|
t_row[col_idx['Debit']-1] = flt(closing_bal)
|
|
|
|
out.append(t_row)
|
2011-09-02 16:55:03 +05:30
|
|
|
|
2011-09-15 14:03:16 +05:30
|
|
|
|
2011-06-08 14:37:15 +05:30
|
|
|
# Print Format
|
2011-09-15 14:03:16 +05:30
|
|
|
#---------------------------------------------------------------------
|
2011-06-08 14:37:15 +05:30
|
|
|
myheader = """<table width = '100%%'><tr><td>"""+l_head+"""</td>
|
|
|
|
</tr>
|
|
|
|
<tr> <td>
|
|
|
|
<div><h3> %(acc)s </h3></div>
|
|
|
|
<div>Ledger Between %(fdt)s and %(tdt)s </div></td></tr></table><br>
|
|
|
|
|
2012-09-28 16:03:11 +05:30
|
|
|
""" % {'acc':account,
|
|
|
|
'fdt':from_date,
|
|
|
|
'tdt':to_date}
|
2011-09-02 16:55:03 +05:30
|
|
|
|
2011-06-08 14:37:15 +05:30
|
|
|
page_template = myheader+"<div>%(table)s</div>"
|