fix(ux): hide Create Purchase Receipt button for Subcontract Return

This commit is contained in:
s-aga-r 2023-11-29 13:21:24 +05:30
parent 874766a82f
commit 7145b040f1
2 changed files with 42 additions and 38 deletions

View File

@ -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');
} }

View File

@ -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
) )
) )