2016-08-24 16:22:30 +05:30
|
|
|
// Copyright (c) 2016, Frappe Technologies Pvt. Ltd. and contributors
|
|
|
|
// For license information, please see license.txt
|
|
|
|
|
|
|
|
frappe.require("assets/erpnext/js/financial_statements.js", function() {
|
|
|
|
frappe.query_reports["Profitability Analysis"] = {
|
|
|
|
"filters": [
|
|
|
|
{
|
|
|
|
"fieldname": "company",
|
|
|
|
"label": __("Company"),
|
|
|
|
"fieldtype": "Link",
|
|
|
|
"options": "Company",
|
|
|
|
"default": frappe.defaults.get_user_default("Company"),
|
|
|
|
"reqd": 1
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"fieldname": "based_on",
|
2016-09-23 21:51:51 +05:30
|
|
|
"label": __("Based On"),
|
2016-08-24 16:22:30 +05:30
|
|
|
"fieldtype": "Select",
|
2023-07-12 10:00:18 +05:30
|
|
|
"options": ["Cost Center", "Project", "Accounting Dimension"],
|
2016-08-24 16:22:30 +05:30
|
|
|
"default": "Cost Center",
|
2023-07-12 20:32:08 +05:30
|
|
|
"reqd": 1,
|
|
|
|
"on_change": function(query_report){
|
|
|
|
let based_on = query_report.get_values().based_on;
|
|
|
|
if(based_on!='Accounting Dimension'){
|
|
|
|
frappe.query_report.set_filter_value({
|
|
|
|
accounting_dimension: ''
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
2016-08-24 16:22:30 +05:30
|
|
|
},
|
2023-07-12 10:00:18 +05:30
|
|
|
{
|
|
|
|
"fieldname": "accounting_dimension",
|
|
|
|
"label": __("Accounting Dimension"),
|
|
|
|
"fieldtype": "Link",
|
|
|
|
"options": "Accounting Dimension",
|
|
|
|
"get_query": () =>{
|
|
|
|
return {
|
|
|
|
filters: {
|
|
|
|
"disabled": 0
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2016-08-24 16:22:30 +05:30
|
|
|
},
|
|
|
|
{
|
|
|
|
"fieldname": "fiscal_year",
|
|
|
|
"label": __("Fiscal Year"),
|
|
|
|
"fieldtype": "Link",
|
|
|
|
"options": "Fiscal Year",
|
2023-07-16 12:58:42 +05:30
|
|
|
"default": erpnext.utils.get_fiscal_year(frappe.datetime.get_today()),
|
2016-08-24 16:22:30 +05:30
|
|
|
"reqd": 1,
|
|
|
|
"on_change": function(query_report) {
|
|
|
|
var fiscal_year = query_report.get_values().fiscal_year;
|
|
|
|
if (!fiscal_year) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
frappe.model.with_doc("Fiscal Year", fiscal_year, function(r) {
|
|
|
|
var fy = frappe.model.get_doc("Fiscal Year", fiscal_year);
|
2018-07-18 09:28:44 +05:30
|
|
|
frappe.query_report.set_filter_value({
|
|
|
|
from_date: fy.year_start_date,
|
|
|
|
to_date: fy.year_end_date
|
|
|
|
});
|
2016-08-24 16:22:30 +05:30
|
|
|
});
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"fieldname": "from_date",
|
|
|
|
"label": __("From Date"),
|
|
|
|
"fieldtype": "Date",
|
2023-07-27 21:03:32 +05:30
|
|
|
"default": erpnext.utils.get_fiscal_year(frappe.datetime.get_today(), true)[1],
|
2016-08-24 16:22:30 +05:30
|
|
|
},
|
|
|
|
{
|
|
|
|
"fieldname": "to_date",
|
|
|
|
"label": __("To Date"),
|
|
|
|
"fieldtype": "Date",
|
2023-07-27 21:03:32 +05:30
|
|
|
"default": erpnext.utils.get_fiscal_year(frappe.datetime.get_today(), true)[2],
|
2016-08-24 17:56:09 +05:30
|
|
|
},
|
|
|
|
{
|
|
|
|
"fieldname": "show_zero_values",
|
|
|
|
"label": __("Show zero values"),
|
|
|
|
"fieldtype": "Check"
|
2016-08-24 16:22:30 +05:30
|
|
|
}
|
|
|
|
],
|
2018-07-20 15:11:55 +05:30
|
|
|
"formatter": function(value, row, column, data, default_formatter) {
|
|
|
|
if (column.fieldname=="account") {
|
|
|
|
value = data.account_name;
|
2016-08-24 19:12:14 +05:30
|
|
|
|
2018-07-20 15:11:55 +05:30
|
|
|
column.link_onclick =
|
|
|
|
"frappe.query_reports['Profitability Analysis'].open_profit_and_loss_statement(" + JSON.stringify(data) + ")";
|
|
|
|
column.is_tree = true;
|
2016-08-24 19:12:14 +05:30
|
|
|
}
|
|
|
|
|
2018-07-20 15:11:55 +05:30
|
|
|
value = default_formatter(value, row, column, data);
|
2016-08-24 19:12:14 +05:30
|
|
|
|
2018-07-20 15:11:55 +05:30
|
|
|
if (!data.parent_account && data.based_on != 'project') {
|
|
|
|
value = $(`<span>${value}</span>`);
|
2016-08-24 19:12:14 +05:30
|
|
|
var $value = $(value).css("font-weight", "bold");
|
2018-07-20 16:35:51 +05:30
|
|
|
if (data.warn_if_negative && data[column.fieldname] < 0) {
|
2016-08-24 19:12:14 +05:30
|
|
|
$value.addClass("text-danger");
|
|
|
|
}
|
|
|
|
|
|
|
|
value = $value.wrap("<p></p>").parent().html();
|
|
|
|
}
|
|
|
|
|
|
|
|
return value;
|
|
|
|
},
|
|
|
|
"open_profit_and_loss_statement": function(data) {
|
|
|
|
if (!data.account) return;
|
|
|
|
|
|
|
|
frappe.route_options = {
|
2018-07-18 09:28:44 +05:30
|
|
|
"company": frappe.query_report.get_filter_value('company'),
|
2016-08-24 19:12:14 +05:30
|
|
|
"from_fiscal_year": data.fiscal_year,
|
|
|
|
"to_fiscal_year": data.fiscal_year
|
|
|
|
};
|
|
|
|
|
|
|
|
if(data.based_on == 'cost_center'){
|
|
|
|
frappe.route_options["cost_center"] = data.account
|
|
|
|
} else {
|
|
|
|
frappe.route_options["project"] = data.account
|
|
|
|
}
|
|
|
|
|
|
|
|
frappe.set_route("query-report", "Profit and Loss Statement");
|
|
|
|
},
|
2016-08-24 16:22:30 +05:30
|
|
|
"tree": true,
|
|
|
|
"name_field": "account",
|
|
|
|
"parent_field": "parent_account",
|
|
|
|
"initial_depth": 3
|
|
|
|
}
|
|
|
|
|
2019-07-18 08:54:15 +05:30
|
|
|
erpnext.dimension_filters.forEach((dimension) => {
|
2019-07-17 15:38:21 +05:30
|
|
|
frappe.query_reports["Profitability Analysis"].filters[1].options.push(dimension["document_type"]);
|
2019-07-07 21:24:45 +05:30
|
|
|
});
|
2019-07-17 15:38:21 +05:30
|
|
|
|
2019-07-07 21:24:45 +05:30
|
|
|
});
|