fix(quality-inspection): fetch all items for inspection type in process (#18716)
* fix(quality-inspection): fetch all items for inspection type in process * fix(quality-inspection): add server side validation for in process items
This commit is contained in:
parent
612b0ff9cd
commit
06ce1f5a40
@ -39,11 +39,12 @@ cur_frm.fields_dict['item_code'].get_query = function(doc, cdt, cdn) {
|
|||||||
query: "erpnext.stock.doctype.quality_inspection.quality_inspection.item_query",
|
query: "erpnext.stock.doctype.quality_inspection.quality_inspection.item_query",
|
||||||
filters: {
|
filters: {
|
||||||
"from": doctype,
|
"from": doctype,
|
||||||
"parent": doc.reference_name
|
"parent": doc.reference_name,
|
||||||
|
"inspection_type": doc.inspection_type
|
||||||
}
|
}
|
||||||
|
};
|
||||||
}
|
}
|
||||||
}
|
},
|
||||||
}
|
|
||||||
|
|
||||||
// Serial No based on item_code
|
// Serial No based on item_code
|
||||||
cur_frm.fields_dict['item_serial_no'].get_query = function(doc, cdt, cdn) {
|
cur_frm.fields_dict['item_serial_no'].get_query = function(doc, cdt, cdn) {
|
||||||
|
@ -3,6 +3,7 @@
|
|||||||
|
|
||||||
from __future__ import unicode_literals
|
from __future__ import unicode_literals
|
||||||
import frappe
|
import frappe
|
||||||
|
from frappe import _
|
||||||
from frappe.model.document import Document
|
from frappe.model.document import Document
|
||||||
from erpnext.stock.doctype.quality_inspection_template.quality_inspection_template \
|
from erpnext.stock.doctype.quality_inspection_template.quality_inspection_template \
|
||||||
import get_template_details
|
import get_template_details
|
||||||
@ -11,6 +12,7 @@ class QualityInspection(Document):
|
|||||||
def validate(self):
|
def validate(self):
|
||||||
if not self.readings and self.item_code:
|
if not self.readings and self.item_code:
|
||||||
self.get_item_specification_details()
|
self.get_item_specification_details()
|
||||||
|
self.validate_inspection_type()
|
||||||
|
|
||||||
def get_item_specification_details(self):
|
def get_item_specification_details(self):
|
||||||
if not self.quality_inspection_template:
|
if not self.quality_inspection_template:
|
||||||
@ -27,6 +29,14 @@ class QualityInspection(Document):
|
|||||||
child.value = d.value
|
child.value = d.value
|
||||||
child.status = "Accepted"
|
child.status = "Accepted"
|
||||||
|
|
||||||
|
def validate_inspection_type(self):
|
||||||
|
if self.inspection_type != "In Process":
|
||||||
|
inspection_required = frappe.db.get_value("Item", filters={
|
||||||
|
'name': self.item_code
|
||||||
|
}, fieldname=['inspection_required_before_purchase', 'inspection_required_before_delivery'])
|
||||||
|
if 0 in inspection_required:
|
||||||
|
frappe.throw(_('Inspection type for the item can only be in process.'))
|
||||||
|
|
||||||
def get_quality_inspection_template(self):
|
def get_quality_inspection_template(self):
|
||||||
template = ''
|
template = ''
|
||||||
if self.bom_no:
|
if self.bom_no:
|
||||||
@ -63,10 +73,12 @@ def item_query(doctype, txt, searchfield, start, page_len, filters):
|
|||||||
mcond = get_match_cond(filters["from"])
|
mcond = get_match_cond(filters["from"])
|
||||||
cond, qi_condition = "", "and (quality_inspection is null or quality_inspection = '')"
|
cond, qi_condition = "", "and (quality_inspection is null or quality_inspection = '')"
|
||||||
|
|
||||||
if filters.get('from') in ['Purchase Invoice Item', 'Purchase Receipt Item']:
|
if filters.get('from') in ['Purchase Invoice Item', 'Purchase Receipt Item']\
|
||||||
|
and filters.get("inspection_type") != "In Process":
|
||||||
cond = """and item_code in (select name from `tabItem` where
|
cond = """and item_code in (select name from `tabItem` where
|
||||||
inspection_required_before_purchase = 1)"""
|
inspection_required_before_purchase = 1)"""
|
||||||
elif filters.get('from') in ['Sales Invoice Item', 'Delivery Note Item']:
|
elif filters.get('from') in ['Sales Invoice Item', 'Delivery Note Item']\
|
||||||
|
and filters.get("inspection_type") != "In Process":
|
||||||
cond = """and item_code in (select name from `tabItem` where
|
cond = """and item_code in (select name from `tabItem` where
|
||||||
inspection_required_before_delivery = 1)"""
|
inspection_required_before_delivery = 1)"""
|
||||||
elif filters.get('from') == 'Stock Entry Detail':
|
elif filters.get('from') == 'Stock Entry Detail':
|
||||||
|
Loading…
x
Reference in New Issue
Block a user