mirror of
https://github.com/immich-app/immich.git
synced 2026-03-23 17:20:09 +03:00
36 lines
1.2 KiB
TypeScript
36 lines
1.2 KiB
TypeScript
import { assetViewerManager } from '$lib/managers/asset-viewer-manager.svelte';
|
|
import { createZoomImageWheel } from '@zoom-image/core';
|
|
|
|
export const zoomImageAction = (node: HTMLElement, options?: { disabled?: boolean }) => {
|
|
const zoomInstance = createZoomImageWheel(node, { maxZoom: 10, initialState: assetViewerManager.zoomState });
|
|
|
|
const unsubscribes = [
|
|
assetViewerManager.on({ ZoomChange: (state) => zoomInstance.setState(state) }),
|
|
zoomInstance.subscribe(({ state }) => assetViewerManager.onZoomChange(state)),
|
|
];
|
|
|
|
const stopIfDisabled = (event: Event) => {
|
|
if (options?.disabled) {
|
|
event.stopImmediatePropagation();
|
|
}
|
|
};
|
|
|
|
node.addEventListener('wheel', stopIfDisabled, { capture: true });
|
|
node.addEventListener('pointerdown', stopIfDisabled, { capture: true });
|
|
|
|
node.style.overflow = 'visible';
|
|
return {
|
|
update(newOptions?: { disabled?: boolean }) {
|
|
options = newOptions;
|
|
},
|
|
destroy() {
|
|
for (const unsubscribe of unsubscribes) {
|
|
unsubscribe();
|
|
}
|
|
node.removeEventListener('wheel', stopIfDisabled, { capture: true });
|
|
node.removeEventListener('pointerdown', stopIfDisabled, { capture: true });
|
|
zoomInstance.cleanup();
|
|
},
|
|
};
|
|
};
|