js-cloudimage-360-view 4.5.3 → 4.6.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,65 @@
1
+ "use strict";var Ci=Object.defineProperty;var xi=(e,t,i)=>t in e?Ci(e,t,{enumerable:!0,configurable:!0,writable:!0,value:i}):e[t]=i;var ge=(e,t,i)=>xi(e,typeof t!="symbol"?t+"":t,i);Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});var _t=typeof globalThis<"u"?globalThis:typeof window<"u"?window:typeof global<"u"?global:typeof self<"u"?self:{};function Ii(e){return e&&e.__esModule&&Object.prototype.hasOwnProperty.call(e,"default")?e.default:e}var qe="Expected a function",ye=NaN,Pi="[object Symbol]",Ei=/^\s+|\s+$/g,Si=/^[-+]0x[0-9a-f]+$/i,Ti=/^0b[01]+$/i,ki=/^0o[0-7]+$/i,Ai=parseInt,Oi=typeof _t=="object"&&_t&&_t.Object===Object&&_t,Li=typeof self=="object"&&self&&self.Object===Object&&self,Mi=Oi||Li||Function("return this")(),Xi=Object.prototype,Yi=Xi.toString,Hi=Math.max,Ri=Math.min,Qt=function(){return Mi.Date.now()};function zi(e,t,i){var o,s,n,r,l,a,c=0,h=!1,u=!1,f=!0;if(typeof e!="function")throw new TypeError(qe);t=be(t)||0,Nt(i)&&(h=!!i.leading,u="maxWait"in i,n=u?Hi(be(i.maxWait)||0,t):n,f="trailing"in i?!!i.trailing:f);function m(p){var g=o,C=s;return o=s=void 0,c=p,r=e.apply(C,g),r}function x(p){return c=p,l=setTimeout(I,t),h?m(p):r}function y(p){var g=p-a,C=p-c,S=t-g;return u?Ri(S,n-C):S}function b(p){var g=p-a,C=p-c;return a===void 0||g>=t||g<0||u&&C>=n}function I(){var p=Qt();if(b(p))return E(p);l=setTimeout(I,y(p))}function E(p){return l=void 0,f&&o?m(p):(o=s=void 0,r)}function w(){l!==void 0&&clearTimeout(l),c=0,o=a=s=l=void 0}function v(){return l===void 0?r:E(Qt())}function P(){var p=Qt(),g=b(p);if(o=arguments,s=this,a=p,g){if(l===void 0)return x(a);if(u)return l=setTimeout(I,t),m(a)}return l===void 0&&(l=setTimeout(I,t)),r}return P.cancel=w,P.flush=v,P}function Zi(e,t,i){var o=!0,s=!0;if(typeof e!="function")throw new TypeError(qe);return Nt(i)&&(o="leading"in i?!!i.leading:o,s="trailing"in i?!!i.trailing:s),zi(e,t,{leading:o,maxWait:t,trailing:s})}function Nt(e){var t=typeof e;return!!e&&(t=="object"||t=="function")}function Di(e){return!!e&&typeof e=="object"}function Bi(e){return typeof e=="symbol"||Di(e)&&Yi.call(e)==Pi}function be(e){if(typeof e=="number")return e;if(Bi(e))return ye;if(Nt(e)){var t=typeof e.valueOf=="function"?e.valueOf():e;e=Nt(t)?t+"":t}if(typeof e!="string")return e===0?e:+e;e=e.replace(Ei,"");var i=Ti.test(e);return i||ki.test(e)?Ai(e.slice(2),i?2:8):Si.test(e)?ye:+e}var _i=Zi;const we=Ii(_i),H={SPIN_X:"spin-x",SPIN_Y:"spin-y",SPIN_XY:"spin-xy",SPIN_YX:"spin-yx"},Fi=[!1,0,null,void 0,"false","0","null","undefined"],L={X:"x-axis",Y:"y-axis"},Wi=[37,39],Ni=[38,40],Vi=typeof navigator<"u"&&/Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent),Ce=Vi?32:10,ji=150,Gi=150,Ui=200,xe=50,$i=50,Ki=50,d={folder:"/",apiVersion:"v7",filenameX:"image-{index}.jpg",filenameY:null,imageListX:null,imageListY:null,indexZeroBase:0,amountX:0,amountY:0,speed:80,dragSpeed:150,draggable:!0,swipeable:!0,keys:!1,keysReverse:!1,autoplay:!1,autoplayBehavior:H.SPIN_X,playOnce:!1,autoplayReverse:!1,pointerZoom:0,pointerZoomTrigger:"dblclick",fullscreen:!1,zoomMax:5,zoomStep:.5,zoomControls:!0,zoomControlsPosition:"bottom-right",scrollHint:!0,bottomCircle:!0,bottomCircleOffset:5,ciToken:null,ciFilters:null,ciTransformation:null,lazyload:!0,dragReverse:!1,stopAtEdges:!1,imageInfo:!1,initialIconShown:!0,hotspots:null,hotspotTrigger:"hover",hide360Logo:!1,logoSrc:null,inertia:!1,pinchZoom:!0,hints:!0,theme:null,markerTheme:null,brandColor:null,hotspotTimelineOnClick:!0,aspectRatio:null,cropAspectRatio:null,cropGravity:null,onReady:null,onLoad:null,onSpin:null,onAutoplayStart:null,onAutoplayStop:null,onFullscreenOpen:null,onFullscreenClose:null,onZoomIn:null,onZoomOut:null,onDragStart:null,onDragEnd:null,onHotspotOpen:null,onHotspotClose:null,onProductClick:null,onError:null},qi=e=>({folder:T(e,"folder",d.folder),apiVersion:T(e,"api-version",d.apiVersion),filenameX:T(e,"filename")||T(e,"filename-x")||d.filenameX,filenameY:T(e,"filename-y",d.filenameY),imageListX:T(e,"image-list-x",d.imageListX),imageListY:T(e,"image-list-y",d.imageListY),indexZeroBase:parseInt(T(e,"index-zero-base",d.indexZeroBase),10),amountX:parseInt(T(e,"amount-x",d.amountX),10),amountY:parseInt(T(e,"amount-y",d.amountY),10),speed:parseInt(T(e,"speed",d.speed),10),dragSpeed:parseInt(T(e,"drag-speed",d.dragSpeed),10),draggable:M(e,"draggable",d.draggable),swipeable:M(e,"swipeable",d.swipeable),keys:M(e,"keys",d.keys),keysReverse:M(e,"keys-reverse",d.keysReverse),autoplay:M(e,"autoplay",d.autoplay),autoplayBehavior:T(e,"autoplay-behavior",d.autoplayBehavior),playOnce:M(e,"play-once",d.playOnce),autoplayReverse:M(e,"autoplay-reverse",d.autoplayReverse),pointerZoom:parseFloat(T(e,"pointer-zoom",d.pointerZoom)),pointerZoomTrigger:T(e,"pointer-zoom-trigger",d.pointerZoomTrigger),fullscreen:M(e,"fullscreen")||M(e,"full-screen",d.fullscreen),magnifier:T(e,"magnifier",null)!=null?parseFloat(T(e,"magnifier",null)):null,zoomMax:parseFloat(T(e,"zoom-max",d.zoomMax)),zoomStep:parseFloat(T(e,"zoom-step",d.zoomStep)),zoomControls:!ct(e,"zoom-controls"),zoomControlsPosition:T(e,"zoom-controls-position",d.zoomControlsPosition),scrollHint:!ct(e,"scroll-hint"),bottomCircleOffset:parseInt(T(e,"bottom-circle-offset",d.bottomCircleOffset),10),ciToken:T(e,"responsive",d.ciToken),ciFilters:T(e,"filters",d.ciFilters),ciTransformation:T(e,"transformation",d.ciTransformation),lazyload:M(e,"lazyload",d.lazyload),dragReverse:M(e,"drag-reverse",d.dragReverse),stopAtEdges:M(e,"stop-at-edges",d.stopAtEdges),imageInfo:M(e,"info",d.imageInfo),initialIconShown:!ct(e,"initial-icon"),bottomCircle:!ct(e,"bottom-circle"),hide360Logo:M(e,"hide-360-logo",d.hide360Logo),logoSrc:T(e,"logo-src",d.logoSrc),inertia:M(e,"inertia",d.inertia),pinchZoom:M(e,"pinch-zoom",d.pinchZoom),hints:!ct(e,"hints"),theme:T(e,"theme",d.theme),markerTheme:T(e,"marker-theme",d.markerTheme),brandColor:T(e,"brand-color",d.brandColor),hotspotTrigger:T(e,"hotspot-trigger",d.hotspotTrigger),hotspotTimelineOnClick:!ct(e,"hotspot-timeline-on-click"),aspectRatio:T(e,"aspect-ratio",d.aspectRatio),cropAspectRatio:T(e,"crop-aspect-ratio",d.cropAspectRatio),cropGravity:T(e,"crop-gravity",d.cropGravity)}),Ji=e=>{const t=[];e.amountX!==void 0&&e.amountX<0&&t.push("amountX should be a positive number"),e.amountY!==void 0&&e.amountY<0&&t.push("amountY should be a positive number"),e.speed!==void 0&&e.speed<=0&&t.push("speed should be a positive number"),e.dragSpeed!==void 0&&e.dragSpeed<=0&&t.push("dragSpeed should be a positive number"),e.pointerZoom!==void 0&&e.pointerZoom!==0&&(e.pointerZoom<1||e.pointerZoom>5)&&t.push("pointerZoom should be between 1 and 5 (or 0 to disable)"),e.magnifier!==void 0&&e.magnifier!==null&&e.magnifier!==0&&t.push("magnifier option is deprecated and will be ignored. Use zoomMax instead."),e.pointerZoomTrigger==="click"&&t.push('pointerZoomTrigger: "click" is deprecated. Zoom is now always triggered by double-click. Use dblclick trigger or the new zoom controls.'),!e.folder&&!e.imageListX&&!e.imageListY&&t.push("Either folder or imageListX/imageListY is required"),e.folder&&!e.amountX&&!e.imageListX&&t.push("amountX is required when using folder (unless imageListX is provided)");const i=["spin-x","spin-y","spin-xy","spin-yx"];return e.autoplayBehavior&&!i.includes(e.autoplayBehavior)&&t.push(`autoplayBehavior should be one of: ${i.join(", ")}`),t.forEach(o=>{console.warn(`CloudImage 360: ${o}`)}),t.length===0},Qi=e=>(Ji(e),{folder:e.folder||d.folder,apiVersion:e.apiVersion||d.apiVersion,filenameX:e.filenameX||e.filename||d.filenameX,filenameY:e.filenameY||d.filenameY,imageListX:e.imageListX||d.imageListX,imageListY:e.imageListY||d.imageListY,indexZeroBase:parseInt(e.indexZeroBase??d.indexZeroBase,10),amountX:parseInt(e.amountX??d.amountX,10),amountY:parseInt(e.amountY??d.amountY,10),speed:parseInt(e.speed??d.speed,10),draggable:e.draggable??d.draggable,swipeable:e.swipeable??d.swipeable,dragSpeed:parseInt(e.dragSpeed??d.dragSpeed,10),keys:e.keys??d.keys,keysReverse:e.keysReverse??d.keysReverse,autoplay:e.autoplay??d.autoplay,autoplayBehavior:e.autoplayBehavior||d.autoplayBehavior,playOnce:e.playOnce??d.playOnce,autoplayReverse:e.autoplayReverse??d.autoplayReverse,pointerZoom:parseFloat(e.pointerZoom??d.pointerZoom),pointerZoomTrigger:e.pointerZoomTrigger||d.pointerZoomTrigger,fullscreen:e.fullscreen??d.fullscreen,magnifier:e.magnifier!=null?parseFloat(e.magnifier):null,zoomMax:parseFloat(e.zoomMax??d.zoomMax),zoomStep:parseFloat(e.zoomStep??d.zoomStep),zoomControls:e.zoomControls??d.zoomControls,zoomControlsPosition:e.zoomControlsPosition||d.zoomControlsPosition,scrollHint:e.scrollHint??d.scrollHint,bottomCircleOffset:parseInt(e.bottomCircleOffset??d.bottomCircleOffset,10),ciToken:e.ciToken||d.ciToken,ciFilters:e.ciFilters||d.ciFilters,ciTransformation:e.ciTransformation||d.ciTransformation,lazyload:e.lazyload??d.lazyload,dragReverse:e.dragReverse??d.dragReverse,stopAtEdges:e.stopAtEdges??d.stopAtEdges,imageInfo:e.imageInfo??d.imageInfo,initialIconShown:e.initialIconShown??d.initialIconShown,bottomCircle:e.bottomCircle??d.bottomCircle,hotspots:e.hotspots??d.hotspots,hotspotTrigger:e.hotspotTrigger||d.hotspotTrigger,hide360Logo:e.hide360Logo??d.hide360Logo,logoSrc:e.logoSrc||d.logoSrc,inertia:e.inertia??d.inertia,pinchZoom:e.pinchZoom??d.pinchZoom,hints:e.hints??d.hints,theme:e.theme||d.theme,markerTheme:e.markerTheme||d.markerTheme,brandColor:e.brandColor||d.brandColor,hotspotTimelineOnClick:e.hotspotTimelineOnClick??d.hotspotTimelineOnClick,aspectRatio:e.aspectRatio||d.aspectRatio,cropAspectRatio:e.cropAspectRatio||d.cropAspectRatio,cropGravity:e.cropGravity||d.cropGravity,onReady:e.onReady??d.onReady,onLoad:e.onLoad??d.onLoad,onSpin:e.onSpin??d.onSpin,onAutoplayStart:e.onAutoplayStart??d.onAutoplayStart,onAutoplayStop:e.onAutoplayStop??d.onAutoplayStop,onFullscreenOpen:e.onFullscreenOpen??d.onFullscreenOpen,onFullscreenClose:e.onFullscreenClose??d.onFullscreenClose,onZoomIn:e.onZoomIn??d.onZoomIn,onZoomOut:e.onZoomOut??d.onZoomOut,onDragStart:e.onDragStart??d.onDragStart,onDragEnd:e.onDragEnd??d.onDragEnd,onHotspotOpen:e.onHotspotOpen??d.onHotspotOpen,onHotspotClose:e.onHotspotClose??d.onHotspotClose,onProductClick:e.onProductClick??d.onProductClick,onError:e.onError??d.onError}),T=(e,t,i)=>e.getAttribute(t)||e.getAttribute(`data-${t}`)||i,M=(e,t,i)=>{if(!(e.hasAttribute(t)||e.hasAttribute(`data-${t}`)))return i;const s=T(e,t,null);return s!=="false"&&s!=="0"},ct=(e,t)=>T(e,t,null)==="false",to=(e=1)=>{const t=Math.round(window.devicePixelRatio||1);return parseInt(e)*t},eo=(e,t,i)=>new URL(e).origin.includes("cloudimg")?e:`https://${t}.cloudimg.io/${i}${e}`,Ie=(e,t)=>e?`ar=${e}&gravity=${t||"auto"}`:"",io=({ciTransformation:e,responsiveWidth:t,ciFilters:i})=>{const o=`width=${t}`,s=e||o,n=i?`&f=${i}`:"";return`${s}${n}`},Pt=(e,t)=>{const{folder:i,apiVersion:o,filename:s="",ciParams:n}=e,{ciToken:r,ciFilters:l,ciTransformation:a,cropAspectRatio:c,cropGravity:h}=n||{},u=`${i}${s}`;if(!r||!t){const w=Ie(c,h);if(!w)return u;const v=u.includes("?")?"&":"?";return`${u}${v}${w}`}const f=Fi.includes(o)?null:o,m=f?`${f}/`:"",x=to(t),y=eo(u,r,m),b=io({ciTransformation:a,responsiveWidth:x,ciFilters:l}),I=Ie(c,h),E=[b,I].filter(Boolean).join("&");return`${y}${E?"?":""}${E}`},Je=(e,t=0)=>(e+="",e.length>=t?e:new Array(t-e.length+1).join("0")+e),oo=(e,{amount:t=0,indexZeroBase:i=0}={})=>Array.from({length:t},(o,s)=>e.replace("{index}",Je(s+1,i))),so=typeof navigator<"u"&&/Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent),no=so?3:6,ro=({imagesUrls:e,onFirstImageLoad:t,onImageLoad:i,onAllImagesLoad:o,onError:s,autoplayReverse:n})=>{let r=0,l=0;const a=e.length,c=[],h=[];let u=0,f=0;const m=[],x=(p,g,C=!1)=>{const S={message:`Failed to load image: ${p}`,url:p,index:g,isFirstImage:C};h.push(S),l++,s==null||s({error:S,errorCount:l,totalImages:a,errors:h})},y=()=>{r===a&&(o==null||o(c,{errorCount:l,errors:h}))},b=()=>{for(;u<no&&f<m.length;){const p=m[f];f++,I(e[p],p)}},I=(p,g)=>{u++;const C=new Image;C.crossOrigin="anonymous",C.src=p,C.onload=async()=>{try{const S=await createImageBitmap(C),k={src:p,bitmapImage:S,naturalWidth:C.naturalWidth,naturalHeight:C.naturalHeight};C.onload=null,C.onerror=null,C.src="",r++,u--,c[g]=k,i==null||i(k,g),y(),b()}catch{C.onload=null,C.onerror=null,C.src="",r++,u--,x(p,g),y(),b()}},C.onerror=()=>{C.onload=null,C.onerror=null,C.src="",r++,u--,x(p,g),y(),b()}},E=p=>{for(let g=0;g<e.length;g++)g!==p&&m.push(g);f=0,b()},w=new Image,v=n?e.length-1:0,P=e[v];w.crossOrigin="anonymous",w.src=P,w.onload=async()=>{try{const p=await createImageBitmap(w),g={src:P,bitmapImage:p,naturalWidth:w.naturalWidth,naturalHeight:w.naturalHeight};w.onload=null,w.onerror=null,w.src="",c[v]=g,r++,t==null||t(g),i==null||i(g,v),a===1?y():E(v)}catch{w.onload=null,w.onerror=null,w.src="",r++,x(P,v,!0),a===1?y():E(v)}},w.onerror=()=>{w.onload=null,w.onerror=null,w.src="",r++,x(P,v,!0),a===1?y():E(v)}},Pe=({cdnPathX:e,cdnPathY:t,configX:i,configY:o,onFirstImageLoad:s,onImageLoad:n,onAllImagesLoad:r,onError:l})=>{let a={x:!1,y:!1},c=[],h=[],u={errorCount:0,errors:[]},f={errorCount:0,errors:[]};const m=e||i.imageList.length,x=t||o.imageList.length,y=()=>{if(a.x&&a.y){const I={errorCount:u.errorCount+f.errorCount,errors:[...u.errors,...f.errors]};r==null||r(c,h,I)}},b=({cdnPath:I,config:E,orientation:w,loadedImages:v,loadStats:P,onFirstImageLoad:p})=>{const g=w===L.X,C=E.imageList.length?E.imageList:oo(I,E);ro({imagesUrls:C,onFirstImageLoad:p,onImageLoad:(S,k)=>{n==null||n(S,k,w),v[k]=S},onError:S=>{l==null||l({...S,orientation:w})},onAllImagesLoad:(S,k)=>{v.length=0,S.forEach((A,X)=>{A&&(v[X]=A)}),P.errorCount=k.errorCount,P.errors=k.errors.map(A=>({...A,orientation:w})),a[g?"x":"y"]=!0,y()},autoplayReverse:E.autoplayReverse})};m?b({cdnPath:e,config:i,orientation:L.X,loadedImages:c,loadStats:u,onFirstImageLoad:s}):a.x=!0,x?b({cdnPath:t,config:o,orientation:L.Y,loadedImages:h,loadStats:f,onFirstImageLoad:m?void 0:s}):a.y=!0,!m&&!x&&y()},ao=`
2
+ <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1052 156" aria-hidden="true">
3
+ <path fill="currentColor" d="M409.9,145.6c-42.7-1.7-85.5-4.4-128.1-8.4c-21.3-2-42.6-4.3-63.8-7.1c-21.2-2.8-42.4-5.9-63.4-9.7c-21.1-3.8-42-8.2-62.7-13.7c-10.3-2.8-20.6-5.8-30.7-9.4c-10.1-3.5-20.1-7.6-29.5-12.7c-4.7-2.6-9.3-5.4-13.5-8.8c-2.1-1.7-4-3.6-5.8-5.6c-1.8-2-3.3-4.3-4.3-6.8c-1.1-2.5-1.6-5.3-1.4-8c0.2-2.7,1.1-5.4,2.4-7.7c2.7-4.8,6.7-8.5,11-11.7c8.6-6.4,18.4-10.9,28.3-15c9.9-4,20.1-7.3,30.4-10.3c-10.2,3.1-20.4,6.5-30.3,10.5c-9.8,4.1-19.6,8.7-28.1,15.1c-4.2,3.2-8.2,6.9-10.7,11.6c-1.2,2.3-2.1,4.8-2.3,7.5c-0.1,2.6,0.4,5.2,1.4,7.6c2.1,4.8,5.9,8.7,10,12.1c4.1,3.3,8.7,6.1,13.4,8.6c9.4,5,19.4,8.9,29.4,12.4c10.1,3.5,20.4,6.4,30.7,9.1c20.7,5.3,41.6,9.5,62.7,13.2c21,3.6,42.2,6.6,63.4,9.2c21.2,2.6,42.5,4.8,63.7,6.6c42.6,3.7,85.2,6,127.9,7.4L409.9,145.6z"/>
4
+ <path fill="currentColor" d="M977.1,11.6c13.8,4.1,27.4,8.8,40.4,15.2c6.4,3.2,12.7,6.9,18.3,11.5c2.7,2.4,5.3,5,7.3,8c2,3,3.3,6.6,3.3,10.3c0,3.7-1.4,7.2-3.3,10.3c-2,3.1-4.5,5.7-7.3,8.1c-2.7,2.4-5.7,4.4-8.8,6.3c-1.6,0.9-3.1,1.9-4.7,2.7l-2.4,1.3l-2.4,1.2C1004.5,93,990.8,97.8,977,102c-6.9,2.1-13.8,4-20.8,5.8c-7,1.8-14,3.5-21,5c-14.1,3.1-28.2,5.9-42.4,8.3c-28.4,4.9-57,8.8-85.6,12c-57.3,6.4-114.8,10.2-172.4,12.2c-57.6,2-115.2,2.3-172.9,0.8l0.1-4c57.5,1.8,115.1,1.9,172.6,0.2c57.5-1.7,115-5.2,172.3-11.2c28.6-3.1,57.2-6.7,85.6-11.5c14.2-2.4,28.3-5,42.4-8.1c7-1.5,14-3.1,21-4.9c7-1.7,13.9-3.6,20.8-5.7c13.8-4.1,27.4-8.8,40.3-15.2l2.4-1.2l2.4-1.3c1.6-0.8,3.1-1.8,4.7-2.7c3-1.9,6-3.9,8.7-6.2c2.7-2.3,5.2-4.9,7.2-7.9c1.9-3,3.2-6.4,3.3-10c0-3.6-1.2-7-3.1-10c-1.9-3-4.4-5.6-7.1-8c-5.5-4.7-11.7-8.3-18.1-11.6C1004.5,20.6,990.8,15.8,977.1,11.6z"/>
5
+ <g transform="translate(415, 136)">
6
+ <path fill="currentColor" d="M18.1,11.2c-1.8,0-2.8-1.2-2.8-3V8c0.8-0.4,1.7-0.6,2.8-0.6c1.5,0,2.5,0.6,2.5,1.7C20.6,10.2,19.8,11.2,18.1,11.2L18.1,11.2z M18.3,5.7c-1.1,0-2,0.3-2.8,0.7c0.3-1.6,1.5-2.6,3.7-2.6c1.1,0,2.3,0.3,3.1,0.5V2.6c-0.8-0.3-1.9-0.5-3.1-0.5c-4.2,0-6.2,2.1-6.2,5.8c0,3.2,1.8,4.9,5.1,4.9c3.3,0,5-1.7,5-3.6C23,7,21.3,5.7,18.3,5.7L18.3,5.7z"/>
7
+ <path fill="currentColor" d="M39.3,1.8c0.9,0,1.6,0.7,1.6,1.5c0,0.8-0.7,1.6-1.6,1.6c-0.8,0-1.6-0.7-1.6-1.6C37.8,2.5,38.5,1.8,39.3,1.8L39.3,1.8z M39.3,6.3c1.7,0,3.1-1.3,3.1-3c0-1.6-1.4-3-3.1-3c-1.7,0-3.1,1.3-3.1,3C36.2,5,37.6,6.3,39.3,6.3L39.3,6.3z"/>
8
+ <path fill="currentColor" d="M30.3,3.8c2.1,0,2.9,1.4,2.9,3.6c0,2.2-0.8,3.6-2.9,3.6c-2.1,0-2.9-1.5-2.9-3.6C27.4,5.3,28.1,3.8,30.3,3.8L30.3,3.8z M30.2,12.8c3.9,0,5.2-2.6,5.2-5.4c0-2.8-1.3-5.3-5.2-5.3c-3.9,0-5.3,2.6-5.3,5.4C25,10.3,26.3,12.8,30.2,12.8L30.2,12.8z"/>
9
+ <path fill="currentColor" d="M10.9,9.7c0-1.1-0.8-2-2.5-2.5c1.3-0.5,1.9-1.3,1.9-2.3c0-1.7-1.7-2.8-4.6-2.8c-1.5,0-2.7,0.3-3.6,0.8v1.7c0.9-0.4,2.3-0.7,3.4-0.7C7,3.9,8,4.4,8,5.1c0,0.8-0.7,1.3-2.4,1.3H4.3v1.6h1.3c2,0,2.9,0.8,2.9,1.6c0,0.8-1,1.5-2.8,1.5c-1.5,0-2.8-0.3-3.7-0.6v1.7c0.9,0.3,2.1,0.6,3.8,0.6C9.2,12.8,10.9,11.4,10.9,9.7"/>
10
+ </g>
11
+ </svg>
12
+ `,lo=e=>{const t=document.createElement("div");return t.innerHTML=ao,t.style.bottom=`${e}%`,t.className="cloudimage-360-view-360-circle",t},ho=`
13
+ <svg width="150" height="87" viewBox="0 0 150 87" xmlns="http://www.w3.org/2000/svg">
14
+ <g clip-path="url(#clip0_751_188)">
15
+ <g filter="url(#filter0_d_751_188)">
16
+ <path d="M112.566 15.2227C112.598 15.706 112.529 16.1906 112.364 16.6458C112.198 17.101 111.94 17.5167 111.605 17.8665C111.27 18.2163 110.866 18.4925 110.418 18.6775C109.971 18.8626 109.489 18.9524 109.005 18.9412C108.532 18.955 108.06 18.871 107.621 18.6944C107.181 18.5178 106.782 18.2524 106.45 17.9148C106.117 17.5772 105.858 17.1747 105.688 16.7323C105.518 16.29 105.442 15.8174 105.463 15.344C105.437 14.8591 105.511 14.374 105.68 13.9188C105.849 13.4635 106.109 13.0477 106.445 12.697C106.781 12.3463 107.186 12.0681 107.633 11.8797C108.081 11.6912 108.562 11.5965 109.048 11.6013C111.213 11.5952 112.566 13.1299 112.566 15.2227ZM106.961 15.2895C106.961 16.7574 107.913 17.825 109.03 17.825C110.146 17.825 111.08 16.8059 111.08 15.2652C111.08 14.1551 110.473 12.7053 109.005 12.7053C107.537 12.7053 106.961 14.0884 106.961 15.2895Z" fill="currentColor"/>
17
+ <path fill-rule="evenodd" clip-rule="evenodd" d="M110.164 12.3811C110.552 12.5859 110.861 12.8886 111.093 13.2348C111.506 13.8535 111.681 14.6156 111.681 15.2652C111.681 16.5122 111.13 17.5742 110.261 18.0908C110.603 17.9385 110.912 17.7212 111.171 17.4507C111.448 17.1612 111.662 16.8172 111.799 16.4404C111.936 16.0637 111.993 15.6626 111.966 15.2626L111.965 15.2427V15.2227C111.965 14.3058 111.67 13.5543 111.182 13.0378C110.913 12.7532 110.573 12.5262 110.164 12.3811ZM108.002 18.1944C107.011 17.7212 106.36 16.5793 106.36 15.2895C106.36 14.6064 106.522 13.8357 106.931 13.2157C107.06 13.021 107.212 12.8427 107.389 12.6885C107.204 12.81 107.033 12.9523 106.88 13.1128C106.6 13.4042 106.384 13.7497 106.244 14.128C106.103 14.5062 106.042 14.9093 106.063 15.3122L106.065 15.3415L106.063 15.3708C106.046 15.7615 106.109 16.1517 106.25 16.5168C106.39 16.882 106.604 17.2143 106.878 17.493C107.153 17.7717 107.482 17.9908 107.845 18.1366C107.897 18.1574 107.949 18.1767 108.002 18.1944ZM109.05 11.0002C108.483 10.9951 107.922 11.1058 107.4 11.3256C106.877 11.5459 106.404 11.8711 106.011 12.2811C105.619 12.6912 105.314 13.1773 105.116 13.7096C104.922 14.2327 104.835 14.7894 104.861 15.3466C104.841 15.8928 104.931 16.4375 105.127 16.9478C105.327 17.4673 105.631 17.9401 106.022 18.3366C106.412 18.7331 106.88 19.0448 107.397 19.2522C107.908 19.4577 108.456 19.5564 109.007 19.5425C109.569 19.5533 110.128 19.448 110.648 19.2331C111.173 19.0162 111.646 18.6924 112.039 18.2823C112.432 17.8722 112.735 17.3848 112.929 16.8512C113.121 16.3239 113.202 15.7628 113.167 15.203C113.163 14.035 112.782 12.9803 112.056 12.2121C111.323 11.4362 110.28 10.9976 109.05 11.0002ZM107.934 13.8783C107.689 14.2501 107.562 14.7714 107.562 15.2895C107.562 16.5291 108.34 17.2239 109.03 17.2239C109.716 17.2239 110.479 16.5808 110.479 15.2652C110.479 14.8047 110.35 14.2869 110.093 13.9031C109.851 13.5403 109.507 13.3065 109.005 13.3065C108.495 13.3065 108.163 13.5319 107.934 13.8783Z" fill="currentColor"/>
18
+ <path d="M94.3617 40.718H95.5396C99.9046 40.718 103.369 37.1844 103.369 32.8193V19.5164C103.369 15.1514 99.8353 11.6871 95.5396 11.6871H94.3617C89.9967 11.6871 86.5324 15.2207 86.5324 19.5164V32.8193C86.4631 37.1844 90.0659 40.718 94.3617 40.718ZM91.1052 19.5164C91.1052 17.715 92.5602 16.26 94.3617 16.26H95.5396C97.341 16.26 98.796 17.715 98.796 19.5164V32.8193C98.796 34.6208 97.341 36.0758 95.5396 36.0758H94.3617C92.5602 36.0758 91.1052 34.6208 91.1052 32.8193V19.5164Z" fill="currentColor"/>
19
+ <path d="M74.6152 40.7179C79.2574 40.7179 82.9988 36.9765 82.9988 32.3343C82.9988 27.6922 79.2574 23.9507 74.6152 23.9507C73.9916 23.9507 73.2988 24.02 72.7445 24.1586C73.9223 21.4564 75.7931 18.685 78.7724 16.4678C79.8117 15.7749 80.0195 14.3199 79.2574 13.2806C78.5645 12.2413 77.1095 12.0335 76.0702 12.7956C67.8944 18.8928 66.578 28.0386 66.3701 31.2258C66.3701 31.2258 66.3701 31.2257 66.3701 31.295C66.3009 31.6415 66.3009 31.9879 66.3009 32.4036C66.2316 36.9072 70.0423 40.7179 74.6152 40.7179ZM74.6152 28.4543C76.6938 28.4543 78.3566 30.1865 78.3566 32.1958C78.3566 34.2051 76.6245 35.9372 74.6152 35.9372C72.6752 35.9372 71.0123 34.3436 70.8737 32.4729C70.8737 32.4036 70.943 32.265 70.943 32.1265C70.943 32.1265 70.943 31.9186 71.0123 31.5722C71.2202 29.84 72.8138 28.4543 74.6152 28.4543Z" fill="currentColor"/>
20
+ <path d="M54.3143 36.0758C52.2358 36.0758 50.5729 34.3436 50.5729 32.3343C50.5729 31.0179 49.5336 30.0479 48.2864 30.0479C46.97 30.0479 46 31.0872 46 32.3343C46 36.9765 49.7414 40.718 54.3836 40.718C59.0258 40.718 62.7672 36.9765 62.7672 32.1958C62.7672 29.84 61.7279 27.6229 60.0651 26.0986C61.7279 24.505 62.7672 22.4264 62.7672 20.0014C62.7672 15.3592 59.0258 11.6178 54.3836 11.6178C49.7414 11.6178 46 15.3592 46 20.0014C46 21.3178 47.0393 22.2879 48.2864 22.2879C49.6029 22.2879 50.5729 21.2486 50.5729 20.0014C50.5729 17.9228 52.305 16.26 54.3143 16.26C56.3236 16.26 58.0558 17.9921 58.0558 20.0014C58.0558 22.0107 56.3236 23.7429 54.3143 23.7429C52.9979 23.7429 52.0279 24.7822 52.0279 26.0293C52.0279 27.3458 53.0672 28.3157 54.3143 28.3157C56.3929 28.3157 58.0558 30.0479 58.0558 32.0572C58.1251 34.3436 56.4622 36.0758 54.3143 36.0758Z" fill="currentColor"/>
21
+ </g>
22
+ <g filter="url(#filter1_d_751_188)">
23
+ <path d="M26.8762 25.5149C27.5172 25.2883 28.1927 25.7659 28.1927 26.4458V33.5925C28.1927 34.0014 27.9493 34.3677 27.5768 34.5364C23.692 36.2966 3.80303 46.5259 37.3945 58.1537C37.3945 58.1537 57.0291 63.5205 76.923 63.6974C77.4752 63.7023 77.9231 63.2541 77.9231 62.7018V57.8317C77.9231 57.0995 78.6841 56.6156 79.3472 56.9261L103.851 68.4011C104.598 68.7507 104.624 69.8027 103.897 70.1897L79.3926 83.2187C78.7265 83.5728 77.9231 83.0901 77.9231 82.3357V75.7982C77.9231 75.2459 77.5039 74.797 76.9517 74.7892C68.3815 74.6673 6 72.8926 6 47.0574C6 47.0574 6 32.8966 26.8762 25.5149Z" fill="currentColor"/>
24
+ <path d="M111.768 58.2062C110.979 57.639 111.335 56.0078 112.271 55.7479C118.431 54.037 131.443 49.0118 131.443 41.6445C131.443 34.2279 126.608 31.5583 124.732 30.8016C124.308 30.6306 124 30.2281 124 29.7708V26.2189C124 25.5882 124.573 25.1253 125.18 25.2967C129.233 26.4408 142.336 31.2278 142.336 45.2982C142.336 45.2982 142.336 58.9459 122.524 65.4395C122.224 65.5379 121.887 65.4876 121.63 65.3031L111.768 58.2062Z" fill="currentColor"/>
25
+ </g>
26
+ </g>
27
+ <defs>
28
+ <filter id="filter0_d_751_188" x="38" y="3" width="83.1749" height="45.718" filterUnits="userSpaceOnUse" color-interpolation-filters="sRGB">
29
+ <feFlood flood-opacity="0" result="BackgroundImageFix"/>
30
+ <feColorMatrix in="SourceAlpha" type="matrix" values="0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0" result="hardAlpha"/>
31
+ <feOffset/>
32
+ <feGaussianBlur stdDeviation="4"/>
33
+ <feComposite in2="hardAlpha" operator="out"/>
34
+ <feColorMatrix type="matrix" values="0 0 0 0 0.133333 0 0 0 0 0.145098 0 0 0 0 0.160784 0 0 0 0.4 0"/>
35
+ <feBlend mode="normal" in2="BackgroundImageFix" result="effect1_dropShadow_751_188"/>
36
+ <feBlend mode="normal" in="SourceGraphic" in2="effect1_dropShadow_751_188" result="shape"/>
37
+ </filter>
38
+ <filter id="filter1_d_751_188" x="4" y="25.2607" width="140.336" height="63.0764" filterUnits="userSpaceOnUse" color-interpolation-filters="sRGB">
39
+ <feFlood flood-opacity="0" result="BackgroundImageFix"/>
40
+ <feColorMatrix in="SourceAlpha" type="matrix" values="0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0" result="hardAlpha"/>
41
+ <feOffset dy="3"/>
42
+ <feGaussianBlur stdDeviation="1"/>
43
+ <feComposite in2="hardAlpha" operator="out"/>
44
+ <feColorMatrix type="matrix" values="0 0 0 0 0.301961 0 0 0 0 0.360784 0 0 0 0 0.454902 0 0 0 0.4 0"/>
45
+ <feBlend mode="normal" in2="BackgroundImageFix" result="effect1_dropShadow_751_188"/>
46
+ <feBlend mode="normal" in="SourceGraphic" in2="effect1_dropShadow_751_188" result="shape"/>
47
+ </filter>
48
+ <clipPath id="clip0_751_188">
49
+ <rect width="150" height="87" fill="white"/>
50
+ </clipPath>
51
+ </defs>
52
+ </svg>
53
+ `,co=e=>{const t=document.createElement("div");return t.className="cloudimage-initial-icon",t.setAttribute("aria-label","360 degree view - drag to rotate"),e?(t.style.backgroundImage=`url('${e}')`,t.style.backgroundPosition="50% 50%",t.style.backgroundSize="contain",t.style.backgroundRepeat="no-repeat"):t.innerHTML=ho,t},uo=(e,t)=>{const{width:i,height:o}=t,s=document.createElement("canvas");return s.width=i,s.height=o,s.style.width="100%",s.style.height="auto",e.appendChild(s),s},Qe='<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" aria-hidden="true"><polyline points="15 3 21 3 21 9"/><polyline points="9 21 3 21 3 15"/><line x1="21" x2="14" y1="3" y2="10"/><line x1="3" x2="10" y1="21" y2="14"/></svg>',po='<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" aria-hidden="true"><polyline points="4 14 10 14 10 20"/><polyline points="20 10 14 10 14 4"/><line x1="14" x2="21" y1="10" y2="3"/><line x1="3" x2="10" y1="21" y2="14"/></svg>',mo=()=>{const e=document.createElement("button");return e.className="cloudimage-360-button cloudimage-360-fullscreen-button",e.setAttribute("aria-label","View fullscreen"),e.setAttribute("type","button"),e.innerHTML=Qe,e},fo=(e,t)=>{e&&(e.innerHTML=t?po:Qe,e.setAttribute("aria-label",t?"Exit fullscreen":"View fullscreen"))},Ee=e=>{const t=document.createElement("div");return t.className="cloudimage-360-icons-container",e.appendChild(t),t},vo=e=>{const t=document.createElement("div");return t.className="cloudimage-360-inner-box",t.setAttribute("role","img"),t.setAttribute("aria-label","360 degree product view. Use mouse drag or arrow keys to rotate."),e.appendChild(t),t},go=e=>{const t=document.createElement("div");t.className="cloudimage-360-loader";const i=document.createElement("span");return i.className="percentage",i.innerText="0%",t.appendChild(i),e.appendChild(t),t},ee=(e,t)=>{const i=e.querySelector(t);i&&i.parentNode.removeChild(i)},yo=()=>{const e=document.createElement("div");return e.className="cloudimage-loading-spinner",e},bo=e=>{const t=document.createElement("div");return t.className="cloudimage-360-hotspot-container",e.appendChild(t),t},wo=e=>{const t=document.createElement("div");return t.className="cloudimage-360-sr-only",t.setAttribute("role","status"),t.setAttribute("aria-live","polite"),t.setAttribute("aria-atomic","true"),e.appendChild(t),t},Co=(e,t)=>{e&&(e.textContent="",setTimeout(()=>{e.textContent=t},50))},ti={drag:'<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" aria-hidden="true"><path d="M18 11V6a2 2 0 0 0-2-2a2 2 0 0 0-2 2"/><path d="M14 10V4a2 2 0 0 0-2-2a2 2 0 0 0-2 2v2"/><path d="M10 10.5V6a2 2 0 0 0-2-2a2 2 0 0 0-2 2v8"/><path d="M18 8a2 2 0 1 1 4 0v6a8 8 0 0 1-8 8h-2c-2.8 0-4.5-.86-5.99-2.34l-3.6-3.6a2 2 0 0 1 2.83-2.82L7 15"/></svg>',swipe:'<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" aria-hidden="true"><path d="m18 16 4-4-4-4"/><path d="m6 8-4 4 4 4"/><path d="M8 12h8"/></svg>',click:'<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" aria-hidden="true"><path d="m9 9 5 12 1.8-5.2L21 14Z"/><path d="M7.2 2.2 8 5.1"/><path d="m5.1 8-2.9-.8"/><path d="M14 4.1 12 6"/><path d="m6 12-1.9 2"/></svg>',dblclick:'<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" aria-hidden="true"><path d="m9 9 5 12 1.8-5.2L21 14Z"/><path d="M7.2 2.2 8 5.1"/><path d="m5.1 8-2.9-.8"/><path d="M14 4.1 12 6"/><path d="m6 12-1.9 2"/><text x="1" y="22" font-size="8" font-weight="bold" fill="currentColor" stroke="none" font-family="sans-serif">2×</text></svg>',pinch:'<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" aria-hidden="true"><path d="M6 6l4 4"/><path d="M18 6l-4 4"/><path d="M6 18l4-4"/><path d="M18 18l-4-4"/><circle cx="12" cy="12" r="2"/></svg>',keys:'<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" aria-hidden="true"><rect width="20" height="16" x="2" y="4" rx="2"/><path d="m9 10 3 3 3-3"/></svg>',fullscreen:'<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" aria-hidden="true"><polyline points="15 3 21 3 21 9"/><polyline points="9 21 3 21 3 15"/><line x1="21" x2="14" y1="3" y2="10"/><line x1="3" x2="10" y1="21" y2="14"/></svg>'},xo={drag:"Drag to rotate",swipe:"Swipe to rotate",click:"Click to zoom",dblclick:"Double-click to zoom",pinch:"Pinch to zoom",keys:"Use arrow keys",fullscreen:"Click for fullscreen"},Io=e=>{const t=document.createElement("div");t.className="cloudimage-360-hint-item";const i=xo[e];return t.innerHTML=`
54
+ ${ti[e]}
55
+ <span>${i}</span>
56
+ `,t},Se=(e,t=[])=>{if(!t||t.length===0)return null;const i=document.createElement("div");i.className="cloudimage-360-hints-overlay",i.setAttribute("role","tooltip"),i.setAttribute("aria-label","Interaction hints");const o=document.createElement("div");return o.className="cloudimage-360-hints-container",t.forEach(s=>{ti[s]&&o.appendChild(Io(s))}),i.appendChild(o),e.appendChild(i),i},Te=(e,t)=>t?["swipe","pinch"]:["drag","dblclick"],ke=e=>{e&&e.classList.add("visible")},Po=e=>{e&&(e.classList.remove("visible"),e.classList.add("hiding"),setTimeout(()=>{e.classList.remove("hiding")},300))},Eo=e=>{if(!e||typeof e!="object")return null;const t=Object.keys(e).map(o=>parseInt(o,10)).filter(o=>!isNaN(o)).sort((o,s)=>o-s);if(t.length===0)return null;const i=Math.floor(t.length/2);return t[i]},So=e=>{const t=[];return!e||!Array.isArray(e)||e.forEach((i,o)=>{const s=Eo(i.positions);s!==null&&t.push({id:i.id||`hotspot-${o}`,frame:s,label:i.label||null})}),t},To=400,ko=(e,t,i,o)=>{const s=document.createElement("button");s.className="cloudimage-360-hotspot-timeline-dot",s.setAttribute("type","button"),s.setAttribute("aria-label",o||`Go to hotspot at frame ${t+1}`),s.setAttribute("data-frame",t.toString()),s.setAttribute("data-hotspot-id",e);const n=i>1?t/(i-1)*100:0;if(s.style.left=`${n}%`,o){const r=document.createElement("span");r.className="cloudimage-360-hotspot-timeline-tooltip",r.textContent=o,s.appendChild(r);let l=null;s.addEventListener("mouseenter",()=>{l=setTimeout(()=>{r.classList.add("visible")},To)}),s.addEventListener("mouseleave",()=>{l&&(clearTimeout(l),l=null),r.classList.remove("visible")}),s.addEventListener("click",()=>{l&&(clearTimeout(l),l=null),r.classList.remove("visible")})}return s},Ao=(e,t,i)=>{const o=So(i);if(o.length===0)return null;const s=document.createElement("div");s.className="cloudimage-360-hotspot-timeline",s.setAttribute("role","navigation"),s.setAttribute("aria-label","Hotspot timeline navigation");const n=document.createElement("div");n.className="cloudimage-360-hotspot-timeline-track";const r=document.createElement("div");return r.className="cloudimage-360-hotspot-timeline-indicator",o.forEach(({id:l,frame:a,label:c})=>{const h=ko(l,a,t,c);n.appendChild(h)}),n.appendChild(r),s.appendChild(n),e.appendChild(s),{element:s,indicator:r,hotspotFrames:o}},Oo=(e,t,i)=>{if(!e)return;const o=i>1?t/(i-1)*100:0;e.style.left=`${o}%`},Lo=e=>{e&&e.classList.add("visible")},Mo=e=>{e&&e.classList.remove("visible")},ie=(e,t=[])=>{if(!e)return t;if(Array.isArray(e))return e;try{return JSON.parse(e)}catch(i){return console.warn("CloudImage 360: Failed to parse JSON:",i.message),t}},Xo=(e,t)=>{const[i,o]=e.split("?");if(!o)return e;const s=new RegExp(`^${t}=|&${t}=`),n=o.split("&").filter(r=>!s.test(r)).join("&");return n?`${i}?${n}`:i},Yo=e=>{const t=Xo(e,"width"),i=t.includes("?")?"&":"?";return`${t}${i}width=${150*devicePixelRatio}`},Ho=e=>{const t={root:null,rootMargin:"0px",threshold:.1},i=s=>{const n=s.getAttribute("data-src");n&&(s.src=n)};new IntersectionObserver((s,n)=>{s.forEach(r=>{r.isIntersecting&&(i(r.target),n.unobserve(r.target))})},t).observe(e)},Ro=(e,t)=>{const i=Je(1,t);return e.replace("{index}",i)},zo=(e,t)=>{const[i]=e,o=/(https?):\/\//i.test(i);return Pt({...t,folder:o?"":t.folder,filename:i})},Zo=(e,t)=>{const{imageList:i,indexZeroBase:o}=t;if(i.length){const s=ie(i,null);if(s)return zo(s,t)}return Ro(e,o)},Ae=(e,t,i)=>{const o=new Image;return o.setAttribute(t?"data-src":"src",e),o.className=i,o.style.cssText=`
57
+ position: ${t?"absolute":"static"};
58
+ width: 100%;
59
+ inset: 0;
60
+ height: 100%;
61
+ object-fit: contain;
62
+ object-position: center;
63
+ filter: blur(10px);
64
+ `,o},Oe=(e,t,i)=>{const{innerBox:o,imageList:s,lazyload:n}=t||{},[r]=s,l=r||Zo(e,t),a=Yo(l),c=Ae(a,n,"cloudimage-lazy"),h=Ae(a,!1,"cloudimage-360-placeholder"),u=f=>{ee(o,".cloudimage-lazy"),i&&i({event:f,width:c.width,height:c.height,naturalWidth:c.naturalWidth,naturalHeight:c.naturalHeight,src:a})};c.onload=u,o.appendChild(c),o.appendChild(h),Ho(c)},Do=(e,t,i)=>{const o=e/i,s=t/i;return{zoomedWidth:o,zoomedHeight:s}},Bo=({pointerX:e,pointerY:t,imageData:i,zoomedWidth:o,zoomedHeight:s,drawWidth:n,drawHeight:r})=>{const{naturalWidth:l,naturalHeight:a}=i;let c=e/n*l-o/2,h=t/r*a-s/2;const u=Math.max(0,l-o),f=Math.max(0,a-s);return c=Math.max(0,Math.min(c,u)),h=Math.max(0,Math.min(h,f)),{zoomOffsetX:c,zoomOffsetY:h}},Le=(e,{bottom:t,top:i})=>{e?t():i()},Me=(e,{left:t,right:i})=>{e?t():i()},_o=({autoplayBehavior:e,spinY:t,reversed:i,loopTriggers:o})=>{switch(e){case H.SPIN_XY:case H.SPIN_YX:t?Le(i,o):Me(i,o);break;case H.SPIN_Y:Le(i,o);break;case H.SPIN_X:default:Me(i,o)}},Fo=({autoplayBehavior:e,activeImageX:t,activeImageY:i,amountX:o,amountY:s,autoplayReverse:n})=>{const r=(l,a)=>{const c=a-1;return n?l===0:l===c};switch(e){case H.SPIN_XY:case H.SPIN_Y:return r(i,s);case H.SPIN_X:case H.SPIN_YX:default:return r(t,o)}},Wo=({autoplayBehavior:e,activeImageX:t,activeImageY:i,amountX:o,amountY:s,autoplayReverse:n,spinDirection:r})=>{const l=t===(n?0:o-1),a=i===(n?0:s-1);return e===H.SPIN_XY||e===H.SPIN_YX?r==="x"&&l||r==="y"&&a:!1},No=(e,t,i)=>{if(!i)return"x";if(!t)return"y";switch(e){case H.SPIN_XY:return"x";case H.SPIN_YX:return"y";case H.SPIN_Y:return"y";case H.SPIN_X:default:return"x"}},Vo=e=>e==="x"?"y":"x",Xe=(e,t)=>{const i=[...Wi];return t?[...i,...Ni].includes(e):i.includes(e)},Ye=({deltaX:e,deltaY:t,reversed:i,allowSpinX:o,allowSpinY:s,threshold:n=0})=>{const r=o&&!s||s&&!o?0:n,l=Math.abs(e),a=Math.abs(t);return o&&l-r>a?i?e>0?"left":"right":e>0?"right":"left":s&&a-r>l?i?t>0?"up":"down":t>0?"down":"up":null},jo=()=>"ontouchstart"in window||navigator.maxTouchPoints>0||navigator.msMaxTouchPoints>0,Go=(e,t=150)=>{let i;return function(...o){clearTimeout(i),i=setTimeout(()=>{e.apply(this,o)},t)}},Uo=()=>document.fullscreenEnabled||document.webkitFullscreenEnabled,te=()=>document.fullscreenElement||document.webkitFullscreenElement,$o=e=>e.requestFullscreen?e.requestFullscreen():e.webkitRequestFullscreen?e.webkitRequestFullscreen():Promise.reject(new Error("Fullscreen API not supported")),He=()=>document.exitFullscreen?document.exitFullscreen():document.webkitExitFullscreen?document.webkitExitFullscreen():Promise.reject(new Error("Fullscreen API not supported")),W=1;class Ko{constructor(t,{zoomMax:i=5,zoomStep:o=.5,onZoomChange:s}={}){this.container=t,this.zoomMax=i,this.zoomStep=o,this.onZoomChange=s,this.zoom=1,this.panX=0,this.panY=0,this.drawWidth=0,this.drawHeight=0,this.isPanning=!1,this.panStartX=0,this.panStartY=0,this._onWheel=this._onWheel.bind(this),this._onDblClick=this._onDblClick.bind(this),this._onMouseMove=this._onMouseMove.bind(this),this._onMouseUp=this._onMouseUp.bind(this),this._onGestureStart=this._onGestureStart.bind(this),this._onGestureChange=this._onGestureChange.bind(this),this._onGestureEnd=this._onGestureEnd.bind(this),this._gestureBaseZoom=1,this._attach()}setDrawSize(t,i,o=!1){const s=this.drawWidth,n=this.drawHeight;this.drawWidth=t,this.drawHeight=i,o&&s&&n?(this.panX=this.panX/s*t,this.panY=this.panY/n*i,this._clampPan()):(this.panX=t/2,this.panY=i/2)}_attach(){this.container.addEventListener("wheel",this._onWheel,{passive:!1}),this.container.addEventListener("dblclick",this._onDblClick),typeof GestureEvent<"u"&&(this.container.addEventListener("gesturestart",this._onGestureStart),this.container.addEventListener("gesturechange",this._onGestureChange),this.container.addEventListener("gestureend",this._onGestureEnd))}destroy(){this.container.removeEventListener("wheel",this._onWheel),this.container.removeEventListener("dblclick",this._onDblClick),this._stopPanListeners(),typeof GestureEvent<"u"&&(this.container.removeEventListener("gesturestart",this._onGestureStart),this.container.removeEventListener("gesturechange",this._onGestureChange),this.container.removeEventListener("gestureend",this._onGestureEnd))}zoomIn(){this._applyZoom(this.zoom+this.zoomStep)}zoomOut(){this._applyZoom(this.zoom-this.zoomStep)}resetZoom(){this._applyZoom(W)}setZoom(t){this._applyZoom(t)}zoomTowardPoint(t,i,o){this._zoomTowardPoint(t,i,o)}getZoom(){return this.zoom}isZoomed(){return this.zoom>W}startPan(t,i){return this.zoom<=W?!1:(this.isPanning=!0,this.panStartX=t,this.panStartY=i,document.addEventListener("mousemove",this._onMouseMove),document.addEventListener("mouseup",this._onMouseUp),!0)}_stopPanListeners(){document.removeEventListener("mousemove",this._onMouseMove),document.removeEventListener("mouseup",this._onMouseUp)}_onMouseMove(t){if(!this.isPanning)return;const i=t.pageX-this.panStartX,o=t.pageY-this.panStartY;this.panStartX=t.pageX,this.panStartY=t.pageY,this._applyPan(this.panX-i,this.panY-o)}_onMouseUp(){this.isPanning=!1,this._stopPanListeners()}_onWheel(t){if(!t.ctrlKey&&!t.metaKey)return;t.preventDefault();const i=t.deltaY>0?-1:1,o=this.zoom+i*this.zoomStep;this._zoomTowardPoint(o,t.clientX,t.clientY)}_onDblClick(t){t.target&&t.target.closest&&(t.target.closest(".cloudimage-360-button")||t.target.closest(".cloudimage-360-hotspot-timeline")||t.target.closest(".cloudimage-360-hotspot")||t.target.closest(".cloudimage-360-zoom-controls"))||(this.zoom>W?this._applyZoom(W):this._zoomTowardPoint(2,t.clientX,t.clientY))}_onGestureStart(t){t.preventDefault(),this._gestureBaseZoom=this.zoom}_onGestureChange(t){t.preventDefault();const i=this._gestureBaseZoom*t.scale;this._zoomTowardPoint(i,t.clientX,t.clientY)}_onGestureEnd(t){t.preventDefault()}handleKeyZoom(t){return t===187||t===107?(this.zoomIn(),!0):t===189||t===109?(this.zoomOut(),!0):t===48||t===96?(this.resetZoom(),!0):!1}handleKeyPan(t,i=50){if(this.zoom<=W)return!1;let o=0,s=0;switch(t){case 37:o=-i;break;case 39:o=i;break;case 38:s=-i;break;case 40:s=i;break;default:return!1}return this._applyPan(this.panX+o,this.panY+s),!0}applyTouchPan(t,i){this.zoom<=W||this._applyPan(this.panX-t,this.panY-i)}applyTouchZoom(t){this._applyZoom(t)}_zoomTowardPoint(t,i,o){var r;const s=Math.max(W,Math.min(t,this.zoomMax));if(s===this.zoom)return;const n=(r=this.container.querySelector("canvas"))==null?void 0:r.getBoundingClientRect();if(n){const l=(i-n.left)/n.width*this.drawWidth,a=(o-n.top)/n.height*this.drawHeight,c=s/this.zoom;this.panX=l+(this.panX-l)*c,this.panY=a+(this.panY-a)*c}this.zoom=s,this._clampPan(),this._emit()}_applyZoom(t){const i=Math.max(W,Math.min(t,this.zoomMax));i!==this.zoom&&(this.zoom=i,this.zoom<=W&&(this.panX=this.drawWidth/2,this.panY=this.drawHeight/2),this._clampPan(),this._emit())}_applyPan(t,i){this.panX=t,this.panY=i,this._clampPan(),this._emit()}_clampPan(){if(this.zoom<=W||!this.drawWidth||!this.drawHeight)return;const t=this.drawWidth/(2*this.zoom),i=this.drawHeight/(2*this.zoom);this.panX=Math.max(t,Math.min(this.panX,this.drawWidth-t)),this.panY=Math.max(i,Math.min(this.panY,this.drawHeight-i))}_emit(){typeof this.onZoomChange=="function"&&this.onZoomChange(this.zoom,this.panX,this.panY)}}class qo{constructor(t,{onPinchZoom:i,onPan:o,onDoubleTap:s,getZoom:n,zoomMax:r=5}={}){this.container=t,this.onPinchZoom=i,this.onPan=o,this.onDoubleTap=s,this.getZoom=n,this.zoomMax=r,this.isPinching=!1,this.initialPinchDistance=0,this.pinchBaseZoom=1,this.lastTouchX=0,this.lastTouchY=0,this.lastTapTime=0,this.lastTapX=0,this.lastTapY=0,this._onTouchStart=this._onTouchStart.bind(this),this._onTouchMove=this._onTouchMove.bind(this),this._onTouchEnd=this._onTouchEnd.bind(this),this._attach()}_attach(){this.container.addEventListener("touchstart",this._onTouchStart,{passive:!1}),this.container.addEventListener("touchmove",this._onTouchMove,{passive:!1}),this.container.addEventListener("touchend",this._onTouchEnd,{passive:!1})}destroy(){this.container.removeEventListener("touchstart",this._onTouchStart),this.container.removeEventListener("touchmove",this._onTouchMove),this.container.removeEventListener("touchend",this._onTouchEnd)}_getPinchDistance(t,i){const o=t.pageX-i.pageX,s=t.pageY-i.pageY;return Math.sqrt(o*o+s*s)}_onTouchStart(t){if(t.touches){if(t.touches.length===2){t.preventDefault(),this.isPinching=!0,this.initialPinchDistance=this._getPinchDistance(t.touches[0],t.touches[1]),this.pinchBaseZoom=typeof this.getZoom=="function"?this.getZoom():1;return}if(t.touches.length===1){const i=t.touches[0];this.lastTouchX=i.pageX,this.lastTouchY=i.pageY;const o=Date.now(),s=o-this.lastTapTime,n=Math.abs(i.pageX-this.lastTapX),r=Math.abs(i.pageY-this.lastTapY);if(s<300&&n<30&&r<30){t.preventDefault(),t.stopPropagation(),this.lastTapTime=0,typeof this.onDoubleTap=="function"&&this.onDoubleTap(i.clientX,i.clientY);return}this.lastTapTime=o,this.lastTapX=i.pageX,this.lastTapY=i.pageY}}}_onTouchMove(t){if(t.touches){if(this.isPinching&&t.touches.length===2){t.preventDefault();const i=this._getPinchDistance(t.touches[0],t.touches[1]);if(this.initialPinchDistance===0){this.initialPinchDistance=i;return}const o=i/this.initialPinchDistance,s=Math.max(1,Math.min(this.pinchBaseZoom*o,this.zoomMax)),n=(t.touches[0].clientX+t.touches[1].clientX)/2,r=(t.touches[0].clientY+t.touches[1].clientY)/2;typeof this.onPinchZoom=="function"&&this.onPinchZoom(s,n,r);return}if(t.touches.length===1){if((typeof this.getZoom=="function"?this.getZoom():1)<=1)return;t.preventDefault();const o=t.touches[0],s=o.pageX-this.lastTouchX,n=o.pageY-this.lastTouchY;this.lastTouchX=o.pageX,this.lastTouchY=o.pageY,typeof this.onPan=="function"&&this.onPan(s,n)}}}_onTouchEnd(t){this.isPinching&&(!t.touches||t.touches.length<2)&&(this.isPinching=!1,this.initialPinchDistance=0,t.touches&&t.touches.length===1&&(this.lastTouchX=t.touches[0].pageX,this.lastTouchY=t.touches[0].pageY))}}const Jo='<svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" aria-hidden="true"><circle cx="11" cy="11" r="8"/><line x1="21" x2="16.65" y1="21" y2="16.65"/><line x1="11" x2="11" y1="8" y2="14"/><line x1="8" x2="14" y1="11" y2="11"/></svg>',Qo='<svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" aria-hidden="true"><circle cx="11" cy="11" r="8"/><line x1="21" x2="16.65" y1="21" y2="16.65"/><line x1="8" x2="14" y1="11" y2="11"/></svg>',ts='<svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" aria-hidden="true"><path d="M3 12a9 9 0 1 0 9-9 9.75 9.75 0 0 0-6.74 2.74L3 8"/><path d="M3 3v5h5"/></svg>',es=(e,{position:t="bottom-right",onZoomIn:i,onZoomOut:o,onReset:s,zoomMax:n=5}={})=>{const r=document.createElement("div");r.className="cloudimage-360-zoom-controls",r.setAttribute("data-position",t),r.setAttribute("role","toolbar"),r.setAttribute("aria-label","Zoom controls");const l=document.createElement("button");l.className="cloudimage-360-zoom-btn cloudimage-360-zoom-btn-in",l.setAttribute("aria-label","Zoom in"),l.innerHTML=Jo,l.addEventListener("click",h=>{h.stopPropagation(),typeof i=="function"&&i()});const a=document.createElement("button");a.className="cloudimage-360-zoom-btn cloudimage-360-zoom-btn-out",a.setAttribute("aria-label","Zoom out"),a.innerHTML=Qo,a.disabled=!0,a.addEventListener("click",h=>{h.stopPropagation(),typeof o=="function"&&o()});const c=document.createElement("button");return c.className="cloudimage-360-zoom-btn cloudimage-360-zoom-btn-reset",c.setAttribute("aria-label","Reset zoom"),c.innerHTML=ts,c.disabled=!0,c.addEventListener("click",h=>{h.stopPropagation(),typeof s=="function"&&s()}),r.appendChild(l),r.appendChild(a),r.appendChild(c),e.appendChild(r),{element:r,updateState(h){l.disabled=h>=n,a.disabled=h<=1,c.disabled=h<=1},show(){r.classList.add("visible")},hide(){r.classList.remove("visible")},destroy(){r.parentNode&&r.parentNode.removeChild(r)}}},ei="KGZ1bmN0aW9uKCl7InVzZSBzdHJpY3QiO2NvbnN0IHY9KHQsYSxlKT0+e2NvbnN0IHM9dC9lLG49YS9lO3JldHVybnt6b29tZWRXaWR0aDpzLHpvb21lZEhlaWdodDpufX0sej0oe3BvaW50ZXJYOnQscG9pbnRlclk6YSxpbWFnZURhdGE6ZSx6b29tZWRXaWR0aDpzLHpvb21lZEhlaWdodDpuLGRyYXdXaWR0aDppLGRyYXdIZWlnaHQ6Y30pPT57Y29uc3R7bmF0dXJhbFdpZHRoOmcsbmF0dXJhbEhlaWdodDp1fT1lO2xldCBmPXQvaSpnLXMvMixtPWEvYyp1LW4vMjtjb25zdCB4PU1hdGgubWF4KDAsZy1zKSxPPU1hdGgubWF4KDAsdS1uKTtyZXR1cm4gZj1NYXRoLm1heCgwLE1hdGgubWluKGYseCkpLG09TWF0aC5tYXgoMCxNYXRoLm1pbihtLE8pKSx7em9vbU9mZnNldFg6Zix6b29tT2Zmc2V0WTptfX07bGV0IG8saCxyLGQsbCx3O3NlbGYub25tZXNzYWdlPWFzeW5jIHQ9Pntjb25zdHthY3Rpb246YSxvZmZzY3JlZW46ZSxkZXZpY2VQaXhlbFJhdGlvOnMsaW1hZ2VEYXRhOm4sem9vbVNjYWxlOmkscG9pbnRlclg6Yyxwb2ludGVyWTpnLGltYWdlQXNwZWN0UmF0aW86dSxjb250YWluZXJXaWR0aDpmLGNvbnRhaW5lckhlaWdodDptfT10LmRhdGE7c3dpdGNoKGEpe2Nhc2UiaW5pdENhbnZhcyI6QyhlLHMpO2JyZWFrO2Nhc2UiYWRhcHRDYW52YXNTaXplIjpwKHUsZixtKTticmVhaztjYXNlImRyYXdJbWFnZU9uQ2FudmFzIjpJKG4saSxjLGcpO2JyZWFrfX07Y29uc3QgQz0odCxhKT0+e289dCxoPW8uZ2V0Q29udGV4dCgiMmQiKSxyPWF9LHA9KHQsYSxlKT0+e2NvbnN0IHM9YS9lO3c9dD5zLG8ud2lkdGg9YSpyLG8uaGVpZ2h0PWUqcixoLnNjYWxlKHIsciksdz8oZD1hLGw9YS90KToobD1lLGQ9ZSp0KSxoLmltYWdlU21vb3RoaW5nRW5hYmxlZD0hMCxoLmltYWdlU21vb3RoaW5nUXVhbGl0eT0iaGlnaCJ9LEk9KHQ9e30sYT0xLGU9MCxzPTApPT57Y29uc3R7Yml0bWFwSW1hZ2U6bn09dDtpZighb3x8IW4pcmV0dXJuO2xldCBpLGM7aWYodz8oaT0wLGM9KG8uaGVpZ2h0L3ItbCkvMik6KGk9KG8ud2lkdGgvci1kKS8yLGM9MCksaC5jbGVhclJlY3QoMCwwLG8ud2lkdGgsby5oZWlnaHQpLGEhPT0xKXtjb25zdHtuYXR1cmFsV2lkdGg6ZyxuYXR1cmFsSGVpZ2h0OnV9PXQse3pvb21lZFdpZHRoOmYsem9vbWVkSGVpZ2h0Om19PXYoZyx1LGEpLHt6b29tT2Zmc2V0WDp4LHpvb21PZmZzZXRZOk99PXooe3BvaW50ZXJYOmUscG9pbnRlclk6cyxpbWFnZURhdGE6dCx6b29tZWRXaWR0aDpmLHpvb21lZEhlaWdodDptLGRyYXdXaWR0aDpkLGRyYXdIZWlnaHQ6bH0pO2guZHJhd0ltYWdlKG4seCxPLGYsbSxpLGMsZCxsKX1lbHNlIGguZHJhd0ltYWdlKG4saSxjLGQsbCl9fSkoKTsKLy8jIHNvdXJjZU1hcHBpbmdVUkw9Y2FudmFzLndvcmtlci1DZzBma3BEMS5qcy5tYXAK",is=e=>Uint8Array.from(atob(e),t=>t.charCodeAt(0)),Re=typeof self<"u"&&self.Blob&&new Blob([is(ei)],{type:"text/javascript;charset=utf-8"});function os(e){let t;try{if(t=Re&&(self.URL||self.webkitURL).createObjectURL(Re),!t)throw"";const i=new Worker(t,{name:e==null?void 0:e.name});return i.addEventListener("error",()=>{(self.URL||self.webkitURL).revokeObjectURL(t)}),i}catch{return new Worker("data:text/javascript;base64,"+ei,{name:e==null?void 0:e.name})}finally{t&&(self.URL||self.webkitURL).revokeObjectURL(t)}}class ss{constructor(){this.canvas=null,this.ctx=null,this.dpr=1,this.drawWidth=0,this.drawHeight=0,this.wideImage=!1}postMessage(t){const{action:i,offscreen:o,devicePixelRatio:s,imageData:n,zoomScale:r,pointerX:l,pointerY:a,imageAspectRatio:c,containerWidth:h,containerHeight:u}=t;switch(i){case"initCanvas":this.initCanvas(o,s);break;case"adaptCanvasSize":this.adaptCanvasSize(c,h,u);break;case"drawImageOnCanvas":this.drawImageOnCanvas(n,r,l,a);break}}terminate(){var t,i;this.ctx&&this.ctx.clearRect(0,0,((t=this.canvas)==null?void 0:t.width)||0,((i=this.canvas)==null?void 0:i.height)||0),this.canvas=null,this.ctx=null}initCanvas(t,i){this.canvas=t,this.ctx=t.getContext("2d"),this.dpr=i}adaptCanvasSize(t,i,o){if(!this.canvas||!this.ctx)return;const s=i/o;this.wideImage=t>s,this.canvas.width=i*this.dpr,this.canvas.height=o*this.dpr,this.ctx.scale(this.dpr,this.dpr),this.wideImage?(this.drawWidth=i,this.drawHeight=i/t):(this.drawHeight=o,this.drawWidth=o*t),this.ctx.imageSmoothingEnabled=!0,this.ctx.imageSmoothingQuality="high"}drawImageOnCanvas(t={},i=1,o=0,s=0){const{bitmapImage:n}=t;if(!this.canvas||!this.ctx||!n)return;let r,l;if(this.wideImage?(r=0,l=(this.canvas.height/this.dpr-this.drawHeight)/2):(r=(this.canvas.width/this.dpr-this.drawWidth)/2,l=0),this.ctx.clearRect(0,0,this.canvas.width,this.canvas.height),i!==1){const{naturalWidth:a,naturalHeight:c}=t,{zoomedWidth:h,zoomedHeight:u}=Do(a,c,i),{zoomOffsetX:f,zoomOffsetY:m}=Bo({pointerX:o,pointerY:s,imageData:t,zoomedWidth:h,zoomedHeight:u,drawWidth:this.drawWidth,drawHeight:this.drawHeight});this.ctx.drawImage(n,f,m,h,u,r,l,this.drawWidth,this.drawHeight)}else this.ctx.drawImage(n,r,l,this.drawWidth,this.drawHeight)}}const ns=new Set(["p","span","div","br","hr","strong","em","b","i","u","s","h1","h2","h3","h4","h5","h6","ul","ol","li","a","img","button","table","thead","tbody","tr","th","td","blockquote","pre","code","label","input","select","option","textarea","svg","path","circle","rect","line","polyline","polygon","ellipse","g","text","tspan","defs","use","symbol","clippath","mask","lineargradient","radialgradient","stop"]),ze={a:["href","title","target","rel"],img:["src","alt","title","width","height"],button:["type","disabled","name","value"],input:["type","name","value","placeholder","disabled","readonly","checked","min","max","step"],select:["name","disabled","multiple"],option:["value","disabled","selected"],textarea:["name","placeholder","disabled","readonly","rows","cols"],label:["for"],svg:["viewbox","width","height","fill","stroke","xmlns","preserveaspectratio"],path:["d","fill","stroke","stroke-width","stroke-linecap","stroke-linejoin","transform"],circle:["cx","cy","r","fill","stroke","stroke-width"],rect:["x","y","width","height","rx","ry","fill","stroke","stroke-width"],line:["x1","y1","x2","y2","stroke","stroke-width"],polyline:["points","fill","stroke","stroke-width"],polygon:["points","fill","stroke","stroke-width"],ellipse:["cx","cy","rx","ry","fill","stroke","stroke-width"],g:["transform","fill","stroke"],text:["x","y","dx","dy","text-anchor","fill","font-size","font-family","font-weight"],tspan:["x","y","dx","dy"],use:["href","xlink:href","x","y","width","height"],lineargradient:["id","x1","y1","x2","y2","gradientunits"],radialgradient:["id","cx","cy","r","fx","fy","gradientunits"],stop:["offset","stop-color","stop-opacity"],clippath:["id"],mask:["id"],"*":["class","id","style"]},rs=[/javascript:/i,/vbscript:/i,/on\w+\s*=/i],as=e=>{if(typeof e!="string")return"";const t=document.createElement("template");t.innerHTML=e;const i=o=>{if(Array.from(o.childNodes).forEach(i),o.nodeType===Node.ELEMENT_NODE){const n=o.tagName.toLowerCase();if(!ns.has(n)){if(n==="script"||n==="style"){o.remove();return}const a=document.createTextNode(o.textContent);o.parentNode.replaceChild(a,o);return}const r=[...ze[n]||[],...ze["*"]||[]];if(Array.from(o.attributes).forEach(a=>{const c=a.name.toLowerCase();if(c.startsWith("on")){o.removeAttribute(a.name);return}if(!r.includes(c)){o.removeAttribute(a.name);return}let h=a.value;rs.forEach(u=>{u.test(h)&&o.removeAttribute(a.name)})}),n==="a"){const a=o.getAttribute("href");a&&(/^(https?:|mailto:|tel:|#|\/)/i.test(a.trim())||o.removeAttribute("href")),o.getAttribute("target")==="_blank"&&o.setAttribute("rel","noopener noreferrer")}if(n==="img"){const a=o.getAttribute("src");a&&(/^(https?:|\/|data:image\/)/i.test(a.trim())||o.removeAttribute("src"))}}};return i(t.content),t.innerHTML},ls=e=>e==="y"?L.Y:L.X,hs=(e,t,i)=>e.filter(o=>ls(o.orientation)===i&&t in o.positions),cs=(e,t,i)=>{const o=document.createElement("button");if(o.id=e,o.className="cloudimage-360-hotspot cloudimage-360-hotspot--pulse",o.dataset.hotspotId=e,o.setAttribute("type","button"),o.setAttribute("aria-label",t||`Hotspot ${e}`),o.setAttribute("aria-haspopup","true"),o.setAttribute("aria-expanded","false"),i==="dot-label"&&t){o.classList.add("cloudimage-360-hotspot--dot-label");const s=document.createElement("span");s.className="cloudimage-360-hotspot-label",s.textContent=t,o.appendChild(s)}return o},ds=e=>{const t=Object.entries(e).sort(([n],[r])=>Number(n)-Number(r));let i=null,o=null;const s={};for(const[n,r]of t)if(!r)s[n]={x:i,y:o};else{const{x:l,y:a}=r;l!=null&&(i=l),a!=null&&(o=a),s[n]={x:l??i,y:a??o}}return s},us=e=>({placement:"top",modifiers:[{name:"offset",options:{offset:[0,10]}},{name:"preventOverflow",options:{boundary:e}},{name:"flip",options:{boundary:e,fallbackPlacements:["bottom","right","left"]}}]}),ps=(e,t,i)=>{const o=document.createElement("div");return o.className="cloudimage-360-popper",o.id=`cloudimage-360-popper-${t}`,o.dataset.popperId=t,o.setAttribute("role","tooltip"),o.setAttribute("aria-hidden","false"),typeof e=="string"&&/<\/?[a-z][\s\S]*>/i.test(e)?o.innerHTML=as(e):o.textContent=e,(i||document.body).appendChild(o),o},ms=e=>e.map(t=>{const i={...ds(t.positions)};return{...t,initialPositions:i,positions:i}}),fs=({newWidth:e,newHeight:t,initialContainerSize:i,imageAspectRatio:o,hotspotsConfig:s})=>{const[n,r]=i;let l=e,a=t,c=0,h=0;const u=e/t;o>u?(a=e/o,h=(t-a)/2):(l=t*o,c=(e-l)/2);const m=l/n,x=a/r;return s.map(y=>{const b={};return Object.entries(y.initialPositions).forEach(([I,E])=>{b[I]={x:E.x*m+c,y:E.y*x+h}}),{...y,positions:b}})};function vs(e){const t=[];e.image&&t.push(`<div class="ci360-popper-image-wrapper"><img class="ci360-popper-image" src="${xt(e.image)}" alt="${xt(e.title||"")}"></div>`);const i=[];if(e.title&&i.push(`<h3 class="ci360-popper-title">${dt(e.title)}</h3>`),e.originalPrice||e.price){let o="";e.originalPrice&&(o+=`<span class="ci360-popper-original-price">${dt(e.originalPrice)}</span>`),e.price&&(o+=`<span class="ci360-popper-price">${dt(e.price)}</span>`),i.push(`<div class="ci360-popper-price-row">${o}</div>`)}if(e.description&&i.push(`<p class="ci360-popper-description">${dt(e.description)}</p>`),e.url&&gs(e.url)){const o=e.ctaText||"View details",s=e.id?` data-product-id="${xt(e.id)}"`:"";i.push(`<a class="ci360-popper-cta" href="${xt(e.url)}"${s}>${dt(String(o))}</a>`)}else if(e.id){const o=e.ctaText||"View details";i.push(`<button class="ci360-popper-cta" data-product-id="${xt(e.id)}">${dt(String(o))}</button>`)}return i.length>0&&t.push(`<div class="ci360-popper-body">${i.join("")}</div>`),t.join("")}function Ze(e){return e.content?e.content:e.data?vs(e.data):""}function dt(e){return e.replace(/&/g,"&amp;").replace(/</g,"&lt;").replace(/>/g,"&gt;").replace(/"/g,"&quot;")}function xt(e){return e.replace(/&/g,"&amp;").replace(/"/g,"&quot;").replace(/'/g,"&#39;").replace(/</g,"&lt;").replace(/>/g,"&gt;")}function gs(e){const t=e.replace(/[\s\x00-\x1f]/g,"");return/^https?:\/\//i.test(t)||/^\/(?!\/)/.test(t)||/^#/.test(t)}var R="top",_="bottom",F="right",z="left",ne="auto",At=[R,_,F,z],ut="start",Tt="end",ys="clippingParents",ii="viewport",It="popper",bs="reference",De=At.reduce(function(e,t){return e.concat([t+"-"+ut,t+"-"+Tt])},[]),oi=[].concat(At,[ne]).reduce(function(e,t){return e.concat([t,t+"-"+ut,t+"-"+Tt])},[]),ws="beforeRead",Cs="read",xs="afterRead",Is="beforeMain",Ps="main",Es="afterMain",Ss="beforeWrite",Ts="write",ks="afterWrite",As=[ws,Cs,xs,Is,Ps,Es,Ss,Ts,ks];function j(e){return e?(e.nodeName||"").toLowerCase():null}function D(e){if(e==null)return window;if(e.toString()!=="[object Window]"){var t=e.ownerDocument;return t&&t.defaultView||window}return e}function st(e){var t=D(e).Element;return e instanceof t||e instanceof Element}function B(e){var t=D(e).HTMLElement;return e instanceof t||e instanceof HTMLElement}function re(e){if(typeof ShadowRoot>"u")return!1;var t=D(e).ShadowRoot;return e instanceof t||e instanceof ShadowRoot}function Os(e){var t=e.state;Object.keys(t.elements).forEach(function(i){var o=t.styles[i]||{},s=t.attributes[i]||{},n=t.elements[i];!B(n)||!j(n)||(Object.assign(n.style,o),Object.keys(s).forEach(function(r){var l=s[r];l===!1?n.removeAttribute(r):n.setAttribute(r,l===!0?"":l)}))})}function Ls(e){var t=e.state,i={popper:{position:t.options.strategy,left:"0",top:"0",margin:"0"},arrow:{position:"absolute"},reference:{}};return Object.assign(t.elements.popper.style,i.popper),t.styles=i,t.elements.arrow&&Object.assign(t.elements.arrow.style,i.arrow),function(){Object.keys(t.elements).forEach(function(o){var s=t.elements[o],n=t.attributes[o]||{},r=Object.keys(t.styles.hasOwnProperty(o)?t.styles[o]:i[o]),l=r.reduce(function(a,c){return a[c]="",a},{});!B(s)||!j(s)||(Object.assign(s.style,l),Object.keys(n).forEach(function(a){s.removeAttribute(a)}))})}}const Ms={name:"applyStyles",enabled:!0,phase:"write",fn:Os,effect:Ls,requires:["computeStyles"]};function V(e){return e.split("-")[0]}var ot=Math.max,Vt=Math.min,pt=Math.round;function oe(){var e=navigator.userAgentData;return e!=null&&e.brands&&Array.isArray(e.brands)?e.brands.map(function(t){return t.brand+"/"+t.version}).join(" "):navigator.userAgent}function si(){return!/^((?!chrome|android).)*safari/i.test(oe())}function mt(e,t,i){t===void 0&&(t=!1),i===void 0&&(i=!1);var o=e.getBoundingClientRect(),s=1,n=1;t&&B(e)&&(s=e.offsetWidth>0&&pt(o.width)/e.offsetWidth||1,n=e.offsetHeight>0&&pt(o.height)/e.offsetHeight||1);var r=st(e)?D(e):window,l=r.visualViewport,a=!si()&&i,c=(o.left+(a&&l?l.offsetLeft:0))/s,h=(o.top+(a&&l?l.offsetTop:0))/n,u=o.width/s,f=o.height/n;return{width:u,height:f,top:h,right:c+u,bottom:h+f,left:c,x:c,y:h}}function ae(e){var t=mt(e),i=e.offsetWidth,o=e.offsetHeight;return Math.abs(t.width-i)<=1&&(i=t.width),Math.abs(t.height-o)<=1&&(o=t.height),{x:e.offsetLeft,y:e.offsetTop,width:i,height:o}}function ni(e,t){var i=t.getRootNode&&t.getRootNode();if(e.contains(t))return!0;if(i&&re(i)){var o=t;do{if(o&&e.isSameNode(o))return!0;o=o.parentNode||o.host}while(o)}return!1}function J(e){return D(e).getComputedStyle(e)}function Xs(e){return["table","td","th"].indexOf(j(e))>=0}function tt(e){return((st(e)?e.ownerDocument:e.document)||window.document).documentElement}function jt(e){return j(e)==="html"?e:e.assignedSlot||e.parentNode||(re(e)?e.host:null)||tt(e)}function Be(e){return!B(e)||J(e).position==="fixed"?null:e.offsetParent}function Ys(e){var t=/firefox/i.test(oe()),i=/Trident/i.test(oe());if(i&&B(e)){var o=J(e);if(o.position==="fixed")return null}var s=jt(e);for(re(s)&&(s=s.host);B(s)&&["html","body"].indexOf(j(s))<0;){var n=J(s);if(n.transform!=="none"||n.perspective!=="none"||n.contain==="paint"||["transform","perspective"].indexOf(n.willChange)!==-1||t&&n.willChange==="filter"||t&&n.filter&&n.filter!=="none")return s;s=s.parentNode}return null}function Ot(e){for(var t=D(e),i=Be(e);i&&Xs(i)&&J(i).position==="static";)i=Be(i);return i&&(j(i)==="html"||j(i)==="body"&&J(i).position==="static")?t:i||Ys(e)||t}function le(e){return["top","bottom"].indexOf(e)>=0?"x":"y"}function Et(e,t,i){return ot(e,Vt(t,i))}function Hs(e,t,i){var o=Et(e,t,i);return o>i?i:o}function ri(){return{top:0,right:0,bottom:0,left:0}}function ai(e){return Object.assign({},ri(),e)}function li(e,t){return t.reduce(function(i,o){return i[o]=e,i},{})}var Rs=function(t,i){return t=typeof t=="function"?t(Object.assign({},i.rects,{placement:i.placement})):t,ai(typeof t!="number"?t:li(t,At))};function zs(e){var t,i=e.state,o=e.name,s=e.options,n=i.elements.arrow,r=i.modifiersData.popperOffsets,l=V(i.placement),a=le(l),c=[z,F].indexOf(l)>=0,h=c?"height":"width";if(!(!n||!r)){var u=Rs(s.padding,i),f=ae(n),m=a==="y"?R:z,x=a==="y"?_:F,y=i.rects.reference[h]+i.rects.reference[a]-r[a]-i.rects.popper[h],b=r[a]-i.rects.reference[a],I=Ot(n),E=I?a==="y"?I.clientHeight||0:I.clientWidth||0:0,w=y/2-b/2,v=u[m],P=E-f[h]-u[x],p=E/2-f[h]/2+w,g=Et(v,p,P),C=a;i.modifiersData[o]=(t={},t[C]=g,t.centerOffset=g-p,t)}}function Zs(e){var t=e.state,i=e.options,o=i.element,s=o===void 0?"[data-popper-arrow]":o;s!=null&&(typeof s=="string"&&(s=t.elements.popper.querySelector(s),!s)||ni(t.elements.popper,s)&&(t.elements.arrow=s))}const Ds={name:"arrow",enabled:!0,phase:"main",fn:zs,effect:Zs,requires:["popperOffsets"],requiresIfExists:["preventOverflow"]};function ft(e){return e.split("-")[1]}var Bs={top:"auto",right:"auto",bottom:"auto",left:"auto"};function _s(e,t){var i=e.x,o=e.y,s=t.devicePixelRatio||1;return{x:pt(i*s)/s||0,y:pt(o*s)/s||0}}function _e(e){var t,i=e.popper,o=e.popperRect,s=e.placement,n=e.variation,r=e.offsets,l=e.position,a=e.gpuAcceleration,c=e.adaptive,h=e.roundOffsets,u=e.isFixed,f=r.x,m=f===void 0?0:f,x=r.y,y=x===void 0?0:x,b=typeof h=="function"?h({x:m,y}):{x:m,y};m=b.x,y=b.y;var I=r.hasOwnProperty("x"),E=r.hasOwnProperty("y"),w=z,v=R,P=window;if(c){var p=Ot(i),g="clientHeight",C="clientWidth";if(p===D(i)&&(p=tt(i),J(p).position!=="static"&&l==="absolute"&&(g="scrollHeight",C="scrollWidth")),p=p,s===R||(s===z||s===F)&&n===Tt){v=_;var S=u&&p===P&&P.visualViewport?P.visualViewport.height:p[g];y-=S-o.height,y*=a?1:-1}if(s===z||(s===R||s===_)&&n===Tt){w=F;var k=u&&p===P&&P.visualViewport?P.visualViewport.width:p[C];m-=k-o.width,m*=a?1:-1}}var A=Object.assign({position:l},c&&Bs),X=h===!0?_s({x:m,y},D(i)):{x:m,y};if(m=X.x,y=X.y,a){var O;return Object.assign({},A,(O={},O[v]=E?"0":"",O[w]=I?"0":"",O.transform=(P.devicePixelRatio||1)<=1?"translate("+m+"px, "+y+"px)":"translate3d("+m+"px, "+y+"px, 0)",O))}return Object.assign({},A,(t={},t[v]=E?y+"px":"",t[w]=I?m+"px":"",t.transform="",t))}function Fs(e){var t=e.state,i=e.options,o=i.gpuAcceleration,s=o===void 0?!0:o,n=i.adaptive,r=n===void 0?!0:n,l=i.roundOffsets,a=l===void 0?!0:l,c={placement:V(t.placement),variation:ft(t.placement),popper:t.elements.popper,popperRect:t.rects.popper,gpuAcceleration:s,isFixed:t.options.strategy==="fixed"};t.modifiersData.popperOffsets!=null&&(t.styles.popper=Object.assign({},t.styles.popper,_e(Object.assign({},c,{offsets:t.modifiersData.popperOffsets,position:t.options.strategy,adaptive:r,roundOffsets:a})))),t.modifiersData.arrow!=null&&(t.styles.arrow=Object.assign({},t.styles.arrow,_e(Object.assign({},c,{offsets:t.modifiersData.arrow,position:"absolute",adaptive:!1,roundOffsets:a})))),t.attributes.popper=Object.assign({},t.attributes.popper,{"data-popper-placement":t.placement})}const Ws={name:"computeStyles",enabled:!0,phase:"beforeWrite",fn:Fs,data:{}};var Ft={passive:!0};function Ns(e){var t=e.state,i=e.instance,o=e.options,s=o.scroll,n=s===void 0?!0:s,r=o.resize,l=r===void 0?!0:r,a=D(t.elements.popper),c=[].concat(t.scrollParents.reference,t.scrollParents.popper);return n&&c.forEach(function(h){h.addEventListener("scroll",i.update,Ft)}),l&&a.addEventListener("resize",i.update,Ft),function(){n&&c.forEach(function(h){h.removeEventListener("scroll",i.update,Ft)}),l&&a.removeEventListener("resize",i.update,Ft)}}const Vs={name:"eventListeners",enabled:!0,phase:"write",fn:function(){},effect:Ns,data:{}};var js={left:"right",right:"left",bottom:"top",top:"bottom"};function Wt(e){return e.replace(/left|right|bottom|top/g,function(t){return js[t]})}var Gs={start:"end",end:"start"};function Fe(e){return e.replace(/start|end/g,function(t){return Gs[t]})}function he(e){var t=D(e),i=t.pageXOffset,o=t.pageYOffset;return{scrollLeft:i,scrollTop:o}}function ce(e){return mt(tt(e)).left+he(e).scrollLeft}function Us(e,t){var i=D(e),o=tt(e),s=i.visualViewport,n=o.clientWidth,r=o.clientHeight,l=0,a=0;if(s){n=s.width,r=s.height;var c=si();(c||!c&&t==="fixed")&&(l=s.offsetLeft,a=s.offsetTop)}return{width:n,height:r,x:l+ce(e),y:a}}function $s(e){var t,i=tt(e),o=he(e),s=(t=e.ownerDocument)==null?void 0:t.body,n=ot(i.scrollWidth,i.clientWidth,s?s.scrollWidth:0,s?s.clientWidth:0),r=ot(i.scrollHeight,i.clientHeight,s?s.scrollHeight:0,s?s.clientHeight:0),l=-o.scrollLeft+ce(e),a=-o.scrollTop;return J(s||i).direction==="rtl"&&(l+=ot(i.clientWidth,s?s.clientWidth:0)-n),{width:n,height:r,x:l,y:a}}function de(e){var t=J(e),i=t.overflow,o=t.overflowX,s=t.overflowY;return/auto|scroll|overlay|hidden/.test(i+s+o)}function hi(e){return["html","body","#document"].indexOf(j(e))>=0?e.ownerDocument.body:B(e)&&de(e)?e:hi(jt(e))}function St(e,t){var i;t===void 0&&(t=[]);var o=hi(e),s=o===((i=e.ownerDocument)==null?void 0:i.body),n=D(o),r=s?[n].concat(n.visualViewport||[],de(o)?o:[]):o,l=t.concat(r);return s?l:l.concat(St(jt(r)))}function se(e){return Object.assign({},e,{left:e.x,top:e.y,right:e.x+e.width,bottom:e.y+e.height})}function Ks(e,t){var i=mt(e,!1,t==="fixed");return i.top=i.top+e.clientTop,i.left=i.left+e.clientLeft,i.bottom=i.top+e.clientHeight,i.right=i.left+e.clientWidth,i.width=e.clientWidth,i.height=e.clientHeight,i.x=i.left,i.y=i.top,i}function We(e,t,i){return t===ii?se(Us(e,i)):st(t)?Ks(t,i):se($s(tt(e)))}function qs(e){var t=St(jt(e)),i=["absolute","fixed"].indexOf(J(e).position)>=0,o=i&&B(e)?Ot(e):e;return st(o)?t.filter(function(s){return st(s)&&ni(s,o)&&j(s)!=="body"}):[]}function Js(e,t,i,o){var s=t==="clippingParents"?qs(e):[].concat(t),n=[].concat(s,[i]),r=n[0],l=n.reduce(function(a,c){var h=We(e,c,o);return a.top=ot(h.top,a.top),a.right=Vt(h.right,a.right),a.bottom=Vt(h.bottom,a.bottom),a.left=ot(h.left,a.left),a},We(e,r,o));return l.width=l.right-l.left,l.height=l.bottom-l.top,l.x=l.left,l.y=l.top,l}function ci(e){var t=e.reference,i=e.element,o=e.placement,s=o?V(o):null,n=o?ft(o):null,r=t.x+t.width/2-i.width/2,l=t.y+t.height/2-i.height/2,a;switch(s){case R:a={x:r,y:t.y-i.height};break;case _:a={x:r,y:t.y+t.height};break;case F:a={x:t.x+t.width,y:l};break;case z:a={x:t.x-i.width,y:l};break;default:a={x:t.x,y:t.y}}var c=s?le(s):null;if(c!=null){var h=c==="y"?"height":"width";switch(n){case ut:a[c]=a[c]-(t[h]/2-i[h]/2);break;case Tt:a[c]=a[c]+(t[h]/2-i[h]/2);break}}return a}function kt(e,t){t===void 0&&(t={});var i=t,o=i.placement,s=o===void 0?e.placement:o,n=i.strategy,r=n===void 0?e.strategy:n,l=i.boundary,a=l===void 0?ys:l,c=i.rootBoundary,h=c===void 0?ii:c,u=i.elementContext,f=u===void 0?It:u,m=i.altBoundary,x=m===void 0?!1:m,y=i.padding,b=y===void 0?0:y,I=ai(typeof b!="number"?b:li(b,At)),E=f===It?bs:It,w=e.rects.popper,v=e.elements[x?E:f],P=Js(st(v)?v:v.contextElement||tt(e.elements.popper),a,h,r),p=mt(e.elements.reference),g=ci({reference:p,element:w,placement:s}),C=se(Object.assign({},w,g)),S=f===It?C:p,k={top:P.top-S.top+I.top,bottom:S.bottom-P.bottom+I.bottom,left:P.left-S.left+I.left,right:S.right-P.right+I.right},A=e.modifiersData.offset;if(f===It&&A){var X=A[s];Object.keys(k).forEach(function(O){var G=[F,_].indexOf(O)>=0?1:-1,U=[R,_].indexOf(O)>=0?"y":"x";k[O]+=X[U]*G})}return k}function Qs(e,t){t===void 0&&(t={});var i=t,o=i.placement,s=i.boundary,n=i.rootBoundary,r=i.padding,l=i.flipVariations,a=i.allowedAutoPlacements,c=a===void 0?oi:a,h=ft(o),u=h?l?De:De.filter(function(x){return ft(x)===h}):At,f=u.filter(function(x){return c.indexOf(x)>=0});f.length===0&&(f=u);var m=f.reduce(function(x,y){return x[y]=kt(e,{placement:y,boundary:s,rootBoundary:n,padding:r})[V(y)],x},{});return Object.keys(m).sort(function(x,y){return m[x]-m[y]})}function tn(e){if(V(e)===ne)return[];var t=Wt(e);return[Fe(e),t,Fe(t)]}function en(e){var t=e.state,i=e.options,o=e.name;if(!t.modifiersData[o]._skip){for(var s=i.mainAxis,n=s===void 0?!0:s,r=i.altAxis,l=r===void 0?!0:r,a=i.fallbackPlacements,c=i.padding,h=i.boundary,u=i.rootBoundary,f=i.altBoundary,m=i.flipVariations,x=m===void 0?!0:m,y=i.allowedAutoPlacements,b=t.options.placement,I=V(b),E=I===b,w=a||(E||!x?[Wt(b)]:tn(b)),v=[b].concat(w).reduce(function(Q,N){return Q.concat(V(N)===ne?Qs(t,{placement:N,boundary:h,rootBoundary:u,padding:c,flipVariations:x,allowedAutoPlacements:y}):N)},[]),P=t.rects.reference,p=t.rects.popper,g=new Map,C=!0,S=v[0],k=0;k<v.length;k++){var A=v[k],X=V(A),O=ft(A)===ut,G=[R,_].indexOf(X)>=0,U=G?"width":"height",Y=kt(t,{placement:A,boundary:h,rootBoundary:u,altBoundary:f,padding:c}),Z=G?O?F:z:O?_:R;P[U]>p[U]&&(Z=Wt(Z));var nt=Wt(Z),$=[];if(n&&$.push(Y[X]<=0),l&&$.push(Y[Z]<=0,Y[nt]<=0),$.every(function(Q){return Q})){S=A,C=!1;break}g.set(A,$)}if(C)for(var rt=x?3:1,vt=function(N){var it=v.find(function(lt){var K=g.get(lt);if(K)return K.slice(0,N).every(function(gt){return gt})});if(it)return S=it,"break"},et=rt;et>0;et--){var at=vt(et);if(at==="break")break}t.placement!==S&&(t.modifiersData[o]._skip=!0,t.placement=S,t.reset=!0)}}const on={name:"flip",enabled:!0,phase:"main",fn:en,requiresIfExists:["offset"],data:{_skip:!1}};function Ne(e,t,i){return i===void 0&&(i={x:0,y:0}),{top:e.top-t.height-i.y,right:e.right-t.width+i.x,bottom:e.bottom-t.height+i.y,left:e.left-t.width-i.x}}function Ve(e){return[R,F,_,z].some(function(t){return e[t]>=0})}function sn(e){var t=e.state,i=e.name,o=t.rects.reference,s=t.rects.popper,n=t.modifiersData.preventOverflow,r=kt(t,{elementContext:"reference"}),l=kt(t,{altBoundary:!0}),a=Ne(r,o),c=Ne(l,s,n),h=Ve(a),u=Ve(c);t.modifiersData[i]={referenceClippingOffsets:a,popperEscapeOffsets:c,isReferenceHidden:h,hasPopperEscaped:u},t.attributes.popper=Object.assign({},t.attributes.popper,{"data-popper-reference-hidden":h,"data-popper-escaped":u})}const nn={name:"hide",enabled:!0,phase:"main",requiresIfExists:["preventOverflow"],fn:sn};function rn(e,t,i){var o=V(e),s=[z,R].indexOf(o)>=0?-1:1,n=typeof i=="function"?i(Object.assign({},t,{placement:e})):i,r=n[0],l=n[1];return r=r||0,l=(l||0)*s,[z,F].indexOf(o)>=0?{x:l,y:r}:{x:r,y:l}}function an(e){var t=e.state,i=e.options,o=e.name,s=i.offset,n=s===void 0?[0,0]:s,r=oi.reduce(function(h,u){return h[u]=rn(u,t.rects,n),h},{}),l=r[t.placement],a=l.x,c=l.y;t.modifiersData.popperOffsets!=null&&(t.modifiersData.popperOffsets.x+=a,t.modifiersData.popperOffsets.y+=c),t.modifiersData[o]=r}const ln={name:"offset",enabled:!0,phase:"main",requires:["popperOffsets"],fn:an};function hn(e){var t=e.state,i=e.name;t.modifiersData[i]=ci({reference:t.rects.reference,element:t.rects.popper,placement:t.placement})}const cn={name:"popperOffsets",enabled:!0,phase:"read",fn:hn,data:{}};function dn(e){return e==="x"?"y":"x"}function un(e){var t=e.state,i=e.options,o=e.name,s=i.mainAxis,n=s===void 0?!0:s,r=i.altAxis,l=r===void 0?!1:r,a=i.boundary,c=i.rootBoundary,h=i.altBoundary,u=i.padding,f=i.tether,m=f===void 0?!0:f,x=i.tetherOffset,y=x===void 0?0:x,b=kt(t,{boundary:a,rootBoundary:c,padding:u,altBoundary:h}),I=V(t.placement),E=ft(t.placement),w=!E,v=le(I),P=dn(v),p=t.modifiersData.popperOffsets,g=t.rects.reference,C=t.rects.popper,S=typeof y=="function"?y(Object.assign({},t.rects,{placement:t.placement})):y,k=typeof S=="number"?{mainAxis:S,altAxis:S}:Object.assign({mainAxis:0,altAxis:0},S),A=t.modifiersData.offset?t.modifiersData.offset[t.placement]:null,X={x:0,y:0};if(p){if(n){var O,G=v==="y"?R:z,U=v==="y"?_:F,Y=v==="y"?"height":"width",Z=p[v],nt=Z+b[G],$=Z-b[U],rt=m?-C[Y]/2:0,vt=E===ut?g[Y]:C[Y],et=E===ut?-C[Y]:-g[Y],at=t.elements.arrow,Q=m&&at?ae(at):{width:0,height:0},N=t.modifiersData["arrow#persistent"]?t.modifiersData["arrow#persistent"].padding:ri(),it=N[G],lt=N[U],K=Et(0,g[Y],Q[Y]),gt=w?g[Y]/2-rt-K-it-k.mainAxis:vt-K-it-k.mainAxis,Gt=w?-g[Y]/2+rt+K+lt+k.mainAxis:et+K+lt+k.mainAxis,yt=t.elements.arrow&&Ot(t.elements.arrow),Ut=yt?v==="y"?yt.clientTop||0:yt.clientLeft||0:0,bt=(O=A==null?void 0:A[v])!=null?O:0,Lt=Z+gt-bt-Ut,Mt=Z+Gt-bt,Xt=Et(m?Vt(nt,Lt):nt,Z,m?ot($,Mt):$);p[v]=Xt,X[v]=Xt-Z}if(l){var Yt,$t=v==="x"?R:z,Kt=v==="x"?_:F,q=p[P],ht=P==="y"?"height":"width",Ht=q+b[$t],Rt=q-b[Kt],wt=[R,z].indexOf(I)!==-1,zt=(Yt=A==null?void 0:A[P])!=null?Yt:0,Zt=wt?Ht:q-g[ht]-C[ht]-zt+k.altAxis,Dt=wt?q+g[ht]+C[ht]-zt-k.altAxis:Rt,Bt=m&&wt?Hs(Zt,q,Dt):Et(m?Zt:Ht,q,m?Dt:Rt);p[P]=Bt,X[P]=Bt-q}t.modifiersData[o]=X}}const pn={name:"preventOverflow",enabled:!0,phase:"main",fn:un,requiresIfExists:["offset"]};function mn(e){return{scrollLeft:e.scrollLeft,scrollTop:e.scrollTop}}function fn(e){return e===D(e)||!B(e)?he(e):mn(e)}function vn(e){var t=e.getBoundingClientRect(),i=pt(t.width)/e.offsetWidth||1,o=pt(t.height)/e.offsetHeight||1;return i!==1||o!==1}function gn(e,t,i){i===void 0&&(i=!1);var o=B(t),s=B(t)&&vn(t),n=tt(t),r=mt(e,s,i),l={scrollLeft:0,scrollTop:0},a={x:0,y:0};return(o||!o&&!i)&&((j(t)!=="body"||de(n))&&(l=fn(t)),B(t)?(a=mt(t,!0),a.x+=t.clientLeft,a.y+=t.clientTop):n&&(a.x=ce(n))),{x:r.left+l.scrollLeft-a.x,y:r.top+l.scrollTop-a.y,width:r.width,height:r.height}}function yn(e){var t=new Map,i=new Set,o=[];e.forEach(function(n){t.set(n.name,n)});function s(n){i.add(n.name);var r=[].concat(n.requires||[],n.requiresIfExists||[]);r.forEach(function(l){if(!i.has(l)){var a=t.get(l);a&&s(a)}}),o.push(n)}return e.forEach(function(n){i.has(n.name)||s(n)}),o}function bn(e){var t=yn(e);return As.reduce(function(i,o){return i.concat(t.filter(function(s){return s.phase===o}))},[])}function wn(e){var t;return function(){return t||(t=new Promise(function(i){Promise.resolve().then(function(){t=void 0,i(e())})})),t}}function Cn(e){var t=e.reduce(function(i,o){var s=i[o.name];return i[o.name]=s?Object.assign({},s,o,{options:Object.assign({},s.options,o.options),data:Object.assign({},s.data,o.data)}):o,i},{});return Object.keys(t).map(function(i){return t[i]})}var je={placement:"bottom",modifiers:[],strategy:"absolute"};function Ge(){for(var e=arguments.length,t=new Array(e),i=0;i<e;i++)t[i]=arguments[i];return!t.some(function(o){return!(o&&typeof o.getBoundingClientRect=="function")})}function xn(e){e===void 0&&(e={});var t=e,i=t.defaultModifiers,o=i===void 0?[]:i,s=t.defaultOptions,n=s===void 0?je:s;return function(l,a,c){c===void 0&&(c=n);var h={placement:"bottom",orderedModifiers:[],options:Object.assign({},je,n),modifiersData:{},elements:{reference:l,popper:a},attributes:{},styles:{}},u=[],f=!1,m={state:h,setOptions:function(I){var E=typeof I=="function"?I(h.options):I;y(),h.options=Object.assign({},n,h.options,E),h.scrollParents={reference:st(l)?St(l):l.contextElement?St(l.contextElement):[],popper:St(a)};var w=bn(Cn([].concat(o,h.options.modifiers)));return h.orderedModifiers=w.filter(function(v){return v.enabled}),x(),m.update()},forceUpdate:function(){if(!f){var I=h.elements,E=I.reference,w=I.popper;if(Ge(E,w)){h.rects={reference:gn(E,Ot(w),h.options.strategy==="fixed"),popper:ae(w)},h.reset=!1,h.placement=h.options.placement,h.orderedModifiers.forEach(function(k){return h.modifiersData[k.name]=Object.assign({},k.data)});for(var v=0;v<h.orderedModifiers.length;v++){if(h.reset===!0){h.reset=!1,v=-1;continue}var P=h.orderedModifiers[v],p=P.fn,g=P.options,C=g===void 0?{}:g,S=P.name;typeof p=="function"&&(h=p({state:h,options:C,name:S,instance:m})||h)}}}},update:wn(function(){return new Promise(function(b){m.forceUpdate(),b(h)})}),destroy:function(){y(),f=!0}};if(!Ge(l,a))return m;m.setOptions(c).then(function(b){!f&&c.onFirstUpdate&&c.onFirstUpdate(b)});function x(){h.orderedModifiers.forEach(function(b){var I=b.name,E=b.options,w=E===void 0?{}:E,v=b.effect;if(typeof v=="function"){var P=v({state:h,name:I,instance:m,options:w}),p=function(){};u.push(P||p)}})}function y(){u.forEach(function(b){return b()}),u=[]}return m}}var In=[Vs,cn,Ws,Ms,ln,on,pn,Ds,nn],Pn=xn({defaultModifiers:In});class En{constructor(t,i,o,s={}){ge(this,"updateHotspotPosition",(t,i)=>{this.currentActiveIndex=t,this.currentOrientation=i;const o=hs(this.hotspotsConfig,t,i);this.hideHotspots(),o.forEach(s=>this.updateAndShowHotspot(s,t))});this.container=i,this.popper=null,this.popperInstance=null,this.hotspotsContainer=bo(this.container),this.hotspotsConfig=ms(t),this.shouldHidePopper=!0,this.hidePopper=this.hidePopper.bind(this),this.forceHidePopper=this.forceHidePopper.bind(this),this.imageAspectRatio=o,this.popperListeners=[],this.trigger=s.trigger||"hover",this.onOpen=s.onOpen||null,this.onClose=s.onClose||null,this.onProductClick=s.onProductClick||null;const{containerSize:n}=t[0];this.initialContainerSize=n||[i.offsetWidth,i.offsetHeight],this.initHotspots(),this.updateHotspotsForResize(i.offsetWidth,i.offsetHeight),this.observeContainerResize()}observeContainerResize(){this.resizeObserver=new ResizeObserver(()=>{const t=this.container.offsetWidth,i=this.container.offsetHeight;this.updateHotspotsForResize(t,i)}),this.resizeObserver.observe(this.container)}updateHotspotsForResize(t,i){this.hotspotsConfig=fs({newWidth:t,newHeight:i,initialContainerSize:this.initialContainerSize,imageAspectRatio:this.imageAspectRatio,hotspotsConfig:this.hotspotsConfig}),this.updateHotspotPosition(this.currentActiveIndex,this.currentOrientation)}cleanupPopperListeners(){this.popperListeners.forEach(({element:t,event:i,handler:o})=>{t.removeEventListener(i,o)}),this.popperListeners=[]}showPopper({hotspotElement:t,content:i,id:o,keepOpen:s}){var u;this.popperInstance&&this.hidePopper();const n=us(this.container);this.popper=ps(i,o,this.container.parentElement),this.currentHotspotElement=t,t.setAttribute("aria-expanded","true"),t.setAttribute("aria-describedby",`cloudimage-360-popper-${o}`);const r=()=>{this.shouldHidePopper=!1},l=()=>{this.shouldHidePopper=!0,this.checkAndHidePopper()},a=()=>{this.shouldHidePopper=!0,this.checkAndHidePopper()},c=()=>{this.shouldHidePopper=!1,this.hidePopperTimeout&&clearTimeout(this.hidePopperTimeout)};if(this.popper.addEventListener("mouseenter",r),this.popper.addEventListener("mouseleave",l),t.addEventListener("mouseleave",a),t.addEventListener("mouseenter",c),this.popperListeners.push({element:this.popper,event:"mouseenter",handler:r},{element:this.popper,event:"mouseleave",handler:l},{element:t,event:"mouseleave",handler:a},{element:t,event:"mouseenter",handler:c}),this.onProductClick){const f=this.onProductClick,m=x=>{const y=x.target.closest(".ci360-popper-cta[data-product-id]");y&&f(y.dataset.productId,o)};this.popper.addEventListener("click",m),this.popperListeners.push({element:this.popper,event:"click",handler:m})}const h=Pn(t,this.popper,n);h.forceUpdate(),this.popper.setAttribute("data-show",""),this.shouldHidePopper=!1,this.popperInstance={...h,keepOpen:s,instanceId:o};try{(u=this.onOpen)==null||u.call(this,o)}catch(f){console.warn("onHotspotOpen callback error:",f)}}checkAndHidePopper(){var t;this.shouldHidePopper&&!((t=this.popperInstance)!=null&&t.keepOpen)&&(this.hidePopperTimeout&&clearTimeout(this.hidePopperTimeout),this.hidePopperTimeout=setTimeout(()=>{this.shouldHidePopper&&this.hidePopper()},Gi))}hidePopper(){var o,s;this.hidePopperTimeout&&(clearTimeout(this.hidePopperTimeout),this.hidePopperTimeout=null);const t=(o=this.popperInstance)==null?void 0:o.instanceId;this.cleanupPopperListeners(),this.currentHotspotElement&&(this.currentHotspotElement.setAttribute("aria-expanded","false"),this.currentHotspotElement.removeAttribute("aria-describedby"),this.currentHotspotElement=null);const i=this.popperInstance;if(this.popperInstance=null,t!=null)try{(s=this.onClose)==null||s.call(this,t)}catch(n){console.warn("onHotspotClose callback error:",n)}if(this.popper){this.popper.removeAttribute("data-show"),this.popper.setAttribute("aria-hidden","true");const n=this.popper;this.popper=null,setTimeout(()=>{i==null||i.destroy(),n.remove()},Ui)}else i==null||i.destroy();this.shouldHidePopper=!0}forceHidePopper(){this.shouldHidePopper=!0,this.popperInstance&&(this.popperInstance.keepOpen=!1),this.hidePopper()}createHotspot(t){const{id:i,keepOpen:o,onClick:s,label:n,markerStyle:r}=t,l=Ze(t),a=cs(i,n,r);(s||l&&this.trigger==="click")&&(a.style.cursor="pointer"),a.onclick=c=>{var h;c.stopPropagation(),l&&this.trigger==="click"&&(((h=this.popperInstance)==null?void 0:h.instanceId)===i?this.hidePopper():this.showPopper({hotspotElement:a,content:l,id:i,keepOpen:o})),s==null||s(c,this.popperInstance,i)},l&&this.trigger==="hover"&&(a.addEventListener("mouseenter",()=>this.showPopper({hotspotElement:a,content:l,id:i,keepOpen:o})),a.addEventListener("mouseleave",()=>{this.shouldHidePopper=!0,this.checkAndHidePopper()}),a.addEventListener("focus",()=>this.showPopper({hotspotElement:a,content:l,id:i,keepOpen:o})),a.addEventListener("blur",()=>{this.shouldHidePopper=!0,this.checkAndHidePopper()})),this.hotspotsContainer.appendChild(a)}hideHotspots(){this.hotspotsContainer.querySelectorAll(".cloudimage-360-hotspot").forEach(t=>{t.style.opacity=0,t.style.pointerEvents="none"})}updateAndShowHotspot(t,i){const{positions:o,id:s}=t,{x:n,y:r}=o[i]??{},l=this.hotspotsContainer.querySelector(`[data-hotspot-id="${s}"]`);l&&(l.style.translate=`${n}px ${r}px`,l.style.opacity=1,l.style.pointerEvents="all")}showHotspotById(t){const i=this.hotspotsConfig.find(n=>n.id===t);if(!i)return;const o=Ze(i);if(!o)return;const s=this.hotspotsContainer.querySelector(`[data-hotspot-id="${t}"]`);s&&s.style.opacity==="1"&&this.showPopper({hotspotElement:s,content:o,id:t,keepOpen:i.keepOpen})}createAllHotspots(){this.hotspotsConfig.forEach(t=>this.createHotspot(t))}initHotspots(){this.createAllHotspots()}destroy(){this.hidePopperTimeout&&clearTimeout(this.hidePopperTimeout),this.resizeObserver.disconnect(),this.hidePopper(),this.hotspotsContainer.innerHTML=""}}const Ue=typeof navigator<"u"&&/Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent);class $e{constructor(t,i){this.container=t,this.isClicked=!1,this.imagesX=[],this.imagesY=[];const o=Math.round(window.devicePixelRatio||1);this.devicePixelRatio=Ue?Math.min(o,2):o,this.id=t.id,this.movementStart={x:0,y:0},this.draggingDirection=null,this.isReady=!1,this.velocityX=0,this.velocityY=0,this.lastDragTime=0,this.lastDragX=0,this.lastDragY=0,this.inertiaAnimationId=null,this.hasInteracted=!1,this.touchDevice=jo(),this.dragJustEnded=!1,this.zoomPan=null,this.gestureRecognizer=null,this.zoomControlsUI=null,this.scrollHintUI=null,this.highResLoaded=!1,this.useMainThreadCanvas=Ue,this.canvasWorker=this.useMainThreadCanvas?new ss:new os,this.hotspotTimeline=null,this.hotspotTimelineIndicator=null,this.isAnimatingToFrame=!1,this.onMoveHandler=this.onMoveHandler.bind(this),this.destroy=this.destroy.bind(this),this.init(this.container,i)}closeImageBitmaps(t){!t||!Array.isArray(t)||t.forEach(i=>{var o;(o=i==null?void 0:i.bitmapImage)!=null&&o.close&&i.bitmapImage.close()})}emit(t,i={}){const o=this[t];typeof o=="function"&&o({...i,viewerId:this.id})}announce(t){Co(this.ariaLiveRegion,t)}mouseDown(t){if(!this.isReady)return;const i=t.target;if(i&&i.closest&&(i.closest(".cloudimage-360-button")||i.closest(".cloudimage-360-hotspot-timeline")||i.closest(".cloudimage-360-hotspot")||i.closest(".cloudimage-360-zoom-controls")))return;const{pageX:o,pageY:s}=t;if(this.hideHints(),this.hideHotspotPopper(),this.inertiaAnimationId&&(cancelAnimationFrame(this.inertiaAnimationId),this.inertiaAnimationId=null),this.autoplayJustStopped=!1,(this.autoplay||this.loopTimeoutId)&&(this.stopAutoplay(),this.autoplay=!1,this.autoplayJustStopped=!0),this.isZoomed&&this.zoomPan){this.zoomPan.startPan(o,s);return}this.movementStart={x:o,y:s},this.isClicked=!0,this.isDragging=!1,this.inertia&&(this.velocityX=0,this.velocityY=0,this.lastDragTime=performance.now(),this.lastDragX=o,this.lastDragY=s)}mouseUp(){this.isReady&&(!this.isZoomed&&!this.autoplayJustStopped&&this.showAllIcons(),this.inertia&&this.isDragging&&(Math.abs(this.velocityX)>.1||Math.abs(this.velocityY)>.1)&&this.startInertia(),this.isDragging&&(this.emit("onDragEnd"),this.dragJustEnded=!0),this.movementStart={x:0,y:0},this.isClicked=!1,this.isDragging=!1,this.innerBox.style.cursor="grab")}startInertia(){const o=this.dragSpeed/xe,s=o*(this.amountX/this.container.offsetWidth),n=o*(this.amountY/this.container.offsetHeight),r=()=>{if(this.velocityX*=.95,this.velocityY*=.95,Math.abs(this.velocityX)<.01&&Math.abs(this.velocityY)<.01){this.inertiaAnimationId=null;return}const l=this.velocityX*16,a=this.velocityY*16,c=Ye({deltaX:l,deltaY:a,reversed:this.dragReverse,allowSpinX:this.allowSpinX,allowSpinY:this.allowSpinY});if(c){const h=this.allowSpinX?Math.max(1,Math.abs(Math.round(l*s))):0,u=this.allowSpinY?Math.max(1,Math.abs(Math.round(a*n))):0;(h>0||u>0)&&this.onMoveHandler(c,h,u)}this.inertiaAnimationId=requestAnimationFrame(r)};this.inertiaAnimationId=requestAnimationFrame(r)}drag(t,i){if(!this.isReady||!this.isClicked)return;const o=t-this.movementStart.x,s=i-this.movementStart.y;if(this.inertia){const u=performance.now(),f=u-this.lastDragTime;f>0&&f<100&&(this.velocityX=(t-this.lastDragX)/f,this.velocityY=(i-this.lastDragY)/f),this.lastDragTime=u,this.lastDragX=t,this.lastDragY=i}this.draggingDirection=Ye({deltaX:o,deltaY:s,reversed:this.dragReverse,allowSpinX:this.allowSpinX,allowSpinY:this.allowSpinY})||this.draggingDirection;const n=this.dragSpeed/xe,r=n*(this.amountX/this.container.offsetWidth),l=n*(this.amountY/this.container.offsetHeight),a=this.allowSpinX?Math.abs(Math.round(o*r)):0,c=this.allowSpinY?Math.abs(Math.round(s*l)):0;(this.allowSpinX&&a!==0||this.allowSpinY&&c!==0)&&(this.hasInteracted=!0,this.hideHotspotPopper(),this.onMoveHandler(this.draggingDirection,a,c),this.movementStart={x:t,y:i},setTimeout(()=>{this.isDragging||(this.isDragging=!0,this.emit("onDragStart"))},ji))}mouseMove(t){!this.isReady||!this.isClicked||this.isZoomed||(this.hideAllIcons(),this.drag(t.pageX,t.pageY))}mouseClick(){this.dragJustEnded=!1,this.autoplayJustStopped=!1}loadHigherQualityImages(t,i){const o=Pt(this.srcXConfig,t),s=this.allowSpinY?Pt(this.srcYConfig,t):null;Pe({cdnPathX:o,cdnPathY:s,configX:this.srcXConfig,configY:this.srcYConfig,onAllImagesLoad:(n,r)=>{this.closeImageBitmaps(this.imagesX),this.closeImageBitmaps(this.imagesY),this.imagesX=n,this.imagesY=r,i()},onError:n=>this.emit("onError",n)})}hideHotspots(){this.hotspotsInstance&&this.hotspotsInstance.hideHotspots()}hideHotspotPopper(){this.hotspotsInstance&&this.hotspotsInstance.forceHidePopper()}getDrawDimensions(){if(!this.canvas||!this.imageAspectRatio)return null;const t=this.canvas.clientWidth,i=t/this.imageAspectRatio,o=t/i;return this.imageAspectRatio>o?{drawWidth:t,drawHeight:t/this.imageAspectRatio}:{drawWidth:i*this.imageAspectRatio,drawHeight:i}}initZoom(){const t=this.zoomMax||5,i=this.zoomStep||.5;this.zoomPan=new Ko(this.innerBox,{zoomMax:t,zoomStep:i,onZoomChange:(s,n,r)=>this.onZoomChange(s,n,r)});const o=this.getDrawDimensions();o&&this.zoomPan.setDrawSize(o.drawWidth,o.drawHeight),this.touchDevice&&this.pinchZoom!==!1&&(this.gestureRecognizer=new qo(this.innerBox,{zoomMax:t,getZoom:()=>this.zoomPan?this.zoomPan.getZoom():1,onPinchZoom:(s,n,r)=>{this.zoomPan&&(n!==void 0?this.zoomPan.zoomTowardPoint(s,n,r):this.zoomPan.applyTouchZoom(s))},onPan:(s,n)=>{this.zoomPan&&this.zoomPan.applyTouchPan(s,n)},onDoubleTap:(s,n)=>{this.zoomPan&&(this.zoomPan.isZoomed()?this.zoomPan.resetZoom():this.zoomPan.zoomTowardPoint(2,s,n))}})),this.zoomControls&&!this.touchDevice&&(this.zoomControlsUI=es(this.innerBox,{position:this.zoomControlsPosition||"bottom-left",zoomMax:t,onZoomIn:()=>this.zoomPan&&this.zoomPan.zoomIn(),onZoomOut:()=>this.zoomPan&&this.zoomPan.zoomOut(),onReset:()=>this.zoomPan&&this.zoomPan.resetZoom()}))}onZoomChange(t,i,o){this.inertiaAnimationId&&(cancelAnimationFrame(this.inertiaAnimationId),this.inertiaAnimationId=null);const s=this.isZoomed;if(this.isZoomed=t>1,this.isZoomed&&!s){if(this.hideAllIcons(),this.hideHotspots(),this.zoomControlsUI&&this.zoomControlsUI.show(),!this.highResLoaded){this.highResLoaded=!0;const n=document.body.offsetWidth;this.loadHigherQualityImages(n,()=>{this.zoomPan&&this.updateView(this.zoomPan.getZoom(),this.zoomPan.panX,this.zoomPan.panY)})}this.emit("onZoomIn",{zoomLevel:t}),this.announce("Zoomed in. Use mouse drag or arrow keys to pan. Double-click or press 0 to reset.")}!this.isZoomed&&s&&(this.showAllIcons(),this.emit("onZoomOut"),this.announce("Zoomed out")),this.zoomControlsUI&&this.zoomControlsUI.updateState(t),this.updateView(t,i,o)}removeZoom(){this.zoomPan&&this.zoomPan.resetZoom()}toggleZoom(){this.zoomPan&&(this.isZoomed?this.zoomPan.resetZoom():this.zoomPan.setZoom(2))}touchStart(t){if(!this.isReady||!t.touches||!t.touches.length)return;const i=t.target;if(i&&i.closest&&(i.closest(".cloudimage-360-button")||i.closest(".cloudimage-360-hotspot-timeline")||i.closest(".cloudimage-360-hotspot")||i.closest(".cloudimage-360-zoom-controls")))return;if(this.hideHints(),t.touches.length>1){this.isClicked=!1;return}if(this.isZoomed)return;const{pageX:o,pageY:s}=t.touches[0];this.inertiaAnimationId&&(cancelAnimationFrame(this.inertiaAnimationId),this.inertiaAnimationId=null),(this.autoplay||this.loopTimeoutId)&&(this.stopAutoplay(),this.autoplay=!1),this.hideAllIcons(),this.hideHotspotPopper(),this.movementStart={x:o,y:s},this.isClicked=!0,this.isDragging=!1,this.inertia&&(this.velocityX=0,this.velocityY=0,this.lastDragTime=performance.now(),this.lastDragX=o,this.lastDragY=s)}touchEnd(t){this.isReady&&(this.isZoomed||this.showAllIcons(),this.inertia&&this.isDragging&&(Math.abs(this.velocityX)>.1||Math.abs(this.velocityY)>.1)&&this.startInertia(),this.movementStart={x:0,y:0},this.isClicked=!1,this.isDragging=!1)}touchMove(t){if(!this.isReady||this.isZoomed||t.touches&&t.touches.length>1||!this.isClicked||!t.touches||!t.touches[0])return;const{pageX:i,pageY:o}=t.touches[0];t.preventDefault(),this.drag(i,o)}keyDown(t){if(!this.isReady)return;const i=t.target&&t.target.tagName;if(i==="INPUT"||i==="TEXTAREA"||t.target&&t.target.isContentEditable)return;const{keyCode:o}=t,s=this.keysReverse;if(this.autoplay&&this.stopAutoplay(),this.zoomPan&&this.zoomPan.handleKeyZoom(o)){t.preventDefault(),this.hideHints();return}if(this.isZoomed&&this.zoomPan&&this.zoomPan.handleKeyPan(o,Ki)){t.preventDefault();return}switch(Xe(o,this.allowSpinY)&&(this.hasInteracted=!0,this.hideAllIcons(),this.hideHints()),o){case 37:s?this.moveLeft():this.moveRight();break;case 39:s?this.moveRight():this.moveLeft();break;case 38:this.allowSpinY&&(t.preventDefault(),s?this.moveTop():this.moveBottom());break;case 40:this.allowSpinY&&(t.preventDefault(),s?this.moveBottom():this.moveTop());break}}keyUp(t){const{keyCode:i}=t;Xe(i,this.allowSpinY)&&this.showAllIcons()}moveActiveXIndexUp(t){this.orientation=L.X,this.activeImageX=(this.activeImageX+t)%this.amountX}moveActiveXIndexDown(t){this.orientation=L.X,this.activeImageX=(this.activeImageX-t+this.amountX)%this.amountX}moveActiveYIndexUp(t){this.orientation=L.Y,this.activeImageY=(this.activeImageY+t)%this.amountY}moveActiveYIndexDown(t){this.orientation=L.Y,this.activeImageY=(this.activeImageY-t+this.amountY)%this.amountY}moveRight(t,i=1){t&&this.activeImageX>=this.imagesX.length-1||(this.moveActiveXIndexUp(i),this.isZoomed||this.updateView())}moveLeft(t,i=1){t&&this.activeImageX<=0||(this.moveActiveXIndexDown(i),this.isZoomed||this.updateView())}moveTop(t,i=1){t&&this.activeImageY>=this.imagesY.length-1||(this.moveActiveYIndexUp(i),this.isZoomed||this.updateView())}moveBottom(t,i=1){t&&this.activeImageY<=0||(this.moveActiveYIndexDown(i),this.isZoomed||this.updateView())}onMoveHandler(t,i=1,o=1){t==="right"?this.moveRight(this.stopAtEdges,i):t==="left"?this.moveLeft(this.stopAtEdges,i):t==="up"?this.moveTop(this.stopAtEdges,o):t==="down"&&this.moveBottom(this.stopAtEdges,o),this.emit("onSpin",{direction:t,activeImageX:this.activeImageX,activeImageY:this.activeImageY,amountX:this.amountX,amountY:this.amountY})}updateView(t,i,o){const s=this.orientation===L.X?this.activeImageX:this.activeImageY,n=this.orientation===L.X?this.imagesX[this.activeImageX]:this.imagesY[this.activeImageY];this.hotspotsInstance&&!this.isZoomed&&!this.autoplay&&this.hotspotsInstance.updateHotspotPosition(s,this.orientation),this.hotspotTimelineIndicator&&this.orientation===L.X&&this.updateHotspotTimelinePosition(),this.drawImageOnCanvas(n,t,i,o)}updatePercentageInLoader(t=0){this.loader&&(this.loader.innerText=t+"%")}adaptCanvasSize(t){const{naturalWidth:i,naturalHeight:o}=t;this.imageAspectRatio=i/o;const s=this.canvas.clientWidth,n=s/this.imageAspectRatio;this.canvasWorker.postMessage({action:"adaptCanvasSize",devicePixelRatio:this.devicePixelRatio,imageAspectRatio:this.imageAspectRatio,containerWidth:s,containerHeight:n})}drawImageOnCanvas(t,i=1,o=0,s=0){this.pendingDrawData={imageData:t,zoomScale:i,pointerX:o,pointerY:s},this.drawFrameRequested||(this.drawFrameRequested=!0,requestAnimationFrame(()=>{if(this.drawFrameRequested=!1,this.pendingDrawData){const{imageData:n,zoomScale:r,pointerX:l,pointerY:a}=this.pendingDrawData;this.canvasWorker.postMessage({action:"drawImageOnCanvas",imageData:n,zoomScale:r,pointerX:l,pointerY:a})}}))}pushImageToSet(t,i,o){o===L.X?this.imagesX[i]=t:this.imagesY[i]=t}calculatePercentage(){const t=this.amountX+this.amountY,i=this.imagesX.length+this.imagesY.length;return Math.round(i/t*100)}onImageLoad(t,i,o){this.pushImageToSet(t,i,o),this.updatePercentageInLoader(this.calculatePercentage())}onFirstImageLoaded(t,i){this.createContainers(t),this.adaptCanvasSize(i),this.drawImageOnCanvas(i)}onAllImagesLoaded(){if(this.addAllIcons(),this.isReady=!0,this.amountX=this.imagesX.length,this.amountY=this.imagesY.length,this.activeImageX=this.autoplayReverse?this.amountX-1:0,this.activeImageY=this.autoplayReverse?this.amountY-1:0,this.hotspots&&(this.hotspotsInstance=new En(this.hotspots,this.innerBox,this.imageAspectRatio,{trigger:this.hotspotTrigger,onOpen:this.onHotspotOpen,onClose:this.onHotspotClose,onProductClick:this.onProductClick}),this.addHotspotTimeline(),this.autoplay?(this.hotspotsInstance.hideHotspots(),this.hideHotspotTimeline()):(this.hotspotsInstance.updateHotspotPosition(this.activeImageX,this.orientation),this.showHotspotTimeline())),this.emit("onLoad",{imagesX:this.imagesX.length,imagesY:this.imagesY.length}),this.emit("onReady"),this.announce("360 degree view loaded. Use mouse drag or arrow keys to rotate."),this.hints!==!1&&!this.autoplay){const t=this.hints===!0||this.hints===void 0?Te(this.viewerConfig,this.touchDevice):this.hints;t&&t.length>0&&(this.hintsOverlay=Se(this.innerBox,t),ke(this.hintsOverlay))}this.autoplay&&(this.hideAllIcons(),Go(this.play.bind(this))())}toggleFullscreen(t){t.stopPropagation(),this.hideHotspotPopper(),te()?He():$o(this.container)}onFullscreenChange(){const t=te()===this.container,i=this.container.classList.contains("cloudimage-360--fullscreen");t!==i&&(this.container.classList.toggle("cloudimage-360--fullscreen",t),fo(this.fullscreenIcon,t),requestAnimationFrame(()=>{if(this.imagesX.length>0){if(this.adaptCanvasSize(this.imagesX[this.activeImageX]),this.zoomPan){const o=this.getDrawDimensions();o&&this.zoomPan.setDrawSize(o.drawWidth,o.drawHeight,!0)}this.updateView()}}),t?(this.emit("onFullscreenOpen"),this.announce("Opened fullscreen mode. Press Escape to exit.")):(this.emit("onFullscreenClose"),this.announce("Exited fullscreen mode")))}play(){if(this.isClicked)return;this.hide360ViewCircleIcon(),this.emit("onAutoplayStart");const t=this.speed*36/(this.amountX+this.amountY),i={left:this.moveLeft.bind(this),right:this.moveRight.bind(this),top:this.moveTop.bind(this),bottom:this.moveBottom.bind(this)};this.loopTimeoutId=window.setInterval(()=>{if(this.playOnce&&Fo({autoplayBehavior:this.autoplayBehavior,activeImageX:this.activeImageX,activeImageY:this.activeImageY,amountX:this.amountX,amountY:this.amountY,autoplayReverse:this.autoplayReverse})){this.stopAutoplay();return}Wo({autoplayBehavior:this.autoplayBehavior,activeImageX:this.activeImageX,activeImageY:this.activeImageY,amountX:this.amountX,amountY:this.amountY,autoplayReverse:this.autoplayReverse,spinDirection:this.spinDirection})&&(this.spinDirection=Vo(this.spinDirection));const n=this.spinDirection==="y";_o({autoplayBehavior:this.autoplayBehavior,spinY:n,reversed:this.autoplayReverse,loopTriggers:i})},t)}stopAutoplay(){if(this.showAllIcons(),this.autoplay=!1,window.clearTimeout(this.loopTimeoutId),this.loopTimeoutId=null,this.emit("onAutoplayStop"),this.hotspotsInstance&&(this.hotspotsInstance.updateHotspotPosition(this.activeImageX,this.orientation),this.showHotspotTimeline()),this.hints!==!1&&!this.hintsOverlay&&!this.hintsHidden){const t=this.hints===!0?Te(this.viewerConfig,this.touchDevice):this.hints;t&&t.length>0&&(this.hintsOverlay=Se(this.innerBox,t),ke(this.hintsOverlay))}}destroy(){this.stopAutoplay(),this.inertiaAnimationId&&(cancelAnimationFrame(this.inertiaAnimationId),this.inertiaAnimationId=null),this.removeEvents(),this.zoomPan&&(this.zoomPan.destroy(),this.zoomPan=null),this.gestureRecognizer&&(this.gestureRecognizer.destroy(),this.gestureRecognizer=null),this.zoomControlsUI&&(this.zoomControlsUI.destroy(),this.zoomControlsUI=null),this.scrollHintUI&&(this.scrollHintUI.destroy(),this.scrollHintUI=null),this.closeImageBitmaps(this.imagesX),this.closeImageBitmaps(this.imagesY),this.imagesX=[],this.imagesY=[],this.canvasWorker&&(this.canvasWorker.terminate(),this.canvasWorker=null),this.hotspotsInstance&&this.hotspotsInstance.destroy(),this.hintsOverlay&&this.hintsOverlay.parentNode&&(this.hintsOverlay.parentNode.removeChild(this.hintsOverlay),this.hintsOverlay=null),this.hotspotTimeline&&this.hotspotTimeline.parentNode&&(this.hotspotTimeline.parentNode.removeChild(this.hotspotTimeline),this.hotspotTimeline=null,this.hotspotTimelineIndicator=null),this.innerBox&&this.innerBox.classList.remove("has-hotspot-timeline"),te()===this.container&&He(),this.container&&(this.container.classList.remove("ci360-theme-dark","ci360-hotspot-marker-inverted","ci360-hotspot-marker-brand","cloudimage-360--fullscreen"),this.container.style.removeProperty("--ci360-hotspot-brand-color"),this.container.innerHTML="")}releaseMemory(){this.stopAutoplay(),this.closeImageBitmaps(this.imagesX),this.closeImageBitmaps(this.imagesY),this.imagesX=[],this.imagesY=[],this.isMemoryReleased=!0}reloadImages(){if(!this.isMemoryReleased)return;this.isMemoryReleased=!1;const t=this.container.offsetWidth;this.loadHigherQualityImages(t,()=>{this.updateView()})}addInitialIcon(){this.initialIcon||this.hide360Logo||(this.initialIcon=co(this.logoSrc),this.innerBox.appendChild(this.initialIcon))}showInitialIcon(){!this.initialIcon||this.hasInteracted||(this.initialIcon.style.opacity=1)}hideInitialIcon(){this.initialIcon&&(this.initialIcon.style.opacity=0)}addFullscreenIcon(){!this.fullscreen||!Uo()||(this.fullscreenIcon=mo(),this.fullscreenIcon.onclick=this.toggleFullscreen.bind(this),this.iconsContainer.appendChild(this.fullscreenIcon))}showFullscreenIcon(){this.fullscreenIcon&&(this.fullscreenIcon.style.opacity=1)}hideFullscreenIcon(){this.fullscreenIcon&&(this.fullscreenIcon.style.opacity=0)}add360ViewCircleIcon(){this.view360CircleIcon||(this.view360CircleIcon=lo(this.bottomCircleOffset),this.innerBox.appendChild(this.view360CircleIcon))}show360ViewCircleIcon(){this.view360CircleIcon&&(this.view360CircleIcon.style.opacity=1)}hide360ViewCircleIcon(){this.view360CircleIcon&&(this.view360CircleIcon.style.opacity=0)}addLoadingSpinner(){this.loadingSpinner=yo(),this.innerBox.appendChild(this.loadingSpinner)}showLoadingSpinner(){this.loadingSpinner&&(this.hideAllIcons(),this.loadingSpinner.style.opacity=1)}hideLoadingSpinner(){this.loadingSpinner&&(this.loadingSpinner.style.opacity=0)}hideHints(){!this.hintsOverlay||this.hintsHidden||(this.hintsHidden=!0,Po(this.hintsOverlay))}addHotspotTimeline(){if(!this.hotspots||this.hotspotTimeline)return;const t=Ao(this.innerBox,this.amountX,this.hotspots);if(!t)return;this.hotspotTimeline=t.element,this.hotspotTimelineIndicator=t.indicator,this.innerBox.classList.add("has-hotspot-timeline"),this.hotspotTimeline.querySelectorAll(".cloudimage-360-hotspot-timeline-dot").forEach(o=>{o.addEventListener("click",s=>{s.stopPropagation(),this.hideAllIcons(),this.hideHints();const n=parseInt(o.getAttribute("data-frame"),10),r=o.getAttribute("data-hotspot-id");isNaN(n)||this.animateToFrame(n,r)})}),this.updateHotspotTimelinePosition()}showHotspotTimeline(){Lo(this.hotspotTimeline)}hideHotspotTimeline(){Mo(this.hotspotTimeline)}updateHotspotTimelinePosition(){Oo(this.hotspotTimelineIndicator,this.activeImageX,this.amountX)}animateToFrame(t,i){if(this.hotspotsInstance&&this.hotspotsInstance.hidePopper(),this.isAnimatingToFrame||t===this.activeImageX){t===this.activeImageX&&i&&this.hotspotsInstance&&this.hotspotTimelineOnClick&&this.hotspotsInstance.showHotspotById(i);return}this.isAnimatingToFrame=!0,this.hasInteracted=!0,(this.autoplay||this.loopTimeoutId)&&(this.stopAutoplay(),this.autoplay=!1),this.inertiaAnimationId&&(cancelAnimationFrame(this.inertiaAnimationId),this.inertiaAnimationId=null);const o=this.activeImageX,s=(t-o+this.amountX)%this.amountX,n=(o-t+this.amountX)%this.amountX,r=s<=n,l=r?s:n;if(l===0){this.isAnimatingToFrame=!1;return}const a=30;let c=l;const h=()=>{if(c<=0){this.isAnimatingToFrame=!1,i&&this.hotspotsInstance&&this.hotspotTimelineOnClick&&setTimeout(()=>{this.hotspotsInstance.showHotspotById(i)},50);return}r?this.moveRight():this.moveLeft(),c--,c>0?setTimeout(h,a):(this.isAnimatingToFrame=!1,i&&this.hotspotsInstance&&this.hotspotTimelineOnClick&&setTimeout(()=>{this.hotspotsInstance.showHotspotById(i)},50))};h()}remove360ViewCircleIcon(){this.view360CircleIcon&&(this.innerBox.removeChild(this.view360CircleIcon),this.view360CircleIcon=null)}addAllIcons(){this.removeLoader(),this.iconsContainer&&(this.innerBox.style.cursor="grab",this.addLoadingSpinner(),this.addFullscreenIcon(),this.initialIconShown&&this.addInitialIcon(),this.bottomCircle&&this.add360ViewCircleIcon(),this.initZoom())}showAllIcons(){this.showInitialIcon(),this.show360ViewCircleIcon(),this.showFullscreenIcon(),this.showHotspotTimeline(),this.zoomControlsUI&&this.zoomControlsUI.show()}hideAllIcons(){this.hideInitialIcon(),this.hide360ViewCircleIcon(),this.hideFullscreenIcon(),this.zoomControlsUI&&this.zoomControlsUI.hide()}removeLoader(){this.loader&&(this.innerBox.removeChild(this.loader),this.loader=null)}attachEvents(t,i,o){t&&this.addMouseEvents(),i&&this.addTouchEvents(),o&&this.addKeyboardEvents(),this.addEscKeyHandler(),this.addFullscreenChangeHandler()}removeEvents(){this.removeMouseEvents(),this.removeTouchEvents(),this.removeKeyboardEvents(),this.removeEscKeyHandler(),this.removeFullscreenChangeHandler()}addMouseEvents(){this.boundMouseClick=this.mouseClick.bind(this),this.boundMouseDown=this.mouseDown.bind(this),this.boundMouseMove=we(this.mouseMove.bind(this),Ce),this.boundMouseUp=this.mouseUp.bind(this),this.innerBox.addEventListener("click",this.boundMouseClick),this.innerBox.addEventListener("mousedown",this.boundMouseDown),document.addEventListener("mousemove",this.boundMouseMove),document.addEventListener("mouseup",this.boundMouseUp)}addTouchEvents(){this.boundTouchStart=this.touchStart.bind(this),this.boundTouchEnd=this.touchEnd.bind(this),this.boundTouchMove=we(this.touchMove.bind(this),Ce),this.container.addEventListener("touchstart",this.boundTouchStart,{passive:!1}),this.container.addEventListener("touchend",this.boundTouchEnd),this.container.addEventListener("touchmove",this.boundTouchMove,{passive:!1})}addKeyboardEvents(){this.boundKeyDown=this.keyDown.bind(this),this.boundKeyUp=this.keyUp.bind(this),document.addEventListener("keydown",this.boundKeyDown),document.addEventListener("keyup",this.boundKeyUp)}addEscKeyHandler(){this.boundEscHandler=t=>{t.keyCode===27&&this.isZoomed&&this.removeZoom()},document.addEventListener("keydown",this.boundEscHandler)}removeEscKeyHandler(){document.removeEventListener("keydown",this.boundEscHandler)}addFullscreenChangeHandler(){this.boundFullscreenChange=this.onFullscreenChange.bind(this),document.addEventListener("fullscreenchange",this.boundFullscreenChange),document.addEventListener("webkitfullscreenchange",this.boundFullscreenChange)}removeFullscreenChangeHandler(){document.removeEventListener("fullscreenchange",this.boundFullscreenChange),document.removeEventListener("webkitfullscreenchange",this.boundFullscreenChange)}removeMouseEvents(){this.innerBox.removeEventListener("click",this.boundMouseClick),this.innerBox.removeEventListener("mousedown",this.boundMouseDown),document.removeEventListener("mousemove",this.boundMouseMove),document.removeEventListener("mouseup",this.boundMouseUp)}removeTouchEvents(){this.container.removeEventListener("touchstart",this.boundTouchStart),this.container.removeEventListener("touchend",this.boundTouchEnd),this.container.removeEventListener("touchmove",this.boundTouchMove)}removeKeyboardEvents(){document.removeEventListener("keydown",this.boundKeyDown),document.removeEventListener("keyup",this.boundKeyUp)}createContainers(t){if(this.iconsContainer=Ee(this.innerBox),this.canvas=uo(this.innerBox,t),this.loader=go(this.innerBox),this.ariaLiveRegion=wo(this.innerBox),this.useMainThreadCanvas)this.canvasWorker.postMessage({action:"initCanvas",offscreen:this.canvas,devicePixelRatio:this.devicePixelRatio});else{const i=this.canvas.transferControlToOffscreen();this.canvasWorker.postMessage({action:"initCanvas",offscreen:i,devicePixelRatio:this.devicePixelRatio},[i])}ee(this.innerBox,".cloudimage-360-placeholder")}update(t){this.isReady&&(this.stopAutoplay(),this.zoomPan&&(this.zoomPan.destroy(),this.zoomPan=null),this.gestureRecognizer&&(this.gestureRecognizer.destroy(),this.gestureRecognizer=null),this.zoomControlsUI&&(this.zoomControlsUI.destroy(),this.zoomControlsUI=null),this.scrollHintUI&&(this.scrollHintUI.destroy(),this.scrollHintUI=null),this.isZoomed=!1,this.highResLoaded=!1,ee(this.innerBox,".cloudimage-360-icons-container"),this.init(this.container,t,!0),this.iconsContainer=Ee(this.innerBox),this.onAllImagesLoaded())}init(t,i,o){const s=i?Qi(i):qi(t),{folder:n,apiVersion:r,filenameX:l,filenameY:a,imageListX:c,imageListY:h,indexZeroBase:u,amountX:f,amountY:m,draggable:x=!0,swipeable:y=!0,keys:b,keysReverse:I,bottomCircleOffset:E,autoplay:w,autoplayBehavior:v,playOnce:P,speed:p,autoplayReverse:g,fullscreen:C,magnifier:S,pointerZoom:k,zoomMax:A,zoomStep:X,zoomControls:O,zoomControlsPosition:G,scrollHint:U,ciToken:Y,ciFilters:Z,ciTransformation:nt,lazyload:$,dragSpeed:rt,stopAtEdges:vt,imageInfo:et="black",initialIconShown:at,bottomCircle:Q,hotspots:N,hotspotTrigger:it="hover",dragReverse:lt,hide360Logo:K,logoSrc:gt,inertia:Gt,pinchZoom:yt,hints:Ut,theme:bt,markerTheme:Lt,brandColor:Mt,hotspotTimelineOnClick:Xt=!0,aspectRatio:Yt,cropAspectRatio:$t,cropGravity:Kt,onReady:q,onLoad:ht,onSpin:Ht,onAutoplayStart:Rt,onAutoplayStop:wt,onFullscreenOpen:zt,onFullscreenClose:Zt,onZoomIn:Dt,onZoomOut:Bt,onDragStart:di,onDragEnd:ui,onHotspotOpen:pi,onHotspotClose:mi,onProductClick:fi,onError:vi}=s,ue={ciToken:Y,ciFilters:Z,ciTransformation:nt,cropAspectRatio:$t,cropGravity:Kt},qt=ie(c,[]),Jt=ie(h,[]),gi=s.zoomMax===5&&k>1?Math.min(k,5):A||5;if(this.viewerConfig=s,this.amountX=qt.length||f,this.amountY=Jt.length||m,this.allowSpinX=!!this.amountX,this.allowSpinY=!!this.amountY,this.orientation=this.allowSpinX?L.X:L.Y,this.activeImageX=g?this.amountX-1:0,this.activeImageY=g?this.amountY-1:0,this.bottomCircleOffset=E,this.autoplay=w,this.autoplayBehavior=v,this.playOnce=P,this.speed=p,this.autoplayReverse=g,this.fullscreen=C,this.zoomMax=gi,this.zoomStep=X||.5,this.zoomControls=O??!0,this.zoomControlsPosition=G||"bottom-left",this.scrollHint=U??!0,this.dragSpeed=Math.max(rt,$i),this.stopAtEdges=vt,this.ciParams=ue,this.apiVersion=r,this.keysReverse=I,this.info=et,this.keys=b,this.innerBox=this.innerBox??vo(this.container),this.container.style.aspectRatio=Yt||"",this.initialIconShown=at,this.bottomCircle=Q,this.spinDirection=No(this.autoplayBehavior,this.allowSpinX,this.allowSpinY),this.dragReverse=lt,this.hotspots=N,this.hotspotTrigger=it,this.onHotspotOpen=pi,this.onHotspotClose=mi,this.onProductClick=fi,this.hide360Logo=K,this.logoSrc=gt,this.inertia=Gt,this.pinchZoom=yt,this.hints=Ut,this.hotspotTimelineOnClick=Xt,bt==="dark"?this.container.classList.add("ci360-theme-dark"):bt==="light"&&this.container.classList.remove("ci360-theme-dark"),this.container.classList.remove("ci360-hotspot-marker-inverted","ci360-hotspot-marker-brand"),Lt==="inverted"?this.container.classList.add("ci360-hotspot-marker-inverted"):Lt==="brand"&&(this.container.classList.add("ci360-hotspot-marker-brand"),Mt&&this.container.style.setProperty("--ci360-hotspot-brand-color",Mt)),this.onReady=q,this.onLoad=ht,this.onSpin=Ht,this.onAutoplayStart=Rt,this.onAutoplayStop=wt,this.onFullscreenOpen=zt,this.onFullscreenClose=Zt,this.onZoomIn=Dt,this.onZoomOut=Bt,this.onDragStart=di,this.onDragEnd=ui,this.onError=vi,this.srcXConfig={folder:n,filename:l,imageList:qt,container:t,innerBox:this.innerBox,apiVersion:r,ciParams:ue,lazyload:$,amount:this.amountX,indexZeroBase:u,autoplayReverse:g,orientation:L.X},this.srcYConfig={...this.srcXConfig,filename:a,imageList:Jt,orientation:L.Y,amount:this.amountY},o&&this.removeEvents(),this.attachEvents(x,y,b),o)return;const pe=this.container.offsetWidth,me=this.allowSpinX&&!qt.length?Pt(this.srcXConfig,pe):null,fe=this.allowSpinY&&!Jt.length?Pt(this.srcYConfig,pe):null,ve=yi=>{Pe({cdnPathX:me,cdnPathY:fe,configX:this.srcXConfig,configY:this.srcYConfig,onImageLoad:(Ct,bi,wi)=>this.onImageLoad(Ct,bi,wi),onFirstImageLoad:Ct=>this.onFirstImageLoaded(yi,Ct),onAllImagesLoad:this.onAllImagesLoaded.bind(this),onError:Ct=>this.emit("onError",Ct)})};this.allowSpinX?Oe(me,this.srcXConfig,ve):this.allowSpinY&&Oe(fe,this.srcYConfig,ve)}}const Ke=typeof navigator<"u"&&/Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent);class Sn{constructor(){this.views=new Map,this.initAll=this.initAll.bind(this),this.getViews=this.getViews.bind(this),this.memoryObserver=null,this.memoryManagementAutoEnabled=!1}generateId(){return`ci360-${Math.random().toString(36).slice(2,11)}`}init(t,i){if(!t)return;const o=t.id||this.generateId();t.id||(t.id=o);const s=new $e(t,i);return this.views.set(o,s),Ke&&!this.memoryManagementAutoEnabled&&(this.memoryManagementAutoEnabled=!0,setTimeout(()=>this.enableMemoryManagement(),100)),s}initAll(t="cloudimage-360"){[...document.querySelectorAll(`.${t}`)].filter(Boolean).forEach(o=>{const s=o.id||this.generateId();o.id||(o.id=s);const n=new $e(o);this.views.set(s,n)}),Ke&&!this.memoryManagementAutoEnabled&&this.views.size>0&&(this.memoryManagementAutoEnabled=!0,setTimeout(()=>this.enableMemoryManagement(),100))}destroy(t){const i=this.getViewById(t);i&&(i.destroy(),this.views.delete(t))}destroyAll(){this.views.forEach(t=>{t.destroy()}),this.views.clear()}getViewById(t){return this.views.get(t)}getViews(){return Array.from(this.views.values())}updateView(t,i){const o=this.getViewById(t);if(!o)return null;const s={...o.viewerConfig,...i};o.destroy();const n=document.getElementById(t);return this.init(n,s)}enableMemoryManagement(t={}){this.memoryObserver&&this.memoryObserver.disconnect();const i=t.rootMargin||"200px";this.memoryObserver=new IntersectionObserver(o=>{o.forEach(s=>{const n=this.getViewById(s.target.id);n&&(s.isIntersecting?n.isMemoryReleased&&n.reloadImages():!n.isMemoryReleased&&n.isReady&&n.releaseMemory())})},{rootMargin:i}),this.views.forEach((o,s)=>{const n=document.getElementById(s);n&&this.memoryObserver.observe(n)}),this.boundVisibilityHandler=()=>{document.hidden?this.views.forEach(o=>{!o.isMemoryReleased&&o.isReady&&o.releaseMemory()}):this.views.forEach((o,s)=>{if(o.isMemoryReleased){const n=document.getElementById(s);if(n){const r=n.getBoundingClientRect();r.top<window.innerHeight&&r.bottom>0&&o.reloadImages()}}})},document.addEventListener("visibilitychange",this.boundVisibilityHandler)}disableMemoryManagement(){this.memoryObserver&&(this.memoryObserver.disconnect(),this.memoryObserver=null),this.boundVisibilityHandler&&(document.removeEventListener("visibilitychange",this.boundVisibilityHandler),this.boundVisibilityHandler=null)}}exports.default=Sn;
65
+ //# sourceMappingURL=ci360-D-8A9XyP.js.map