mirror of
https://github.com/ae-utbm/sith.git
synced 2026-05-22 17:00:19 +00:00
clean invalid items from eboutic baskets
This commit is contained in:
@@ -11,7 +11,7 @@ const BASKET_CACHE_KEY = "basket";
|
|||||||
const BASKET_CACHE_VERSION = 1;
|
const BASKET_CACHE_VERSION = 1;
|
||||||
|
|
||||||
document.addEventListener("alpine:init", () => {
|
document.addEventListener("alpine:init", () => {
|
||||||
Alpine.data("basket", (lastPurchaseTime?: number) => ({
|
Alpine.data("basket", (validPrices: number[], lastPurchaseTime?: number) => ({
|
||||||
basket: [] as BasketItem[],
|
basket: [] as BasketItem[],
|
||||||
|
|
||||||
init() {
|
init() {
|
||||||
@@ -19,15 +19,6 @@ document.addEventListener("alpine:init", () => {
|
|||||||
this.$watch("basket", () => {
|
this.$watch("basket", () => {
|
||||||
this.saveBasket();
|
this.saveBasket();
|
||||||
});
|
});
|
||||||
// Invalidate basket if a purchase was made
|
|
||||||
if (lastPurchaseTime !== null && localStorage.basketTimestamp !== undefined) {
|
|
||||||
if (
|
|
||||||
new Date(lastPurchaseTime) >=
|
|
||||||
new Date(Number.parseInt(localStorage.basketTimestamp, 10))
|
|
||||||
) {
|
|
||||||
this.basket = [];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
document
|
document
|
||||||
.getElementById("id_form-TOTAL_FORMS")
|
.getElementById("id_form-TOTAL_FORMS")
|
||||||
.setAttribute(":value", "basket.length");
|
.setAttribute(":value", "basket.length");
|
||||||
@@ -37,7 +28,22 @@ document.addEventListener("alpine:init", () => {
|
|||||||
const cached = versionedLocalStorage.getItem<BasketItem[]>(BASKET_CACHE_KEY, {
|
const cached = versionedLocalStorage.getItem<BasketItem[]>(BASKET_CACHE_KEY, {
|
||||||
version: BASKET_CACHE_VERSION,
|
version: BASKET_CACHE_VERSION,
|
||||||
});
|
});
|
||||||
return cached ?? [];
|
if (!cached) {
|
||||||
|
return [];
|
||||||
|
}
|
||||||
|
if (
|
||||||
|
lastPurchaseTime !== null &&
|
||||||
|
localStorage.basketTimestamp !== undefined &&
|
||||||
|
new Date(lastPurchaseTime) >=
|
||||||
|
new Date(Number.parseInt(localStorage.basketTimestamp, 10))
|
||||||
|
) {
|
||||||
|
// Invalidate basket if a purchase was made
|
||||||
|
return [];
|
||||||
|
}
|
||||||
|
// The basket is cached and not expired, so return it,
|
||||||
|
// but without items that are invalid
|
||||||
|
// (e.g. because the product is archived, or sold out)
|
||||||
|
return cached.filter((item) => validPrices.includes(item.priceId));
|
||||||
},
|
},
|
||||||
|
|
||||||
saveBasket() {
|
saveBasket() {
|
||||||
|
|||||||
@@ -30,7 +30,13 @@
|
|||||||
{% block content %}
|
{% block content %}
|
||||||
<h1 id="eboutic-title">{% trans %}Eboutic{% endtrans %}</h1>
|
<h1 id="eboutic-title">{% trans %}Eboutic{% endtrans %}</h1>
|
||||||
|
|
||||||
<div id="eboutic" x-data="basket({{ last_purchase_time }})">
|
<div
|
||||||
|
id="eboutic"
|
||||||
|
x-data="basket(
|
||||||
|
[{% for prices in categories %}{% for p in prices %}{{ p.id }},{% endfor %}{% endfor %}],
|
||||||
|
{{ last_purchase_time }},
|
||||||
|
)"
|
||||||
|
>
|
||||||
<div id="basket">
|
<div id="basket">
|
||||||
<h3>Panier</h3>
|
<h3>Panier</h3>
|
||||||
<form method="post" action="">
|
<form method="post" action="">
|
||||||
|
|||||||
Reference in New Issue
Block a user