Skip to content

Commit

Permalink
Bug fix for #905.
Browse files Browse the repository at this point in the history
  • Loading branch information
davidjerleke committed Jul 31, 2024
1 parent f4fd87f commit c72b85d
Showing 1 changed file with 10 additions and 8 deletions.
18 changes: 10 additions & 8 deletions packages/embla-carousel/src/components/ResizeHandler.ts
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@ export function ResizeHandler(
watchResize: ResizeHandlerOptionType,
nodeRects: NodeRectsType
): ResizeHandlerType {
const observeNodes = [container].concat(slides)
let resizeObserver: ResizeObserver
let containerSize: number
let slideSizes: number[] = []
Expand All @@ -42,36 +43,37 @@ export function ResizeHandler(

function defaultCallback(entries: ResizeObserverEntry[]): void {
for (const entry of entries) {
if (destroyed) return

const isContainer = entry.target === container
const slideIndex = slides.indexOf(<HTMLElement>entry.target)
const lastSize = isContainer ? containerSize : slideSizes[slideIndex]
const newSize = readSize(isContainer ? container : slides[slideIndex])
const diffSize = mathAbs(newSize - lastSize)

if (diffSize >= 0.5) {
ownerWindow.requestAnimationFrame(() => {
emblaApi.reInit()
eventHandler.emit('resize')
})
emblaApi.reInit()
eventHandler.emit('resize')

break
}
}
}

resizeObserver = new ResizeObserver((entries) => {
if (destroyed) return
if (isBoolean(watchResize) || watchResize(emblaApi, entries)) {
defaultCallback(entries)
}
})

const observeNodes = [container].concat(slides)
observeNodes.forEach((node) => resizeObserver.observe(node))
ownerWindow.requestAnimationFrame(() => {
observeNodes.forEach((node) => resizeObserver.observe(node))
})
}

function destroy(): void {
if (resizeObserver) resizeObserver.disconnect()
destroyed = true
if (resizeObserver) resizeObserver.disconnect()
}

const self: ResizeHandlerType = {
Expand Down

0 comments on commit c72b85d

Please sign in to comment.