mirror of
https://github.com/frappe/erpnext.git
synced 2026-04-28 19:18:32 +00:00
Lease Agreement
Used by leasing and loan agents (i.e. Automobile leasing etc) for receipt follow up and reporting Account Transactions Upload Uploads transactions from a csv files, creates Journal Vouchers and submits
This commit is contained in:
@@ -0,0 +1,18 @@
|
||||
|
||||
//--------- ONLOAD -------------
|
||||
cur_frm.cscript.onload = function(doc, cdt, cdn) {
|
||||
}
|
||||
|
||||
cur_frm.cscript.refresh = function(doc, cdt, cdn) {
|
||||
if(!doc.file_list) {
|
||||
set_field_options('Upload Accounts Transactions Help', '<div class="help_box">To upload transactions, please attach a (.csv) file with 5 columns - <b>Date, Transaction Number, Account, Debit Amount, Credit Amount</b> (no headings necessary). See attachments box in the right column</div>')
|
||||
} else {
|
||||
set_field_options('Upload Accounts Transactions Help', '<div class="help_box">To update transactions from the attachment, please click on "Upload Accounts Transactions"</div>')
|
||||
}
|
||||
}
|
||||
|
||||
cur_frm.cscript['Upload Accounts Transactions'] = function(doc, cdt, cdn) {
|
||||
if(confirm("This action will append all transactions and cannot be un-done. Are you sure you want to continue?")) {
|
||||
$c_obj([doc], 'upload_accounts_transactions', '', function(r, rt) { });
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,103 @@
|
||||
# Please edit this list and import only required elements
|
||||
import webnotes
|
||||
|
||||
from webnotes.utils import add_days, add_months, add_years, cint, cstr, date_diff, default_fields, flt, fmt_money, formatdate, generate_hash, getTraceback, get_defaults, get_first_day, get_last_day, getdate, has_common, month_name, now, nowdate, replace_newlines, sendmail, set_default, str_esc_quote, user_format, validate_email_add
|
||||
from webnotes.model import db_exists
|
||||
from webnotes.model.doc import Document, addchild, removechild, getchildren, make_autoname, SuperDocType
|
||||
from webnotes.model.doclist import getlist, copy_doclist
|
||||
from webnotes.model.code import get_obj, get_server_obj, run_server_obj, updatedb, check_syntax
|
||||
from webnotes import session, form, is_testing, msgprint, errprint
|
||||
|
||||
set = webnotes.conn.set
|
||||
sql = webnotes.conn.sql
|
||||
get_value = webnotes.conn.get_value
|
||||
in_transaction = webnotes.conn.in_transaction
|
||||
convert_to_lists = webnotes.conn.convert_to_lists
|
||||
|
||||
# -----------------------------------------------------------------------------------------
|
||||
|
||||
class DocType:
|
||||
def __init__(self, d, dl):
|
||||
self.doc, self.doclist = d, dl
|
||||
self.cl = []
|
||||
|
||||
# upload transactions
|
||||
def upload_accounts_transactions(self):
|
||||
import csv
|
||||
data = csv.reader(self.get_csv_data().splitlines())
|
||||
|
||||
abbr = sql("select concat(' - ',abbr) as abbr from tabCompany where name=%s",self.doc.company)
|
||||
updated = 0
|
||||
jv_name=''
|
||||
# jv = Document('Journal Voucher')
|
||||
global line,jv,name,jv_go
|
||||
for line in data:
|
||||
if len(line)>=7: #Minimum no of fields
|
||||
if line[3]!=jv_name: #Create JV
|
||||
if jv_name!='':
|
||||
jv_go = get_obj('Journal Voucher',name, with_children=1)
|
||||
jv_go.validate()
|
||||
jv_go.on_submit()
|
||||
|
||||
jv_name=line[3]
|
||||
jv = Document('Journal Voucher')
|
||||
jv.voucher_type = line[0]
|
||||
jv.naming_series = line[1]
|
||||
jv.voucher_date = formatdate(line[2])
|
||||
jv.posting_date = formatdate(line[2])
|
||||
# jv.name = line[3]
|
||||
jv.fiscal_year = self.doc.fiscal_year
|
||||
jv.company = self.doc.company
|
||||
jv.remark = len(line)==8 and line[3]+' '+line[7] or line[3]+' Uploaded Record'
|
||||
jv.docstatus=1
|
||||
jv.save(1)
|
||||
name=jv.name
|
||||
|
||||
jc = addchild(jv,'entries','Journal Voucher Detail',0)
|
||||
jc.account = line[4]+abbr[0][0]
|
||||
jc.cost_center=len(line)==9 and line[8] or self.doc.default_cost_center
|
||||
if line[5]!='':
|
||||
jc.debit = line[5]
|
||||
else:
|
||||
jc.credit = line[6]
|
||||
jc.save()
|
||||
|
||||
else: #Create JV Child
|
||||
jc = addchild(jv,'entries','Journal Voucher Detail',0)
|
||||
jc.account = line[4]+abbr[0][0]
|
||||
jc.cost_center=len(line)==9 and line[8] or self.doc.default_cost_center
|
||||
if line[5]!='':
|
||||
jc.debit = line[5]
|
||||
else:
|
||||
jc.credit = line[6]
|
||||
jc.save()
|
||||
else:
|
||||
msgprint("[Ignored] Incorrect format: %s" % str(line))
|
||||
if jv_name!='':
|
||||
jv_go = get_obj('Journal Voucher',name, with_children=1)
|
||||
jv_go.validate()
|
||||
jv_go.on_submit()
|
||||
|
||||
msgprint("<b>%s</b> items updated" % updated)
|
||||
|
||||
# clear prices
|
||||
def clear_prices(self):
|
||||
cnt = sql("select count(*) from `tabRef Rate Detail` where price_list_name = %s", self.doc.name)
|
||||
sql("delete from `tabRef Rate Detail` where price_list_name = %s", self.doc.name)
|
||||
msgprint("%s prices cleared" % cnt[0][0])
|
||||
|
||||
# Update CSV data
|
||||
def get_csv_data(self):
|
||||
if not self.doc.file_list:
|
||||
msgprint("File not attached!")
|
||||
raise Exception
|
||||
|
||||
fid = self.doc.file_list.split(',')[1]
|
||||
|
||||
from webnotes.utils import file_manager
|
||||
fn, content = file_manager.get_file(fid)
|
||||
|
||||
if not type(content) == str:
|
||||
content = content.tostring()
|
||||
|
||||
return content
|
||||
Reference in New Issue
Block a user