X-Git-Url: http://source.bookstackapp.com/bookstack/blobdiff_plain/effc03e99e8a455932884dccf1195287f87d09a3..refs/pull/4815/head:/resources/js/services/util.js diff --git a/resources/js/services/util.js b/resources/js/services/util.js index d9c3bd0e9..59affff88 100644 --- a/resources/js/services/util.js +++ b/resources/js/services/util.js @@ -30,19 +30,29 @@ export function debounce(func, waitMs, immediate) { */ export function scrollAndHighlightElement(element) { if (!element) return; + + const parentDetails = element.closest('details'); + if (parentDetails && !parentDetails.open) { + parentDetails.open = true; + } + element.scrollIntoView({behavior: 'smooth'}); - const color = getComputedStyle(document.body).getPropertyValue('--color-primary-light'); - const initColor = window.getComputedStyle(element).getPropertyValue('background-color'); - element.style.backgroundColor = color; + const highlight = getComputedStyle(document.body).getPropertyValue('--color-link'); + element.style.outline = `2px dashed ${highlight}`; + element.style.outlineOffset = '5px'; + element.style.transition = null; setTimeout(() => { - element.classList.add('selectFade'); - element.style.backgroundColor = initColor; - }, 10); - setTimeout(() => { - element.classList.remove('selectFade'); - element.style.backgroundColor = ''; - }, 3000); + element.style.transition = 'outline linear 3s'; + element.style.outline = '2px dashed rgba(0, 0, 0, 0)'; + const listener = () => { + element.removeEventListener('transitionend', listener); + element.style.transition = null; + element.style.outline = null; + element.style.outlineOffset = null; + }; + element.addEventListener('transitionend', listener); + }, 1000); } /**