2015-03-03 09:25:30 +00:00
|
|
|
// Copyright (c) 2015, Frappe Technologies Pvt. Ltd. and Contributors
|
2013-08-05 09:29:54 +00:00
|
|
|
// License: GNU General Public License v3. See license.txt
|
2014-02-14 10:17:51 +00:00
|
|
|
frappe.provide("erpnext");
|
2014-12-16 07:19:13 +00:00
|
|
|
frappe.provide("erpnext.utils");
|
2012-11-19 10:13:18 +00:00
|
|
|
|
2013-07-09 07:33:39 +00:00
|
|
|
$.extend(erpnext, {
|
|
|
|
get_currency: function(company) {
|
|
|
|
if(!company && cur_frm)
|
|
|
|
company = cur_frm.doc.company;
|
|
|
|
if(company)
|
2014-03-27 08:47:33 +00:00
|
|
|
return frappe.get_doc(":Company", company).default_currency || frappe.boot.sysdefaults.currency;
|
2013-07-09 07:33:39 +00:00
|
|
|
else
|
2014-02-14 10:17:51 +00:00
|
|
|
return frappe.boot.sysdefaults.currency;
|
2013-07-09 07:33:39 +00:00
|
|
|
},
|
2014-04-16 11:51:25 +00:00
|
|
|
|
2014-04-24 12:41:49 +00:00
|
|
|
toggle_naming_series: function() {
|
2014-04-16 11:51:25 +00:00
|
|
|
if(cur_frm.fields_dict.naming_series) {
|
2013-07-09 07:33:39 +00:00
|
|
|
cur_frm.toggle_display("naming_series", cur_frm.doc.__islocal?true:false);
|
|
|
|
}
|
|
|
|
},
|
2014-04-16 11:51:25 +00:00
|
|
|
|
2013-07-09 07:33:39 +00:00
|
|
|
hide_company: function() {
|
|
|
|
if(cur_frm.fields_dict.company) {
|
2013-10-07 12:52:29 +00:00
|
|
|
var companies = Object.keys(locals[":Company"] || {});
|
2013-07-09 07:33:39 +00:00
|
|
|
if(companies.length === 1) {
|
|
|
|
if(!cur_frm.doc.company) cur_frm.set_value("company", companies[0]);
|
|
|
|
cur_frm.toggle_display("company", false);
|
2015-04-28 10:32:09 +00:00
|
|
|
} else if(erpnext.last_selected_company) {
|
|
|
|
if(!cur_frm.doc.company) cur_frm.set_value("company", erpnext.last_selected_company);
|
2013-07-09 07:33:39 +00:00
|
|
|
}
|
|
|
|
}
|
2013-07-15 12:39:43 +00:00
|
|
|
},
|
2014-04-16 11:51:25 +00:00
|
|
|
|
2017-06-19 07:24:59 +00:00
|
|
|
is_perpetual_inventory_enabled: function(company) {
|
|
|
|
if(company) {
|
|
|
|
return frappe.get_doc(":Company", company).enable_perpetual_inventory
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2017-10-25 06:47:40 +00:00
|
|
|
stale_rate_allowed: () => {
|
2017-11-02 12:42:14 +00:00
|
|
|
return cint(frappe.boot.sysdefaults.allow_stale);
|
2017-10-25 06:47:40 +00:00
|
|
|
},
|
|
|
|
|
2015-02-25 09:38:42 +00:00
|
|
|
setup_serial_no: function() {
|
|
|
|
var grid_row = cur_frm.open_grid_row();
|
2016-07-28 08:23:17 +00:00
|
|
|
if(!grid_row || !grid_row.grid_form.fields_dict.serial_no ||
|
|
|
|
grid_row.grid_form.fields_dict.serial_no.get_status()!=="Write") return;
|
2014-04-16 11:51:25 +00:00
|
|
|
|
2014-04-14 10:55:30 +00:00
|
|
|
var $btn = $('<button class="btn btn-sm btn-default">'+__("Add Serial No")+'</button>')
|
2013-08-14 13:07:28 +00:00
|
|
|
.appendTo($("<div>")
|
2015-02-25 09:38:42 +00:00
|
|
|
.css({"margin-bottom": "10px", "margin-top": "10px"})
|
2016-07-28 08:23:17 +00:00
|
|
|
.appendTo(grid_row.grid_form.fields_dict.serial_no.$wrapper));
|
2014-04-16 11:51:25 +00:00
|
|
|
|
2013-08-14 13:07:28 +00:00
|
|
|
$btn.on("click", function() {
|
2014-02-14 10:17:51 +00:00
|
|
|
var d = new frappe.ui.Dialog({
|
2014-04-14 10:55:30 +00:00
|
|
|
title: __("Add Serial No"),
|
2013-08-14 13:07:28 +00:00
|
|
|
fields: [
|
|
|
|
{
|
|
|
|
"fieldtype": "Link",
|
2017-02-27 08:13:04 +00:00
|
|
|
"fieldname": "serial_no",
|
2013-08-14 13:07:28 +00:00
|
|
|
"options": "Serial No",
|
2014-04-14 10:55:30 +00:00
|
|
|
"label": __("Serial No"),
|
2015-03-12 07:21:50 +00:00
|
|
|
"get_query": function () {
|
2015-04-28 10:32:09 +00:00
|
|
|
return {
|
|
|
|
filters: {
|
2015-03-12 07:21:50 +00:00
|
|
|
item_code:grid_row.doc.item_code ,
|
2015-08-04 06:48:12 +00:00
|
|
|
warehouse:cur_frm.doc.is_return ? null : grid_row.doc.warehouse
|
2015-03-12 07:21:50 +00:00
|
|
|
}
|
|
|
|
}
|
2013-08-14 13:07:28 +00:00
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"fieldtype": "Button",
|
2017-02-27 07:23:05 +00:00
|
|
|
"fieldname": "add",
|
2014-04-14 10:55:30 +00:00
|
|
|
"label": __("Add")
|
2013-08-14 13:07:28 +00:00
|
|
|
}
|
|
|
|
]
|
|
|
|
});
|
2014-04-16 11:51:25 +00:00
|
|
|
|
2013-08-14 13:07:28 +00:00
|
|
|
d.get_input("add").on("click", function() {
|
|
|
|
var serial_no = d.get_value("serial_no");
|
|
|
|
if(serial_no) {
|
|
|
|
var val = (grid_row.doc.serial_no || "").split("\n").concat([serial_no]).join("\n");
|
2016-07-28 08:23:17 +00:00
|
|
|
grid_row.grid_form.fields_dict.serial_no.set_model_value(val.trim());
|
2013-08-14 13:07:28 +00:00
|
|
|
}
|
|
|
|
d.hide();
|
|
|
|
return false;
|
|
|
|
});
|
2014-04-16 11:51:25 +00:00
|
|
|
|
2013-08-14 13:07:28 +00:00
|
|
|
d.show();
|
|
|
|
});
|
2015-05-19 06:30:34 +00:00
|
|
|
}
|
2014-04-16 11:51:25 +00:00
|
|
|
});
|
2014-11-24 08:46:47 +00:00
|
|
|
|
2014-12-16 07:19:13 +00:00
|
|
|
|
|
|
|
$.extend(erpnext.utils, {
|
2016-09-19 10:34:58 +00:00
|
|
|
set_party_dashboard_indicators: function(frm) {
|
|
|
|
if(frm.doc.__onload && frm.doc.__onload.dashboard_info) {
|
|
|
|
var info = frm.doc.__onload.dashboard_info;
|
|
|
|
frm.dashboard.add_indicator(__('Annual Billing: {0}',
|
2016-12-05 11:39:30 +00:00
|
|
|
[format_currency(info.billing_this_year, info.currency)]), 'blue');
|
2016-09-19 10:34:58 +00:00
|
|
|
frm.dashboard.add_indicator(__('Total Unpaid: {0}',
|
2016-12-05 11:39:30 +00:00
|
|
|
[format_currency(info.total_unpaid, info.currency)]),
|
2016-09-19 10:34:58 +00:00
|
|
|
info.total_unpaid ? 'orange' : 'green');
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2018-03-27 05:59:25 +00:00
|
|
|
get_party_name: function(party_type) {
|
|
|
|
var dict = {'Customer': 'customer_name', 'Supplier': 'supplier_name', 'Employee': 'employee_name',
|
|
|
|
'Member': 'member_name'};
|
|
|
|
return dict[party_type];
|
|
|
|
},
|
|
|
|
|
2015-07-08 12:46:51 +00:00
|
|
|
copy_value_in_all_row: function(doc, dt, dn, table_fieldname, fieldname) {
|
|
|
|
var d = locals[dt][dn];
|
|
|
|
if(d[fieldname]){
|
|
|
|
var cl = doc[table_fieldname] || [];
|
|
|
|
for(var i = 0; i < cl.length; i++) {
|
|
|
|
if(!cl[i][fieldname]) cl[i][fieldname] = d[fieldname];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
refresh_field(table_fieldname);
|
2017-05-26 16:02:33 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
get_terms: function(tc_name, doc, callback) {
|
|
|
|
if(tc_name) {
|
|
|
|
return frappe.call({
|
|
|
|
method: 'erpnext.setup.doctype.terms_and_conditions.terms_and_conditions.get_terms_and_conditions',
|
|
|
|
args: {
|
|
|
|
template_name: tc_name,
|
|
|
|
doc: doc
|
|
|
|
},
|
|
|
|
callback: function(r) {
|
|
|
|
callback(r)
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
2017-08-29 12:48:27 +00:00
|
|
|
},
|
|
|
|
|
2017-09-07 10:44:22 +00:00
|
|
|
make_subscription: function(doctype, docname) {
|
|
|
|
frappe.call({
|
2017-09-15 10:46:36 +00:00
|
|
|
method: "erpnext.accounts.doctype.subscription.subscription.make_subscription",
|
2017-09-07 10:44:22 +00:00
|
|
|
args: {
|
|
|
|
doctype: doctype,
|
|
|
|
docname: docname
|
|
|
|
},
|
|
|
|
callback: function(r) {
|
|
|
|
var doclist = frappe.model.sync(r.message);
|
|
|
|
frappe.set_route("Form", doclist[0].doctype, doclist[0].name);
|
|
|
|
}
|
|
|
|
})
|
|
|
|
},
|
|
|
|
|
2017-08-29 12:48:27 +00:00
|
|
|
/**
|
|
|
|
* Checks if the first row of a given child table is empty
|
|
|
|
* @param child_table - Child table Doctype
|
|
|
|
* @return {Boolean}
|
|
|
|
**/
|
|
|
|
first_row_is_empty: function(child_table){
|
|
|
|
if($.isArray(child_table) && child_table.length > 0) {
|
|
|
|
return !child_table[0].item_code;
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Removes the first row of a child table if it is empty
|
|
|
|
* @param {_Frm} frm - The current form
|
|
|
|
* @param {String} child_table_name - The child table field name
|
|
|
|
* @return {Boolean}
|
|
|
|
**/
|
|
|
|
remove_empty_first_row: function(frm, child_table_name){
|
|
|
|
const rows = frm['doc'][child_table_name];
|
|
|
|
if (this.first_row_is_empty(rows)){
|
|
|
|
frm['doc'][child_table_name] = rows.splice(1);
|
|
|
|
}
|
|
|
|
return rows;
|
|
|
|
},
|
2015-05-28 06:40:55 +00:00
|
|
|
});
|
|
|
|
|
2016-07-14 12:13:48 +00:00
|
|
|
erpnext.utils.map_current_doc = function(opts) {
|
|
|
|
if(opts.get_query_filters) {
|
|
|
|
opts.get_query = function() {
|
|
|
|
return {filters: opts.get_query_filters};
|
|
|
|
}
|
|
|
|
}
|
|
|
|
var _map = function() {
|
2016-07-15 11:13:25 +00:00
|
|
|
if($.isArray(cur_frm.doc.items) && cur_frm.doc.items.length > 0) {
|
2017-05-15 06:02:06 +00:00
|
|
|
// remove first item row if empty
|
2016-07-14 12:13:48 +00:00
|
|
|
if(!cur_frm.doc.items[0].item_code) {
|
|
|
|
cur_frm.doc.items = cur_frm.doc.items.splice(1);
|
|
|
|
}
|
2016-11-30 09:02:11 +00:00
|
|
|
|
|
|
|
// find the doctype of the items table
|
|
|
|
var items_doctype = frappe.meta.get_docfield(cur_frm.doctype, 'items').options;
|
2017-05-15 06:02:06 +00:00
|
|
|
|
2016-11-30 09:02:11 +00:00
|
|
|
// find the link fieldname from items table for the given
|
|
|
|
// source_doctype
|
|
|
|
var link_fieldname = null;
|
2017-05-15 06:02:06 +00:00
|
|
|
frappe.get_meta(items_doctype).fields.forEach(function(d) {
|
2016-11-30 09:02:11 +00:00
|
|
|
if(d.options===opts.source_doctype) link_fieldname = d.fieldname; });
|
|
|
|
|
2017-01-09 10:02:20 +00:00
|
|
|
// search in existing items if the source_name is already set and full qty fetched
|
2016-11-30 09:02:11 +00:00
|
|
|
var already_set = false;
|
2017-01-09 10:02:20 +00:00
|
|
|
var item_qty_map = {};
|
2017-05-15 06:02:06 +00:00
|
|
|
|
2016-11-30 09:02:11 +00:00
|
|
|
$.each(cur_frm.doc.items, function(i, d) {
|
2017-05-15 06:02:06 +00:00
|
|
|
opts.source_name.forEach(function(src) {
|
|
|
|
if(d[link_fieldname]==src) {
|
|
|
|
already_set = true;
|
|
|
|
if (item_qty_map[d.item_code])
|
|
|
|
item_qty_map[d.item_code] += flt(d.qty);
|
|
|
|
else
|
|
|
|
item_qty_map[d.item_code] = flt(d.qty);
|
|
|
|
}
|
|
|
|
});
|
2016-11-30 09:02:11 +00:00
|
|
|
});
|
2017-05-15 06:02:06 +00:00
|
|
|
|
2016-11-30 09:02:11 +00:00
|
|
|
if(already_set) {
|
2017-05-15 06:02:06 +00:00
|
|
|
opts.source_name.forEach(function(src) {
|
|
|
|
frappe.model.with_doc(opts.source_doctype, src, function(r) {
|
|
|
|
var source_doc = frappe.model.get_doc(opts.source_doctype, src);
|
|
|
|
$.each(source_doc.items || [], function(i, row) {
|
|
|
|
if(row.qty > flt(item_qty_map[row.item_code])) {
|
|
|
|
already_set = false;
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
})
|
2017-01-09 10:02:20 +00:00
|
|
|
})
|
2016-11-30 09:02:11 +00:00
|
|
|
|
2017-05-15 06:02:06 +00:00
|
|
|
if(already_set) {
|
|
|
|
frappe.msgprint(__("You have already selected items from {0} {1}",
|
|
|
|
[opts.source_doctype, src]));
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
})
|
2017-01-09 10:02:20 +00:00
|
|
|
}
|
2016-07-14 12:13:48 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return frappe.call({
|
|
|
|
// Sometimes we hit the limit for URL length of a GET request
|
|
|
|
// as we send the full target_doc. Hence this is a POST request.
|
|
|
|
type: "POST",
|
2017-05-15 06:02:06 +00:00
|
|
|
method: 'frappe.model.mapper.map_docs',
|
2016-07-14 12:13:48 +00:00
|
|
|
args: {
|
2017-05-15 06:02:06 +00:00
|
|
|
"method": opts.method,
|
|
|
|
"source_names": opts.source_name,
|
|
|
|
"target_doc": cur_frm.doc,
|
2016-07-14 12:13:48 +00:00
|
|
|
},
|
|
|
|
callback: function(r) {
|
|
|
|
if(!r.exc) {
|
|
|
|
var doc = frappe.model.sync(r.message);
|
2017-12-26 10:52:40 +00:00
|
|
|
cur_frm.dirty();
|
2016-07-14 12:13:48 +00:00
|
|
|
cur_frm.refresh();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
if(opts.source_doctype) {
|
2017-05-15 06:02:06 +00:00
|
|
|
var d = new frappe.ui.form.MultiSelectDialog({
|
|
|
|
doctype: opts.source_doctype,
|
|
|
|
target: opts.target,
|
|
|
|
date_field: opts.date_field || undefined,
|
|
|
|
setters: opts.setters,
|
|
|
|
get_query: opts.get_query,
|
|
|
|
action: function(selections, args) {
|
|
|
|
let values = selections;
|
|
|
|
if(values.length === 0){
|
2017-12-04 08:06:50 +00:00
|
|
|
frappe.msgprint(__("Please select {0}", [opts.source_doctype]))
|
2017-05-15 06:02:06 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
opts.source_name = values;
|
|
|
|
opts.setters = args;
|
|
|
|
d.dialog.hide();
|
|
|
|
_map();
|
|
|
|
},
|
2016-07-14 12:13:48 +00:00
|
|
|
});
|
|
|
|
} else if(opts.source_name) {
|
2017-05-15 06:02:06 +00:00
|
|
|
opts.source_name = [opts.source_name];
|
2016-07-14 12:13:48 +00:00
|
|
|
_map();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-07-26 12:27:42 +00:00
|
|
|
frappe.form.link_formatters['Item'] = function(value, doc) {
|
2016-07-31 06:14:43 +00:00
|
|
|
if(doc && doc.item_name && doc.item_name !== value) {
|
2016-10-27 04:19:22 +00:00
|
|
|
return value? value + ': ' + doc.item_name: doc.item_name;
|
2016-07-26 12:27:42 +00:00
|
|
|
} else {
|
|
|
|
return value;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
frappe.form.link_formatters['Employee'] = function(value, doc) {
|
2016-07-31 06:14:43 +00:00
|
|
|
if(doc && doc.employee_name && doc.employee_name !== value) {
|
2016-10-27 04:19:22 +00:00
|
|
|
return value? value + ': ' + doc.employee_name: doc.employee_name;
|
2016-07-26 12:27:42 +00:00
|
|
|
} else {
|
|
|
|
return value;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-05-28 06:40:55 +00:00
|
|
|
// add description on posting time
|
|
|
|
$(document).on('app_ready', function() {
|
|
|
|
if(!frappe.datetime.is_timezone_same()) {
|
|
|
|
$.each(["Stock Reconciliation", "Stock Entry", "Stock Ledger Entry",
|
|
|
|
"Delivery Note", "Purchase Receipt", "Sales Invoice"], function(i, d) {
|
|
|
|
frappe.ui.form.on(d, "onload", function(frm) {
|
|
|
|
cur_frm.set_df_property("posting_time", "description",
|
2017-05-30 07:24:42 +00:00
|
|
|
frappe.sys_defaults.time_zone);
|
2015-05-28 06:40:55 +00:00
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
2016-07-28 08:23:17 +00:00
|
|
|
});
|