Merge branch 'develop' into refactor/report/bom-variance-report

This commit is contained in:
Sagar Sharma 2022-09-20 23:11:08 +05:30 committed by GitHub
commit d3a6881737
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 45 additions and 46 deletions

View File

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

View File

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