blob: 114f85ba3b0f6cca2fd9b0e23e4924dbbda27ab0 [file] [log] [blame]
Rushabh Mehtae67d1fb2013-08-05 14:59:54 +05301// Copyright (c) 2013, Web Notes Technologies Pvt. Ltd.
2// 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 Doshic2a35272013-06-19 17:19:20 +05307 wn.cart.bind_events();
Anand Doshi1fac2a92013-07-29 19:30:39 +05308 return wn.call({
Anand Doshic2a35272013-06-19 17:19:20 +05309 type: "POST",
Anand Doshi3dceb842013-06-19 14:57:14 +053010 method: "website.helpers.cart.get_cart_quotation",
Anand Doshi3dceb842013-06-19 14:57:14 +053011 callback: function(r) {
12 console.log(r);
13 $("#cart-container").removeClass("hide");
14 $(".progress").remove();
15 if(r.exc) {
16 if(r.exc.indexOf("WebsitePriceListMissingError")!==-1) {
17 wn.cart.show_error("Oops!", "Price List not configured.");
Anand Doshiedbf3e12013-07-02 11:40:16 +053018 } else if(r["403"]) {
19 wn.cart.show_error("Hey!", "You need to be logged in to view your cart.");
Anand Doshi3dceb842013-06-19 14:57:14 +053020 } else {
21 wn.cart.show_error("Oops!", "Something went wrong.");
22 }
23 } else {
Anand Doshi2ac0a832013-07-10 20:49:44 +053024 wn.cart.set_cart_count();
Anand Doshic2a35272013-06-19 17:19:20 +053025 wn.cart.render(r.message);
Anand Doshi3dceb842013-06-19 14:57:14 +053026 }
Anand Doshi3dceb842013-06-19 14:57:14 +053027 }
28 });
Anand Doshiab690292013-06-13 11:21:35 +053029});
30
31// shopping cart
32if(!wn.cart) wn.cart = {};
33$.extend(wn.cart, {
Anand Doshi3dceb842013-06-19 14:57:14 +053034 show_error: function(title, text) {
35 $("#cart-container").html('<div class="well"><h4>' + title + '</h4> ' + text + '</div>');
36 },
37
Anand Doshic2a35272013-06-19 17:19:20 +053038 bind_events: function() {
39 // bind update button
40 $(document).on("click", ".item-update-cart button", function() {
Anand Doshic2a35272013-06-19 17:19:20 +053041 var item_code = $(this).attr("data-item-code");
42 wn.cart.update_cart({
43 item_code: item_code,
44 qty: $('input[data-item-code="'+item_code+'"]').val(),
45 with_doclist: 1,
46 btn: this,
47 callback: function(r) {
48 if(!r.exc) {
49 wn.cart.render(r.message);
50 var $button = $('button[data-item-code="'+item_code+'"]').addClass("btn-success");
51 setTimeout(function() { $button.removeClass("btn-success"); }, 1000);
52 }
53 },
54 });
55 });
Anand Doshiedbf3e12013-07-02 11:40:16 +053056
57 $("#cart-add-shipping-address").on("click", function() {
58 window.location.href = "address?address_fieldname=shipping_address_name";
59 });
60
61 $("#cart-add-billing-address").on("click", function() {
62 window.location.href = "address?address_fieldname=customer_address";
63 });
Anand Doshi2ac0a832013-07-10 20:49:44 +053064
65 $(".btn-place-order").on("click", function() {
66 wn.cart.place_order();
67 });
Anand Doshic2a35272013-06-19 17:19:20 +053068 },
69
Anand Doshiedbf3e12013-07-02 11:40:16 +053070 render: function(out) {
71 var doclist = out.doclist;
72 var addresses = out.addresses;
Anand Doshi0b4943c2013-07-04 23:45:22 +053073
Anand Doshiedbf3e12013-07-02 11:40:16 +053074 var $cart_items = $("#cart-items").empty();
75 var $cart_taxes = $("#cart-taxes").empty();
Anand Doshi0b4943c2013-07-04 23:45:22 +053076 var $cart_totals = $("#cart-totals").empty();
Anand Doshiedbf3e12013-07-02 11:40:16 +053077 var $cart_billing_address = $("#cart-billing-address").empty();
78 var $cart_shipping_address = $("#cart-shipping-address").empty();
Anand Doshic2a35272013-06-19 17:19:20 +053079
Anand Doshiedbf3e12013-07-02 11:40:16 +053080 var no_items = $.map(doclist, function(d) { return d.item_code || null;}).length===0;
81 if(no_items) {
Anand Doshic2a35272013-06-19 17:19:20 +053082 wn.cart.show_error("Empty :-(", "Go ahead and add something to your cart.");
Anand Doshiedbf3e12013-07-02 11:40:16 +053083 $("#cart-addresses").toggle(false);
Anand Doshic2a35272013-06-19 17:19:20 +053084 return;
85 }
86
Anand Doshi0b4943c2013-07-04 23:45:22 +053087 var shipping_rule_added = false;
88 var taxes_exist = false;
Anand Doshi2862c9e2013-07-08 18:50:33 +053089 var shipping_rule_labels = $.map(out.shipping_rules || [], function(rule) { return rule[1]; });
Anand Doshic2a35272013-06-19 17:19:20 +053090 $.each(doclist, function(i, doc) {
91 if(doc.doctype === "Quotation Item") {
Anand Doshiedbf3e12013-07-02 11:40:16 +053092 wn.cart.render_item_row($cart_items, doc);
Anand Doshi0b4943c2013-07-04 23:45:22 +053093 } else if (doc.doctype === "Sales Taxes and Charges") {
94 if(out.shipping_rules && out.shipping_rules.length &&
95 shipping_rule_labels.indexOf(doc.description)!==-1) {
96 shipping_rule_added = true;
97 wn.cart.render_tax_row($cart_taxes, doc, out.shipping_rules);
98 } else {
99 wn.cart.render_tax_row($cart_taxes, doc);
100 }
101
102 taxes_exist = true;
Anand Doshic2a35272013-06-19 17:19:20 +0530103 }
104 });
105
Anand Doshi0b4943c2013-07-04 23:45:22 +0530106 if(out.shipping_rules && out.shipping_rules.length && !shipping_rule_added) {
107 wn.cart.render_tax_row($cart_taxes, {description: "", formatted_tax_amount: ""},
108 out.shipping_rules);
109 taxes_exist = true;
110 }
111
112 if(taxes_exist)
113 $('<hr>').appendTo($cart_taxes);
114
115 wn.cart.render_tax_row($cart_totals, {
116 description: "<strong>Total</strong>",
117 formatted_tax_amount: "<strong>" + doclist[0].formatted_grand_total_export + "</strong>"
118 });
119
Anand Doshiedbf3e12013-07-02 11:40:16 +0530120 if(!(addresses && addresses.length)) {
121 $cart_shipping_address.html('<div class="well">Hey! Go ahead and add an address</div>');
Anand Doshiab690292013-06-13 11:21:35 +0530122 } else {
Anand Doshiedbf3e12013-07-02 11:40:16 +0530123 wn.cart.render_address($cart_shipping_address, addresses, doclist[0].shipping_address_name);
124 wn.cart.render_address($cart_billing_address, addresses, doclist[0].customer_address);
Anand Doshiab690292013-06-13 11:21:35 +0530125 }
Anand Doshiabc10032013-06-14 17:44:03 +0530126 },
127
Anand Doshiedbf3e12013-07-02 11:40:16 +0530128 render_item_row: function($cart_items, doc) {
129 doc.image_html = doc.image ?
130 '<div style="height: 120px; overflow: hidden;"><img src="' + doc.image + '" /></div>' :
131 '{% include "app/website/templates/html/product_missing_image.html" %}';
132
Anand Doshicefccb92013-07-15 18:28:14 +0530133 if(doc.description === doc.item_name) doc.description = "";
Anand Doshiedbf3e12013-07-02 11:40:16 +0530134
135 $(repl('<div class="row">\
136 <div class="col col-lg-9 col-sm-9">\
137 <div class="row">\
138 <div class="col col-lg-3">%(image_html)s</div>\
139 <div class="col col-lg-9">\
140 <h4><a href="%(page_name)s">%(item_name)s</a></h4>\
Anand Doshicefccb92013-07-15 18:28:14 +0530141 <p>%(description)s</p>\
Anand Doshiedbf3e12013-07-02 11:40:16 +0530142 </div>\
143 </div>\
144 </div>\
Anand Doshi0b4943c2013-07-04 23:45:22 +0530145 <div class="col col-lg-3 col-sm-3 text-right">\
Anand Doshiedbf3e12013-07-02 11:40:16 +0530146 <div class="input-group item-update-cart">\
147 <input type="text" placeholder="Qty" value="%(qty)s" \
Anand Doshi0b4943c2013-07-04 23:45:22 +0530148 data-item-code="%(item_code)s" class="text-right">\
Anand Doshiedbf3e12013-07-02 11:40:16 +0530149 <div class="input-group-btn">\
150 <button class="btn btn-primary" data-item-code="%(item_code)s">\
151 <i class="icon-ok"></i></button>\
152 </div>\
153 </div>\
154 <p style="margin-top: 10px;">at %(formatted_rate)s</p>\
155 <small class="text-muted" style="margin-top: 10px;">= %(formatted_amount)s</small>\
156 </div>\
157 </div><hr>', doc)).appendTo($cart_items);
158 },
159
Anand Doshi0b4943c2013-07-04 23:45:22 +0530160 render_tax_row: function($cart_taxes, doc, shipping_rules) {
161 var shipping_selector;
162 if(shipping_rules) {
163 shipping_selector = '<select>' + $.map(shipping_rules, function(rule) {
164 return '<option value="' + rule[0] + '">' + rule[1] + '</option>' }).join("\n") +
165 '</select>';
166 }
167
168 var $tax_row = $(repl('<div class="row">\
169 <div class="col col-lg-9 col-sm-9">\
170 <div class="row">\
171 <div class="col col-lg-9 col-offset-3">' +
172 (shipping_selector || '<p>%(description)s</p>') +
173 '</div>\
174 </div>\
175 </div>\
176 <div class="col col-lg-3 col-sm-3 text-right">\
177 <p' + (shipping_selector ? ' style="margin-top: 5px;"' : "") + '>%(formatted_tax_amount)s</p>\
178 </div>\
179 </div>', doc)).appendTo($cart_taxes);
180
181 if(shipping_selector) {
182 $tax_row.find('select option').each(function(i, opt) {
183 if($(opt).html() == doc.description) {
184 $(opt).attr("selected", "selected");
185 }
186 });
187 $tax_row.find('select').on("change", function() {
188 wn.cart.apply_shipping_rule($(this).val(), this);
189 });
190 }
191 },
192
193 apply_shipping_rule: function(rule, btn) {
Anand Doshi1fac2a92013-07-29 19:30:39 +0530194 return wn.call({
Anand Doshi0b4943c2013-07-04 23:45:22 +0530195 btn: btn,
196 type: "POST",
197 method: "website.helpers.cart.apply_shipping_rule",
198 args: { shipping_rule: rule },
199 callback: function(r) {
200 if(!r.exc) {
201 wn.cart.render(r.message);
202 }
203 }
204 });
205 },
206
Anand Doshiedbf3e12013-07-02 11:40:16 +0530207 render_address: function($address_wrapper, addresses, address_name) {
208 $.each(addresses, function(i, address) {
209 $(repl('<div class="accordion-group"> \
210 <div class="accordion-heading"> \
211 <div class="row"> \
212 <div class="col col-lg-10 address-title" \
213 data-address-name="%(name)s"><strong>%(name)s</strong></div> \
214 <div class="col col-lg-2"><input type="checkbox" \
215 data-address-name="%(name)s"></div> \
216 </div> \
217 </div> \
218 <div class="accordion-body collapse" data-address-name="%(name)s"> \
219 <div class="accordion-inner">%(display)s</div> \
220 </div> \
221 </div>', address))
222 .css({"margin": "10px auto"})
223 .appendTo($address_wrapper);
224 });
225
226 $address_wrapper.find(".accordion-heading")
227 .css({
228 "background-color": "#eee",
229 "padding": "10px",
230 })
231 .find(".address-title")
232 .css({"cursor": "pointer"})
233 .on("click", function() {
234 $address_wrapper.find('.accordion-body[data-address-name="'
235 +$(this).attr("data-address-name")+'"]').collapse("toggle");
236 });
237
238 $address_wrapper.find('input[type="checkbox"]').on("click", function() {
Anand Doshi1672fd82013-07-24 13:07:23 +0530239 if($(this).prop("checked")) {
Anand Doshiedbf3e12013-07-02 11:40:16 +0530240 var me = this;
241 $address_wrapper.find('input[type="checkbox"]').each(function(i, chk) {
242 if($(chk).attr("data-address-name")!=$(me).attr("data-address-name")) {
Anand Doshi1672fd82013-07-24 13:07:23 +0530243 $(chk).prop("checked", false);
Anand Doshiedbf3e12013-07-02 11:40:16 +0530244 }
245 });
246
Anand Doshi1fac2a92013-07-29 19:30:39 +0530247 return wn.call({
Anand Doshiedbf3e12013-07-02 11:40:16 +0530248 type: "POST",
249 method: "website.helpers.cart.update_cart_address",
250 args: {
251 address_fieldname: $address_wrapper.attr("data-fieldname"),
252 address_name: $(this).attr("data-address-name")
253 },
254 callback: function(r) {
255 if(!r.exc) {
256 wn.cart.render(r.message);
257 }
258 }
259 });
260 } else {
261 return false;
262 }
263 });
264
265 $address_wrapper.find('input[type="checkbox"][data-address-name="'+ address_name +'"]')
Anand Doshi1672fd82013-07-24 13:07:23 +0530266 .prop("checked", true);
Anand Doshiedbf3e12013-07-02 11:40:16 +0530267
268 $address_wrapper.find(".accordion-body").collapse({
269 parent: $address_wrapper,
270 toggle: false
271 });
272
273 $address_wrapper.find('.accordion-body[data-address-name="'+ address_name +'"]')
274 .collapse("show");
Anand Doshi2ac0a832013-07-10 20:49:44 +0530275 },
276
277 place_order: function() {
Anand Doshi1fac2a92013-07-29 19:30:39 +0530278 return wn.call({
Anand Doshi2ac0a832013-07-10 20:49:44 +0530279 type: "POST",
280 method: "website.helpers.cart.place_order",
281 callback: function(r) {
282 if(r.exc) {
283 var msg = "";
284 if(r._server_messages) {
285 msg = JSON.parse(r._server_messages || []).join("<br>");
286 }
287
288 $("#cart-error")
289 .empty()
290 .html(msg || "Something went wrong!")
291 .toggle(true);
292 } else {
293 window.location.href = "order?name=" + encodeURIComponent(r.message);
294 }
295 }
296 });
Anand Doshiedbf3e12013-07-02 11:40:16 +0530297 }
Anand Doshiab690292013-06-13 11:21:35 +0530298});