(function(S,_){typeof exports=="object"&&typeof module<"u"?module.exports=_():typeof define=="function"&&define.amd?define(_):(S=typeof globalThis<"u"?globalThis:S||self,S.Zoomist=_())})(this,function(){var G,zt,P,yt,F,At,q,Mt,K,It,J,Ct,Q,xt,tt,$t,et,Nt,st,Bt,nt,Wt,it,Ht;"use strict";var pe=Object.defineProperty;var Ee=(S,_,O)=>_ in S?pe(S,_,{enumerable:!0,configurable:!0,writable:!0,value:O}):S[_]=O;var R=(S,_,O)=>(Ee(S,typeof _!="symbol"?_+"":_,O),O),Se=(S,_,O)=>{if(!_.has(S))throw TypeError("Cannot "+O)};var D=(S,_,O)=>{if(_.has(S))throw TypeError("Cannot add the same private member more than once");_ instanceof WeakSet?_.add(S):_.set(S,O)};var w=(S,_,O)=>(Se(S,_,"access private method"),O);const S="",_=n=>document.contains(H(n)),O=n=>{if(!n)return!1;try{const{constructor:t}=n,{prototype:e}=t,{hasOwnProperty:s}=Object.prototype;return t&&e&&s.call(e,"isPrototypeOf")}catch{return!1}},pt=n=>typeof n=="function",W=n=>!isNaN(Number(n)),at=n=>n==null,H=n=>n instanceof HTMLElement?n:document.querySelector(n),lt=(n,t)=>t?n.closest(`.${t}`):null,X=n=>{const t="touches"in n?n.touches[0]:n;return{clientX:t.clientX,clientY:t.clientY}},Z=n=>({clientX:[...n].map(t=>t.clientX).reduce((t,e)=>t+e)/n.length,clientY:[...n].map(t=>t.clientY).reduce((t,e)=>t+e)/n.length}),L=n=>{const{width:t,height:e,top:s,left:i,bottom:a}=n.getBoundingClientRect();return{width:t,height:e,top:s,left:i,bottom:a}},Et=n=>n.length>=2?Math.hypot(n[0].clientX-n[1].clientX,n[0].clientY-n[1].clientY):0,I=(n,t)=>{for(const[e,s]of Object.entries(t))typeof s=="string"&&n.style.setProperty(e,s)},C=(n,t)=>{for(const[e,s]of Object.entries(t))n.setAttribute(e,s)},T=(n,t)=>{for(const[e,s]of Object.entries(t))n[e]=s},z=(n,t,e)=>Math.min(Math.max(n,t),e),Y=n=>{const t=+(Math.round(+(n+"e+2"))+"e-2");return isNaN(t)?0:t},St=n=>{throw new Error(n)},ct=n=>console.warn(n),x=(n="div",t,e,s)=>{const i=document.createElement(n);return t&&i.classList.add(...t.split(" ")),e&&C(i,e),s&&(i.innerHTML=s),i},E="zoomist",Zt=`${E}-container`,bt=`${E}-wrapper`,ht=`${E}-image`,Vt=`${E}-not-draggable`,Ut=`${E}-not-wheelable`,$=`${E}-slider`,jt=`${E}-slider-wrapper`,kt=`${E}-slider-bar`,Gt=`${E}-slider-button`,V=`${E}-zoomer`,Pt=`${E}-zoomer-button`,dt=`${E}-zoomer-icon`,ut=`${E}-zoomer-in`,mt=`${E}-zoomer-out`,ft=`${E}-zoomer-reset`,Ft=`${E}-zoomer-disabled`,qt={tabindex:"0",role:"slider","aria-label":"slider for zoomist","aria-valuemin":"0","aria-valuemax":"100","aria-valuenow":"0","aria-disabled":"false"},gt={tabindex:"0",role:"button",type:"button","aria-disabled":"false"},Kt={...gt,"aria-label":"button for zoom in zoomist"},Jt={...gt,"aria-label":"button for zoom out zoomist"},Qt={...gt,"aria-label":"button for reset zoomist scale"},A=typeof window<"u"&&typeof window.document<"u"&&"ontouchstart"in window,te=A?"touchstart":"mousedown",U=A?"touchmove":"mousemove",j=A?"touchend":"mouseup",ee="wheel",se=["left","right","center"],ne=["top","bottom","center"],Ot="--scale",vt="--translate-x",Tt="--translate-y",ie="--value",Dt={draggable:!0,wheelable:!0,pinchable:!0,bounds:!0,zoomRatio:.1,maxScale:10,minScale:1,initScale:null,dragReleaseOnBounds:!1,wheelReleaseOnMinMax:!1,disableDraggingClass:Vt,disableWheelingClass:Ut},oe={el:null,direction:"horizontal"},re={el:`.${$}`},ae={el:null,inEl:null,outEl:null,resetEl:null,disabledClass:Ft},le={el:`.${V}`,inEl:`.${ut}`,outEl:`.${mt}`,resetEl:`.${ft}`},ce={ready:null,reset:null,resize:null,beforeDestroy:null,destroy:null,beforeUpdate:null,update:null,zoom:null,wheel:null,dragStart:null,drag:null,dragEnd:null,pinchStart:null,pinch:null,pinchEnd:null,slideStart:null,slide:null,slideEnd:null},he={slider:null,zoomer:null},de=` `,ue=` `,me=` `,fe={on(n,t){if(!t||!pt(t))return this;const{__events__:e}=this;return n.split(" ").forEach(s=>{const i=s;e[i]||(e[i]=[]),e[i].push(t)}),this},emit(n,...t){const{__events__:e}=this;return e[n]?(e[n].forEach(s=>{pt(s)&&s.apply(this,t)}),this):this},zoom(n,t){const{scale:e}=this.transform,s=this.useFixedRatio(Y(e*(n+1)));return e===s?this:(this.zoomTo(s,t),this)},zoomTo(n,t=!0){const{image:e,transform:{scale:s,translateX:i,translateY:a},options:{bounds:r}}=this;if(n=this.useFixedRatio(n),n===s)return this;if(this.transform.scale=n,!t)return this.emit("zoom",this,this.transform.scale),this;t=typeof t=="boolean"?this.getContainerCenterClient():t;const{clientX:c,clientY:l}=t,{top:d,left:o,width:h,height:m}=L(e),{width:u,height:f}=this.getImageDiff(),b=n/s-1,p=(h/2-c+o)*b+i,g=(m/2-l+d)*b+a,v=r?z(p,u,-u):p,y=r?z(g,f,-f):g;return T(this.transform,{translateX:v,translateY:y}),this.emit("zoom",this,this.transform.scale),this},move(n){const{options:{bounds:t},transform:{translateX:e,translateY:s}}=this,{x:i,y:a}=n,{width:r,height:c}=this.getImageDiff();if(W(i)){const l=e+i,d=t?z(l,r,-r):l;this.transform.translateX=d}if(W(a)){const l=s+a,d=t?z(l,c,-c):l;this.transform.translateY=d}return this},moveTo(n){const{options:{bounds:t}}=this,{x:e,y:s}=n,{width:i,height:a}=this.getImageDiff();if(W(e)){const r=Number(e),c=t?z(r,i,-i):r;this.transform.translateX=c}if(se.some(r=>r===e)){const c={left:-i,right:i,center:0}[e];this.transform.translateX=c}if(W(s)){const r=Number(s),c=t?z(r,a,-a):r;this.transform.translateY=c}if(ne.some(r=>r===s)){const c={top:-a,bottom:a,center:0}[s];this.transform.translateY=c}return this},slideTo(n){const{options:{minScale:t,maxScale:e}}=this,s=(e-t)*n/100+t;return this.zoomTo(s),this},reset(){const{options:{initScale:n}}=this;return T(this.transform,{scale:n,translateX:0,translateY:0}),this.emit("reset",this),this},destroy(n=!1){const{element:t,image:e,controller:s}=this;return this.mounted&&(this.emit("beforeDestroy",this),s.abort(),this.destroyModules(),n&&e&&(this.reset(),e.removeAttribute("style")),t[E]=null,this.mounted=!1,this.emit("destroy",this)),null},update(n){const{element:t,controller:e}=this;return this.emit("beforeUpdate",this),t[E]=null,this.mounted=!1,e.abort(),this.destroyModules(),n&&(this.options=Object.assign({},Dt,O(n)&&n)),this.init(),this.emit("update",this),this},getImageData(){return{...this.data.imageData}},getContainerData(){return{...this.data.containerData}},getSliderValue(){const{__modules__:{slider:n}}=this;return n&&n.value!==void 0?n.value:null},isOnBoundTop(){const{options:{bounds:n}}=this;if(!n)return!1;const{transform:{translateY:t}}=this,{height:e}=this.getImageDiff();return t*-1===Y(e)},isOnBoundBottom(){const{options:{bounds:n}}=this;if(!n)return!1;const{transform:{translateY:t}}=this,{height:e}=this.getImageDiff();return t===Y(e)},isOnBoundLeft(){const{options:{bounds:n}}=this;if(!n)return!1;const{transform:{translateX:t}}=this,{width:e}=this.getImageDiff();return t*-1===Y(e)},isOnBoundRight(){const{options:{bounds:n}}=this;if(!n)return!1;const{transform:{translateX:t}}=this,{width:e}=this.getImageDiff();return t===Y(e)},isOnBoundX(){const{options:{bounds:n}}=this;if(!n)return!1;const{transform:{translateX:t}}=this,{width:e}=this.getImageDiff();return Math.abs(t)===Math.abs(Y(e))},isOnBoundY(){const{options:{bounds:n}}=this;if(!n)return!1;const{transform:{translateY:t}}=this,{height:e}=this.getImageDiff();return Math.abs(t)===Math.abs(Y(e))},isOnMinScale(){const{options:{minScale:n}}=this,{transform:{scale:t}}=this;return t===n},isOnMaxScale(){const{options:{maxScale:n}}=this,{transform:{scale:t}}=this;return t===n},getImageDiff(){const{width:n,height:t}=this.getContainerData(),{width:e,height:s}=this.getImageData();return{width:(n-e)/2,height:(t-s)/2}},getContainerCenterClient(){const{element:n}=this,{top:t,left:e,width:s,height:i}=L(n);return{clientX:e+s/2,clientY:t+i/2}},getScaleRatio(){const{transform:{scale:n},options:{minScale:t,maxScale:e}}=this;return(n-t)/(e-t)},useFixedRatio(n){const{options:{minScale:t,maxScale:e}}=this;return z(n,t,e)}},{defineProperty:k}=Object;class wt{constructor(t,e){D(this,G);D(this,P);D(this,F);D(this,q);D(this,K);D(this,J);D(this,Q);D(this,tt);D(this,et);D(this,st);D(this,nt);D(this,it);R(this,"element");R(this,"options");R(this,"wrapper");R(this,"image");R(this,"mounted");R(this,"data");R(this,"transform");R(this,"states");R(this,"controller");R(this,"__events__");R(this,"__modules__");t||St("The first argument is required."),_(t)||St(`Element ${t} is not exist.`),this.element=H(t),this.options=Object.assign({},Dt,O(e)&&e),this.init()}init(){const{element:t}=this,{options:{bounds:e,minScale:s,maxScale:i,initScale:a}}=this;if(t[E])return;t[E]=this;const r=t.querySelector(`.${bt}`),c=t.querySelector(`.${ht}`);if(!r)return ct(`${E} needs a ".${bt}" element.`);if(!c)return ct(`${E} needs a ".${ht}" element.`);this.options.minScale=e&&s<1?1:s,this.options.maxScale=Math.max(i,s),this.options.initScale=z(a||s,s,i),this.wrapper=r,this.image=c,w(this,G,zt).call(this)}destroyModules(){const{slider:t,zoomer:e}=this.__modules__;t&&this.destroySlider(),e&&this.destroyZoomer()}destroySlider(){var a,r;const{__modules__:{slider:t}}=this;if(!t||!t.mounted)return;const{options:{el:e},controller:s}=t;e===`.${$}`?(a=t.sliderEl)==null||a.remove():(r=t.sliderTrack)==null||r.remove(),s==null||s.abort(),t.mounted=!1}destroyZoomer(){const{__modules__:{zoomer:t}}=this;if(!t||!t.mounted)return;const{options:{el:e,inEl:s,outEl:i,resetEl:a},controller:r,zoomerEl:c,zoomerInEl:l,zoomerOutEl:d,zoomerResetEl:o}=t,h=(m,u,f)=>{m===`.${u}`&&(f==null||f.remove())};[{target:e,className:V,el:c},{target:s,className:ut,el:l},{target:i,className:mt,el:d},{target:a,className:ft,el:o}].forEach(m=>h(m.target,m.className,m.el)),r==null||r.abort(),t.mounted=!1}}return G=new WeakSet,zt=function(){const{element:t,image:e,options:s}=this,{draggable:i,pinchable:a}=s,{offsetWidth:r,offsetHeight:c}=t,{offsetWidth:l,offsetHeight:d}=e,{width:o,height:h}=L(e);if(!l||!d)return ct(`The width or height of ${ht} should not be 0.`);if(this.transform={scale:0,translateX:0,translateY:0},this.data={imageData:{originWidth:l,originHeight:d,width:o,height:h},containerData:{width:r,height:c}},A&&(i||a)&&(this.data.touchData={hypot:0,startX:0,startY:0,prevX:0,prevY:0,imageTop:0,imageLeft:0,widthDiff:0,heightDiff:0}),!A&&i&&(this.data.dragData={startX:0,startY:0}),this.__events__={...ce},s.on)for(const[m,u]of Object.entries(s.on))this.__events__[m]=[u];if(this.__modules__={...he},s.slider){const m=s.slider===!0?re:s.slider;this.__modules__.slider={options:Object.assign({},oe,m)}}if(s.zoomer){const m=s.zoomer===!0?le:s.zoomer;this.__modules__.zoomer={options:Object.assign({},ae,m)}}this.controller=new AbortController,w(this,P,yt).call(this)},P=new WeakSet,yt=function(){if(this.mounted)return;const{element:t,image:e,options:{minScale:s,maxScale:i,initScale:a},__modules__:{slider:r,zoomer:c}}=this,l=this;I(e,{transform:` translate(var(${vt}, 0px), var(${Tt}, 0px)) scale(var(${Ot}, 0))`}),k(this.transform,"scale",{get(){return l.transform.__scale__},set(d){const o=l.useFixedRatio(d);if(!(at(o)||l.transform.__scale__===o)){if(l.transform.__scale__=o,I(e,{[Ot]:o.toString()}),T(l.data.imageData,{width:L(e).width,height:L(e).height}),r){const h=Math.round(l.getScaleRatio()*100);r.value=h}if(c&&c.options.disabledClass){const{zoomerInEl:h,zoomerOutEl:m,zoomerResetEl:u,options:{disabledClass:f}}=c;h&&(h.classList[o===i?"add":"remove"](f),C(h,{"aria-disabled":o===i?"true":"false"})),m&&(m.classList[o===s?"add":"remove"](f),C(m,{"aria-disabled":o===s?"true":"false"})),u&&(u.classList[o===a?"add":"remove"](f),C(u,{"aria-disabled":o===a?"true":"false"}))}}}}),k(this.transform,"translateX",{get(){return l.transform.__translateX__},set(d){const o=Y(d);at(o)||l.transform.__translateX__===o||(l.transform.__translateX__=o,I(e,{[vt]:`${o}px`}))}}),k(this.transform,"translateY",{get(){return l.transform.__translateY__},set(d){const o=Y(d);at(o)||l.transform.__translateY__===o||(l.transform.__translateY__=o,I(e,{[Tt]:`${o}px`}))}}),w(this,F,At).call(this),w(this,tt,$t).call(this),T(this.transform,{scale:a,translateX:0,translateY:0}),t.classList.add(Zt),this.mounted=!0,this.emit("ready",this)},F=new WeakSet,At=function(){const{wrapper:t,options:e,controller:{signal:s}}=this,{draggable:i,pinchable:a,wheelable:r}=e;if(this.states={},r){this.states.wheeling=!1;const c=l=>w(this,q,Mt).call(this,l);t.addEventListener(ee,c,{signal:s})}if(A&&(i||a)){i&&(this.states.dragging=!1),a&&(this.states.pinching=!1);const c=l=>w(this,J,Ct).call(this,l);t.addEventListener("touchstart",c,{signal:s})}if(!A&&i){this.states.dragging=!1;const c=l=>w(this,K,It).call(this,l);t.addEventListener("mousedown",c,{signal:s})}w(this,Q,xt).call(this)},q=new WeakSet,Mt=function(t){const{options:{zoomRatio:e,wheelReleaseOnMinMax:s,disableWheelingClass:i}}=this,a=(t.deltaY||t.detail)>0?-1:1;if(s){const r=this.isOnMinScale(),c=this.isOnMaxScale();r&&a===-1||c&&a===1||t.preventDefault()}else t.preventDefault();this.states.wheeling||lt(t.target,i)||(this.states.wheeling=!0,setTimeout(()=>{this.states.wheeling=!1},30),this.zoom(a*e,X(t)),this.emit("wheel",this,this.transform.scale,t))},K=new WeakSet,It=function(t){const{data:e,transform:s,options:{disableDraggingClass:i}}=this,{dragData:a,imageData:r}=e;if(!a||!r)return;const c=o=>{o&&o.button!==0||(o.preventDefault(),!lt(o.target,i)&&(T(a,{startX:X(o).clientX,startY:X(o).clientY}),this.states.dragging=!0,this.emit("dragStart",this,{x:s.translateX,y:s.translateY},o),document.addEventListener(U,l),document.addEventListener(j,d)))},l=o=>{if(o.touches||!this.states.dragging)return;o.preventDefault();const h=X(o).clientX,m=X(o).clientY,u=h-a.startX+s.translateX,f=m-a.startY+s.translateY;this.moveTo({x:u,y:f}),T(a,{startX:X(o).clientX,startY:X(o).clientY}),this.emit("drag",this,{x:u,y:f},o)},d=o=>{o.touches||(this.states.dragging=!1,this.emit("dragEnd",this,{x:s.translateX,y:s.translateY},o),document.removeEventListener(U,l),document.removeEventListener(j,d))};c(t)},J=new WeakSet,Ct=function(t){const{data:e,transform:s,options:{maxScale:i,minScale:a,draggable:r,pinchable:c,bounds:l,dragReleaseOnBounds:d,disableDraggingClass:o}}=this,{touchData:h,imageData:m}=e;if(!h||!m)return;const u=p=>{const g=p.touches;if(!g)return;if(l&&d){const ot=this.isOnBoundX(),rt=this.isOnBoundY(),M=g.length===1&&(ot||rt);console.log(M),M||p.preventDefault()}else p.preventDefault();if(lt(p.target,o)&&g.length<=1)return;const{top:v,left:y}=L(this.image),{width:N,height:B}=this.getImageDiff();T(h,{hypot:Et(g),startX:Z(g).clientX,startY:Z(g).clientY,prevX:0,prevY:0,imageTop:v,imageLeft:y,widthDiff:N,heightDiff:B}),r&&(this.states.dragging=!0,this.emit("dragStart",this,{x:s.translateX,y:s.translateY},p)),c&&g.length===2&&(this.states.pinching=!0,this.emit("pinchStart",this,s.scale,p)),document.addEventListener("touchmove",f),document.addEventListener("touchend",b)},f=p=>{const g=p.touches;if(!g)return;const{states:{dragging:v,pinching:y}}=this,{top:N,left:B}=L(this.image),{width:ot,height:rt}=this.getImageDiff(),M=Et(g),Yt=M?M/h.hypot:1,_t=this.useFixedRatio(Yt*s.scale),Rt=Z(g).clientX+h.prevX,Xt=Z(g).clientY+h.prevY;if(y&&g.length===2&&this.zoomTo(_t,!1),v){const Lt=_t!==i&&_t!==a&&c?Yt:1,ge=Y(Rt-h.imageLeft-(ot-h.widthDiff)-(h.startX-h.imageLeft)*Lt+s.translateX),_e=Y(Xt-h.imageTop-(rt-h.heightDiff)-(h.startY-h.imageTop)*Lt+s.translateY);this.moveTo({x:ge,y:_e})}T(h,{hypot:M,startX:Rt,startY:Xt,imageTop:N,imageLeft:B,widthDiff:ot,heightDiff:rt}),y&&g.length===2&&this.emit("pinch",this,s.scale,p),v&&this.emit("drag",this,{x:s.translateX,y:s.translateY},p)},b=p=>{const g=p.touches;if(!g)return;const{states:{dragging:v,pinching:y}}=this;if(v&&!g.length&&(this.states.dragging=!1,this.emit("dragEnd",this,{x:s.translateX,y:s.translateY},p)),y&&g.length<2&&(this.states.pinching=!1,this.emit("pinchEnd",this,s.scale,p)),v&&g.length===1){const N=X(p).clientX,B=X(p).clientY;T(h,{prevX:h.startX-N,prevY:h.startY-B})}g.length||(document.removeEventListener("touchmove",f),document.removeEventListener("touchend",b))};u(t)},Q=new WeakSet,xt=function(){const{element:t,image:e,transform:s}=this;new ResizeObserver(()=>{const{offsetWidth:a,offsetHeight:r}=t,{width:c,height:l}=this.getContainerData();if(a===c&&r===l)return;const d=s.translateX,o=s.translateY;if(d){const b=a/c*d;this.transform.translateX=b}if(o){const b=r/l*o;this.transform.translateY=b}const{offsetWidth:h,offsetHeight:m}=e,{width:u,height:f}=L(e);T(this.data.containerData,{width:a,height:r}),T(this.data.imageData,{originWidth:h,originHeight:m,width:u,height:f}),this.emit("resize",this)}).observe(t)},tt=new WeakSet,$t=function(){const{slider:t,zoomer:e}=this.__modules__;t&&w(this,et,Nt).call(this),e&&w(this,nt,Wt).call(this)},et=new WeakSet,Nt=function(){const{element:t,__modules__:{slider:e}}=this;if(!e||e.mounted)return;const{options:{el:s,direction:i}}=e,a=s===`.${$}`;if(!s||!a&&!_(s))return;const r=a?x("div",$):H(s),c=x("div",jt),l=x("span",kt),d=x("span",Gt,{...qt,"aria-orientation":i});r.classList.add(`${$}-${i}`),k(e,"value",{get(){return e.__value__},set(o){e.__value__!==o&&(e.__value__=o,I(r,{[ie]:o.toString()}),C(d,{"aria-valuenow":o.toString()}))}}),T(e,{value:this.getScaleRatio()*100,controller:new AbortController,sliding:!1,sliderEl:r,sliderTrack:c,sliderButton:d}),w(this,st,Bt).call(this),c.append(l,d),r.append(c),a&&t.append(r),e.mounted=!0},st=new WeakSet,Bt=function(){const{options:{minScale:t,maxScale:e},__modules__:{slider:s}}=this;if(!s)return;const{options:{direction:i},controller:a,sliderEl:r,sliderTrack:c}=s;if(!r||!c)return;const l=i==="vertical",d=u=>{const f=L(c),b=f[l?"height":"width"],p=f[l?"bottom":"left"],g=X(u)[l?"clientY":"clientX"],v=Y(z((g-p)*(l?-1:1)/b,0,1));return(e-t)*v+t},o=u=>{if(u instanceof MouseEvent&&u.button!==0)return;s.sliding=!0;const f=d(u);this.zoomTo(f),this.emit("slideStart",this,this.getSliderValue(),u),document.addEventListener(U,h),document.addEventListener(j,m)},h=u=>{if(!s.sliding)return;const f=d(u);this.zoomTo(f),this.emit("slide",this,this.getSliderValue(),u)},m=u=>{this.emit("slideEnd",this,this.getSliderValue(),u),s.sliding=!1,document.removeEventListener(U,h),document.removeEventListener(j,m)};r.addEventListener(te,o,{signal:a==null?void 0:a.signal})},nt=new WeakSet,Wt=function(){const{element:t,__modules__:{zoomer:e}}=this;if(!e||e.mounted)return;const{options:{el:s,inEl:i,outEl:a,resetEl:r}}=e,c=[i,a,r],l=(u,f,b,p,g)=>{const v=u===`.${b}`;return!u||!v&&!_(u)?null:(b=c.includes(u)?`${b} ${Pt}`:b,v?x(f,b,p,g):H(u))},d=l(s,"div",V),o=l(i,"button",ut,Kt,de),h=l(a,"button",mt,Jt,ue),m=l(r,"button",ft,Qt,me);T(e,{controller:new AbortController,zoomerEl:d,zoomerInEl:o,zoomerOutEl:h,zoomerResetEl:m}),d&&(o&&d.append(o),h&&d.append(h),m&&d.append(m),s===`.${V}`&&t.append(d)),w(this,it,Ht).call(this),e.mounted=!0},it=new WeakSet,Ht=function(){const{options:{zoomRatio:t},__modules__:{zoomer:e}}=this,s=this;if(!e)return;const{controller:i,zoomerInEl:a,zoomerOutEl:r,zoomerResetEl:c}=e;a&&a.addEventListener("click",()=>{s.zoom(t)},{signal:i==null?void 0:i.signal}),r&&r.addEventListener("click",()=>{s.zoom(-t)},{signal:i==null?void 0:i.signal}),c&&c.addEventListener("click",()=>{s.reset()},{signal:i==null?void 0:i.signal})},Object.assign(wt.prototype,fe),wt});