@zoom-image/svelte
Version:
Adapter of zoom image core for Svelte
1 lines • 1.39 kB
Source Map (JSON)
{"version":3,"sources":["../src/useZoomImageClick.ts"],"names":[],"mappings":";AAAA,SAAS,gBAAgB;AACzB,SAAS,iBAAiB;AAC1B,SAAS,wBAAwB,6BAA6B;AAIvD,SAAS,oBAAoB;AAClC,MAAI;AACJ,QAAM,EAAE,WAAW,IAAI,IAAI,SAA8B;AAAA,IACvD,iBAAiB;AAAA,EACnB,CAAC;AAED,QAAM,kBAAkB,IAAI,QAAkD;AAC5E,YAAQ,QAAQ;AAChB,aAAS,sBAAsB,GAAG,GAAG;AACrC,QAAI,OAAO,SAAS,CAAC;AAErB,WAAO,UAAU,CAAC,EAAE,MAAM,MAAM;AAC9B,UAAI,KAAK;AAAA,IACX,CAAC;AAAA,EACH;AAEA,YAAU,MAAM;AACd,YAAQ,QAAQ;AAAA,EAClB,CAAC;AAED,SAAO;AAAA,IACL,gBAAgB;AAAA,MACd;AAAA,IACF;AAAA,IACA;AAAA,EACF;AACF","sourcesContent":["import { writable } from \"svelte/store\"\nimport { onDestroy } from \"svelte\"\nimport { createZoomImageClick as _createZoomImageClick } from \"@zoom-image/core\"\n\nimport type { ZoomImageClickState } from \"@zoom-image/core\"\n\nexport function useZoomImageClick() {\n let result: ReturnType<typeof _createZoomImageClick> | undefined\n const { subscribe, set } = writable<ZoomImageClickState>({\n zoomedImgStatus: \"idle\",\n })\n\n const createZoomImage = (...arg: Parameters<typeof _createZoomImageClick>) => {\n result?.cleanup()\n result = _createZoomImageClick(...arg)\n set(result.getState())\n\n result.subscribe(({ state }) => {\n set(state)\n })\n }\n\n onDestroy(() => {\n result?.cleanup()\n })\n\n return {\n zoomImageState: {\n subscribe,\n },\n createZoomImage,\n }\n}\n"]}