tweaks after rebase on clic-limit

This commit is contained in:
imperosol
2026-06-05 13:37:58 +02:00
parent 4c5149aec9
commit d73b7de903
2 changed files with 75 additions and 61 deletions
@@ -6,7 +6,9 @@ interface Basket {
timeout: Date; timeout: Date;
} }
document.addEventListener("alpine:init", () => { document.addEventListener("alpine:init", () => {
Alpine.data("etransaction", (initialData, basket: Basket) => ({ Alpine.data(
"etransaction",
(initialData: Record<string, string>, basket: Basket) => ({
data: initialData, data: initialData,
isCbAvailable: Object.keys(initialData).length > 0, isCbAvailable: Object.keys(initialData).length > 0,
isSithAvailable: true, isSithAvailable: true,
@@ -14,10 +16,11 @@ document.addEventListener("alpine:init", () => {
init() { init() {
const now = new Date(); const now = new Date();
const timeout = basket.timeout.getTime() - now.getTime(); const timeout = basket.timeout.getTime() - now.getTime();
if (timeout <= 0) { if (timeout > 0) {
// basket was already outdated at initial page load // if not going inside this condition, it means that
this.timeoutBasket(); // basket was already outdated at initial page load,
} else { // in which case disabling buttons and displaying
// error message has been done at rendering time
setTimeout(() => this.timeoutBasket(), timeout); setTimeout(() => this.timeoutBasket(), timeout);
} }
}, },
@@ -35,7 +38,7 @@ document.addEventListener("alpine:init", () => {
.getAll() .getAll()
.find( .find(
(n: Notification) => (n: Notification) =>
n.tag === NotificationLevel.Error && n.message === message, n.tag === NotificationLevel.Error && n.text === message,
); );
if (existingNotif === undefined) { if (existingNotif === undefined) {
this.$notifications.error(message); this.$notifications.error(message);
@@ -59,7 +62,7 @@ document.addEventListener("alpine:init", () => {
path: { basket_id: basket.id }, path: { basket_id: basket.id },
}); });
if (res.response.ok) { if (res.response.ok) {
this.data = res.data; this.data = res.data as Record<string, string>;
this.isCbAvailable = true; this.isCbAvailable = true;
} else if (res.response.status === 410) { } else if (res.response.status === 410) {
// The basket is expired, so no payment method should be available at all. // The basket is expired, so no payment method should be available at all.
@@ -68,5 +71,6 @@ document.addEventListener("alpine:init", () => {
this.timeoutBasket(); this.timeoutBasket();
} }
}, },
})); }),
);
}); });
@@ -72,8 +72,18 @@
we have a third dummy form, containing only the cgv button, we have a third dummy form, containing only the cgv button,
which validation is triggered when one of the two other forms is submitted. which validation is triggered when one of the two other forms is submitted.
If the validation of this form fails, the submit event will be cancelled. #} If the validation of this form fails, the submit event will be cancelled. #}
<div class="form-group margin-bottom"> <div class="form-group">
<input type="checkbox" id="cgv-checkbox" name="cgv" required> <input
type="checkbox"
id="cgv-checkbox"
name="cgv"
required
{% if basket.is_expired %}
disabled="disabled"
{% else %}
:disabled="!isCbAvailable && !isSithAvailable"
{% endif %}
>
<label for="cgv-checkbox"> <label for="cgv-checkbox">
{% trans trimmed %}I have read and I accept{% endtrans %} {% trans trimmed %}I have read and I accept{% endtrans %}
<a href="{{ url('core:page', 'cgv') }}">{% trans %}the general terms and conditions{% endtrans%}</a> <a href="{{ url('core:page', 'cgv') }}">{% trans %}the general terms and conditions{% endtrans%}</a>