// Copyright (c) 2015, Frappe Technologies Pvt. Ltd. and Contributors // License: GNU General Public License v3. See license.txt // js inside blog page // shopping cart frappe.provide("shopping_cart"); $.extend(shopping_cart, { show_error: function(title, text) { $("#cart-container").html('

' + title + '

' + text + '

'); }, bind_events: function() { // bind update button $(document).on("click", ".item-update-cart button", function() { var item_code = $(this).attr("data-item-code"); shopping_cart.update_cart({ item_code: item_code, qty: $('input[data-item-code="'+item_code+'"]').val(), with_doc: 1, btn: this, callback: function(r) { if(!r.exc) { shopping_cart.render(r.message); var $button = $('button[data-item-code="'+item_code+'"]').addClass("btn-success"); setTimeout(function() { $button.removeClass("btn-success"); }, 1000); } }, }); }); $("#cart-add-shipping-address").on("click", function() { window.location.href = "addresses"; }); $("#cart-add-billing-address").on("click", function() { window.location.href = "address"; }); $(".btn-place-order").on("click", function() { shopping_cart.place_order(this); }); }, render: function(out) { var doc = out.doc; var addresses = out.addresses; var $cart_items = $("#cart-items").empty(); var $cart_taxes = $("#cart-taxes").empty(); var $cart_totals = $("#cart-totals").empty(); var $cart_billing_address = $("#cart-billing-address").empty(); var $cart_shipping_address = $("#cart-shipping-address").empty(); var no_items = $.map(doc.items || [], function(d) { return d.item_code || null;}).length===0; if(no_items) { shopping_cart.show_error("Cart Empty", frappe._("Go ahead and add something to your cart.")); $("#cart-addresses").toggle(false); return; } var shipping_rule_added = false; var taxes_exist = false; var shipping_rule_labels = $.map(out.shipping_rules || [], function(rule) { return rule[1]; }); $.each(doc.items || [], function(i, d) { shopping_cart.render_item_row($cart_items, d); }); $.each(doc.taxes || [], function(i, d) { if(out.shipping_rules && out.shipping_rules.length && shipping_rule_labels.indexOf(d.description)!==-1) { shipping_rule_added = true; shopping_cart.render_tax_row($cart_taxes, d, out.shipping_rules); } else { shopping_cart.render_tax_row($cart_taxes, d); } taxes_exist = true; }); if(out.shipping_rules && out.shipping_rules.length && !shipping_rule_added) { shopping_cart.render_tax_row($cart_taxes, {description: "", formatted_tax_amount: ""}, out.shipping_rules); taxes_exist = true; } if(taxes_exist) $('
').appendTo($cart_taxes); shopping_cart.render_tax_row($cart_totals, { description: "Total", formatted_tax_amount: "" + doc.formatted_grand_total_export + "" }); if(!(addresses && addresses.length)) { $cart_shipping_address.html('
'+frappe._("Hey! Go ahead and add an address")+'
'); } else { shopping_cart.render_address($cart_shipping_address, addresses, doc.shipping_address_name); shopping_cart.render_address($cart_billing_address, addresses, doc.customer_address); } }, render_item_row: function($cart_items, doc) { doc.image_html = doc.website_image ? '
': ""; if(doc.description === doc.item_name) doc.description = ""; $(repl('
\
\
\
%(image_html)s
\
\

%(item_name)s

\

%(description)s

\
\
\
\
\
\ \
\ \
\
\

at %(formatted_rate)s

\ = %(formatted_amount)s\
\

', doc)).appendTo($cart_items); }, render_tax_row: function($cart_taxes, doc, shipping_rules) { var shipping_selector; if(shipping_rules) { shipping_selector = ''; } var $tax_row = $(repl('
\
\
\
' + (shipping_selector || '

%(description)s

') + '
\
\
\
\ %(formatted_tax_amount)s

\
\
', doc)).appendTo($cart_taxes); if(shipping_selector) { $tax_row.find('select option').each(function(i, opt) { if($(opt).html() == doc.description) { $(opt).attr("selected", "selected"); } }); $tax_row.find('select').on("change", function() { shopping_cart.apply_shipping_rule($(this).val(), this); }); } }, apply_shipping_rule: function(rule, btn) { return frappe.call({ btn: btn, type: "POST", method: "erpnext.shopping_cart.cart.apply_shipping_rule", args: { shipping_rule: rule }, callback: function(r) { if(!r.exc) { shopping_cart.render(r.message); } } }); }, render_address: function($address_wrapper, addresses, address_name) { $.each(addresses, function(i, address) { $(repl('
\
\
\
%(name)s
\
\
\
\
\
%(display)s
\
\
', address)) .css({"margin": "10px auto"}) .appendTo($address_wrapper); }); $address_wrapper.find(".panel-heading") .find(".address-title") .css({"cursor": "pointer"}) .on("click", function() { $address_wrapper.find('.panel-collapse[data-address-name="' +$(this).attr("data-address-name")+'"]').collapse("toggle"); }); $address_wrapper.find('input[type="checkbox"]').on("click", function() { if($(this).prop("checked")) { var me = this; $address_wrapper.find('input[type="checkbox"]').each(function(i, chk) { if($(chk).attr("data-address-name")!=$(me).attr("data-address-name")) { $(chk).prop("checked", false); } }); return frappe.call({ type: "POST", method: "erpnext.shopping_cart.cart.update_cart_address", args: { address_fieldname: $address_wrapper.attr("data-fieldname"), address_name: $(this).attr("data-address-name") }, callback: function(r) { if(!r.exc) { shopping_cart.render(r.message); } } }); } else { return false; } }); $address_wrapper.find('input[type="checkbox"][data-address-name="'+ address_name +'"]') .prop("checked", true); $address_wrapper.find(".panel-collapse").collapse({ parent: $address_wrapper, toggle: false }); $address_wrapper.find('.panel-collapse[data-address-name="'+ address_name +'"]') .collapse("show"); }, place_order: function(btn) { return frappe.call({ type: "POST", method: "erpnext.shopping_cart.cart.place_order", btn: btn, callback: function(r) { if(r.exc) { var msg = ""; if(r._server_messages) { msg = JSON.parse(r._server_messages || []).join("
"); } $("#cart-error") .empty() .html(msg || frappe._("Something went wrong!")) .toggle(true); } else { window.location.href = "/orders/" + encodeURIComponent(r.message); } } }); } }); $(document).ready(function() { shopping_cart.bind_events(); return frappe.call({ type: "POST", method: "erpnext.shopping_cart.cart.get_cart_quotation", callback: function(r) { $("#cart-container").removeClass("hide"); $(".progress").remove(); if(r.exc) { if(r.exc.indexOf("WebsitePriceListMissingError")!==-1) { shopping_cart.show_error("Configuration Error", frappe._("Price List not configured.")); } else if(r["403"]) { shopping_cart.show_error("Not Allowed", frappe._("You need to be logged in to view your cart.")); } else { shopping_cart.show_error("Error", frappe._("Something went wrong.")); } } else { shopping_cart.set_cart_count(); shopping_cart.render(r.message); } } }); });