handler-playable-sdk 1.0.8 → 1.0.9

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.
@@ -1,4 +1,4 @@
1
- "use strict";var wa=Object.create;var Mt=Object.defineProperty;var xa=Object.getOwnPropertyDescriptor;var Sa=Object.getOwnPropertyNames;var Ea=Object.getPrototypeOf,Ca=Object.prototype.hasOwnProperty;var ce=(i,e)=>()=>(i&&(e=i(i=0)),e);var Wi=(i,e)=>{for(var t in e)Mt(i,t,{get:e[t],enumerable:!0})},Yi=(i,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let a of Sa(e))!Ca.call(i,a)&&a!==t&&Mt(i,a,{get:()=>e[a],enumerable:!(n=xa(e,a))||n.enumerable});return i};var ri=(i,e,t)=>(t=i!=null?wa(Ea(i)):{},Yi(e||!i||!i.__esModule?Mt(t,"default",{value:i,enumerable:!0}):t,i)),Aa=i=>Yi(Mt({},"__esModule",{value:!0}),i);var Ma,ae=ce(()=>{"use strict";Ma="handler_preview_override_mode";if(typeof window!="undefined"){let i=window.localStorage.getItem(Ma);window.__enableConfigOverrides=i===null?!0:i==="true"}});var Tn,_e,ir,pi=ce(()=>{"use strict";ae();Tn=null,_e="dev";if(typeof window!="undefined"){let i=window.__BUILD_SETTINGS__;if(i!=null&&i.buildMode)Tn=i,_e=i.buildMode,console.log("[CONFIG] Loaded inline build settings:",i,"buildMode:",_e);else try{let e=new XMLHttpRequest;if(e.open("GET","./build-settings.json",!1),e.send(),e.status===200&&e.responseText){let t=JSON.parse(e.responseText);Tn=t,_e=t.buildMode||"dev",console.log("[CONFIG] Loaded build settings:",t,"buildMode:",_e)}else console.log("[CONFIG] No build-settings.json found, using default buildMode:",_e)}catch(e){console.log("[CONFIG] Failed to load build-settings.json:",e instanceof Error?e.message:String(e))}}console.log("[CONFIG] Final buildMode:",_e);ir=_e==="dev"||typeof window!="undefined"&&window.location.search.includes("hot-reload")});var ui=ce(()=>{"use strict"});var Pn=ce(()=>{"use strict";ui();pi()});var gi=ce(()=>{"use strict";pi();ui();Pn()});var se,mi=ce(()=>{"use strict";se=class{static get(e){var t;return(t=this.store.get(e))==null?void 0:t.data}static set(e,t){this.store.set(e,{data:t})}static has(e){return this.store.has(e)}static clear(){this.store.clear()}};se.store=new Map});function Ba(){var i,e;try{let t=typeof window!="undefined"&&(document.querySelector('script[src*="inline-assets.js"]')||((e=(i=document.querySelector("script"))==null?void 0:i.textContent)==null?void 0:e.includes("inline-assets.js"))||window.INLINE_ASSETS),n=typeof window!="undefined"&&document.querySelector('link[href*="assets/"], script[src*="assets/"]');return!!(t&&!n)}catch{return!1}}async function Ga(){try{if(typeof window!="undefined"){let i=await fetch("./build-settings.json");if(i.ok){let e=await i.json();return console.log("[AssetLoader] Loaded build settings:",e),e}}}catch{}return null}function Ua(){try{if(typeof window!="undefined"){let i=new XMLHttpRequest;if(i.open("GET","./build-settings.json",!1),i.send(),i.status===200&&i.responseText){let e=JSON.parse(i.responseText);return console.log("[AssetLoader] Loaded build settings (sync):",e),e}}}catch{}return null}async function qa(){if(console.log(`[AssetLoader] getInlineAssets() called - Effective mode: ${I}`),Object.keys(de).length>0)return console.log("[AssetLoader] Returning cached inline assets:",Object.keys(de)),de;if(typeof window!="undefined"&&window.INLINE_ASSETS)return console.log("[AssetLoader] Using pre-loaded INLINE_ASSETS from window:",Object.keys(window.INLINE_ASSETS)),de={...window.INLINE_ASSETS},de;if(!(I==="publish"&&re!==!1))return console.log("[AssetLoader] Inline assets disabled for this build mode."),de;if(!bi){let e=typeof window!="undefined"?new URL("inline-assets.js",window.location.href).href:"./inline-assets.js";console.log("[AssetLoader] Loading inline assets from:",e),bi=(async()=>{try{try{let s=await import(e+"?t="+Date.now());if(s.INLINE_ASSETS)return console.log("[AssetLoader] Loaded INLINE_ASSETS via ES module:",Object.keys(s.INLINE_ASSETS)),s.INLINE_ASSETS}catch(s){console.warn("[AssetLoader] ES module import failed, trying text parse:",s)}let t=await fetch(e);if(!t.ok)throw new Error(`HTTP ${t.status}: ${t.statusText}`);let n=await t.text();console.log("[AssetLoader] Received JS code, length:",n.length);let a=n.match(/export\s+const\s+INLINE_ASSETS\s*=\s*({[\s\S]*?});?\s*$/m);if(a)try{let s=a[1];console.log("[AssetLoader] Found INLINE_ASSETS export, parsing...");let r=new Function("return "+s)();return console.log("[AssetLoader] Parsed inline assets:",Object.keys(r)),r}catch(s){return console.warn("[AssetLoader] Failed to parse inline assets:",s),{}}else return console.warn("[AssetLoader] INLINE_ASSETS export not found in response"),console.log("[AssetLoader] JS code preview:",n.substring(0,500)),{}}catch(t){return console.warn("[AssetLoader] Failed to load inline assets:",t),{}}})()}return de=await bi,console.log("[AssetLoader] Final inline assets cache:",Object.keys(de)),de}function yi(i){return i===null||typeof i!="object"||(Object.freeze(i),Object.values(i).forEach(e=>yi(e))),i}function Va(i=64,e=64,t=16711680){let n=document.createElement("canvas");n.width=i,n.height=e;let a=n.getContext("2d");return a.fillStyle=`#${t.toString(16).padStart(6,"0")}`,a.fillRect(0,0,i,e),a.strokeStyle="#000",a.strokeRect(0,0,i,e),a.fillStyle="#fff",a.font="10px sans-serif",a.textAlign="center",a.fillText("MISSING",i/2,e/2),pe.Texture.from(n)}function $t(i,e){Dn.set(i,e)}var pe,zn,$n,Oe,I,re,Ae,de,bi,Dn,Le,Dt=ce(()=>{"use strict";pe=require("pixi.js");mi();zn=typeof __BUILD_MODE__!="undefined"?__BUILD_MODE__:"undefined",$n=Ba(),Oe=typeof window!="undefined"?window.__BUILD_SETTINGS__:null,I=$n?"publish":zn,re=Oe==null?void 0:Oe.assetsInlined;Oe!=null&&Oe.buildMode&&(I=Oe.buildMode,console.log(`[AssetLoader] Build mode overridden by inline settings: ${I}`));Ae=Ua();Ae!=null&&Ae.buildMode&&(I=Ae.buildMode,console.log(`[AssetLoader] Build mode overridden by sync settings: ${I}`));(Ae==null?void 0:Ae.assetsInlined)!==void 0&&(re=Ae.assetsInlined);Ga().then(i=>{i!=null&&i.buildMode&&i.buildMode!==I&&(I=i.buildMode,console.log(`[AssetLoader] Build mode overridden by settings: ${I}`)),(i==null?void 0:i.assetsInlined)!==void 0&&(re=i.assetsInlined)}).catch(()=>{});console.log(`[AssetLoader] MODULE LOADED - Compile: ${zn}, Runtime: ${$n?"publish":"dev"}, Effective: ${I}`);de={},bi=null;Dn=new Map;Le=class{static async load(e,t,n,a){let s=`${e}:${t.path}`,r=se.get(s);if(r!==void 0)return r;console.log(`[AssetLoader] Loading asset: ${e}, type: ${t.type}, Effective mode: ${I}`),console.log(`[AssetLoader] Window defined: ${typeof window!="undefined"}, INLINE_ASSETS exists: ${!!(typeof window!="undefined"&&window.INLINE_ASSETS)}, keys: ${typeof window!="undefined"&&window.INLINE_ASSETS?Object.keys(window.INLINE_ASSETS).length:"N/A"}`);let o=await qa(),l=o[e];if(!l&&a&&(l=o[a],l&&console.log(`[AssetLoader] Found inline data for ${e} using configId: ${a}`)),!l&&t.path){let c=t.path.split("/");if(c.length>=2){let p=c[c.length-1].split(".")[0];o[p]&&(l=o[p],console.log(`[AssetLoader] Found inline data for ${e} using assetName: ${p}`))}}if(console.log("[AssetLoader] Inline data for",e,":",l?"FOUND":"NOT FOUND"),I==="publish"&&re!==!1&&(console.log("[AssetLoader] \u26A0\uFE0F PUBLISH MODE DETECTED - inline assets are MANDATORY"),!l))throw new Error(`[AssetLoader] PUBLISH MODE: Inline asset required but NOT FOUND for object: ${e}, path: ${t.path}`);let u=Dn.get(t.type);if(u)try{let c=await u(t.path,l,e,n);return se.set(s,c),c}catch(c){return this.handleFailure(e,t.type,c)}try{let c;switch(t.type){case"image":c=await this.loadImage(t.path,l);break;case"json":c=await this.loadJSON(t.path,l),c=yi(c);break;default:throw new Error(`Unknown asset type: ${t.type}`)}return se.set(s,c),c}catch(c){return this.handleFailure(e,t.type,c)}}static async loadImage(e,t){let n=I==="publish",a=n&&re!==!1;if(console.log(`[AssetLoader] loadImage - Effective mode: ${I}, isPublishMode: ${n}, inlineData: ${t?"EXISTS":"MISSING"}`),a){if(console.log("[AssetLoader] PUBLISH MODE ACTIVATED - inline assets are MANDATORY"),!t)throw new Error(`[AssetLoader] Publish mode: inline asset required but not found for object. Path: ${e}`);if(typeof t!="string"||!t.startsWith("data:"))throw new Error(`[AssetLoader] Publish mode: inline asset must be data URI string, got: ${typeof t}`);try{return await pe.Assets.load(t)}catch(s){throw console.error("[AssetLoader] Failed to load texture from data URI:",s),s}}if(t&&typeof t=="string"&&t.startsWith("data:"))try{return await pe.Assets.load(t)}catch(s){return console.error("[AssetLoader] Failed to load texture from data URI, falling back to path:",s),await pe.Assets.load(e)}return await pe.Assets.load(e)}static async loadJSON(e,t){let n=I==="publish",a=n&&re!==!1;if(console.log(`[AssetLoader] loadJSON - Effective mode: ${I}, isPublishMode: ${n}, inlineData: ${t?"EXISTS":"MISSING"}`),a){if(console.log("[AssetLoader] PUBLISH MODE ACTIVATED - inline assets are MANDATORY"),!t)throw new Error(`[AssetLoader] Publish mode: inline asset required but not found for path: ${e}`);if(typeof t=="object"&&t!==null)return t;if(typeof t=="string"&&t.startsWith("data:")){let r=atob(t.split(",")[1]);return JSON.parse(r)}return JSON.parse(t)}if(t){if(typeof t=="object"&&t!==null)return t;if(typeof t=="string"&&t.startsWith("data:")){let r=atob(t.split(",")[1]);return JSON.parse(r)}return JSON.parse(t)}let s=await fetch(e);if(!s.ok)throw new Error(`JSON fetch failed: ${e}`);return s.json()}static handleFailure(e,t,n){if(I==="dev"){let s=t==="image"?Va():yi({__placeholder:!0,type:t});return se.set(e+":"+((n==null?void 0:n.path)||"missing"),s),s}throw n}};$t("image",async(i,e)=>{let t=I==="publish",n=t&&re!==!1,a=I==="brand",s=t&&re===!1;if(console.log(`[AssetLoader] registerType('image') - Effective mode: ${I}, isPublishMode: ${t}, isBrandMode: ${a}, inlineData: ${e?"EXISTS":"MISSING"}`),n){if(console.log("[AssetLoader] PUBLISH MODE ACTIVATED - inline assets are MANDATORY"),!e)throw new Error(`[AssetLoader] Publish mode: inline asset required but not found for path: ${i}`);if(typeof e!="string"||!e.startsWith("data:"))throw new Error(`[AssetLoader] Publish mode: inline asset must be data URI string, got: ${typeof e}`);return pe.Assets.load(e)}let r=i;return(a||s)&&i&&!i.startsWith("assets/")&&(typeof window!="undefined"&&!document.querySelector('link[href*="assets/"], script[src*="assets/"]')&&!document.querySelector('link[href*="configs/"], script[src*="configs/"]')?(r=i,console.log(`[AssetLoader] BRAND MODE: flattened build, using path "${i}" as-is`)):(r=`assets/${i}`,console.log(`[AssetLoader] BRAND MODE: transformed path "${i}" -> "${r}"`))),pe.Assets.load(e||r)});$t("json",async(i,e)=>{let t=I==="publish",n=t&&re!==!1,a=I==="brand",s=t&&re===!1;if(console.log(`[AssetLoader] registerType('json') - Effective mode: ${I}, isPublishMode: ${t}, isBrandMode: ${a}, inlineData: ${e?"EXISTS":"MISSING"}`),n){if(console.log("[AssetLoader] PUBLISH MODE ACTIVATED - inline assets are MANDATORY"),!e)throw new Error(`[AssetLoader] Publish mode: inline asset required but not found for path: ${i}`);return typeof e=="object"&&e!==null?e:typeof e=="string"&&e.startsWith("data:")?JSON.parse(atob(e.split(",")[1])):JSON.parse(e)}let r=i;if((a||s)&&i&&!i.startsWith("assets/")&&(typeof window!="undefined"&&!document.querySelector('link[href*="assets/"], script[src*="assets/"]')&&!document.querySelector('link[href*="configs/"], script[src*="configs/"]')?(r=i,console.log(`[AssetLoader] BRAND MODE: flattened build, using path "${i}" as-is`)):(r=`assets/${i}`,console.log(`[AssetLoader] BRAND MODE: transformed path "${i}" -> "${r}"`))),e)return typeof e=="object"&&e!==null?e:typeof e=="string"&&e.startsWith("data:")?JSON.parse(atob(e.split(",")[1])):JSON.parse(e);let o=await fetch(r);if(!o.ok)throw new Error(`JSON fetch failed: ${i}`);return o.json()})});function Ht(i,e){Hn.init(i,e),typeof window!="undefined"&&(window.__AssetTextures=Te)}var vi,Hn,Te,ht=ce(()=>{"use strict";Dt();vi=class{constructor(){this.textures=new Map;this.readyPromise=null;this.priorityReadyPromise=null;this.priorityReadyResolve=null;this.config=null;this.app=null;this.attempted=new Set;this.waiters=new Set}init(e,t){if(this.config===e&&this.app===t&&this.priorityReadyPromise){console.log("[AssetTextures] init called with same config/app; keeping existing state");return}this.textures.clear(),this.readyPromise=null,this.priorityReadyPromise=null,this.priorityReadyResolve=null,this.attempted.clear(),this.waiters.clear(),this.priorityReadyPromise=new Promise(n=>{this.priorityReadyResolve=n}),this.config=e,this.app=t,console.log("[AssetTextures] Initialized with config, cleared previous textures")}async ready(){if(this.readyPromise){await this.readyPromise;return}if(!this.config)throw new Error("[AssetTextures] Must call init() before ready() - config is null");if(!this.app)throw new Error("[AssetTextures] Must call init() before ready() - app is null");let e=this.config,t=this.app;return this.readyPromise=(async()=>{var r;console.log("[AssetTextures] Loading all assets...");let n=new Set(["background_loading_1"]),a=[],s=[];for(let[o,l]of e.objects.entries()){let d=(r=l.render)==null?void 0:r.asset;if(!d)continue;let u=async()=>{var c;try{let p=(c=l.identity)==null?void 0:c.id;console.log(`[AssetTextures] Loading ${d.type}: ${o} (${p})`);let g=await Le.load(o,d,t,p);this.textures.set(o,g),console.log(`[AssetTextures] \u2713 Loaded: ${o}`)}catch(p){console.error(`[AssetTextures] \u2717 Failed to load: ${o}`,p)}finally{this.attempted.add(o);try{for(let p of Array.from(this.waiters))p()}catch{}}};n.has(o)?a.push(u()):s.push(u())}a.length>0&&(console.log("[AssetTextures] Phase 1: Loading priority assets (loading screen)..."),await Promise.all(a),console.log("[AssetTextures] Phase 1: Priority assets ready")),this.priorityReadyResolve&&this.priorityReadyResolve(),console.log("[AssetTextures] Phase 2: Loading remaining assets..."),await Promise.all(s),console.log("[AssetTextures] All textures loaded:",Array.from(this.textures.keys()))})(),this.readyPromise}async priorityReady(){return this.priorityReadyPromise?this.priorityReadyPromise:Promise.resolve()}async waitFor(e,t={}){if(!this.config)throw new Error("[AssetTextures] Must call init() before waitFor() - config is null");if(!this.app)throw new Error("[AssetTextures] Must call init() before waitFor() - app is null");let a=Array.from(new Set((e||[]).filter(o=>typeof o=="string"&&o))).filter(o=>{var l,d,u,c;try{let p=(u=(d=(l=this.config)==null?void 0:l.objects)==null?void 0:d.get)==null?void 0:u.call(d,o);return!!((c=p==null?void 0:p.render)!=null&&c.asset)}catch{return!1}});if(a.length===0)return;this.ready().catch(()=>{});let s=()=>a.every(o=>this.textures.has(o)||this.attempted.has(o));if(s())return;let r=typeof t.timeoutMs=="number"?t.timeoutMs:15e3;await new Promise(o=>{let l=!1,d=()=>{l||s()&&(l=!0,this.waiters.delete(d),o())};this.waiters.add(d),d(),r>0&&setTimeout(()=>{l||(l=!0,this.waiters.delete(d),console.warn("[AssetTextures] waitFor timed out; continuing",{ids:a}),o())},r)})}get(e){return this.textures.get(e)}set(e,t){this.textures.set(e,t),console.log(`[AssetTextures] Updated texture: ${e}`)}clear(){this.textures.clear(),this.readyPromise=null,console.log("[AssetTextures] Cleared all textures")}getAllIds(){return Array.from(this.textures.keys())}},Hn=new vi,Te=new Proxy(Hn,{get(i,e){return e in i&&typeof i[e]=="function"?i[e].bind(i):i.get(e)},set(i,e,t){return i.set(e,t),!0}})});var Bn={};Wi(Bn,{AssetEditorModal:()=>Ci});var Ci,Ai=ce(()=>{"use strict";Ci=class{constructor(){this.modal=null;this.currentObjectId=null;this.currentPath=null;this.currentAsset="";this.onApplyCallback=null}show(e,t,n,a){this.currentObjectId=e,this.currentPath=t,this.currentAsset=n,this.onApplyCallback=a,this.createModal(e,n),document.body.appendChild(this.modal),this.attachModalListeners()}createModal(e,t){let n=document.createElement("div");n.className="asset-editor-modal",n.innerHTML=`
1
+ "use strict";var Da=Object.create;var jt=Object.defineProperty;var Ha=Object.getOwnPropertyDescriptor;var Na=Object.getOwnPropertyNames;var Fa=Object.getPrototypeOf,Ba=Object.prototype.hasOwnProperty;var ge=(i,e)=>()=>(i&&(e=i(i=0)),e);var cn=(i,e)=>{for(var t in e)jt(i,t,{get:e[t],enumerable:!0})},dn=(i,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let a of Na(e))!Ba.call(i,a)&&a!==t&&jt(i,a,{get:()=>e[a],enumerable:!(n=Ha(e,a))||n.enumerable});return i};var ci=(i,e,t)=>(t=i!=null?Da(Fa(i)):{},dn(e||!i||!i.__esModule?jt(t,"default",{value:i,enumerable:!0}):t,i)),Ga=i=>dn(jt({},"__esModule",{value:!0}),i);var Ka,oe=ge(()=>{"use strict";Ka="handler_preview_override_mode";if(typeof window!="undefined"){let i=window.localStorage.getItem(Ka);window.__enableConfigOverrides=i===null?!0:i==="true"}});var Bn,Re,wr,hi=ge(()=>{"use strict";oe();Bn=null,Re="dev";if(typeof window!="undefined"){let i=window.__BUILD_SETTINGS__;if(i!=null&&i.buildMode)Bn=i,Re=i.buildMode,console.log("[CONFIG] Loaded inline build settings:",i,"buildMode:",Re);else try{let e=new XMLHttpRequest;if(e.open("GET","./build-settings.json",!1),e.send(),e.status===200&&e.responseText){let t=JSON.parse(e.responseText);Bn=t,Re=t.buildMode||"dev",console.log("[CONFIG] Loaded build settings:",t,"buildMode:",Re)}else console.log("[CONFIG] No build-settings.json found, using default buildMode:",Re)}catch(e){console.log("[CONFIG] Failed to load build-settings.json:",e instanceof Error?e.message:String(e))}}console.log("[CONFIG] Final buildMode:",Re);wr=Re==="dev"||typeof window!="undefined"&&window.location.search.includes("hot-reload")});var fi=ge(()=>{"use strict"});var Un=ge(()=>{"use strict";fi();hi()});var mi=ge(()=>{"use strict";hi();fi();Un()});var le,vi=ge(()=>{"use strict";le=class{static get(e){var t;return(t=this.store.get(e))==null?void 0:t.data}static set(e,t){this.store.set(e,{data:t})}static has(e){return this.store.has(e)}static clear(){this.store.clear()}};le.store=new Map});function rs(){var i,e;try{let t=typeof window!="undefined"&&(document.querySelector('script[src*="inline-assets.js"]')||((e=(i=document.querySelector("script"))==null?void 0:i.textContent)==null?void 0:e.includes("inline-assets.js"))||window.INLINE_ASSETS),n=typeof window!="undefined"&&document.querySelector('link[href*="assets/"], script[src*="assets/"]');return!!(t&&!n)}catch{return!1}}async function os(){try{if(typeof window!="undefined"){let i=await fetch("./build-settings.json");if(i.ok){let e=await i.json();return console.log("[AssetLoader] Loaded build settings:",e),e}}}catch{}return null}function ls(){try{if(typeof window!="undefined"){let i=new XMLHttpRequest;if(i.open("GET","./build-settings.json",!1),i.send(),i.status===200&&i.responseText){let e=JSON.parse(i.responseText);return console.log("[AssetLoader] Loaded build settings (sync):",e),e}}}catch{}return null}async function cs(){if(console.log(`[AssetLoader] getInlineAssets() called - Effective mode: ${I}`),Object.keys(he).length>0)return console.log("[AssetLoader] Returning cached inline assets:",Object.keys(he)),he;if(typeof window!="undefined"&&window.INLINE_ASSETS)return console.log("[AssetLoader] Using pre-loaded INLINE_ASSETS from window:",Object.keys(window.INLINE_ASSETS)),he={...window.INLINE_ASSETS},he;if(!(I==="publish"&&ce!==!1))return console.log("[AssetLoader] Inline assets disabled for this build mode."),he;if(!wi){let e=typeof window!="undefined"?new URL("inline-assets.js",window.location.href).href:"./inline-assets.js";console.log("[AssetLoader] Loading inline assets from:",e),wi=(async()=>{try{try{let s=await import(e+"?t="+Date.now());if(s.INLINE_ASSETS)return console.log("[AssetLoader] Loaded INLINE_ASSETS via ES module:",Object.keys(s.INLINE_ASSETS)),s.INLINE_ASSETS}catch(s){console.warn("[AssetLoader] ES module import failed, trying text parse:",s)}let t=await fetch(e);if(!t.ok)throw new Error(`HTTP ${t.status}: ${t.statusText}`);let n=await t.text();console.log("[AssetLoader] Received JS code, length:",n.length);let a=n.match(/export\s+const\s+INLINE_ASSETS\s*=\s*({[\s\S]*?});?\s*$/m);if(a)try{let s=a[1];console.log("[AssetLoader] Found INLINE_ASSETS export, parsing...");let r=new Function("return "+s)();return console.log("[AssetLoader] Parsed inline assets:",Object.keys(r)),r}catch(s){return console.warn("[AssetLoader] Failed to parse inline assets:",s),{}}else return console.warn("[AssetLoader] INLINE_ASSETS export not found in response"),console.log("[AssetLoader] JS code preview:",n.substring(0,500)),{}}catch(t){return console.warn("[AssetLoader] Failed to load inline assets:",t),{}}})()}return he=await wi,console.log("[AssetLoader] Final inline assets cache:",Object.keys(he)),he}function xi(i){return i===null||typeof i!="object"||(Object.freeze(i),Object.values(i).forEach(e=>xi(e))),i}function ds(i=64,e=64,t=16711680){let n=document.createElement("canvas");n.width=i,n.height=e;let a=n.getContext("2d");return a.fillStyle=`#${t.toString(16).padStart(6,"0")}`,a.fillRect(0,0,i,e),a.strokeStyle="#000",a.strokeRect(0,0,i,e),a.fillStyle="#fff",a.font="10px sans-serif",a.textAlign="center",a.fillText("MISSING",i/2,e/2),fe.Texture.from(n)}function Dt(i,e){Qn.set(i,e)}var fe,Jn,Zn,ze,I,ce,ke,he,wi,Qn,Pe,Ht=ge(()=>{"use strict";fe=require("pixi.js");vi();Jn=typeof __BUILD_MODE__!="undefined"?__BUILD_MODE__:"undefined",Zn=rs(),ze=typeof window!="undefined"?window.__BUILD_SETTINGS__:null,I=Zn?"publish":Jn,ce=ze==null?void 0:ze.assetsInlined;ze!=null&&ze.buildMode&&(I=ze.buildMode,console.log(`[AssetLoader] Build mode overridden by inline settings: ${I}`));ke=ls();ke!=null&&ke.buildMode&&(I=ke.buildMode,console.log(`[AssetLoader] Build mode overridden by sync settings: ${I}`));(ke==null?void 0:ke.assetsInlined)!==void 0&&(ce=ke.assetsInlined);os().then(i=>{i!=null&&i.buildMode&&i.buildMode!==I&&(I=i.buildMode,console.log(`[AssetLoader] Build mode overridden by settings: ${I}`)),(i==null?void 0:i.assetsInlined)!==void 0&&(ce=i.assetsInlined)}).catch(()=>{});console.log(`[AssetLoader] MODULE LOADED - Compile: ${Jn}, Runtime: ${Zn?"publish":"dev"}, Effective: ${I}`);he={},wi=null;Qn=new Map;Pe=class{static async load(e,t,n,a){let s=`${e}:${t.path}`,r=le.get(s);if(r!==void 0)return r;console.log(`[AssetLoader] Loading asset: ${e}, type: ${t.type}, Effective mode: ${I}`),console.log(`[AssetLoader] Window defined: ${typeof window!="undefined"}, INLINE_ASSETS exists: ${!!(typeof window!="undefined"&&window.INLINE_ASSETS)}, keys: ${typeof window!="undefined"&&window.INLINE_ASSETS?Object.keys(window.INLINE_ASSETS).length:"N/A"}`);let o=await cs(),c=o[e];if(!c&&a&&(c=o[a],c&&console.log(`[AssetLoader] Found inline data for ${e} using configId: ${a}`)),!c&&t.path){let d=t.path.split("/");if(d.length>=2){let p=d[d.length-1].split(".")[0];o[p]&&(c=o[p],console.log(`[AssetLoader] Found inline data for ${e} using assetName: ${p}`))}}if(console.log("[AssetLoader] Inline data for",e,":",c?"FOUND":"NOT FOUND"),I==="publish"&&ce!==!1&&(console.log("[AssetLoader] \u26A0\uFE0F PUBLISH MODE DETECTED - inline assets are MANDATORY"),!c))throw new Error(`[AssetLoader] PUBLISH MODE: Inline asset required but NOT FOUND for object: ${e}, path: ${t.path}`);let u=Qn.get(t.type);if(u)try{let d=await u(t.path,c,e,n);return le.set(s,d),d}catch(d){return this.handleFailure(e,t.type,d)}try{let d;switch(t.type){case"image":d=await this.loadImage(t.path,c);break;case"json":d=await this.loadJSON(t.path,c),d=xi(d);break;default:throw new Error(`Unknown asset type: ${t.type}`)}return le.set(s,d),d}catch(d){return this.handleFailure(e,t.type,d)}}static async loadImage(e,t){let n=I==="publish",a=n&&ce!==!1;if(console.log(`[AssetLoader] loadImage - Effective mode: ${I}, isPublishMode: ${n}, inlineData: ${t?"EXISTS":"MISSING"}`),a){if(console.log("[AssetLoader] PUBLISH MODE ACTIVATED - inline assets are MANDATORY"),!t)throw new Error(`[AssetLoader] Publish mode: inline asset required but not found for object. Path: ${e}`);if(typeof t!="string"||!t.startsWith("data:"))throw new Error(`[AssetLoader] Publish mode: inline asset must be data URI string, got: ${typeof t}`);try{return await fe.Assets.load(t)}catch(s){throw console.error("[AssetLoader] Failed to load texture from data URI:",s),s}}if(t&&typeof t=="string"&&t.startsWith("data:"))try{return await fe.Assets.load(t)}catch(s){return console.error("[AssetLoader] Failed to load texture from data URI, falling back to path:",s),await fe.Assets.load(e)}return await fe.Assets.load(e)}static async loadJSON(e,t){let n=I==="publish",a=n&&ce!==!1;if(console.log(`[AssetLoader] loadJSON - Effective mode: ${I}, isPublishMode: ${n}, inlineData: ${t?"EXISTS":"MISSING"}`),a){if(console.log("[AssetLoader] PUBLISH MODE ACTIVATED - inline assets are MANDATORY"),!t)throw new Error(`[AssetLoader] Publish mode: inline asset required but not found for path: ${e}`);if(typeof t=="object"&&t!==null)return t;if(typeof t=="string"&&t.startsWith("data:")){let r=atob(t.split(",")[1]);return JSON.parse(r)}return JSON.parse(t)}if(t){if(typeof t=="object"&&t!==null)return t;if(typeof t=="string"&&t.startsWith("data:")){let r=atob(t.split(",")[1]);return JSON.parse(r)}return JSON.parse(t)}let s=await fetch(e);if(!s.ok)throw new Error(`JSON fetch failed: ${e}`);return s.json()}static handleFailure(e,t,n){if(I==="dev"){let s=t==="image"?ds():xi({__placeholder:!0,type:t});return le.set(e+":"+((n==null?void 0:n.path)||"missing"),s),s}throw n}};Dt("image",async(i,e)=>{let t=I==="publish",n=t&&ce!==!1,a=I==="brand",s=t&&ce===!1;if(console.log(`[AssetLoader] registerType('image') - Effective mode: ${I}, isPublishMode: ${t}, isBrandMode: ${a}, inlineData: ${e?"EXISTS":"MISSING"}`),n){if(console.log("[AssetLoader] PUBLISH MODE ACTIVATED - inline assets are MANDATORY"),!e)throw new Error(`[AssetLoader] Publish mode: inline asset required but not found for path: ${i}`);if(typeof e!="string"||!e.startsWith("data:"))throw new Error(`[AssetLoader] Publish mode: inline asset must be data URI string, got: ${typeof e}`);return fe.Assets.load(e)}let r=i;return(a||s)&&i&&!i.startsWith("assets/")&&(typeof window!="undefined"&&!document.querySelector('link[href*="assets/"], script[src*="assets/"]')&&!document.querySelector('link[href*="configs/"], script[src*="configs/"]')?(r=i,console.log(`[AssetLoader] BRAND MODE: flattened build, using path "${i}" as-is`)):(r=`assets/${i}`,console.log(`[AssetLoader] BRAND MODE: transformed path "${i}" -> "${r}"`))),fe.Assets.load(e||r)});Dt("json",async(i,e)=>{let t=I==="publish",n=t&&ce!==!1,a=I==="brand",s=t&&ce===!1;if(console.log(`[AssetLoader] registerType('json') - Effective mode: ${I}, isPublishMode: ${t}, isBrandMode: ${a}, inlineData: ${e?"EXISTS":"MISSING"}`),n){if(console.log("[AssetLoader] PUBLISH MODE ACTIVATED - inline assets are MANDATORY"),!e)throw new Error(`[AssetLoader] Publish mode: inline asset required but not found for path: ${i}`);return typeof e=="object"&&e!==null?e:typeof e=="string"&&e.startsWith("data:")?JSON.parse(atob(e.split(",")[1])):JSON.parse(e)}let r=i;if((a||s)&&i&&!i.startsWith("assets/")&&(typeof window!="undefined"&&!document.querySelector('link[href*="assets/"], script[src*="assets/"]')&&!document.querySelector('link[href*="configs/"], script[src*="configs/"]')?(r=i,console.log(`[AssetLoader] BRAND MODE: flattened build, using path "${i}" as-is`)):(r=`assets/${i}`,console.log(`[AssetLoader] BRAND MODE: transformed path "${i}" -> "${r}"`))),e)return typeof e=="object"&&e!==null?e:typeof e=="string"&&e.startsWith("data:")?JSON.parse(atob(e.split(",")[1])):JSON.parse(e);let o=await fetch(r);if(!o.ok)throw new Error(`JSON fetch failed: ${i}`);return o.json()})});function Nt(i,e){ea.init(i,e),typeof window!="undefined"&&(window.__AssetTextures=Me)}var Si,ea,Me,vt=ge(()=>{"use strict";Ht();Si=class{constructor(){this.textures=new Map;this.readyPromise=null;this.priorityReadyPromise=null;this.priorityReadyResolve=null;this.config=null;this.app=null;this.attempted=new Set;this.waiters=new Set}init(e,t){if(this.config===e&&this.app===t&&this.priorityReadyPromise){console.log("[AssetTextures] init called with same config/app; keeping existing state");return}this.textures.clear(),this.readyPromise=null,this.priorityReadyPromise=null,this.priorityReadyResolve=null,this.attempted.clear(),this.waiters.clear(),this.priorityReadyPromise=new Promise(n=>{this.priorityReadyResolve=n}),this.config=e,this.app=t,console.log("[AssetTextures] Initialized with config, cleared previous textures")}async ready(){if(this.readyPromise){await this.readyPromise;return}if(!this.config)throw new Error("[AssetTextures] Must call init() before ready() - config is null");if(!this.app)throw new Error("[AssetTextures] Must call init() before ready() - app is null");let e=this.config,t=this.app;return this.readyPromise=(async()=>{var r;console.log("[AssetTextures] Loading all assets...");let n=new Set(["background_loading_1"]),a=[],s=[];for(let[o,c]of e.objects.entries()){let l=(r=c.render)==null?void 0:r.asset;if(!l)continue;let u=async()=>{var d;try{let p=(d=c.identity)==null?void 0:d.id;console.log(`[AssetTextures] Loading ${l.type}: ${o} (${p})`);let g=await Pe.load(o,l,t,p);this.textures.set(o,g),console.log(`[AssetTextures] \u2713 Loaded: ${o}`)}catch(p){console.error(`[AssetTextures] \u2717 Failed to load: ${o}`,p)}finally{this.attempted.add(o);try{for(let p of Array.from(this.waiters))p()}catch{}}};n.has(o)?a.push(u()):s.push(u())}a.length>0&&(console.log("[AssetTextures] Phase 1: Loading priority assets (loading screen)..."),await Promise.all(a),console.log("[AssetTextures] Phase 1: Priority assets ready")),this.priorityReadyResolve&&this.priorityReadyResolve(),console.log("[AssetTextures] Phase 2: Loading remaining assets..."),await Promise.all(s),console.log("[AssetTextures] All textures loaded:",Array.from(this.textures.keys()))})(),this.readyPromise}async priorityReady(){return this.priorityReadyPromise?this.priorityReadyPromise:Promise.resolve()}async waitFor(e,t={}){if(!this.config)throw new Error("[AssetTextures] Must call init() before waitFor() - config is null");if(!this.app)throw new Error("[AssetTextures] Must call init() before waitFor() - app is null");let a=Array.from(new Set((e||[]).filter(o=>typeof o=="string"&&o))).filter(o=>{var c,l,u,d;try{let p=(u=(l=(c=this.config)==null?void 0:c.objects)==null?void 0:l.get)==null?void 0:u.call(l,o);return!!((d=p==null?void 0:p.render)!=null&&d.asset)}catch{return!1}});if(a.length===0)return;this.ready().catch(()=>{});let s=()=>a.every(o=>this.textures.has(o)||this.attempted.has(o));if(s())return;let r=typeof t.timeoutMs=="number"?t.timeoutMs:15e3;await new Promise(o=>{let c=!1,l=()=>{c||s()&&(c=!0,this.waiters.delete(l),o())};this.waiters.add(l),l(),r>0&&setTimeout(()=>{c||(c=!0,this.waiters.delete(l),console.warn("[AssetTextures] waitFor timed out; continuing",{ids:a}),o())},r)})}get(e){return this.textures.get(e)}set(e,t){this.textures.set(e,t),console.log(`[AssetTextures] Updated texture: ${e}`)}clear(){this.textures.clear(),this.readyPromise=null,console.log("[AssetTextures] Cleared all textures")}getAllIds(){return Array.from(this.textures.keys())}},ea=new Si,Me=new Proxy(ea,{get(i,e){return e in i&&typeof i[e]=="function"?i[e].bind(i):i.get(e)},set(i,e,t){return i.set(e,t),!0}})});var na={};cn(na,{AssetEditorModal:()=>Ti});var Ti,ki=ge(()=>{"use strict";Ti=class{constructor(){this.modal=null;this.currentObjectId=null;this.currentPath=null;this.currentAsset="";this.onApplyCallback=null}show(e,t,n,a){this.currentObjectId=e,this.currentPath=t,this.currentAsset=n,this.onApplyCallback=a,this.createModal(e,n),document.body.appendChild(this.modal),this.attachModalListeners()}createModal(e,t){let n=document.createElement("div");n.className="asset-editor-modal",n.innerHTML=`
2
2
  <div class="asset-editor-card">
3
3
  <div class="asset-editor-header">
4
4
  <div>
@@ -43,7 +43,7 @@
43
43
  <button class="debug-btn primary" data-modal-apply>Apply</button>
44
44
  </div>
45
45
  </div>
46
- `,this.modal=n}attachModalListeners(){if(!this.modal)return;this.modal.querySelectorAll("[data-modal-close]").forEach(r=>{r.addEventListener("click",()=>this.close())}),this.modal.querySelectorAll("[data-tab]").forEach(r=>{r.addEventListener("click",o=>{let d=o.target.dataset.tab;d&&this.switchTab(d)})});let n=this.modal.querySelector("[data-ai-generate]");n==null||n.addEventListener("click",()=>{this.openAiEditor("generate")});let a=this.modal.querySelector("[data-ai-edit]");a==null||a.addEventListener("click",()=>{this.openAiEditor("edit")});let s=this.modal.querySelector("[data-modal-apply]");s==null||s.addEventListener("click",()=>{this.apply()}),this.modal.addEventListener("click",r=>{r.target===this.modal&&this.close()})}switchTab(e){if(!this.modal)return;this.modal.querySelectorAll("[data-tab]").forEach(a=>{a.classList.toggle("active",a.getAttribute("data-tab")===e)}),this.modal.querySelectorAll("[data-tab-panel]").forEach(a=>{a.classList.toggle("active",a.getAttribute("data-tab-panel")===e)})}openAiEditor(e){let t=window.__openAiEditor;if(typeof t!="function"){alert("AI Editor not available. Please check your setup.");return}let n="";e==="edit"&&this.currentAsset?n=`Edit this image: ${this.currentObjectId}`:n=`Create an image for: ${this.currentObjectId}`,t(this.currentObjectId||"unknown",n,this.currentAsset,{path:this.currentPath,onApply:a=>{this.onApplyCallback&&this.onApplyCallback(a),this.close()}})}apply(){this.onApplyCallback&&this.onApplyCallback("library/placeholder.png"),this.close()}close(){this.modal&&this.modal.parentNode&&this.modal.parentNode.removeChild(this.modal),this.modal=null,this.currentObjectId=null,this.currentPath=null,this.onApplyCallback=null}}});var Gs={};Wi(Gs,{AssetCache:()=>se,AssetLoader:()=>Le,AssetSystem:()=>ai,AssetTextures:()=>Te,Assets:()=>ba,BaseSystem:()=>tt,GameEngine:()=>ni,GameObject:()=>Tt,GameObjectManager:()=>Qe,ObjectFactory:()=>ue,Renderer:()=>Lt,RuntimeObjectRegistry:()=>it,Transform:()=>At,applyScreenAnchor:()=>Bt,basePixi:()=>ga,clearResponsiveElements:()=>Gn,createPixiBase:()=>ti,getRegisteredFontIds:()=>ca,globalResponsiveMultipliers:()=>bt,initAssetTextures:()=>Ht,initAssets:()=>ya,layout:()=>qn,playLottieOverlay:()=>pa,registerFont:()=>la,registerType:()=>$t,resolveAnchorVec2:()=>ke,resolveFont:()=>ra,resolveFontWeight:()=>oa,resolveScreenAnchorPoint:()=>$e,resolveScreenRatioPoint:()=>De,runInitSequence:()=>va,setLottieInstance:()=>Kt,spawnSceneFromConfig:()=>fa,updateScreenState:()=>Ft});module.exports=Aa(Gs);var sa=require("pixi.js");var Ce={};function jt(i,e,t=!1){Ce[i]||(Ce[i]=[]),Ce[i].push({fn:e,once:t})}function oi(i,e){if(Ce[i]){if(!e){delete Ce[i];return}Ce[i]=Ce[i].filter(t=>t.fn!==e)}}function _t(i,...e){let t=Ce[i];if(t)for(let n of[...t])n.fn(...e),n.once&&oi(i,n.fn)}function J(i,e){jt(i,e,!0)}var $=null,ee=[],Be=null;function Ji(i){$=i,ee=[],Be!==null&&(clearTimeout(Be),Be=null)}function Zi(){var i,e,t;return{endpoint:($==null?void 0:$.endpoint)||"",transport:($==null?void 0:$.transport)||"beacon",batchSize:(i=$==null?void 0:$.batchSize)!=null?i:10,flushIntervalMs:(e=$==null?void 0:$.flushIntervalMs)!=null?e:300,maxQueue:(t=$==null?void 0:$.maxQueue)!=null?t:200,debug:!!($!=null&&$.debug)}}async function Ki(i,e,t,n){let a=JSON.stringify(e);if(t==="beacon"&&typeof navigator!="undefined"&&typeof navigator.sendBeacon=="function")try{let s=navigator.sendBeacon(i,new Blob([a],{type:"application/json"}));n&&console.log("[handler.telemetry] beacon",s,e);return}catch(s){n&&console.warn("[handler.telemetry] beacon failed, fallback to fetch",s)}try{await fetch(i,{method:"POST",headers:{"Content-Type":"application/json"},body:a,keepalive:!0}),n&&console.log("[handler.telemetry] fetch",e)}catch(s){n&&console.warn("[handler.telemetry] fetch failed",s)}}function li(i,e){let t=Zi();if(e&&t.endpoint){if(ee.push(i),ee.length>t.maxQueue&&(ee=ee.slice(ee.length-t.maxQueue)),ee.length>=t.batchSize){Xi();return}Be===null&&(Be=window.setTimeout(()=>{Be=null,Xi()},t.flushIntervalMs))}}async function Xi(){let i=Zi();if(!i.endpoint||ee.length===0)return;let e=ee.splice(0,i.batchSize);await Ki(i.endpoint,{events:e},i.transport,i.debug),ee.length>0&&await Ki(i.endpoint,{events:ee.splice(0,i.batchSize)},i.transport,i.debug)}function Qi(i){return Math.max(0,Math.min(1,i))}function La(i){let e=String(i!=null?i:"power2.out");if(e==="linear")return t=>t;if(e==="sine.inOut")return t=>.5-Math.cos(Math.PI*t)/2;if(e==="power2.out"||e==="easeOutQuad")return t=>1-(1-t)*(1-t);if(e.startsWith("back.out")){let t=e.match(/back\.out\(([\d.]+)\)/),n=t?Number(t[1]):1.8;return a=>1+(n+1)*Math.pow(a-1,3)+n*Math.pow(a-1,2)}return t=>1-(1-t)*(1-t)}function gt(){return typeof performance!="undefined"&&performance.now?performance.now():Date.now()}function Ta(i,e){let t=i==null?void 0:i[e];return typeof t=="number"?t:0}function en(i,e,t){try{i[e]=t}catch{}}function ka(i){let e=i==null?void 0:i.scale;if(!e)return null;let t=typeof e.x=="number"?e.x:1,n=typeof e.y=="number"?e.y:1;return{x:t,y:n}}function tn(i,e){let t=i==null?void 0:i.scale;if(t)try{typeof t.set=="function"?t.set(e.x,e.y):(typeof t.x=="number"&&(t.x=e.x),typeof t.y=="number"&&(t.y=e.y))}catch{}}function nn(i,e){let t=ka(i);if(!t)return{from:null,to:null};let n=null,a=null;return typeof e.scale=="number"?(n=e.scale,a=e.scale):e.scale&&typeof e.scale=="object"&&(typeof e.scale.x=="number"&&(n=e.scale.x),typeof e.scale.y=="number"&&(a=e.scale.y)),typeof e.scaleX=="number"&&(n=e.scaleX),typeof e.scaleY=="number"&&(a=e.scaleY),n===null&&a===null?{from:null,to:null}:{from:{x:t.x,y:t.y},to:{x:n!=null?n:t.x,y:a!=null?a:t.y}}}function an(){let i=new Set,e=new WeakMap,t=null,n=()=>{if(t!=null)return;t=requestAnimationFrame(()=>{t=null,o(),i.size>0&&n()})},a=u=>{var p;i.add(u);let c=(p=e.get(u.target))!=null?p:new Set;c.add(u),e.set(u.target,c),n()},s=u=>{i.delete(u);let c=e.get(u.target);c&&(c.delete(u),c.size===0&&e.delete(u.target))},r=u=>{u.killed||(u.killed=!0,s(u))},o=()=>{var c,p;let u=gt();for(let g of Array.from(i)){if(g.killed||g.paused)continue;let m=u-g.startMs-g.delayMs;if(m<0)continue;let f=g.durationMs>0?m/g.durationMs:1,C=Qi(f),b=g.repeat>=0?g.repeat+1:1,h=g.repeat>0?Math.min(Math.floor(f),b-1):0;if(g.repeat>0&&f>=1){let y=f-h;C=Qi(y)}let v=g.ease(C);g.yoyo&&h%2===1&&(v=1-v);for(let y of g.props)en(g.target,y.key,y.from+(y.to-y.from)*v);g.scaleFrom&&g.scaleTo&&tn(g.target,{x:g.scaleFrom.x+(g.scaleTo.x-g.scaleFrom.x)*v,y:g.scaleFrom.y+(g.scaleTo.y-g.scaleFrom.y)*v});try{(c=g.onUpdate)==null||c.call(g)}catch{}if(f>=b){r(g);try{(p=g.onComplete)==null||p.call(g)}catch{}}}},l=(u,c,p)=>{var y;let g=Math.max(0,(typeof c.duration=="number"?c.duration:.5)*1e3),m=Math.max(0,(typeof c.delay=="number"?c.delay:0)*1e3+((y=p==null?void 0:p.delayMsOverride)!=null?y:0)),f=La(c.ease),C=typeof c.repeat=="number"?Math.max(0,c.repeat|0):0,b=c.yoyo===!0,h=new Set(["duration","delay","ease","repeat","yoyo","onUpdate","onComplete","scale","scaleX","scaleY"]),v=[];for(let P of Object.keys(c)){if(h.has(P))continue;let j=c[P];typeof j=="number"&&v.push({key:P,from:Ta(u,P),to:j})}let w=nn(u,c);return{target:u,startMs:gt(),delayMs:m,durationMs:g,ease:f,props:v,scaleFrom:w.from,scaleTo:w.to,repeat:C,yoyo:b,onUpdate:typeof c.onUpdate=="function"?c.onUpdate:void 0,onComplete:typeof c.onComplete=="function"?c.onComplete:void 0,killed:!1,paused:!1,pauseAtMs:null}},d={to(u,c){let p=l(u,c);return a(p),{kill:()=>r(p),pause:()=>{p.paused||(p.paused=!0,p.pauseAtMs=gt())},resume:()=>{var f;if(!p.paused)return;let g=(f=p.pauseAtMs)!=null?f:gt(),m=gt()-g;p.startMs+=m,p.paused=!1,p.pauseAtMs=null},isActive:()=>!p.killed&&!p.paused}},fromTo(u,c,p){return d.set(u,c),d.to(u,p)},set(u,c){if(!u||!c)return;for(let g of Object.keys(c)){let m=c[g];g==="scale"||g==="scaleX"||g==="scaleY"||typeof m=="number"&&en(u,g,m)}let p=nn(u,c);p.to&&tn(u,p.to)},killTweensOf(u){let c=e.get(u);if(c)for(let p of Array.from(c))r(p)},timeline(u={}){let c=[],p=0,g=!1,m=[],f=h=>{if(typeof h=="number")return Math.max(0,h*1e3);let v=typeof h=="string"?h.trim():"";return v.startsWith("+=")?p+Math.max(0,Number(v.slice(2))*1e3||0):v?Math.max(0,Number(v)*1e3||0):p},C=h=>{c.push(h);let v=Math.max(0,(typeof h.vars.duration=="number"?h.vars.duration:.5)*1e3);p=Math.max(p,h.atMs+v)},b={to(h,v,w){return C({kind:"to",target:h,vars:v,atMs:f(w)}),b},fromTo(h,v,w,y){return C({kind:"fromTo",target:h,vars:w,from:v,atMs:f(y)}),b},play(){var h,v;if(g)return b;g=!0,m=[];for(let w of c)w.kind==="fromTo"&&d.set(w.target,(h=w.from)!=null?h:{}),m.push(d.to(w.target,{...w.vars,delay:w.atMs/1e3+((v=w.vars.delay)!=null?v:0)}));return b},pause(){for(let h of m)h.pause();return b},kill(){for(let h of m)h.kill();m=[],g=!1}};return u.paused||b.play(),b}};return d}function sn(){if(typeof window=="undefined")return;let i=window;if(!i.gsap)try{i.gsap=an()}catch{}}var rn={name:"handler-playable-sdk",version:"1.0.8",type:"module",description:"Handler Playable SDK v0.1 with contract-aligned surface (root sandbox, canonical event envelope).",main:"dist/index.cjs",module:"dist/index.js",types:"dist/index.d.ts",exports:{".":{types:"./dist/index.d.ts",import:"./dist/index.js",require:"./dist/index.cjs"},"./pixi":{types:"./dist/pixi/index.d.ts",import:"./dist/pixi/index.js",require:"./dist/pixi/index.cjs"},"./pixi/index.css":{import:"./dist/pixi/index.css",require:"./dist/pixi/index.css"},"./three":{types:"./dist/three/index.d.ts",import:"./dist/three/index.js",require:"./dist/three/index.cjs"},"./cli":{types:"./dist/cli/index.d.ts",import:"./dist/cli/index.js",require:"./dist/cli/index.cjs"}},bin:{"handler-student-helper":"./bin/student-helper.mjs","handler-validate":"./bin/validate.mjs","handler-sync-screens":"./bin/sync-screens.mjs","handler-brand-dna":"./bin/brand-dna.mjs","handler-setup-library":"./bin/setup-library.mjs","handler-screen-helper":"./bin/screen-helper.mjs"},scripts:{prebuild:"python3 src/preview/build-css.py",build:"tsup src/index.ts src/pixi/index.ts src/three/index.ts src/cli/index.ts --format cjs,esm --dts --clean --minify --external lottie-web --external jszip && npm run create-mjs-symlinks && npm run postbuild-cli && npm run obfuscate && npm run postbuild",postbuild:"python3 src/preview/copy-css-to-dist.py","postbuild-cli":"cp src/cli/*.mjs dist/cli/ && chmod +x dist/cli/*.mjs && chmod +x bin/*.mjs","create-mjs-symlinks":"cd dist && ln -sf index.js index.mjs && cd pixi && ln -sf index.js index.mjs && cd ../three && ln -sf index.js index.mjs","build:dev":"tsup src/index.ts src/pixi/index.ts src/three/index.ts src/cli/index.ts --format cjs,esm --dts --clean --external lottie-web --external jszip && npm run create-mjs-symlinks && npm run postbuild-cli",obfuscate:"javascript-obfuscator dist/pixi/index.js --output dist/pixi/index.js --config obfuscator.config.json && javascript-obfuscator dist/three/index.js --output dist/three/index.js --config obfuscator.config.json && javascript-obfuscator dist/cli/index.js --output dist/cli/index.js --config obfuscator.config.json && npm run obfuscate-cli","obfuscate-cli":'for file in dist/cli/*.mjs; do javascript-obfuscator "$file" --output "$file" --config obfuscator.config.json; done',lint:"eslint 'src/**/*.{ts,tsx}'",typecheck:"tsc --noEmit",prepublishOnly:"npm run build","publish:update":"node scripts/publish-and-update.cjs patch","publish:update:minor":"node scripts/publish-and-update.cjs minor","publish:update:major":"node scripts/publish-and-update.cjs major"},author:"Handler",license:"MIT",publishConfig:{access:"public"},repository:{type:"git",url:"https://github.com/HandlerAIGames/handler-playable-sdk.git"},files:["dist","bin","LICENSE","README.md"],peerDependencies:{"lottie-web":"^5.0.0","pixi.js":"^8.0.0",three:"^0.182.0"},peerDependenciesMeta:{"pixi.js":{optional:!0},three:{optional:!0},"lottie-web":{optional:!0}},devDependencies:{"@types/three":"^0.182.0",eslint:"^9.39.2","javascript-obfuscator":"^5.1.0","pixi.js":"8.8.1",three:"^0.182.0","ts-node":"^10.9.2",tsup:"^8.4.0",typescript:"^5.7.2","typescript-eslint":"^8.53.0"},dependencies:{"@google/genai":"^1.35.0","@google/generative-ai":"^0.24.1",jszip:"^3.10.1",sharp:"^0.34.5"}};var Z=0,Ia=Z++,on=Z++,ln=Z++,cn=Z++,dn=Z++,pn=Z++,un=Z++,gn=Z++,hn=Z++,fn=Z++,mn=Z++,bn=Z++,O=Ia;function yn(){return O===on}function vn(){return O===ln}function wn(){return O===cn}function xn(){return O===dn}function Ge(){return O===pn}function Ue(){return O===un}function Sn(){return O===gn}function En(){return O===hn}function Cn(){return O===fn}function ci(){return O===mn}function di(){return O===bn}function An(){let i=typeof AD_PROTOCOL!="undefined"?AD_PROTOCOL:"none",e=typeof AD_NETWORK!="undefined"?AD_NETWORK:"web_embed";if(i==="mraid")try{mraid.getState(),O=on;return}catch{}else if(i==="dapi")try{dapi.isReady(),O=ln;return}catch{}if(e==="facebook")try{typeof FbPlayableAd!="undefined"&&(O=cn)}catch{}else if(e==="google")try{typeof ExitApi!="undefined"&&(O=dn)}catch{}else if(e==="mintegral")window.gameReady&&(O=pn);else if(e==="tapjoy")window.TJ_API&&(O=un);else if(e==="tiktok")window.openAppStore&&(O=gn);else if(e==="smadex")try{window.smxTracking&&(O=hn)}catch{}else if(e==="snapchat")try{window.ScPlayableAd&&(O=fn)}catch{}else e==="vungle"?O=mn:(i==="nucleo"||e==="nucleo")&&(O=bn)}var Ot=ri(require("lottie-web"),1),Ln=Ot.default;typeof window!="undefined"&&(window.lottie=Ot.default,window.__baseLottie=Ot.default);gi();function D(i,e){let t=(a,s)=>s===0?a:t(s,a%s),n=t(i,e);return`${i/n}:${e/n}`}var Sr=[{id:"iphone-15-pro-max",label:"iPhone 15 Pro Max",width:430,height:932,category:"iphone",ratio:D(430,932)},{id:"iphone-15-pro",label:"iPhone 15 Pro",width:393,height:852,category:"iphone",ratio:D(393,852)},{id:"iphone-15",label:"iPhone 15",width:393,height:852,category:"iphone",ratio:D(393,852)},{id:"iphone-14",label:"iPhone 14",width:390,height:844,category:"iphone",ratio:D(390,844)},{id:"iphone-se",label:"iPhone SE",width:375,height:667,category:"iphone",ratio:D(375,667)},{id:"iphone-12-mini",label:"iPhone 12 Mini",width:360,height:780,category:"iphone",ratio:D(360,780)}],Er=[{id:"pixel-8-pro",label:"Pixel 8 Pro",width:448,height:998,category:"android",ratio:D(448,998)},{id:"pixel-8",label:"Pixel 8",width:412,height:915,category:"android",ratio:D(412,915)},{id:"samsung-s24-ultra",label:"Samsung S24 Ultra",width:412,height:915,category:"android",ratio:D(412,915)},{id:"samsung-s24",label:"Samsung S24",width:360,height:780,category:"android",ratio:D(360,780)},{id:"samsung-a54",label:"Samsung A54",width:412,height:915,category:"android",ratio:D(412,915)},{id:"oneplus-12",label:"OnePlus 12",width:412,height:915,category:"android",ratio:D(412,915)}],Cr=[{id:"ipad-pro-12",label:'iPad Pro 12.9"',width:1024,height:1366,category:"tablet",ratio:D(1024,1366)},{id:"ipad-pro-11",label:'iPad Pro 11"',width:834,height:1194,category:"tablet",ratio:D(834,1194)},{id:"ipad-air",label:"iPad Air",width:820,height:1180,category:"tablet",ratio:D(820,1180)},{id:"ipad-mini",label:"iPad Mini",width:768,height:1024,category:"tablet",ratio:D(768,1024)},{id:"samsung-tab-s9",label:"Samsung Tab S9",width:800,height:1280,category:"tablet",ratio:D(800,1280)}],In=[{id:"playable-portrait",label:"Playable Portrait",width:320,height:480,category:"playable",ratio:"2:3",mraidScale:1},{id:"mraid-320x480",label:"MRAID 320\xD7480",width:320,height:480,category:"playable",ratio:"2:3",mraidScale:1},{id:"iphone-14",label:"iPhone 14",width:390,height:844,category:"playable",ratio:D(390,844),mraidScale:.7},{id:"ipad-mini",label:"iPad Mini",width:768,height:1024,category:"playable",ratio:D(768,1024),mraidScale:.7}];var Ar=[...In];var Da=In[0];ae();function Ha(i){return new Promise((e,t)=>{let n=new FileReader;n.onerror=()=>t(new Error("FileReader failed")),n.onload=()=>e(String(n.result||"")),n.readAsDataURL(i)})}function Na(i){var a;let[e,t]=i.split(","),n=e==null?void 0:e.match(/data:(.*?);base64/);return{base64:t!=null?t:"",mimeType:(a=n==null?void 0:n[1])!=null?a:"image/png"}}async function Fa(i){return await new Promise(e=>{let t=new Image;t.onload=()=>e({width:t.naturalWidth||t.width,height:t.naturalHeight||t.height}),t.onerror=()=>e(null),t.src=i})}async function hi(i){var e,t;try{console.log("[ImageUtils] Fetching image data from URL:",i);let n=await fetch(i);if(!n.ok)return console.warn("[ImageUtils] Fetch failed with status:",n.status,i),null;let a=await n.blob();console.log("[ImageUtils] Blob received, size:",a.size,"type:",a.type);let s=await Ha(a),r=await Fa(s),o=Na(s);return console.log("[ImageUtils] Success resolution:",r==null?void 0:r.width,"x",r==null?void 0:r.height,"mime:",o.mimeType),{base64:o.base64,mimeType:o.mimeType,dataUrl:s,width:(e=r==null?void 0:r.width)!=null?e:0,height:(t=r==null?void 0:r.height)!=null?t:0}}catch(n){return console.error("[ImageUtils] Error fetching image data:",n),null}}async function Rt(i,e=30){try{console.log("[ImageUtils] Removing background color...");let t=await new Promise((c,p)=>{let g=new Image;g.onload=()=>c(g),g.onerror=()=>p(new Error("Failed to load image")),g.src=i}),n=document.createElement("canvas");n.width=t.width,n.height=t.height;let a=n.getContext("2d");if(!a)return console.error("[ImageUtils] Failed to get canvas context"),i;a.drawImage(t,0,0);let s=a.getImageData(0,0,n.width,n.height),r=s.data,l=[{name:"top-left",offset:0},{name:"top-right",offset:(n.width-1)*4},{name:"bottom-left",offset:(n.height-1)*n.width*4},{name:"bottom-right",offset:((n.height-1)*n.width+(n.width-1))*4}].map(c=>({r:r[c.offset],g:r[c.offset+1],b:r[c.offset+2]})),d=0;for(let c=0;c<r.length;c+=4){let p=r[c],g=r[c+1],m=r[c+2],f=!1;for(let C of l)if(Math.sqrt(Math.pow(p-C.r,2)+Math.pow(g-C.g,2)+Math.pow(m-C.b,2))<e){f=!0;break}f&&(r[c+3]=0,d++)}return console.log(`[ImageUtils] Removed background from ${d} pixels (4-corner sampling, tolerance: ${e})`),a.putImageData(s,0,0),n.toDataURL("image/png")}catch(t){return console.error("[ImageUtils] Error removing background:",t),i}}var _n=require("@google/genai");async function fi(i,e,t=[],n={}){var a,s,r,o,l,d,u;try{if(!(i!=null&&i.trim()))throw new Error("Gemini API key is required");if(!(e!=null&&e.trim()))throw new Error("Prompt is required");for(let b=0;b<t.length;b++){let h=t[b];if(!h.base64||!h.mimeType)throw new Error(`Image ${b+1} is missing required data`);if(h.base64.length<1e3&&console.warn(`Image ${b+1} data appears very small, may be corrupted`),!h.mimeType.startsWith("image/"))throw new Error(`Image ${b+1} has invalid MIME type: ${h.mimeType}`)}let c=new _n.GoogleGenAI({apiKey:i}),p="gemini-2.5-flash",g=[e];t.length>0&&t.forEach((b,h)=>{g.push({inlineData:{data:b.base64,mimeType:b.mimeType}}),console.log(`[Gemini] Added image ${h+1}: ${b.mimeType}, size: ${Math.round(b.base64.length/1024)}KB`)}),console.log(`[Gemini] Making request with ${t.length} images and prompt length: ${e.length}`);let m=await c.models.generateContent({model:p,contents:g}),f="",C=(r=(s=(a=m.candidates)==null?void 0:a[0])==null?void 0:s.content)==null?void 0:r.parts;if(C)for(let b of C)b.text&&(f+=b.text);if(!f.trim())throw new Error("Empty response from Gemini API");return console.log(`[Gemini] Response received, length: ${f.length}`),f}catch(c){throw console.error("[Gemini] API error:",c),(o=c.message)!=null&&o.includes("Unable to process input image")?new Error("Unable to process the uploaded image. Please ensure it's a valid PNG, JPG, or JPEG file under 10MB and not corrupted."):(l=c.message)!=null&&l.includes("API_KEY_INVALID")?new Error("Invalid Gemini API key. Please check your API key configuration."):(d=c.message)!=null&&d.includes("QUOTA_EXCEEDED")?new Error("Gemini API quota exceeded. Please try again later or check your billing."):(u=c.message)!=null&&u.includes("SAFETY")?new Error("Content was flagged by Gemini safety filters. Please try with different images."):c}}var On=require("@google/genai");async function zt(i,e,t=[],n={}){try{console.info("[GEMINI-REAL-SDK] Initializing GoogleGenAI...");let a=new On.GoogleGenAI({apiKey:i}),s=[{text:e}];t.length>0&&t.forEach((o,l)=>{console.info(`[GEMINI-REAL-SDK] Adding image part ${l}`),s.push({inlineData:{mimeType:o.mimeType,data:o.base64}})}),console.info("[GEMINI-REAL-SDK] Calling generateContent with model: gemini-2.5-flash-image");let r=await a.models.generateContent({model:"gemini-2.5-flash-image",contents:s});if(console.info("[GEMINI-REAL-SDK] Received response from model"),!r.candidates||!r.candidates[0]||!r.candidates[0].content||!r.candidates[0].content.parts)throw new Error("Gemini 2.5 Flash Image returned invalid response structure.");for(let o of r.candidates[0].content.parts)if(o.text)console.log(o.text);else if(o.inlineData){let l=o.inlineData.data,d=o.inlineData.mimeType||"image/png";return console.info("[GEMINI-REAL-SDK] Found inline image data in response"),`data:${d};base64,${l}`}throw new Error("Gemini 2.5 Flash Image returned no image data.")}catch(a){throw console.error("[GEMINI-REAL-SDK] Error in generateImageWithGemini25Flash:",JSON.stringify(a,Object.getOwnPropertyNames(a),2)),a}}var Wa=require("pixi.js");ht();ae();var Nn=require("pixi.js");var Ka=require("pixi.js");ae();function ss(i){return new Promise((e,t)=>{let n=new FileReader;n.onerror=()=>t(new Error("FileReader failed")),n.onload=()=>e(String(n.result||"")),n.readAsDataURL(i)})}function rs(i){var a;let[e,t]=i.split(","),n=e==null?void 0:e.match(/data:(.*?);base64/);return{base64:t!=null?t:"",mimeType:(a=n==null?void 0:n[1])!=null?a:"image/png"}}function os(i){return`
46
+ `,this.modal=n}attachModalListeners(){if(!this.modal)return;this.modal.querySelectorAll("[data-modal-close]").forEach(r=>{r.addEventListener("click",()=>this.close())}),this.modal.querySelectorAll("[data-tab]").forEach(r=>{r.addEventListener("click",o=>{let l=o.target.dataset.tab;l&&this.switchTab(l)})});let n=this.modal.querySelector("[data-ai-generate]");n==null||n.addEventListener("click",()=>{this.openAiEditor("generate")});let a=this.modal.querySelector("[data-ai-edit]");a==null||a.addEventListener("click",()=>{this.openAiEditor("edit")});let s=this.modal.querySelector("[data-modal-apply]");s==null||s.addEventListener("click",()=>{this.apply()}),this.modal.addEventListener("click",r=>{r.target===this.modal&&this.close()})}switchTab(e){if(!this.modal)return;this.modal.querySelectorAll("[data-tab]").forEach(a=>{a.classList.toggle("active",a.getAttribute("data-tab")===e)}),this.modal.querySelectorAll("[data-tab-panel]").forEach(a=>{a.classList.toggle("active",a.getAttribute("data-tab-panel")===e)})}openAiEditor(e){let t=window.__openAiEditor;if(typeof t!="function"){alert("AI Editor not available. Please check your setup.");return}let n="";e==="edit"&&this.currentAsset?n=`Edit this image: ${this.currentObjectId}`:n=`Create an image for: ${this.currentObjectId}`,t(this.currentObjectId||"unknown",n,this.currentAsset,{path:this.currentPath,onApply:a=>{this.onApplyCallback&&this.onApplyCallback(a),this.close()}})}apply(){this.onApplyCallback&&this.onApplyCallback("library/placeholder.png"),this.close()}close(){this.modal&&this.modal.parentNode&&this.modal.parentNode.removeChild(this.modal),this.modal=null,this.currentObjectId=null,this.currentPath=null,this.onApplyCallback=null}}});var or={};cn(or,{AssetCache:()=>le,AssetLoader:()=>Pe,AssetSystem:()=>si,AssetTextures:()=>Me,Assets:()=>Oa,BaseSystem:()=>at,GameEngine:()=>ai,GameObject:()=>It,GameObjectManager:()=>it,ObjectFactory:()=>me,Renderer:()=>Mt,RuntimeObjectRegistry:()=>st,Transform:()=>Pt,applyScreenAnchor:()=>Gt,basePixi:()=>Ma,clearResponsiveElements:()=>ra,createPixiBase:()=>ii,getRegisteredFontIds:()=>La,globalResponsiveMultipliers:()=>Ye,initAssetTextures:()=>Nt,initAssets:()=>Ra,layout:()=>la,playLottieOverlay:()=>ka,registerFont:()=>Aa,registerType:()=>Dt,resolveAnchorVec2:()=>Ie,resolveFont:()=>Ea,resolveFontWeight:()=>Ca,resolveScreenAnchorPoint:()=>He,resolveScreenRatioPoint:()=>Ne,runInitSequence:()=>za,setLottieInstance:()=>Xt,spawnSceneFromConfig:()=>ja,updateScreenState:()=>Bt});module.exports=Ga(or);var Sa=require("pixi.js");var Te={};function _t(i,e,t=!1){Te[i]||(Te[i]=[]),Te[i].push({fn:e,once:t})}function di(i,e){if(Te[i]){if(!e){delete Te[i];return}Te[i]=Te[i].filter(t=>t.fn!==e)}}function Ot(i,...e){let t=Te[i];if(t)for(let n of[...t])n.fn(...e),n.once&&di(i,n.fn)}function Z(i,e){_t(i,e,!0)}var D=null,ie=[],Ue=null;function gn(i){D=i,ie=[],Ue!==null&&(clearTimeout(Ue),Ue=null)}function hn(){var i,e,t;return{endpoint:(D==null?void 0:D.endpoint)||"",transport:(D==null?void 0:D.transport)||"beacon",batchSize:(i=D==null?void 0:D.batchSize)!=null?i:10,flushIntervalMs:(e=D==null?void 0:D.flushIntervalMs)!=null?e:300,maxQueue:(t=D==null?void 0:D.maxQueue)!=null?t:200,debug:!!(D!=null&&D.debug)}}async function pn(i,e,t,n){let a=JSON.stringify(e);if(t==="beacon"&&typeof navigator!="undefined"&&typeof navigator.sendBeacon=="function")try{let s=navigator.sendBeacon(i,new Blob([a],{type:"application/json"}));n&&console.log("[handler.telemetry] beacon",s,e);return}catch(s){n&&console.warn("[handler.telemetry] beacon failed, fallback to fetch",s)}try{await fetch(i,{method:"POST",headers:{"Content-Type":"application/json"},body:a,keepalive:!0}),n&&console.log("[handler.telemetry] fetch",e)}catch(s){n&&console.warn("[handler.telemetry] fetch failed",s)}}function pi(i,e){let t=hn();if(e&&t.endpoint){if(ie.push(i),ie.length>t.maxQueue&&(ie=ie.slice(ie.length-t.maxQueue)),ie.length>=t.batchSize){un();return}Ue===null&&(Ue=window.setTimeout(()=>{Ue=null,un()},t.flushIntervalMs))}}async function un(){let i=hn();if(!i.endpoint||ie.length===0)return;let e=ie.splice(0,i.batchSize);await pn(i.endpoint,{events:e},i.transport,i.debug),ie.length>0&&await pn(i.endpoint,{events:ie.splice(0,i.batchSize)},i.transport,i.debug)}function fn(i){return Math.max(0,Math.min(1,i))}function Ua(i){let e=String(i!=null?i:"power2.out");if(e==="linear")return t=>t;if(e==="sine.inOut")return t=>.5-Math.cos(Math.PI*t)/2;if(e==="power2.out"||e==="easeOutQuad")return t=>1-(1-t)*(1-t);if(e.startsWith("back.out")){let t=e.match(/back\.out\(([\d.]+)\)/),n=t?Number(t[1]):1.8;return a=>1+(n+1)*Math.pow(a-1,3)+n*Math.pow(a-1,2)}return t=>1-(1-t)*(1-t)}function yt(){return typeof performance!="undefined"&&performance.now?performance.now():Date.now()}function qa(i,e){let t=i==null?void 0:i[e];return typeof t=="number"?t:0}function mn(i,e,t){try{i[e]=t}catch{}}function Va(i){let e=i==null?void 0:i.scale;if(!e)return null;let t=typeof e.x=="number"?e.x:1,n=typeof e.y=="number"?e.y:1;return{x:t,y:n}}function bn(i,e){let t=i==null?void 0:i.scale;if(t)try{typeof t.set=="function"?t.set(e.x,e.y):(typeof t.x=="number"&&(t.x=e.x),typeof t.y=="number"&&(t.y=e.y))}catch{}}function yn(i,e){let t=Va(i);if(!t)return{from:null,to:null};let n=null,a=null;return typeof e.scale=="number"?(n=e.scale,a=e.scale):e.scale&&typeof e.scale=="object"&&(typeof e.scale.x=="number"&&(n=e.scale.x),typeof e.scale.y=="number"&&(a=e.scale.y)),typeof e.scaleX=="number"&&(n=e.scaleX),typeof e.scaleY=="number"&&(a=e.scaleY),n===null&&a===null?{from:null,to:null}:{from:{x:t.x,y:t.y},to:{x:n!=null?n:t.x,y:a!=null?a:t.y}}}function vn(){let i=new Set,e=new WeakMap,t=null,n=()=>{if(t!=null)return;t=requestAnimationFrame(()=>{t=null,o(),i.size>0&&n()})},a=u=>{var p;i.add(u);let d=(p=e.get(u.target))!=null?p:new Set;d.add(u),e.set(u.target,d),n()},s=u=>{i.delete(u);let d=e.get(u.target);d&&(d.delete(u),d.size===0&&e.delete(u.target))},r=u=>{u.killed||(u.killed=!0,s(u))},o=()=>{var d,p;let u=yt();for(let g of Array.from(i)){if(g.killed||g.paused)continue;let m=u-g.startMs-g.delayMs;if(m<0)continue;let f=g.durationMs>0?m/g.durationMs:1,C=fn(f),b=g.repeat>=0?g.repeat+1:1,h=g.repeat>0?Math.min(Math.floor(f),b-1):0;if(g.repeat>0&&f>=1){let y=f-h;C=fn(y)}let v=g.ease(C);g.yoyo&&h%2===1&&(v=1-v);for(let y of g.props)mn(g.target,y.key,y.from+(y.to-y.from)*v);g.scaleFrom&&g.scaleTo&&bn(g.target,{x:g.scaleFrom.x+(g.scaleTo.x-g.scaleFrom.x)*v,y:g.scaleFrom.y+(g.scaleTo.y-g.scaleFrom.y)*v});try{(d=g.onUpdate)==null||d.call(g)}catch{}if(f>=b){r(g);try{(p=g.onComplete)==null||p.call(g)}catch{}}}},c=(u,d,p)=>{var y;let g=Math.max(0,(typeof d.duration=="number"?d.duration:.5)*1e3),m=Math.max(0,(typeof d.delay=="number"?d.delay:0)*1e3+((y=p==null?void 0:p.delayMsOverride)!=null?y:0)),f=Ua(d.ease),C=typeof d.repeat=="number"?Math.max(0,d.repeat|0):0,b=d.yoyo===!0,h=new Set(["duration","delay","ease","repeat","yoyo","onUpdate","onComplete","scale","scaleX","scaleY"]),v=[];for(let M of Object.keys(d)){if(h.has(M))continue;let _=d[M];typeof _=="number"&&v.push({key:M,from:qa(u,M),to:_})}let w=yn(u,d);return{target:u,startMs:yt(),delayMs:m,durationMs:g,ease:f,props:v,scaleFrom:w.from,scaleTo:w.to,repeat:C,yoyo:b,onUpdate:typeof d.onUpdate=="function"?d.onUpdate:void 0,onComplete:typeof d.onComplete=="function"?d.onComplete:void 0,killed:!1,paused:!1,pauseAtMs:null}},l={to(u,d){let p=c(u,d);return a(p),{kill:()=>r(p),pause:()=>{p.paused||(p.paused=!0,p.pauseAtMs=yt())},resume:()=>{var f;if(!p.paused)return;let g=(f=p.pauseAtMs)!=null?f:yt(),m=yt()-g;p.startMs+=m,p.paused=!1,p.pauseAtMs=null},isActive:()=>!p.killed&&!p.paused}},fromTo(u,d,p){return l.set(u,d),l.to(u,p)},set(u,d){if(!u||!d)return;for(let g of Object.keys(d)){let m=d[g];g==="scale"||g==="scaleX"||g==="scaleY"||typeof m=="number"&&mn(u,g,m)}let p=yn(u,d);p.to&&bn(u,p.to)},killTweensOf(u){let d=e.get(u);if(d)for(let p of Array.from(d))r(p)},timeline(u={}){let d=[],p=0,g=!1,m=[],f=h=>{if(typeof h=="number")return Math.max(0,h*1e3);let v=typeof h=="string"?h.trim():"";return v.startsWith("+=")?p+Math.max(0,Number(v.slice(2))*1e3||0):v?Math.max(0,Number(v)*1e3||0):p},C=h=>{d.push(h);let v=Math.max(0,(typeof h.vars.duration=="number"?h.vars.duration:.5)*1e3);p=Math.max(p,h.atMs+v)},b={to(h,v,w){return C({kind:"to",target:h,vars:v,atMs:f(w)}),b},fromTo(h,v,w,y){return C({kind:"fromTo",target:h,vars:w,from:v,atMs:f(y)}),b},play(){var h,v;if(g)return b;g=!0,m=[];for(let w of d)w.kind==="fromTo"&&l.set(w.target,(h=w.from)!=null?h:{}),m.push(l.to(w.target,{...w.vars,delay:w.atMs/1e3+((v=w.vars.delay)!=null?v:0)}));return b},pause(){for(let h of m)h.pause();return b},kill(){for(let h of m)h.kill();m=[],g=!1}};return u.paused||b.play(),b}};return l}function wn(){if(typeof window=="undefined")return;let i=window;if(!i.gsap)try{i.gsap=vn()}catch{}}var xn={name:"handler-playable-sdk",version:"1.0.9",type:"module",description:"Handler Playable SDK v0.1 with contract-aligned surface (root sandbox, canonical event envelope).",main:"dist/index.cjs",module:"dist/index.js",types:"dist/index.d.ts",exports:{".":{types:"./dist/index.d.ts",import:"./dist/index.js",require:"./dist/index.cjs"},"./pixi":{types:"./dist/pixi/index.d.ts",import:"./dist/pixi/index.js",require:"./dist/pixi/index.cjs"},"./pixi/index.css":{import:"./dist/pixi/index.css",require:"./dist/pixi/index.css"},"./three":{types:"./dist/three/index.d.ts",import:"./dist/three/index.js",require:"./dist/three/index.cjs"},"./cli":{types:"./dist/cli/index.d.ts",import:"./dist/cli/index.js",require:"./dist/cli/index.cjs"}},bin:{"handler-student-helper":"./bin/student-helper.mjs","handler-validate":"./bin/validate.mjs","handler-sync-screens":"./bin/sync-screens.mjs","handler-brand-dna":"./bin/brand-dna.mjs","handler-setup-library":"./bin/setup-library.mjs","handler-screen-helper":"./bin/screen-helper.mjs"},scripts:{prebuild:"python3 src/preview/build-css.py",build:"tsup src/index.ts src/pixi/index.ts src/three/index.ts src/cli/index.ts --format cjs,esm --dts --clean --minify --external lottie-web --external jszip && npm run create-mjs-symlinks && npm run postbuild-cli && npm run obfuscate && npm run postbuild",postbuild:"python3 src/preview/copy-css-to-dist.py","postbuild-cli":"cp src/cli/*.mjs dist/cli/ && chmod +x dist/cli/*.mjs && chmod +x bin/*.mjs","create-mjs-symlinks":"cd dist && ln -sf index.js index.mjs && cd pixi && ln -sf index.js index.mjs && cd ../three && ln -sf index.js index.mjs","build:dev":"tsup src/index.ts src/pixi/index.ts src/three/index.ts src/cli/index.ts --format cjs,esm --dts --clean --external lottie-web --external jszip && npm run create-mjs-symlinks && npm run postbuild-cli",obfuscate:"javascript-obfuscator dist/pixi/index.js --output dist/pixi/index.js --config obfuscator.config.json && javascript-obfuscator dist/three/index.js --output dist/three/index.js --config obfuscator.config.json && javascript-obfuscator dist/cli/index.js --output dist/cli/index.js --config obfuscator.config.json && npm run obfuscate-cli","obfuscate-cli":'for file in dist/cli/*.mjs; do javascript-obfuscator "$file" --output "$file" --config obfuscator.config.json; done',lint:"eslint 'src/**/*.{ts,tsx}'",typecheck:"tsc --noEmit",prepublishOnly:"npm run build","publish:update":"node scripts/publish-and-update.cjs patch","publish:update:minor":"node scripts/publish-and-update.cjs minor","publish:update:major":"node scripts/publish-and-update.cjs major"},author:"Handler",license:"MIT",publishConfig:{access:"public"},repository:{type:"git",url:"https://github.com/HandlerAIGames/handler-playable-sdk.git"},files:["dist","bin","LICENSE","README.md"],peerDependencies:{"lottie-web":"^5.0.0","pixi.js":"^8.0.0",three:"^0.182.0"},peerDependenciesMeta:{"pixi.js":{optional:!0},three:{optional:!0},"lottie-web":{optional:!0}},devDependencies:{"@types/three":"^0.182.0",eslint:"^9.39.2","javascript-obfuscator":"^5.1.0","pixi.js":"8.8.1",three:"^0.182.0","ts-node":"^10.9.2",tsup:"^8.4.0",typescript:"^5.7.2","typescript-eslint":"^8.53.0"},dependencies:{"@google/genai":"^1.35.0","@google/generative-ai":"^0.24.1",jszip:"^3.10.1",sharp:"^0.34.5"}};var Q=0,Ya=Q++,Sn=Q++,En=Q++,Cn=Q++,An=Q++,Ln=Q++,Tn=Q++,kn=Q++,Pn=Q++,Mn=Q++,In=Q++,jn=Q++,R=Ya;function _n(){return R===Sn}function On(){return R===En}function Rn(){return R===Cn}function zn(){return R===An}function qe(){return R===Ln}function Ve(){return R===Tn}function $n(){return R===kn}function Dn(){return R===Pn}function Hn(){return R===Mn}function ui(){return R===In}function gi(){return R===jn}function Nn(){let i=typeof AD_PROTOCOL!="undefined"?AD_PROTOCOL:"none",e=typeof AD_NETWORK!="undefined"?AD_NETWORK:"web_embed";if(i==="mraid")try{mraid.getState(),R=Sn;return}catch{}else if(i==="dapi")try{dapi.isReady(),R=En;return}catch{}if(e==="facebook")try{typeof FbPlayableAd!="undefined"&&(R=Cn)}catch{}else if(e==="google")try{typeof ExitApi!="undefined"&&(R=An)}catch{}else if(e==="mintegral")window.gameReady&&(R=Ln);else if(e==="tapjoy")window.TJ_API&&(R=Tn);else if(e==="tiktok")window.openAppStore&&(R=kn);else if(e==="smadex")try{window.smxTracking&&(R=Pn)}catch{}else if(e==="snapchat")try{window.ScPlayableAd&&(R=Mn)}catch{}else e==="vungle"?R=In:(i==="nucleo"||e==="nucleo")&&(R=jn)}var Rt=ci(require("lottie-web"),1),Fn=Rt.default;typeof window!="undefined"&&(window.lottie=Rt.default,window.__baseLottie=Rt.default);mi();function H(i,e){let t=(a,s)=>s===0?a:t(s,a%s),n=t(i,e);return`${i/n}:${e/n}`}var Nr=[{id:"iphone-15-pro-max",label:"iPhone 15 Pro Max",width:430,height:932,category:"iphone",ratio:H(430,932)},{id:"iphone-15-pro",label:"iPhone 15 Pro",width:393,height:852,category:"iphone",ratio:H(393,852)},{id:"iphone-15",label:"iPhone 15",width:393,height:852,category:"iphone",ratio:H(393,852)},{id:"iphone-14",label:"iPhone 14",width:390,height:844,category:"iphone",ratio:H(390,844)},{id:"iphone-se",label:"iPhone SE",width:375,height:667,category:"iphone",ratio:H(375,667)},{id:"iphone-12-mini",label:"iPhone 12 Mini",width:360,height:780,category:"iphone",ratio:H(360,780)}],Fr=[{id:"pixel-8-pro",label:"Pixel 8 Pro",width:448,height:998,category:"android",ratio:H(448,998)},{id:"pixel-8",label:"Pixel 8",width:412,height:915,category:"android",ratio:H(412,915)},{id:"samsung-s24-ultra",label:"Samsung S24 Ultra",width:412,height:915,category:"android",ratio:H(412,915)},{id:"samsung-s24",label:"Samsung S24",width:360,height:780,category:"android",ratio:H(360,780)},{id:"samsung-a54",label:"Samsung A54",width:412,height:915,category:"android",ratio:H(412,915)},{id:"oneplus-12",label:"OnePlus 12",width:412,height:915,category:"android",ratio:H(412,915)}],Br=[{id:"ipad-pro-12",label:'iPad Pro 12.9"',width:1024,height:1366,category:"tablet",ratio:H(1024,1366)},{id:"ipad-pro-11",label:'iPad Pro 11"',width:834,height:1194,category:"tablet",ratio:H(834,1194)},{id:"ipad-air",label:"iPad Air",width:820,height:1180,category:"tablet",ratio:H(820,1180)},{id:"ipad-mini",label:"iPad Mini",width:768,height:1024,category:"tablet",ratio:H(768,1024)},{id:"samsung-tab-s9",label:"Samsung Tab S9",width:800,height:1280,category:"tablet",ratio:H(800,1280)}],qn=[{id:"playable-portrait",label:"Playable Portrait",width:320,height:480,category:"playable",ratio:"2:3",mraidScale:1},{id:"mraid-320x480",label:"MRAID 320\xD7480",width:320,height:480,category:"playable",ratio:"2:3",mraidScale:1},{id:"iphone-14",label:"iPhone 14",width:390,height:844,category:"playable",ratio:H(390,844),mraidScale:.7},{id:"ipad-mini",label:"iPad Mini",width:768,height:1024,category:"playable",ratio:H(768,1024),mraidScale:.7}];var Gr=[...qn];var is=qn[0];oe();function ns(i){return new Promise((e,t)=>{let n=new FileReader;n.onerror=()=>t(new Error("FileReader failed")),n.onload=()=>e(String(n.result||"")),n.readAsDataURL(i)})}function as(i){var a;let[e,t]=i.split(","),n=e==null?void 0:e.match(/data:(.*?);base64/);return{base64:t!=null?t:"",mimeType:(a=n==null?void 0:n[1])!=null?a:"image/png"}}async function ss(i){return await new Promise(e=>{let t=new Image;t.onload=()=>e({width:t.naturalWidth||t.width,height:t.naturalHeight||t.height}),t.onerror=()=>e(null),t.src=i})}async function bi(i){var e,t;try{console.log("[ImageUtils] Fetching image data from URL:",i);let n=await fetch(i);if(!n.ok)return console.warn("[ImageUtils] Fetch failed with status:",n.status,i),null;let a=await n.blob();console.log("[ImageUtils] Blob received, size:",a.size,"type:",a.type);let s=await ns(a),r=await ss(s),o=as(s);return console.log("[ImageUtils] Success resolution:",r==null?void 0:r.width,"x",r==null?void 0:r.height,"mime:",o.mimeType),{base64:o.base64,mimeType:o.mimeType,dataUrl:s,width:(e=r==null?void 0:r.width)!=null?e:0,height:(t=r==null?void 0:r.height)!=null?t:0}}catch(n){return console.error("[ImageUtils] Error fetching image data:",n),null}}async function zt(i,e=30){try{console.log("[ImageUtils] Removing background color...");let t=await new Promise((d,p)=>{let g=new Image;g.onload=()=>d(g),g.onerror=()=>p(new Error("Failed to load image")),g.src=i}),n=document.createElement("canvas");n.width=t.width,n.height=t.height;let a=n.getContext("2d");if(!a)return console.error("[ImageUtils] Failed to get canvas context"),i;a.drawImage(t,0,0);let s=a.getImageData(0,0,n.width,n.height),r=s.data,c=[{name:"top-left",offset:0},{name:"top-right",offset:(n.width-1)*4},{name:"bottom-left",offset:(n.height-1)*n.width*4},{name:"bottom-right",offset:((n.height-1)*n.width+(n.width-1))*4}].map(d=>({r:r[d.offset],g:r[d.offset+1],b:r[d.offset+2]})),l=0;for(let d=0;d<r.length;d+=4){let p=r[d],g=r[d+1],m=r[d+2],f=!1;for(let C of c)if(Math.sqrt(Math.pow(p-C.r,2)+Math.pow(g-C.g,2)+Math.pow(m-C.b,2))<e){f=!0;break}f&&(r[d+3]=0,l++)}return console.log(`[ImageUtils] Removed background from ${l} pixels (4-corner sampling, tolerance: ${e})`),a.putImageData(s,0,0),n.toDataURL("image/png")}catch(t){return console.error("[ImageUtils] Error removing background:",t),i}}var Yn=require("@google/genai");async function yi(i,e,t=[],n={}){var a,s,r,o,c,l,u;try{if(!(i!=null&&i.trim()))throw new Error("Gemini API key is required");if(!(e!=null&&e.trim()))throw new Error("Prompt is required");for(let b=0;b<t.length;b++){let h=t[b];if(!h.base64||!h.mimeType)throw new Error(`Image ${b+1} is missing required data`);if(h.base64.length<1e3&&console.warn(`Image ${b+1} data appears very small, may be corrupted`),!h.mimeType.startsWith("image/"))throw new Error(`Image ${b+1} has invalid MIME type: ${h.mimeType}`)}let d=new Yn.GoogleGenAI({apiKey:i}),p="gemini-2.5-flash",g=[e];t.length>0&&t.forEach((b,h)=>{g.push({inlineData:{data:b.base64,mimeType:b.mimeType}}),console.log(`[Gemini] Added image ${h+1}: ${b.mimeType}, size: ${Math.round(b.base64.length/1024)}KB`)}),console.log(`[Gemini] Making request with ${t.length} images and prompt length: ${e.length}`);let m=await d.models.generateContent({model:p,contents:g}),f="",C=(r=(s=(a=m.candidates)==null?void 0:a[0])==null?void 0:s.content)==null?void 0:r.parts;if(C)for(let b of C)b.text&&(f+=b.text);if(!f.trim())throw new Error("Empty response from Gemini API");return console.log(`[Gemini] Response received, length: ${f.length}`),f}catch(d){throw console.error("[Gemini] API error:",d),(o=d.message)!=null&&o.includes("Unable to process input image")?new Error("Unable to process the uploaded image. Please ensure it's a valid PNG, JPG, or JPEG file under 10MB and not corrupted."):(c=d.message)!=null&&c.includes("API_KEY_INVALID")?new Error("Invalid Gemini API key. Please check your API key configuration."):(l=d.message)!=null&&l.includes("QUOTA_EXCEEDED")?new Error("Gemini API quota exceeded. Please try again later or check your billing."):(u=d.message)!=null&&u.includes("SAFETY")?new Error("Content was flagged by Gemini safety filters. Please try with different images."):d}}var Kn=require("@google/genai");async function $t(i,e,t=[],n={}){try{console.info("[GEMINI-REAL-SDK] Initializing GoogleGenAI...");let a=new Kn.GoogleGenAI({apiKey:i}),s=[{text:e}];t.length>0&&t.forEach((o,c)=>{console.info(`[GEMINI-REAL-SDK] Adding image part ${c}`),s.push({inlineData:{mimeType:o.mimeType,data:o.base64}})}),console.info("[GEMINI-REAL-SDK] Calling generateContent with model: gemini-2.5-flash-image");let r=await a.models.generateContent({model:"gemini-2.5-flash-image",contents:s});if(console.info("[GEMINI-REAL-SDK] Received response from model"),!r.candidates||!r.candidates[0]||!r.candidates[0].content||!r.candidates[0].content.parts)throw new Error("Gemini 2.5 Flash Image returned invalid response structure.");for(let o of r.candidates[0].content.parts)if(o.text)console.log(o.text);else if(o.inlineData){let c=o.inlineData.data,l=o.inlineData.mimeType||"image/png";return console.info("[GEMINI-REAL-SDK] Found inline image data in response"),`data:${l};base64,${c}`}throw new Error("Gemini 2.5 Flash Image returned no image data.")}catch(a){throw console.error("[GEMINI-REAL-SDK] Error in generateImageWithGemini25Flash:",JSON.stringify(a,Object.getOwnPropertyNames(a),2)),a}}var ps=require("pixi.js");vt();oe();var ta=require("pixi.js");var gs=require("pixi.js");oe();function Es(i){return new Promise((e,t)=>{let n=new FileReader;n.onerror=()=>t(new Error("FileReader failed")),n.onload=()=>e(String(n.result||"")),n.readAsDataURL(i)})}function Cs(i){var a;let[e,t]=i.split(","),n=e==null?void 0:e.match(/data:(.*?);base64/);return{base64:t!=null?t:"",mimeType:(a=n==null?void 0:n[1])!=null?a:"image/png"}}function As(i){return`
47
47
  Analyze these screenshots of a brand or game and extract its "Brand DNA".
48
48
 
49
49
  Provide a concise summary (2-3 sentences) covering:
@@ -60,9 +60,9 @@ Palette: [#RRGGBB, #RRGGBB, ...]
60
60
  ${i?`
61
61
  ADDITIONAL RULES/NOTES:
62
62
  ${i}`:""}
63
- `.trim()}function Fn(){let i=[],e="",t=null;return{async addSources(n){let a=[];for(let s of n){let r=await ss(s),o=rs(r),l={id:`${Date.now()}-${Math.random().toString(16).slice(2)}`,name:s.name,base64:o.base64,mimeType:o.mimeType,dataUrl:r};i.push(l),a.push(l)}return a},getSources(){return i.slice()},async analyze(n,a,s){if(i.length===0)throw new Error("No screenshots to analyze.");let r=os(a),o=i.map(p=>({base64:p.base64,mimeType:p.mimeType})),l=await fi(n,r,o,{model:s}),d=e,u=[],c=l.split(`
64
- `);for(let p of c)if(p.toLowerCase().startsWith("summary:"))d=p.slice(8).trim();else if(p.toLowerCase().includes("palette:")){let g=p.match(/#[0-9A-Fa-f]{6}/g);g&&g.forEach(m=>{u.includes(m.toUpperCase())||u.push(m.toUpperCase())})}return(!d||d===e)&&(d=l.split(`
65
- Palette:`)[0].replace(/^Summary:\s*/i,"").trim()),t={summary:d,palette:u.slice(0,10)},t},setSummary(n){e=n,t&&(t={...t,summary:n})},getResult(){return t}}}var Re="handler_api_key_";var qe=class{static setKey(e,t,n){try{let a={key:this.encryptKey(t),created:Date.now(),lastUsed:Date.now(),label:n||e},s=`${Re}${e}`;localStorage.setItem(s,JSON.stringify(a))}catch(a){console.error("[ApiKeyStorage] Failed to store API key:",a)}}static getKey(e){try{let t=`${Re}${e}`,n=localStorage.getItem(t);if(!n)return null;let a=JSON.parse(n);return a.lastUsed=Date.now(),localStorage.setItem(t,JSON.stringify(a)),this.decryptKey(a.key)}catch(t){return console.error("[ApiKeyStorage] Failed to retrieve API key:",t),null}}static hasKey(e){let t=`${Re}${e}`;return localStorage.getItem(t)!==null}static removeKey(e){try{let t=`${Re}${e}`;localStorage.removeItem(t)}catch(t){console.error("[ApiKeyStorage] Failed to remove API key:",t)}}static getStoredServices(){let e=[];try{for(let t=0;t<localStorage.length;t++){let n=localStorage.key(t);if(n&&n.startsWith(Re)){let a=n.substring(Re.length),s=localStorage.getItem(n);if(s){let r=JSON.parse(s);e.push({service:a,label:r.label,created:r.created,lastUsed:r.lastUsed})}}}}catch(t){console.error("[ApiKeyStorage] Failed to get stored services:",t)}return e.sort((t,n)=>n.lastUsed-t.lastUsed)}static clearAll(){try{let e=[];for(let t=0;t<localStorage.length;t++){let n=localStorage.key(t);n&&n.startsWith(Re)&&e.push(n)}e.forEach(t=>localStorage.removeItem(t))}catch(e){console.error("[ApiKeyStorage] Failed to clear API keys:",e)}}static encryptKey(e){try{let n="handler_preview_salt_2024"+e;return btoa(n)}catch(t){return console.warn("[ApiKeyStorage] Encryption failed, storing as-is:",t),e}}static decryptKey(e){try{let t=atob(e),n="handler_preview_salt_2024";return t.startsWith(n)?t.substring(n.length):t}catch(t){return console.warn("[ApiKeyStorage] Decryption failed, returning as-is:",t),e}}},wi=()=>qe.getKey("gemini"),xi=(i,e)=>qe.setKey("gemini",i,e),ls=()=>qe.hasKey("gemini");window.ApiKeyStorage=qe;window.getGeminiApiKey=wi;window.setGeminiApiKey=xi;window.hasGeminiApiKey=ls;var Ei=class{constructor(){this.modal=null;this.options=null;this.analyzer=Fn();this.currentPrompt="";this.isGenerating=!1;this.generatedImages=[];this.selectedImageIndex=-1;this.promptInput=null;this.generateBtn=null;this.loadingEl=null;this.galleryEl=null;this.previewEl=null}open(e){this.options=e,this.currentPrompt=e.initialPrompt||"",this.generatedImages=[],this.selectedImageIndex=-1,this.isGenerating=!1,this.createModal(),document.body.appendChild(this.modal),setTimeout(()=>{var t,n;(t=this.promptInput)==null||t.focus(),(n=this.promptInput)==null||n.select()},100)}createModal(){var t;let e=document.createElement("div");e.className="ai-modal",e.innerHTML=`
63
+ `.trim()}function ia(){let i=[],e="",t=null;return{async addSources(n){let a=[];for(let s of n){let r=await Es(s),o=Cs(r),c={id:`${Date.now()}-${Math.random().toString(16).slice(2)}`,name:s.name,base64:o.base64,mimeType:o.mimeType,dataUrl:r};i.push(c),a.push(c)}return a},getSources(){return i.slice()},async analyze(n,a,s){if(i.length===0)throw new Error("No screenshots to analyze.");let r=As(a),o=i.map(p=>({base64:p.base64,mimeType:p.mimeType})),c=await yi(n,r,o,{model:s}),l=e,u=[],d=c.split(`
64
+ `);for(let p of d)if(p.toLowerCase().startsWith("summary:"))l=p.slice(8).trim();else if(p.toLowerCase().includes("palette:")){let g=p.match(/#[0-9A-Fa-f]{6}/g);g&&g.forEach(m=>{u.includes(m.toUpperCase())||u.push(m.toUpperCase())})}return(!l||l===e)&&(l=c.split(`
65
+ Palette:`)[0].replace(/^Summary:\s*/i,"").trim()),t={summary:l,palette:u.slice(0,10)},t},setSummary(n){e=n,t&&(t={...t,summary:n})},getResult(){return t}}}var $e="handler_api_key_";var We=class{static setKey(e,t,n){try{let a={key:this.encryptKey(t),created:Date.now(),lastUsed:Date.now(),label:n||e},s=`${$e}${e}`;localStorage.setItem(s,JSON.stringify(a))}catch(a){console.error("[ApiKeyStorage] Failed to store API key:",a)}}static getKey(e){try{let t=`${$e}${e}`,n=localStorage.getItem(t);if(!n)return null;let a=JSON.parse(n);return a.lastUsed=Date.now(),localStorage.setItem(t,JSON.stringify(a)),this.decryptKey(a.key)}catch(t){return console.error("[ApiKeyStorage] Failed to retrieve API key:",t),null}}static hasKey(e){let t=`${$e}${e}`;return localStorage.getItem(t)!==null}static removeKey(e){try{let t=`${$e}${e}`;localStorage.removeItem(t)}catch(t){console.error("[ApiKeyStorage] Failed to remove API key:",t)}}static getStoredServices(){let e=[];try{for(let t=0;t<localStorage.length;t++){let n=localStorage.key(t);if(n&&n.startsWith($e)){let a=n.substring($e.length),s=localStorage.getItem(n);if(s){let r=JSON.parse(s);e.push({service:a,label:r.label,created:r.created,lastUsed:r.lastUsed})}}}}catch(t){console.error("[ApiKeyStorage] Failed to get stored services:",t)}return e.sort((t,n)=>n.lastUsed-t.lastUsed)}static clearAll(){try{let e=[];for(let t=0;t<localStorage.length;t++){let n=localStorage.key(t);n&&n.startsWith($e)&&e.push(n)}e.forEach(t=>localStorage.removeItem(t))}catch(e){console.error("[ApiKeyStorage] Failed to clear API keys:",e)}}static encryptKey(e){try{let n="handler_preview_salt_2024"+e;return btoa(n)}catch(t){return console.warn("[ApiKeyStorage] Encryption failed, storing as-is:",t),e}}static decryptKey(e){try{let t=atob(e),n="handler_preview_salt_2024";return t.startsWith(n)?t.substring(n.length):t}catch(t){return console.warn("[ApiKeyStorage] Decryption failed, returning as-is:",t),e}}},Ei=()=>We.getKey("gemini"),Ci=(i,e)=>We.setKey("gemini",i,e),Ls=()=>We.hasKey("gemini");window.ApiKeyStorage=We;window.getGeminiApiKey=Ei;window.setGeminiApiKey=Ci;window.hasGeminiApiKey=Ls;var Li=class{constructor(){this.modal=null;this.options=null;this.analyzer=ia();this.currentPrompt="";this.isGenerating=!1;this.generatedImages=[];this.selectedImageIndex=-1;this.promptInput=null;this.generateBtn=null;this.loadingEl=null;this.galleryEl=null;this.previewEl=null}open(e){this.options=e,this.currentPrompt=e.initialPrompt||"",this.generatedImages=[],this.selectedImageIndex=-1,this.isGenerating=!1,this.createModal(),document.body.appendChild(this.modal),setTimeout(()=>{var t,n;(t=this.promptInput)==null||t.focus(),(n=this.promptInput)==null||n.select()},100)}createModal(){var t;let e=document.createElement("div");e.className="ai-modal",e.innerHTML=`
66
66
  <div class="ai-modal-card">
67
67
  <div class="ai-modal-header">
68
68
  <div class="ai-modal-actions">
@@ -143,12 +143,12 @@ Palette:`)[0].replace(/^Summary:\s*/i,"").trim()),t={summary:d,palette:u.slice(0
143
143
  </div>
144
144
  `,this.modal=e,this.attachEventListeners(),this.updatePromptFromDna()}attachEventListeners(){var n;if(!this.modal)return;this.promptInput=this.modal.querySelector(".ai-textarea"),this.generateBtn=this.modal.querySelector('[data-action="generate"]'),this.loadingEl=this.modal.querySelector("[data-loading]"),this.galleryEl=this.modal.querySelector("[data-gallery]"),this.previewEl=this.modal.querySelector("[data-preview]"),(n=this.promptInput)==null||n.addEventListener("input",()=>{var a;this.currentPrompt=((a=this.promptInput)==null?void 0:a.value)||"",this.updateGenerateButton()});let e=this.modal.querySelector('[data-strength="creativity"]'),t=this.modal.querySelector(".ai-strength-value");e==null||e.addEventListener("input",()=>{t.textContent=e.value}),this.modal.addEventListener("click",a=>{var o;let s=a.target;switch(s.dataset.action||((o=s.closest("[data-action]"))==null?void 0:o.getAttribute("data-action"))){case"generate":this.generateImage();break;case"apply":this.applySelectedImage();break;case"gallery":this.toggleGallery();break;case"close":case"cancel":this.close();break}}),this.modal.addEventListener("click",a=>{let s=a.target;if(s.classList.contains("ai-gallery-item")||s.closest(".ai-gallery-item")){let r=s.closest(".ai-gallery-item"),o=parseInt(r.dataset.index||"-1");o>=0&&this.selectImage(o)}}),this.modal.addEventListener("click",a=>{a.target===this.modal&&this.close()}),this.updateGenerateButton()}updateGenerateButton(){if(!this.generateBtn)return;let e=this.currentPrompt.trim().length>0;this.generateBtn.disabled=!e||this.isGenerating}async updatePromptFromDna(){var t;let e=(t=this.modal)==null?void 0:t.querySelector("#ai-use-dna");if(e!=null&&e.checked)try{let n=this.analyzer.getResult();if(n!=null&&n.summary&&this.promptInput){let a=`${this.currentPrompt}
145
145
 
146
- Style guidelines: ${n.summary}`;this.promptInput.value=a,this.currentPrompt=a}}catch(n){console.warn("[AiEditorModal] Failed to apply brand DNA:",n)}}async generateImage(){var e,t,n,a;if(!(!this.options||this.isGenerating)){this.isGenerating=!0,this.updateGenerateButton(),(e=this.loadingEl)==null||e.classList.remove("hidden"),(t=this.previewEl)==null||t.classList.add("hidden");try{let s=this.getApiKey();if(!s){alert("Please set your Gemini API key first. You can do this in the AI Creative Suite panel.");return}let r=[];if(this.options.currentValue&&this.options.currentValue.startsWith("data:"))try{let d=await hi(this.options.currentValue);d&&(r=[{base64:d.base64,mimeType:d.mimeType}])}catch(d){console.warn("[AiEditorModal] Failed to load current image:",d)}let o=await zt(s,this.currentPrompt,r,{aspectRatio:"1:1"}),l=await Rt(o);this.generatedImages.push(l||o),this.selectedImageIndex=this.generatedImages.length-1,this.updateGallery(),this.updatePreview(),this.updateApplyButton()}catch(s){console.error("[AiEditorModal] Generation failed:",s),alert(`Generation failed: ${s instanceof Error?s.message:"Unknown error"}`)}finally{this.isGenerating=!1,(n=this.loadingEl)==null||n.classList.add("hidden"),(a=this.previewEl)==null||a.classList.remove("hidden"),this.updateGenerateButton()}}}updateGallery(){if(!this.galleryEl)return;let e=this.galleryEl.querySelector("[data-gallery-grid]");e&&(e.innerHTML=this.generatedImages.map((t,n)=>`
146
+ Style guidelines: ${n.summary}`;this.promptInput.value=a,this.currentPrompt=a}}catch(n){console.warn("[AiEditorModal] Failed to apply brand DNA:",n)}}async generateImage(){var e,t,n,a;if(!(!this.options||this.isGenerating)){this.isGenerating=!0,this.updateGenerateButton(),(e=this.loadingEl)==null||e.classList.remove("hidden"),(t=this.previewEl)==null||t.classList.add("hidden");try{let s=this.getApiKey();if(!s){alert("Please set your Gemini API key first. You can do this in the AI Creative Suite panel.");return}let r=[];if(this.options.currentValue&&this.options.currentValue.startsWith("data:"))try{let l=await bi(this.options.currentValue);l&&(r=[{base64:l.base64,mimeType:l.mimeType}])}catch(l){console.warn("[AiEditorModal] Failed to load current image:",l)}let o=await $t(s,this.currentPrompt,r,{aspectRatio:"1:1"}),c=await zt(o);this.generatedImages.push(c||o),this.selectedImageIndex=this.generatedImages.length-1,this.updateGallery(),this.updatePreview(),this.updateApplyButton()}catch(s){console.error("[AiEditorModal] Generation failed:",s),alert(`Generation failed: ${s instanceof Error?s.message:"Unknown error"}`)}finally{this.isGenerating=!1,(n=this.loadingEl)==null||n.classList.add("hidden"),(a=this.previewEl)==null||a.classList.remove("hidden"),this.updateGenerateButton()}}}updateGallery(){if(!this.galleryEl)return;let e=this.galleryEl.querySelector("[data-gallery-grid]");e&&(e.innerHTML=this.generatedImages.map((t,n)=>`
147
147
  <div class="ai-gallery-item ${n===this.selectedImageIndex?"active":""}" data-index="${n}">
148
148
  <img class="ai-gallery-thumb" src="${t}" alt="Generated ${n+1}" />
149
149
  <div class="ai-gallery-label">#${n+1}</div>
150
150
  </div>
151
- `).join(""))}updatePreview(){if(!this.previewEl||this.selectedImageIndex<0)return;let e=this.generatedImages[this.selectedImageIndex];this.previewEl.innerHTML=`<img src="${e}" alt="Selected image" />`}selectImage(e){e<0||e>=this.generatedImages.length||(this.selectedImageIndex=e,this.updateGallery(),this.updatePreview(),this.updateApplyButton())}toggleGallery(){this.galleryEl&&this.galleryEl.classList.toggle("hidden")}updateApplyButton(){var t;let e=(t=this.modal)==null?void 0:t.querySelector('[data-action="apply"]');e&&(e.disabled=this.selectedImageIndex<0)}applySelectedImage(){var t;if(this.selectedImageIndex<0||!((t=this.options)!=null&&t.onApply))return;let e=this.generatedImages[this.selectedImageIndex];this.options.onApply(e),this.close()}getApiKey(){let e=wi();if(e)return e;try{let t=this.analyzer.getResult();if(t&&t.apiKey)return xi(t.apiKey,"From Brand DNA"),t.apiKey}catch(t){console.warn("[AiEditorModal] Failed to get API key from brand DNA:",t)}return null}close(){this.modal&&this.modal.parentNode&&this.modal.parentNode.removeChild(this.modal),this.modal=null,this.options=null}},Si=null;window.__openAiEditor=function(i,e,t,n){Si||(Si=new Ei),Si.open({objectId:i,initialPrompt:e,currentValue:t,path:n==null?void 0:n.path,onApply:a=>{if(n!=null&&n.path){let s=window.updateManager;if(s)s.updateProperty(i,n.path,a);else{let r=window.getEditableObjectConfig,o=r==null?void 0:r(i);if(o){let l=n.path.split("."),d=o;for(let u=0;u<l.length-1;u++)d[l[u]]||(d[l[u]]={}),d=d[l[u]];d[l[l.length-1]]=a}}}window.dispatchEvent(new CustomEvent("inspector:refresh"))}})};Ai();var Li=class{constructor(){this.modal=null;this.options=null}open(e){this.options=e,this.createModal(),document.body.appendChild(this.modal)}createModal(){if(!this.options)return;let{assetPath:e,assetType:t,objectId:n}=this.options,a=n||"Asset Preview",s=document.createElement("div");s.className="asset-preview-modal",s.innerHTML=`
151
+ `).join(""))}updatePreview(){if(!this.previewEl||this.selectedImageIndex<0)return;let e=this.generatedImages[this.selectedImageIndex];this.previewEl.innerHTML=`<img src="${e}" alt="Selected image" />`}selectImage(e){e<0||e>=this.generatedImages.length||(this.selectedImageIndex=e,this.updateGallery(),this.updatePreview(),this.updateApplyButton())}toggleGallery(){this.galleryEl&&this.galleryEl.classList.toggle("hidden")}updateApplyButton(){var t;let e=(t=this.modal)==null?void 0:t.querySelector('[data-action="apply"]');e&&(e.disabled=this.selectedImageIndex<0)}applySelectedImage(){var t;if(this.selectedImageIndex<0||!((t=this.options)!=null&&t.onApply))return;let e=this.generatedImages[this.selectedImageIndex];this.options.onApply(e),this.close()}getApiKey(){let e=Ei();if(e)return e;try{let t=this.analyzer.getResult();if(t&&t.apiKey)return Ci(t.apiKey,"From Brand DNA"),t.apiKey}catch(t){console.warn("[AiEditorModal] Failed to get API key from brand DNA:",t)}return null}close(){this.modal&&this.modal.parentNode&&this.modal.parentNode.removeChild(this.modal),this.modal=null,this.options=null}},Ai=null;window.__openAiEditor=function(i,e,t,n){Ai||(Ai=new Li),Ai.open({objectId:i,initialPrompt:e,currentValue:t,path:n==null?void 0:n.path,onApply:a=>{if(n!=null&&n.path){let s=window.updateManager;if(s)s.updateProperty(i,n.path,a);else{let r=window.getEditableObjectConfig,o=r==null?void 0:r(i);if(o){let c=n.path.split("."),l=o;for(let u=0;u<c.length-1;u++)l[c[u]]||(l[c[u]]={}),l=l[c[u]];l[c[c.length-1]]=a}}}window.dispatchEvent(new CustomEvent("inspector:refresh"))}})};ki();var Pi=class{constructor(){this.modal=null;this.options=null}open(e){this.options=e,this.createModal(),document.body.appendChild(this.modal)}createModal(){if(!this.options)return;let{assetPath:e,assetType:t,objectId:n}=this.options,a=n||"Asset Preview",s=document.createElement("div");s.className="asset-preview-modal",s.innerHTML=`
152
152
  <div class="asset-preview-card">
153
153
  <div class="asset-preview-header">
154
154
  <div class="asset-preview-title">${a}</div>
@@ -175,7 +175,7 @@ Style guidelines: ${n.summary}`;this.promptInput.value=a,this.currentPrompt=a}}c
175
175
  <source src="${a}" type="audio/wav">
176
176
  Your browser does not support the audio element.
177
177
  </audio>
178
- `;case"text":return`<pre style="background: rgba(0,0,0,0.2); padding: 16px; border-radius: 8px; max-height: 300px; overflow-y: auto; white-space: pre-wrap;">${e}</pre>`;default:return`<div class="asset-preview-placeholder">Cannot preview ${t} assets</div>`}}resolveAssetUrl(e){return e.startsWith("data:")||e.startsWith("blob:")||e.startsWith("/")?e:`/raw/${e}`}attachEventListeners(){if(!this.modal)return;this.modal.addEventListener("click",n=>{let a=n.target;(a.dataset.action==="close"||a===this.modal)&&this.close()});let e=this.modal.querySelector('[data-action="change"]');e&&e.addEventListener("click",()=>{this.openAssetEditor()});let t=this.modal.querySelector('[data-action="edit"]');t&&t.addEventListener("click",()=>{this.openAiEditor(),this.close()})}openAssetEditor(){this.options&&Promise.resolve().then(()=>(Ai(),Bn)).then(({AssetEditorModal:e})=>{new e().show(this.options.objectId||"unknown",this.options.propertyPath||"",this.options.assetPath,n=>{var a;(a=this.options)!=null&&a.onChange&&this.options.onChange(n),this.close()})})}openAiEditor(){if(!this.options||this.options.assetType!=="image")return;let e=window.__openAiEditor;typeof e=="function"&&e(this.options.objectId||"asset","Edit this image asset",this.options.assetPath,{path:this.options.propertyPath,onApply:t=>{var n;(n=this.options)!=null&&n.onChange&&this.options.onChange(t)}})}close(){this.modal&&this.modal.parentNode&&this.modal.parentNode.removeChild(this.modal),this.modal=null,this.options=null}};window.openAssetPreview=function(i){new Li().open(i)};var Ti=class{constructor(){this.modal=null;this.canvas=null;this.ctx=null;this.image=null;this.options=null;this.cropX=0;this.cropY=0;this.cropWidth=100;this.cropHeight=100;this.scale=1;this.panX=0;this.panY=0;this.isDragging=!1;this.dragStartX=0;this.dragStartY=0;this.lastPanX=0;this.lastPanY=0}open(e){this.options=e,this.createModal(),this.loadImage(),document.body.appendChild(this.modal)}createModal(){let e=document.createElement("div");e.className="asset-crop-modal",e.innerHTML=`
178
+ `;case"text":return`<pre style="background: rgba(0,0,0,0.2); padding: 16px; border-radius: 8px; max-height: 300px; overflow-y: auto; white-space: pre-wrap;">${e}</pre>`;default:return`<div class="asset-preview-placeholder">Cannot preview ${t} assets</div>`}}resolveAssetUrl(e){return e.startsWith("data:")||e.startsWith("blob:")||e.startsWith("/")?e:`/raw/${e}`}attachEventListeners(){if(!this.modal)return;this.modal.addEventListener("click",n=>{let a=n.target;(a.dataset.action==="close"||a===this.modal)&&this.close()});let e=this.modal.querySelector('[data-action="change"]');e&&e.addEventListener("click",()=>{this.openAssetEditor()});let t=this.modal.querySelector('[data-action="edit"]');t&&t.addEventListener("click",()=>{this.openAiEditor(),this.close()})}openAssetEditor(){this.options&&Promise.resolve().then(()=>(ki(),na)).then(({AssetEditorModal:e})=>{new e().show(this.options.objectId||"unknown",this.options.propertyPath||"",this.options.assetPath,n=>{var a;(a=this.options)!=null&&a.onChange&&this.options.onChange(n),this.close()})})}openAiEditor(){if(!this.options||this.options.assetType!=="image")return;let e=window.__openAiEditor;typeof e=="function"&&e(this.options.objectId||"asset","Edit this image asset",this.options.assetPath,{path:this.options.propertyPath,onApply:t=>{var n;(n=this.options)!=null&&n.onChange&&this.options.onChange(t)}})}close(){this.modal&&this.modal.parentNode&&this.modal.parentNode.removeChild(this.modal),this.modal=null,this.options=null}};window.openAssetPreview=function(i){new Pi().open(i)};var Mi=class{constructor(){this.modal=null;this.canvas=null;this.ctx=null;this.image=null;this.options=null;this.cropX=0;this.cropY=0;this.cropWidth=100;this.cropHeight=100;this.scale=1;this.panX=0;this.panY=0;this.isDragging=!1;this.dragStartX=0;this.dragStartY=0;this.lastPanX=0;this.lastPanY=0}open(e){this.options=e,this.createModal(),this.loadImage(),document.body.appendChild(this.modal)}createModal(){let e=document.createElement("div");e.className="asset-crop-modal",e.innerHTML=`
179
179
  <div class="asset-crop-card">
180
180
  <div class="asset-crop-header">
181
181
  <div>
@@ -226,7 +226,7 @@ Style guidelines: ${n.summary}`;this.promptInput.value=a,this.currentPrompt=a}}c
226
226
  <button class="asset-crop-apply primary" data-action="apply">Apply Crop</button>
227
227
  </div>
228
228
  </div>
229
- `,this.modal=e,this.attachEventListeners(),this.initializeCanvas()}initializeCanvas(){this.modal&&(this.canvas=this.modal.querySelector(".asset-crop-canvas"),this.canvas&&(this.ctx=this.canvas.getContext("2d"),this.canvas.width=400,this.canvas.height=300))}loadImage(){this.options&&(this.image=new Image,this.image.crossOrigin="anonymous",this.image.onload=()=>{this.initializeCrop(),this.render()},this.image.src=this.options.imageSrc)}initializeCrop(){var n;if(!this.image||!this.canvas)return;let e=this.image.width/this.image.height,t=this.canvas.width/this.canvas.height;e>t?(this.cropHeight=this.image.height,this.cropWidth=this.cropHeight*t,this.cropX=(this.image.width-this.cropWidth)/2,this.cropY=0):(this.cropWidth=this.image.width,this.cropHeight=this.cropWidth/t,this.cropX=0,this.cropY=(this.image.height-this.cropHeight)/2),(n=this.options)!=null&&n.aspectRatio&&this.applyAspectRatio(this.options.aspectRatio),this.fitToCanvas()}applyAspectRatio(e){if(!this.image)return;let t=this.image.width/this.image.height,n=this.cropX+this.cropWidth/2,a=this.cropY+this.cropHeight/2;e>t?(this.cropWidth=Math.min(this.image.width,this.cropHeight*e),this.cropHeight=this.cropWidth/e):(this.cropHeight=Math.min(this.image.height,this.cropWidth/e),this.cropWidth=this.cropHeight*e),this.cropX=Math.max(0,Math.min(this.image.width-this.cropWidth,n-this.cropWidth/2)),this.cropY=Math.max(0,Math.min(this.image.height-this.cropHeight,a-this.cropHeight/2))}fitToCanvas(){if(!this.image||!this.canvas)return;let e=this.canvas.width/this.cropWidth,t=this.canvas.height/this.cropHeight;this.scale=Math.min(e,t)*.9,this.panX=(this.canvas.width-this.cropWidth*this.scale)/2,this.panY=(this.canvas.height-this.cropHeight*this.scale)/2}render(){!this.ctx||!this.image||!this.canvas||(this.ctx.clearRect(0,0,this.canvas.width,this.canvas.height),this.ctx.save(),this.ctx.translate(this.panX,this.panY),this.ctx.scale(this.scale,this.scale),this.ctx.drawImage(this.image,-this.cropX,-this.cropY,this.image.width,this.image.height),this.ctx.restore(),this.drawCropOverlay(),this.updatePreview())}drawCropOverlay(){if(!this.ctx||!this.canvas)return;let e=this.panX,t=this.panY,n=this.cropWidth*this.scale,a=this.cropHeight*this.scale;this.ctx.fillStyle="rgba(0, 0, 0, 0.5)",this.ctx.fillRect(0,0,this.canvas.width,this.canvas.height),this.ctx.clearRect(e,t,n,a),this.ctx.strokeStyle="#ffffff",this.ctx.lineWidth=2,this.ctx.strokeRect(e,t,n,a),this.ctx.fillStyle="#ffffff";let s=8;[[e,t],[e+n-s,t],[e,t+a-s],[e+n-s,t+a-s]].forEach(([o,l])=>{var d;(d=this.ctx)==null||d.fillRect(o,l,s,s)})}updatePreview(){if(!this.modal||!this.image)return;let e=this.modal.querySelector(".asset-crop-preview-canvas");if(!e)return;let t=e.getContext("2d");if(!t)return;let n=150;e.width=n,e.height=n;let a=n/this.cropWidth,s=n/this.cropHeight,r=Math.min(a,s),o=this.cropWidth*r,l=this.cropHeight*r,d=(n-o)/2,u=(n-l)/2;t.drawImage(this.image,this.cropX,this.cropY,this.cropWidth,this.cropHeight,d,u,o,l)}attachEventListeners(){if(!this.modal||!this.canvas)return;this.canvas.addEventListener("mousedown",this.handleMouseDown.bind(this)),this.canvas.addEventListener("mousemove",this.handleMouseMove.bind(this)),this.canvas.addEventListener("mouseup",this.handleMouseUp.bind(this)),this.canvas.addEventListener("wheel",this.handleWheel.bind(this)),this.canvas.addEventListener("touchstart",this.handleTouchStart.bind(this)),this.canvas.addEventListener("touchmove",this.handleTouchMove.bind(this)),this.canvas.addEventListener("touchend",this.handleTouchEnd.bind(this));let e=this.modal.querySelector(".asset-crop-zoom-slider");e==null||e.addEventListener("input",n=>{let a=parseFloat(n.target.value);this.setZoom(a)});let t=this.modal.querySelector(".asset-crop-aspect-select");t==null||t.addEventListener("change",n=>{let a=n.target.value;this.setAspectRatio(a)}),this.modal.addEventListener("click",n=>{switch(n.target.dataset.action){case"reset":this.reset();break;case"apply":this.applyCrop();break;case"cancel":case"close":this.close();break}}),this.modal.addEventListener("click",n=>{n.target===this.modal&&this.close()})}handleMouseDown(e){this.isDragging=!0,this.dragStartX=e.clientX,this.dragStartY=e.clientY,this.lastPanX=this.panX,this.lastPanY=this.panY,this.canvas.style.cursor="grabbing"}handleMouseMove(e){if(!this.isDragging)return;let t=e.clientX-this.dragStartX,n=e.clientY-this.dragStartY;this.panX=this.lastPanX+t,this.panY=this.lastPanY+n,this.constrainPan(),this.render()}handleMouseUp(){this.isDragging=!1,this.canvas.style.cursor="grab"}handleWheel(e){e.preventDefault();let t=e.deltaY>0?.9:1.1;this.setZoom(this.scale*t)}handleTouchStart(e){e.touches.length===1&&(this.isDragging=!0,this.dragStartX=e.touches[0].clientX,this.dragStartY=e.touches[0].clientY,this.lastPanX=this.panX,this.lastPanY=this.panY)}handleTouchMove(e){if(!this.isDragging||e.touches.length!==1)return;e.preventDefault();let t=e.touches[0].clientX-this.dragStartX,n=e.touches[0].clientY-this.dragStartY;this.panX=this.lastPanX+t,this.panY=this.lastPanY+n,this.constrainPan(),this.render()}handleTouchEnd(){this.isDragging=!1}setZoom(e){this.scale=Math.max(.1,Math.min(3,e)),this.updateZoomUI(),this.constrainPan(),this.render()}setAspectRatio(e){let t;switch(e){case"1:1":t=1;break;case"4:3":t=4/3;break;case"16:9":t=16/9;break;case"3:2":t=3/2;break;default:t=void 0}t&&this.applyAspectRatio(t),this.fitToCanvas(),this.render()}updateZoomUI(){if(!this.modal)return;let e=this.modal.querySelector(".asset-crop-zoom-value"),t=this.modal.querySelector(".asset-crop-zoom-slider");e&&(e.textContent=`${this.scale.toFixed(1)}x`),t&&(t.value=this.scale.toString())}constrainPan(){if(!this.canvas)return;let e=this.cropWidth*this.scale,t=this.cropHeight*this.scale;this.panX=Math.max(this.canvas.width-e,Math.min(0,this.panX)),this.panY=Math.max(this.canvas.height-t,Math.min(0,this.panY))}reset(){this.initializeCrop(),this.render()}applyCrop(){var a;if(!this.image||!((a=this.options)!=null&&a.onCrop))return;let e=document.createElement("canvas"),t=e.getContext("2d");if(!t)return;e.width=this.cropWidth,e.height=this.cropHeight,t.drawImage(this.image,this.cropX,this.cropY,this.cropWidth,this.cropHeight,0,0,this.cropWidth,this.cropHeight);let n=e.toDataURL("image/png");this.options.onCrop(n),this.close()}close(){this.modal&&this.modal.parentNode&&this.modal.parentNode.removeChild(this.modal);let e=this.options;this.modal=null,this.canvas=null,this.ctx=null,this.image=null,this.options=null,e!=null&&e.onCancel&&e.onCancel()}};window.openAssetCrop=function(i){new Ti().open(i)};ae();var He=require("pixi.js");var ft=require("pixi.js");Dt();var cs=typeof __BUILD_MODE__!="undefined"?__BUILD_MODE__:"undefined",ki=cs;if(typeof window!="undefined")try{let i=new XMLHttpRequest;if(i.open("GET","./build-settings.json",!1),i.send(),i.status===200&&i.responseText){let e=JSON.parse(i.responseText);e!=null&&e.buildMode&&(ki=e.buildMode,console.log(`[ObjectFactory] Build mode overridden by settings: ${ki}`))}}catch{}function ds(i){var t,n,a,s,r;if(typeof window!="undefined"&&window.resolveAnchorVec2)return window.resolveAnchorVec2(i);let e={center:{x:.5,y:.5},"top-left":{x:0,y:0},"top-center":{x:.5,y:0},"top-right":{x:1,y:0},"center-left":{x:0,y:.5},"center-right":{x:1,y:.5},"bottom-left":{x:0,y:1},"bottom-center":{x:.5,y:1},"bottom-right":{x:1,y:1},left:{x:0,y:.5},right:{x:1,y:.5},top:{x:.5,y:0},bottom:{x:.5,y:1}};if(Array.isArray(i))return{x:(t=i[0])!=null?t:.5,y:(n=i[1])!=null?n:.5};if(i&&typeof i=="object"&&"x"in i&&"y"in i)return{x:(a=i.x)!=null?a:.5,y:(s=i.y)!=null?s:.5};if(typeof i=="string"){let o=i.trim().toLowerCase();return(r=e[o])!=null?r:{x:.5,y:.5}}return null}var ue=class{static async create(e,t,n){var l,d,u,c,p,g,m;console.log(`[ObjectFactory] create() called for: ${e}, __BUILD_MODE__: ${ki}`);let a=(l=t==null?void 0:t.render)==null?void 0:l.asset;if(!a){console.log(`[ObjectFactory] No asset definition for: ${e}, returning empty container`);let f=new ft.Container;return this.applyTransform(f,t==null?void 0:t.transform,t),f}let s=(d=t==null?void 0:t.identity)==null?void 0:d.id;console.log(`[ObjectFactory] Calling AssetLoader.load() for: ${e}, configId: ${s}, type: ${a.type}, path: ${a.path}`);let r=await Le.load(e,a,n,s);console.log(`[ObjectFactory] AssetLoader.load() completed for: ${e}, rawAsset type: ${(u=r==null?void 0:r.constructor)==null?void 0:u.name}`);let o;if(a.type==="image")console.log("[ObjectFactory] Creating Sprite from texture:",r,"for object:",e),o=new ft.Sprite(r),console.log("[ObjectFactory] Created object:",o,"type:",(c=o==null?void 0:o.constructor)==null?void 0:c.name),this.applyTransform(o,t==null?void 0:t.transform,t);else if(a.type==="json")if(console.log("[ObjectFactory] JSON asset for",e,"rawAsset type:",(p=r==null?void 0:r.constructor)==null?void 0:p.name,r),r&&(((g=r.constructor)==null?void 0:g.name)==="Container"||r instanceof ft.Container)){console.warn("[ObjectFactory] JSON asset is Container (from cache), reloading JSON directly");let f=[a.path,`/assets/${a.path}`,`assets/${a.path}`,`../assets/${a.path}`],C=!1;for(let b of f)try{let h=await fetch(b);if(h.ok){o=await h.json(),console.log("[ObjectFactory] Reloaded JSON directly from:",b,"type:",(m=o==null?void 0:o.constructor)==null?void 0:m.name),C=!0;break}}catch{continue}C||(console.error("[ObjectFactory] Failed to reload JSON from any path"),o=r)}else o=r;else o=r,o&&typeof o=="object"&&("x"in o||"position"in o)&&this.applyTransform(o,t==null?void 0:t.transform,t);return o}static applyTransform(e,t,n){var a,s,r,o;if(!(!t||!e)&&(t.position&&("x"in e&&"y"in e?(e.x=(a=t.position.x)!=null?a:0,e.y=(s=t.position.y)!=null?s:0):"position"in e&&e.position&&e.position.set((r=t.position.x)!=null?r:0,(o=t.position.y)!=null?o:0)),t.scale!==void 0&&"scale"in e&&e.scale&&(typeof e.scale=="object"&&"set"in e.scale?e.scale.set(t.scale):e.scale=t.scale),t.rotation!==void 0&&"rotation"in e&&(e.rotation=t.rotation),t.anchor&&"anchor"in e&&e.anchor)){let l=ds(t.anchor);l&&("set"in e.anchor?e.anchor.set(l.x,l.y):(e.anchor.x=l.x,e.anchor.y=l.y))}}};ae();var Gt=require("pixi.js"),ge={width:400,height:600,designWidth:400,scaleFactor:1},bt={scale:1,position:1},Ut=[];function ps(i,e,t,n,a,s,r){Ut.push({element:i,originalScale:s,positionHelper:e,heightPercent:a}),e(i,t,n,a,s,r,!1)}function us(){Ut.forEach(({element:i,originalScale:e,positionHelper:t,heightPercent:n})=>{let a=e*ge.scaleFactor;t(i,ge.width,ge.height,n,a,!0,!1)})}function Gn(){Ut.length=0,console.log("[LAYOUT] Cleared all responsive elements")}function Ft(i,e){console.log(`[SCREEN] updateScreenState called: ${i}x${e}`),ge.width=i,ge.height=e,ge.scaleFactor=Math.min(i/ge.designWidth,1.15),bt.scale=ge.scaleFactor,bt.position=1,console.log(`[SCREEN] Global multipliers - scale: ${bt.scale.toFixed(3)}`),us()}var M={layout:{scale_multiplier:1,position_offset:{x:0,y:0},debug_rect_visible:!0,debug_rect_color:16711680,debug_rect_thickness:4,debug_rect_scale_x:1,debug_rect_scale_y:1,screen_scale_x:1,screen_scale_y:1},engine:{scale:1,background_scale:1.05,background_offset_y:0,background_alpha:.98,label_pulse_speed:3,label_pulse_intensity:.03}};function gs(i,e,t){let n=M[i];n&&n[e]!==void 0&&(n[e]=t,console.log(`Updated ${i}.${e} = ${t}`))}function hs(){return M}var fs={center:{x:.5,y:.5},"center-center":{x:.5,y:.5},middle:{x:.5,y:.5},"middle-center":{x:.5,y:.5},"top-left":{x:0,y:0},"top-center":{x:.5,y:0},"top-right":{x:1,y:0},"bottom-left":{x:0,y:1},"bottom-center":{x:.5,y:1},"bottom-right":{x:1,y:1},"left-center":{x:0,y:.5},"right-center":{x:1,y:.5},"center-left":{x:0,y:.5},"center-right":{x:1,y:.5},left:{x:0,y:.5},right:{x:1,y:.5},top:{x:.5,y:0},bottom:{x:.5,y:1}};function Nt(i,e){return typeof i=="number"&&Number.isFinite(i)?i:e}function ke(i,e={x:.5,y:.5}){var t;if(Array.isArray(i))return{x:Nt(i[0],e.x),y:Nt(i[1],e.y)};if(i&&typeof i=="object"){let n=i;return{x:Nt(n.x,e.x),y:Nt(n.y,e.y)}}if(typeof i=="string"){let n=i.trim().toLowerCase();return(t=fs[n])!=null?t:e}return e}function $e(i,e,t,n={}){var g,m,f,C,b,h;let a=ke(t),s=(g=n.inset)!=null?g:{},r=(m=n.padding)!=null?m:{x:0,y:0},o=((f=s.left)!=null?f:0)+r.x,l=((C=s.right)!=null?C:0)+r.x,d=((b=s.top)!=null?b:0)+r.y,u=((h=s.bottom)!=null?h:0)+r.y,c=Math.max(0,i-o-l),p=Math.max(0,e-d-u);return{x:o+c*a.x,y:d+p*a.y}}function De(i,e,t,n={}){var f,C,b,h,v,w;let a=(f=n.inset)!=null?f:{},s=(C=n.padding)!=null?C:{x:0,y:0},r=((b=a.left)!=null?b:0)+s.x,o=((h=a.right)!=null?h:0)+s.x,l=((v=a.top)!=null?v:0)+s.y,d=((w=a.bottom)!=null?w:0)+s.y,u=Math.max(0,i-r-o),c=Math.max(0,e-l-d),p=ke(t,{x:.5,y:.5}),g=Math.min(Math.max(p.x,0),1),m=Math.min(Math.max(p.y,0),1);return{x:r+u*g,y:l+c*m}}function Bt(i,e,t,n={}){var u,c,p;if(!i)return;let a=n.positionRatio?De(e,t,n.positionRatio,{inset:n.inset,padding:n.screenPadding}):$e(e,t,n.anchor,{inset:n.inset,padding:n.screenPadding}),s=(u=n.offset)!=null?u:{x:0,y:0},r=a.x+s.x,o=a.y+s.y;i.anchor&&n.renderAnchor&&i.anchor.set(n.renderAnchor.x,n.renderAnchor.y),te(i,r,o);let l=(c=n.scale)!=null?c:1,d=(p=n.scaleMultiplier)!=null?p:1;(n.scale!==void 0||n.scaleMultiplier!==void 0)&&oe(i,l*d)}if(typeof window!="undefined"){let i=window.innerWidth,e=window.innerHeight,t=()=>{let n=window.innerWidth,a=window.innerHeight;(n!==i||a!==e)&&(i=n,e=a,Ft(n,a))};window.addEventListener("resize",t),window.addEventListener("orientationchange",()=>{setTimeout(t,100)}),window.mraid&&(window.mraid.addEventListener("viewableChange",t),window.mraid.addEventListener("sizeChange",t)),Ft(window.innerWidth,window.innerHeight),window.updateDebugConfig=gs,window.getDebugConfig=hs,window.copyConfig=Ls,window.applyConfig=mt,window.applyConfigForRatio=Ts,window.positionAtBottom=Un,window.positionAtTop=ys,window.positionAtCenter=vs,window.positionAtLeft=ws,window.positionAtRight=xs,window.positionAtBottomLeft=Ss,window.positionAtBottomRight=Es,window.positionAtTopLeft=Cs,window.positionAtTopRight=As,window.applyPositionContract=bs,console.log("\u{1F3AE} Debug Config Functions Available:"),console.log("\u2022 updateDebugConfig(category, key, value)"),console.log("\u2022 getDebugConfig()"),console.log("\u2022 copyConfig(presetName)"),console.log("\u2022 applyConfig(config)"),console.log("\u2022 applyConfigForRatio(width, height)"),console.log("\u{1F4CD} Positioning Helpers Available (with scale):"),console.log("\u2022 positionAtBottom(element, w, h, percent, scale)"),console.log("\u2022 positionAtTop(element, w, h, percent, scale)"),console.log("\u2022 positionAtCenter(element, w, h, offsetX, offsetY, scale)"),console.log("\u2022 positionAtLeft/Right(element, w, h, percent, scale)"),console.log("\u2022 Corner positions: BottomLeft/Right, TopLeft/Right (all with scale)"),console.log("\u2022 applyPositionContract(element, w, h, contract)"),console.log("Example: positionAtCenter(mySprite, 400, 600, 0, -50, 1.2)")}function qt(i,e,t=0){return i*e+t}function Vt(i,e,t=0){return i*(1-e)+t}function Wt(i,e,t=0){return i*e+t}function Yt(i,e,t=0){return i*(1-e)+t}function Q(i,e=0){return i/2+e}function ms(i,e){return i*e}function bs(i,e,t,n){var r,o,l,d,u,c,p,g,m,f,C,b,h,v,w,y,P,j,B,R;let a=0,s=0;switch(n.type){case"top":a=Q(e,(o=(r=n.offset)==null?void 0:r.x)!=null?o:0),s=qt(t,n.percent,(d=(l=n.offset)==null?void 0:l.y)!=null?d:0);break;case"bottom":a=Q(e,(c=(u=n.offset)==null?void 0:u.x)!=null?c:0),s=Vt(t,n.percent,(g=(p=n.offset)==null?void 0:p.y)!=null?g:0);break;case"left":a=Wt(e,n.percent,(f=(m=n.offset)==null?void 0:m.x)!=null?f:0),s=Q(t,(b=(C=n.offset)==null?void 0:C.y)!=null?b:0);break;case"right":a=Yt(e,n.percent,(v=(h=n.offset)==null?void 0:h.x)!=null?v:0),s=Q(t,(y=(w=n.offset)==null?void 0:w.y)!=null?y:0);break;case"center":a=Q(e,(j=(P=n.offset)==null?void 0:P.x)!=null?j:0),s=Q(t,(R=(B=n.offset)==null?void 0:B.y)!=null?R:0);break}i.position?i.position.set(a,s):(i.x=a,i.y=s),n.scale!==void 0&&n.scale!==1&&i.scale&&(typeof i.scale.set=="function"?i.scale.set(n.scale,n.scale):(i.scale.x=n.scale,i.scale.y=n.scale))}function Un(i,e,t,n=.2,a=1,s=!0,r=!1){let o=ms(t,n),l=Vt(t,n/2);te(i,Q(e),l);let d=s?a*ge.scaleFactor:a;oe(i,d),r&&!Ut.find(u=>u.element===i)&&ps(i,Un,e,t,n,a,s)}function ys(i,e,t,n=.1,a=1){te(i,Q(e),qt(t,n)),oe(i,a)}function vs(i,e,t,n=0,a=0,s=1){te(i,Q(e,n),Q(t,a)),oe(i,s)}function ws(i,e,t,n=.1,a=1){te(i,Wt(e,n),Q(t)),oe(i,a)}function xs(i,e,t,n=.1,a=1){te(i,Yt(e,n),Q(t)),oe(i,a)}function Ss(i,e,t,n=.05,a=.05,s=1){te(i,Wt(e,a),Vt(t,n)),oe(i,s)}function Es(i,e,t,n=.05,a=.05,s=1){te(i,Yt(e,a),Vt(t,n)),oe(i,s)}function Cs(i,e,t,n=.05,a=.05,s=1){te(i,Wt(e,a),qt(t,n)),oe(i,s)}function As(i,e,t,n=.05,a=.05,s=1){te(i,Yt(e,a),qt(t,n)),oe(i,s)}function te(i,e,t){i&&i.position?typeof i.position.set=="function"?i.position.set(e,t):(i.position.x=e,i.position.y=t):i&&(i.x=e,i.y=t)}function oe(i,e){e!==1&&i&&i.scale&&(typeof i.scale.set=="function"?i.scale.set(e,e):i.scale.x!==void 0&&i.scale.y!==void 0&&(i.scale.x=e,i.scale.y=e))}var ze={default:{layout:{scale_multiplier:1,position_offset:{x:0,y:0},debug_rect_visible:!0,debug_rect_color:16711680,debug_rect_thickness:4,debug_rect_scale_x:1,debug_rect_scale_y:1,screen_scale_x:1,screen_scale_y:1},engine:{scale:1,background_scale:1.05,background_offset_y:0,background_alpha:.98,label_pulse_speed:3,label_pulse_intensity:.03}},wide:{layout:{scale_multiplier:1,position_offset:{x:0,y:0},debug_rect_visible:!0,debug_rect_color:16711680,debug_rect_thickness:4,debug_rect_scale_x:1,debug_rect_scale_y:1,screen_scale_x:.9,screen_scale_y:1.1},engine:{scale:1,background_scale:1.1,background_offset_y:0,background_alpha:.95,label_pulse_speed:3,label_pulse_intensity:.03}},square:{layout:{scale_multiplier:1,position_offset:{x:0,y:0},debug_rect_visible:!0,debug_rect_color:16711680,debug_rect_thickness:4,debug_rect_scale_x:1,debug_rect_scale_y:1,screen_scale_x:.85,screen_scale_y:.85},engine:{scale:1,background_scale:1,background_offset_y:0,background_alpha:1,label_pulse_speed:3,label_pulse_intensity:.03}},tall:{layout:{scale_multiplier:1,position_offset:{x:0,y:0},debug_rect_visible:!0,debug_rect_color:16711680,debug_rect_thickness:4,debug_rect_scale_x:1,debug_rect_scale_y:1,screen_scale_x:1.1,screen_scale_y:.9},engine:{scale:1,background_scale:.95,background_offset_y:0,background_alpha:1,label_pulse_speed:3,label_pulse_intensity:.03}}};function Ls(i){return i&&ze[i]?JSON.parse(JSON.stringify(ze[i])):JSON.parse(JSON.stringify(M))}function mt(i){Object.keys(i).forEach(e=>{let t=e;M[t]&&i[t]&&Object.assign(M[t],i[t])}),console.log("Config applied:",i)}function Ts(i,e){let t=i/e;t>1.6?(mt(ze.wide),console.log("Applied WIDE config for ratio:",t)):t<.7?(mt(ze.tall),console.log("Applied TALL config for ratio:",t)):t>.8&&t<1.2?(mt(ze.square),console.log("Applied SQUARE config for ratio:",t)):(mt(ze.default),console.log("Applied DEFAULT config for ratio:",t))}if(typeof window!="undefined"){let i=window;i.configPresets=ze,i.resolveAnchorVec2=i.resolveAnchorVec2||ke,i.resolveScreenAnchorPoint=i.resolveScreenAnchorPoint||$e,i.resolveScreenRatioPoint=i.resolveScreenRatioPoint||De}var W=null;function qn(i,e,t,n,a,s={}){var U,ie,be,ye,ve,we,xe,Se,q,Ie,nt,at,st,rt,ot,lt,ct,dt,pt,ut,N,K,G,X,Fe,Me,Hi,Ni,Fi,Bi,Gi,Ui,qi,Vi;let r=(U=s.enableDebugLogs)!=null?U:!1;r&&(console.log("\u{1F3AF} [LAYOUT_DEBUGS] ===== STARTING LAYOUT CALCULATION ====="),console.log("\u{1F3AF} [LAYOUT_DEBUGS] Screen dimensions:",{width:n.width,height:n.height}),console.log("\u{1F3AF} [LAYOUT_DEBUGS] Time:",t),console.log("\u{1F3AF} [LAYOUT_DEBUGS] Options:",s));let{mainContainer:o,label:l,background:d,backgroundTexture:u,app:c}=i;if(!c||!c.renderer){r&&console.log("\u{1F3AF} [LAYOUT_DEBUGS] \u274C No app or renderer, skipping layout");return}r&&(console.log("\u{1F3AF} [LAYOUT_DEBUGS] App renderer dimensions:",{width:c.renderer.width,height:c.renderer.height}),console.log("\u{1F3AF} [LAYOUT_DEBUGS] App screen dimensions:",{width:c.screen.width,height:c.screen.height}));let p=n.width,g=n.height;r&&console.log("\u{1F3AF} [LAYOUT_DEBUGS] Base dimensions:",{baseWidth:p,baseHeight:g});let m=p*M.layout.screen_scale_x,f=g*M.layout.screen_scale_y,C=p/2,b=e.engine.runtime||{},h=b.layout||{};r&&(console.log("\u{1F3AF} [LAYOUT_DEBUGS] Debug config:",{screen_scale_x:M.layout.screen_scale_x,screen_scale_y:M.layout.screen_scale_y}),console.log("\u{1F3AF} [LAYOUT_DEBUGS] Calculated dimensions:",{width:m,height:f,midX:C}),console.log("\u{1F3AF} [LAYOUT_DEBUGS] Engine runtime:",b),console.log("\u{1F3AF} [LAYOUT_DEBUGS] Layout config:",h));let v=h.design_width_portrait||400,w=m/v;w=Math.min(w,1.15);let y=w*((ie=M.engine.scale)!=null?ie:1),P=(be=s.skipMainContainerTransform)!=null?be:!1;!P&&o&&o.scale&&(typeof o.scale.set=="function"?o.scale.set(y):(o.scale.x=y,o.scale.y=y));let j=(ye=h.main_container_anchor)!=null?ye:"center",B=(ve=h.main_container_position_ratio)!=null?ve:{x:.5,y:.5},R=(we=h.main_container_offset)!=null?we:{x:0,y:0},H=h.main_container_position_ratio?De(p,g,B):$e(p,g,j),z=H.x+R.x+M.layout.position_offset.x,L=H.y+R.y+M.layout.position_offset.y;if(!P&&o&&o.position&&(typeof o.position.set=="function"?o.position.set(z,L):(o.position.x=z,o.position.y=L)),a&&(o!=null&&o.toLocal))for(let[V,F]of e.objects.entries()){let _=F==null?void 0:F.transform;if(!_||((xe=_.position_mode)!=null?xe:"static")!=="static")continue;let k=(Se=a.get)==null?void 0:Se.call(a,V),ne=((q=k==null?void 0:k.getDisplayObject)==null?void 0:q.call(k))||(k==null?void 0:k.pixiObject)||k;if(!ne||ne.parent!==o)continue;let kt=_.position_ratio!=null?De(p,g,_.position_ratio):$e(p,g,(Ie=_.anchor)!=null?Ie:"center"),Pt=o.toLocal(new Gt.Point(kt.x,kt.y)),It=(nt=_.position)!=null?nt:{x:0,y:0},je=Pt.x+It.x,si=Pt.y+It.y;typeof(k==null?void 0:k.setPosition)=="function"?k.setPosition(je,si):(te(ne,je,si),(at=k==null?void 0:k.transform)!=null&&at.position&&(k.transform.position.x=je,k.transform.position.y=si))}let S=typeof window!="undefined"?window.__BUILD_SETTINGS__:null,A=((S==null?void 0:S.buildMode)||(typeof __BUILD_MODE__!="undefined"?__BUILD_MODE__:"dev"))==="dev";if(M.layout.debug_rect_visible&&A){(!W||W.parent!==c.stage)&&(W==null||W.destroy(),W=new Gt.Graphics,W.zIndex=9999,c.stage.addChild(W)),W.clear();let V=M.layout.debug_rect_scale_x,F=M.layout.debug_rect_scale_y,_=(p-4)*V,Ee=(g-4)*F,k=(p-_)/2,ne=(g-Ee)/2;r&&(console.log("\u{1F3AF} [LAYOUT_DEBUGS] ===== DEBUG RECT POSITIONING ====="),console.log("\u{1F3AF} [LAYOUT_DEBUGS] Debug rect calculations:",{baseWidth:p,baseHeight:g,rectW:_,rectH:Ee,offsetX:k,offsetY:ne}),console.log("\u{1F3AF} [LAYOUT_DEBUGS] Debug rect final position:",{x:2+k,y:2+ne,width:_,height:Ee})),W.rect(2+k,2+ne,_,Ee).stroke({width:M.layout.debug_rect_thickness,color:M.layout.debug_rect_color})}else W&&(W.destroy(),W=null);let T=((st=i.label)==null?void 0:st.config)||e.objects.get("label_1")||e.objects.get("ui_tutorial_1");if(l&&l.position&&T){let V=(ot=(rt=T==null?void 0:T.transform)==null?void 0:rt.anchor)!=null?ot:"center",F=(lt=T==null?void 0:T.transform)==null?void 0:lt.position_ratio,_=((ct=T==null?void 0:T.transform)==null?void 0:ct.offset)||{x:0,y:0};Bt(l,p,g,{anchor:V,positionRatio:F,offset:{x:_.x*y,y:_.y*y},renderAnchor:ke(V)})}if(l&&l.alpha>0){let V=1+Math.sin(t*M.engine.label_pulse_speed)*M.engine.label_pulse_intensity,F=(pt=(dt=T==null?void 0:T.transform)==null?void 0:dt.scale)!=null?pt:1,_=V*y*F;l.scale&&(typeof l.scale.set=="function"?l.scale.set(_):(l.scale.x=_,l.scale.y=_))}if(r&&console.log("\u{1F3AF} [LAYOUT_DEBUGS] ===== BACKGROUND POSITIONING ====="),d){r&&(console.log("\u{1F3AF} [LAYOUT_DEBUGS] Background object exists:",!!d),console.log("\u{1F3AF} [LAYOUT_DEBUGS] Background type:",(ut=d.constructor)==null?void 0:ut.name)),d.alpha=((K=(N=b.background)==null?void 0:N.alpha)!=null?K:.98)*M.engine.background_alpha,r&&console.log("\u{1F3AF} [LAYOUT_DEBUGS] Background alpha set to:",d.alpha);let V=e.objects.get("background_1");r&&console.log("\u{1F3AF} [LAYOUT_DEBUGS] Background config:",V);let F=(V==null?void 0:V.transform)||{};r&&console.log("\u{1F3AF} [LAYOUT_DEBUGS] Background transform:",F);let _=F.offset||{x:0,y:0},Ee=((X=(G=b.background)==null?void 0:G.offset_y)!=null?X:0)+M.engine.background_offset_y,k=(Fe=F.anchor)!=null?Fe:"center",ne=F.position_ratio;if(r&&console.log("\u{1F3AF} [LAYOUT_DEBUGS] Background positioning params:",{bgOffset:_,bgRuntimeOffsetY:Ee,bgScreenAnchor:k,bgPositionRatio:ne,baseWidth:p,baseHeight:g,finalScale:y}),Bt(d,p,g,{anchor:k,positionRatio:ne,offset:{x:_.x*y,y:_.y*y+Ee},renderAnchor:ke(k)}),r&&(console.log("\u{1F3AF} [LAYOUT_DEBUGS] Background position after applyScreenAnchor:",{x:d.x,y:d.y,scaleX:(Me=d.scale)==null?void 0:Me.x,scaleY:(Hi=d.scale)==null?void 0:Hi.y,anchorX:(Ni=d.anchor)==null?void 0:Ni.x,anchorY:(Fi=d.anchor)==null?void 0:Fi.y,pivotX:(Bi=d.pivot)==null?void 0:Bi.x,pivotY:(Gi=d.pivot)==null?void 0:Gi.y,width:d.width,height:d.height}),console.log("\u{1F3AF} [LAYOUT_DEBUGS] Background texture dimensions:",{textureWidth:u==null?void 0:u.width,textureHeight:u==null?void 0:u.height})),u){let kt=Math.max(m/u.width,f/u.height),Pt=(qi=(Ui=b.background)==null?void 0:Ui.scale_multiplier)!=null?qi:1.05,It=(Vi=F.scale)!=null?Vi:1,je=kt*Pt*M.engine.background_scale*It;d.scale&&(typeof d.scale.set=="function"?d.scale.set(je):(d.scale.x=je,d.scale.y=je))}else d&&typeof d.clear=="function"&&(d.clear(),d.rect(-m/2,-f/2,m,f).fill({color:1444375}))}}ae();ae();var Vn=ri(require("lottie-web"),1);Kt(Ln);typeof window!="undefined"&&!window.lottie&&(window.lottie=Vn.default);gi();ae();var Pi=rn.version,Ps=new Set(["init","boot","view","ready","start","pause","resume","complete","error","engagement","first_interaction","retry","cta_show","cta_click","cta_dismiss","clickout","conversion","session_time","level_time","load_time","level_start","level_complete","level_fail","checkpoint","reward","tutorial_start","tutorial_complete","tutorial_skip","ab_assign","fps","memory","asset_load_start","asset_load_complete"]);sn();var Qn={mechanic_id:"TODO_mechanic_id",variant_id:"TODO_variant_id",deployment_id:"TODO_deployment_id",export_id:"TODO_export_id",profile_id:"TODO_profile_id",instance_id:"default"},ea=Math.random().toString(36).slice(2),Ye=null,Ve={...Qn},ta="web_embed",_i={},wt,Ii=!1,vt=!1,St=!1,ia=!1,$i=1,Jt=0,ei=!1,he=!1,We="",Ke=Math.floor(window.innerWidth),Xe=Math.floor(window.innerHeight),Oi=Ke>Xe,fe=!1,xt=!1,Wn=!1,Yn=!1,Mi=!1,Zt=null,Ne=null,Ri=!1,zi=!1,Xt=new Map;function na(){if(!Ne)return null;let i=Date.now()-Ne;return!Number.isFinite(i)||i<0?null:i}function ji(i){if(Ri)return;let e=na();e!==null&&(Ri=!0,x("session_time",{duration_ms:e,reason:i}))}function Kn(){if(Ye)return Ye;let i=document.createElement("div");return i.id="handler-root",i.setAttribute("data-handler-root","true"),document.body.appendChild(i),Ye=i,i}function Qt(i){switch(i){case"interaction":return"engagement";case"finish":return"complete";case"install":return"cta_click";default:return i}}function aa(i,e){return{event_name:i,ts:Date.now(),session_id:ea,deployment_id:Ve.deployment_id,variant_id:Ve.variant_id,export_profile_id:Ve.profile_id,instance_id:Ve.instance_id||"default",env:ta==="mraid"?"mraid":"web",attribution:wt,payload:e}}function x(i,e){let t=Qt(i),n=aa(t,e);li(n,!!_i.analytics),_t(t,n),t!==i&&_t(i,n)}function Et(){Zt&&(Zt(Ke,Xe),Zt=null)}function Je(i){$i=i,x("volume",i)}function Ze(i){i&&(ia=!0),!St&&(St=!0,x("pause"),Je(0))}function Ct(i){!i&&ia||St&&(St=!1,x("resume"),Je($i))}function Pe(i,e){Ke=Math.floor(i||window.innerWidth),Xe=Math.floor(e||window.innerHeight),Oi=Ke>Xe,x("resize",{width:Ke,height:Xe})}function Is(){if(yn())try{let i=mraid.getMaxSize();Pe(i.width,i.height);let e=()=>{mraid.isViewable()&&mraid.getState()!=="hidden"?Ct():Ze()};if(mraid.addEventListener("viewableChange",e),mraid.addEventListener("stateChange",e),mraid.addEventListener("sizeChange",()=>{let t=mraid.getMaxSize();Pe(t.width,t.height)}),mraid.getAudioVolume){let t=mraid.getAudioVolume();Je(t?1:0)}if(mraid.addEventListener("audioVolumeChange",t=>{t!==null&&Je(t>0?1:0)}),mraid.addEventListener("error",(t,n)=>{console.warn("mraid error:",t,"action:",n)}),ei=!0,mraid.isViewable()&&mraid.getState()!=="hidden")fe=!0,x("boot"),x("view"),x("ready"),he=!0,Et();else{let t=()=>{fe=!0,x("boot"),x("view"),x("ready"),he=!0,Et()};mraid.addEventListener("ready",t)}}catch(i){console.warn("MRAID hook skipped",i)}}function Ms(){if(vn())try{let i=dapi.getScreenSize();Pe(i.width,i.height),dapi.addEventListener("viewableChange",t=>{t.isViewable?Ct():Ze()}),dapi.addEventListener("adResized",t=>{let n=dapi.getScreenSize();Pe(t.width||n.width,t.height||n.height)});let e=dapi.getAudioVolume();if(Je(e?1:0),dapi.addEventListener("audioVolumeChange",t=>Je(t?1:0)),ei=!0,dapi.isViewable())fe=!0,x("boot"),x("view"),x("ready"),he=!0,Et();else{let t=()=>{fe=!0,x("boot"),x("view"),x("ready"),he=!0,Et()};dapi.addEventListener("ready",t)}}catch(i){console.warn("DAPI hook skipped",i)}}function Xn(){let i=()=>{fe||document.visibilityState==="visible"&&(document.readyState==="complete"||document.readyState==="interactive")&&(fe=!0,x("boot"),x("view"),x("ready"),he=!0,Et(),xt&&(xt=!1,le.start()))};window.addEventListener("resize",()=>Pe()),document.addEventListener("visibilitychange",()=>{document.visibilityState==="visible"?(Ct(),i()):Ze()}),document.readyState==="complete"||document.readyState==="interactive"?i():window.addEventListener("load",i),ei=!0}function js(){let i=e=>{typeof TouchEvent!="undefined"&&e instanceof TouchEvent&&(Wn=!0),!(Wn&&e instanceof MouseEvent)&&(Jt+=1,zi||(zi=!0,x("first_interaction",{count:Jt})),x("interaction",Jt))};document.addEventListener("mousedown",i),document.addEventListener("touchstart",i)}function Jn(i){var n,a,s,r,o,l,d,u,c,p,g,m;let e=typeof AD_PROTOCOL!="undefined"?AD_PROTOCOL:"none";if((typeof AD_NETWORK!="undefined"?AD_NETWORK:"web_embed")==="google")try{(n=window.ExitApi)==null||n.exit();return}catch{}if(e==="mraid"&&typeof mraid!="undefined")mraid.open(i||"");else if(e==="dapi"&&typeof dapi!="undefined")dapi.openStoreUrl();else if(Ue())(s=(a=window.TJ_API)==null?void 0:a.click)==null||s.call(a);else if(wn())(o=(r=window.FbPlayableAd)==null?void 0:r.onCTAClick)==null||o.call(r);else if(Cn())(d=(l=window.ScPlayableAd)==null?void 0:l.onCTAClick)==null||d.call(l);else if(En())try{(c=(u=window.smxTracking)==null?void 0:u.redirect)==null||c.call(u)}catch(f){console.warn("Smadex redirect failed",f)}else if(xn()){let f=window.ExitApi;f&&typeof f.exit=="function"?f.exit(i||We||""):i&&window.open(i)}else Ge()?(p=window.install)==null||p.call(window):Sn()?(g=window.openAppStore)==null||g.call(window):ci()?(m=parent==null?void 0:parent.postMessage)==null||m.call(parent,"download","*"):i&&window.open(i)}function _s(){let i=typeof AD_NETWORK!="undefined"?AD_NETWORK:"web_embed",e=t=>{if(!t)return;let n=new Image;n.src=t};if(i==="bigabid"){let t=window.BIGABID_BIDTIMEMACROS;if(!t)return;J("view",()=>e(t.mraid_viewable)),J("start",()=>e(t.game_viewable)),J("engagement",()=>e(t.engagement));let n=()=>e(t.complete);J("complete",n),jt("engagement",a=>{var s;((s=a==null?void 0:a.payload)==null?void 0:s.count)>3&&n()}),J("cta_click",()=>e(t.click))}else if(i==="inmobi"){let t=window.INMOBI_DSPMACROS;if(!t)return;J("view",()=>e(t.Ad_Load_Start)),J("start",()=>e(t.Ad_Viewable)),J("engagement",()=>e(t.First_Engagement)),J("complete",()=>e(t.Gameplay_Complete)),J("cta_click",()=>e(t.DSP_Click)),J("start",()=>{[5,10,15,20,25,30].forEach(n=>setTimeout(()=>e(t[`Spent_${n}_Seconds`]),n*1e3))})}}function Os(){if(!Ue())return;let i=window.TJ_API;i&&i.setPlayableAPI&&i.setPlayableAPI({skipAd:()=>{try{le.finish()}catch(e){console.warn("Tapjoy skip failed",e)}}})}function Zn(){var e,t,n;let i=window.TJ_API;(e=i==null?void 0:i.objectiveComplete)==null||e.call(i),(t=i==null?void 0:i.playableFinished)==null||t.call(i),(n=i==null?void 0:i.gameplayFinished)==null||n.call(i)}function Rs(){Ge()&&(window.mintGameStart=()=>{Ct(!0),Pe()},window.mintGameClose=()=>{Ze(!0)})}function zs(){if(!di())return;let i=window.NUC;!i||!i.trigger||(le.on("cta_click",()=>{var e,t;return(t=(e=i.trigger).convert)==null?void 0:t.call(e,We)}),le.on("complete",()=>{var e,t;return(t=(e=i.trigger).tryAgain)==null?void 0:t.call(e)}))}var le={init(i={},e){var t;if(ta=i.profile||"web_embed",_i=i.consent||{},Ve={...Qn,...i.ids||{}},Ye=i.rootEl||Ye,wt=void 0,Ji((t=i.telemetry)!=null&&t.endpoint?i.telemetry:null),Ne=null,Ri=!1,zi=!1,Xt.clear(),We=i.destinationUrl||(/android/i.test(navigator.userAgent)?"https://play.google.com/store":"https://www.apple.com/app-store/"),e&&(Zt=e),x("init"),document.body.oncontextmenu=()=>!1,Kn(),Ds(Ye),An(),Is(),Ms(),!ei){if(document.readyState==="complete")Xn();else if(!Yn){Yn=!0;let n=()=>{Xn(),window.removeEventListener("load",n),document.removeEventListener("DOMContentLoaded",n)};window.addEventListener("load",n),document.addEventListener("DOMContentLoaded",n)}}js(),_s(),Os(),Rs(),zs(),console.log(`%c @handler/playable-sdk %c v${Pi} `,"background: var(--ui-console-info); color: var(--ui-white); font-size: 14px; padding: 4px 8px; border-top-left-radius: 4px; border-bottom-left-radius: 4px;","background: var(--ui-console-bg); color: var(--ui-console-text); font-size: 14px; padding: 4px 8px; border-top-right-radius: 4px; border-bottom-right-radius: 4px;"),fe&&!he&&(x("boot"),x("view"),x("ready"),xt&&(xt=!1,le.start()),he=!0),he=fe},getRoot(){return Kn()},get version(){return Pi},get maxWidth(){return Ke},get maxHeight(){return Xe},get isLandscape(){return Oi},get isReady(){return he},get isStarted(){return Ii},get isPaused(){return St},get isFinished(){return vt},get volume(){return $i},get interactions(){return Jt},on(i,e){jt(Qt(i),e)},off(i,e){oi(Qt(i),e)},start(){var i,e;if(!Ii){if(!fe){xt=!0;return}if(Ii=!0,Ne||(Ne=Date.now()),x("start"),Pe(),Ge())Ze(),(i=window.gameReady)==null||i.call(window);else if(Ue()){let t=window.TJ_API;(e=t==null?void 0:t.setPlayableBuild)==null||e.call(t,{orientation:Oi?"landscape":"portrait",buildID:Pi})}}},finish(){var i,e;vt||(vt=!0,x("complete"),ji("complete"),Ge()?(i=window.gameEnd)==null||i.call(window):ci()?(e=parent==null?void 0:parent.postMessage)==null||e.call(parent,"complete","*"):Ue()&&Zn())},install(i){if(!vt){vt=!0,Ue()?(Zn(),setTimeout(()=>le.install(i),300)):(x("complete"),setTimeout(()=>le.install(i),0));return}Mi||(Mi=!0,setTimeout(()=>Mi=!1,500),x("cta_click"),x("conversion"),ji("cta"),Jn(i||We))},emit(i,e){let t=Qt(i);if(!Ps.has(t)&&t!=="resize"&&t!=="volume"&&!t.startsWith("custom."))throw new Error(`Event ${i} must be canonical or namespaced as custom.<mechanic_id>.<event>`);let n=aa(t,e);li(n,!!_i.analytics),_t(t,n)},gameStart(){le.start()},gameEnd(){le.finish()},ctaClick(i,e){x("cta_click",{url:i||We,manual:!0}),(e==null?void 0:e.open)!==!1&&Jn(i||We)},ctaShow(i){x("cta_show",i)},ctaDismiss(i){x("cta_dismiss",i)},getGameTimeMs(){return na()},endSession(i="manual"){ji(i)},setAttribution(i){wt=i},abTest(i,e){if(!i)throw new Error("abTest requires experimentId");if(!Array.isArray(e)||e.length<2)throw new Error("abTest requires at least 2 variants");let t=Math.abs($s(`${ea}:${i}`))%e.length,n=e[t];return wt={...wt||{},experiment_id:i},Ve.variant_id=n,x("ab_assign",{experiment_id:i,variant_id:n}),n},levelStart(i,e){Ne||(Ne=Date.now()),x("level_start",{level_id:i,...e})},levelComplete(i,e){x("level_complete",{level_id:i,...e})},levelFail(i,e){x("level_fail",{level_id:i,...e})},checkpoint(i,e){x("checkpoint",{checkpoint_id:i,...e})},reward(i,e){x("reward",{reward_id:i,...e})},tutorialStart(i,e){x("tutorial_start",{step_id:i,...e})},tutorialComplete(i,e){x("tutorial_complete",{step_id:i,...e})},tutorialSkip(i,e){x("tutorial_skip",{step_id:i,...e})},timerStart(i){i&&Xt.set(i,Date.now())},timerEnd(i,e="custom",t){if(!i)return;let n=Xt.get(i);if(!n)return;Xt.delete(i);let a=Date.now()-n;if(!(!Number.isFinite(a)||a<0)){if(e==="custom"){x("engagement",{action:"timer",key:i,duration_ms:a,...t});return}x(e,{key:i,duration_ms:a,...t})}},fps(i,e){x("fps",{value:i,...e})},memory(i,e){x("memory",{bytes:i,...e})},assetLoadStart(i,e){x("asset_load_start",{asset_id:i,...e})},assetLoadComplete(i,e){x("asset_load_complete",{asset_id:i,...e})},reportError(i,e,t){x("error",{code:i,message:e,...t})},retry(){var i,e,t;if(Ge())(i=window.gameRetry)==null||i.call(window);else if(di()){let n=window.NUC;(t=(e=n==null?void 0:n.trigger)==null?void 0:e.tryAgain)==null||t.call(e)}x("engagement",{action:"retry"})},pause(){Ze(!0)},resume(){Ct(!0)},resize(i,e){Pe(i,e)}},yt=le;function $s(i){let e=2166136261;for(let t=0;t<i.length;t++)e^=i.charCodeAt(t),e=Math.imul(e,16777619);return e|0}function Ds(i){let e=document.createElement("script");e.type="text/javascript",e.textContent=`
229
+ `,this.modal=e,this.attachEventListeners(),this.initializeCanvas()}initializeCanvas(){this.modal&&(this.canvas=this.modal.querySelector(".asset-crop-canvas"),this.canvas&&(this.ctx=this.canvas.getContext("2d"),this.canvas.width=400,this.canvas.height=300))}loadImage(){this.options&&(this.image=new Image,this.image.crossOrigin="anonymous",this.image.onload=()=>{this.initializeCrop(),this.render()},this.image.src=this.options.imageSrc)}initializeCrop(){var n;if(!this.image||!this.canvas)return;let e=this.image.width/this.image.height,t=this.canvas.width/this.canvas.height;e>t?(this.cropHeight=this.image.height,this.cropWidth=this.cropHeight*t,this.cropX=(this.image.width-this.cropWidth)/2,this.cropY=0):(this.cropWidth=this.image.width,this.cropHeight=this.cropWidth/t,this.cropX=0,this.cropY=(this.image.height-this.cropHeight)/2),(n=this.options)!=null&&n.aspectRatio&&this.applyAspectRatio(this.options.aspectRatio),this.fitToCanvas()}applyAspectRatio(e){if(!this.image)return;let t=this.image.width/this.image.height,n=this.cropX+this.cropWidth/2,a=this.cropY+this.cropHeight/2;e>t?(this.cropWidth=Math.min(this.image.width,this.cropHeight*e),this.cropHeight=this.cropWidth/e):(this.cropHeight=Math.min(this.image.height,this.cropWidth/e),this.cropWidth=this.cropHeight*e),this.cropX=Math.max(0,Math.min(this.image.width-this.cropWidth,n-this.cropWidth/2)),this.cropY=Math.max(0,Math.min(this.image.height-this.cropHeight,a-this.cropHeight/2))}fitToCanvas(){if(!this.image||!this.canvas)return;let e=this.canvas.width/this.cropWidth,t=this.canvas.height/this.cropHeight;this.scale=Math.min(e,t)*.9,this.panX=(this.canvas.width-this.cropWidth*this.scale)/2,this.panY=(this.canvas.height-this.cropHeight*this.scale)/2}render(){!this.ctx||!this.image||!this.canvas||(this.ctx.clearRect(0,0,this.canvas.width,this.canvas.height),this.ctx.save(),this.ctx.translate(this.panX,this.panY),this.ctx.scale(this.scale,this.scale),this.ctx.drawImage(this.image,-this.cropX,-this.cropY,this.image.width,this.image.height),this.ctx.restore(),this.drawCropOverlay(),this.updatePreview())}drawCropOverlay(){if(!this.ctx||!this.canvas)return;let e=this.panX,t=this.panY,n=this.cropWidth*this.scale,a=this.cropHeight*this.scale;this.ctx.fillStyle="rgba(0, 0, 0, 0.5)",this.ctx.fillRect(0,0,this.canvas.width,this.canvas.height),this.ctx.clearRect(e,t,n,a),this.ctx.strokeStyle="#ffffff",this.ctx.lineWidth=2,this.ctx.strokeRect(e,t,n,a),this.ctx.fillStyle="#ffffff";let s=8;[[e,t],[e+n-s,t],[e,t+a-s],[e+n-s,t+a-s]].forEach(([o,c])=>{var l;(l=this.ctx)==null||l.fillRect(o,c,s,s)})}updatePreview(){if(!this.modal||!this.image)return;let e=this.modal.querySelector(".asset-crop-preview-canvas");if(!e)return;let t=e.getContext("2d");if(!t)return;let n=150;e.width=n,e.height=n;let a=n/this.cropWidth,s=n/this.cropHeight,r=Math.min(a,s),o=this.cropWidth*r,c=this.cropHeight*r,l=(n-o)/2,u=(n-c)/2;t.drawImage(this.image,this.cropX,this.cropY,this.cropWidth,this.cropHeight,l,u,o,c)}attachEventListeners(){if(!this.modal||!this.canvas)return;this.canvas.addEventListener("mousedown",this.handleMouseDown.bind(this)),this.canvas.addEventListener("mousemove",this.handleMouseMove.bind(this)),this.canvas.addEventListener("mouseup",this.handleMouseUp.bind(this)),this.canvas.addEventListener("wheel",this.handleWheel.bind(this)),this.canvas.addEventListener("touchstart",this.handleTouchStart.bind(this)),this.canvas.addEventListener("touchmove",this.handleTouchMove.bind(this)),this.canvas.addEventListener("touchend",this.handleTouchEnd.bind(this));let e=this.modal.querySelector(".asset-crop-zoom-slider");e==null||e.addEventListener("input",n=>{let a=parseFloat(n.target.value);this.setZoom(a)});let t=this.modal.querySelector(".asset-crop-aspect-select");t==null||t.addEventListener("change",n=>{let a=n.target.value;this.setAspectRatio(a)}),this.modal.addEventListener("click",n=>{switch(n.target.dataset.action){case"reset":this.reset();break;case"apply":this.applyCrop();break;case"cancel":case"close":this.close();break}}),this.modal.addEventListener("click",n=>{n.target===this.modal&&this.close()})}handleMouseDown(e){this.isDragging=!0,this.dragStartX=e.clientX,this.dragStartY=e.clientY,this.lastPanX=this.panX,this.lastPanY=this.panY,this.canvas.style.cursor="grabbing"}handleMouseMove(e){if(!this.isDragging)return;let t=e.clientX-this.dragStartX,n=e.clientY-this.dragStartY;this.panX=this.lastPanX+t,this.panY=this.lastPanY+n,this.constrainPan(),this.render()}handleMouseUp(){this.isDragging=!1,this.canvas.style.cursor="grab"}handleWheel(e){e.preventDefault();let t=e.deltaY>0?.9:1.1;this.setZoom(this.scale*t)}handleTouchStart(e){e.touches.length===1&&(this.isDragging=!0,this.dragStartX=e.touches[0].clientX,this.dragStartY=e.touches[0].clientY,this.lastPanX=this.panX,this.lastPanY=this.panY)}handleTouchMove(e){if(!this.isDragging||e.touches.length!==1)return;e.preventDefault();let t=e.touches[0].clientX-this.dragStartX,n=e.touches[0].clientY-this.dragStartY;this.panX=this.lastPanX+t,this.panY=this.lastPanY+n,this.constrainPan(),this.render()}handleTouchEnd(){this.isDragging=!1}setZoom(e){this.scale=Math.max(.1,Math.min(3,e)),this.updateZoomUI(),this.constrainPan(),this.render()}setAspectRatio(e){let t;switch(e){case"1:1":t=1;break;case"4:3":t=4/3;break;case"16:9":t=16/9;break;case"3:2":t=3/2;break;default:t=void 0}t&&this.applyAspectRatio(t),this.fitToCanvas(),this.render()}updateZoomUI(){if(!this.modal)return;let e=this.modal.querySelector(".asset-crop-zoom-value"),t=this.modal.querySelector(".asset-crop-zoom-slider");e&&(e.textContent=`${this.scale.toFixed(1)}x`),t&&(t.value=this.scale.toString())}constrainPan(){if(!this.canvas)return;let e=this.cropWidth*this.scale,t=this.cropHeight*this.scale;this.panX=Math.max(this.canvas.width-e,Math.min(0,this.panX)),this.panY=Math.max(this.canvas.height-t,Math.min(0,this.panY))}reset(){this.initializeCrop(),this.render()}applyCrop(){var a;if(!this.image||!((a=this.options)!=null&&a.onCrop))return;let e=document.createElement("canvas"),t=e.getContext("2d");if(!t)return;e.width=this.cropWidth,e.height=this.cropHeight,t.drawImage(this.image,this.cropX,this.cropY,this.cropWidth,this.cropHeight,0,0,this.cropWidth,this.cropHeight);let n=e.toDataURL("image/png");this.options.onCrop(n),this.close()}close(){this.modal&&this.modal.parentNode&&this.modal.parentNode.removeChild(this.modal);let e=this.options;this.modal=null,this.canvas=null,this.ctx=null,this.image=null,this.options=null,e!=null&&e.onCancel&&e.onCancel()}};window.openAssetCrop=function(i){new Mi().open(i)};oe();var Fe=require("pixi.js");var wt=require("pixi.js");Ht();var Ts=typeof __BUILD_MODE__!="undefined"?__BUILD_MODE__:"undefined",Ii=Ts;if(typeof window!="undefined")try{let i=new XMLHttpRequest;if(i.open("GET","./build-settings.json",!1),i.send(),i.status===200&&i.responseText){let e=JSON.parse(i.responseText);e!=null&&e.buildMode&&(Ii=e.buildMode,console.log(`[ObjectFactory] Build mode overridden by settings: ${Ii}`))}}catch{}function ks(i){var t,n,a,s,r;if(typeof window!="undefined"&&window.resolveAnchorVec2)return window.resolveAnchorVec2(i);let e={center:{x:.5,y:.5},"top-left":{x:0,y:0},"top-center":{x:.5,y:0},"top-right":{x:1,y:0},"center-left":{x:0,y:.5},"center-right":{x:1,y:.5},"bottom-left":{x:0,y:1},"bottom-center":{x:.5,y:1},"bottom-right":{x:1,y:1},left:{x:0,y:.5},right:{x:1,y:.5},top:{x:.5,y:0},bottom:{x:.5,y:1}};if(Array.isArray(i))return{x:(t=i[0])!=null?t:.5,y:(n=i[1])!=null?n:.5};if(i&&typeof i=="object"&&"x"in i&&"y"in i)return{x:(a=i.x)!=null?a:.5,y:(s=i.y)!=null?s:.5};if(typeof i=="string"){let o=i.trim().toLowerCase();return(r=e[o])!=null?r:{x:.5,y:.5}}return null}var me=class{static async create(e,t,n){var c,l,u,d,p,g,m;console.log(`[ObjectFactory] create() called for: ${e}, __BUILD_MODE__: ${Ii}`);let a=(c=t==null?void 0:t.render)==null?void 0:c.asset;if(!a){console.log(`[ObjectFactory] No asset definition for: ${e}, returning empty container`);let f=new wt.Container;return this.applyTransform(f,t==null?void 0:t.transform,t),f}let s=(l=t==null?void 0:t.identity)==null?void 0:l.id;console.log(`[ObjectFactory] Calling AssetLoader.load() for: ${e}, configId: ${s}, type: ${a.type}, path: ${a.path}`);let r=await Pe.load(e,a,n,s);console.log(`[ObjectFactory] AssetLoader.load() completed for: ${e}, rawAsset type: ${(u=r==null?void 0:r.constructor)==null?void 0:u.name}`);let o;if(a.type==="image")console.log("[ObjectFactory] Creating Sprite from texture:",r,"for object:",e),o=new wt.Sprite(r),console.log("[ObjectFactory] Created object:",o,"type:",(d=o==null?void 0:o.constructor)==null?void 0:d.name),this.applyTransform(o,t==null?void 0:t.transform,t);else if(a.type==="json")if(console.log("[ObjectFactory] JSON asset for",e,"rawAsset type:",(p=r==null?void 0:r.constructor)==null?void 0:p.name,r),r&&(((g=r.constructor)==null?void 0:g.name)==="Container"||r instanceof wt.Container)){console.warn("[ObjectFactory] JSON asset is Container (from cache), reloading JSON directly");let f=[a.path,`/assets/${a.path}`,`assets/${a.path}`,`../assets/${a.path}`],C=!1;for(let b of f)try{let h=await fetch(b);if(h.ok){o=await h.json(),console.log("[ObjectFactory] Reloaded JSON directly from:",b,"type:",(m=o==null?void 0:o.constructor)==null?void 0:m.name),C=!0;break}}catch{continue}C||(console.error("[ObjectFactory] Failed to reload JSON from any path"),o=r)}else o=r;else o=r,o&&typeof o=="object"&&("x"in o||"position"in o)&&this.applyTransform(o,t==null?void 0:t.transform,t);return o}static applyTransform(e,t,n){var a,s,r,o;if(!(!t||!e)&&(t.position&&("x"in e&&"y"in e?(e.x=(a=t.position.x)!=null?a:0,e.y=(s=t.position.y)!=null?s:0):"position"in e&&e.position&&e.position.set((r=t.position.x)!=null?r:0,(o=t.position.y)!=null?o:0)),t.scale!==void 0&&"scale"in e&&e.scale&&(typeof e.scale=="object"&&"set"in e.scale?e.scale.set(t.scale):e.scale=t.scale),t.rotation!==void 0&&"rotation"in e&&(e.rotation=t.rotation),t.anchor&&"anchor"in e&&e.anchor)){let c=ks(t.anchor);c&&("set"in e.anchor?e.anchor.set(c.x,c.y):(e.anchor.x=c.x,e.anchor.y=c.y))}}};oe();var Ut=require("pixi.js"),de={width:400,height:600,designWidth:400,scaleFactor:1},Ye={scale:1,position:1},qt=[];function Ps(i,e,t,n,a,s,r){qt.push({element:i,originalScale:s,positionHelper:e,heightPercent:a}),e(i,t,n,a,s,r,!1)}function Ms(){qt.forEach(({element:i,originalScale:e,positionHelper:t,heightPercent:n})=>{let a=e*de.scaleFactor;t(i,de.width,de.height,n,a,!0,!1)})}function ra(){qt.length=0,console.log("[LAYOUT] Cleared all responsive elements")}function Bt(i,e){console.log(`[SCREEN] updateScreenState called: ${i}x${e}`),de.width=i,de.height=e,de.scaleFactor=Math.min(i/de.designWidth,1.15),Ye.scale=de.scaleFactor,Ye.position=1,console.log(`[SCREEN] Global multipliers - scale: ${Ye.scale.toFixed(3)}`),Ms()}var j={layout:{scale_multiplier:1,position_offset:{x:0,y:0},debug_rect_visible:!0,debug_rect_color:16711680,debug_rect_thickness:4,debug_rect_scale_x:1,debug_rect_scale_y:1,screen_scale_x:1,screen_scale_y:1},engine:{scale:1,background_scale:1.05,background_offset_y:0,background_alpha:.98,label_pulse_speed:3,label_pulse_intensity:.03}};function Is(i,e,t){let n=j[i];n&&n[e]!==void 0&&(n[e]=t,console.log(`Updated ${i}.${e} = ${t}`))}function js(){return j}var _s={center:{x:.5,y:.5},"center-center":{x:.5,y:.5},middle:{x:.5,y:.5},"middle-center":{x:.5,y:.5},"top-left":{x:0,y:0},"top-center":{x:.5,y:0},"top-right":{x:1,y:0},"bottom-left":{x:0,y:1},"bottom-center":{x:.5,y:1},"bottom-right":{x:1,y:1},"left-center":{x:0,y:.5},"right-center":{x:1,y:.5},"center-left":{x:0,y:.5},"center-right":{x:1,y:.5},left:{x:0,y:.5},right:{x:1,y:.5},top:{x:.5,y:0},bottom:{x:.5,y:1}};function Ft(i,e){return typeof i=="number"&&Number.isFinite(i)?i:e}function Ie(i,e={x:.5,y:.5}){var t;if(Array.isArray(i))return{x:Ft(i[0],e.x),y:Ft(i[1],e.y)};if(i&&typeof i=="object"){let n=i;return{x:Ft(n.x,e.x),y:Ft(n.y,e.y)}}if(typeof i=="string"){let n=i.trim().toLowerCase();return(t=_s[n])!=null?t:e}return e}function He(i,e,t,n={}){var g,m,f,C,b,h;let a=Ie(t),s=(g=n.inset)!=null?g:{},r=(m=n.padding)!=null?m:{x:0,y:0},o=((f=s.left)!=null?f:0)+r.x,c=((C=s.right)!=null?C:0)+r.x,l=((b=s.top)!=null?b:0)+r.y,u=((h=s.bottom)!=null?h:0)+r.y,d=Math.max(0,i-o-c),p=Math.max(0,e-l-u);return{x:o+d*a.x,y:l+p*a.y}}function Ne(i,e,t,n={}){var f,C,b,h,v,w;let a=(f=n.inset)!=null?f:{},s=(C=n.padding)!=null?C:{x:0,y:0},r=((b=a.left)!=null?b:0)+s.x,o=((h=a.right)!=null?h:0)+s.x,c=((v=a.top)!=null?v:0)+s.y,l=((w=a.bottom)!=null?w:0)+s.y,u=Math.max(0,i-r-o),d=Math.max(0,e-c-l),p=Ie(t,{x:.5,y:.5}),g=Math.min(Math.max(p.x,0),1),m=Math.min(Math.max(p.y,0),1);return{x:r+u*g,y:c+d*m}}function Gt(i,e,t,n={}){var u,d,p;if(!i)return;let a=n.positionRatio?Ne(e,t,n.positionRatio,{inset:n.inset,padding:n.screenPadding}):He(e,t,n.anchor,{inset:n.inset,padding:n.screenPadding}),s=(u=n.offset)!=null?u:{x:0,y:0},r=a.x+s.x,o=a.y+s.y;i.anchor&&n.renderAnchor&&i.anchor.set(n.renderAnchor.x,n.renderAnchor.y),ne(i,r,o);let c=(d=n.scale)!=null?d:1,l=(p=n.scaleMultiplier)!=null?p:1;(n.scale!==void 0||n.scaleMultiplier!==void 0)&&pe(i,c*l)}if(typeof window!="undefined"){let i=window.innerWidth,e=window.innerHeight,t=()=>{let n=window.innerWidth,a=window.innerHeight;(n!==i||a!==e)&&(i=n,e=a,Bt(n,a))};window.addEventListener("resize",t),window.addEventListener("orientationchange",()=>{setTimeout(t,100)}),window.mraid&&(window.mraid.addEventListener("viewableChange",t),window.mraid.addEventListener("sizeChange",t)),Bt(window.innerWidth,window.innerHeight),window.updateDebugConfig=Is,window.getDebugConfig=js,window.copyConfig=Us,window.applyConfig=xt,window.applyConfigForRatio=qs,window.positionAtBottom=oa,window.positionAtTop=zs,window.positionAtCenter=$s,window.positionAtLeft=Ds,window.positionAtRight=Hs,window.positionAtBottomLeft=Ns,window.positionAtBottomRight=Fs,window.positionAtTopLeft=Bs,window.positionAtTopRight=Gs,window.applyPositionContract=Rs,console.log("\u{1F3AE} Debug Config Functions Available:"),console.log("\u2022 updateDebugConfig(category, key, value)"),console.log("\u2022 getDebugConfig()"),console.log("\u2022 copyConfig(presetName)"),console.log("\u2022 applyConfig(config)"),console.log("\u2022 applyConfigForRatio(width, height)"),console.log("\u{1F4CD} Positioning Helpers Available (with scale):"),console.log("\u2022 positionAtBottom(element, w, h, percent, scale)"),console.log("\u2022 positionAtTop(element, w, h, percent, scale)"),console.log("\u2022 positionAtCenter(element, w, h, offsetX, offsetY, scale)"),console.log("\u2022 positionAtLeft/Right(element, w, h, percent, scale)"),console.log("\u2022 Corner positions: BottomLeft/Right, TopLeft/Right (all with scale)"),console.log("\u2022 applyPositionContract(element, w, h, contract)"),console.log("Example: positionAtCenter(mySprite, 400, 600, 0, -50, 1.2)")}function Vt(i,e,t=0){return i*e+t}function Wt(i,e,t=0){return i*(1-e)+t}function Yt(i,e,t=0){return i*e+t}function Kt(i,e,t=0){return i*(1-e)+t}function ee(i,e=0){return i/2+e}function Os(i,e){return i*e}function Rs(i,e,t,n){var r,o,c,l,u,d,p,g,m,f,C,b,h,v,w,y,M,_,G,z;let a=0,s=0;switch(n.type){case"top":a=ee(e,(o=(r=n.offset)==null?void 0:r.x)!=null?o:0),s=Vt(t,n.percent,(l=(c=n.offset)==null?void 0:c.y)!=null?l:0);break;case"bottom":a=ee(e,(d=(u=n.offset)==null?void 0:u.x)!=null?d:0),s=Wt(t,n.percent,(g=(p=n.offset)==null?void 0:p.y)!=null?g:0);break;case"left":a=Yt(e,n.percent,(f=(m=n.offset)==null?void 0:m.x)!=null?f:0),s=ee(t,(b=(C=n.offset)==null?void 0:C.y)!=null?b:0);break;case"right":a=Kt(e,n.percent,(v=(h=n.offset)==null?void 0:h.x)!=null?v:0),s=ee(t,(y=(w=n.offset)==null?void 0:w.y)!=null?y:0);break;case"center":a=ee(e,(_=(M=n.offset)==null?void 0:M.x)!=null?_:0),s=ee(t,(z=(G=n.offset)==null?void 0:G.y)!=null?z:0);break}i.position?i.position.set(a,s):(i.x=a,i.y=s),n.scale!==void 0&&n.scale!==1&&i.scale&&(typeof i.scale.set=="function"?i.scale.set(n.scale,n.scale):(i.scale.x=n.scale,i.scale.y=n.scale))}function oa(i,e,t,n=.2,a=1,s=!0,r=!1){let o=Os(t,n),c=Wt(t,n/2);ne(i,ee(e),c);let l=s?a*de.scaleFactor:a;pe(i,l),r&&!qt.find(u=>u.element===i)&&Ps(i,oa,e,t,n,a,s)}function zs(i,e,t,n=.1,a=1){ne(i,ee(e),Vt(t,n)),pe(i,a)}function $s(i,e,t,n=0,a=0,s=1){ne(i,ee(e,n),ee(t,a)),pe(i,s)}function Ds(i,e,t,n=.1,a=1){ne(i,Yt(e,n),ee(t)),pe(i,a)}function Hs(i,e,t,n=.1,a=1){ne(i,Kt(e,n),ee(t)),pe(i,a)}function Ns(i,e,t,n=.05,a=.05,s=1){ne(i,Yt(e,a),Wt(t,n)),pe(i,s)}function Fs(i,e,t,n=.05,a=.05,s=1){ne(i,Kt(e,a),Wt(t,n)),pe(i,s)}function Bs(i,e,t,n=.05,a=.05,s=1){ne(i,Yt(e,a),Vt(t,n)),pe(i,s)}function Gs(i,e,t,n=.05,a=.05,s=1){ne(i,Kt(e,a),Vt(t,n)),pe(i,s)}function ne(i,e,t){i&&i.position?typeof i.position.set=="function"?i.position.set(e,t):(i.position.x=e,i.position.y=t):i&&(i.x=e,i.y=t)}function pe(i,e){e!==1&&i&&i.scale&&(typeof i.scale.set=="function"?i.scale.set(e,e):i.scale.x!==void 0&&i.scale.y!==void 0&&(i.scale.x=e,i.scale.y=e))}var De={default:{layout:{scale_multiplier:1,position_offset:{x:0,y:0},debug_rect_visible:!0,debug_rect_color:16711680,debug_rect_thickness:4,debug_rect_scale_x:1,debug_rect_scale_y:1,screen_scale_x:1,screen_scale_y:1},engine:{scale:1,background_scale:1.05,background_offset_y:0,background_alpha:.98,label_pulse_speed:3,label_pulse_intensity:.03}},wide:{layout:{scale_multiplier:1,position_offset:{x:0,y:0},debug_rect_visible:!0,debug_rect_color:16711680,debug_rect_thickness:4,debug_rect_scale_x:1,debug_rect_scale_y:1,screen_scale_x:.9,screen_scale_y:1.1},engine:{scale:1,background_scale:1.1,background_offset_y:0,background_alpha:.95,label_pulse_speed:3,label_pulse_intensity:.03}},square:{layout:{scale_multiplier:1,position_offset:{x:0,y:0},debug_rect_visible:!0,debug_rect_color:16711680,debug_rect_thickness:4,debug_rect_scale_x:1,debug_rect_scale_y:1,screen_scale_x:.85,screen_scale_y:.85},engine:{scale:1,background_scale:1,background_offset_y:0,background_alpha:1,label_pulse_speed:3,label_pulse_intensity:.03}},tall:{layout:{scale_multiplier:1,position_offset:{x:0,y:0},debug_rect_visible:!0,debug_rect_color:16711680,debug_rect_thickness:4,debug_rect_scale_x:1,debug_rect_scale_y:1,screen_scale_x:1.1,screen_scale_y:.9},engine:{scale:1,background_scale:.95,background_offset_y:0,background_alpha:1,label_pulse_speed:3,label_pulse_intensity:.03}}};function Us(i){return i&&De[i]?JSON.parse(JSON.stringify(De[i])):JSON.parse(JSON.stringify(j))}function xt(i){Object.keys(i).forEach(e=>{let t=e;j[t]&&i[t]&&Object.assign(j[t],i[t])}),console.log("Config applied:",i)}function qs(i,e){let t=i/e;t>1.6?(xt(De.wide),console.log("Applied WIDE config for ratio:",t)):t<.7?(xt(De.tall),console.log("Applied TALL config for ratio:",t)):t>.8&&t<1.2?(xt(De.square),console.log("Applied SQUARE config for ratio:",t)):(xt(De.default),console.log("Applied DEFAULT config for ratio:",t))}if(typeof window!="undefined"){let i=window;i.configPresets=De,i.resolveAnchorVec2=i.resolveAnchorVec2||Ie,i.resolveScreenAnchorPoint=i.resolveScreenAnchorPoint||He,i.resolveScreenRatioPoint=i.resolveScreenRatioPoint||Ne}var Y=null,aa=new Map,sa=null;function la(i,e,t,n,a,s={}){var q,ae,we,xe,Se,Ee,Ce,Ae,V,_e,rt,ot,lt,ct,dt,pt,ut,gt,ht,ft,F,X,U,J,Ge,Oe,Bi,Gi,Ui,qi,Vi,Wi,Yi,Ki,Xi,Ji,Zi,Qi,en,tn,nn,an,sn,rn,on,ln;let r=(q=s.enableDebugLogs)!=null?q:!1;r&&(console.log("\u{1F3AF} [LAYOUT_DEBUGS] ===== STARTING LAYOUT CALCULATION ====="),console.log("\u{1F3AF} [LAYOUT_DEBUGS] Screen dimensions:",{width:n.width,height:n.height}),console.log("\u{1F3AF} [LAYOUT_DEBUGS] Time:",t),console.log("\u{1F3AF} [LAYOUT_DEBUGS] Options:",s));let{mainContainer:o,label:c,background:l,backgroundTexture:u,app:d}=i;if(!d||!d.renderer){r&&console.log("\u{1F3AF} [LAYOUT_DEBUGS] \u274C No app or renderer, skipping layout");return}r&&(console.log("\u{1F3AF} [LAYOUT_DEBUGS] App renderer dimensions:",{width:d.renderer.width,height:d.renderer.height}),console.log("\u{1F3AF} [LAYOUT_DEBUGS] App screen dimensions:",{width:d.screen.width,height:d.screen.height}));let p=n.width,g=n.height;r&&console.log("\u{1F3AF} [LAYOUT_DEBUGS] Base dimensions:",{baseWidth:p,baseHeight:g});let m=p*j.layout.screen_scale_x,f=g*j.layout.screen_scale_y,C=p/2,b=e.engine.runtime||{},h=b.layout||{};r&&(console.log("\u{1F3AF} [LAYOUT_DEBUGS] Debug config:",{screen_scale_x:j.layout.screen_scale_x,screen_scale_y:j.layout.screen_scale_y}),console.log("\u{1F3AF} [LAYOUT_DEBUGS] Calculated dimensions:",{width:m,height:f,midX:C}),console.log("\u{1F3AF} [LAYOUT_DEBUGS] Engine runtime:",b),console.log("\u{1F3AF} [LAYOUT_DEBUGS] Layout config:",h));let v=h.design_width_portrait||400,w=m/v;w=Math.min(w,1.15);let y=w*((ae=j.engine.scale)!=null?ae:1),M=(we=s.skipMainContainerTransform)!=null?we:!1;!M&&o&&o.scale&&(typeof o.scale.set=="function"?o.scale.set(y):(o.scale.x=y,o.scale.y=y));let _=(xe=h.main_container_anchor)!=null?xe:"center",G=(Se=h.main_container_position_ratio)!=null?Se:{x:.5,y:.5},z=(Ee=h.main_container_offset)!=null?Ee:{x:0,y:0},N=h.main_container_position_ratio?Ne(p,g,G):He(p,g,_),$=N.x+z.x+j.layout.position_offset.x,L=N.y+z.y+j.layout.position_offset.y;if(!M&&o&&o.position&&(typeof o.position.set=="function"?o.position.set($,L):(o.position.x=$,o.position.y=L)),a&&(o!=null&&o.toLocal))for(let[W,B]of e.objects.entries()){let O=B==null?void 0:B.transform;if(!O||((Ce=O.position_mode)!=null?Ce:"static")!=="static")continue;let k=(Ae=a.get)==null?void 0:Ae.call(a,W),se=((V=k==null?void 0:k.getDisplayObject)==null?void 0:V.call(k))||(k==null?void 0:k.pixiObject)||k;if(!se||se.parent!==o)continue;let mt=O.position_ratio!=null?Ne(p,g,O.position_ratio):He(p,g,(_e=O.anchor)!=null?_e:"center"),P=o.toLocal(new Ut.Point(mt.x,mt.y)),re=(rt=O.position)!=null?rt:{x:0,y:0},bt=P.x+re.x,te=P.y+re.y;typeof(k==null?void 0:k.setPosition)=="function"?k.setPosition(bt,te):(ne(se,bt,te),(ot=k==null?void 0:k.transform)!=null&&ot.position&&(k.transform.position.x=bt,k.transform.position.y=te))}let S=typeof window!="undefined"?window.__BUILD_SETTINGS__:null,A=((S==null?void 0:S.buildMode)||(typeof __BUILD_MODE__!="undefined"?__BUILD_MODE__:"dev"))==="dev";if(j.layout.debug_rect_visible&&A){(!Y||Y.parent!==d.stage)&&(Y==null||Y.destroy(),Y=new Ut.Graphics,Y.zIndex=9999,d.stage.addChild(Y)),Y.clear();let W=j.layout.debug_rect_scale_x,B=j.layout.debug_rect_scale_y,O=(p-4)*W,Le=(g-4)*B,k=(p-O)/2,se=(g-Le)/2;r&&(console.log("\u{1F3AF} [LAYOUT_DEBUGS] ===== DEBUG RECT POSITIONING ====="),console.log("\u{1F3AF} [LAYOUT_DEBUGS] Debug rect calculations:",{baseWidth:p,baseHeight:g,rectW:O,rectH:Le,offsetX:k,offsetY:se}),console.log("\u{1F3AF} [LAYOUT_DEBUGS] Debug rect final position:",{x:2+k,y:2+se,width:O,height:Le})),Y.rect(2+k,2+se,O,Le).stroke({width:j.layout.debug_rect_thickness,color:j.layout.debug_rect_color})}else Y&&(Y.destroy(),Y=null);let T=((lt=i.label)==null?void 0:lt.config)||e.objects.get("label_1")||e.objects.get("ui_tutorial_1");if(c&&c.position&&T){let W=(dt=(ct=T==null?void 0:T.transform)==null?void 0:ct.anchor)!=null?dt:"center",B=(pt=T==null?void 0:T.transform)==null?void 0:pt.position_ratio,O=((ut=T==null?void 0:T.transform)==null?void 0:ut.offset)||{x:0,y:0};Gt(c,p,g,{anchor:W,positionRatio:B,offset:{x:O.x*y,y:O.y*y},renderAnchor:Ie(W)})}if(c&&c.alpha>0){let W=1+Math.sin(t*j.engine.label_pulse_speed)*j.engine.label_pulse_intensity,B=(ht=(gt=T==null?void 0:T.transform)==null?void 0:gt.scale)!=null?ht:1,O=W*y*B;c.scale&&(typeof c.scale.set=="function"?c.scale.set(O):(c.scale.x=O,c.scale.y=O))}if(r&&console.log("\u{1F3AF} [LAYOUT_DEBUGS] ===== BACKGROUND POSITIONING ====="),l){r&&(console.log("\u{1F3AF} [LAYOUT_DEBUGS] Background object exists:",!!l),console.log("\u{1F3AF} [LAYOUT_DEBUGS] Background type:",(ft=l.constructor)==null?void 0:ft.name)),l.alpha=((X=(F=b.background)==null?void 0:F.alpha)!=null?X:.98)*j.engine.background_alpha,r&&console.log("\u{1F3AF} [LAYOUT_DEBUGS] Background alpha set to:",l.alpha);let W=e.objects.get("background_1");r&&console.log("\u{1F3AF} [LAYOUT_DEBUGS] Background config:",W);let B=(W==null?void 0:W.transform)||{};r&&console.log("\u{1F3AF} [LAYOUT_DEBUGS] Background transform:",B);let O=B.offset||{x:0,y:0},Le=((J=(U=b.background)==null?void 0:U.offset_y)!=null?J:0)+j.engine.background_offset_y,k=(Ge=B.anchor)!=null?Ge:"center",se=B.position_ratio;if(r&&console.log("\u{1F3AF} [LAYOUT_DEBUGS] Background positioning params:",{bgOffset:O,bgRuntimeOffsetY:Le,bgScreenAnchor:k,bgPositionRatio:se,baseWidth:p,baseHeight:g,finalScale:y}),Gt(l,p,g,{anchor:k,positionRatio:se,offset:{x:O.x*y,y:O.y*y+Le},renderAnchor:Ie(k)}),r&&(console.log("\u{1F3AF} [LAYOUT_DEBUGS] Background position after applyScreenAnchor:",{x:l.x,y:l.y,scaleX:(Oe=l.scale)==null?void 0:Oe.x,scaleY:(Bi=l.scale)==null?void 0:Bi.y,anchorX:(Gi=l.anchor)==null?void 0:Gi.x,anchorY:(Ui=l.anchor)==null?void 0:Ui.y,pivotX:(qi=l.pivot)==null?void 0:qi.x,pivotY:(Vi=l.pivot)==null?void 0:Vi.y,width:l.width,height:l.height}),console.log("\u{1F3AF} [LAYOUT_DEBUGS] Background texture dimensions:",{textureWidth:u==null?void 0:u.width,textureHeight:u==null?void 0:u.height})),u){let ri=Math.max(m/u.width,f/u.height),oi=(Yi=(Wi=b.background)==null?void 0:Wi.scale_multiplier)!=null?Yi:1.05,$a=(Ki=B.scale)!=null?Ki:1,li=ri*oi*j.engine.background_scale*$a;l.scale&&(typeof l.scale.set=="function"?l.scale.set(li):(l.scale.x=li,l.scale.y=li))}else l&&typeof l.clear=="function"&&(l.clear(),l.rect(-m/2,-f/2,m,f).fill({color:1444375}));let mt=`${p}x${g}`,P=(Xi=aa.get(mt))!=null?Xi:sa,re={x:Number((Ji=l.x)!=null?Ji:0),y:Number((Zi=l.y)!=null?Zi:0),scaleX:Number((en=(Qi=l.scale)==null?void 0:Qi.x)!=null?en:1),scaleY:Number((nn=(tn=l.scale)==null?void 0:tn.y)!=null?nn:1),rotation:Number.isFinite(l.rotation)?l.rotation:void 0,anchorX:Number.isFinite((an=l.anchor)==null?void 0:an.x)?l.anchor.x:void 0,anchorY:Number.isFinite((sn=l.anchor)==null?void 0:sn.y)?l.anchor.y:void 0,pivotX:Number.isFinite((rn=l.pivot)==null?void 0:rn.x)?l.pivot.x:void 0,pivotY:Number.isFinite((on=l.pivot)==null?void 0:on.y)?l.pivot.y:void 0},bt=Number.isFinite(re.x)&&Number.isFinite(re.y)&&Number.isFinite(re.scaleX)&&Number.isFinite(re.scaleY),te=re;if(P){let ri=Math.hypot(re.x-P.x,re.y-P.y),oi=Math.max(p,g)*.5;(!bt||ri>oi)&&((ln=l.position)!=null&&ln.set?l.position.set(P.x,P.y):(l.x=P.x,l.y=P.y),l.scale&&(typeof l.scale.set=="function"?l.scale.set(P.scaleX,P.scaleY):(l.scale.x=P.scaleX,l.scale.y=P.scaleY)),Number.isFinite(P.rotation)&&typeof l.rotation=="number"&&(l.rotation=P.rotation),l.anchor&&Number.isFinite(P.anchorX)&&Number.isFinite(P.anchorY)&&l.anchor.set(P.anchorX,P.anchorY),l.pivot&&Number.isFinite(P.pivotX)&&Number.isFinite(P.pivotY)&&l.pivot.set(P.pivotX,P.pivotY),te=P)}Number.isFinite(te.x)&&Number.isFinite(te.y)&&Number.isFinite(te.scaleX)&&Number.isFinite(te.scaleY)&&(aa.set(mt,te),sa=te)}}oe();oe();var ca=ci(require("lottie-web"),1);Xt(Fn);typeof window!="undefined"&&!window.lottie&&(window.lottie=ca.default);mi();oe();var ji=xn.version,Ws=new Set(["init","boot","view","ready","start","pause","resume","complete","error","engagement","first_interaction","retry","cta_show","cta_click","cta_dismiss","clickout","conversion","session_time","level_time","load_time","level_start","level_complete","level_fail","checkpoint","reward","tutorial_start","tutorial_complete","tutorial_skip","ab_assign","fps","memory","asset_load_start","asset_load_complete"]);wn();var ma={mechanic_id:"TODO_mechanic_id",variant_id:"TODO_variant_id",deployment_id:"TODO_deployment_id",export_id:"TODO_export_id",profile_id:"TODO_profile_id",instance_id:"default"},ba=Math.random().toString(36).slice(2),Je=null,Ke={...ma},ya="web_embed",zi={},Ct,_i=!1,Et=!1,Lt=!1,va=!1,Ni=1,Zt=0,ti=!1,be=!1,Xe="",Ze=Math.floor(window.innerWidth),Qe=Math.floor(window.innerHeight),$i=Ze>Qe,ye=!1,At=!1,da=!1,pa=!1,Oi=!1,Qt=null,Be=null,Di=!1,Hi=!1,Jt=new Map;function wa(){if(!Be)return null;let i=Date.now()-Be;return!Number.isFinite(i)||i<0?null:i}function Ri(i){if(Di)return;let e=wa();e!==null&&(Di=!0,x("session_time",{duration_ms:e,reason:i}))}function ua(){if(Je)return Je;let i=document.createElement("div");return i.id="handler-root",i.setAttribute("data-handler-root","true"),document.body.appendChild(i),Je=i,i}function ei(i){switch(i){case"interaction":return"engagement";case"finish":return"complete";case"install":return"cta_click";default:return i}}function xa(i,e){return{event_name:i,ts:Date.now(),session_id:ba,deployment_id:Ke.deployment_id,variant_id:Ke.variant_id,export_profile_id:Ke.profile_id,instance_id:Ke.instance_id||"default",env:ya==="mraid"?"mraid":"web",attribution:Ct,payload:e}}function x(i,e){let t=ei(i),n=xa(t,e);pi(n,!!zi.analytics),Ot(t,n),t!==i&&Ot(i,n)}function Tt(){Qt&&(Qt(Ze,Qe),Qt=null)}function et(i){Ni=i,x("volume",i)}function tt(i){i&&(va=!0),!Lt&&(Lt=!0,x("pause"),et(0))}function kt(i){!i&&va||Lt&&(Lt=!1,x("resume"),et(Ni))}function je(i,e){Ze=Math.floor(i||window.innerWidth),Qe=Math.floor(e||window.innerHeight),$i=Ze>Qe,x("resize",{width:Ze,height:Qe})}function Ys(){if(_n())try{let i=mraid.getMaxSize();je(i.width,i.height);let e=()=>{mraid.isViewable()&&mraid.getState()!=="hidden"?kt():tt()};if(mraid.addEventListener("viewableChange",e),mraid.addEventListener("stateChange",e),mraid.addEventListener("sizeChange",()=>{let t=mraid.getMaxSize();je(t.width,t.height)}),mraid.getAudioVolume){let t=mraid.getAudioVolume();et(t?1:0)}if(mraid.addEventListener("audioVolumeChange",t=>{t!==null&&et(t>0?1:0)}),mraid.addEventListener("error",(t,n)=>{console.warn("mraid error:",t,"action:",n)}),ti=!0,mraid.isViewable()&&mraid.getState()!=="hidden")ye=!0,x("boot"),x("view"),x("ready"),be=!0,Tt();else{let t=()=>{ye=!0,x("boot"),x("view"),x("ready"),be=!0,Tt()};mraid.addEventListener("ready",t)}}catch(i){console.warn("MRAID hook skipped",i)}}function Ks(){if(On())try{let i=dapi.getScreenSize();je(i.width,i.height),dapi.addEventListener("viewableChange",t=>{t.isViewable?kt():tt()}),dapi.addEventListener("adResized",t=>{let n=dapi.getScreenSize();je(t.width||n.width,t.height||n.height)});let e=dapi.getAudioVolume();if(et(e?1:0),dapi.addEventListener("audioVolumeChange",t=>et(t?1:0)),ti=!0,dapi.isViewable())ye=!0,x("boot"),x("view"),x("ready"),be=!0,Tt();else{let t=()=>{ye=!0,x("boot"),x("view"),x("ready"),be=!0,Tt()};dapi.addEventListener("ready",t)}}catch(i){console.warn("DAPI hook skipped",i)}}function ga(){let i=()=>{ye||document.visibilityState==="visible"&&(document.readyState==="complete"||document.readyState==="interactive")&&(ye=!0,x("boot"),x("view"),x("ready"),be=!0,Tt(),At&&(At=!1,ue.start()))};window.addEventListener("resize",()=>je()),document.addEventListener("visibilitychange",()=>{document.visibilityState==="visible"?(kt(),i()):tt()}),document.readyState==="complete"||document.readyState==="interactive"?i():window.addEventListener("load",i),ti=!0}function Xs(){let i=e=>{typeof TouchEvent!="undefined"&&e instanceof TouchEvent&&(da=!0),!(da&&e instanceof MouseEvent)&&(Zt+=1,Hi||(Hi=!0,x("first_interaction",{count:Zt})),x("interaction",Zt))};document.addEventListener("mousedown",i),document.addEventListener("touchstart",i)}function ha(i){var n,a,s,r,o,c,l,u,d,p,g,m;let e=typeof AD_PROTOCOL!="undefined"?AD_PROTOCOL:"none";if((typeof AD_NETWORK!="undefined"?AD_NETWORK:"web_embed")==="google")try{(n=window.ExitApi)==null||n.exit();return}catch{}if(e==="mraid"&&typeof mraid!="undefined")mraid.open(i||"");else if(e==="dapi"&&typeof dapi!="undefined")dapi.openStoreUrl();else if(Ve())(s=(a=window.TJ_API)==null?void 0:a.click)==null||s.call(a);else if(Rn())(o=(r=window.FbPlayableAd)==null?void 0:r.onCTAClick)==null||o.call(r);else if(Hn())(l=(c=window.ScPlayableAd)==null?void 0:c.onCTAClick)==null||l.call(c);else if(Dn())try{(d=(u=window.smxTracking)==null?void 0:u.redirect)==null||d.call(u)}catch(f){console.warn("Smadex redirect failed",f)}else if(zn()){let f=window.ExitApi;f&&typeof f.exit=="function"?f.exit(i||Xe||""):i&&window.open(i)}else qe()?(p=window.install)==null||p.call(window):$n()?(g=window.openAppStore)==null||g.call(window):ui()?(m=parent==null?void 0:parent.postMessage)==null||m.call(parent,"download","*"):i&&window.open(i)}function Js(){let i=typeof AD_NETWORK!="undefined"?AD_NETWORK:"web_embed",e=t=>{if(!t)return;let n=new Image;n.src=t};if(i==="bigabid"){let t=window.BIGABID_BIDTIMEMACROS;if(!t)return;Z("view",()=>e(t.mraid_viewable)),Z("start",()=>e(t.game_viewable)),Z("engagement",()=>e(t.engagement));let n=()=>e(t.complete);Z("complete",n),_t("engagement",a=>{var s;((s=a==null?void 0:a.payload)==null?void 0:s.count)>3&&n()}),Z("cta_click",()=>e(t.click))}else if(i==="inmobi"){let t=window.INMOBI_DSPMACROS;if(!t)return;Z("view",()=>e(t.Ad_Load_Start)),Z("start",()=>e(t.Ad_Viewable)),Z("engagement",()=>e(t.First_Engagement)),Z("complete",()=>e(t.Gameplay_Complete)),Z("cta_click",()=>e(t.DSP_Click)),Z("start",()=>{[5,10,15,20,25,30].forEach(n=>setTimeout(()=>e(t[`Spent_${n}_Seconds`]),n*1e3))})}}function Zs(){if(!Ve())return;let i=window.TJ_API;i&&i.setPlayableAPI&&i.setPlayableAPI({skipAd:()=>{try{ue.finish()}catch(e){console.warn("Tapjoy skip failed",e)}}})}function fa(){var e,t,n;let i=window.TJ_API;(e=i==null?void 0:i.objectiveComplete)==null||e.call(i),(t=i==null?void 0:i.playableFinished)==null||t.call(i),(n=i==null?void 0:i.gameplayFinished)==null||n.call(i)}function Qs(){qe()&&(window.mintGameStart=()=>{kt(!0),je()},window.mintGameClose=()=>{tt(!0)})}function er(){if(!gi())return;let i=window.NUC;!i||!i.trigger||(ue.on("cta_click",()=>{var e,t;return(t=(e=i.trigger).convert)==null?void 0:t.call(e,Xe)}),ue.on("complete",()=>{var e,t;return(t=(e=i.trigger).tryAgain)==null?void 0:t.call(e)}))}var ue={init(i={},e){var t;if(ya=i.profile||"web_embed",zi=i.consent||{},Ke={...ma,...i.ids||{}},Je=i.rootEl||Je,Ct=void 0,gn((t=i.telemetry)!=null&&t.endpoint?i.telemetry:null),Be=null,Di=!1,Hi=!1,Jt.clear(),Xe=i.destinationUrl||(/android/i.test(navigator.userAgent)?"https://play.google.com/store":"https://www.apple.com/app-store/"),e&&(Qt=e),x("init"),document.body.oncontextmenu=()=>!1,ua(),ir(Je),Nn(),Ys(),Ks(),!ti){if(document.readyState==="complete")ga();else if(!pa){pa=!0;let n=()=>{ga(),window.removeEventListener("load",n),document.removeEventListener("DOMContentLoaded",n)};window.addEventListener("load",n),document.addEventListener("DOMContentLoaded",n)}}Xs(),Js(),Zs(),Qs(),er(),console.log(`%c @handler/playable-sdk %c v${ji} `,"background: var(--ui-console-info); color: var(--ui-white); font-size: 14px; padding: 4px 8px; border-top-left-radius: 4px; border-bottom-left-radius: 4px;","background: var(--ui-console-bg); color: var(--ui-console-text); font-size: 14px; padding: 4px 8px; border-top-right-radius: 4px; border-bottom-right-radius: 4px;"),ye&&!be&&(x("boot"),x("view"),x("ready"),At&&(At=!1,ue.start()),be=!0),be=ye},getRoot(){return ua()},get version(){return ji},get maxWidth(){return Ze},get maxHeight(){return Qe},get isLandscape(){return $i},get isReady(){return be},get isStarted(){return _i},get isPaused(){return Lt},get isFinished(){return Et},get volume(){return Ni},get interactions(){return Zt},on(i,e){_t(ei(i),e)},off(i,e){di(ei(i),e)},start(){var i,e;if(!_i){if(!ye){At=!0;return}if(_i=!0,Be||(Be=Date.now()),x("start"),je(),qe())tt(),(i=window.gameReady)==null||i.call(window);else if(Ve()){let t=window.TJ_API;(e=t==null?void 0:t.setPlayableBuild)==null||e.call(t,{orientation:$i?"landscape":"portrait",buildID:ji})}}},finish(){var i,e;Et||(Et=!0,x("complete"),Ri("complete"),qe()?(i=window.gameEnd)==null||i.call(window):ui()?(e=parent==null?void 0:parent.postMessage)==null||e.call(parent,"complete","*"):Ve()&&fa())},install(i){if(!Et){Et=!0,Ve()?(fa(),setTimeout(()=>ue.install(i),300)):(x("complete"),setTimeout(()=>ue.install(i),0));return}Oi||(Oi=!0,setTimeout(()=>Oi=!1,500),x("cta_click"),x("conversion"),Ri("cta"),ha(i||Xe))},emit(i,e){let t=ei(i);if(!Ws.has(t)&&t!=="resize"&&t!=="volume"&&!t.startsWith("custom."))throw new Error(`Event ${i} must be canonical or namespaced as custom.<mechanic_id>.<event>`);let n=xa(t,e);pi(n,!!zi.analytics),Ot(t,n)},gameStart(){ue.start()},gameEnd(){ue.finish()},ctaClick(i,e){x("cta_click",{url:i||Xe,manual:!0}),(e==null?void 0:e.open)!==!1&&ha(i||Xe)},ctaShow(i){x("cta_show",i)},ctaDismiss(i){x("cta_dismiss",i)},getGameTimeMs(){return wa()},endSession(i="manual"){Ri(i)},setAttribution(i){Ct=i},abTest(i,e){if(!i)throw new Error("abTest requires experimentId");if(!Array.isArray(e)||e.length<2)throw new Error("abTest requires at least 2 variants");let t=Math.abs(tr(`${ba}:${i}`))%e.length,n=e[t];return Ct={...Ct||{},experiment_id:i},Ke.variant_id=n,x("ab_assign",{experiment_id:i,variant_id:n}),n},levelStart(i,e){Be||(Be=Date.now()),x("level_start",{level_id:i,...e})},levelComplete(i,e){x("level_complete",{level_id:i,...e})},levelFail(i,e){x("level_fail",{level_id:i,...e})},checkpoint(i,e){x("checkpoint",{checkpoint_id:i,...e})},reward(i,e){x("reward",{reward_id:i,...e})},tutorialStart(i,e){x("tutorial_start",{step_id:i,...e})},tutorialComplete(i,e){x("tutorial_complete",{step_id:i,...e})},tutorialSkip(i,e){x("tutorial_skip",{step_id:i,...e})},timerStart(i){i&&Jt.set(i,Date.now())},timerEnd(i,e="custom",t){if(!i)return;let n=Jt.get(i);if(!n)return;Jt.delete(i);let a=Date.now()-n;if(!(!Number.isFinite(a)||a<0)){if(e==="custom"){x("engagement",{action:"timer",key:i,duration_ms:a,...t});return}x(e,{key:i,duration_ms:a,...t})}},fps(i,e){x("fps",{value:i,...e})},memory(i,e){x("memory",{bytes:i,...e})},assetLoadStart(i,e){x("asset_load_start",{asset_id:i,...e})},assetLoadComplete(i,e){x("asset_load_complete",{asset_id:i,...e})},reportError(i,e,t){x("error",{code:i,message:e,...t})},retry(){var i,e,t;if(qe())(i=window.gameRetry)==null||i.call(window);else if(gi()){let n=window.NUC;(t=(e=n==null?void 0:n.trigger)==null?void 0:e.tryAgain)==null||t.call(e)}x("engagement",{action:"retry"})},pause(){tt(!0)},resume(){kt(!0)},resize(i,e){je(i,e)}},St=ue;function tr(i){let e=2166136261;for(let t=0;t<i.length;t++)e^=i.charCodeAt(t),e=Math.imul(e,16777619);return e|0}function ir(i){let e=document.createElement("script");e.type="text/javascript",e.textContent=`
230
230
  (function(){
231
231
  var events = ['touchstart','touchend','mousedown','keydown'];
232
232
  function unlock(){
@@ -242,14 +242,14 @@ Style guidelines: ${n.summary}`;this.promptInput.value=a,this.currentPrompt=a}}c
242
242
  }
243
243
  events.forEach(function(e){ document.addEventListener(e, unlock, false); });
244
244
  })();
245
- `,i.appendChild(e)}async function ti(i,e={}){let t=new sa.Application;await t.init({resizeTo:i,autoDensity:!0,resolution:window.devicePixelRatio||1,antialias:!0,backgroundAlpha:0});let n=r=>{var c,p,g,m;if(!t.renderer)return;let o=(c=r==null?void 0:r.width)!=null?c:i.clientWidth,l=(p=r==null?void 0:r.height)!=null?p:i.clientHeight,d=o&&o>0?o:(g=window.innerWidth)!=null?g:320,u=l&&l>0?l:(m=window.innerHeight)!=null?m:480;t.renderer.resize(d,u)};i.appendChild(t.canvas),i.style.position="relative",i.style.display="flex",i.style.flexDirection="column",i.style.alignItems="stretch",i.style.width="100%",i.style.height="100dvh",i.style.minHeight="100vh",i.style.maxWidth="100%",i.style.maxHeight="100%",i.style.boxSizing="border-box",i.style.overflow="hidden",e.background&&(i.style.background=e.background),n();let a=document.createElement("div");return a.setAttribute("style",["position:absolute","inset:0","display:flex","flex-direction:column","align-items:center","justify-content:flex-start","gap:12px","pointer-events:none","font-family:Arial,sans-serif","padding:20px 16px","padding-bottom:clamp(24px, 6vh, 96px)","box-sizing:border-box","z-index:2"].join(";")),i.appendChild(a),yt.on("pause",()=>{t.ticker.stop(),document.querySelectorAll("audio").forEach(o=>o.pause())}),yt.on("resume",()=>{t.ticker.start(),document.querySelectorAll("audio").forEach(o=>{o.currentTime>0&&!o.ended&&o.play().catch(()=>{})})}),yt.on("resize",({payload:r})=>{n({width:r==null?void 0:r.width,height:r==null?void 0:r.height})}),window.addEventListener("resize",()=>n()),requestAnimationFrame(()=>n()),new ResizeObserver(r=>{let o=r[0];if(o&&o.contentRect.width>0&&o.contentRect.height>0){let l=Math.round(o.contentRect.width),d=Math.round(o.contentRect.height);if(n({width:l,height:d}),typeof window!="undefined"&&window.gameApp&&window.gameObjectManager){let u={width:l,height:d,dpr:Math.max(1,Math.floor(window.devicePixelRatio||1)),presetId:"auto-resize",isLandscape:l>d};window.dispatchEvent(new CustomEvent("handler-preview:screen",{detail:u}))}}}).observe(i),{app:t,stage:t.stage,overlay:a,applySize:n}}var Y=require("pixi.js"),At=class{constructor(e){var a,s;let t=e==null?void 0:e.position,n=e==null?void 0:e.offset;this._basePosition={x:typeof(t==null?void 0:t.x)=="number"?t.x:0,y:typeof(t==null?void 0:t.y)=="number"?t.y:0},this._offset={x:typeof(n==null?void 0:n.x)=="number"?n.x:0,y:typeof(n==null?void 0:n.y)=="number"?n.y:0},this.position={x:this._basePosition.x+this._offset.x,y:this._basePosition.y+this._offset.y},this.scale=(a=e==null?void 0:e.scale)!=null?a:1,this.rotation=(s=e==null?void 0:e.rotation)!=null?s:0}update(e){let t=e.position,n=e.offset;t!==void 0&&(this._basePosition={x:typeof(t==null?void 0:t.x)=="number"?t.x:0,y:typeof(t==null?void 0:t.y)=="number"?t.y:0}),n!==void 0&&(this._offset={x:typeof(n==null?void 0:n.x)=="number"?n.x:0,y:typeof(n==null?void 0:n.y)=="number"?n.y:0}),(t!==void 0||n!==void 0)&&(this.position={x:this._basePosition.x+this._offset.x,y:this._basePosition.y+this._offset.y}),e.scale!==void 0&&(this.scale=e.scale),e.rotation!==void 0&&(this.rotation=e.rotation)}syncToPixi(e){e&&(e.position.set(this.position.x,this.position.y),e.scale.set(this.scale),e.rotation=this.rotation)}},Lt=class{constructor(e){var t,n,a,s;this.z_index=(t=e==null?void 0:e.z_index)!=null?t:0,this.alpha=(n=e==null?void 0:e.alpha)!=null?n:1,this.visible=(a=e==null?void 0:e.visible)!=null?a:!0,this.tint=(s=e==null?void 0:e.tint)!=null?s:null}update(e){e.z_index!==void 0&&(this.z_index=e.z_index),e.alpha!==void 0&&(this.alpha=e.alpha),e.visible!==void 0&&(this.visible=e.visible),e.tint!==void 0&&(this.tint=e.tint)}syncToPixi(e,t){if(!e)return;if(e.zIndex=this.z_index,t!=null&&t.startsWith("ui_endgame_")||(e.alpha=this.alpha),e.visible=this.visible,this.tint!==null&&"tint"in e&&(e.tint=this.tint),t&&"texture"in e)try{let{AssetTextures:a}=require("handler-playable-sdk/pixi");if(a&&a[t]){let s=a[t];s&&(e.texture=s)}}catch{}}},Tt=class{constructor(e,t,n,a){this._tickerCleanup=null;this.onRebuildRequired=null;this.instanceId=e,this.objectConfig=t,this.pixiObject=n,this._config=a,this.transform=new At(a.transform),this.renderer=new Lt(a.render),this.sync()}sync(){this.transform.syncToPixi(this.pixiObject),this.renderer.syncToPixi(this.pixiObject,this.instanceId),this.applyAnchor(),this.applyEffectsScale(),this.applyEffects(),this.syncTextProperties(),(!this._initialized||this._shouldReplayIntro)&&(this.applyIntro(),this._initialized=!0,this._shouldReplayIntro=!1),this.applyMotion()}syncTextProperties(){var t;if(!this.pixiObject||!("text"in this.pixiObject))return;let e=(t=this._config)==null?void 0:t.ui;e&&(e.text!==void 0&&this.pixiObject.text!==e.text&&(this.pixiObject.text=e.text),this.pixiObject.style&&(e.fontSize!==void 0&&(this.pixiObject.style.fontSize=e.fontSize),e.color!==void 0&&(this.pixiObject.style.fill=e.color),e.align!==void 0&&(this.pixiObject.style.align=e.align)))}destroy(){this._tickerCleanup&&(this._tickerCleanup(),this._tickerCleanup=null),this._introTicker&&(Y.Ticker.shared.remove(this._introTicker),this._introTicker=null),this.pixiObject&&this.pixiObject.parent&&this.pixiObject.parent.removeChild(this.pixiObject)}updateConfig(e){var l,d,u,c,p,g,m,f,C,b,h;let t=(d=(l=this._config)==null?void 0:l.motion)==null?void 0:d.intro,n=(u=e==null?void 0:e.motion)==null?void 0:u.intro;n!=null&&n.enabled&&JSON.stringify(t)!==JSON.stringify(n)&&(this._shouldReplayIntro=!0);let a=(g=(p=(c=this._config)==null?void 0:c.render)==null?void 0:p.asset)==null?void 0:g.type,s=(f=(m=e==null?void 0:e.render)==null?void 0:m.asset)==null?void 0:f.type,r=(b=(C=this._config)==null?void 0:C.ui)==null?void 0:b.renderMode,o=(h=e==null?void 0:e.ui)==null?void 0:h.renderMode;if((a!==s||r!==o)&&(console.log(`[GameObject] Rebuild required for ${this.instanceId}: type changed from ${a}/${r} to ${s}/${o}`),this.onRebuildRequired)){this.onRebuildRequired(this,e);return}this._config=e,e.transform&&this.transform.update(e.transform),e.render&&this.renderer.update(e.render),this.sync()}applyAnchor(){var a,s,r,o;if(!this.pixiObject||!("anchor"in this.pixiObject)||!this.pixiObject.anchor)return;let e=(s=(a=this._config)==null?void 0:a.render)==null?void 0:s.anchor,t=(o=(r=this._config)==null?void 0:r.transform)==null?void 0:o.anchor,n=e&&typeof e=="object"?e:t&&typeof t=="object"?t:null;n&&typeof n.x=="number"&&typeof n.y=="number"&&this.pixiObject.anchor.set(n.x,n.y)}applyEffectsScale(){var s,r,o;if(!((s=this.pixiObject)!=null&&s.scale))return;let e=(r=this._config)==null?void 0:r.effects,t=typeof(e==null?void 0:e.scale_x)=="number"?e.scale_x:1,n=typeof(e==null?void 0:e.scale_y)=="number"?e.scale_y:1;if(t===1&&n===1)return;let a=(o=this.transform.scale)!=null?o:1;typeof this.pixiObject.scale.set=="function"?this.pixiObject.scale.set(a*t,a*n):(this.pixiObject.scale.x=a*t,this.pixiObject.scale.y=a*n)}applyEffects(){var n,a,s,r,o,l,d,u,c;if(!this.pixiObject)return;let e=(n=this._config)==null?void 0:n.effects;if(!e||e.enabled===!1){this.pixiObject.filters=null;return}let t=[];if((a=e.blur)!=null&&a.enabled){let p=new Y.BlurFilter;p.blur=(s=e.blur.strength)!=null?s:4,t.push(p)}if((r=e.shadow)!=null&&r.enabled){let p=e.shadow,g=new Y.BlurFilter;g.blur=(o=p.blur)!=null?o:4,g.blendMode="multiply",t.push(g),(p.offsetX!==0||p.offsetY!==0)&&console.warn("[Effects] Drop shadow offset requires pixi-filters. Install: npm install pixi-filters")}if((l=e.glow)!=null&&l.enabled){let p=e.glow,g=new Y.BlurFilter;if(g.blur=(d=p.blur)!=null?d:8,t.push(g),p.color){let m=new Y.ColorMatrixFilter,f=typeof p.color=="string"?parseInt(p.color.replace("#",""),16):p.color;m.tint(f),t.push(m)}}(u=e.stroke)!=null&&u.enabled&&console.warn("[Effects] Stroke/outline effect requires pixi-filters. Install: npm install pixi-filters"),(c=e.distortion)!=null&&c.enabled&&console.warn("[Effects] Distortion effect requires pixi-filters or a displacement map. Install: npm install pixi-filters"),this.pixiObject.filters=t.length>0?t:null}applyIntro(){var u,c,p,g,m,f,C;let e=(u=this._config)==null?void 0:u.motion;if(!e||!((c=e.intro)!=null&&c.enabled)||!this.pixiObject)return;let t=e.intro,n=(t.duration||0)/1e3,a=(t.delay||0)/1e3,s=this.transform.position.y,r=this.transform.scale*(((g=(p=this._config)==null?void 0:p.effects)==null?void 0:g.scale_x)||1),o=this.transform.scale*(((f=(m=this._config)==null?void 0:m.effects)==null?void 0:f.scale_y)||1);if(this.pixiObject.alpha=(C=t.startAlpha)!=null?C:0,t.startScale!==void 0&&this.pixiObject.scale.set(r*t.startScale,o*t.startScale),t.startYOffset!==void 0&&(this.pixiObject.y=s+(t.startYOffset||0)),this._introTicker&&Y.Ticker.shared.remove(this._introTicker),n<=0&&a<=0){this.pixiObject.alpha=this.renderer.alpha,this.pixiObject.y=this.transform.position.y,this.pixiObject.scale.set(r,o);return}let l=0,d=b=>{var R,H,z,L,S,E;if(l+=b.deltaTime/60,l<a)return;let h=n>0?Math.min(1,(l-a)/n):1,v=1-Math.pow(1-h,3),w=this.renderer.alpha,y=this.transform.scale*(((H=(R=this._config)==null?void 0:R.effects)==null?void 0:H.scale_x)||1),P=this.transform.scale*(((L=(z=this._config)==null?void 0:z.effects)==null?void 0:L.scale_y)||1),j=this.transform.position.y,B=this.transform.position.x;if(this.pixiObject.alpha=((S=t.startAlpha)!=null?S:0)+(w-((E=t.startAlpha)!=null?E:0))*v,t.startScale!==void 0){let A=t.startScale+(1-t.startScale)*v;this.pixiObject.scale.set(y*A,P*A)}t.startYOffset!==void 0&&(this.pixiObject.y=j+t.startYOffset+(j-(j+t.startYOffset))*v),h>=1&&(Y.Ticker.shared.remove(d),this._introTicker=null,this.pixiObject.alpha=w,this.pixiObject.x=B,this.pixiObject.y=j,this.pixiObject.scale.set(y,P))};this._introTicker=d,Y.Ticker.shared.add(d)}applyMotion(){var c,p,g,m,f,C;let e=(c=this._config)==null?void 0:c.motion,t=e&&e.enabled!==!1,n=JSON.stringify(e);if(this._lastMotionStr===n&&this._tickerCleanup)return;if(this._lastMotionStr=n,!t){this._tickerCleanup&&(this._tickerCleanup(),this._tickerCleanup=null);return}if(this._tickerCleanup&&this._tickerCleanup(),!(((p=e.pulse)==null?void 0:p.enabled)||((g=e.swing)==null?void 0:g.enabled)||((m=e.continuousMove)==null?void 0:m.enabled)||((f=e.continuousRotate)==null?void 0:f.enabled)||((C=e.orbit)==null?void 0:C.enabled)))return;let s=0,r=0,o=0,l=0,d=1/60,u=b=>{var z,L,S,E,A,T,U,ie,be,ye,ve,we,xe,Se,q,Ie,nt,at,st,rt,ot,lt,ct,dt,pt,ut;let h=((z=b.deltaTime)!=null?z:1)*d;s+=b.deltaTime*.05;let v=this.transform.scale,w=v*(((S=(L=this._config)==null?void 0:L.effects)==null?void 0:S.scale_x)||1),y=v*(((A=(E=this._config)==null?void 0:E.effects)==null?void 0:A.scale_y)||1),P=this.transform.position.x,j=this.transform.position.y,B=this.transform.rotation,R=0,H=0;if((T=e.swing)!=null&&T.enabled){let N=(U=e.swing.amplitude)!=null?U:10,K=(ie=e.swing.speed)!=null?ie:1,G=Math.sin(s*K)*N;e.swing.axis==="vertical"?H+=G:e.swing.axis==="both"?(R+=G,H+=G):R+=G}if((be=e.continuousMove)!=null&&be.enabled){let N=(ye=e.continuousMove.axis)!=null?ye:"x",K=Math.max(0,(ve=e.continuousMove.speed)!=null?ve:50),G=Math.sign((we=e.continuousMove.direction)!=null?we:1)||1,X=Math.max(0,(xe=e.continuousMove.lifetime)!=null?xe:0);r+=h;let Fe=X>0?Math.min(r,X):r,Me=K*G*Fe;(N==="x"||N==="both")&&(R+=Me),(N==="y"||N==="both")&&(H+=Me)}if((Se=e.orbit)!=null&&Se.enabled){let N=Math.max(0,(q=e.orbit.radius)!=null?q:50),K=Math.max(0,(Ie=e.orbit.speed)!=null?Ie:45),G=Math.sign((nt=e.orbit.direction)!=null?nt:1)||1,X=K*Math.PI/180;l+=X*G*h;let Fe=(at=e.orbit.pivotOffsetX)!=null?at:0,Me=(st=e.orbit.pivotOffsetY)!=null?st:0;R+=Fe+N*Math.cos(l),H+=Me+N*Math.sin(l)}if(this.pixiObject.x=P+R,this.pixiObject.y=j+H,(rt=e.pulse)!=null&&rt.enabled){let N=(ot=e.pulse.intensity)!=null?ot:.1,K=(lt=e.pulse.speed)!=null?lt:1,X=1+Math.sin(s*K)*N;(ct=this.pixiObject.scale)!=null&&ct.set?this.pixiObject.scale.set(w*X,y*X):this.pixiObject.scale&&(this.pixiObject.scale.x=w*X,this.pixiObject.scale.y=y*X)}if((dt=e.continuousRotate)!=null&&dt.enabled){let N=Math.max(0,(pt=e.continuousRotate.speed)!=null?pt:90),K=Math.sign((ut=e.continuousRotate.direction)!=null?ut:1)||1,G=N*Math.PI/180;o+=G*K*h,this.pixiObject.rotation=B+o}};Y.Ticker.shared.add(u),this._tickerCleanup=()=>{var b,h,v,w,y;if(Y.Ticker.shared.remove(u),this.pixiObject){let P=this.transform.scale*(((h=(b=this._config)==null?void 0:b.effects)==null?void 0:h.scale_x)||1),j=this.transform.scale*(((w=(v=this._config)==null?void 0:v.effects)==null?void 0:w.scale_y)||1);this.pixiObject.x=this.transform.position.x,this.pixiObject.y=this.transform.position.y,this.pixiObject.rotation=this.transform.rotation,(y=this.pixiObject.scale)!=null&&y.set?this.pixiObject.scale.set(P,j):this.pixiObject.scale&&(this.pixiObject.scale.x=P,this.pixiObject.scale.y=j)}}}getComponent(e){return this._config[e]}getPosition(){return{...this.transform.position}}setPosition(e,t){this.transform.position={x:e,y:t},this.transform.syncToPixi(this.pixiObject)}getAlpha(){return this.renderer.alpha}setAlpha(e){this.renderer.alpha=e,this.renderer.syncToPixi(this.pixiObject)}getVisible(){return this.renderer.visible}setVisible(e){this.renderer.visible=e,this.renderer.syncToPixi(this.pixiObject)}},Qe=class{constructor(e){this.objects=new Map;this.onObjectRebuildRequired=null;this.config=e}create(e,t){let n=this.config.objects.get(e);if(!n)throw new Error(`Object config not found: ${e}`);let a=new Tt(e,n.object_config||e,t,n);return this.objects.set(e,a),a.onRebuildRequired=async(s,r)=>{if(this.onObjectRebuildRequired){console.log(`[GameObjectManager] Triggering rebuild for ${e}`);let o=await this.onObjectRebuildRequired(e,r);o&&this.objects.get(e)===o&&console.log(`[GameObjectManager] \u2705 Rebuilt ${e} successfully`)}else console.warn(`[GameObjectManager] Rebuild required for ${e} but no factory provided`),s.updateConfig(r)},a}get(e){return this.objects.get(e)}updateConfig(e){this.config=e;for(let[t,n]of this.objects.entries()){let a=e.objects.get(t);a&&n.updateConfig(a)}}getAll(){return Array.from(this.objects.values())}remove(e){let t=this.objects.get(e);t&&t.destroy(),this.objects.delete(e)}clear(){for(let e of this.objects.values())e.destroy();this.objects.clear()}};var ii={"brand.primary":{family:"Arial, sans-serif",weight:"400"},"brand.warning":{family:"Arial Black, Arial, sans-serif",weight:"900"},"brand.heading":{family:"Arial Black, Arial, sans-serif",weight:"800"},"brand.body":{family:"Arial, sans-serif",weight:"400"}};function ra(i){let e=ii[i];return e?e.family:(console.warn(`Font ID "${i}" not found in registry, using fallback`),"Arial, sans-serif")}function oa(i){var t;let e=ii[i];return e&&(t=e.weight)!=null?t:"400"}function la(i,e){ii[i]=e}function ca(){return Object.keys(ii)}var et=null;function Hs(){return console.log("[LottieOverlay] getLottie called, lottieLib cached?",!!et),console.log("[LottieOverlay] window.lottie exists?",typeof window!="undefined"&&!!window.lottie),et||(typeof window!="undefined"&&window.lottie?(et=window.lottie,console.log("[LottieOverlay] \u2705 Found window.lottie, cached it")):(console.warn("[LottieOverlay] \u274C lottie-web is not available globally. Make sure it is loaded before using Lottie animations."),console.log("[LottieOverlay] window keys:",typeof window!="undefined"?Object.keys(window).filter(i=>i.toLowerCase().includes("lottie")):"no window"),et=null)),et}function Ns(i){return!i||i.startsWith("http://")||i.startsWith("https://")||i.startsWith("/")?i:`/${i.replace(/^\.\//,"")}`}function Fs(i){try{let e=new XMLHttpRequest;return e.open("GET",Ns(i),!1),e.send(null),e.status<200||e.status>=300||!e.responseText?null:JSON.parse(e.responseText)}catch{return null}}function da(i){return!i||typeof i!="object"||!Array.isArray(i.layers)?null:(Array.isArray(i.assets)||(i.assets=[]),Array.isArray(i.chars)||(i.chars=[]),i)}function Kt(i){et=i}function pa(i,e,t,n){var P,j,B,R,H,z,L,S,E,A,T,U,ie,be,ye,ve,we,xe,Se;let a=t.objects.get(i);if(!a)return console.warn(`[LottieOverlay] Object config not found: ${i}`),null;let s=((P=a.effects)==null?void 0:P.lottie)||{},r=a.transform||{},o=a.render||{};if(s.enabled===!1||o.visible===!1)return null;let l=n==null?void 0:n[i],d=da(l);if(!d){let q=(B=(j=a.render)==null?void 0:j.asset)==null?void 0:B.path;if(typeof q=="string"&&q.toLowerCase().endsWith(".json")){let Ie=Fs(q);if(d=da(Ie),d)try{n[i]=d}catch{}}}if(!d){let q=l&&typeof l=="object"?Object.prototype.toString.call(l):typeof l;return console.warn(`[LottieOverlay] Lottie JSON invalid for: ${i}`,{kind:q}),null}let u=Hs();if(!u)return console.warn(`[LottieOverlay] lottie-web is not available. Cannot play animation: ${i}`),null;let c=(R=s.width)!=null?R:300,p=(H=s.height)!=null?H:300,g=(z=r.scale)!=null?z:1,m=((S=(L=r.position)==null?void 0:L.x)!=null?S:0)+((A=(E=r.offset)==null?void 0:E.x)!=null?A:0),f=((U=(T=r.position)==null?void 0:T.y)!=null?U:0)+((be=(ie=r.offset)==null?void 0:ie.y)!=null?be:0),C=(ye=r.rotation)!=null?ye:0,b=(ve=o.z_index)!=null?ve:100,h=(we=o.alpha)!=null?we:1,v=document.createElement("div");v.style.cssText=`
245
+ `,i.appendChild(e)}async function ii(i,e={}){let t=new Sa.Application;await t.init({resizeTo:i,autoDensity:!0,resolution:window.devicePixelRatio||1,antialias:!0,backgroundAlpha:0});let n=r=>{var d,p,g,m;if(!t.renderer)return;let o=(d=r==null?void 0:r.width)!=null?d:i.clientWidth,c=(p=r==null?void 0:r.height)!=null?p:i.clientHeight,l=o&&o>0?o:(g=window.innerWidth)!=null?g:320,u=c&&c>0?c:(m=window.innerHeight)!=null?m:480;t.renderer.resize(l,u)};i.appendChild(t.canvas),i.style.position="relative",i.style.display="flex",i.style.flexDirection="column",i.style.alignItems="stretch",i.style.width="100%",i.style.height="100dvh",i.style.minHeight="100vh",i.style.maxWidth="100%",i.style.maxHeight="100%",i.style.boxSizing="border-box",i.style.overflow="hidden",e.background&&(i.style.background=e.background),n();let a=document.createElement("div");return a.setAttribute("style",["position:absolute","inset:0","display:flex","flex-direction:column","align-items:center","justify-content:flex-start","gap:12px","pointer-events:none","font-family:Arial,sans-serif","padding:20px 16px","padding-bottom:clamp(24px, 6vh, 96px)","box-sizing:border-box","z-index:2"].join(";")),i.appendChild(a),St.on("pause",()=>{t.ticker.stop(),document.querySelectorAll("audio").forEach(o=>o.pause())}),St.on("resume",()=>{t.ticker.start(),document.querySelectorAll("audio").forEach(o=>{o.currentTime>0&&!o.ended&&o.play().catch(()=>{})})}),St.on("resize",({payload:r})=>{n({width:r==null?void 0:r.width,height:r==null?void 0:r.height})}),window.addEventListener("resize",()=>n()),requestAnimationFrame(()=>n()),new ResizeObserver(r=>{let o=r[0];if(o&&o.contentRect.width>0&&o.contentRect.height>0){let c=Math.round(o.contentRect.width),l=Math.round(o.contentRect.height);if(n({width:c,height:l}),typeof window!="undefined"&&window.gameApp&&window.gameObjectManager){let u={width:c,height:l,dpr:Math.max(1,Math.floor(window.devicePixelRatio||1)),presetId:"auto-resize",isLandscape:c>l};window.dispatchEvent(new CustomEvent("handler-preview:screen",{detail:u}))}}}).observe(i),{app:t,stage:t.stage,overlay:a,applySize:n}}var K=require("pixi.js"),Pt=class{constructor(e){var a,s;let t=e==null?void 0:e.position,n=e==null?void 0:e.offset;this._basePosition={x:typeof(t==null?void 0:t.x)=="number"?t.x:0,y:typeof(t==null?void 0:t.y)=="number"?t.y:0},this._offset={x:typeof(n==null?void 0:n.x)=="number"?n.x:0,y:typeof(n==null?void 0:n.y)=="number"?n.y:0},this.position={x:this._basePosition.x+this._offset.x,y:this._basePosition.y+this._offset.y},this.scale=(a=e==null?void 0:e.scale)!=null?a:1,this.rotation=(s=e==null?void 0:e.rotation)!=null?s:0}update(e){let t=e.position,n=e.offset;t!==void 0&&(this._basePosition={x:typeof(t==null?void 0:t.x)=="number"?t.x:0,y:typeof(t==null?void 0:t.y)=="number"?t.y:0}),n!==void 0&&(this._offset={x:typeof(n==null?void 0:n.x)=="number"?n.x:0,y:typeof(n==null?void 0:n.y)=="number"?n.y:0}),(t!==void 0||n!==void 0)&&(this.position={x:this._basePosition.x+this._offset.x,y:this._basePosition.y+this._offset.y}),e.scale!==void 0&&(this.scale=e.scale),e.rotation!==void 0&&(this.rotation=e.rotation)}syncToPixi(e){e&&(e.position.set(this.position.x,this.position.y),e.scale.set(this.scale),e.rotation=this.rotation)}},Mt=class{constructor(e){var t,n,a,s;this.z_index=(t=e==null?void 0:e.z_index)!=null?t:0,this.alpha=(n=e==null?void 0:e.alpha)!=null?n:1,this.visible=(a=e==null?void 0:e.visible)!=null?a:!0,this.tint=(s=e==null?void 0:e.tint)!=null?s:null}update(e){e.z_index!==void 0&&(this.z_index=e.z_index),e.alpha!==void 0&&(this.alpha=e.alpha),e.visible!==void 0&&(this.visible=e.visible),e.tint!==void 0&&(this.tint=e.tint)}syncToPixi(e,t){if(!e)return;if(e.zIndex=this.z_index,t!=null&&t.startsWith("ui_endgame_")||(e.alpha=this.alpha),e.visible=this.visible,this.tint!==null&&"tint"in e&&(e.tint=this.tint),t&&"texture"in e)try{let{AssetTextures:a}=require("handler-playable-sdk/pixi");if(a&&a[t]){let s=a[t];s&&(e.texture=s)}}catch{}}},It=class{constructor(e,t,n,a){this._tickerCleanup=null;this.onRebuildRequired=null;this.instanceId=e,this.objectConfig=t,this.pixiObject=n,this._config=a,this.transform=new Pt(a.transform),this.renderer=new Mt(a.render),this.sync()}sync(){this.transform.syncToPixi(this.pixiObject),this.renderer.syncToPixi(this.pixiObject,this.instanceId),this.applyAnchor(),this.applyEffectsScale(),this.applyEffects(),this.syncTextProperties(),(!this._initialized||this._shouldReplayIntro)&&(this.applyIntro(),this._initialized=!0,this._shouldReplayIntro=!1),this.applyMotion()}syncTextProperties(){var t;if(!this.pixiObject||!("text"in this.pixiObject))return;let e=(t=this._config)==null?void 0:t.ui;e&&(e.text!==void 0&&this.pixiObject.text!==e.text&&(this.pixiObject.text=e.text),this.pixiObject.style&&(e.fontSize!==void 0&&(this.pixiObject.style.fontSize=e.fontSize),e.color!==void 0&&(this.pixiObject.style.fill=e.color),e.align!==void 0&&(this.pixiObject.style.align=e.align)))}destroy(){this._tickerCleanup&&(this._tickerCleanup(),this._tickerCleanup=null),this._introTicker&&(K.Ticker.shared.remove(this._introTicker),this._introTicker=null),this.pixiObject&&this.pixiObject.parent&&this.pixiObject.parent.removeChild(this.pixiObject)}updateConfig(e){var c,l,u,d,p,g,m,f,C,b,h;let t=(l=(c=this._config)==null?void 0:c.motion)==null?void 0:l.intro,n=(u=e==null?void 0:e.motion)==null?void 0:u.intro;n!=null&&n.enabled&&JSON.stringify(t)!==JSON.stringify(n)&&(this._shouldReplayIntro=!0);let a=(g=(p=(d=this._config)==null?void 0:d.render)==null?void 0:p.asset)==null?void 0:g.type,s=(f=(m=e==null?void 0:e.render)==null?void 0:m.asset)==null?void 0:f.type,r=(b=(C=this._config)==null?void 0:C.ui)==null?void 0:b.renderMode,o=(h=e==null?void 0:e.ui)==null?void 0:h.renderMode;if((a!==s||r!==o)&&(console.log(`[GameObject] Rebuild required for ${this.instanceId}: type changed from ${a}/${r} to ${s}/${o}`),this.onRebuildRequired)){this.onRebuildRequired(this,e);return}this._config=e,e.transform&&this.transform.update(e.transform),e.render&&this.renderer.update(e.render),this.sync()}applyAnchor(){var a,s,r,o;if(!this.pixiObject||!("anchor"in this.pixiObject)||!this.pixiObject.anchor)return;let e=(s=(a=this._config)==null?void 0:a.render)==null?void 0:s.anchor,t=(o=(r=this._config)==null?void 0:r.transform)==null?void 0:o.anchor,n=e&&typeof e=="object"?e:t&&typeof t=="object"?t:null;n&&typeof n.x=="number"&&typeof n.y=="number"&&this.pixiObject.anchor.set(n.x,n.y)}applyEffectsScale(){var s,r,o;if(!((s=this.pixiObject)!=null&&s.scale))return;let e=(r=this._config)==null?void 0:r.effects,t=typeof(e==null?void 0:e.scale_x)=="number"?e.scale_x:1,n=typeof(e==null?void 0:e.scale_y)=="number"?e.scale_y:1;if(t===1&&n===1)return;let a=(o=this.transform.scale)!=null?o:1;typeof this.pixiObject.scale.set=="function"?this.pixiObject.scale.set(a*t,a*n):(this.pixiObject.scale.x=a*t,this.pixiObject.scale.y=a*n)}applyEffects(){var n,a,s,r,o,c,l,u,d;if(!this.pixiObject)return;let e=(n=this._config)==null?void 0:n.effects;if(!e||e.enabled===!1){this.pixiObject.filters=null;return}let t=[];if((a=e.blur)!=null&&a.enabled){let p=new K.BlurFilter;p.blur=(s=e.blur.strength)!=null?s:4,t.push(p)}if((r=e.shadow)!=null&&r.enabled){let p=e.shadow,g=new K.BlurFilter;g.blur=(o=p.blur)!=null?o:4,g.blendMode="multiply",t.push(g),(p.offsetX!==0||p.offsetY!==0)&&console.warn("[Effects] Drop shadow offset requires pixi-filters. Install: npm install pixi-filters")}if((c=e.glow)!=null&&c.enabled){let p=e.glow,g=new K.BlurFilter;if(g.blur=(l=p.blur)!=null?l:8,t.push(g),p.color){let m=new K.ColorMatrixFilter,f=typeof p.color=="string"?parseInt(p.color.replace("#",""),16):p.color;m.tint(f),t.push(m)}}(u=e.stroke)!=null&&u.enabled&&console.warn("[Effects] Stroke/outline effect requires pixi-filters. Install: npm install pixi-filters"),(d=e.distortion)!=null&&d.enabled&&console.warn("[Effects] Distortion effect requires pixi-filters or a displacement map. Install: npm install pixi-filters"),this.pixiObject.filters=t.length>0?t:null}applyIntro(){var u,d,p,g,m,f,C;let e=(u=this._config)==null?void 0:u.motion;if(!e||!((d=e.intro)!=null&&d.enabled)||!this.pixiObject)return;let t=e.intro,n=(t.duration||0)/1e3,a=(t.delay||0)/1e3,s=this.transform.position.y,r=this.transform.scale*(((g=(p=this._config)==null?void 0:p.effects)==null?void 0:g.scale_x)||1),o=this.transform.scale*(((f=(m=this._config)==null?void 0:m.effects)==null?void 0:f.scale_y)||1);if(this.pixiObject.alpha=(C=t.startAlpha)!=null?C:0,t.startScale!==void 0&&this.pixiObject.scale.set(r*t.startScale,o*t.startScale),t.startYOffset!==void 0&&(this.pixiObject.y=s+(t.startYOffset||0)),this._introTicker&&K.Ticker.shared.remove(this._introTicker),n<=0&&a<=0){this.pixiObject.alpha=this.renderer.alpha,this.pixiObject.y=this.transform.position.y,this.pixiObject.scale.set(r,o);return}let c=0,l=b=>{var z,N,$,L,S,E;if(c+=b.deltaTime/60,c<a)return;let h=n>0?Math.min(1,(c-a)/n):1,v=1-Math.pow(1-h,3),w=this.renderer.alpha,y=this.transform.scale*(((N=(z=this._config)==null?void 0:z.effects)==null?void 0:N.scale_x)||1),M=this.transform.scale*(((L=($=this._config)==null?void 0:$.effects)==null?void 0:L.scale_y)||1),_=this.transform.position.y,G=this.transform.position.x;if(this.pixiObject.alpha=((S=t.startAlpha)!=null?S:0)+(w-((E=t.startAlpha)!=null?E:0))*v,t.startScale!==void 0){let A=t.startScale+(1-t.startScale)*v;this.pixiObject.scale.set(y*A,M*A)}t.startYOffset!==void 0&&(this.pixiObject.y=_+t.startYOffset+(_-(_+t.startYOffset))*v),h>=1&&(K.Ticker.shared.remove(l),this._introTicker=null,this.pixiObject.alpha=w,this.pixiObject.x=G,this.pixiObject.y=_,this.pixiObject.scale.set(y,M))};this._introTicker=l,K.Ticker.shared.add(l)}applyMotion(){var d,p,g,m,f,C;let e=(d=this._config)==null?void 0:d.motion,t=e&&e.enabled!==!1,n=JSON.stringify(e);if(this._lastMotionStr===n&&this._tickerCleanup)return;if(this._lastMotionStr=n,!t){this._tickerCleanup&&(this._tickerCleanup(),this._tickerCleanup=null);return}if(this._tickerCleanup&&this._tickerCleanup(),!(((p=e.pulse)==null?void 0:p.enabled)||((g=e.swing)==null?void 0:g.enabled)||((m=e.continuousMove)==null?void 0:m.enabled)||((f=e.continuousRotate)==null?void 0:f.enabled)||((C=e.orbit)==null?void 0:C.enabled)))return;let s=0,r=0,o=0,c=0,l=1/60,u=b=>{var $,L,S,E,A,T,q,ae,we,xe,Se,Ee,Ce,Ae,V,_e,rt,ot,lt,ct,dt,pt,ut,gt,ht,ft;let h=(($=b.deltaTime)!=null?$:1)*l;s+=b.deltaTime*.05;let v=this.transform.scale,w=v*(((S=(L=this._config)==null?void 0:L.effects)==null?void 0:S.scale_x)||1),y=v*(((A=(E=this._config)==null?void 0:E.effects)==null?void 0:A.scale_y)||1),M=this.transform.position.x,_=this.transform.position.y,G=this.transform.rotation,z=0,N=0;if((T=e.swing)!=null&&T.enabled){let F=(q=e.swing.amplitude)!=null?q:10,X=(ae=e.swing.speed)!=null?ae:1,U=Math.sin(s*X)*F;e.swing.axis==="vertical"?N+=U:e.swing.axis==="both"?(z+=U,N+=U):z+=U}if((we=e.continuousMove)!=null&&we.enabled){let F=(xe=e.continuousMove.axis)!=null?xe:"x",X=Math.max(0,(Se=e.continuousMove.speed)!=null?Se:50),U=Math.sign((Ee=e.continuousMove.direction)!=null?Ee:1)||1,J=Math.max(0,(Ce=e.continuousMove.lifetime)!=null?Ce:0);r+=h;let Ge=J>0?Math.min(r,J):r,Oe=X*U*Ge;(F==="x"||F==="both")&&(z+=Oe),(F==="y"||F==="both")&&(N+=Oe)}if((Ae=e.orbit)!=null&&Ae.enabled){let F=Math.max(0,(V=e.orbit.radius)!=null?V:50),X=Math.max(0,(_e=e.orbit.speed)!=null?_e:45),U=Math.sign((rt=e.orbit.direction)!=null?rt:1)||1,J=X*Math.PI/180;c+=J*U*h;let Ge=(ot=e.orbit.pivotOffsetX)!=null?ot:0,Oe=(lt=e.orbit.pivotOffsetY)!=null?lt:0;z+=Ge+F*Math.cos(c),N+=Oe+F*Math.sin(c)}if(this.pixiObject.x=M+z,this.pixiObject.y=_+N,(ct=e.pulse)!=null&&ct.enabled){let F=(dt=e.pulse.intensity)!=null?dt:.1,X=(pt=e.pulse.speed)!=null?pt:1,J=1+Math.sin(s*X)*F;(ut=this.pixiObject.scale)!=null&&ut.set?this.pixiObject.scale.set(w*J,y*J):this.pixiObject.scale&&(this.pixiObject.scale.x=w*J,this.pixiObject.scale.y=y*J)}if((gt=e.continuousRotate)!=null&&gt.enabled){let F=Math.max(0,(ht=e.continuousRotate.speed)!=null?ht:90),X=Math.sign((ft=e.continuousRotate.direction)!=null?ft:1)||1,U=F*Math.PI/180;o+=U*X*h,this.pixiObject.rotation=G+o}};K.Ticker.shared.add(u),this._tickerCleanup=()=>{var b,h,v,w,y;if(K.Ticker.shared.remove(u),this.pixiObject){let M=this.transform.scale*(((h=(b=this._config)==null?void 0:b.effects)==null?void 0:h.scale_x)||1),_=this.transform.scale*(((w=(v=this._config)==null?void 0:v.effects)==null?void 0:w.scale_y)||1);this.pixiObject.x=this.transform.position.x,this.pixiObject.y=this.transform.position.y,this.pixiObject.rotation=this.transform.rotation,(y=this.pixiObject.scale)!=null&&y.set?this.pixiObject.scale.set(M,_):this.pixiObject.scale&&(this.pixiObject.scale.x=M,this.pixiObject.scale.y=_)}}}getComponent(e){return this._config[e]}getPosition(){return{...this.transform.position}}setPosition(e,t){this.transform.position={x:e,y:t},this.transform.syncToPixi(this.pixiObject)}getAlpha(){return this.renderer.alpha}setAlpha(e){this.renderer.alpha=e,this.renderer.syncToPixi(this.pixiObject)}getVisible(){return this.renderer.visible}setVisible(e){this.renderer.visible=e,this.renderer.syncToPixi(this.pixiObject)}},it=class{constructor(e){this.objects=new Map;this.onObjectRebuildRequired=null;this.config=e}create(e,t){let n=this.config.objects.get(e);if(!n)throw new Error(`Object config not found: ${e}`);let a=new It(e,n.object_config||e,t,n);return this.objects.set(e,a),a.onRebuildRequired=async(s,r)=>{if(this.onObjectRebuildRequired){console.log(`[GameObjectManager] Triggering rebuild for ${e}`);let o=await this.onObjectRebuildRequired(e,r);o&&this.objects.get(e)===o&&console.log(`[GameObjectManager] \u2705 Rebuilt ${e} successfully`)}else console.warn(`[GameObjectManager] Rebuild required for ${e} but no factory provided`),s.updateConfig(r)},a}get(e){return this.objects.get(e)}updateConfig(e){this.config=e;for(let[t,n]of this.objects.entries()){let a=e.objects.get(t);a&&n.updateConfig(a)}}getAll(){return Array.from(this.objects.values())}remove(e){let t=this.objects.get(e);t&&t.destroy(),this.objects.delete(e)}clear(){for(let e of this.objects.values())e.destroy();this.objects.clear()}};var ni={"brand.primary":{family:"Arial, sans-serif",weight:"400"},"brand.warning":{family:"Arial Black, Arial, sans-serif",weight:"900"},"brand.heading":{family:"Arial Black, Arial, sans-serif",weight:"800"},"brand.body":{family:"Arial, sans-serif",weight:"400"}};function Ea(i){let e=ni[i];return e?e.family:(console.warn(`Font ID "${i}" not found in registry, using fallback`),"Arial, sans-serif")}function Ca(i){var t;let e=ni[i];return e&&(t=e.weight)!=null?t:"400"}function Aa(i,e){ni[i]=e}function La(){return Object.keys(ni)}var nt=null;function nr(){return console.log("[LottieOverlay] getLottie called, lottieLib cached?",!!nt),console.log("[LottieOverlay] window.lottie exists?",typeof window!="undefined"&&!!window.lottie),nt||(typeof window!="undefined"&&window.lottie?(nt=window.lottie,console.log("[LottieOverlay] \u2705 Found window.lottie, cached it")):(console.warn("[LottieOverlay] \u274C lottie-web is not available globally. Make sure it is loaded before using Lottie animations."),console.log("[LottieOverlay] window keys:",typeof window!="undefined"?Object.keys(window).filter(i=>i.toLowerCase().includes("lottie")):"no window"),nt=null)),nt}function ar(i){return!i||i.startsWith("http://")||i.startsWith("https://")||i.startsWith("/")?i:`/${i.replace(/^\.\//,"")}`}function sr(i){try{let e=new XMLHttpRequest;return e.open("GET",ar(i),!1),e.send(null),e.status<200||e.status>=300||!e.responseText?null:JSON.parse(e.responseText)}catch{return null}}function Ta(i){return!i||typeof i!="object"||!Array.isArray(i.layers)?null:(Array.isArray(i.assets)||(i.assets=[]),Array.isArray(i.chars)||(i.chars=[]),i)}function Xt(i){nt=i}function ka(i,e,t,n){var M,_,G,z,N,$,L,S,E,A,T,q,ae,we,xe,Se,Ee,Ce,Ae;let a=t.objects.get(i);if(!a)return console.warn(`[LottieOverlay] Object config not found: ${i}`),null;let s=((M=a.effects)==null?void 0:M.lottie)||{},r=a.transform||{},o=a.render||{};if(s.enabled===!1||o.visible===!1)return null;let c=n==null?void 0:n[i],l=Ta(c);if(!l){let V=(G=(_=a.render)==null?void 0:_.asset)==null?void 0:G.path;if(typeof V=="string"&&V.toLowerCase().endsWith(".json")){let _e=sr(V);if(l=Ta(_e),l)try{n[i]=l}catch{}}}if(!l){let V=c&&typeof c=="object"?Object.prototype.toString.call(c):typeof c;return console.warn(`[LottieOverlay] Lottie JSON invalid for: ${i}`,{kind:V}),null}let u=nr();if(!u)return console.warn(`[LottieOverlay] lottie-web is not available. Cannot play animation: ${i}`),null;let d=(z=s.width)!=null?z:300,p=(N=s.height)!=null?N:300,g=($=r.scale)!=null?$:1,m=((S=(L=r.position)==null?void 0:L.x)!=null?S:0)+((A=(E=r.offset)==null?void 0:E.x)!=null?A:0),f=((q=(T=r.position)==null?void 0:T.y)!=null?q:0)+((we=(ae=r.offset)==null?void 0:ae.y)!=null?we:0),C=(xe=r.rotation)!=null?xe:0,b=(Se=o.z_index)!=null?Se:100,h=(Ee=o.alpha)!=null?Ee:1,v=document.createElement("div");v.style.cssText=`
246
246
  position: absolute;
247
247
  top: calc(50% + ${f}px);
248
248
  left: calc(50% + ${m}px);
249
249
  transform: translate(-50%, -50%) scale(${g}) rotate(${C}deg);
250
- width: ${c}px;
250
+ width: ${d}px;
251
251
  height: ${p}px;
252
252
  pointer-events: none;
253
253
  z-index: ${b};
254
254
  opacity: ${h};
255
- `,e.appendChild(v);let w;try{w=u.loadAnimation({container:v,renderer:s.renderer||"svg",loop:(xe=s.loop)!=null?xe:!1,autoplay:(Se=s.autoplay)!=null?Se:!0,animationData:d})}catch(q){return v.parentNode&&v.parentNode.removeChild(v),console.warn(`[LottieOverlay] Failed to start animation: ${i}`,q),null}s.speed!==void 0&&w.setSpeed(s.speed);let y=()=>{w.destroy(),v.parentNode&&v.parentNode.removeChild(v)};return s.loop||w.addEventListener("complete",y),{animation:w,cleanup:y}}Dt();mi();var ni=class{constructor(e,t,n){this.systems=[];this.totalTime=0;this.context=null;this.root=e,this.config=t,this.destinationUrl=n}async createApp(e){if(this.context)return{app:this.app,gameObjectManager:this.gameObjectManager};let{app:t,stage:n}=await ti(this.root,{background:e.background_color,text:e.text_color,primary:e.cta_background,cta_text:e.cta_text});this.app=t,this.stage=n,this.gameObjectManager=new Qe(this.config),this.stage.eventMode="passive",this.stage.interactive=!1,this.stage.interactiveChildren=!0,this.stage.sortableChildren=!0,this.context={app:this.app,stage:this.stage,config:this.config,gameObjectManager:this.gameObjectManager,destinationUrl:this.destinationUrl,root:this.root,engine:this};for(let a of this.systems)a.setContext(this.context);return{app:this.app,gameObjectManager:this.gameObjectManager}}async initSystems(){if(!this.context)throw new Error("[GameEngine] createApp() must be called before initSystems()");for(let e of this.systems)e.init&&await e.init()}async init(e){return await this.createApp(e),await this.initSystems(),{app:this.app,gameObjectManager:this.gameObjectManager}}registerSystems(e){this.systems.push(...e)}async start(){for(let e of this.systems)e.onStart&&await e.onStart();this.app.ticker.add(this.update.bind(this)),window.addEventListener("handler-preview:screen",e=>{let{width:t,height:n}=e.detail;this.resize(t,n)})}update(e){let t=e.deltaTime/60;this.totalTime+=t;for(let n of this.systems)n.update&&n.update(t,this.totalTime)}resize(e,t){for(let n of this.systems)n.onResize&&n.onResize(e,t)}updateConfig(e){this.config=e;for(let t of this.systems)t.context.config=e,t.onConfigUpdate&&t.onConfigUpdate(e)}destroy(){for(let e of this.systems)e.onDestroy&&e.onDestroy();this.app.ticker.remove(this.update.bind(this)),this.app.destroy(!0,{children:!0,texture:!1})}getApp(){return this.app}getGameObjectManager(){return this.gameObjectManager}getTotalTime(){return this.totalTime}getSystem(e){let t=this.systems.find(n=>n instanceof e);if(!t)throw new Error(`System ${e.name} not found!`);return t}};var tt=class{setContext(e){this.context=e}};var it=class{constructor(){this.config=null}init(e){this.config=e}get(e){if(!this.config)throw new Error("RuntimeObjectRegistry not initialized. Call init() first.");return this.config.objects.get(e)}getAllIds(){if(!this.config)throw new Error("RuntimeObjectRegistry not initialized. Call init() first.");return Array.from(this.config.objects.keys())}has(e){return this.config?this.config.objects.has(e):!1}};var ua=ri(require("pixi.js"),1),ga=ua;typeof window!="undefined"&&(window.__basePixi=ua);ht();var me=require("pixi.js");ht();var ha=i=>i*Math.PI/180;function Bs(i,e){var r,o,l,d,u;let t=e.ui;if(!(t!=null&&t.text))return null;let n="#ffffff";(r=e.render)!=null&&r.tint&&(n=e.render.tint);let a=new me.TextStyle({fontFamily:(o=t.font)!=null?o:"Arial",fontSize:(l=t.fontSize)!=null?l:16,fill:n,align:(d=t.align)!=null?d:"center",letterSpacing:(u=t.letterSpacing)!=null?u:0}),s=new me.Text({text:t.text,style:a});return s.label=i,s}function fa(i){var u,c,p,g,m,f,C,b,h,v;let{stage:e,mainContainer:t,activeConfig:n,gameObjectManager:a,allowList:s,denyList:r}=i,o={},l={},d={};t.sortableChildren=!0;for(let[w,y]of n.objects.entries()){if(r!=null&&r.has(w)||s&&!s.has(w)||(y==null?void 0:y.enabled)===!1)continue;let P=(c=(u=y==null?void 0:y.render)==null?void 0:u.asset)==null?void 0:c.path,j=(g=(p=y==null?void 0:y.render)==null?void 0:p.asset)==null?void 0:g.type,B=!!(P&&j==="image"),R=!!((m=y==null?void 0:y.ui)!=null&&m.text),H=R?(f=y==null?void 0:y.ui)==null?void 0:f.renderMode:void 0,z;if(H==="png"&&B?z="png":H==="text"&&R?z="text":B?z="png":R?z="text":z="skip",z!=="skip"){if(z==="text"){let L=Bs(w,y);if(!L)continue;let S=y.render;L.alpha=typeof(S==null?void 0:S.alpha)=="number"?S.alpha:1,L.visible=(S==null?void 0:S.visible)!==!1,L.zIndex=typeof(S==null?void 0:S.z_index)=="number"?S.z_index:0,S!=null&&S.anchor&&typeof S.anchor.x=="number"&&typeof S.anchor.y=="number"?L.anchor.set(S.anchor.x,S.anchor.y):L.anchor.set(.5,.5);let E=y.transform,A=(E==null?void 0:E.position)||(E==null?void 0:E.offset);A&&L.position.set((C=A.x)!=null?C:0,(b=A.y)!=null?b:0);let T=typeof(E==null?void 0:E.scale)=="number"?E.scale:1;L.scale.set(T,T);let U=typeof(E==null?void 0:E.rotation)=="number"?E.rotation:0;L.rotation=ha(U),L.parent||t.addChild(L);try{a.create(w,L)}catch{}o[w]=L,d[w]=L}else if(z==="png"){let L=Te[w]||(typeof me.Texture!="undefined"?me.Texture.EMPTY:void 0),S=new me.Sprite(L);S.label=w;let E=y.render;S.alpha=typeof(E==null?void 0:E.alpha)=="number"?E.alpha:1,S.visible=(E==null?void 0:E.visible)!==!1,S.zIndex=typeof(E==null?void 0:E.z_index)=="number"?E.z_index:0,E!=null&&E.anchor&&typeof E.anchor.x=="number"&&typeof E.anchor.y=="number"&&S.anchor.set(E.anchor.x,E.anchor.y);let A=y.transform,T=(A==null?void 0:A.position)||(A==null?void 0:A.offset);T&&S.position.set((h=T.x)!=null?h:0,(v=T.y)!=null?v:0);let U=typeof(A==null?void 0:A.scale)=="number"?A.scale:1;S.scale.set(U,U);let ie=typeof(A==null?void 0:A.rotation)=="number"?A.rotation:0;S.rotation=ha(ie),S.parent||t.addChild(S);try{a.create(w,S)}catch{}o[w]=S,l[w]=S}}}return t.parent||e.addChild(t),{objects:o,sprites:l,texts:d}}var Di=class{constructor(){this.instanceCache=new Map;this.readyPromise=null;this.app=null;this.registry=new it}init(e,t){this.registry.init(e),this.app=t}updateConfig(e){this.registry.init(e),this.instanceCache.clear(),this.readyPromise=null}async ready(){this.readyPromise&&await this.readyPromise;let t=this.registry.getAllIds().filter(a=>!this.instanceCache.has(a));if(t.length===0)return;let n=async a=>{a.length&&(console.log("[Assets] Loading objects:",a),await Promise.all(a.map(async s=>{var o;let r=this.registry.get(s);if(!r){console.warn("[Assets] No config found for object:",s);return}try{let l=await ue.create(s,r,this.app);this.instanceCache.set(s,l),console.log("[Assets] Loaded object:",s,(o=l==null?void 0:l.constructor)==null?void 0:o.name)}catch(l){console.error("[Assets] Failed to load object:",s,l)}})))};return this.readyPromise=(async()=>{await n(t);let a=this.registry.getAllIds().filter(s=>!this.instanceCache.has(s));a.length>0&&(console.warn("[Assets] Retrying missing assets:",a),await n(a)),console.log("[Assets] Ready. Cached objects:",Array.from(this.instanceCache.keys()))})(),this.readyPromise}resetScene(){this.instanceCache.clear(),this.readyPromise=null}async reloadObject(e){let t=this.registry.get(e);if(t){let n=await ue.create(e,t,this.app);this.instanceCache.set(e,n)}}get(e){return this.instanceCache.get(e)}},ma=new Di,ba=new Proxy(ma,{get(i,e){if(e in i&&typeof i[e]=="function")return i[e].bind(i);if(i.get(e))return i.get(e)}});function ya(i,e){ma.init(i,e)}ht();var ai=class extends tt{async init(){Ht(this.context.config,this.context.app),await Te.ready(),console.log("[AssetSystem] All assets preloaded and ready")}async onStart(){}onConfigUpdate(){console.log("[AssetSystem] Config updated - systems will refresh textures")}};function va(i){var o,l,d;let{setState:e,updateLabelAlpha:t,updateHandAlpha:n,config:a,states:s}=i,r=((l=(o=a.engine)==null?void 0:o.runtime)==null?void 0:l.timeline)||{};e(s.showHook),setTimeout(()=>{t(1),n(1),e(s.waitInput),console.log("[GAME] \u23F3 Game ready for user input - tutorial shown")},(d=r.tutorial_delay_ms)!=null?d:1500)}0&&(module.exports={AssetCache,AssetLoader,AssetSystem,AssetTextures,Assets,BaseSystem,GameEngine,GameObject,GameObjectManager,ObjectFactory,Renderer,RuntimeObjectRegistry,Transform,applyScreenAnchor,basePixi,clearResponsiveElements,createPixiBase,getRegisteredFontIds,globalResponsiveMultipliers,initAssetTextures,initAssets,layout,playLottieOverlay,registerFont,registerType,resolveAnchorVec2,resolveFont,resolveFontWeight,resolveScreenAnchorPoint,resolveScreenRatioPoint,runInitSequence,setLottieInstance,spawnSceneFromConfig,updateScreenState});
255
+ `,e.appendChild(v);let w;try{w=u.loadAnimation({container:v,renderer:s.renderer||"svg",loop:(Ce=s.loop)!=null?Ce:!1,autoplay:(Ae=s.autoplay)!=null?Ae:!0,animationData:l})}catch(V){return v.parentNode&&v.parentNode.removeChild(v),console.warn(`[LottieOverlay] Failed to start animation: ${i}`,V),null}s.speed!==void 0&&w.setSpeed(s.speed);let y=()=>{w.destroy(),v.parentNode&&v.parentNode.removeChild(v)};return s.loop||w.addEventListener("complete",y),{animation:w,cleanup:y}}Ht();vi();var ai=class{constructor(e,t,n){this.systems=[];this.totalTime=0;this.context=null;this.root=e,this.config=t,this.destinationUrl=n}async createApp(e){if(this.context)return{app:this.app,gameObjectManager:this.gameObjectManager};let{app:t,stage:n}=await ii(this.root,{background:e.background_color,text:e.text_color,primary:e.cta_background,cta_text:e.cta_text});this.app=t,this.stage=n,this.gameObjectManager=new it(this.config),this.stage.eventMode="passive",this.stage.interactive=!1,this.stage.interactiveChildren=!0,this.stage.sortableChildren=!0,this.context={app:this.app,stage:this.stage,config:this.config,gameObjectManager:this.gameObjectManager,destinationUrl:this.destinationUrl,root:this.root,engine:this};for(let a of this.systems)a.setContext(this.context);return{app:this.app,gameObjectManager:this.gameObjectManager}}async initSystems(){if(!this.context)throw new Error("[GameEngine] createApp() must be called before initSystems()");for(let e of this.systems)e.init&&await e.init()}async init(e){return await this.createApp(e),await this.initSystems(),{app:this.app,gameObjectManager:this.gameObjectManager}}registerSystems(e){this.systems.push(...e)}async start(){for(let e of this.systems)e.onStart&&await e.onStart();this.app.ticker.add(this.update.bind(this)),window.addEventListener("handler-preview:screen",e=>{let{width:t,height:n}=e.detail;this.resize(t,n)})}update(e){let t=e.deltaTime/60;this.totalTime+=t;for(let n of this.systems)n.update&&n.update(t,this.totalTime)}resize(e,t){for(let n of this.systems)n.onResize&&n.onResize(e,t)}updateConfig(e){this.config=e;for(let t of this.systems)t.context.config=e,t.onConfigUpdate&&t.onConfigUpdate(e)}destroy(){for(let e of this.systems)e.onDestroy&&e.onDestroy();this.app.ticker.remove(this.update.bind(this)),this.app.destroy(!0,{children:!0,texture:!1})}getApp(){return this.app}getGameObjectManager(){return this.gameObjectManager}getTotalTime(){return this.totalTime}getSystem(e){let t=this.systems.find(n=>n instanceof e);if(!t)throw new Error(`System ${e.name} not found!`);return t}};var at=class{setContext(e){this.context=e}};var st=class{constructor(){this.config=null}init(e){this.config=e}get(e){if(!this.config)throw new Error("RuntimeObjectRegistry not initialized. Call init() first.");return this.config.objects.get(e)}getAllIds(){if(!this.config)throw new Error("RuntimeObjectRegistry not initialized. Call init() first.");return Array.from(this.config.objects.keys())}has(e){return this.config?this.config.objects.has(e):!1}};var Pa=ci(require("pixi.js"),1),Ma=Pa;typeof window!="undefined"&&(window.__basePixi=Pa);vt();var ve=require("pixi.js");vt();var Ia=i=>i*Math.PI/180;function rr(i,e){var r,o,c,l,u;let t=e.ui;if(!(t!=null&&t.text))return null;let n="#ffffff";(r=e.render)!=null&&r.tint&&(n=e.render.tint);let a=new ve.TextStyle({fontFamily:(o=t.font)!=null?o:"Arial",fontSize:(c=t.fontSize)!=null?c:16,fill:n,align:(l=t.align)!=null?l:"center",letterSpacing:(u=t.letterSpacing)!=null?u:0}),s=new ve.Text({text:t.text,style:a});return s.label=i,s}function ja(i){var u,d,p,g,m,f,C,b,h,v;let{stage:e,mainContainer:t,activeConfig:n,gameObjectManager:a,allowList:s,denyList:r}=i,o={},c={},l={};t.sortableChildren=!0;for(let[w,y]of n.objects.entries()){if(r!=null&&r.has(w)||s&&!s.has(w)||(y==null?void 0:y.enabled)===!1)continue;let M=(d=(u=y==null?void 0:y.render)==null?void 0:u.asset)==null?void 0:d.path,_=(g=(p=y==null?void 0:y.render)==null?void 0:p.asset)==null?void 0:g.type,G=!!(M&&_==="image"),z=!!((m=y==null?void 0:y.ui)!=null&&m.text),N=z?(f=y==null?void 0:y.ui)==null?void 0:f.renderMode:void 0,$;if(N==="png"&&G?$="png":N==="text"&&z?$="text":G?$="png":z?$="text":$="skip",$!=="skip"){if($==="text"){let L=rr(w,y);if(!L)continue;let S=y.render;L.alpha=typeof(S==null?void 0:S.alpha)=="number"?S.alpha:1,L.visible=(S==null?void 0:S.visible)!==!1,L.zIndex=typeof(S==null?void 0:S.z_index)=="number"?S.z_index:0,S!=null&&S.anchor&&typeof S.anchor.x=="number"&&typeof S.anchor.y=="number"?L.anchor.set(S.anchor.x,S.anchor.y):L.anchor.set(.5,.5);let E=y.transform,A=(E==null?void 0:E.position)||(E==null?void 0:E.offset);A&&L.position.set((C=A.x)!=null?C:0,(b=A.y)!=null?b:0);let T=typeof(E==null?void 0:E.scale)=="number"?E.scale:1;L.scale.set(T,T);let q=typeof(E==null?void 0:E.rotation)=="number"?E.rotation:0;L.rotation=Ia(q),L.parent||t.addChild(L);try{a.create(w,L)}catch{}o[w]=L,l[w]=L}else if($==="png"){let L=Me[w]||(typeof ve.Texture!="undefined"?ve.Texture.EMPTY:void 0),S=new ve.Sprite(L);S.label=w;let E=y.render;S.alpha=typeof(E==null?void 0:E.alpha)=="number"?E.alpha:1,S.visible=(E==null?void 0:E.visible)!==!1,S.zIndex=typeof(E==null?void 0:E.z_index)=="number"?E.z_index:0,E!=null&&E.anchor&&typeof E.anchor.x=="number"&&typeof E.anchor.y=="number"&&S.anchor.set(E.anchor.x,E.anchor.y);let A=y.transform,T=(A==null?void 0:A.position)||(A==null?void 0:A.offset);T&&S.position.set((h=T.x)!=null?h:0,(v=T.y)!=null?v:0);let q=typeof(A==null?void 0:A.scale)=="number"?A.scale:1;S.scale.set(q,q);let ae=typeof(A==null?void 0:A.rotation)=="number"?A.rotation:0;S.rotation=Ia(ae),S.parent||t.addChild(S);try{a.create(w,S)}catch{}o[w]=S,c[w]=S}}}return t.parent||e.addChild(t),{objects:o,sprites:c,texts:l}}var Fi=class{constructor(){this.instanceCache=new Map;this.readyPromise=null;this.app=null;this.registry=new st}init(e,t){this.registry.init(e),this.app=t}updateConfig(e){this.registry.init(e),this.instanceCache.clear(),this.readyPromise=null}async ready(){this.readyPromise&&await this.readyPromise;let t=this.registry.getAllIds().filter(a=>!this.instanceCache.has(a));if(t.length===0)return;let n=async a=>{a.length&&(console.log("[Assets] Loading objects:",a),await Promise.all(a.map(async s=>{var o;let r=this.registry.get(s);if(!r){console.warn("[Assets] No config found for object:",s);return}try{let c=await me.create(s,r,this.app);this.instanceCache.set(s,c),console.log("[Assets] Loaded object:",s,(o=c==null?void 0:c.constructor)==null?void 0:o.name)}catch(c){console.error("[Assets] Failed to load object:",s,c)}})))};return this.readyPromise=(async()=>{await n(t);let a=this.registry.getAllIds().filter(s=>!this.instanceCache.has(s));a.length>0&&(console.warn("[Assets] Retrying missing assets:",a),await n(a)),console.log("[Assets] Ready. Cached objects:",Array.from(this.instanceCache.keys()))})(),this.readyPromise}resetScene(){this.instanceCache.clear(),this.readyPromise=null}async reloadObject(e){let t=this.registry.get(e);if(t){let n=await me.create(e,t,this.app);this.instanceCache.set(e,n)}}get(e){return this.instanceCache.get(e)}},_a=new Fi,Oa=new Proxy(_a,{get(i,e){if(e in i&&typeof i[e]=="function")return i[e].bind(i);if(i.get(e))return i.get(e)}});function Ra(i,e){_a.init(i,e)}vt();var si=class extends at{async init(){Nt(this.context.config,this.context.app),await Me.ready(),console.log("[AssetSystem] All assets preloaded and ready")}async onStart(){}onConfigUpdate(){console.log("[AssetSystem] Config updated - systems will refresh textures")}};function za(i){var o,c,l;let{setState:e,updateLabelAlpha:t,updateHandAlpha:n,config:a,states:s}=i,r=((c=(o=a.engine)==null?void 0:o.runtime)==null?void 0:c.timeline)||{};e(s.showHook),setTimeout(()=>{t(1),n(1),e(s.waitInput),console.log("[GAME] \u23F3 Game ready for user input - tutorial shown")},(l=r.tutorial_delay_ms)!=null?l:1500)}0&&(module.exports={AssetCache,AssetLoader,AssetSystem,AssetTextures,Assets,BaseSystem,GameEngine,GameObject,GameObjectManager,ObjectFactory,Renderer,RuntimeObjectRegistry,Transform,applyScreenAnchor,basePixi,clearResponsiveElements,createPixiBase,getRegisteredFontIds,globalResponsiveMultipliers,initAssetTextures,initAssets,layout,playLottieOverlay,registerFont,registerType,resolveAnchorVec2,resolveFont,resolveFontWeight,resolveScreenAnchorPoint,resolveScreenRatioPoint,runInitSequence,setLottieInstance,spawnSceneFromConfig,updateScreenState});