2016-03-28 13:21:43 +05:30
|
|
|
# Copyright (c) 2016, Frappe Technologies Pvt. Ltd. and Contributors
|
|
|
|
# See license.txt
|
|
|
|
|
|
|
|
|
|
|
|
import frappe
|
|
|
|
from frappe import _
|
|
|
|
from frappe.utils.bot import BotParser
|
2021-09-02 16:44:59 +05:30
|
|
|
|
2016-03-28 13:21:43 +05:30
|
|
|
|
|
|
|
class FindItemBot(BotParser):
|
|
|
|
def get_reply(self):
|
|
|
|
if self.startswith("where is", "find item", "locate"):
|
2016-03-29 11:53:07 +05:30
|
|
|
if not frappe.has_permission("Warehouse"):
|
|
|
|
raise frappe.PermissionError
|
|
|
|
|
2016-03-28 13:21:43 +05:30
|
|
|
item = "%{0}%".format(self.strip_words(self.query, "where is", "find item", "locate"))
|
|
|
|
items = frappe.db.sql(
|
|
|
|
"""select name from `tabItem` where item_code like %(txt)s
|
|
|
|
or item_name like %(txt)s or description like %(txt)s""",
|
|
|
|
dict(txt=item),
|
|
|
|
)
|
|
|
|
|
|
|
|
if items:
|
|
|
|
out = []
|
|
|
|
warehouses = frappe.get_all("Warehouse")
|
|
|
|
for item in items:
|
|
|
|
found = False
|
|
|
|
for warehouse in warehouses:
|
|
|
|
qty = frappe.db.get_value(
|
|
|
|
"Bin", {"item_code": item[0], "warehouse": warehouse.name}, "actual_qty"
|
|
|
|
)
|
|
|
|
if qty:
|
2020-11-18 15:00:34 +05:30
|
|
|
out.append(
|
|
|
|
_("{0} units of [{1}](/app/Form/Item/{1}) found in [{2}](/app/Form/Warehouse/{2})").format(
|
2016-03-28 13:21:43 +05:30
|
|
|
qty, item[0], warehouse.name
|
|
|
|
)
|
2022-03-28 18:52:46 +05:30
|
|
|
)
|
2016-03-28 13:21:43 +05:30
|
|
|
found = True
|
|
|
|
|
|
|
|
if not found:
|
2020-11-18 15:00:34 +05:30
|
|
|
out.append(_("[{0}](/app/Form/Item/{0}) is out of stock").format(item[0]))
|
2016-03-28 13:21:43 +05:30
|
|
|
|
|
|
|
return "\n\n".join(out)
|
|
|
|
|
|
|
|
else:
|
2020-01-29 15:06:18 +05:30
|
|
|
return _("Did not find any item called {0}").format(item)
|