2019-01-03 18:52:25 +05:30
|
|
|
# Copyright (c) 2013, Frappe Technologies Pvt. Ltd. and contributors
|
|
|
|
# For license information, please see license.txt
|
|
|
|
|
2021-09-02 16:44:59 +05:30
|
|
|
|
2019-01-03 18:52:25 +05:30
|
|
|
import frappe
|
|
|
|
from frappe import _
|
2021-09-02 16:44:59 +05:30
|
|
|
|
2019-01-03 18:52:25 +05:30
|
|
|
from erpnext.accounts.utils import get_balance_on
|
|
|
|
|
2021-09-02 16:44:59 +05:30
|
|
|
|
2019-01-03 18:52:25 +05:30
|
|
|
def execute(filters=None):
|
|
|
|
filters = frappe._dict(filters or {})
|
|
|
|
columns = get_columns(filters)
|
|
|
|
data = get_data(filters)
|
|
|
|
return columns, data
|
|
|
|
|
2022-03-28 18:52:46 +05:30
|
|
|
|
2019-01-03 18:52:25 +05:30
|
|
|
def get_columns(filters):
|
|
|
|
columns = [
|
|
|
|
{
|
|
|
|
"label": _("Account"),
|
|
|
|
"fieldtype": "Link",
|
|
|
|
"fieldname": "account",
|
|
|
|
"options": "Account",
|
|
|
|
"width": 100,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"label": _("Currency"),
|
|
|
|
"fieldtype": "Link",
|
|
|
|
"fieldname": "currency",
|
|
|
|
"options": "Currency",
|
|
|
|
"hidden": 1,
|
|
|
|
"width": 50,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"label": _("Balance"),
|
|
|
|
"fieldtype": "Currency",
|
|
|
|
"fieldname": "balance",
|
|
|
|
"options": "currency",
|
|
|
|
"width": 100,
|
|
|
|
},
|
|
|
|
]
|
|
|
|
|
|
|
|
return columns
|
|
|
|
|
2022-03-28 18:52:46 +05:30
|
|
|
|
2019-01-03 18:52:25 +05:30
|
|
|
def get_conditions(filters):
|
|
|
|
conditions = {}
|
|
|
|
|
|
|
|
if filters.account_type:
|
|
|
|
conditions["account_type"] = filters.account_type
|
|
|
|
return conditions
|
|
|
|
|
|
|
|
if filters.company:
|
|
|
|
conditions["company"] = filters.company
|
|
|
|
|
|
|
|
if filters.root_type:
|
|
|
|
conditions["root_type"] = filters.root_type
|
|
|
|
|
|
|
|
return conditions
|
|
|
|
|
2022-03-28 18:52:46 +05:30
|
|
|
|
2019-01-03 18:52:25 +05:30
|
|
|
def get_data(filters):
|
|
|
|
|
|
|
|
data = []
|
|
|
|
conditions = get_conditions(filters)
|
|
|
|
accounts = frappe.db.get_all(
|
|
|
|
"Account", fields=["name", "account_currency"], filters=conditions, order_by="name"
|
2021-06-10 18:09:49 +05:30
|
|
|
)
|
2019-01-03 18:52:25 +05:30
|
|
|
|
|
|
|
for d in accounts:
|
|
|
|
balance = get_balance_on(d.name, date=filters.report_date)
|
|
|
|
row = {"account": d.name, "balance": balance, "currency": d.account_currency}
|
|
|
|
|
|
|
|
data.append(row)
|
|
|
|
|
|
|
|
return data
|