133 lines
4.3 KiB
Python
Raw Normal View History

# Copyright (c) 2015, Frappe Technologies Pvt. Ltd. and Contributors
2014-07-14 19:06:52 +05:30
# License: GNU General Public License v3. See license.txt
from __future__ import unicode_literals
import frappe
2014-07-21 16:13:06 +05:30
from frappe import _
from frappe.utils import flt
2014-07-22 19:02:11 +05:30
from erpnext.accounts.report.financial_statements import (get_period_list, get_columns, get_data)
2014-07-14 19:06:52 +05:30
def execute(filters=None):
period_list = get_period_list(filters.from_fiscal_year, filters.to_fiscal_year, filters.periodicity)
2016-03-23 18:28:50 +05:30
asset = get_data(filters.company, "Asset", "Debit", period_list, only_current_fiscal_year=False)
liability = get_data(filters.company, "Liability", "Credit", period_list, only_current_fiscal_year=False)
equity = get_data(filters.company, "Equity", "Credit", period_list, only_current_fiscal_year=False)
2016-03-23 18:28:50 +05:30
provisional_profit_loss,total_credit = get_provisional_profit_loss(asset, liability, equity,
period_list, filters.company)
2016-03-23 18:28:50 +05:30
message,opening_balance = check_opening_balance(asset, liability, equity)
2014-07-21 16:13:06 +05:30
2014-07-14 19:06:52 +05:30
data = []
2014-07-21 16:13:06 +05:30
data.extend(asset or [])
2016-03-23 18:28:50 +05:30
data.extend(liability or [])
2014-07-21 16:13:06 +05:30
data.extend(equity or [])
if opening_balance and round(opening_balance,2) !=0:
unclosed ={
"account_name": "'" + _("Unclosed Fiscal Years Profit / Loss (Credit)") + "'",
"account": None,
"warn_if_negative": True,
"currency": frappe.db.get_value("Company", filters.company, "default_currency")
}
for period in period_list:
unclosed[period.key] = opening_balance
provisional_profit_loss[period.key] = provisional_profit_loss[period.key] - opening_balance
unclosed["total"]=opening_balance
data.append(unclosed)
2014-07-21 16:13:06 +05:30
if provisional_profit_loss:
data.append(provisional_profit_loss)
2016-10-26 13:05:08 +05:30
if total_credit:
data.append(total_credit)
2014-07-17 19:12:28 +05:30
columns = get_columns(filters.periodicity, period_list, company=filters.company)
chart = get_chart_data(columns, asset, liability, equity)
2014-07-17 19:12:28 +05:30
return columns, data, message, chart
2014-07-17 19:12:28 +05:30
def get_provisional_profit_loss(asset, liability, equity, period_list, company):
2014-07-21 16:13:06 +05:30
if asset and (liability or equity):
2016-09-12 17:43:14 +05:30
total = total_row_total=0
currency = frappe.db.get_value("Company", company, "default_currency")
2014-07-21 16:13:06 +05:30
provisional_profit_loss = {
2015-05-21 13:38:03 +05:30
"account_name": "'" + _("Provisional Profit / Loss (Credit)") + "'",
2014-07-21 16:13:06 +05:30
"account": None,
"warn_if_negative": True,
"currency": currency
}
total_row = {
"account_name": "'" + _("Total (Credit)") + "'",
"account": None,
"warn_if_negative": True,
"currency": currency
2014-07-21 16:13:06 +05:30
}
has_value = False
for period in period_list:
effective_liability = 0.0
if liability:
effective_liability += flt(liability[-2].get(period.key))
2014-07-21 16:13:06 +05:30
if equity:
effective_liability += flt(equity[-2].get(period.key))
2014-07-21 16:13:06 +05:30
provisional_profit_loss[period.key] = flt(asset[-2].get(period.key)) - effective_liability
total_row[period.key] = effective_liability + provisional_profit_loss[period.key]
2014-07-21 16:13:06 +05:30
if provisional_profit_loss[period.key]:
has_value = True
2016-03-23 18:28:50 +05:30
total += flt(provisional_profit_loss[period.key])
provisional_profit_loss["total"] = total
2016-09-12 17:43:14 +05:30
total_row_total += flt(total_row[period.key])
total_row["total"] = total_row_total
2014-07-17 19:12:28 +05:30
2014-07-21 16:13:06 +05:30
if has_value:
return provisional_profit_loss, total_row
return None,total_row
2016-10-26 13:05:08 +05:30
return None, None
def check_opening_balance(asset, liability, equity):
# Check if previous year balance sheet closed
opening_balance = 0
if asset:
opening_balance = flt(asset[0].get("opening_balance", 0))
if liability:
opening_balance -= flt(liability[0].get("opening_balance", 0))
if equity:
2016-09-06 15:44:09 +08:00
opening_balance -= flt(equity[0].get("opening_balance", 0))
2016-03-23 18:28:50 +05:30
if opening_balance:
return _("Previous Financial Year is not closed"),opening_balance
return None,None
def get_chart_data(columns, asset, liability, equity):
x_intervals = ['x'] + [d.get("label") for d in columns[2:]]
2016-05-27 12:21:28 +05:30
asset_data, liability_data, equity_data = [], [], []
for p in columns[2:]:
2016-05-27 12:21:28 +05:30
if asset:
asset_data.append(asset[-2].get(p.get("fieldname")))
if liability:
liability_data.append(liability[-2].get(p.get("fieldname")))
if equity:
equity_data.append(equity[-2].get(p.get("fieldname")))
columns = [x_intervals]
if asset_data:
columns.append(["Assets"] + asset_data)
if liability_data:
columns.append(["Liabilities"] + liability_data)
if equity_data:
columns.append(["Equity"] + equity_data)
return {
"data": {
'x': 'x',
2016-05-27 12:21:28 +05:30
'columns': columns
}
2016-09-06 15:44:09 +08:00
}