2018-11-12 17:01:02 +05:30
|
|
|
// Copyright (c) 2016, Frappe Technologies Pvt. Ltd. and contributors
|
|
|
|
// For license information, please see license.txt
|
2023-07-14 18:53:02 +05:30
|
|
|
|
2018-11-12 17:01:02 +05:30
|
|
|
|
|
|
|
frappe.query_reports["Purchase Analytics"] = {
|
|
|
|
"filters": [
|
|
|
|
{
|
|
|
|
fieldname: "tree_type",
|
|
|
|
label: __("Tree Type"),
|
|
|
|
fieldtype: "Select",
|
|
|
|
options: ["Supplier Group","Supplier","Item Group","Item"],
|
|
|
|
default: "Supplier",
|
|
|
|
reqd: 1
|
|
|
|
},
|
|
|
|
{
|
|
|
|
fieldname: "doc_type",
|
|
|
|
label: __("based_on"),
|
|
|
|
fieldtype: "Select",
|
|
|
|
options: ["Purchase Order","Purchase Receipt","Purchase Invoice"],
|
|
|
|
default: "Purchase Invoice",
|
|
|
|
reqd: 1
|
|
|
|
},
|
|
|
|
{
|
|
|
|
fieldname: "value_quantity",
|
|
|
|
label: __("Value Or Qty"),
|
|
|
|
fieldtype: "Select",
|
|
|
|
options: [
|
|
|
|
{ "value": "Value", "label": __("Value") },
|
|
|
|
{ "value": "Quantity", "label": __("Quantity") },
|
|
|
|
],
|
|
|
|
default: "Value",
|
|
|
|
reqd: 1
|
|
|
|
},
|
|
|
|
{
|
|
|
|
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],
|
2018-11-12 17:01:02 +05:30
|
|
|
reqd: 1
|
|
|
|
},
|
|
|
|
{
|
|
|
|
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],
|
2018-11-12 17:01:02 +05:30
|
|
|
reqd: 1
|
|
|
|
},
|
|
|
|
{
|
|
|
|
fieldname: "company",
|
|
|
|
label: __("Company"),
|
|
|
|
fieldtype: "Link",
|
|
|
|
options: "Company",
|
|
|
|
default: frappe.defaults.get_user_default("Company"),
|
|
|
|
reqd: 1
|
|
|
|
},
|
|
|
|
{
|
|
|
|
fieldname: "range",
|
|
|
|
label: __("Range"),
|
|
|
|
fieldtype: "Select",
|
|
|
|
options: [
|
|
|
|
{ "value": "Weekly", "label": __("Weekly") },
|
|
|
|
{ "value": "Monthly", "label": __("Monthly") },
|
|
|
|
{ "value": "Quarterly", "label": __("Quarterly") },
|
|
|
|
{ "value": "Yearly", "label": __("Yearly") }
|
|
|
|
],
|
|
|
|
default: "Monthly",
|
|
|
|
reqd: 1
|
|
|
|
}
|
|
|
|
|
|
|
|
],
|
|
|
|
get_datatable_options(options) {
|
|
|
|
return Object.assign(options, {
|
|
|
|
checkboxColumn: true,
|
|
|
|
events: {
|
2020-12-16 14:41:04 +05:30
|
|
|
onCheckRow: function (data) {
|
|
|
|
if (!data) return;
|
|
|
|
|
|
|
|
const data_doctype = $(
|
|
|
|
data[2].html
|
|
|
|
)[0].attributes.getNamedItem("data-doctype").value;
|
|
|
|
const tree_type = frappe.query_report.filters[0].value;
|
|
|
|
if (data_doctype != tree_type) return;
|
|
|
|
|
2023-07-14 18:53:02 +05:30
|
|
|
let row_name = data[2].content;
|
|
|
|
let length = data.length;
|
|
|
|
let row_values = '';
|
2018-12-15 15:36:09 +05:30
|
|
|
|
2020-12-25 16:34:43 +05:30
|
|
|
if (tree_type == "Supplier") {
|
2020-12-16 14:41:04 +05:30
|
|
|
row_values = data
|
|
|
|
.slice(4, length - 1)
|
|
|
|
.map(function (column) {
|
|
|
|
return column.content;
|
|
|
|
});
|
2020-12-25 16:34:43 +05:30
|
|
|
} else if (tree_type == "Item") {
|
|
|
|
row_values = data
|
|
|
|
.slice(5, length - 1)
|
|
|
|
.map(function (column) {
|
|
|
|
return column.content;
|
|
|
|
});
|
2020-12-16 14:41:04 +05:30
|
|
|
} else {
|
|
|
|
row_values = data
|
|
|
|
.slice(3, length - 1)
|
|
|
|
.map(function (column) {
|
|
|
|
return column.content;
|
|
|
|
});
|
2018-12-15 15:36:09 +05:30
|
|
|
}
|
2018-11-12 17:01:02 +05:30
|
|
|
|
2023-07-14 18:53:02 +05:30
|
|
|
let entry = {
|
2020-12-16 14:41:04 +05:30
|
|
|
name: row_name,
|
|
|
|
values: row_values,
|
|
|
|
};
|
2018-11-12 17:01:02 +05:30
|
|
|
|
|
|
|
let raw_data = frappe.query_report.chart.data;
|
|
|
|
let new_datasets = raw_data.datasets;
|
|
|
|
|
2020-12-25 16:34:43 +05:30
|
|
|
let element_found = new_datasets.some((element, index, array)=>{
|
|
|
|
if(element.name == row_name){
|
|
|
|
array.splice(index, 1)
|
|
|
|
return true
|
2018-11-12 17:01:02 +05:30
|
|
|
}
|
2020-12-25 16:34:43 +05:30
|
|
|
return false
|
|
|
|
})
|
2018-11-12 17:01:02 +05:30
|
|
|
|
2020-12-25 16:34:43 +05:30
|
|
|
if (!element_found) {
|
2018-11-12 17:01:02 +05:30
|
|
|
new_datasets.push(entry);
|
|
|
|
}
|
|
|
|
let new_data = {
|
|
|
|
labels: raw_data.labels,
|
2020-12-16 14:41:04 +05:30
|
|
|
datasets: new_datasets,
|
|
|
|
};
|
2022-07-15 13:29:17 +05:30
|
|
|
const new_options = Object.assign({}, frappe.query_report.chart_options, {data: new_data});
|
|
|
|
frappe.query_report.render_chart(new_options);
|
2018-11-12 17:01:02 +05:30
|
|
|
|
|
|
|
frappe.query_report.raw_chart_data = new_data;
|
|
|
|
},
|
2020-12-16 14:41:04 +05:30
|
|
|
},
|
2018-11-29 08:34:47 +05:30
|
|
|
});
|
|
|
|
}
|
2018-11-12 17:01:02 +05:30
|
|
|
}
|