mirror of
https://github.com/pretix/pretix.git
synced 2026-05-14 16:44:06 +00:00
add js to prevent illegal inputs
This commit is contained in:
@@ -21,7 +21,7 @@
|
||||
#
|
||||
import datetime
|
||||
from collections import namedtuple
|
||||
from typing import Union
|
||||
from typing import Tuple, Union
|
||||
from zoneinfo import ZoneInfo
|
||||
|
||||
from dateutil import parser
|
||||
@@ -42,6 +42,7 @@ EVENT_CHOICES = (
|
||||
('presale_end', _('Presale end')),
|
||||
)
|
||||
|
||||
# extend NO_BEFORE_VALUES in reldate.js if changed
|
||||
ORDER_CHOICES = (
|
||||
('datetime', _('Moment of order')),
|
||||
)
|
||||
|
||||
@@ -1,4 +1,6 @@
|
||||
{% load i18n %}
|
||||
{% load static %}
|
||||
<script src="{% static 'pretixbase/js/reldate.js' %}" defer></script>
|
||||
<div class="reldatetime">
|
||||
{% for group_name, group_choices, group-index in widget.subwidgets.0.optgroups %}
|
||||
{% for selopt in group_choices %}
|
||||
|
||||
@@ -1,4 +1,6 @@
|
||||
{% load i18n %}
|
||||
{% load static %}
|
||||
<script src="{% static 'pretixbase/js/reldate.js' %}" defer></script>
|
||||
<div class="reldatetime">
|
||||
{% for group_name, group_choices, group-index in widget.subwidgets.0.optgroups %}
|
||||
{% for selopt in group_choices %}
|
||||
|
||||
44
src/pretix/static/pretixbase/js/reldate.js
Normal file
44
src/pretix/static/pretixbase/js/reldate.js
Normal file
@@ -0,0 +1,44 @@
|
||||
if (!window.__reldateInitialized) {
|
||||
window.__reldateInitialized = true;
|
||||
document.addEventListener('DOMContentLoaded', () => {
|
||||
const NO_BEFORE_VALUES = ['datetime'];
|
||||
|
||||
document.querySelectorAll('.reldatetime, .reldate').forEach(container => {
|
||||
const groups = container.querySelectorAll('.radio');
|
||||
|
||||
groups.forEach(group => {
|
||||
const selects = group.querySelectorAll('select');
|
||||
if (selects.length < 2) return;
|
||||
|
||||
let referenceSelect = null;
|
||||
let beforeAfterSelect = null;
|
||||
|
||||
selects.forEach(sel => {
|
||||
const values = Array.from(sel.options).map(o => o.value);
|
||||
// only attach to selects that contain problematic values
|
||||
if (NO_BEFORE_VALUES.some(v => values.includes(v))) {
|
||||
referenceSelect = sel;
|
||||
} else if (values.includes('before') && values.includes('after')) {
|
||||
beforeAfterSelect = sel;
|
||||
}
|
||||
});
|
||||
if (!referenceSelect || !beforeAfterSelect) return;
|
||||
|
||||
const beforeOption = beforeAfterSelect.querySelector('option[value="before"]');
|
||||
const updateBeforeOption = () => {
|
||||
if (NO_BEFORE_VALUES.includes(referenceSelect.value)) {
|
||||
beforeOption.disabled = true;
|
||||
if (beforeAfterSelect.value === 'before') {
|
||||
beforeAfterSelect.value = 'after';
|
||||
beforeAfterSelect.dispatchEvent(new Event('change', { bubbles: true }));
|
||||
}
|
||||
} else {
|
||||
beforeOption.disabled = false;
|
||||
}
|
||||
};
|
||||
referenceSelect.addEventListener('change', updateBeforeOption);
|
||||
updateBeforeOption();
|
||||
});
|
||||
});
|
||||
});
|
||||
}
|
||||
Reference in New Issue
Block a user