48b3ce82b9
- Auto Height on Cards - Title with ellipses on length exceed - Changed namepaces - Moved product card rendering to JS - Added Image and List View Toggling buttons - Kept basic filters rendering just as before
226 lines
5.8 KiB
JavaScript
226 lines
5.8 KiB
JavaScript
// Copyright (c) 2015, Frappe Technologies Pvt. Ltd. and Contributors
|
|
// License: GNU General Public License v3. See license.txt
|
|
|
|
// shopping cart
|
|
frappe.provide("e_commerce.shopping_cart");
|
|
var shopping_cart = e_commerce.shopping_cart;
|
|
|
|
var getParams = function (url) {
|
|
var params = [];
|
|
var parser = document.createElement('a');
|
|
parser.href = url;
|
|
var query = parser.search.substring(1);
|
|
var vars = query.split('&');
|
|
for (var i = 0; i < vars.length; i++) {
|
|
var pair = vars[i].split('=');
|
|
params[pair[0]] = decodeURIComponent(pair[1]);
|
|
}
|
|
return params;
|
|
};
|
|
|
|
frappe.ready(function() {
|
|
var full_name = frappe.session && frappe.session.user_fullname;
|
|
// update user
|
|
if(full_name) {
|
|
$('.navbar li[data-label="User"] a')
|
|
.html('<i class="fa fa-fixed-width fa fa-user"></i> ' + full_name);
|
|
}
|
|
// set coupon code and sales partner code
|
|
|
|
var url_args = getParams(window.location.href);
|
|
|
|
var referral_coupon_code = url_args['cc'];
|
|
var referral_sales_partner = url_args['sp'];
|
|
|
|
var d = new Date();
|
|
// expires within 30 minutes
|
|
d.setTime(d.getTime() + (0.02 * 24 * 60 * 60 * 1000));
|
|
var expires = "expires="+d.toUTCString();
|
|
if (referral_coupon_code) {
|
|
document.cookie = "referral_coupon_code=" + referral_coupon_code + ";" + expires + ";path=/";
|
|
}
|
|
if (referral_sales_partner) {
|
|
document.cookie = "referral_sales_partner=" + referral_sales_partner + ";" + expires + ";path=/";
|
|
}
|
|
referral_coupon_code=frappe.get_cookie("referral_coupon_code");
|
|
referral_sales_partner=frappe.get_cookie("referral_sales_partner");
|
|
|
|
if (referral_coupon_code && $(".tot_quotation_discount").val()==undefined ) {
|
|
$(".txtcoupon").val(referral_coupon_code);
|
|
}
|
|
if (referral_sales_partner) {
|
|
$(".txtreferral_sales_partner").val(referral_sales_partner);
|
|
}
|
|
// update login
|
|
shopping_cart.show_shoppingcart_dropdown();
|
|
shopping_cart.set_cart_count();
|
|
shopping_cart.bind_dropdown_cart_buttons();
|
|
shopping_cart.show_cart_navbar();
|
|
});
|
|
|
|
$.extend(shopping_cart, {
|
|
show_shoppingcart_dropdown: function() {
|
|
$(".shopping-cart").on('shown.bs.dropdown', function() {
|
|
if (!$('.shopping-cart-menu .cart-container').length) {
|
|
return frappe.call({
|
|
method: 'erpnext.e_commerce.shopping_cart.cart.get_shopping_cart_menu',
|
|
callback: function(r) {
|
|
if (r.message) {
|
|
$('.shopping-cart-menu').html(r.message);
|
|
}
|
|
}
|
|
});
|
|
}
|
|
});
|
|
},
|
|
|
|
update_cart: function(opts) {
|
|
if(frappe.session.user==="Guest") {
|
|
if(localStorage) {
|
|
localStorage.setItem("last_visited", window.location.pathname);
|
|
}
|
|
window.location.href = "/login";
|
|
} else {
|
|
return frappe.call({
|
|
type: "POST",
|
|
method: "erpnext.e_commerce.shopping_cart.cart.update_cart",
|
|
args: {
|
|
item_code: opts.item_code,
|
|
qty: opts.qty,
|
|
additional_notes: opts.additional_notes !== undefined ? opts.additional_notes : undefined,
|
|
with_items: opts.with_items || 0
|
|
},
|
|
btn: opts.btn,
|
|
callback: function(r) {
|
|
shopping_cart.set_cart_count();
|
|
if(opts.callback)
|
|
opts.callback(r);
|
|
}
|
|
});
|
|
}
|
|
},
|
|
|
|
set_cart_count: function() {
|
|
var cart_count = frappe.get_cookie("cart_count");
|
|
if(frappe.session.user==="Guest") {
|
|
cart_count = 0;
|
|
}
|
|
|
|
if(cart_count) {
|
|
$(".shopping-cart").toggleClass('hidden', false);
|
|
}
|
|
|
|
var $cart = $('.cart-icon');
|
|
var $badge = $cart.find("#cart-count");
|
|
|
|
if(parseInt(cart_count) === 0 || cart_count === undefined) {
|
|
$cart.css("display", "none");
|
|
$(".cart-items").html('Cart is Empty');
|
|
$(".cart-tax-items").hide();
|
|
$(".btn-place-order").hide();
|
|
$(".cart-addresses").hide();
|
|
}
|
|
else {
|
|
$cart.css("display", "inline");
|
|
}
|
|
|
|
if(cart_count) {
|
|
$badge.html(cart_count);
|
|
$cart.addClass('cart-animate');
|
|
setTimeout(() => {
|
|
$cart.removeClass('cart-animate');
|
|
}, 500);
|
|
} else {
|
|
$badge.remove();
|
|
}
|
|
},
|
|
|
|
shopping_cart_update: function({item_code, qty, cart_dropdown, additional_notes}) {
|
|
frappe.freeze();
|
|
shopping_cart.update_cart({
|
|
item_code,
|
|
qty,
|
|
additional_notes,
|
|
with_items: 1,
|
|
btn: this,
|
|
callback: function(r) {
|
|
frappe.unfreeze();
|
|
if(!r.exc) {
|
|
$(".cart-items").html(r.message.items);
|
|
$(".cart-tax-items").html(r.message.taxes);
|
|
if (cart_dropdown != true) {
|
|
$(".cart-icon").hide();
|
|
}
|
|
}
|
|
},
|
|
});
|
|
},
|
|
|
|
|
|
bind_dropdown_cart_buttons: function () {
|
|
$(".cart-icon").on('click', '.number-spinner button', function () {
|
|
var btn = $(this),
|
|
input = btn.closest('.number-spinner').find('input'),
|
|
oldValue = input.val().trim(),
|
|
newVal = 0;
|
|
|
|
if (btn.attr('data-dir') == 'up') {
|
|
newVal = parseInt(oldValue) + 1;
|
|
} else {
|
|
if (oldValue > 1) {
|
|
newVal = parseInt(oldValue) - 1;
|
|
}
|
|
}
|
|
input.val(newVal);
|
|
var item_code = input.attr("data-item-code");
|
|
shopping_cart.shopping_cart_update({item_code, qty: newVal, cart_dropdown: true});
|
|
return false;
|
|
});
|
|
|
|
},
|
|
|
|
show_cart_navbar: function () {
|
|
frappe.call({
|
|
method: "erpnext.e_commerce.doctype.e_commerce_settings.e_commerce_settings.is_cart_enabled",
|
|
callback: function(r) {
|
|
$(".shopping-cart").toggleClass('hidden', r.message ? false : true);
|
|
}
|
|
});
|
|
},
|
|
|
|
animate_add_to_cart(button) {
|
|
// Create 'added to cart' animation
|
|
let btn_id = "#" + button[0].id;
|
|
this.toggle_button_class(button, 'not-added', 'added-to-cart');
|
|
$(btn_id).text('Added to Cart');
|
|
|
|
// undo
|
|
setTimeout(() => {
|
|
this.toggle_button_class(button, 'added-to-cart', 'not-added');
|
|
$(btn_id).text('Add to Cart');
|
|
}, 2000);
|
|
},
|
|
|
|
toggle_button_class(button, remove, add) {
|
|
button.removeClass(remove);
|
|
button.addClass(add);
|
|
},
|
|
|
|
bind_add_to_cart_action() {
|
|
$('.page_content').on('click', '.btn-add-to-cart-list', (e) => {
|
|
const $btn = $(e.currentTarget);
|
|
$btn.prop('disabled', true);
|
|
|
|
this.animate_add_to_cart($btn);
|
|
|
|
const item_code = $btn.data('item-code');
|
|
e_commerce.shopping_cart.update_cart({
|
|
item_code,
|
|
qty: 1
|
|
});
|
|
|
|
});
|
|
}
|
|
|
|
});
|