2015-03-09 16:31:11 +05:30
|
|
|
# Copyright (c) 2013, Web Notes Technologies Pvt. Ltd. and Contributors
|
|
|
|
# License: GNU General Public License v3. See license.txt
|
|
|
|
|
2021-09-02 16:44:59 +05:30
|
|
|
|
2015-03-09 16:31:11 +05:30
|
|
|
import frappe
|
2021-09-02 16:44:59 +05:30
|
|
|
|
2015-08-24 16:16:29 +05:30
|
|
|
from erpnext.stock.stock_balance import get_reserved_qty, update_bin_qty
|
2021-09-02 16:44:59 +05:30
|
|
|
|
2015-03-09 16:31:11 +05:30
|
|
|
|
|
|
|
def execute():
|
2016-04-20 11:53:34 +05:30
|
|
|
for doctype in ("Sales Order Item", "Bin"):
|
|
|
|
frappe.reload_doctype(doctype)
|
2016-01-07 16:47:44 +05:30
|
|
|
|
2015-08-17 15:36:23 +05:30
|
|
|
repost_for = frappe.db.sql(
|
|
|
|
"""
|
2016-01-07 16:47:44 +05:30
|
|
|
select
|
|
|
|
distinct item_code, warehouse
|
|
|
|
from
|
2015-08-17 15:36:23 +05:30
|
|
|
(
|
|
|
|
(
|
2016-01-07 16:47:44 +05:30
|
|
|
select distinct item_code, warehouse
|
2015-08-17 15:36:23 +05:30
|
|
|
from `tabSales Order Item` where docstatus=1
|
|
|
|
) UNION (
|
2016-01-07 16:47:44 +05:30
|
|
|
select distinct item_code, warehouse
|
2015-08-17 15:36:23 +05:30
|
|
|
from `tabPacked Item` where docstatus=1 and parenttype='Sales Order'
|
|
|
|
)
|
2015-08-20 14:59:25 +05:30
|
|
|
) so_item
|
|
|
|
where
|
|
|
|
exists(select name from tabItem where name=so_item.item_code and ifnull(is_stock_item, 0)=1)
|
2015-08-17 15:36:23 +05:30
|
|
|
"""
|
|
|
|
)
|
2015-08-20 14:59:25 +05:30
|
|
|
|
2015-08-17 15:36:23 +05:30
|
|
|
for item_code, warehouse in repost_for:
|
2022-02-17 19:25:00 +05:30
|
|
|
if not (item_code and warehouse):
|
|
|
|
continue
|
|
|
|
update_bin_qty(item_code, warehouse, {"reserved_qty": get_reserved_qty(item_code, warehouse)})
|
2016-01-07 16:47:44 +05:30
|
|
|
|
|
|
|
frappe.db.sql(
|
|
|
|
"""delete from tabBin
|
2015-08-20 15:21:42 +05:30
|
|
|
where exists(
|
|
|
|
select name from tabItem where name=tabBin.item_code and ifnull(is_stock_item, 0) = 0
|
|
|
|
)
|
2016-01-07 16:47:44 +05:30
|
|
|
"""
|
|
|
|
)
|