Anand Doshi | 885e074 | 2015-03-03 14:55:30 +0530 | [diff] [blame] | 1 | // Copyright (c) 2015, Frappe Technologies Pvt. Ltd. and Contributors |
Rushabh Mehta | 3daa49a | 2014-10-21 16:16:30 +0530 | [diff] [blame] | 2 | // License: GNU General Public License v3. See license.txt |
| 3 | |
| 4 | // js inside blog page |
| 5 | |
| 6 | // shopping cart |
marination | 48b3ce8 | 2021-05-13 01:22:05 +0530 | [diff] [blame] | 7 | frappe.provide("e_commerce.shopping_cart"); |
| 8 | var shopping_cart = e_commerce.shopping_cart; |
Rushabh Mehta | 3daa49a | 2014-10-21 16:16:30 +0530 | [diff] [blame] | 9 | |
| 10 | $.extend(shopping_cart, { |
| 11 | show_error: function(title, text) { |
Rushabh Mehta | fc3d871 | 2015-07-10 10:11:07 +0530 | [diff] [blame] | 12 | $("#cart-container").html('<div class="msg-box"><h4>' + |
| 13 | title + '</h4><p class="text-muted">' + text + '</p></div>'); |
Rushabh Mehta | 3daa49a | 2014-10-21 16:16:30 +0530 | [diff] [blame] | 14 | }, |
| 15 | |
| 16 | bind_events: function() { |
prssanna | b00eb1b | 2021-01-20 17:52:54 +0530 | [diff] [blame] | 17 | shopping_cart.bind_address_picker_dialog(); |
Rushabh Mehta | 8ffd483 | 2015-09-17 16:28:30 +0530 | [diff] [blame] | 18 | shopping_cart.bind_place_order(); |
Faris Ansari | 5f8b358 | 2019-03-19 11:48:32 +0530 | [diff] [blame] | 19 | shopping_cart.bind_request_quotation(); |
Rushabh Mehta | 8ffd483 | 2015-09-17 16:28:30 +0530 | [diff] [blame] | 20 | shopping_cart.bind_change_qty(); |
marination | 53bb7a9 | 2021-05-27 18:53:11 +0530 | [diff] [blame] | 21 | shopping_cart.bind_remove_cart_item(); |
Faris Ansari | 5f8b358 | 2019-03-19 11:48:32 +0530 | [diff] [blame] | 22 | shopping_cart.bind_change_notes(); |
ashish-greycube | 74dc3c9 | 2019-08-12 13:39:25 +0530 | [diff] [blame] | 23 | shopping_cart.bind_coupon_code(); |
Rushabh Mehta | 3daa49a | 2014-10-21 16:16:30 +0530 | [diff] [blame] | 24 | }, |
Faris Ansari | ab74ca7 | 2017-05-30 12:54:42 +0530 | [diff] [blame] | 25 | |
prssanna | b00eb1b | 2021-01-20 17:52:54 +0530 | [diff] [blame] | 26 | bind_address_picker_dialog: function() { |
| 27 | const d = this.get_update_address_dialog(); |
| 28 | this.parent.find('.btn-change-address').on('click', (e) => { |
| 29 | const type = $(e.currentTarget).parents('.address-container').attr('data-address-type'); |
| 30 | $(d.get_field('address_picker').wrapper).html( |
| 31 | this.get_address_template(type) |
| 32 | ); |
| 33 | d.show(); |
Rushabh Mehta | 3d76686 | 2015-09-16 18:52:52 +0530 | [diff] [blame] | 34 | }); |
Rushabh Mehta | 3d76686 | 2015-09-16 18:52:52 +0530 | [diff] [blame] | 35 | }, |
| 36 | |
prssanna | b00eb1b | 2021-01-20 17:52:54 +0530 | [diff] [blame] | 37 | get_update_address_dialog() { |
prssanna | a3585e4 | 2021-02-01 19:50:27 +0530 | [diff] [blame] | 38 | let d = new frappe.ui.Dialog({ |
prssanna | b00eb1b | 2021-01-20 17:52:54 +0530 | [diff] [blame] | 39 | title: "Select Address", |
| 40 | fields: [{ |
| 41 | 'fieldtype': 'HTML', |
| 42 | 'fieldname': 'address_picker', |
| 43 | }], |
| 44 | primary_action_label: __('Set Address'), |
| 45 | primary_action: () => { |
| 46 | const $card = d.$wrapper.find('.address-card.active'); |
| 47 | const address_type = $card.closest('[data-address-type]').attr('data-address-type'); |
| 48 | const address_name = $card.closest('[data-address-name]').attr('data-address-name'); |
| 49 | frappe.call({ |
| 50 | type: "POST", |
marination | 22f41a1 | 2021-02-25 13:56:38 +0530 | [diff] [blame] | 51 | method: "erpnext.e_commerce.shopping_cart.cart.update_cart_address", |
prssanna | b00eb1b | 2021-01-20 17:52:54 +0530 | [diff] [blame] | 52 | freeze: true, |
| 53 | args: { |
| 54 | address_type, |
| 55 | address_name |
| 56 | }, |
| 57 | callback: function(r) { |
| 58 | d.hide(); |
prssanna | a3585e4 | 2021-02-01 19:50:27 +0530 | [diff] [blame] | 59 | if (!r.exc) { |
prssanna | b00eb1b | 2021-01-20 17:52:54 +0530 | [diff] [blame] | 60 | $(".cart-tax-items").html(r.message.taxes); |
| 61 | shopping_cart.parent.find( |
| 62 | `.address-container[data-address-type="${address_type}"]` |
| 63 | ).html(r.message.address); |
| 64 | } |
| 65 | } |
| 66 | }); |
| 67 | } |
| 68 | }); |
prssanna | a3585e4 | 2021-02-01 19:50:27 +0530 | [diff] [blame] | 69 | |
| 70 | return d; |
prssanna | b00eb1b | 2021-01-20 17:52:54 +0530 | [diff] [blame] | 71 | }, |
| 72 | |
| 73 | get_address_template(type) { |
| 74 | return { |
| 75 | shipping: `<div class="mb-3" data-section="shipping-address"> |
| 76 | <div class="row no-gutters" data-fieldname="shipping_address_name"> |
| 77 | {% for address in shipping_addresses %} |
| 78 | <div class="mr-3 mb-3 w-100" data-address-name="{{address.name}}" data-address-type="shipping" |
| 79 | {% if doc.shipping_address_name == address.name %} data-active {% endif %}> |
| 80 | {% include "templates/includes/cart/address_picker_card.html" %} |
| 81 | </div> |
| 82 | {% endfor %} |
| 83 | </div> |
| 84 | </div>`, |
| 85 | billing: `<div class="mb-3" data-section="billing-address"> |
| 86 | <div class="row no-gutters" data-fieldname="customer_address"> |
| 87 | {% for address in billing_addresses %} |
| 88 | <div class="mr-3 mb-3 w-100" data-address-name="{{address.name}}" data-address-type="billing" |
| 89 | {% if doc.shipping_address_name == address.name %} data-active {% endif %}> |
| 90 | {% include "templates/includes/cart/address_picker_card.html" %} |
| 91 | </div> |
| 92 | {% endfor %} |
| 93 | </div> |
| 94 | </div>`, |
| 95 | }[type]; |
| 96 | }, |
| 97 | |
Rushabh Mehta | 8ffd483 | 2015-09-17 16:28:30 +0530 | [diff] [blame] | 98 | bind_place_order: function() { |
| 99 | $(".btn-place-order").on("click", function() { |
| 100 | shopping_cart.place_order(this); |
Rushabh Mehta | 3daa49a | 2014-10-21 16:16:30 +0530 | [diff] [blame] | 101 | }); |
Rushabh Mehta | 3daa49a | 2014-10-21 16:16:30 +0530 | [diff] [blame] | 102 | }, |
| 103 | |
Faris Ansari | 5f8b358 | 2019-03-19 11:48:32 +0530 | [diff] [blame] | 104 | bind_request_quotation: function() { |
| 105 | $('.btn-request-for-quotation').on('click', function() { |
| 106 | shopping_cart.request_quotation(this); |
| 107 | }); |
| 108 | }, |
| 109 | |
Rushabh Mehta | 8ffd483 | 2015-09-17 16:28:30 +0530 | [diff] [blame] | 110 | bind_change_qty: function() { |
| 111 | // bind update button |
| 112 | $(".cart-items").on("change", ".cart-qty", function() { |
| 113 | var item_code = $(this).attr("data-item-code"); |
Kanchan Chauhan | a756e3f | 2016-06-22 15:51:42 +0530 | [diff] [blame] | 114 | var newVal = $(this).val(); |
Faris Ansari | 5f8b358 | 2019-03-19 11:48:32 +0530 | [diff] [blame] | 115 | shopping_cart.shopping_cart_update({item_code, qty: newVal}); |
Kanchan Chauhan | 239b351 | 2016-05-02 11:43:44 +0530 | [diff] [blame] | 116 | }); |
Faris Ansari | ab74ca7 | 2017-05-30 12:54:42 +0530 | [diff] [blame] | 117 | |
| 118 | $(".cart-items").on('click', '.number-spinner button', function () { |
Kanchan Chauhan | c8d47da | 2016-06-22 15:46:38 +0530 | [diff] [blame] | 119 | var btn = $(this), |
Kanchan Chauhan | a756e3f | 2016-06-22 15:51:42 +0530 | [diff] [blame] | 120 | input = btn.closest('.number-spinner').find('input'), |
| 121 | oldValue = input.val().trim(), |
Kanchan Chauhan | c8d47da | 2016-06-22 15:46:38 +0530 | [diff] [blame] | 122 | newVal = 0; |
Faris Ansari | ab74ca7 | 2017-05-30 12:54:42 +0530 | [diff] [blame] | 123 | |
Kanchan Chauhan | c8d47da | 2016-06-22 15:46:38 +0530 | [diff] [blame] | 124 | if (btn.attr('data-dir') == 'up') { |
Kanchan Chauhan | c8d47da | 2016-06-22 15:46:38 +0530 | [diff] [blame] | 125 | newVal = parseInt(oldValue) + 1; |
| 126 | } else { |
| 127 | if (oldValue > 1) { |
| 128 | newVal = parseInt(oldValue) - 1; |
| 129 | } |
| 130 | } |
Kanchan Chauhan | a756e3f | 2016-06-22 15:51:42 +0530 | [diff] [blame] | 131 | input.val(newVal); |
marination | 423d751 | 2021-05-19 21:17:47 +0530 | [diff] [blame] | 132 | |
| 133 | let notes = input.closest("td").siblings().find(".notes").text().trim(); |
Faris Ansari | ab74ca7 | 2017-05-30 12:54:42 +0530 | [diff] [blame] | 134 | var item_code = input.attr("data-item-code"); |
marination | 423d751 | 2021-05-19 21:17:47 +0530 | [diff] [blame] | 135 | shopping_cart.shopping_cart_update({ |
| 136 | item_code, |
| 137 | qty: newVal, |
| 138 | additional_notes: notes |
| 139 | }); |
Faris Ansari | 5f8b358 | 2019-03-19 11:48:32 +0530 | [diff] [blame] | 140 | }); |
| 141 | }, |
| 142 | |
| 143 | bind_change_notes: function() { |
| 144 | $('.cart-items').on('change', 'textarea', function() { |
| 145 | const $textarea = $(this); |
| 146 | const item_code = $textarea.attr('data-item-code'); |
| 147 | const qty = $textarea.closest('tr').find('.cart-qty').val(); |
| 148 | const notes = $textarea.val(); |
| 149 | shopping_cart.shopping_cart_update({ |
| 150 | item_code, |
| 151 | qty, |
| 152 | additional_notes: notes |
| 153 | }); |
Kanchan Chauhan | c8d47da | 2016-06-22 15:46:38 +0530 | [diff] [blame] | 154 | }); |
Kanchan Chauhan | 239b351 | 2016-05-02 11:43:44 +0530 | [diff] [blame] | 155 | }, |
Faris Ansari | ab74ca7 | 2017-05-30 12:54:42 +0530 | [diff] [blame] | 156 | |
marination | 53bb7a9 | 2021-05-27 18:53:11 +0530 | [diff] [blame] | 157 | bind_remove_cart_item: function() { |
| 158 | $(".cart-items").on("click", ".remove-cart-item", (e) => { |
| 159 | const $remove_cart_item_btn = $(e.currentTarget); |
| 160 | var item_code = $remove_cart_item_btn.data("item-code"); |
| 161 | |
| 162 | shopping_cart.shopping_cart_update({ |
| 163 | item_code: item_code, |
| 164 | qty: 0 |
| 165 | }); |
marination | b0d7e32 | 2021-06-01 12:44:49 +0530 | [diff] [blame] | 166 | }); |
marination | 53bb7a9 | 2021-05-27 18:53:11 +0530 | [diff] [blame] | 167 | }, |
| 168 | |
Rushabh Mehta | 3daa49a | 2014-10-21 16:16:30 +0530 | [diff] [blame] | 169 | render_tax_row: function($cart_taxes, doc, shipping_rules) { |
| 170 | var shipping_selector; |
| 171 | if(shipping_rules) { |
| 172 | shipping_selector = '<select class="form-control">' + $.map(shipping_rules, function(rule) { |
Faris Ansari | ab74ca7 | 2017-05-30 12:54:42 +0530 | [diff] [blame] | 173 | return '<option value="' + rule[0] + '">' + rule[1] + '</option>' }).join("\n") + |
| 174 | '</select>'; |
Rushabh Mehta | 3daa49a | 2014-10-21 16:16:30 +0530 | [diff] [blame] | 175 | } |
| 176 | |
| 177 | var $tax_row = $(repl('<div class="row">\ |
| 178 | <div class="col-md-9 col-sm-9">\ |
| 179 | <div class="row">\ |
| 180 | <div class="col-md-9 col-md-offset-3">' + |
| 181 | (shipping_selector || '<p>%(description)s</p>') + |
| 182 | '</div>\ |
| 183 | </div>\ |
| 184 | </div>\ |
| 185 | <div class="col-md-3 col-sm-3 text-right">\ |
| 186 | <p' + (shipping_selector ? ' style="margin-top: 5px;"' : "") + '>%(formatted_tax_amount)s</p>\ |
| 187 | </div>\ |
| 188 | </div>', doc)).appendTo($cart_taxes); |
| 189 | |
| 190 | if(shipping_selector) { |
| 191 | $tax_row.find('select option').each(function(i, opt) { |
| 192 | if($(opt).html() == doc.description) { |
| 193 | $(opt).attr("selected", "selected"); |
| 194 | } |
| 195 | }); |
| 196 | $tax_row.find('select').on("change", function() { |
| 197 | shopping_cart.apply_shipping_rule($(this).val(), this); |
| 198 | }); |
| 199 | } |
| 200 | }, |
| 201 | |
| 202 | apply_shipping_rule: function(rule, btn) { |
| 203 | return frappe.call({ |
| 204 | btn: btn, |
| 205 | type: "POST", |
marination | 22f41a1 | 2021-02-25 13:56:38 +0530 | [diff] [blame] | 206 | method: "erpnext.e_commerce.shopping_cart.cart.apply_shipping_rule", |
Rushabh Mehta | 3daa49a | 2014-10-21 16:16:30 +0530 | [diff] [blame] | 207 | args: { shipping_rule: rule }, |
| 208 | callback: function(r) { |
| 209 | if(!r.exc) { |
| 210 | shopping_cart.render(r.message); |
| 211 | } |
| 212 | } |
| 213 | }); |
| 214 | }, |
| 215 | |
Rushabh Mehta | 3daa49a | 2014-10-21 16:16:30 +0530 | [diff] [blame] | 216 | place_order: function(btn) { |
| 217 | return frappe.call({ |
| 218 | type: "POST", |
marination | 22f41a1 | 2021-02-25 13:56:38 +0530 | [diff] [blame] | 219 | method: "erpnext.e_commerce.shopping_cart.cart.place_order", |
Rushabh Mehta | 3daa49a | 2014-10-21 16:16:30 +0530 | [diff] [blame] | 220 | btn: btn, |
| 221 | callback: function(r) { |
| 222 | if(r.exc) { |
| 223 | var msg = ""; |
| 224 | if(r._server_messages) { |
| 225 | msg = JSON.parse(r._server_messages || []).join("<br>"); |
| 226 | } |
| 227 | |
| 228 | $("#cart-error") |
| 229 | .empty() |
| 230 | .html(msg || frappe._("Something went wrong!")) |
| 231 | .toggle(true); |
| 232 | } else { |
Faris Ansari | 358329d | 2019-05-01 14:56:50 +0530 | [diff] [blame] | 233 | $('.cart-container table').hide(); |
| 234 | $(btn).hide(); |
Faris Ansari | 5f1eebe | 2019-05-01 14:32:15 +0530 | [diff] [blame] | 235 | window.location.href = '/orders/' + encodeURIComponent(r.message); |
Faris Ansari | 5f8b358 | 2019-03-19 11:48:32 +0530 | [diff] [blame] | 236 | } |
| 237 | } |
| 238 | }); |
| 239 | }, |
| 240 | |
| 241 | request_quotation: function(btn) { |
| 242 | return frappe.call({ |
| 243 | type: "POST", |
marination | 22f41a1 | 2021-02-25 13:56:38 +0530 | [diff] [blame] | 244 | method: "erpnext.e_commerce.shopping_cart.cart.request_for_quotation", |
Faris Ansari | 5f8b358 | 2019-03-19 11:48:32 +0530 | [diff] [blame] | 245 | btn: btn, |
| 246 | callback: function(r) { |
| 247 | if(r.exc) { |
| 248 | var msg = ""; |
| 249 | if(r._server_messages) { |
| 250 | msg = JSON.parse(r._server_messages || []).join("<br>"); |
| 251 | } |
| 252 | |
| 253 | $("#cart-error") |
| 254 | .empty() |
| 255 | .html(msg || frappe._("Something went wrong!")) |
| 256 | .toggle(true); |
| 257 | } else { |
Faris Ansari | 358329d | 2019-05-01 14:56:50 +0530 | [diff] [blame] | 258 | $('.cart-container table').hide(); |
| 259 | $(btn).hide(); |
Faris Ansari | 5f1eebe | 2019-05-01 14:32:15 +0530 | [diff] [blame] | 260 | window.location.href = '/quotations/' + encodeURIComponent(r.message); |
Rushabh Mehta | 3daa49a | 2014-10-21 16:16:30 +0530 | [diff] [blame] | 261 | } |
| 262 | } |
| 263 | }); |
ashish-greycube | 74dc3c9 | 2019-08-12 13:39:25 +0530 | [diff] [blame] | 264 | }, |
| 265 | |
| 266 | bind_coupon_code: function() { |
| 267 | $(".bt-coupon").on("click", function() { |
| 268 | shopping_cart.apply_coupon_code(this); |
| 269 | }); |
| 270 | }, |
| 271 | |
| 272 | apply_coupon_code: function(btn) { |
| 273 | return frappe.call({ |
| 274 | type: "POST", |
marination | 22f41a1 | 2021-02-25 13:56:38 +0530 | [diff] [blame] | 275 | method: "erpnext.e_commerce.shopping_cart.cart.apply_coupon_code", |
ashish-greycube | 74dc3c9 | 2019-08-12 13:39:25 +0530 | [diff] [blame] | 276 | btn: btn, |
| 277 | args : { |
| 278 | applied_code : $('.txtcoupon').val(), |
| 279 | applied_referral_sales_partner: $('.txtreferral_sales_partner').val() |
| 280 | }, |
| 281 | callback: function(r) { |
| 282 | if (r && r.message){ |
| 283 | location.reload(); |
| 284 | } |
| 285 | } |
| 286 | }); |
Rushabh Mehta | 3daa49a | 2014-10-21 16:16:30 +0530 | [diff] [blame] | 287 | } |
| 288 | }); |
| 289 | |
Kanchan Chauhan | a756e3f | 2016-06-22 15:51:42 +0530 | [diff] [blame] | 290 | frappe.ready(function() { |
Saurabh | 69f9975 | 2016-01-06 16:41:50 +0530 | [diff] [blame] | 291 | $(".cart-icon").hide(); |
prssanna | b00eb1b | 2021-01-20 17:52:54 +0530 | [diff] [blame] | 292 | shopping_cart.parent = $(".cart-container"); |
Rushabh Mehta | 3daa49a | 2014-10-21 16:16:30 +0530 | [diff] [blame] | 293 | shopping_cart.bind_events(); |
Rushabh Mehta | 3daa49a | 2014-10-21 16:16:30 +0530 | [diff] [blame] | 294 | }); |
Kanchan Chauhan | b3fe6a4 | 2016-03-16 18:01:22 +0530 | [diff] [blame] | 295 | |
| 296 | function show_terms() { |
Faris Ansari | ab74ca7 | 2017-05-30 12:54:42 +0530 | [diff] [blame] | 297 | var html = $(".cart-terms").html(); |
| 298 | frappe.msgprint(html); |
Kanchan Chauhan | b3fe6a4 | 2016-03-16 18:01:22 +0530 | [diff] [blame] | 299 | } |