Make indicators more responsive
This commit is contained in:
parent
f87035aa9b
commit
933942ef26
|
@ -32,6 +32,7 @@
|
||||||
|
|
||||||
let interval
|
let interval
|
||||||
let state = defaultState()
|
let state = defaultState()
|
||||||
|
let observing = false
|
||||||
|
|
||||||
$: offset = $builderStore.inBuilder ? 5 : -1
|
$: offset = $builderStore.inBuilder ? 5 : -1
|
||||||
$: config.set({
|
$: config.set({
|
||||||
|
@ -45,6 +46,26 @@
|
||||||
// Update position when any props change
|
// Update position when any props change
|
||||||
$: $config, debouncedUpdate()
|
$: $config, debouncedUpdate()
|
||||||
|
|
||||||
|
// Observe style changes
|
||||||
|
$: observeChanges(componentId)
|
||||||
|
|
||||||
|
const observer = new MutationObserver(() => debouncedUpdate())
|
||||||
|
|
||||||
|
const observeChanges = id => {
|
||||||
|
observer.disconnect()
|
||||||
|
observing = false
|
||||||
|
const node = document.getElementsByClassName(id)[0]
|
||||||
|
if (node) {
|
||||||
|
observer.observe(node, {
|
||||||
|
attributes: true,
|
||||||
|
attributeFilter: ["style"],
|
||||||
|
childList: false,
|
||||||
|
subtree: false,
|
||||||
|
})
|
||||||
|
observing = true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
const checkInsideGrid = id => {
|
const checkInsideGrid = id => {
|
||||||
return isGridChild(document.getElementsByClassName(id)[0])
|
return isGridChild(document.getElementsByClassName(id)[0])
|
||||||
}
|
}
|
||||||
|
@ -55,6 +76,17 @@
|
||||||
state = defaultState()
|
state = defaultState()
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
const parents = document.getElementsByClassName(componentId)
|
||||||
|
if (!parents.length) {
|
||||||
|
state = defaultState()
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
// Start observing if this is the first time we've seen our component
|
||||||
|
// in the DOM
|
||||||
|
if (!observing) {
|
||||||
|
observeChanges(componentId)
|
||||||
|
}
|
||||||
let nextState = defaultState()
|
let nextState = defaultState()
|
||||||
|
|
||||||
// Check if we're inside a grid
|
// Check if we're inside a grid
|
||||||
|
@ -62,9 +94,7 @@
|
||||||
nextState.insideGrid = checkInsideGrid(componentId)
|
nextState.insideGrid = checkInsideGrid(componentId)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Determine next set of indicators
|
// Get text to display
|
||||||
const parents = document.getElementsByClassName(componentId)
|
|
||||||
if (parents.length) {
|
|
||||||
nextState.text = parents[0].dataset.name
|
nextState.text = parents[0].dataset.name
|
||||||
if (nextState.prefix) {
|
if (nextState.prefix) {
|
||||||
nextState.text = `${nextState.prefix} ${nextState.text}`
|
nextState.text = `${nextState.prefix} ${nextState.text}`
|
||||||
|
@ -72,8 +102,7 @@
|
||||||
if (parents[0].dataset.icon) {
|
if (parents[0].dataset.icon) {
|
||||||
nextState.icon = parents[0].dataset.icon
|
nextState.icon = parents[0].dataset.icon
|
||||||
}
|
}
|
||||||
}
|
nextState.error = parents[0].classList.contains("error")
|
||||||
nextState.error = parents?.[0]?.classList.contains("error")
|
|
||||||
|
|
||||||
// Batch reads to minimize reflow
|
// Batch reads to minimize reflow
|
||||||
const scrollX = window.scrollX
|
const scrollX = window.scrollX
|
||||||
|
@ -114,6 +143,7 @@
|
||||||
})
|
})
|
||||||
|
|
||||||
onDestroy(() => {
|
onDestroy(() => {
|
||||||
|
observer.disconnect()
|
||||||
clearInterval(interval)
|
clearInterval(interval)
|
||||||
document.removeEventListener("scroll", debouncedUpdate, true)
|
document.removeEventListener("scroll", debouncedUpdate, true)
|
||||||
})
|
})
|
||||||
|
|
Loading…
Reference in New Issue