brotherton-erpnext/erpnext/accounts/page/accounts_browser/accounts_browser.py

58 lines
2.0 KiB
Python
Raw Normal View History

# Copyright (c) 2015, Frappe Technologies Pvt. Ltd. and Contributors
# License: GNU General Public License v3. See license.txt
from __future__ import unicode_literals
2014-02-14 10:17:51 +00:00
import frappe
import frappe.defaults
from frappe.utils import flt
from erpnext.accounts.utils import get_balance_on
from erpnext.accounts.report.financial_statements import sort_root_accounts
2012-04-13 13:34:55 +00:00
2014-02-14 10:17:51 +00:00
@frappe.whitelist()
2012-04-13 13:34:55 +00:00
def get_companies():
"""get a list of companies based on permission"""
return [d.name for d in frappe.get_list("Company", fields=["name"],
order_by="name")]
2012-12-05 08:57:50 +00:00
2014-02-14 10:17:51 +00:00
@frappe.whitelist()
2012-04-13 13:34:55 +00:00
def get_children():
2014-02-14 10:17:51 +00:00
args = frappe.local.form_dict
2012-05-22 11:24:46 +00:00
ctype, company = args['ctype'], args['comp']
2015-12-15 06:36:37 +00:00
fieldname = frappe.db.escape(ctype.lower().replace(' ','_'))
doctype = frappe.db.escape(ctype)
2012-04-13 13:34:55 +00:00
# root
2013-06-24 10:13:18 +00:00
if args['parent'] in ("Accounts", "Cost Centers"):
2015-12-15 06:36:37 +00:00
fields = ", root_type, report_type, account_currency" if ctype=="Account" else ""
acc = frappe.db.sql(""" select
2015-12-15 06:36:37 +00:00
name as value, is_group as expandable {fields}
from `tab{doctype}`
where ifnull(`parent_{fieldname}`,'') = ''
and `company` = %s and docstatus<2
2015-12-15 06:36:37 +00:00
order by name""".format(fields=fields, fieldname = fieldname, doctype=doctype),
2013-06-24 10:13:18 +00:00
company, as_dict=1)
if args["parent"]=="Accounts":
sort_root_accounts(acc)
else:
2012-05-22 11:24:46 +00:00
# other
2015-12-15 06:36:37 +00:00
fields = ", account_currency" if ctype=="Account" else ""
acc = frappe.db.sql("""select
2015-12-15 06:36:37 +00:00
name as value, is_group as expandable, parent_{fieldname} as parent {fields}
from `tab{doctype}`
where ifnull(`parent_{fieldname}`,'') = %s
and docstatus<2
2015-12-15 06:36:37 +00:00
order by name""".format(fields=fields, fieldname=fieldname, doctype=doctype),
2012-05-22 11:24:46 +00:00
args['parent'], as_dict=1)
2012-05-22 11:24:46 +00:00
if ctype == 'Account':
company_currency = frappe.db.get_value("Company", company, "default_currency")
2012-05-22 11:24:46 +00:00
for each in acc:
each["company_currency"] = company_currency
each["balance"] = flt(get_balance_on(each.get("value"), in_account_currency=False))
2015-12-15 06:36:37 +00:00
if each.account_currency != company_currency:
each["balance_in_account_currency"] = flt(get_balance_on(each.get("value")))
2012-05-22 11:24:46 +00:00
return acc