2015-03-03 09:25:30 +00:00
|
|
|
# Copyright (c) 2015, Frappe Technologies Pvt. Ltd. and Contributors
|
2014-10-21 10:46:30 +00:00
|
|
|
# License: GNU General Public License v3. See license.txt
|
|
|
|
|
|
|
|
from __future__ import unicode_literals
|
|
|
|
|
|
|
|
import frappe
|
2015-07-13 10:53:42 +00:00
|
|
|
from frappe.utils import cint, fmt_money
|
2014-10-21 10:46:30 +00:00
|
|
|
from erpnext.shopping_cart.cart import _get_cart_quotation
|
2015-07-13 10:53:42 +00:00
|
|
|
from erpnext.shopping_cart.doctype.shopping_cart_settings.shopping_cart_settings import is_cart_enabled
|
2014-10-21 10:46:30 +00:00
|
|
|
|
|
|
|
@frappe.whitelist(allow_guest=True)
|
|
|
|
def get_product_info(item_code):
|
|
|
|
"""get product price / stock info"""
|
2015-07-13 10:53:42 +00:00
|
|
|
if not is_cart_enabled():
|
2014-10-21 10:46:30 +00:00
|
|
|
return {}
|
|
|
|
|
|
|
|
qty = 0
|
2015-10-20 12:00:02 +00:00
|
|
|
cart_quotation = _get_cart_quotation()
|
|
|
|
template_item_code = frappe.db.get_value("Item", item_code, "variant_of")
|
|
|
|
in_stock = get_qty_in_stock(item_code, template_item_code)
|
|
|
|
price = get_price(item_code, template_item_code, cart_quotation.selling_price_list)
|
2014-10-21 10:46:30 +00:00
|
|
|
|
|
|
|
if price:
|
|
|
|
price["formatted_price"] = fmt_money(price["price_list_rate"], currency=price["currency"])
|
|
|
|
|
|
|
|
price["currency"] = not cint(frappe.db.get_default("hide_currency_symbol")) \
|
|
|
|
and (frappe.db.get_value("Currency", price.currency, "symbol") or price.currency) \
|
|
|
|
or ""
|
|
|
|
|
|
|
|
if frappe.session.user != "Guest":
|
|
|
|
item = cart_quotation.get({"item_code": item_code})
|
|
|
|
if item:
|
|
|
|
qty = item[0].qty
|
|
|
|
|
|
|
|
return {
|
|
|
|
"price": price,
|
|
|
|
"stock": in_stock,
|
|
|
|
"uom": frappe.db.get_value("Item", item_code, "stock_uom"),
|
|
|
|
"qty": qty
|
|
|
|
}
|
2015-10-20 12:00:02 +00:00
|
|
|
|
|
|
|
def get_qty_in_stock(item_code, template_item_code):
|
|
|
|
warehouse = frappe.db.get_value("Item", item_code, "website_warehouse")
|
|
|
|
if not warehouse and template_item_code and template_item_code != item_code:
|
|
|
|
warehouse = frappe.db.get_value("Item", template_item_code, "website_warehouse")
|
|
|
|
|
|
|
|
if warehouse:
|
|
|
|
in_stock = frappe.db.sql("""select actual_qty from tabBin where
|
|
|
|
item_code=%s and warehouse=%s""", (item_code, warehouse))
|
|
|
|
if in_stock:
|
|
|
|
in_stock = in_stock[0][0] > 0 and 1 or 0
|
|
|
|
|
|
|
|
else:
|
|
|
|
in_stock = -1
|
|
|
|
|
|
|
|
return in_stock
|
|
|
|
|
|
|
|
def get_price(item_code, template_item_code, price_list):
|
|
|
|
if price_list:
|
|
|
|
price = frappe.get_all("Item Price", fields=["price_list_rate", "currency"],
|
|
|
|
filters={"price_list": price_list, "item_code": item_code})
|
|
|
|
|
|
|
|
if not price:
|
|
|
|
price = frappe.get_all("Item Price", fields=["price_list_rate", "currency"],
|
|
|
|
filters={"price_list": price_list, "item_code": template_item_code})
|
|
|
|
|
|
|
|
if price:
|
|
|
|
return price[0]
|