# 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 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this program. If not, see . from __future__ import unicode_literals sal_slips_ids = '' for r in res: if not sal_slips_ids == '': sal_slips_ids +="," sal_slips_ids+="'%s'"%r[col_idx['ID']] earn_heads, ded_heads = [], [] if res: earn_heads =[i[0] for i in sql("select distinct e_type from `tabSalary Slip Earning` where parent in (%s)"%sal_slips_ids)] ded_heads =[i[0] for i in sql("select distinct d_type from `tabSalary Slip Deduction` where parent in (%s)"%sal_slips_ids)] col=[] for e in earn_heads: l = (len(cstr(e))*9) if l < 150 : col_width = '150px' else: col_width = '%spx'%(l) col.append([e,'Currency',col_width,'']) col.append(['Arrear Amount','Currency','150px','']) col.append(['Encashment Amount','Currency','170px','']) col.append(['Gross Pay','Currency','150px','']) for d in ded_heads: l = (len(cstr(d))*9) if l < 150 : col_width = '150px' else: col_width = '%spx'%(l) col.append([d,'Currency',col_width,'']) col.append(['Total Deduction','Currency','150px','']) col.append(['Net Pay','Currency','150px','']) for c in col: colnames.append(c[0]) coltypes.append(c[1]) colwidths.append(c[2]) coloptions.append(c[3]) col_idx[c[0]] = len(colnames) grand_tot = 0 for r in res: for i in range(6,len(colnames)): if colnames[i] not in ('Arrear Amount','Encashment Amount','Net Pay','Gross Pay','Total Deduction'): amt = sql("select e_modified_amount from `tabSalary Slip Earning` where e_type = '%s' and parent = '%s'"%(colnames[i],r[0])) if not amt: amt = sql("select d_modified_amount from `tabSalary Slip Deduction` where d_type = '%s' and parent = '%s'"%(colnames[i],r[0])) amt = amt and amt[0][0] or 0 r.append(flt(amt)) else: fld_nm = cstr(colnames[i]).lower().replace(' ','_') tot = sql("select %s from `tabSalary Slip` where name ='%s'"%(fld_nm,r[0])) tot = tot and flt(tot[0][0]) or 0 if colnames[i] == 'Net Pay': grand_tot += tot r.append(tot) gt_row = ['' for i in range(len(colnames))] gt_row[col_idx['Employee Name']] = 'Grand Totals' gt_row[col_idx['Net Pay']-1] = fmt_money(grand_tot) res.append(gt_row)