2012-07-19 13:40:31 +05:30
|
|
|
from __future__ import unicode_literals
|
2017-06-15 11:09:27 +05:30
|
|
|
import frappe
|
2018-10-08 18:19:53 +05:30
|
|
|
from frappe import _
|
2017-06-15 11:09:27 +05:30
|
|
|
|
2012-04-05 18:27:56 +05:30
|
|
|
install_docs = [
|
2015-07-13 15:06:12 +05:30
|
|
|
{"doctype":"Role", "role_name":"Stock Manager", "name":"Stock Manager"},
|
|
|
|
{"doctype":"Role", "role_name":"Item Manager", "name":"Item Manager"},
|
|
|
|
{"doctype":"Role", "role_name":"Stock User", "name":"Stock User"},
|
2012-04-17 11:45:35 +05:30
|
|
|
{"doctype":"Role", "role_name":"Quality Manager", "name":"Quality Manager"},
|
2016-07-14 14:03:19 +05:30
|
|
|
{"doctype":"Item Group", "item_group_name":"All Item Groups", "is_group": 1},
|
2019-03-08 11:13:35 +05:30
|
|
|
{"doctype":"Item Group", "item_group_name":"Default",
|
2016-07-14 14:03:19 +05:30
|
|
|
"parent_item_group":"All Item Groups", "is_group": 0},
|
2012-04-05 18:27:56 +05:30
|
|
|
]
|
2017-06-15 11:09:27 +05:30
|
|
|
|
2019-03-08 11:13:35 +05:30
|
|
|
def get_warehouse_account_map(company=None):
|
2020-03-31 15:31:15 +05:30
|
|
|
company_warehouse_account_map = company and frappe.flags.setdefault('warehouse_account_map', {}).get(company)
|
|
|
|
warehouse_account_map = frappe.flags.warehouse_account_map
|
|
|
|
|
|
|
|
if not warehouse_account_map or not company_warehouse_account_map or frappe.flags.in_test:
|
2017-06-15 11:09:27 +05:30
|
|
|
warehouse_account = frappe._dict()
|
|
|
|
|
2019-03-08 11:13:35 +05:30
|
|
|
filters = {}
|
|
|
|
if company:
|
|
|
|
filters['company'] = company
|
2020-03-31 15:31:15 +05:30
|
|
|
frappe.flags.setdefault('warehouse_account_map', {}).setdefault(company, {})
|
2019-03-08 11:13:35 +05:30
|
|
|
|
2018-04-02 10:30:17 +05:30
|
|
|
for d in frappe.get_all('Warehouse',
|
2019-10-31 15:55:03 +05:30
|
|
|
fields = ["name", "account", "parent_warehouse", "company", "is_group"],
|
2019-03-08 11:13:35 +05:30
|
|
|
filters = filters,
|
2018-04-02 10:30:17 +05:30
|
|
|
order_by="lft, rgt"):
|
2017-06-15 11:09:27 +05:30
|
|
|
if not d.account:
|
2018-04-02 10:30:17 +05:30
|
|
|
d.account = get_warehouse_account(d, warehouse_account)
|
2017-06-15 11:09:27 +05:30
|
|
|
|
|
|
|
if d.account:
|
2018-04-02 10:30:17 +05:30
|
|
|
d.account_currency = frappe.db.get_value('Account', d.account, 'account_currency', cache=True)
|
2017-06-15 11:09:27 +05:30
|
|
|
warehouse_account.setdefault(d.name, d)
|
2020-03-31 15:31:15 +05:30
|
|
|
if company:
|
|
|
|
frappe.flags.warehouse_account_map[company] = warehouse_account
|
|
|
|
else:
|
|
|
|
frappe.flags.warehouse_account_map = warehouse_account
|
2021-02-26 17:34:53 +05:30
|
|
|
|
2020-03-31 15:31:15 +05:30
|
|
|
return frappe.flags.warehouse_account_map.get(company) or frappe.flags.warehouse_account_map
|
2017-06-15 11:09:27 +05:30
|
|
|
|
2018-04-02 10:30:17 +05:30
|
|
|
def get_warehouse_account(warehouse, warehouse_account=None):
|
|
|
|
account = warehouse.account
|
|
|
|
if not account and warehouse.parent_warehouse:
|
|
|
|
if warehouse_account:
|
2018-10-08 18:19:53 +05:30
|
|
|
if warehouse_account.get(warehouse.parent_warehouse):
|
|
|
|
account = warehouse_account.get(warehouse.parent_warehouse).account
|
|
|
|
else:
|
|
|
|
from frappe.utils.nestedset import rebuild_tree
|
|
|
|
rebuild_tree("Warehouse", "parent_warehouse")
|
2018-04-02 10:30:17 +05:30
|
|
|
else:
|
|
|
|
account = frappe.db.sql("""
|
|
|
|
select
|
|
|
|
account from `tabWarehouse`
|
|
|
|
where
|
|
|
|
lft <= %s and rgt >= %s and company = %s
|
|
|
|
and account is not null and ifnull(account, '') !=''
|
|
|
|
order by lft desc limit 1""", (warehouse.lft, warehouse.rgt, warehouse.company), as_list=1)
|
|
|
|
|
|
|
|
account = account[0][0] if account else None
|
|
|
|
|
2018-08-16 13:58:44 +05:30
|
|
|
if not account and warehouse.company:
|
2018-04-02 10:30:17 +05:30
|
|
|
account = get_company_default_inventory_account(warehouse.company)
|
|
|
|
|
2021-02-26 17:34:53 +05:30
|
|
|
if not account and warehouse.company:
|
|
|
|
account = frappe.db.get_value('Account',
|
|
|
|
{'account_type': 'Stock', 'is_group': 0, 'company': warehouse.company}, 'name')
|
|
|
|
|
2021-02-16 14:57:00 +05:30
|
|
|
if not account and warehouse.company and not warehouse.is_group:
|
2018-10-08 18:19:53 +05:30
|
|
|
frappe.throw(_("Please set Account in Warehouse {0} or Default Inventory Account in Company {1}")
|
2018-10-19 18:03:13 +05:30
|
|
|
.format(warehouse.name, warehouse.company))
|
2017-06-15 11:09:27 +05:30
|
|
|
return account
|
2019-03-08 11:13:35 +05:30
|
|
|
|
2017-06-15 11:09:27 +05:30
|
|
|
def get_company_default_inventory_account(company):
|
2021-02-18 14:14:21 +05:30
|
|
|
return frappe.get_cached_value('Company', company, 'default_inventory_account')
|