2016-04-21 19:00:34 +05:30
|
|
|
import frappe
|
2019-01-24 15:45:46 +05:30
|
|
|
from frappe.model.db_query import DatabaseQuery
|
2021-04-09 11:55:44 +05:30
|
|
|
from frappe.utils import cint, flt
|
2021-09-02 16:44:59 +05:30
|
|
|
|
2023-09-02 11:02:24 +05:30
|
|
|
from erpnext.stock.doctype.stock_reservation_entry.stock_reservation_entry import (
|
|
|
|
get_sre_reserved_qty_for_item_and_warehouse as get_reserved_stock,
|
|
|
|
)
|
|
|
|
|
2016-04-21 19:00:34 +05:30
|
|
|
|
|
|
|
@frappe.whitelist()
|
2016-11-08 12:40:04 +05:30
|
|
|
def get_data(
|
|
|
|
item_code=None, warehouse=None, item_group=None, start=0, sort_by="actual_qty", sort_order="desc"
|
|
|
|
):
|
|
|
|
"""Return data to render the item dashboard"""
|
2019-01-24 15:45:46 +05:30
|
|
|
filters = []
|
2016-04-21 19:00:34 +05:30
|
|
|
if item_code:
|
2019-01-24 15:45:46 +05:30
|
|
|
filters.append(["item_code", "=", item_code])
|
2016-04-21 19:00:34 +05:30
|
|
|
if warehouse:
|
2019-01-24 15:45:46 +05:30
|
|
|
filters.append(["warehouse", "=", warehouse])
|
2016-11-08 12:40:04 +05:30
|
|
|
if item_group:
|
2019-02-01 11:59:18 +05:30
|
|
|
lft, rgt = frappe.db.get_value("Item Group", item_group, ["lft", "rgt"])
|
|
|
|
items = frappe.db.sql_list(
|
|
|
|
"""
|
|
|
|
select i.name from `tabItem` i
|
|
|
|
where exists(select name from `tabItem Group`
|
|
|
|
where name=i.item_group and lft >=%s and rgt<=%s)
|
|
|
|
""",
|
|
|
|
(lft, rgt),
|
|
|
|
)
|
|
|
|
filters.append(["item_code", "in", items])
|
2019-01-24 15:45:46 +05:30
|
|
|
try:
|
|
|
|
# check if user has any restrictions based on user permissions on warehouse
|
|
|
|
if DatabaseQuery("Warehouse", user=frappe.session.user).build_match_conditions():
|
|
|
|
filters.append(["warehouse", "in", [w.name for w in frappe.get_list("Warehouse")]])
|
|
|
|
except frappe.PermissionError:
|
2019-01-24 16:26:48 +05:30
|
|
|
# user does not have access on warehouse
|
2019-01-24 15:45:46 +05:30
|
|
|
return []
|
2016-11-08 12:40:04 +05:30
|
|
|
|
2019-02-19 19:51:23 +05:30
|
|
|
items = frappe.db.get_all(
|
|
|
|
"Bin",
|
|
|
|
fields=[
|
|
|
|
"item_code",
|
|
|
|
"warehouse",
|
|
|
|
"projected_qty",
|
2019-01-24 16:18:43 +05:30
|
|
|
"reserved_qty",
|
|
|
|
"reserved_qty_for_production",
|
|
|
|
"reserved_qty_for_sub_contract",
|
|
|
|
"actual_qty",
|
|
|
|
"valuation_rate",
|
|
|
|
],
|
2019-01-24 15:45:46 +05:30
|
|
|
or_filters={
|
|
|
|
"projected_qty": ["!=", 0],
|
|
|
|
"reserved_qty": ["!=", 0],
|
|
|
|
"reserved_qty_for_production": ["!=", 0],
|
|
|
|
"reserved_qty_for_sub_contract": ["!=", 0],
|
|
|
|
"actual_qty": ["!=", 0],
|
|
|
|
},
|
|
|
|
filters=filters,
|
|
|
|
order_by=sort_by + " " + sort_order,
|
|
|
|
limit_start=start,
|
2022-03-25 00:01:23 +05:30
|
|
|
limit_page_length=21,
|
|
|
|
)
|
2019-02-19 19:51:23 +05:30
|
|
|
|
2023-09-02 11:02:24 +05:30
|
|
|
sre_reserved_stock_details = get_reserved_stock(item_code, warehouse)
|
2021-04-09 11:56:49 +05:30
|
|
|
precision = cint(frappe.db.get_single_value("System Settings", "float_precision"))
|
2021-03-17 18:40:21 +05:30
|
|
|
|
2019-02-19 19:51:23 +05:30
|
|
|
for item in items:
|
|
|
|
item.update(
|
|
|
|
{
|
2022-03-25 00:01:23 +05:30
|
|
|
"item_name": frappe.get_cached_value("Item", item.item_code, "item_name"),
|
|
|
|
"disable_quick_entry": frappe.get_cached_value("Item", item.item_code, "has_batch_no")
|
|
|
|
or frappe.get_cached_value("Item", item.item_code, "has_serial_no"),
|
2021-03-17 18:40:21 +05:30
|
|
|
"projected_qty": flt(item.projected_qty, precision),
|
|
|
|
"reserved_qty": flt(item.reserved_qty, precision),
|
|
|
|
"reserved_qty_for_production": flt(item.reserved_qty_for_production, precision),
|
|
|
|
"reserved_qty_for_sub_contract": flt(item.reserved_qty_for_sub_contract, precision),
|
|
|
|
"actual_qty": flt(item.actual_qty, precision),
|
2023-09-02 11:02:24 +05:30
|
|
|
"reserved_stock": sre_reserved_stock_details.get((item.item_code, item.warehouse), 0),
|
2019-02-19 19:51:23 +05:30
|
|
|
}
|
|
|
|
)
|
|
|
|
return items
|