// 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", "label": __("Based On"), "fieldtype": "Select", "options": ["Cost Center", "Project", "Accounting Dimension"], "default": "Cost Center", "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: '' }); } } }, { "fieldname": "accounting_dimension", "label": __("Accounting Dimension"), "fieldtype": "Link", "options": "Accounting Dimension", "get_query": () =>{ return { filters: { "disabled": 0 } } } }, { "fieldname": "fiscal_year", "label": __("Fiscal Year"), "fieldtype": "Link", "options": "Fiscal Year", "default": erpnext.utils.get_fiscal_year(frappe.datetime.get_today()), "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); frappe.query_report.set_filter_value({ from_date: fy.year_start_date, to_date: fy.year_end_date }); }); } }, { "fieldname": "from_date", "label": __("From Date"), "fieldtype": "Date", "default": erpnext.utils.get_fiscal_year(frappe.datetime.get_today(), true)[1], }, { "fieldname": "to_date", "label": __("To Date"), "fieldtype": "Date", "default": erpnext.utils.get_fiscal_year(frappe.datetime.get_today(), true)[2], }, { "fieldname": "show_zero_values", "label": __("Show zero values"), "fieldtype": "Check" } ], "formatter": function(value, row, column, data, default_formatter) { if (column.fieldname=="account") { value = data.account_name; column.link_onclick = "frappe.query_reports['Profitability Analysis'].open_profit_and_loss_statement(" + JSON.stringify(data) + ")"; column.is_tree = true; } value = default_formatter(value, row, column, data); if (!data.parent_account && data.based_on != 'project') { value = $(`${value}`); var $value = $(value).css("font-weight", "bold"); if (data.warn_if_negative && data[column.fieldname] < 0) { $value.addClass("text-danger"); } value = $value.wrap("
").parent().html(); } return value; }, "open_profit_and_loss_statement": function(data) { if (!data.account) return; frappe.route_options = { "company": frappe.query_report.get_filter_value('company'), "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"); }, "tree": true, "name_field": "account", "parent_field": "parent_account", "initial_depth": 3 } erpnext.dimension_filters.forEach((dimension) => { frappe.query_reports["Profitability Analysis"].filters[1].options.push(dimension["document_type"]); }); });