Extract panzoom logic into separate module

This commit is contained in:
2025-06-16 22:41:29 -07:00
parent 6990e20e15
commit 5e3fac3d67
2 changed files with 46 additions and 44 deletions

44
src/modules/panzoom.js Normal file
View File

@@ -0,0 +1,44 @@
import { pan, zoom } from 'svg-pan-zoom';
export default class PanZoom {
#storageKey = 'pan-zoom';
constructor(svg) {
this.#restorePanZoomVal(svg);
this.#addEventListeners(svg);
this.#observePanZoomChanges(svg);
}
#storePanZoomVal(transformMatrix) {
localStorage.setItem(this.#storageKey, transformMatrix);
}
#observePanZoomChanges(svg) {
const observer =
new MutationObserver(() => this.#storePanZoomVal(svg.style.transform));
observer.observe(svg, { attributeFilter: ['style'] });
}
#restorePanZoomVal(svg) {
const storedPanZoomVal = localStorage.getItem(this.#storageKey);
if (storedPanZoomVal) {
svg.style.transform = storedPanZoomVal;
}
}
#addEventListeners(svg) {
svg.addEventListener('wheel', e => {
e.preventDefault();
zoom(svg, e);
}, { passive: false });
svg.addEventListener('pointerdown', e => {
e.preventDefault();
pan(svg, e);
}, { passive: false });
}
};