2017-02-04 14:25:53 -08:00
|
|
|
// Copyright (c) 2015, Frappe Technologies Pvt. Ltd. and Contributors
|
|
|
|
// License: GNU General Public License v3. See license.txt
|
|
|
|
|
|
|
|
frappe.pages['production-analytics'].on_page_load = function(wrapper) {
|
|
|
|
frappe.ui.make_app_page({
|
|
|
|
parent: wrapper,
|
|
|
|
title: __('Production Analytics'),
|
|
|
|
single_column: true
|
|
|
|
});
|
|
|
|
|
|
|
|
new erpnext.ProductionAnalytics(wrapper);
|
|
|
|
|
|
|
|
frappe.breadcrumbs.add("Manufacturing");
|
|
|
|
}
|
|
|
|
|
|
|
|
erpnext.ProductionAnalytics = frappe.views.GridReportWithPlot.extend({
|
|
|
|
init: function(wrapper) {
|
|
|
|
this._super({
|
|
|
|
title: __("Production Analytics"),
|
|
|
|
parent: $(wrapper).find('.layout-main'),
|
|
|
|
page: wrapper.page,
|
|
|
|
doctypes: ["Item", "Company", "Fiscal Year", "Production Order"]
|
|
|
|
});
|
|
|
|
|
|
|
|
},
|
|
|
|
setup_columns: function() {
|
|
|
|
|
|
|
|
var std_columns = [
|
|
|
|
{id: "_check", name: __("Plot"), field: "_check", width: 30,
|
|
|
|
formatter: this.check_formatter},
|
|
|
|
{id: "name", name: __("Status"), field: "name", width: 100},
|
|
|
|
];
|
|
|
|
|
|
|
|
this.make_date_range_columns();
|
|
|
|
this.columns = std_columns.concat(this.columns);
|
|
|
|
},
|
|
|
|
filters: [
|
2017-02-20 17:41:44 +05:30
|
|
|
{fieldtype:"Select", label: __("Company"), link:"Company", fieldname: "company",
|
2017-02-04 14:25:53 -08:00
|
|
|
default_value: __("Select Company...")},
|
|
|
|
{fieldtype:"Date", label: __("From Date"), fieldname: "from_date"},
|
|
|
|
{fieldtype:"Date", label: __("To Date"), fieldname: "to_date"},
|
|
|
|
{fieldtype:"Select", label: __("Range"), fieldname: "range",
|
|
|
|
options:[{label: __("Daily"), value: "Daily"}, {label: __("Weekly"), value: "Weekly"},
|
|
|
|
{label: __("Monthly"), value: "Monthly"}, {label: __("Quarterly"), value: "Quarterly"},
|
|
|
|
{label: __("Yearly"), value: "Yearly"}]}
|
|
|
|
],
|
|
|
|
setup_filters: function() {
|
|
|
|
var me = this;
|
|
|
|
this._super();
|
|
|
|
|
|
|
|
this.trigger_refresh_on_change(["company"]);
|
|
|
|
this.trigger_refresh_on_change(["range"]);
|
|
|
|
|
|
|
|
this.show_zero_check()
|
|
|
|
this.setup_chart_check();
|
2017-10-17 12:03:02 +05:30
|
|
|
|
2017-02-04 14:25:53 -08:00
|
|
|
},
|
|
|
|
init_filter_values: function() {
|
|
|
|
this._super();
|
|
|
|
this.filter_inputs.range.val('Monthly');
|
|
|
|
},
|
2017-02-05 13:39:39 -08:00
|
|
|
setup_chart: function() {
|
|
|
|
var me = this;
|
2017-10-17 12:03:02 +05:30
|
|
|
|
2017-02-05 13:39:39 -08:00
|
|
|
var chart_data = this.get_chart_data ? this.get_chart_data() : null;
|
|
|
|
|
2018-05-21 18:04:50 +05:30
|
|
|
this.chart = new frappeChart.Chart(".chart", {
|
2017-10-17 12:03:02 +05:30
|
|
|
data: chart_data,
|
|
|
|
type: 'line'
|
2017-02-05 13:39:39 -08:00
|
|
|
});
|
|
|
|
},
|
2017-02-05 14:00:46 -08:00
|
|
|
set_default_values: function() {
|
|
|
|
var values = {
|
2017-05-30 12:54:42 +05:30
|
|
|
from_date: frappe.datetime.str_to_user(frappe.datetime.add_months(frappe.datetime.now_datetime(),-12) ),
|
|
|
|
to_date: frappe.datetime.str_to_user(frappe.datetime.add_months(frappe.datetime.now_datetime(),1))
|
2017-02-05 14:00:46 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
var me = this;
|
|
|
|
$.each(values, function(i, v) {
|
|
|
|
if(me.filter_inputs[i] && !me.filter_inputs[i].val())
|
|
|
|
me.filter_inputs[i].val(v);
|
|
|
|
})
|
|
|
|
},
|
2017-02-04 14:25:53 -08:00
|
|
|
|
|
|
|
prepare_data: function() {
|
|
|
|
// add Opening, Closing, Totals rows
|
|
|
|
// if filtered by account and / or voucher
|
|
|
|
var me = this;
|
|
|
|
var all_open_orders = {name:"All Production Orders", "id": "all-open-pos",
|
|
|
|
checked:true};
|
|
|
|
var not_started = {name:"Not Started", "id":"not-started-pos",
|
|
|
|
checked:true};
|
|
|
|
var overdue = {name:"Overdue (Not Started)", "id":"overdue-pos",
|
|
|
|
checked:true};
|
|
|
|
var pending = {name:"Pending", "id":"pending-pos",
|
|
|
|
checked:true};
|
|
|
|
var completed = {name:"Completed", "id":"completed-pos",
|
2017-10-17 12:03:02 +05:30
|
|
|
checked:true};
|
2017-02-04 14:25:53 -08:00
|
|
|
|
|
|
|
$.each(frappe.report_dump.data["Production Order"], function(i, d) {
|
2017-05-30 12:54:42 +05:30
|
|
|
var dateobj = frappe.datetime.str_to_obj(d.creation);
|
|
|
|
var date = frappe.datetime.str_to_user(d.creation.split(" ")[0]);
|
2017-02-04 14:25:53 -08:00
|
|
|
|
2017-02-05 13:39:39 -08:00
|
|
|
$.each(me.columns, function(i,col) {
|
|
|
|
if (i > 1){
|
2017-05-30 12:54:42 +05:30
|
|
|
var start_period = frappe.datetime.user_to_obj(frappe.datetime.str_to_user(col.id));
|
|
|
|
var end_period = frappe.datetime.user_to_obj(frappe.datetime.str_to_user(col.name));
|
|
|
|
var astart_date = frappe.datetime.user_to_obj(frappe.datetime.str_to_user(d.actual_start_date));
|
|
|
|
var planned_start_date = frappe.datetime.user_to_obj(frappe.datetime.str_to_user(d.planned_start_date));
|
|
|
|
var aend_date = frappe.datetime.user_to_obj(frappe.datetime.str_to_user(d.actual_end_date));
|
|
|
|
var modified = frappe.datetime.user_to_obj(frappe.datetime.str_to_user(d.modified));
|
2017-10-17 12:03:02 +05:30
|
|
|
|
2017-02-06 20:58:25 -08:00
|
|
|
if (dateobj <= start_period || dateobj <= end_period) {
|
2017-02-05 13:39:39 -08:00
|
|
|
all_open_orders[col.field] = flt(all_open_orders[col.field]) + 1;
|
2017-10-17 12:03:02 +05:30
|
|
|
|
2017-02-05 13:39:39 -08:00
|
|
|
if(d.status=="Completed") {
|
2017-02-06 20:58:25 -08:00
|
|
|
if(aend_date < start_period || modified < start_period) {
|
|
|
|
completed[col.field] = flt(completed[col.field]) + 1;
|
|
|
|
}
|
|
|
|
else if (astart_date < start_period) {
|
|
|
|
pending[col.field] = flt(pending[col.field]) + 1;
|
|
|
|
}
|
|
|
|
else if (planned_start_date < start_period) {
|
2017-02-05 13:39:39 -08:00
|
|
|
overdue[col.field] = flt(overdue[col.field]) + 1;
|
2017-02-06 20:58:25 -08:00
|
|
|
} else {
|
2017-02-05 13:39:39 -08:00
|
|
|
not_started[col.field] = flt(not_started[col.field]) + 1;
|
2017-02-06 20:58:25 -08:00
|
|
|
}
|
|
|
|
}else if(d.status == "In Process")
|
|
|
|
{
|
|
|
|
if (astart_date < start_period || modified < start_period){
|
|
|
|
pending[col.field] = flt(pending[col.field]) + 1;
|
|
|
|
}else if (planned_start_date < start_period) {
|
|
|
|
overdue[col.field] = flt(overdue[col.field]) + 1;
|
|
|
|
}else{
|
2017-02-05 13:39:39 -08:00
|
|
|
not_started[col.field] = flt(not_started[col.field]) + 1;
|
2017-02-06 20:58:25 -08:00
|
|
|
}
|
|
|
|
}else if(d.status == "Not Started") {
|
|
|
|
if (planned_start_date < start_period){
|
2017-02-05 13:39:39 -08:00
|
|
|
overdue[col.field] = flt(overdue[col.field]) + 1;
|
2017-02-06 20:58:25 -08:00
|
|
|
}else{
|
|
|
|
not_started[col.field] = flt(not_started[col.field]) + 1;
|
2017-02-05 13:39:39 -08:00
|
|
|
}
|
2017-10-17 12:03:02 +05:30
|
|
|
}
|
2017-02-04 14:25:53 -08:00
|
|
|
}
|
|
|
|
}
|
2017-02-05 13:39:39 -08:00
|
|
|
});
|
2017-02-04 14:25:53 -08:00
|
|
|
});
|
2017-02-06 20:58:25 -08:00
|
|
|
if(me.columns.length < 30){
|
|
|
|
this.chart_area.toggle(true);
|
|
|
|
}else {
|
|
|
|
this.chart_area.toggle(false);
|
|
|
|
}
|
2017-02-04 14:25:53 -08:00
|
|
|
this.data = [all_open_orders, not_started, overdue, pending, completed];
|
2017-10-17 12:03:02 +05:30
|
|
|
|
2017-02-04 14:25:53 -08:00
|
|
|
}
|
|
|
|
});
|