1 Commits

Author SHA1 Message Date
d5c0786a55 add: Добавлена кнопка "Очистить" для формы ввода и счетчик символов. новая версия сайта (v0.2.3)
All checks were successful
Build ETPGRF-site / build (push) Successful in 1m30s
2026-02-11 11:37:28 +03:00
3 changed files with 41 additions and 5 deletions

View File

@@ -79,7 +79,7 @@
{# Футер #}<footer class="footer mt-auto py-2 mt-4">
<div class="container d-flex justify-content-between align-items-center">
<span class="text-muted small nowrap me-2">&copy; Sergei Erjemin, 2025&ndash;{% now 'Y' %}.</span>
<nobr class="text-muted small mx-2"><i class="bi bi-tags me-1" title="Версия библиотеки etpgrf / Версия сайта"></i><a href="/changelog">v0.1.4 / v0.2.2</a></nobr>
<nobr class="text-muted small mx-2"><i class="bi bi-tags me-1" title="Версия библиотеки etpgrf / Версия сайта"></i><a href="/changelog">v0.1.4 / v0.2.3</a></nobr>
{# Сводная статистика (HTMX) #}<span class="text-muted small ms-2" hx-get="{% url 'stats_summary' %}" hx-trigger="load">
...
</span>

View File

@@ -38,10 +38,18 @@
{# ГЛАВНОЕ ПОЛЕ ВВОДА #}
<div class="mb-3">
<label class="form-label fw-bold small text-muted ls-1">
<div class="d-flex justify-content-between align-items-end mb-2">
<label class="form-label fw-bold small text-muted ls-1 mb-0">
<i class="bi bi-file-text me-1"></i> Исходный текст:
</label>
<textarea class="form-control" name="text" rows="10" placeholder="Вставьте текст сюда..."></textarea>
<div class="d-flex align-items-center">
<span id="char-count" class="small text-muted me-3 nowrap">0 симв.</span>
<button type="button" id="btn-clear" class="btn btn-sm btn-outline-secondary" title="Очистить поле">
<i class="bi bi-trash me-1"></i> Очистить
</button>
</div>
</div>
<textarea class="form-control" name="text" id="source-text" rows="10" placeholder="Вставьте текст сюда..."></textarea>
</div>
{# Блок настроек (Collapse) #}

View File

@@ -23,6 +23,34 @@ const btnCopy = document.getElementById('btn-copy');
const sourceTextarea = document.querySelector('textarea[name="text"]');
const processingTimeSpan = document.getElementById('processing-time');
// --- ОЧИСТКА И СЧЕТЧИК ---
const btnClear = document.getElementById('btn-clear');
const charCount = document.getElementById('char-count');
if (sourceTextarea && charCount) {
function updateCharCount() {
const count = sourceTextarea.value.length;
// Форматируем число с разделителями тысяч (1 234)
charCount.textContent = `${count.toLocaleString('ru-RU')} симв.`;
}
sourceTextarea.addEventListener('input', updateCharCount);
// Инициализация с задержкой, чтобы браузер успел восстановить состояние формы
setTimeout(updateCharCount, 100);
if (btnClear) {
btnClear.addEventListener('click', () => {
sourceTextarea.value = '';
updateCharCount();
sourceTextarea.focus();
// Сбрасываем результат (триггерим событие input, чтобы сработал существующий обработчик)
sourceTextarea.dispatchEvent(new Event('input'));
});
}
}
const themeCompartment = new Compartment();
function getTheme() {
return window.matchMedia('(prefers-color-scheme: dark)').matches ? oneDark : [];