Merge branch 'develop' into refactor/report/exponential-smoothing-forecasting
This commit is contained in:
		
						commit
						1c0f1a2831
					
				| @ -194,16 +194,16 @@ class BuyingController(SubcontractingController): | |||||||
| 
 | 
 | ||||||
| 		if self.meta.get_field("base_in_words"): | 		if self.meta.get_field("base_in_words"): | ||||||
| 			if self.meta.get_field("base_rounded_total") and not self.is_rounded_total_disabled(): | 			if self.meta.get_field("base_rounded_total") and not self.is_rounded_total_disabled(): | ||||||
| 				amount = self.base_rounded_total | 				amount = abs(self.base_rounded_total) | ||||||
| 			else: | 			else: | ||||||
| 				amount = self.base_grand_total | 				amount = abs(self.base_grand_total) | ||||||
| 			self.base_in_words = money_in_words(amount, self.company_currency) | 			self.base_in_words = money_in_words(amount, self.company_currency) | ||||||
| 
 | 
 | ||||||
| 		if self.meta.get_field("in_words"): | 		if self.meta.get_field("in_words"): | ||||||
| 			if self.meta.get_field("rounded_total") and not self.is_rounded_total_disabled(): | 			if self.meta.get_field("rounded_total") and not self.is_rounded_total_disabled(): | ||||||
| 				amount = self.rounded_total | 				amount = abs(self.rounded_total) | ||||||
| 			else: | 			else: | ||||||
| 				amount = self.grand_total | 				amount = abs(self.grand_total) | ||||||
| 
 | 
 | ||||||
| 			self.in_words = money_in_words(amount, self.currency) | 			self.in_words = money_in_words(amount, self.currency) | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -146,7 +146,7 @@ def get_bom_data(filters): | |||||||
| 				) | 				) | ||||||
| 			) | 			) | ||||||
| 		else: | 		else: | ||||||
| 			query = query.where(bin.warehouse == frappe.db.escape(filters.get("warehouse"))) | 			query = query.where(bin.warehouse == filters.get("warehouse")) | ||||||
| 
 | 
 | ||||||
| 	return query.run(as_dict=True) | 	return query.run(as_dict=True) | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -4,6 +4,8 @@ | |||||||
| 
 | 
 | ||||||
| import frappe | import frappe | ||||||
| from frappe import _ | from frappe import _ | ||||||
|  | from frappe.query_builder.functions import Floor, Sum | ||||||
|  | from pypika.terms import ExistsCriterion | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| def execute(filters=None): | def execute(filters=None): | ||||||
| @ -11,7 +13,6 @@ def execute(filters=None): | |||||||
| 		filters = {} | 		filters = {} | ||||||
| 
 | 
 | ||||||
| 	columns = get_columns() | 	columns = get_columns() | ||||||
| 
 |  | ||||||
| 	data = get_bom_stock(filters) | 	data = get_bom_stock(filters) | ||||||
| 
 | 
 | ||||||
| 	return columns, data | 	return columns, data | ||||||
| @ -33,59 +34,57 @@ def get_columns(): | |||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| def get_bom_stock(filters): | def get_bom_stock(filters): | ||||||
| 	conditions = "" | 	qty_to_produce = filters.get("qty_to_produce") or 1 | ||||||
| 	bom = filters.get("bom") | 	if int(qty_to_produce) < 0: | ||||||
| 
 |  | ||||||
| 	table = "`tabBOM Item`" |  | ||||||
| 	qty_field = "stock_qty" |  | ||||||
| 
 |  | ||||||
| 	qty_to_produce = filters.get("qty_to_produce", 1) |  | ||||||
| 	if int(qty_to_produce) <= 0: |  | ||||||
| 		frappe.throw(_("Quantity to Produce can not be less than Zero")) | 		frappe.throw(_("Quantity to Produce can not be less than Zero")) | ||||||
| 
 | 
 | ||||||
| 	if filters.get("show_exploded_view"): | 	if filters.get("show_exploded_view"): | ||||||
| 		table = "`tabBOM Explosion Item`" | 		bom_item_table = "BOM Explosion Item" | ||||||
|  | 	else: | ||||||
|  | 		bom_item_table = "BOM Item" | ||||||
|  | 
 | ||||||
|  | 	bin = frappe.qb.DocType("Bin") | ||||||
|  | 	bom = frappe.qb.DocType("BOM") | ||||||
|  | 	bom_item = frappe.qb.DocType(bom_item_table) | ||||||
|  | 
 | ||||||
|  | 	query = ( | ||||||
|  | 		frappe.qb.from_(bom) | ||||||
|  | 		.inner_join(bom_item) | ||||||
|  | 		.on(bom.name == bom_item.parent) | ||||||
|  | 		.left_join(bin) | ||||||
|  | 		.on(bom_item.item_code == bin.item_code) | ||||||
|  | 		.select( | ||||||
|  | 			bom_item.item_code, | ||||||
|  | 			bom_item.description, | ||||||
|  | 			bom_item.stock_qty, | ||||||
|  | 			bom_item.stock_uom, | ||||||
|  | 			bom_item.stock_qty * qty_to_produce / bom.quantity, | ||||||
|  | 			Sum(bin.actual_qty).as_("actual_qty"), | ||||||
|  | 			Sum(Floor(bin.actual_qty / (bom_item.stock_qty * qty_to_produce / bom.quantity))), | ||||||
|  | 		) | ||||||
|  | 		.where((bom_item.parent == filters.get("bom")) & (bom_item.parenttype == "BOM")) | ||||||
|  | 		.groupby(bom_item.item_code) | ||||||
|  | 	) | ||||||
| 
 | 
 | ||||||
| 	if filters.get("warehouse"): | 	if filters.get("warehouse"): | ||||||
| 		warehouse_details = frappe.db.get_value( | 		warehouse_details = frappe.db.get_value( | ||||||
| 			"Warehouse", filters.get("warehouse"), ["lft", "rgt"], as_dict=1 | 			"Warehouse", filters.get("warehouse"), ["lft", "rgt"], as_dict=1 | ||||||
| 		) | 		) | ||||||
|  | 
 | ||||||
| 		if warehouse_details: | 		if warehouse_details: | ||||||
| 			conditions += ( | 			wh = frappe.qb.DocType("Warehouse") | ||||||
| 				" and exists (select name from `tabWarehouse` wh \ | 			query = query.where( | ||||||
| 				where wh.lft >= %s and wh.rgt <= %s and ledger.warehouse = wh.name)" | 				ExistsCriterion( | ||||||
| 				% (warehouse_details.lft, warehouse_details.rgt) | 					frappe.qb.from_(wh) | ||||||
|  | 					.select(wh.name) | ||||||
|  | 					.where( | ||||||
|  | 						(wh.lft >= warehouse_details.lft) | ||||||
|  | 						& (wh.rgt <= warehouse_details.rgt) | ||||||
|  | 						& (bin.warehouse == wh.name) | ||||||
|  | 					) | ||||||
|  | 				) | ||||||
| 			) | 			) | ||||||
| 		else: | 		else: | ||||||
| 			conditions += " and ledger.warehouse = %s" % frappe.db.escape(filters.get("warehouse")) | 			query = query.where(bin.warehouse == filters.get("warehouse")) | ||||||
| 
 | 
 | ||||||
| 	else: | 	return query.run() | ||||||
| 		conditions += "" |  | ||||||
| 
 |  | ||||||
| 	return frappe.db.sql( |  | ||||||
| 		""" |  | ||||||
| 			SELECT |  | ||||||
| 				bom_item.item_code, |  | ||||||
| 				bom_item.description , |  | ||||||
| 				bom_item.{qty_field}, |  | ||||||
| 				bom_item.stock_uom, |  | ||||||
| 				bom_item.{qty_field} * {qty_to_produce} / bom.quantity, |  | ||||||
| 				sum(ledger.actual_qty) as actual_qty, |  | ||||||
| 				sum(FLOOR(ledger.actual_qty / (bom_item.{qty_field} * {qty_to_produce} / bom.quantity))) |  | ||||||
| 			FROM |  | ||||||
| 				`tabBOM` AS bom INNER JOIN {table} AS bom_item |  | ||||||
| 					ON bom.name = bom_item.parent |  | ||||||
| 				LEFT JOIN `tabBin` AS ledger |  | ||||||
| 					ON bom_item.item_code = ledger.item_code |  | ||||||
| 				{conditions} |  | ||||||
| 			WHERE |  | ||||||
| 				bom_item.parent = {bom} and bom_item.parenttype='BOM' |  | ||||||
| 
 |  | ||||||
| 			GROUP BY bom_item.item_code""".format( |  | ||||||
| 			qty_field=qty_field, |  | ||||||
| 			table=table, |  | ||||||
| 			conditions=conditions, |  | ||||||
| 			bom=frappe.db.escape(bom), |  | ||||||
| 			qty_to_produce=qty_to_produce or 1, |  | ||||||
| 		) |  | ||||||
| 	) |  | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user