| // 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('<div class="msg-box"><h4>' + title + '</h4> ' + text + '</div>'); |
| }, |
| |
| 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 = "address?address_fieldname=shipping_address_name"; |
| }); |
| |
| $("#cart-add-billing-address").on("click", function() { |
| window.location.href = "address?address_fieldname=customer_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("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) |
| $('<hr>').appendTo($cart_taxes); |
| |
| shopping_cart.render_tax_row($cart_totals, { |
| description: "<strong>Total</strong>", |
| formatted_tax_amount: "<strong>" + doc.formatted_grand_total_export + "</strong>" |
| }); |
| |
| if(!(addresses && addresses.length)) { |
| $cart_shipping_address.html('<div class="msg-box">'+frappe._("Hey! Go ahead and add an address")+'</div>'); |
| } 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 ? |
| '<div style="height: 120px; overflow: hidden;"><img src="' + doc.website_image + '" /></div>': ""; |
| |
| if(doc.description === doc.item_name) doc.description = ""; |
| |
| $(repl('<div class="row">\ |
| <div class="col-md-9 col-sm-9">\ |
| <div class="row">\ |
| <div class="col-md-3">%(image_html)s</div>\ |
| <div class="col-md-9">\ |
| <h4><a href="%(page_name)s">%(item_name)s</a></h4>\ |
| <p>%(description)s</p>\ |
| </div>\ |
| </div>\ |
| </div>\ |
| <div class="col-md-3 col-sm-3 text-right">\ |
| <div class="input-group item-update-cart">\ |
| <input type="text" placeholder="Qty" value="%(qty)s" \ |
| data-item-code="%(item_code)s" class="text-right form-control">\ |
| <div class="input-group-btn">\ |
| <button class="btn btn-primary" data-item-code="%(item_code)s">\ |
| <i class="icon-ok"></i></button>\ |
| </div>\ |
| </div>\ |
| <p style="margin-top: 10px;">at %(formatted_rate)s</p>\ |
| <small class="text-muted" style="margin-top: 10px;">= %(formatted_amount)s</small>\ |
| </div>\ |
| </div><hr>', doc)).appendTo($cart_items); |
| }, |
| |
| render_tax_row: function($cart_taxes, doc, shipping_rules) { |
| var shipping_selector; |
| if(shipping_rules) { |
| shipping_selector = '<select class="form-control">' + $.map(shipping_rules, function(rule) { |
| return '<option value="' + rule[0] + '">' + rule[1] + '</option>' }).join("\n") + |
| '</select>'; |
| } |
| |
| var $tax_row = $(repl('<div class="row">\ |
| <div class="col-md-9 col-sm-9">\ |
| <div class="row">\ |
| <div class="col-md-9 col-md-offset-3">' + |
| (shipping_selector || '<p>%(description)s</p>') + |
| '</div>\ |
| </div>\ |
| </div>\ |
| <div class="col-md-3 col-sm-3 text-right">\ |
| <p' + (shipping_selector ? ' style="margin-top: 5px;"' : "") + '>%(formatted_tax_amount)s</p>\ |
| </div>\ |
| </div>', 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('<div class="panel panel-default"> \ |
| <div class="panel-heading"> \ |
| <div class="row"> \ |
| <div class="col-md-10 address-title" \ |
| data-address-name="%(name)s"><strong>%(name)s</strong></div> \ |
| <div class="col-md-2"><input type="checkbox" \ |
| data-address-name="%(name)s"></div> \ |
| </div> \ |
| </div> \ |
| <div class="panel-collapse collapse" data-address-name="%(name)s"> \ |
| <div class="panel-body">%(display)s</div> \ |
| </div> \ |
| </div>', 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("<br>"); |
| } |
| |
| $("#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("Oops!", frappe._("Price List not configured.")); |
| } else if(r["403"]) { |
| shopping_cart.show_error("Hey!", frappe._("You need to be logged in to view your cart.")); |
| } else { |
| shopping_cart.show_error("Oops!", frappe._("Something went wrong.")); |
| } |
| } else { |
| shopping_cart.set_cart_count(); |
| shopping_cart.render(r.message); |
| } |
| } |
| }); |
| }); |