brotherton-erpnext/erpnext/public/js/utils/serial_no_batch_selector.js

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

306 lines
6.3 KiB
JavaScript
Raw Normal View History

erpnext.SerialBatchPackageSelector = class SerialNoBatchBundleUpdate {
2022-10-10 13:28:19 +05:30
constructor(frm, item, callback) {
this.frm = frm;
this.item = item;
this.qty = item.qty;
this.callback = callback;
this.bundle = this.item?.is_rejected ?
this.item.rejected_serial_and_batch_bundle : this.item.serial_and_batch_bundle;
2022-10-10 13:28:19 +05:30
this.make();
this.render_data();
}
make() {
let label = this.item?.has_serial_no ? __('Serial No') : __('Batch No');
let primary_label = this.bundle
? __('Update') : __('Add');
if (this.item?.has_serial_no && this.item?.batch_no) {
label = __('Serial No / Batch No');
}
primary_label += ' ' + label;
2022-10-10 13:28:19 +05:30
this.dialog = new frappe.ui.Dialog({
title: this.item?.title || primary_label,
2022-10-10 13:28:19 +05:30
fields: this.get_dialog_fields(),
primary_action_label: primary_label,
2022-10-10 13:28:19 +05:30
primary_action: () => this.update_ledgers()
});
2023-04-07 11:21:01 +05:30
this.dialog.set_value("qty", this.item.qty);
2022-10-10 13:28:19 +05:30
this.dialog.show();
}
get_serial_no_filters() {
let warehouse = this.item?.outward ?
(this.item.warehouse || this.item.s_warehouse) : "";
2022-10-10 13:28:19 +05:30
return {
'item_code': this.item.item_code,
'warehouse': ["=", warehouse]
2022-10-10 13:28:19 +05:30
};
}
get_dialog_fields() {
let fields = [];
if (this.item.has_serial_no) {
fields.push({
fieldtype: 'Link',
fieldname: 'scan_serial_no',
label: __('Scan Serial No'),
options: 'Serial No',
get_query: () => {
return {
filters: this.get_serial_no_filters()
};
},
onchange: () => this.update_serial_batch_no()
});
}
if (this.item.has_batch_no && this.item.has_serial_no) {
fields.push({
fieldtype: 'Column Break',
});
}
if (this.item.has_batch_no) {
fields.push({
fieldtype: 'Link',
fieldname: 'scan_batch_no',
label: __('Scan Batch No'),
options: 'Batch',
2023-04-04 11:50:38 +05:30
get_query: () => {
return {
filters: {
'item': this.item.item_code
}
};
},
2022-10-10 13:28:19 +05:30
onchange: () => this.update_serial_batch_no()
});
}
if (this.frm.doc.doctype === 'Stock Entry'
&& this.frm.doc.purpose === 'Manufacture') {
fields.push({
fieldtype: 'Column Break',
});
fields.push({
fieldtype: 'Link',
fieldname: 'work_order',
label: __('For Work Order'),
options: 'Work Order',
read_only: 1,
default: this.frm.doc.work_order,
});
}
if (this.item?.outward) {
2023-04-04 11:50:38 +05:30
fields = [...this.get_filter_fields(), ...fields];
2022-10-10 13:28:19 +05:30
}
fields.push({
fieldtype: 'Section Break',
});
2022-10-10 13:28:19 +05:30
fields.push({
fieldname: 'entries',
2022-10-10 13:28:19 +05:30
fieldtype: 'Table',
allow_bulk_edit: true,
data: [],
fields: this.get_dialog_table_fields(),
});
return fields;
}
get_filter_fields() {
return [
{
fieldtype: 'Section Break',
label: __('Auto Fetch')
},
{
fieldtype: 'Float',
fieldname: 'qty',
label: __('Qty to Fetch'),
2023-04-04 11:50:38 +05:30
onchange: () => this.get_auto_data()
},
{
fieldtype: 'Column Break',
},
{
fieldtype: 'Select',
options: ['FIFO', 'LIFO', 'Expiry'],
default: 'FIFO',
fieldname: 'based_on',
2023-04-04 11:50:38 +05:30
label: __('Fetch Based On'),
onchange: () => this.get_auto_data()
},
{
2023-04-04 11:50:38 +05:30
fieldtype: 'Section Break',
},
]
}
2022-10-10 13:28:19 +05:30
get_dialog_table_fields() {
let fields = []
if (this.item.has_serial_no) {
fields.push({
fieldtype: 'Link',
options: 'Serial No',
fieldname: 'serial_no',
label: __('Serial No'),
in_list_view: 1,
get_query: () => {
return {
filters: this.get_serial_no_filters()
}
}
})
}
let batch_fields = []
if (this.item.has_batch_no) {
batch_fields = [
2022-10-10 13:28:19 +05:30
{
fieldtype: 'Link',
options: 'Batch',
fieldname: 'batch_no',
label: __('Batch No'),
in_list_view: 1,
2023-04-04 11:50:38 +05:30
get_query: () => {
return {
filters: {
'item': this.item.item_code
}
};
},
}
]
if (!this.item.has_serial_no) {
batch_fields.push({
2022-10-10 13:28:19 +05:30
fieldtype: 'Float',
fieldname: 'qty',
label: __('Quantity'),
in_list_view: 1,
})
}
2022-10-10 13:28:19 +05:30
}
fields = [...fields, ...batch_fields];
2022-10-10 13:28:19 +05:30
fields.push({
fieldtype: 'Data',
fieldname: 'name',
label: __('Name'),
hidden: 1,
});
2022-10-10 13:28:19 +05:30
return fields;
}
get_auto_data() {
const { qty, based_on } = this.dialog.get_values();
if (!qty) {
frappe.throw(__('Please enter Qty to Fetch'));
}
2023-04-04 11:50:38 +05:30
if (!based_on) {
based_on = 'FIFO';
}
frappe.call({
method: 'erpnext.stock.doctype.serial_and_batch_bundle.serial_and_batch_bundle.get_auto_data',
args: {
item_code: this.item.item_code,
warehouse: this.item.warehouse || this.item.s_warehouse,
has_serial_no: this.item.has_serial_no,
has_batch_no: this.item.has_batch_no,
qty: qty,
based_on: based_on
},
callback: (r) => {
if (r.message) {
this.dialog.fields_dict.entries.df.data = r.message;
this.dialog.fields_dict.entries.grid.refresh();
}
}
});
}
2022-10-10 13:28:19 +05:30
update_serial_batch_no() {
const { scan_serial_no, scan_batch_no } = this.dialog.get_values();
if (scan_serial_no) {
this.dialog.fields_dict.entries.df.data.push({
2022-10-10 13:28:19 +05:30
serial_no: scan_serial_no
});
this.dialog.fields_dict.scan_serial_no.set_value('');
} else if (scan_batch_no) {
this.dialog.fields_dict.entries.df.data.push({
2022-10-10 13:28:19 +05:30
batch_no: scan_batch_no
});
this.dialog.fields_dict.scan_batch_no.set_value('');
}
this.dialog.fields_dict.entries.grid.refresh();
2022-10-10 13:28:19 +05:30
}
update_ledgers() {
let entries = this.dialog.get_values().entries;
2022-10-10 13:28:19 +05:30
if (entries && !entries.length || !entries) {
frappe.throw(__('Please add atleast one Serial No / Batch No'));
2022-10-10 13:28:19 +05:30
}
frappe.call({
method: 'erpnext.stock.doctype.serial_and_batch_bundle.serial_and_batch_bundle.add_serial_batch_ledgers',
args: {
entries: entries,
child_row: this.item,
doc: this.frm.doc,
}
}).then(r => {
this.callback && this.callback(r.message);
this.frm.save();
this.dialog.hide();
})
2022-10-10 13:28:19 +05:30
}
render_data() {
if (!this.frm.is_new() && this.bundle) {
2022-10-10 13:28:19 +05:30
frappe.call({
method: 'erpnext.stock.doctype.serial_and_batch_bundle.serial_and_batch_bundle.get_serial_batch_ledgers',
2022-10-10 13:28:19 +05:30
args: {
item_code: this.item.item_code,
name: this.bundle,
2022-10-10 13:28:19 +05:30
voucher_no: this.item.parent,
}
}).then(r => {
if (r.message) {
this.set_data(r.message);
}
})
}
}
set_data(data) {
data.forEach(d => {
this.dialog.fields_dict.entries.df.data.push(d);
2022-10-10 13:28:19 +05:30
});
this.dialog.fields_dict.entries.grid.refresh();
2022-10-10 13:28:19 +05:30
}
}