Merge branch 'master' of github.com:webnotes/erpnext
This commit is contained in:
commit
c81236770f
@ -1,26 +1,5 @@
|
|||||||
wn.query_reports["Batch-Wise Balance History"] = {
|
wn.query_reports["Batch-Wise Balance History"] = {
|
||||||
"filters": [
|
"filters": [
|
||||||
{
|
|
||||||
"fieldname":"item_code",
|
|
||||||
"label": "Item",
|
|
||||||
"fieldtype": "Link",
|
|
||||||
"options": "Item",
|
|
||||||
"width": "80"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"fieldname":"warehouse",
|
|
||||||
"label": "Warehouse",
|
|
||||||
"fieldtype": "Link",
|
|
||||||
"options": "Warehouse",
|
|
||||||
"width": "80"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"fieldname":"batch_no",
|
|
||||||
"label": "Batch",
|
|
||||||
"fieldtype": "Link",
|
|
||||||
"options": "Batch",
|
|
||||||
"width": "80"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"fieldname":"from_date",
|
"fieldname":"from_date",
|
||||||
"label": "From Date",
|
"label": "From Date",
|
||||||
|
@ -49,15 +49,6 @@ def get_columns(filters):
|
|||||||
|
|
||||||
def get_conditions(filters):
|
def get_conditions(filters):
|
||||||
conditions = ""
|
conditions = ""
|
||||||
if filters.get("item_code"):
|
|
||||||
conditions += " and item_code='%s'" % filters["item_code"]
|
|
||||||
|
|
||||||
if filters.get("warehouse"):
|
|
||||||
conditions += " and warehouse='%s'" % filters["warehouse"]
|
|
||||||
|
|
||||||
if filters.get("batch_no"):
|
|
||||||
conditions += " and batch_no='%s'" % filters["batch_no"]
|
|
||||||
|
|
||||||
if not filters.get("from_date"):
|
if not filters.get("from_date"):
|
||||||
webnotes.msgprint("Please enter From Date", raise_exception=1)
|
webnotes.msgprint("Please enter From Date", raise_exception=1)
|
||||||
|
|
||||||
@ -100,8 +91,6 @@ def get_item_warehouse_batch_map(filters):
|
|||||||
return iwb_map
|
return iwb_map
|
||||||
|
|
||||||
def get_item_details(filters):
|
def get_item_details(filters):
|
||||||
if filters.get("item_code"):
|
|
||||||
conditions = " and name = '%s'" % filters["item_code"]
|
|
||||||
item_map = {}
|
item_map = {}
|
||||||
for d in webnotes.conn.sql("select name, item_name, description from tabItem", as_dict=1):
|
for d in webnotes.conn.sql("select name, item_name, description from tabItem", as_dict=1):
|
||||||
item_map.setdefault(d.name, d)
|
item_map.setdefault(d.name, d)
|
||||||
|
@ -1,19 +1,5 @@
|
|||||||
wn.query_reports["Warehouse-Wise Stock Balance"] = {
|
wn.query_reports["Warehouse-Wise Stock Balance"] = {
|
||||||
"filters": [
|
"filters": [
|
||||||
{
|
|
||||||
"fieldname":"item_code",
|
|
||||||
"label": "Item",
|
|
||||||
"fieldtype": "Link",
|
|
||||||
"options": "Item",
|
|
||||||
"width": "80"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"fieldname":"warehouse",
|
|
||||||
"label": "Warehouse",
|
|
||||||
"fieldtype": "Link",
|
|
||||||
"options": "Warehouse",
|
|
||||||
"width": "80"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"fieldname":"from_date",
|
"fieldname":"from_date",
|
||||||
"label": "From Date",
|
"label": "From Date",
|
||||||
|
@ -26,34 +26,29 @@ def execute(filters=None):
|
|||||||
iwb_map = get_item_warehouse_map(filters)
|
iwb_map = get_item_warehouse_map(filters)
|
||||||
|
|
||||||
data = []
|
data = []
|
||||||
for item in sorted(iwb_map):
|
for company in sorted(iwb_map):
|
||||||
for wh in sorted(iwb_map[item]):
|
for item in sorted(iwb_map[company]):
|
||||||
qty_dict = iwb_map[item][wh]
|
for wh in sorted(iwb_map[company][item]):
|
||||||
data.append([item, item_map[item]["item_name"],
|
qty_dict = iwb_map[company][item][wh]
|
||||||
item_map[item]["description"], wh,
|
data.append([item, item_map[item]["item_name"],
|
||||||
qty_dict.opening_qty, qty_dict.in_qty,
|
item_map[item]["description"], wh,
|
||||||
qty_dict.out_qty, qty_dict.bal_qty
|
qty_dict.opening_qty, qty_dict.in_qty,
|
||||||
])
|
qty_dict.out_qty, qty_dict.bal_qty, company
|
||||||
|
])
|
||||||
|
|
||||||
return columns, data
|
return columns, data
|
||||||
|
|
||||||
def get_columns(filters):
|
def get_columns(filters):
|
||||||
"""return columns based on filters"""
|
"""return columns based on filters"""
|
||||||
|
|
||||||
columns = ["Item:Link/Item:100"] + ["Item Name::150"] + ["Description::150"] + \
|
columns = ["Item:Link/Item:100", "Item Name::150", "Description::150", \
|
||||||
["Warehouse:Link/Warehouse:100"] + ["Opening Qty::90"] + \
|
"Warehouse:Link/Warehouse:100", "Opening Qty::90", \
|
||||||
["In Qty::80"] + ["Out Qty::80"] + ["Balance Qty::90"]
|
"In Qty::80", "Out Qty::80", "Balance Qty::90", "Company:Link/Company:100"]
|
||||||
|
|
||||||
return columns
|
return columns
|
||||||
|
|
||||||
def get_conditions(filters):
|
def get_conditions(filters):
|
||||||
conditions = ""
|
conditions = ""
|
||||||
if filters.get("item_code"):
|
|
||||||
conditions += " and item_code='%s'" % filters["item_code"]
|
|
||||||
|
|
||||||
if filters.get("warehouse"):
|
|
||||||
conditions += " and warehouse='%s'" % filters["warehouse"]
|
|
||||||
|
|
||||||
if not filters.get("from_date"):
|
if not filters.get("from_date"):
|
||||||
webnotes.msgprint("Please enter From Date", raise_exception=1)
|
webnotes.msgprint("Please enter From Date", raise_exception=1)
|
||||||
|
|
||||||
@ -68,7 +63,7 @@ def get_conditions(filters):
|
|||||||
def get_stock_ledger_entries(filters):
|
def get_stock_ledger_entries(filters):
|
||||||
conditions = get_conditions(filters)
|
conditions = get_conditions(filters)
|
||||||
return webnotes.conn.sql("""select item_code, warehouse,
|
return webnotes.conn.sql("""select item_code, warehouse,
|
||||||
posting_date, actual_qty
|
posting_date, actual_qty, company
|
||||||
from `tabStock Ledger Entry`
|
from `tabStock Ledger Entry`
|
||||||
where ifnull(is_cancelled, 'No') = 'No' %s order by item_code, warehouse""" %
|
where ifnull(is_cancelled, 'No') = 'No' %s order by item_code, warehouse""" %
|
||||||
conditions, as_dict=1)
|
conditions, as_dict=1)
|
||||||
@ -78,10 +73,11 @@ def get_item_warehouse_map(filters):
|
|||||||
iwb_map = {}
|
iwb_map = {}
|
||||||
|
|
||||||
for d in sle:
|
for d in sle:
|
||||||
iwb_map.setdefault(d.item_code, {}).setdefault(d.warehouse, webnotes._dict({\
|
iwb_map.setdefault(d.company, {}).setdefault(d.item_code, {}).\
|
||||||
|
setdefault(d.warehouse, webnotes._dict({\
|
||||||
"opening_qty": 0.0, "in_qty": 0.0, "out_qty": 0.0, "bal_qty": 0.0
|
"opening_qty": 0.0, "in_qty": 0.0, "out_qty": 0.0, "bal_qty": 0.0
|
||||||
}))
|
}))
|
||||||
qty_dict = iwb_map[d.item_code][d.warehouse]
|
qty_dict = iwb_map[d.company][d.item_code][d.warehouse]
|
||||||
if d.posting_date < filters["from_date"]:
|
if d.posting_date < filters["from_date"]:
|
||||||
qty_dict.opening_qty += flt(d.actual_qty)
|
qty_dict.opening_qty += flt(d.actual_qty)
|
||||||
elif d.posting_date >= filters["from_date"] and d.posting_date <= filters["to_date"]:
|
elif d.posting_date >= filters["from_date"] and d.posting_date <= filters["to_date"]:
|
||||||
@ -95,8 +91,6 @@ def get_item_warehouse_map(filters):
|
|||||||
return iwb_map
|
return iwb_map
|
||||||
|
|
||||||
def get_item_details(filters):
|
def get_item_details(filters):
|
||||||
if filters.get("item_code"):
|
|
||||||
conditions = " and name = '%s'" % filters["item_code"]
|
|
||||||
item_map = {}
|
item_map = {}
|
||||||
for d in webnotes.conn.sql("select name, item_name, description from tabItem", as_dict=1):
|
for d in webnotes.conn.sql("select name, item_name, description from tabItem", as_dict=1):
|
||||||
item_map.setdefault(d.name, d)
|
item_map.setdefault(d.name, d)
|
||||||
|
Loading…
Reference in New Issue
Block a user