X-Git-Url: http://source.bookstackapp.com/bookstack/blobdiff_plain/effc03e99e8a455932884dccf1195287f87d09a3..refs/pull/5280/head:/resources/js/services/util.js diff --git a/resources/js/services/util.js b/resources/js/services/util.js index d9c3bd0e9..1264d1058 100644 --- a/resources/js/services/util.js +++ b/resources/js/services/util.js @@ -30,19 +30,32 @@ export function debounce(func, waitMs, immediate) { */ export function scrollAndHighlightElement(element) { if (!element) return; + + let parent = element; + while (parent.parentElement) { + parent = parent.parentElement; + if (parent.nodeName === 'DETAILS' && !parent.open) { + parent.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; - setTimeout(() => { - element.classList.add('selectFade'); - element.style.backgroundColor = initColor; - }, 10); + 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.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); } /** @@ -71,6 +84,17 @@ export function uniqueId() { return (`${S4() + S4()}-${S4()}-${S4()}-${S4()}-${S4()}${S4()}${S4()}`); } +/** + * Generate a random smaller unique ID. + * + * @returns {string} + */ +export function uniqueIdSmall() { + // eslint-disable-next-line no-bitwise + const S4 = () => (((1 + Math.random()) * 0x10000) | 0).toString(16).substring(1); + return S4(); +} + /** * Create a promise that resolves after the given time. * @param {int} timeMs