basic-business-template/assets/js/product.js

47 lines
2.4 KiB
JavaScript
Raw Normal View History

2023-10-21 04:05:42 +00:00
import * as Cart from './modules/cart.js';
document.addEventListener("DOMContentLoaded", async () => {
let productId = document.querySelector('meta[name="product-id"]').getAttribute('content');
if (productId != undefined) {
let products = await Cart.getItems();
let objProduct = products.find(obj => obj.id == productId);
if (objProduct == undefined) {
document.querySelector('#btn-add-to-bag').style.display = "block";
document.querySelector('#btn-show-bag').style.display = "none";
if (Cart.getItems().length > 0) document.querySelector('#btn-check-out').parentElement.style.display = "none";
else document.querySelector('#btn-check-out').parentElement.display = "block";
}
else {
$('#btn-add-to-bag').hide();
$('#btn-show-bag').show();
$('#btn-check-out').parent().hide();
$('#count-items-in-bag').html(objProduct.quantity + `<svg style="fill: white; width: 12px; margin-left: 3px; margin-bottom: 2px;" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"><path d="M352 128C352 57.42 294.579 0 224 0 153.42 0 96 57.42 96 128H0v304c0 44.183 35.817 80 80 80h288c44.183 0 80-35.817 80-80V128h-96zM224 48c44.112 0 80 35.888 80 80H144c0-44.112 35.888-80 80-80zm176 384c0 17.645-14.355 32-32 32H80c-17.645 0-32-14.355-32-32V176h48v40c0 13.255 10.745 24 24 24s24-10.745 24-24v-40h160v40c0 13.255 10.745 24 24 24s24-10.745 24-24v-40h48v256z"/></svg>`);
}
}
let btnCheckOut = document.querySelector('#btn-check-out');
btnCheckOut.addEventListener("click", () => {
let productId = btnCheckOut.getAttribute("data-id");
Cart.addItem(productId);
window.location.replace(document.querySelector('meta[name="checkout"]').getAttribute('content'));
});
let btnAddToBag = document.querySelector('#btn-add-to-bag');
btnAddToBag.addEventListener("click", () => {
let productId = btnAddToBag.getAttribute("data-id");
let parentElement = document.querySelector('#count-products-in-bag').parentElement;
let copyElemetn = document.querySelector('#count-products-in-bag').clone();
copyElemetn.attr('id', '');
copyElemetn.appendTo(parentElement);
$('#count-products-in-bag').addClass('animate__animated animate__backInUp');
$('#count-products-in-bag').on('animationend', function () {
$('#count-products-in-bag').removeClass('animate__animated animate__backInUp');
copyElemetn.remove();
2023-07-25 14:32:35 +00:00
});
2023-10-21 04:05:42 +00:00
Cart.addProduct(productId);
});
2023-07-25 14:32:35 +00:00
});