// Copyright (c) 2015, Frappe Technologies Pvt. Ltd. and Contributors // License: GNU General Public License v3. See license.txt // searches for enabled users frappe.provide("erpnext.queries"); $.extend(erpnext.queries, { user: function () { return { query: "frappe.core.doctype.user.user.user_query" }; }, lead: function () { return { query: "erpnext.controllers.queries.lead_query" }; }, customer: function () { return { query: "erpnext.controllers.queries.customer_query" }; }, supplier: function () { return { query: "erpnext.controllers.queries.supplier_query" }; }, item: function (filters) { var args = { query: "erpnext.controllers.queries.item_query" }; if (filters) args["filters"] = filters; return args; }, bom: function () { return { query: "erpnext.controllers.queries.bom" }; }, task: function () { return { query: "erpnext.projects.utils.query_task" }; }, customer_filter: function (doc) { if (!doc.customer) { frappe.throw( __("Please set {0}", [__(frappe.meta.get_label(doc.doctype, "customer", doc.name))]) ); } return { filters: { customer: doc.customer } }; }, contact_query: function (doc) { if (frappe.dynamic_link) { if (!doc[frappe.dynamic_link.fieldname]) { frappe.throw( __("Please set {0}", [ __(frappe.meta.get_label(doc.doctype, frappe.dynamic_link.fieldname, doc.name)), ]) ); } return { query: "frappe.contacts.doctype.contact.contact.contact_query", filters: { link_doctype: frappe.dynamic_link.doctype, link_name: doc[frappe.dynamic_link.fieldname], }, }; } }, address_query: function (doc) { if (frappe.dynamic_link) { if (!doc[frappe.dynamic_link.fieldname]) { frappe.throw( __("Please set {0}", [ __(frappe.meta.get_label(doc.doctype, frappe.dynamic_link.fieldname, doc.name)), ]) ); } return { query: "frappe.contacts.doctype.address.address.address_query", filters: { link_doctype: frappe.dynamic_link.doctype, link_name: doc[frappe.dynamic_link.fieldname], }, }; } }, company_address_query: function (doc) { if (!doc.company) { frappe.throw(__("Please set {0}", [frappe.meta.get_label(doc.doctype, "company", doc.name)])); } return { query: "frappe.contacts.doctype.address.address.address_query", filters: { link_doctype: "Company", link_name: doc.company }, }; }, dispatch_address_query: function (doc) { return { query: "frappe.contacts.doctype.address.address.address_query", filters: { link_doctype: "Company", link_name: doc.company || "" }, }; }, supplier_filter: function (doc) { if (!doc.supplier) { frappe.throw( __("Please set {0}", [__(frappe.meta.get_label(doc.doctype, "supplier", doc.name))]) ); } return { filters: { supplier: doc.supplier } }; }, lead_filter: function (doc) { if (!doc.lead) { frappe.throw( __("Please specify a {0}", [__(frappe.meta.get_label(doc.doctype, "lead", doc.name))]) ); } return { filters: { lead: doc.lead } }; }, not_a_group_filter: function () { return { filters: { is_group: 0 } }; }, employee: function () { return { query: "erpnext.controllers.queries.employee_query" }; }, warehouse: function (doc) { return { filters: [ ["Warehouse", "company", "in", ["", cstr(doc.company)]], ["Warehouse", "is_group", "=", 0], ], }; }, get_filtered_dimensions: function (doc, child_fields, dimension, company) { let account = ""; child_fields.forEach((field) => { if (!account) { account = doc[field]; } }); return { query: "erpnext.controllers.queries.get_filtered_dimensions", filters: { dimension: dimension, account: account, company: company, }, }; }, }); erpnext.queries.setup_queries = function (frm, options, query_fn) { var me = this; var set_query = function (doctype, parentfield) { var link_fields = frappe.meta.get_docfields(doctype, frm.doc.name, { fieldtype: "Link", options: options, }); $.each(link_fields, function (i, df) { if (parentfield) { frm.set_query(df.fieldname, parentfield, query_fn); } else { frm.set_query(df.fieldname, query_fn); } }); }; set_query(frm.doc.doctype); // warehouse field in tables $.each( frappe.meta.get_docfields(frm.doc.doctype, frm.doc.name, { fieldtype: "Table" }), function (i, df) { set_query(df.options, df.fieldname); } ); }; /* if item code is selected in child table then list down warehouses with its quantity else apply default filters. */ erpnext.queries.setup_warehouse_query = function (frm) { frm.set_query("warehouse", "items", function (doc, cdt, cdn) { var row = locals[cdt][cdn]; var filters = erpnext.queries.warehouse(frm.doc); if (row.item_code) { $.extend(filters, { query: "erpnext.controllers.queries.warehouse_query" }); filters["filters"].push(["Bin", "item_code", "=", row.item_code]); } return filters; }); };