index : btroops | |
Virtual board game-aid for BattleTroops, an infantry combat simulator wargame published by FASA in 1989. |
aboutsummaryrefslogtreecommitdiff |
diff options
author | Catalin Mititiuc <webdevcat@proton.me> | 2024-04-24 19:35:42 -0700 |
---|---|---|
committer | Catalin Mititiuc <webdevcat@proton.me> | 2024-04-24 19:35:42 -0700 |
commit | 7f0c19becd5979a16d9298cae9f6ff8a6f96d9c2 (patch) | |
tree | 063c3737b276d4117edf4ee17b255b8d84a87a80 /src/modules/panzoom.js | |
parent | e7f7bf1f31a7e1f937eb3eda4ee735db04e6384e (diff) |
More functional refactor
Diffstat (limited to 'src/modules/panzoom.js')
-rw-r--r-- | src/modules/panzoom.js | 51 |
1 files changed, 24 insertions, 27 deletions
diff --git a/src/modules/panzoom.js b/src/modules/panzoom.js index ae95171..dcc6b34 100644 --- a/src/modules/panzoom.js +++ b/src/modules/panzoom.js @@ -1,36 +1,33 @@ import { pan, zoom } from 'pan-zoom'; -export default class PanZoom { - #storageKey = 'pan-zoom'; - #zoomFactor = 0.25; - - constructor(svg) { - this.#restorePanZoomVal(svg); - this.#addEventListeners(svg); - this.#observePanZoomChanges(svg); - } +const storageKey = 'pan-zoom', + zoomFactor = 0.25; + +function restorePanZoomVal(svg) { + const storedPanZoomVal = localStorage.getItem(storageKey); - #storePanZoomVal(transformMatrix) { - localStorage.setItem(this.#storageKey, transformMatrix); + if (storedPanZoomVal) { + svg.style.transform = storedPanZoomVal; } +} - #observePanZoomChanges(svg) { - const observer = - new MutationObserver(() => this.#storePanZoomVal(svg.style.transform)); +function addEventListeners(svg) { + svg.addEventListener('wheel', e => zoom(svg, e, zoomFactor), { passive: false }); + svg.addEventListener('pointerdown', e => pan(svg, e), { passive: false }); +} - observer.observe(svg, { attributeFilter: ['style'] }); - } +function storePanZoomVal(transformMatrix) { + localStorage.setItem(storageKey, transformMatrix); +} - #restorePanZoomVal(svg) { - const storedPanZoomVal = localStorage.getItem(this.#storageKey); +function observePanZoomChanges(svg) { + const observer = new MutationObserver(() => storePanZoomVal(svg.style.transform)); - if (storedPanZoomVal) { - svg.style.transform = storedPanZoomVal; - } - } + observer.observe(svg, { attributeFilter: ['style'] }); +} - #addEventListeners(svg) { - svg.addEventListener('wheel', e => zoom(svg, e, this.#zoomFactor), { passive: false }); - svg.addEventListener('pointerdown', e => pan(svg, e), { passive: false }); - } -}; +export default function (svg) { + restorePanZoomVal(svg); + addEventListeners(svg); + observePanZoomChanges(svg); +} |