From 58f628a3b7344ecdb10c8ad77643da6c1a24dca8 Mon Sep 17 00:00:00 2001 From: nkoexe Date: Tue, 3 Sep 2024 23:37:16 +0200 Subject: [PATCH] refresh page indicator on list resize --- .../static/scripts/display/sostituzioni.js | 29 +++++++++++-------- 1 file changed, 17 insertions(+), 12 deletions(-) diff --git a/sostituzioni/view/static/scripts/display/sostituzioni.js b/sostituzioni/view/static/scripts/display/sostituzioni.js index 8496f04..4356310 100644 --- a/sostituzioni/view/static/scripts/display/sostituzioni.js +++ b/sostituzioni/view/static/scripts/display/sostituzioni.js @@ -155,16 +155,6 @@ function refresh_sostituzioni() { } genera_indici_scroll_sostituzioni() - - ui_sostituzioni_pagine.innerHTML = "" - for (let i = 0; i < sostituzioni_indici_scroll.length; i++) { - const element = document.createElement("div") - element.classList.add("sostituzioni-pagina") - if (i == sostituzioni_elemento_scroll) { - element.classList.add("current") - } - ui_sostituzioni_pagine.appendChild(element) - } } function ordina_sostituzioni() { @@ -203,13 +193,28 @@ function genera_indici_scroll_sostituzioni() { // element.style.fontWeight = "bold" // test } } + + // Aggiorna gli indici di paginazione + ui_sostituzioni_pagine.innerHTML = "" + for (let i = 0; i < sostituzioni_indici_scroll.length; i++) { + const element = document.createElement("div") + element.classList.add("sostituzioni-pagina") + if (i == sostituzioni_elemento_scroll) { + element.classList.add("current") + } + ui_sostituzioni_pagine.appendChild(element) + } } +new ResizeObserver(genera_indici_scroll_sostituzioni).observe(ui_sostituzioni_container) + // Loop che scrolla la lista di sostituzioni setInterval(() => { - // Rimuovi la classe "current" dall'indice della pagina attuale - ui_sostituzioni_pagine.children[sostituzioni_elemento_scroll].classList.remove("current") + // Rimuovi la classe "current" dall'indice della pagina attuale, se presente + if (ui_sostituzioni_pagine.children[sostituzioni_elemento_scroll]) { + ui_sostituzioni_pagine.children[sostituzioni_elemento_scroll].classList.remove("current") + } // Prossimo elemento della lista di indici sostituzioni_elemento_scroll = (sostituzioni_elemento_scroll + 1) % sostituzioni_indici_scroll.length // Trova la sostituzione tra gli elementi del DOM tramite l'indice fornito dalla lista