brotherton-erpnext/erpnext/patches/v13_0/add_bin_unique_constraint.py

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

72 lines
1.7 KiB
Python
Raw Normal View History

2022-01-30 18:10:43 +05:30
import frappe
from erpnext.stock.stock_balance import (
get_balance_qty_from_sle,
get_indented_qty,
get_ordered_qty,
get_planned_qty,
get_reserved_qty,
)
from erpnext.stock.utils import get_bin
2022-01-30 18:10:43 +05:30
def execute():
delete_broken_bins()
delete_and_patch_duplicate_bins()
2022-01-30 18:10:43 +05:30
2022-03-28 18:52:46 +05:30
def delete_broken_bins():
# delete useless bins
frappe.db.sql("delete from `tabBin` where item_code is null or warehouse is null")
2022-03-28 18:52:46 +05:30
def delete_and_patch_duplicate_bins():
duplicate_bins = frappe.db.sql(
"""
2022-01-30 18:10:43 +05:30
SELECT
item_code, warehouse, count(*) as bin_count
2022-01-30 18:10:43 +05:30
FROM
tabBin
GROUP BY
item_code, warehouse
HAVING
bin_count > 1
2022-01-30 18:10:43 +05:30
""",
as_dict=1,
)
for duplicate_bin in duplicate_bins:
item_code = duplicate_bin.item_code
warehouse = duplicate_bin.warehouse
existing_bins = frappe.get_list(
"Bin",
filters={"item_code": item_code, "warehouse": warehouse},
fields=["name"],
order_by="creation",
)
# keep last one
existing_bins.pop()
2022-01-30 18:10:43 +05:30
for broken_bin in existing_bins:
frappe.delete_doc("Bin", broken_bin.name)
2022-01-30 18:10:43 +05:30
qty_dict = {
"reserved_qty": get_reserved_qty(item_code, warehouse),
"indented_qty": get_indented_qty(item_code, warehouse),
"ordered_qty": get_ordered_qty(item_code, warehouse),
"planned_qty": get_planned_qty(item_code, warehouse),
"actual_qty": get_balance_qty_from_sle(item_code, warehouse),
2022-01-30 18:10:43 +05:30
}
bin = get_bin(item_code, warehouse)
bin.update(qty_dict)
bin.update_reserved_qty_for_production()
bin.update_reserved_qty_for_sub_contracting()
if frappe.db.count(
"Purchase Order", {"status": ["!=", "Completed"], "is_old_subcontracting_flow": 1}
):
bin.update_reserved_qty_for_sub_contracting(subcontract_doctype="Purchase Order")
bin.db_update()