blob: 232501d4a20a8ea9f9af4651f4fbdb08c2086a9d [file] [log] [blame]
Rushabh Mehtaad45e312013-11-20 12:59:58 +05301// Copyright (c) 2013, Web Notes Technologies Pvt. Ltd. and Contributors
Rushabh Mehtae67d1fb2013-08-05 14:59:54 +05302// License: GNU General Public License v3. See license.txt
Anand Doshiab690292013-06-13 11:21:35 +05303
4// js inside blog page
5
6$(document).ready(function() {
Anand Doshi0748cb72013-09-11 15:31:58 +05307 erpnext.cart.bind_events();
Anand Doshi1fac2a92013-07-29 19:30:39 +05308 return wn.call({
Anand Doshic2a35272013-06-19 17:19:20 +05309 type: "POST",
Rushabh Mehtac59c4e02013-09-09 12:17:45 +053010 method: "selling.utils.cart.get_cart_quotation",
Anand Doshi3dceb842013-06-19 14:57:14 +053011 callback: function(r) {
Anand Doshi3dceb842013-06-19 14:57:14 +053012 $("#cart-container").removeClass("hide");
13 $(".progress").remove();
14 if(r.exc) {
15 if(r.exc.indexOf("WebsitePriceListMissingError")!==-1) {
Bárbara Perretti187ea332013-10-09 14:53:44 -030016 erpnext.cart.show_error("Oops!", wn._("Price List not configured."));
Anand Doshiedbf3e12013-07-02 11:40:16 +053017 } else if(r["403"]) {
Bárbara Perretti187ea332013-10-09 14:53:44 -030018 erpnext.cart.show_error("Hey!", wn._("You need to be logged in to view your cart."));
Anand Doshi3dceb842013-06-19 14:57:14 +053019 } else {
Bárbara Perretti187ea332013-10-09 14:53:44 -030020 erpnext.cart.show_error("Oops!", wn._("Something went wrong."));
Anand Doshi3dceb842013-06-19 14:57:14 +053021 }
22 } else {
Anand Doshi0748cb72013-09-11 15:31:58 +053023 erpnext.cart.set_cart_count();
24 erpnext.cart.render(r.message);
Anand Doshi3dceb842013-06-19 14:57:14 +053025 }
Anand Doshi3dceb842013-06-19 14:57:14 +053026 }
27 });
Anand Doshiab690292013-06-13 11:21:35 +053028});
29
30// shopping cart
Anand Doshi0748cb72013-09-11 15:31:58 +053031if(!erpnext.cart) erpnext.cart = {};
32$.extend(erpnext.cart, {
Anand Doshi3dceb842013-06-19 14:57:14 +053033 show_error: function(title, text) {
34 $("#cart-container").html('<div class="well"><h4>' + title + '</h4> ' + text + '</div>');
35 },
36
Anand Doshic2a35272013-06-19 17:19:20 +053037 bind_events: function() {
38 // bind update button
39 $(document).on("click", ".item-update-cart button", function() {
Anand Doshic2a35272013-06-19 17:19:20 +053040 var item_code = $(this).attr("data-item-code");
Anand Doshi0748cb72013-09-11 15:31:58 +053041 erpnext.cart.update_cart({
Anand Doshic2a35272013-06-19 17:19:20 +053042 item_code: item_code,
43 qty: $('input[data-item-code="'+item_code+'"]').val(),
44 with_doclist: 1,
45 btn: this,
46 callback: function(r) {
47 if(!r.exc) {
Anand Doshi0748cb72013-09-11 15:31:58 +053048 erpnext.cart.render(r.message);
Anand Doshic2a35272013-06-19 17:19:20 +053049 var $button = $('button[data-item-code="'+item_code+'"]').addClass("btn-success");
50 setTimeout(function() { $button.removeClass("btn-success"); }, 1000);
51 }
52 },
53 });
54 });
Anand Doshiedbf3e12013-07-02 11:40:16 +053055
56 $("#cart-add-shipping-address").on("click", function() {
57 window.location.href = "address?address_fieldname=shipping_address_name";
58 });
59
60 $("#cart-add-billing-address").on("click", function() {
61 window.location.href = "address?address_fieldname=customer_address";
62 });
Anand Doshi2ac0a832013-07-10 20:49:44 +053063
64 $(".btn-place-order").on("click", function() {
Anand Doshi0748cb72013-09-11 15:31:58 +053065 erpnext.cart.place_order(this);
Anand Doshi2ac0a832013-07-10 20:49:44 +053066 });
Anand Doshic2a35272013-06-19 17:19:20 +053067 },
68
Anand Doshiedbf3e12013-07-02 11:40:16 +053069 render: function(out) {
70 var doclist = out.doclist;
71 var addresses = out.addresses;
Anand Doshi0b4943c2013-07-04 23:45:22 +053072
Anand Doshiedbf3e12013-07-02 11:40:16 +053073 var $cart_items = $("#cart-items").empty();
74 var $cart_taxes = $("#cart-taxes").empty();
Anand Doshi0b4943c2013-07-04 23:45:22 +053075 var $cart_totals = $("#cart-totals").empty();
Anand Doshiedbf3e12013-07-02 11:40:16 +053076 var $cart_billing_address = $("#cart-billing-address").empty();
77 var $cart_shipping_address = $("#cart-shipping-address").empty();
Anand Doshic2a35272013-06-19 17:19:20 +053078
Anand Doshiedbf3e12013-07-02 11:40:16 +053079 var no_items = $.map(doclist, function(d) { return d.item_code || null;}).length===0;
80 if(no_items) {
Bárbara Perretti187ea332013-10-09 14:53:44 -030081 erpnext.cart.show_error("Empty :-(", wn._("Go ahead and add something to your cart."));
Anand Doshiedbf3e12013-07-02 11:40:16 +053082 $("#cart-addresses").toggle(false);
Anand Doshic2a35272013-06-19 17:19:20 +053083 return;
84 }
85
Anand Doshi0b4943c2013-07-04 23:45:22 +053086 var shipping_rule_added = false;
87 var taxes_exist = false;
Anand Doshi2862c9e2013-07-08 18:50:33 +053088 var shipping_rule_labels = $.map(out.shipping_rules || [], function(rule) { return rule[1]; });
Anand Doshic2a35272013-06-19 17:19:20 +053089 $.each(doclist, function(i, doc) {
90 if(doc.doctype === "Quotation Item") {
Anand Doshi0748cb72013-09-11 15:31:58 +053091 erpnext.cart.render_item_row($cart_items, doc);
Anand Doshi0b4943c2013-07-04 23:45:22 +053092 } else if (doc.doctype === "Sales Taxes and Charges") {
93 if(out.shipping_rules && out.shipping_rules.length &&
94 shipping_rule_labels.indexOf(doc.description)!==-1) {
95 shipping_rule_added = true;
Anand Doshi0748cb72013-09-11 15:31:58 +053096 erpnext.cart.render_tax_row($cart_taxes, doc, out.shipping_rules);
Anand Doshi0b4943c2013-07-04 23:45:22 +053097 } else {
Anand Doshi0748cb72013-09-11 15:31:58 +053098 erpnext.cart.render_tax_row($cart_taxes, doc);
Anand Doshi0b4943c2013-07-04 23:45:22 +053099 }
100
101 taxes_exist = true;
Anand Doshic2a35272013-06-19 17:19:20 +0530102 }
103 });
104
Anand Doshi0b4943c2013-07-04 23:45:22 +0530105 if(out.shipping_rules && out.shipping_rules.length && !shipping_rule_added) {
Anand Doshi0748cb72013-09-11 15:31:58 +0530106 erpnext.cart.render_tax_row($cart_taxes, {description: "", formatted_tax_amount: ""},
Anand Doshi0b4943c2013-07-04 23:45:22 +0530107 out.shipping_rules);
108 taxes_exist = true;
109 }
110
111 if(taxes_exist)
112 $('<hr>').appendTo($cart_taxes);
113
Anand Doshi0748cb72013-09-11 15:31:58 +0530114 erpnext.cart.render_tax_row($cart_totals, {
Anand Doshi0b4943c2013-07-04 23:45:22 +0530115 description: "<strong>Total</strong>",
116 formatted_tax_amount: "<strong>" + doclist[0].formatted_grand_total_export + "</strong>"
117 });
118
Anand Doshiedbf3e12013-07-02 11:40:16 +0530119 if(!(addresses && addresses.length)) {
Bárbara Perretti187ea332013-10-09 14:53:44 -0300120 $cart_shipping_address.html('<div class="well">'+wn._("Hey! Go ahead and add an address")+'</div>');
Anand Doshiab690292013-06-13 11:21:35 +0530121 } else {
Anand Doshi0748cb72013-09-11 15:31:58 +0530122 erpnext.cart.render_address($cart_shipping_address, addresses, doclist[0].shipping_address_name);
123 erpnext.cart.render_address($cart_billing_address, addresses, doclist[0].customer_address);
Anand Doshiab690292013-06-13 11:21:35 +0530124 }
Anand Doshiabc10032013-06-14 17:44:03 +0530125 },
126
Anand Doshiedbf3e12013-07-02 11:40:16 +0530127 render_item_row: function($cart_items, doc) {
Nabin Hait6ec4b0c2013-09-26 15:45:44 +0530128 doc.image_html = doc.website_image ?
129 '<div style="height: 120px; overflow: hidden;"><img src="' + doc.website_image + '" /></div>' :
Anand Doshib0d996f2013-09-10 18:29:39 +0530130 '{% include "app/stock/doctype/item/templates/includes/product_missing_image.html" %}';
Anand Doshiedbf3e12013-07-02 11:40:16 +0530131
Anand Doshicefccb92013-07-15 18:28:14 +0530132 if(doc.description === doc.item_name) doc.description = "";
Anand Doshiedbf3e12013-07-02 11:40:16 +0530133
134 $(repl('<div class="row">\
Rushabh Mehtacce21d12013-08-21 17:48:08 +0530135 <div class="col-md-9 col-sm-9">\
Anand Doshiedbf3e12013-07-02 11:40:16 +0530136 <div class="row">\
Rushabh Mehtacce21d12013-08-21 17:48:08 +0530137 <div class="col-md-3">%(image_html)s</div>\
138 <div class="col-md-9">\
Anand Doshiedbf3e12013-07-02 11:40:16 +0530139 <h4><a href="%(page_name)s">%(item_name)s</a></h4>\
Anand Doshicefccb92013-07-15 18:28:14 +0530140 <p>%(description)s</p>\
Anand Doshiedbf3e12013-07-02 11:40:16 +0530141 </div>\
142 </div>\
143 </div>\
Rushabh Mehtacce21d12013-08-21 17:48:08 +0530144 <div class="col-md-3 col-sm-3 text-right">\
Anand Doshiedbf3e12013-07-02 11:40:16 +0530145 <div class="input-group item-update-cart">\
146 <input type="text" placeholder="Qty" value="%(qty)s" \
Anand Doshi65f5c582013-08-21 19:36:23 +0530147 data-item-code="%(item_code)s" class="text-right form-control">\
Anand Doshiedbf3e12013-07-02 11:40:16 +0530148 <div class="input-group-btn">\
149 <button class="btn btn-primary" data-item-code="%(item_code)s">\
150 <i class="icon-ok"></i></button>\
151 </div>\
152 </div>\
153 <p style="margin-top: 10px;">at %(formatted_rate)s</p>\
154 <small class="text-muted" style="margin-top: 10px;">= %(formatted_amount)s</small>\
155 </div>\
156 </div><hr>', doc)).appendTo($cart_items);
157 },
158
Anand Doshi0b4943c2013-07-04 23:45:22 +0530159 render_tax_row: function($cart_taxes, doc, shipping_rules) {
160 var shipping_selector;
161 if(shipping_rules) {
Anand Doshi65f5c582013-08-21 19:36:23 +0530162 shipping_selector = '<select class="form-control">' + $.map(shipping_rules, function(rule) {
Anand Doshi0b4943c2013-07-04 23:45:22 +0530163 return '<option value="' + rule[0] + '">' + rule[1] + '</option>' }).join("\n") +
164 '</select>';
165 }
166
167 var $tax_row = $(repl('<div class="row">\
Rushabh Mehtacce21d12013-08-21 17:48:08 +0530168 <div class="col-md-9 col-sm-9">\
Anand Doshi0b4943c2013-07-04 23:45:22 +0530169 <div class="row">\
Rushabh Mehtacce21d12013-08-21 17:48:08 +0530170 <div class="col-md-9 col-md-offset-3">' +
Anand Doshi0b4943c2013-07-04 23:45:22 +0530171 (shipping_selector || '<p>%(description)s</p>') +
172 '</div>\
173 </div>\
174 </div>\
Rushabh Mehtacce21d12013-08-21 17:48:08 +0530175 <div class="col-md-3 col-sm-3 text-right">\
Anand Doshi0b4943c2013-07-04 23:45:22 +0530176 <p' + (shipping_selector ? ' style="margin-top: 5px;"' : "") + '>%(formatted_tax_amount)s</p>\
177 </div>\
178 </div>', doc)).appendTo($cart_taxes);
179
180 if(shipping_selector) {
181 $tax_row.find('select option').each(function(i, opt) {
182 if($(opt).html() == doc.description) {
183 $(opt).attr("selected", "selected");
184 }
185 });
186 $tax_row.find('select').on("change", function() {
Anand Doshi0748cb72013-09-11 15:31:58 +0530187 erpnext.cart.apply_shipping_rule($(this).val(), this);
Anand Doshi0b4943c2013-07-04 23:45:22 +0530188 });
189 }
190 },
191
192 apply_shipping_rule: function(rule, btn) {
Anand Doshi1fac2a92013-07-29 19:30:39 +0530193 return wn.call({
Anand Doshi0b4943c2013-07-04 23:45:22 +0530194 btn: btn,
195 type: "POST",
Rushabh Mehtac59c4e02013-09-09 12:17:45 +0530196 method: "selling.utils.cart.apply_shipping_rule",
Anand Doshi0b4943c2013-07-04 23:45:22 +0530197 args: { shipping_rule: rule },
198 callback: function(r) {
199 if(!r.exc) {
Anand Doshi0748cb72013-09-11 15:31:58 +0530200 erpnext.cart.render(r.message);
Anand Doshi0b4943c2013-07-04 23:45:22 +0530201 }
202 }
203 });
204 },
205
Anand Doshiedbf3e12013-07-02 11:40:16 +0530206 render_address: function($address_wrapper, addresses, address_name) {
207 $.each(addresses, function(i, address) {
Anand Doshi65f5c582013-08-21 19:36:23 +0530208 $(repl('<div class="panel panel-default"> \
209 <div class="panel-heading"> \
Anand Doshiedbf3e12013-07-02 11:40:16 +0530210 <div class="row"> \
Rushabh Mehtacce21d12013-08-21 17:48:08 +0530211 <div class="col-md-10 address-title" \
Anand Doshiedbf3e12013-07-02 11:40:16 +0530212 data-address-name="%(name)s"><strong>%(name)s</strong></div> \
Rushabh Mehtacce21d12013-08-21 17:48:08 +0530213 <div class="col-md-2"><input type="checkbox" \
Anand Doshiedbf3e12013-07-02 11:40:16 +0530214 data-address-name="%(name)s"></div> \
215 </div> \
216 </div> \
Anand Doshi65f5c582013-08-21 19:36:23 +0530217 <div class="panel-collapse collapse" data-address-name="%(name)s"> \
218 <div class="panel-body">%(display)s</div> \
Anand Doshiedbf3e12013-07-02 11:40:16 +0530219 </div> \
220 </div>', address))
221 .css({"margin": "10px auto"})
222 .appendTo($address_wrapper);
223 });
224
Anand Doshi65f5c582013-08-21 19:36:23 +0530225 $address_wrapper.find(".panel-heading")
Anand Doshiedbf3e12013-07-02 11:40:16 +0530226 .find(".address-title")
227 .css({"cursor": "pointer"})
228 .on("click", function() {
Anand Doshi65f5c582013-08-21 19:36:23 +0530229 $address_wrapper.find('.panel-collapse[data-address-name="'
Anand Doshiedbf3e12013-07-02 11:40:16 +0530230 +$(this).attr("data-address-name")+'"]').collapse("toggle");
231 });
232
233 $address_wrapper.find('input[type="checkbox"]').on("click", function() {
Anand Doshi1672fd82013-07-24 13:07:23 +0530234 if($(this).prop("checked")) {
Anand Doshiedbf3e12013-07-02 11:40:16 +0530235 var me = this;
236 $address_wrapper.find('input[type="checkbox"]').each(function(i, chk) {
237 if($(chk).attr("data-address-name")!=$(me).attr("data-address-name")) {
Anand Doshi1672fd82013-07-24 13:07:23 +0530238 $(chk).prop("checked", false);
Anand Doshiedbf3e12013-07-02 11:40:16 +0530239 }
240 });
241
Anand Doshi1fac2a92013-07-29 19:30:39 +0530242 return wn.call({
Anand Doshiedbf3e12013-07-02 11:40:16 +0530243 type: "POST",
Rushabh Mehtac59c4e02013-09-09 12:17:45 +0530244 method: "selling.utils.cart.update_cart_address",
Anand Doshiedbf3e12013-07-02 11:40:16 +0530245 args: {
246 address_fieldname: $address_wrapper.attr("data-fieldname"),
247 address_name: $(this).attr("data-address-name")
248 },
249 callback: function(r) {
250 if(!r.exc) {
Anand Doshi0748cb72013-09-11 15:31:58 +0530251 erpnext.cart.render(r.message);
Anand Doshiedbf3e12013-07-02 11:40:16 +0530252 }
253 }
254 });
255 } else {
256 return false;
257 }
258 });
259
260 $address_wrapper.find('input[type="checkbox"][data-address-name="'+ address_name +'"]')
Anand Doshi1672fd82013-07-24 13:07:23 +0530261 .prop("checked", true);
Anand Doshiedbf3e12013-07-02 11:40:16 +0530262
Anand Doshi65f5c582013-08-21 19:36:23 +0530263 $address_wrapper.find(".panel-collapse").collapse({
Anand Doshiedbf3e12013-07-02 11:40:16 +0530264 parent: $address_wrapper,
265 toggle: false
266 });
267
Anand Doshi65f5c582013-08-21 19:36:23 +0530268 $address_wrapper.find('.panel-collapse[data-address-name="'+ address_name +'"]')
Anand Doshiedbf3e12013-07-02 11:40:16 +0530269 .collapse("show");
Anand Doshi2ac0a832013-07-10 20:49:44 +0530270 },
271
Anand Doshi0748cb72013-09-11 15:31:58 +0530272 place_order: function(btn) {
Anand Doshi1fac2a92013-07-29 19:30:39 +0530273 return wn.call({
Anand Doshi2ac0a832013-07-10 20:49:44 +0530274 type: "POST",
Rushabh Mehtac59c4e02013-09-09 12:17:45 +0530275 method: "selling.utils.cart.place_order",
Anand Doshi0748cb72013-09-11 15:31:58 +0530276 btn: btn,
Anand Doshi2ac0a832013-07-10 20:49:44 +0530277 callback: function(r) {
278 if(r.exc) {
279 var msg = "";
280 if(r._server_messages) {
281 msg = JSON.parse(r._server_messages || []).join("<br>");
282 }
283
284 $("#cart-error")
285 .empty()
Bárbara Perretti187ea332013-10-09 14:53:44 -0300286 .html(msg || wn._("Something went wrong!"))
Anand Doshi2ac0a832013-07-10 20:49:44 +0530287 .toggle(true);
288 } else {
289 window.location.href = "order?name=" + encodeURIComponent(r.message);
290 }
291 }
292 });
Anand Doshiedbf3e12013-07-02 11:40:16 +0530293 }
Anand Doshiab690292013-06-13 11:21:35 +0530294});