fix(ux): hide Create Purchase Receipt button for Subcontract Return
This commit is contained in:
parent
874766a82f
commit
7145b040f1
@ -52,49 +52,51 @@ frappe.ui.form.on('Subcontracting Receipt', {
|
|||||||
frappe.set_route('query-report', 'General Ledger');
|
frappe.set_route('query-report', 'General Ledger');
|
||||||
}, __('View'));
|
}, __('View'));
|
||||||
|
|
||||||
frm.add_custom_button(__('Purchase Receipt'), () => {
|
if (frm.doc.is_return === 0) {
|
||||||
frappe.model.open_mapped_doc({
|
frm.add_custom_button(__('Purchase Receipt'), () => {
|
||||||
method: 'erpnext.subcontracting.doctype.subcontracting_receipt.subcontracting_receipt.make_purchase_receipt',
|
frappe.model.open_mapped_doc({
|
||||||
frm: frm,
|
method: 'erpnext.subcontracting.doctype.subcontracting_receipt.subcontracting_receipt.make_purchase_receipt',
|
||||||
freeze: true,
|
frm: frm,
|
||||||
freeze_message: __('Creating Purchase Receipt ...')
|
freeze: true,
|
||||||
});
|
freeze_message: __('Creating Purchase Receipt ...')
|
||||||
}, __('Create'));
|
});
|
||||||
|
}, __('Create'));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!frm.doc.is_return && frm.doc.docstatus === 1 && frm.doc.per_returned < 100) {
|
if (!frm.doc.is_return && frm.doc.docstatus === 1 && frm.doc.per_returned < 100) {
|
||||||
frm.add_custom_button(__('Subcontract Return'), () => {
|
frm.add_custom_button(__('Subcontract Return'), () => {
|
||||||
frappe.model.open_mapped_doc({
|
frappe.model.open_mapped_doc({
|
||||||
method: 'erpnext.subcontracting.doctype.subcontracting_receipt.subcontracting_receipt.make_subcontract_return',
|
method: 'erpnext.subcontracting.doctype.subcontracting_receipt.subcontracting_receipt.make_subcontract_return',
|
||||||
frm: frm
|
frm: frm
|
||||||
});
|
});
|
||||||
}, __('Create'));
|
}, __('Create'));
|
||||||
frm.page.set_inner_btn_group_as_primary(__('Create'));
|
frm.page.set_inner_btn_group_as_primary(__('Create'));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (frm.doc.docstatus === 0) {
|
if (frm.doc.docstatus === 0) {
|
||||||
frm.add_custom_button(__('Subcontracting Order'), () => {
|
frm.add_custom_button(__('Subcontracting Order'), () => {
|
||||||
if (!frm.doc.supplier) {
|
if (!frm.doc.supplier) {
|
||||||
frappe.throw({
|
frappe.throw({
|
||||||
title: __('Mandatory'),
|
title: __('Mandatory'),
|
||||||
message: __('Please Select a Supplier')
|
message: __('Please Select a Supplier')
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
erpnext.utils.map_current_doc({
|
|
||||||
method: 'erpnext.subcontracting.doctype.subcontracting_order.subcontracting_order.make_subcontracting_receipt',
|
|
||||||
source_doctype: 'Subcontracting Order',
|
|
||||||
target: frm,
|
|
||||||
setters: {
|
|
||||||
supplier: frm.doc.supplier,
|
|
||||||
},
|
|
||||||
get_query_filters: {
|
|
||||||
docstatus: 1,
|
|
||||||
per_received: ['<', 100],
|
|
||||||
company: frm.doc.company
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
}, __('Get Items From'));
|
}
|
||||||
|
|
||||||
|
erpnext.utils.map_current_doc({
|
||||||
|
method: 'erpnext.subcontracting.doctype.subcontracting_order.subcontracting_order.make_subcontracting_receipt',
|
||||||
|
source_doctype: 'Subcontracting Order',
|
||||||
|
target: frm,
|
||||||
|
setters: {
|
||||||
|
supplier: frm.doc.supplier,
|
||||||
|
},
|
||||||
|
get_query_filters: {
|
||||||
|
docstatus: 1,
|
||||||
|
per_received: ['<', 100],
|
||||||
|
company: frm.doc.company
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}, __('Get Items From'));
|
||||||
|
|
||||||
frm.fields_dict.supplied_items.grid.update_docfield_property('consumed_qty', 'read_only', frm.doc.__onload && frm.doc.__onload.backflush_based_on === 'BOM');
|
frm.fields_dict.supplied_items.grid.update_docfield_property('consumed_qty', 'read_only', frm.doc.__onload && frm.doc.__onload.backflush_based_on === 'BOM');
|
||||||
}
|
}
|
||||||
|
|||||||
@ -545,9 +545,11 @@ def make_subcontract_return(source_name, target_doc=None):
|
|||||||
@frappe.whitelist()
|
@frappe.whitelist()
|
||||||
def make_purchase_receipt(source_name, target_doc=None, save=False, submit=False, notify=False):
|
def make_purchase_receipt(source_name, target_doc=None, save=False, submit=False, notify=False):
|
||||||
if isinstance(source_name, str):
|
if isinstance(source_name, str):
|
||||||
source_name = frappe.get_doc("Subcontracting Receipt", source_name)
|
source_doc = frappe.get_doc("Subcontracting Receipt", source_name)
|
||||||
|
else:
|
||||||
|
source_doc = source_name
|
||||||
|
|
||||||
if not source_name.is_return:
|
if not source_doc.is_return:
|
||||||
if not target_doc:
|
if not target_doc:
|
||||||
target_doc = frappe.new_doc("Purchase Receipt")
|
target_doc = frappe.new_doc("Purchase Receipt")
|
||||||
target_doc.is_subcontracted = 1
|
target_doc.is_subcontracted = 1
|
||||||
@ -555,7 +557,7 @@ def make_purchase_receipt(source_name, target_doc=None, save=False, submit=False
|
|||||||
|
|
||||||
target_doc = get_mapped_doc(
|
target_doc = get_mapped_doc(
|
||||||
"Subcontracting Receipt",
|
"Subcontracting Receipt",
|
||||||
source_name.name,
|
source_doc.name,
|
||||||
{
|
{
|
||||||
"Subcontracting Receipt": {
|
"Subcontracting Receipt": {
|
||||||
"doctype": "Purchase Receipt",
|
"doctype": "Purchase Receipt",
|
||||||
@ -573,7 +575,7 @@ def make_purchase_receipt(source_name, target_doc=None, save=False, submit=False
|
|||||||
)
|
)
|
||||||
|
|
||||||
po_items_details = {}
|
po_items_details = {}
|
||||||
for item in source_name.items:
|
for item in source_doc.items:
|
||||||
if item.purchase_order and item.purchase_order_item:
|
if item.purchase_order and item.purchase_order_item:
|
||||||
if item.purchase_order not in po_items_details:
|
if item.purchase_order not in po_items_details:
|
||||||
po_doc = frappe.get_doc("Purchase Order", item.purchase_order)
|
po_doc = frappe.get_doc("Purchase Order", item.purchase_order)
|
||||||
@ -599,7 +601,7 @@ def make_purchase_receipt(source_name, target_doc=None, save=False, submit=False
|
|||||||
if not target_doc.items:
|
if not target_doc.items:
|
||||||
frappe.throw(
|
frappe.throw(
|
||||||
_("Purchase Order Item reference is missing in Subcontracting Receipt {0}").format(
|
_("Purchase Order Item reference is missing in Subcontracting Receipt {0}").format(
|
||||||
source_name.name
|
source_doc.name
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user