mod: валидатор форм, парсера и моделей (08) избежания дублей в синонимах других записей через админку

This commit is contained in:
2026-06-22 18:52:24 +03:00
parent 5b339d1a53
commit 562b58be47
3 changed files with 54 additions and 19 deletions

View File

@@ -402,24 +402,19 @@ def validate_entity_for_admin_form(form_instance, cleaned_data,
dup_list = ", ".join(dup_links)
# Кнопка подтверждения создания несмотря на синонимы
# При клике добавляет класс force-ignore-validation ко всем submit-кнопкам
# При клике вызывает функцию markSubmitButtonsToIgnoreValidation()
# которая добавляет класс force-ignore-validation ко всем submit-кнопкам.
# Вотчер видит этот класс и добавляет onclick обработчик к кнопкам
# Onclick обработчик вызывает addGetParam() перед отправкой формы
# для добавления GET параметра ignore_validate=1 перед отправкой формы.
# Весь JS код находится в form-field-watcher.js для чистоты и переиспользования.
confirmation_button = '''
<div class="confirmation-button-container" style="display: block; margin-top: 15px;">
<br>
<button type="button" onclick="
// Добавляем класс force-ignore-validation ко всем submit-кнопкам
document.querySelectorAll('input[type=submit]').forEach(function(btn) {
btn.classList.add('force-ignore-validation');
});
"
style="padding: 10px 15px; background: #e74c3c; color: white; border: none; border-radius: 4px; cursor: pointer; font-weight: bold;">
Я уверен! Создать несмотря на синонимы.
<div class="confirmation-button-container">
<button type="button" onclick="markSubmitButtonsToIgnoreValidation();">
<big>Я проверил и уверен!</big><br/>
Сохранить, несмотря на синонимы.<br/>
<i>Точно совпадения в синонимах других записей будут удалены.</i>
</button>
<em style="display: block; margin-top: 8px; color: #666; font-size: 12px;">
Теперь нажмите стандартные кнопки сохранения снизу, чтобы сохранить.
</em>
<em>Теперь нажмите стандартные кнопки сохранения снизу, чтобы сохранить.</em>
</div>
'''

View File

@@ -7,16 +7,46 @@
input[type=submit].force-ignore-validation {
background-color: #f39c12 !important; /* Оранжевый/жёлтый цвет */
color: #fff;
border: 2px solid #e67e22;
}
input[type=submit].force-ignore-validation:hover {
background-color: #e67e22 !important;
cursor: pointer;
transition: background-color 0.3s ease;
}
input[type=submit].force-ignore-validation:not(:hover) {
transition: background-color 0.6s ease;
}
/* Скрываем красную кнопку подтверждения если она есть */
/* Блок красной кнопки подтверждения игнорирования валидации */
.confirmation-button-container {
display: none;
display: block;
padding-top: 15px;
}
.confirmation-button-container button {
padding: 10px 15px;
background: #e74c3c;
color: white;
border: none;
border-radius: 4px;
cursor: pointer;
font-weight: bold;
}
.confirmation-button-container button:hover {
background: #c0392b;
transition: background-color 0.6s ease;
}
.confirmation-button-container button:not(:hover) {
transition: background-color 0.6s ease;
}
.confirmation-button-container em {
display: block;
margin-top: 8px;
color: #666;
font-size: 12px;
}

View File

@@ -31,6 +31,17 @@ function addGetParam(button, key, value) {
button.formAction = baseAction + separator + key + '=' + value;
}
// Функция для добавления класса force-ignore-validation ко всем submit-кнопкам формы
// Используется при клике на кнопку "Я проверил и уверен!"
function markSubmitButtonsToIgnoreValidation() {
// Находим все submit-кнопки на странице и добавляем им класс
// form-field-watcher.js потом отследит добавление класса через MutationObserver
// и добавит соответствующие onclick обработчики
document.querySelectorAll('input[type=submit]').forEach(function(btn) {
btn.classList.add('force-ignore-validation');
});
}
document.addEventListener('DOMContentLoaded', function() {
// Находим все submit-кнопки администратора
let submitButtons = document.querySelectorAll('input[type=submit]');
@@ -124,4 +135,3 @@ document.addEventListener('DOMContentLoaded', function() {
observer.observe(btn, { attributes: true, attributeFilter: ['class'] });
});
});