blob: d5956f991233539566eaa4f54f75c676893c876a [file] [log] [blame]
Anand Doshi885e0742015-03-03 14:55:30 +05301// Copyright (c) 2015, Frappe Technologies Pvt. Ltd. and Contributors
Rushabh Mehta3daa49a2014-10-21 16:16:30 +05302// License: GNU General Public License v3. See license.txt
3
4// js inside blog page
5
6// shopping cart
7frappe.provide("shopping_cart");
8
9$.extend(shopping_cart, {
10 show_error: function(title, text) {
Rushabh Mehtafc3d8712015-07-10 10:11:07 +053011 $("#cart-container").html('<div class="msg-box"><h4>' +
12 title + '</h4><p class="text-muted">' + text + '</p></div>');
Rushabh Mehta3daa49a2014-10-21 16:16:30 +053013 },
14
15 bind_events: function() {
16 // bind update button
17 $(document).on("click", ".item-update-cart button", function() {
18 var item_code = $(this).attr("data-item-code");
19 shopping_cart.update_cart({
20 item_code: item_code,
21 qty: $('input[data-item-code="'+item_code+'"]').val(),
22 with_doc: 1,
23 btn: this,
24 callback: function(r) {
25 if(!r.exc) {
26 shopping_cart.render(r.message);
27 var $button = $('button[data-item-code="'+item_code+'"]').addClass("btn-success");
28 setTimeout(function() { $button.removeClass("btn-success"); }, 1000);
29 }
30 },
31 });
32 });
33
34 $("#cart-add-shipping-address").on("click", function() {
Anand Doshie6f7ac92015-07-13 16:23:42 +053035 window.location.href = "addresses";
Rushabh Mehta3daa49a2014-10-21 16:16:30 +053036 });
37
38 $("#cart-add-billing-address").on("click", function() {
Anand Doshie6f7ac92015-07-13 16:23:42 +053039 window.location.href = "address";
Rushabh Mehta3daa49a2014-10-21 16:16:30 +053040 });
41
42 $(".btn-place-order").on("click", function() {
43 shopping_cart.place_order(this);
44 });
45 },
46
47 render: function(out) {
48 var doc = out.doc;
49 var addresses = out.addresses;
50
51 var $cart_items = $("#cart-items").empty();
52 var $cart_taxes = $("#cart-taxes").empty();
53 var $cart_totals = $("#cart-totals").empty();
54 var $cart_billing_address = $("#cart-billing-address").empty();
55 var $cart_shipping_address = $("#cart-shipping-address").empty();
56
Nabin Haite7d15362014-12-25 16:01:55 +053057 var no_items = $.map(doc.items || [],
Rushabh Mehta3daa49a2014-10-21 16:16:30 +053058 function(d) { return d.item_code || null;}).length===0;
59 if(no_items) {
Rushabh Mehtafc3d8712015-07-10 10:11:07 +053060 shopping_cart.show_error("Cart Empty", frappe._("Go ahead and add something to your cart."));
Rushabh Mehta3daa49a2014-10-21 16:16:30 +053061 $("#cart-addresses").toggle(false);
62 return;
63 }
64
65 var shipping_rule_added = false;
66 var taxes_exist = false;
67 var shipping_rule_labels = $.map(out.shipping_rules || [], function(rule) { return rule[1]; });
68
Nabin Haite7d15362014-12-25 16:01:55 +053069 $.each(doc.items || [], function(i, d) {
Rushabh Mehta3daa49a2014-10-21 16:16:30 +053070 shopping_cart.render_item_row($cart_items, d);
71 });
72
Nabin Haite7d15362014-12-25 16:01:55 +053073 $.each(doc.taxes || [], function(i, d) {
Rushabh Mehta3daa49a2014-10-21 16:16:30 +053074 if(out.shipping_rules && out.shipping_rules.length &&
75 shipping_rule_labels.indexOf(d.description)!==-1) {
76 shipping_rule_added = true;
77 shopping_cart.render_tax_row($cart_taxes, d, out.shipping_rules);
78 } else {
79 shopping_cart.render_tax_row($cart_taxes, d);
80 }
81
82 taxes_exist = true;
83 });
84
85 if(out.shipping_rules && out.shipping_rules.length && !shipping_rule_added) {
86 shopping_cart.render_tax_row($cart_taxes, {description: "", formatted_tax_amount: ""},
87 out.shipping_rules);
88 taxes_exist = true;
89 }
90
91 if(taxes_exist)
92 $('<hr>').appendTo($cart_taxes);
93
94 shopping_cart.render_tax_row($cart_totals, {
95 description: "<strong>Total</strong>",
96 formatted_tax_amount: "<strong>" + doc.formatted_grand_total_export + "</strong>"
97 });
98
99 if(!(addresses && addresses.length)) {
Rushabh Mehtaa5b149c2014-12-25 17:17:32 +0530100 $cart_shipping_address.html('<div class="msg-box">'+frappe._("Hey! Go ahead and add an address")+'</div>');
Rushabh Mehta3daa49a2014-10-21 16:16:30 +0530101 } else {
102 shopping_cart.render_address($cart_shipping_address, addresses, doc.shipping_address_name);
103 shopping_cart.render_address($cart_billing_address, addresses, doc.customer_address);
104 }
105 },
106
107 render_item_row: function($cart_items, doc) {
108 doc.image_html = doc.website_image ?
Anand Doshida858cc2015-02-24 17:50:44 +0530109 '<div style="height: 120px; overflow: hidden;"><img src="' + doc.website_image + '" /></div>': "";
Rushabh Mehta3daa49a2014-10-21 16:16:30 +0530110
111 if(doc.description === doc.item_name) doc.description = "";
112
113 $(repl('<div class="row">\
114 <div class="col-md-9 col-sm-9">\
115 <div class="row">\
116 <div class="col-md-3">%(image_html)s</div>\
117 <div class="col-md-9">\
118 <h4><a href="%(page_name)s">%(item_name)s</a></h4>\
119 <p>%(description)s</p>\
120 </div>\
121 </div>\
122 </div>\
123 <div class="col-md-3 col-sm-3 text-right">\
124 <div class="input-group item-update-cart">\
125 <input type="text" placeholder="Qty" value="%(qty)s" \
126 data-item-code="%(item_code)s" class="text-right form-control">\
127 <div class="input-group-btn">\
128 <button class="btn btn-primary" data-item-code="%(item_code)s">\
129 <i class="icon-ok"></i></button>\
130 </div>\
131 </div>\
132 <p style="margin-top: 10px;">at %(formatted_rate)s</p>\
133 <small class="text-muted" style="margin-top: 10px;">= %(formatted_amount)s</small>\
134 </div>\
135 </div><hr>', doc)).appendTo($cart_items);
136 },
137
138 render_tax_row: function($cart_taxes, doc, shipping_rules) {
139 var shipping_selector;
140 if(shipping_rules) {
141 shipping_selector = '<select class="form-control">' + $.map(shipping_rules, function(rule) {
142 return '<option value="' + rule[0] + '">' + rule[1] + '</option>' }).join("\n") +
143 '</select>';
144 }
145
146 var $tax_row = $(repl('<div class="row">\
147 <div class="col-md-9 col-sm-9">\
148 <div class="row">\
149 <div class="col-md-9 col-md-offset-3">' +
150 (shipping_selector || '<p>%(description)s</p>') +
151 '</div>\
152 </div>\
153 </div>\
154 <div class="col-md-3 col-sm-3 text-right">\
155 <p' + (shipping_selector ? ' style="margin-top: 5px;"' : "") + '>%(formatted_tax_amount)s</p>\
156 </div>\
157 </div>', doc)).appendTo($cart_taxes);
158
159 if(shipping_selector) {
160 $tax_row.find('select option').each(function(i, opt) {
161 if($(opt).html() == doc.description) {
162 $(opt).attr("selected", "selected");
163 }
164 });
165 $tax_row.find('select').on("change", function() {
166 shopping_cart.apply_shipping_rule($(this).val(), this);
167 });
168 }
169 },
170
171 apply_shipping_rule: function(rule, btn) {
172 return frappe.call({
173 btn: btn,
174 type: "POST",
175 method: "erpnext.shopping_cart.cart.apply_shipping_rule",
176 args: { shipping_rule: rule },
177 callback: function(r) {
178 if(!r.exc) {
179 shopping_cart.render(r.message);
180 }
181 }
182 });
183 },
184
185 render_address: function($address_wrapper, addresses, address_name) {
186 $.each(addresses, function(i, address) {
187 $(repl('<div class="panel panel-default"> \
188 <div class="panel-heading"> \
189 <div class="row"> \
190 <div class="col-md-10 address-title" \
191 data-address-name="%(name)s"><strong>%(name)s</strong></div> \
192 <div class="col-md-2"><input type="checkbox" \
193 data-address-name="%(name)s"></div> \
194 </div> \
195 </div> \
196 <div class="panel-collapse collapse" data-address-name="%(name)s"> \
197 <div class="panel-body">%(display)s</div> \
198 </div> \
199 </div>', address))
200 .css({"margin": "10px auto"})
201 .appendTo($address_wrapper);
202 });
203
204 $address_wrapper.find(".panel-heading")
205 .find(".address-title")
206 .css({"cursor": "pointer"})
207 .on("click", function() {
208 $address_wrapper.find('.panel-collapse[data-address-name="'
209 +$(this).attr("data-address-name")+'"]').collapse("toggle");
210 });
211
212 $address_wrapper.find('input[type="checkbox"]').on("click", function() {
213 if($(this).prop("checked")) {
214 var me = this;
215 $address_wrapper.find('input[type="checkbox"]').each(function(i, chk) {
216 if($(chk).attr("data-address-name")!=$(me).attr("data-address-name")) {
217 $(chk).prop("checked", false);
218 }
219 });
220
221 return frappe.call({
222 type: "POST",
223 method: "erpnext.shopping_cart.cart.update_cart_address",
224 args: {
225 address_fieldname: $address_wrapper.attr("data-fieldname"),
226 address_name: $(this).attr("data-address-name")
227 },
228 callback: function(r) {
229 if(!r.exc) {
230 shopping_cart.render(r.message);
231 }
232 }
233 });
234 } else {
235 return false;
236 }
237 });
238
239 $address_wrapper.find('input[type="checkbox"][data-address-name="'+ address_name +'"]')
240 .prop("checked", true);
241
242 $address_wrapper.find(".panel-collapse").collapse({
243 parent: $address_wrapper,
244 toggle: false
245 });
246
247 $address_wrapper.find('.panel-collapse[data-address-name="'+ address_name +'"]')
248 .collapse("show");
249 },
250
251 place_order: function(btn) {
252 return frappe.call({
253 type: "POST",
254 method: "erpnext.shopping_cart.cart.place_order",
255 btn: btn,
256 callback: function(r) {
257 if(r.exc) {
258 var msg = "";
259 if(r._server_messages) {
260 msg = JSON.parse(r._server_messages || []).join("<br>");
261 }
262
263 $("#cart-error")
264 .empty()
265 .html(msg || frappe._("Something went wrong!"))
266 .toggle(true);
267 } else {
Anand Doshida858cc2015-02-24 17:50:44 +0530268 window.location.href = "/orders/" + encodeURIComponent(r.message);
Rushabh Mehta3daa49a2014-10-21 16:16:30 +0530269 }
270 }
271 });
272 }
273});
274
275$(document).ready(function() {
276 shopping_cart.bind_events();
277 return frappe.call({
278 type: "POST",
279 method: "erpnext.shopping_cart.cart.get_cart_quotation",
280 callback: function(r) {
281 $("#cart-container").removeClass("hide");
282 $(".progress").remove();
283 if(r.exc) {
284 if(r.exc.indexOf("WebsitePriceListMissingError")!==-1) {
Rushabh Mehtafc3d8712015-07-10 10:11:07 +0530285 shopping_cart.show_error("Configuration Error", frappe._("Price List not configured."));
Rushabh Mehta3daa49a2014-10-21 16:16:30 +0530286 } else if(r["403"]) {
Rushabh Mehtafc3d8712015-07-10 10:11:07 +0530287 shopping_cart.show_error("Not Allowed", frappe._("You need to be logged in to view your cart."));
Rushabh Mehta3daa49a2014-10-21 16:16:30 +0530288 } else {
Rushabh Mehtafc3d8712015-07-10 10:11:07 +0530289 shopping_cart.show_error("Error", frappe._("Something went wrong."));
Rushabh Mehta3daa49a2014-10-21 16:16:30 +0530290 }
291 } else {
292 shopping_cart.set_cart_count();
293 shopping_cart.render(r.message);
294 }
295 }
296 });
297});