const shoppingCarts = new ShoppingCarts(); shoppingCarts.load(); async function load() { const items = await loadItems(); lookup = {}; for (item of items) { lookup[item.store + item.id] = item; } // Update carts with latest price info for (cart of shoppingCarts.carts) { const items = []; for (cartItem of cart.items) { const item = lookup[cartItem.store + cartItem.id]; if (!item) continue; items.push(item); } cart.items = items; } shoppingCarts.save(); if (shoppingCarts.carts.findIndex(cart => cart.name === "Momentum Eigenmarken Vergleich") == -1) { response = await fetch("momentum-cart.json"); momentumCart = await response.json(); shoppingCarts.carts.unshift(momentumCart); shoppingCarts.save(); } const newCartButton = document.querySelector("#newcart"); newCartButton.addEventListener("click", () => { let name = prompt("Name für Warenkorb eingeben:"); if (name.length === 0) return; for (cart of shoppingCarts.carts) { if (cart.name === name) { alert("Warenkorb mit Namen '" + name + "' existiert bereits"); return; } } shoppingCarts.add(name); location.href = "/cart.html?name=" + name; }); const exportButton = document.querySelector("#export"); exportButton.addEventListener("click", () => { downloadFile("carts.json", JSON.stringify(shoppingCarts.carts, null, 2)); }); const importButton = document.querySelector("#import"); importButton.addEventListener("click", () => { document.getElementById('fileInput').value = null document.getElementById('fileInput').click(); }); document.querySelector("#fileInput").addEventListener('change', function (event) { const file = event.target.files[0]; const reader = new FileReader(); reader.onload = function (event) { const contents = event.target.result; const importedCarts = JSON.parse(contents); for (const importedCart of importedCarts) { const items = []; for (cartItem of importedCart.items) { const item = lookup[cartItem.store + cartItem.id]; if (!item) continue; items.push(item); } importedCart.items = items; const index = shoppingCarts.carts.findIndex(cart => cart.name === importedCart.name); if (index != -1) { if (confirm("Existierenden Warenkorb '" + importedCart.name + " überschreiben?")) { console.log(shoppingCarts.carts[index]); shoppingCarts.carts[index] = importedCart; console.log(shoppingCarts.carts[index]) } } else { shoppingCarts.carts.push(importedCart); } } shoppingCarts.save(); showCarts(lookup); }; reader.readAsText(file); }); showCarts(lookup); } function showCarts(lookup) { const cartsTable = document.querySelector("#carts"); cartsTable.innerHTML = ""; cartsTable.appendChild(dom("thead", ` Name Produkte Preis `)); shoppingCarts.carts.forEach(cart => { let oldPrice = 0; let currPrice = 0; let link = cart.name + ";" for (cartItem of cart.items) { const item = lookup[cartItem.store + cartItem.id]; if (!item) continue; oldPrice += item.priceHistory[item.priceHistory.length - 1].price; currPrice += item.priceHistory[0].price; link += item.store + item.id + ";"; } const increase = oldPrice != 0 ? Math.round((currPrice - oldPrice) / oldPrice * 100) : 0; const row = dom("tr", ``); const nameDom = dom("td", `${cart.name}`); nameDom.setAttribute("data-label", "Name"); row.appendChild(nameDom); const itemsDom = dom("td", cart.items.length); itemsDom.setAttribute("data-label", "Produkte"); row.appendChild(itemsDom); const priceDom = dom("td", `${currPrice.toFixed(2)} ${(increase > 0 ? "+" : "") + increase + "%"}`); priceDom.setAttribute("data-label", "Preis"); row.appendChild(priceDom); const actionsDom = dom("div", ""); actionsDom.classList.add("cartactions") const linkDom = dom("a", "Teilen"); linkDom.setAttribute("href", "cart.html?cart=" + link); actionsDom.appendChild(linkDom); const jsonDom = dom("a", "JSON"); jsonDom.setAttribute("href", ""); jsonDom.addEventListener("click", (event) => { event.preventDefault(); downloadFile(cart.name + ".json", JSON.stringify(cart, null, 2)); }) actionsDom.appendChild(jsonDom); if (cart.name != "Momentum Eigenmarken Vergleich") { let deleteButton = dom("input"); deleteButton.setAttribute("type", "button"); deleteButton.setAttribute("value", "Löschen"); actionsDom.appendChild(deleteButton); deleteButton.addEventListener("click", () => { shoppingCarts.remove(cart.name); showCarts(lookup); }); } const actionsCell = dom("td", ""); actionsCell.append(actionsDom); row.appendChild(actionsCell); cartsTable.appendChild(row); }); } load();