handler-playable-sdk 0.4.71 → 0.5.2
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.
- package/dist/{chunk-PPPD3Q3N.js → chunk-4EJGJBZO.js} +171 -75
- package/dist/cli/brand-dna.mjs +1 -1
- package/dist/cli/canva-import.mjs +1 -1
- package/dist/cli/cleanup-assets.mjs +1 -1
- package/dist/cli/fix-scales.mjs +1 -1
- package/dist/cli/index.js +1 -1
- package/dist/cli/screen-helper.mjs +1 -1
- package/dist/cli/setup-library.mjs +1 -1
- package/dist/cli/student-helper.mjs +1 -1
- package/dist/cli/sync-screens.mjs +1 -1
- package/dist/cli/validate-assets.mjs +1 -1
- package/dist/cli/validate.mjs +1 -1
- package/dist/index.cjs +158 -62
- package/dist/index.css +488 -0
- package/dist/index.d.cts +6 -0
- package/dist/index.d.ts +6 -0
- package/dist/index.js +1 -1
- package/dist/pixi/index.cjs +6 -6
- package/dist/pixi/index.css +488 -0
- package/dist/pixi/index.js +1 -1
- package/dist/three/index.cjs +25 -25
- package/dist/three/index.css +488 -0
- package/dist/three/index.js +1 -1
- package/package.json +1 -1
package/dist/three/index.cjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
"use strict";var fs=Object.create;var ft=Object.defineProperty;var ms=Object.getOwnPropertyDescriptor;var bs=Object.getOwnPropertyNames;var ys=Object.getPrototypeOf,vs=Object.prototype.hasOwnProperty;var ne=(t,e)=>()=>(t&&(e=t(t=0)),e);var sa=(t,e)=>{for(var i in e)ft(t,i,{get:e[i],enumerable:!0})},oa=(t,e,i,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let a of bs(e))!vs.call(t,a)&&a!==i&&ft(t,a,{get:()=>e[a],enumerable:!(n=ms(e,a))||n.enumerable});return t};var ae=(t,e,i)=>(i=t!=null?fs(ys(t)):{},oa(e||!t||!t.__esModule?ft(i,"default",{value:t,enumerable:!0}):i,t)),xs=t=>oa(ft({},"__esModule",{value:!0}),t);var re,ii=ne(()=>{"use strict";re=class{static get(e){var i;return(i=this.store.get(e))==null?void 0:i.data}static set(e,i){this.store.set(e,{data:i})}static has(e){return this.store.has(e)}static clear(){this.store.clear()}};re.store=new Map});function _s(){var t,e;try{let i=typeof window!="undefined"&&(document.querySelector('script[src*="inline-assets.js"]')||((e=(t=document.querySelector("script"))==null?void 0:t.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!!(i&&!n)}catch{return!1}}async function ks(){try{if(typeof window!="undefined"){let t=await fetch("./build-settings.json");if(t.ok){let e=await t.json();return console.log("[AssetLoader] Loaded build settings:",e),e}}}catch{}return null}function Ms(){try{if(typeof window!="undefined"){let t=new XMLHttpRequest;if(t.open("GET","./build-settings.json",!1),t.send(),t.status===200&&t.responseText){let e=JSON.parse(t.responseText);return console.log("[AssetLoader] Loaded build settings (sync):",e),e}}}catch{}return null}async function Ps(){if(console.log(`[AssetLoader] getInlineAssets() called - Effective mode: ${C}`),Object.keys(se).length>0)return console.log("[AssetLoader] Returning cached inline assets:",Object.keys(se)),se;if(typeof window!="undefined"&&window.INLINE_ASSETS)return console.log("[AssetLoader] Using pre-loaded INLINE_ASSETS from window:",Object.keys(window.INLINE_ASSETS)),se={...window.INLINE_ASSETS},se;if(!(C==="publish"&&K!==!1))return console.log("[AssetLoader] Inline assets disabled for this build mode."),se;if(!ni){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),ni=(async()=>{try{try{let r=await import(e+"?t="+Date.now());if(r.INLINE_ASSETS)return console.log("[AssetLoader] Loaded INLINE_ASSETS via ES module:",Object.keys(r.INLINE_ASSETS)),r.INLINE_ASSETS}catch(r){console.warn("[AssetLoader] ES module import failed, trying text parse:",r)}let i=await fetch(e);if(!i.ok)throw new Error(`HTTP ${i.status}: ${i.statusText}`);let n=await i.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 r=a[1];console.log("[AssetLoader] Found INLINE_ASSETS export, parsing...");let s=new Function("return "+r)();return console.log("[AssetLoader] Parsed inline assets:",Object.keys(s)),s}catch(r){return console.warn("[AssetLoader] Failed to parse inline assets:",r),{}}else return console.warn("[AssetLoader] INLINE_ASSETS export not found in response"),console.log("[AssetLoader] JS code preview:",n.substring(0,500)),{}}catch(i){return console.warn("[AssetLoader] Failed to load inline assets:",i),{}}})()}return se=await ni,console.log("[AssetLoader] Final inline assets cache:",Object.keys(se)),se}function ai(t){return t===null||typeof t!="object"||(Object.freeze(t),Object.values(t).forEach(e=>ai(e))),t}function Is(t=64,e=64,i=16711680){let n=document.createElement("canvas");n.width=t,n.height=e;let a=n.getContext("2d");return a.fillStyle=`#${i.toString(16).padStart(6,"0")}`,a.fillRect(0,0,t,e),a.strokeStyle="#000",a.strokeRect(0,0,t,e),a.fillStyle="#fff",a.font="10px sans-serif",a.textAlign="center",a.fillText("MISSING",t/2,e/2),oe.Texture.from(n)}function ri(t,e){Na.set(t,e)}var oe,$a,Fa,Ee,C,K,he,se,ni,Na,Se,vt=ne(()=>{"use strict";oe=require("pixi.js");ii();$a=typeof __BUILD_MODE__!="undefined"?__BUILD_MODE__:"undefined",Fa=_s(),Ee=typeof window!="undefined"?window.__BUILD_SETTINGS__:null,C=Fa?"publish":$a,K=Ee==null?void 0:Ee.assetsInlined;Ee!=null&&Ee.buildMode&&(C=Ee.buildMode,console.log(`[AssetLoader] Build mode overridden by inline settings: ${C}`));he=Ms();he!=null&&he.buildMode&&(C=he.buildMode,console.log(`[AssetLoader] Build mode overridden by sync settings: ${C}`));(he==null?void 0:he.assetsInlined)!==void 0&&(K=he.assetsInlined);ks().then(t=>{t!=null&&t.buildMode&&t.buildMode!==C&&(C=t.buildMode,console.log(`[AssetLoader] Build mode overridden by settings: ${C}`)),(t==null?void 0:t.assetsInlined)!==void 0&&(K=t.assetsInlined)}).catch(()=>{});console.log(`[AssetLoader] MODULE LOADED - Compile: ${$a}, Runtime: ${Fa?"publish":"dev"}, Effective: ${C}`);se={},ni=null;Na=new Map;Se=class{static async load(e,i,n,a){let r=`${e}:${i.path}`,s=re.get(r);if(s!==void 0)return s;console.log(`[AssetLoader] Loading asset: ${e}, type: ${i.type}, Effective mode: ${C}`),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 Ps(),l=o[e];if(!l&&a&&(l=o[a],l&&console.log(`[AssetLoader] Found inline data for ${e} using configId: ${a}`)),!l&&i.path){let c=i.path.split("/");if(c.length>=2){let g=c[c.length-1].split(".")[0];o[g]&&(l=o[g],console.log(`[AssetLoader] Found inline data for ${e} using assetName: ${g}`))}}if(console.log("[AssetLoader] Inline data for",e,":",l?"FOUND":"NOT FOUND"),C==="publish"&&K!==!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: ${i.path}`);let p=Na.get(i.type);if(p)try{let c=await p(i.path,l,e,n);return re.set(r,c),c}catch(c){return this.handleFailure(e,i.type,c)}try{let c;switch(i.type){case"image":c=await this.loadImage(i.path,l);break;case"json":c=await this.loadJSON(i.path,l),c=ai(c);break;default:throw new Error(`Unknown asset type: ${i.type}`)}return re.set(r,c),c}catch(c){return this.handleFailure(e,i.type,c)}}static async loadImage(e,i){let n=C==="publish",a=n&&K!==!1;if(console.log(`[AssetLoader] loadImage - Effective mode: ${C}, isPublishMode: ${n}, inlineData: ${i?"EXISTS":"MISSING"}`),a){if(console.log("[AssetLoader] PUBLISH MODE ACTIVATED - inline assets are MANDATORY"),!i)throw new Error(`[AssetLoader] Publish mode: inline asset required but not found for object. Path: ${e}`);if(typeof i!="string"||!i.startsWith("data:"))throw new Error(`[AssetLoader] Publish mode: inline asset must be data URI string, got: ${typeof i}`);try{return await oe.Assets.load(i)}catch(r){throw console.error("[AssetLoader] Failed to load texture from data URI:",r),r}}if(i&&typeof i=="string"&&i.startsWith("data:"))try{return await oe.Assets.load(i)}catch(r){return console.error("[AssetLoader] Failed to load texture from data URI, falling back to path:",r),await oe.Assets.load(e)}return await oe.Assets.load(e)}static async loadJSON(e,i){let n=C==="publish",a=n&&K!==!1;if(console.log(`[AssetLoader] loadJSON - Effective mode: ${C}, isPublishMode: ${n}, inlineData: ${i?"EXISTS":"MISSING"}`),a){if(console.log("[AssetLoader] PUBLISH MODE ACTIVATED - inline assets are MANDATORY"),!i)throw new Error(`[AssetLoader] Publish mode: inline asset required but not found for path: ${e}`);if(typeof i=="object"&&i!==null)return i;if(typeof i=="string"&&i.startsWith("data:")){let s=atob(i.split(",")[1]);return JSON.parse(s)}return JSON.parse(i)}if(i){if(typeof i=="object"&&i!==null)return i;if(typeof i=="string"&&i.startsWith("data:")){let s=atob(i.split(",")[1]);return JSON.parse(s)}return JSON.parse(i)}let r=await fetch(e);if(!r.ok)throw new Error(`JSON fetch failed: ${e}`);return r.json()}static handleFailure(e,i,n){if(C==="dev"){let r=i==="image"?Is():ai({__placeholder:!0,type:i});return re.set(e+":"+((n==null?void 0:n.path)||"missing"),r),r}throw n}};ri("image",async(t,e)=>{let i=C==="publish",n=i&&K!==!1,a=C==="brand",r=i&&K===!1;if(console.log(`[AssetLoader] registerType('image') - Effective mode: ${C}, isPublishMode: ${i}, 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: ${t}`);if(typeof e!="string"||!e.startsWith("data:"))throw new Error(`[AssetLoader] Publish mode: inline asset must be data URI string, got: ${typeof e}`);return oe.Assets.load(e)}let s=t;return(a||r)&&t&&!t.startsWith("assets/")&&(typeof window!="undefined"&&!document.querySelector('link[href*="assets/"], script[src*="assets/"]')&&!document.querySelector('link[href*="configs/"], script[src*="configs/"]')?(s=t,console.log(`[AssetLoader] BRAND MODE: flattened build, using path "${t}" as-is`)):(s=`assets/${t}`,console.log(`[AssetLoader] BRAND MODE: transformed path "${t}" -> "${s}"`))),oe.Assets.load(e||s)});ri("json",async(t,e)=>{let i=C==="publish",n=i&&K!==!1,a=C==="brand",r=i&&K===!1;if(console.log(`[AssetLoader] registerType('json') - Effective mode: ${C}, isPublishMode: ${i}, 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: ${t}`);return typeof e=="object"&&e!==null?e:typeof e=="string"&&e.startsWith("data:")?JSON.parse(atob(e.split(",")[1])):JSON.parse(e)}let s=t;if((a||r)&&t&&!t.startsWith("assets/")&&(typeof window!="undefined"&&!document.querySelector('link[href*="assets/"], script[src*="assets/"]')&&!document.querySelector('link[href*="configs/"], script[src*="configs/"]')?(s=t,console.log(`[AssetLoader] BRAND MODE: flattened build, using path "${t}" as-is`)):(s=`assets/${t}`,console.log(`[AssetLoader] BRAND MODE: transformed path "${t}" -> "${s}"`))),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(s);if(!o.ok)throw new Error(`JSON fetch failed: ${t}`);return o.json()})});var oi,Hs,xt,Ke=ne(()=>{"use strict";vt();oi=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,i){if(this.config===e&&this.app===i&&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=i,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,i=this.app;return this.readyPromise=(async()=>{var s;console.log("[AssetTextures] Loading all assets...");let n=new Set(["background_loading_1"]),a=[],r=[];for(let[o,l]of e.objects.entries()){let d=(s=l.render)==null?void 0:s.asset;if(!d)continue;let p=async()=>{var c;try{let g=(c=l.identity)==null?void 0:c.id;console.log(`[AssetTextures] Loading ${d.type}: ${o} (${g})`);let u=await Se.load(o,d,i,g);this.textures.set(o,u),console.log(`[AssetTextures] \u2713 Loaded: ${o}`)}catch(g){console.error(`[AssetTextures] \u2717 Failed to load: ${o}`,g)}finally{this.attempted.add(o);try{for(let g of Array.from(this.waiters))g()}catch{}}};n.has(o)?a.push(p()):r.push(p())}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(r),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,i={}){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,p,c;try{let g=(p=(d=(l=this.config)==null?void 0:l.objects)==null?void 0:d.get)==null?void 0:p.call(d,o);return!!((c=g==null?void 0:g.render)!=null&&c.asset)}catch{return!1}});if(a.length===0)return;this.ready().catch(()=>{});let r=()=>a.every(o=>this.textures.has(o)||this.attempted.has(o));if(r())return;let s=typeof i.timeoutMs=="number"?i.timeoutMs:15e3;await new Promise(o=>{let l=!1,d=()=>{l||r()&&(l=!0,this.waiters.delete(d),o())};this.waiters.add(d),d(),s>0&&setTimeout(()=>{l||(l=!0,this.waiters.delete(d),console.warn("[AssetTextures] waitFor timed out; continuing",{ids:a}),o())},s)})}get(e){return this.textures.get(e)}set(e,i){this.textures.set(e,i),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())}},Hs=new oi,xt=new Proxy(Hs,{get(t,e){return e in t&&typeof t[e]=="function"?t[e].bind(t):t.get(e)},set(t,e,i){return t.set(e,i),!0}})});var so,fe=ne(()=>{"use strict";so="handler_preview_override_mode";if(typeof window!="undefined"){let t=window.localStorage.getItem(so);window.__enableConfigOverrides=t===null?!0:t==="true"}});var Wa,Te,Ec,pi=ne(()=>{"use strict";fe();Wa=null,Te="dev";if(typeof window!="undefined"){let t=window.__BUILD_SETTINGS__;if(t!=null&&t.buildMode)Wa=t,Te=t.buildMode,console.log("[CONFIG] Loaded inline build settings:",t,"buildMode:",Te);else try{let e=new XMLHttpRequest;if(e.open("GET","./build-settings.json",!1),e.send(),e.status===200&&e.responseText){let i=JSON.parse(e.responseText);Wa=i,Te=i.buildMode||"dev",console.log("[CONFIG] Loaded build settings:",i,"buildMode:",Te)}else console.log("[CONFIG] No build-settings.json found, using default buildMode:",Te)}catch(e){console.log("[CONFIG] Failed to load build-settings.json:",e instanceof Error?e.message:String(e))}}console.log("[CONFIG] Final buildMode:",Te);Ec=Te==="dev"||typeof window!="undefined"&&window.location.search.includes("hot-reload")});var ui=ne(()=>{"use strict"});var Ya=ne(()=>{"use strict";ui();pi()});var gi=ne(()=>{"use strict";pi();ui();Ya()});var tr={};sa(tr,{AssetEditorModal:()=>xi});var xi,wi=ne(()=>{"use strict";xi=class{constructor(){this.modal=null;this.currentObjectId=null;this.currentPath=null;this.currentAsset="";this.onApplyCallback=null}show(e,i,n,a){this.currentObjectId=e,this.currentPath=i,this.currentAsset=n,this.onApplyCallback=a,this.createModal(e,n),document.body.appendChild(this.modal),this.attachModalListeners()}createModal(e,i){let n=document.createElement("div");n.className="asset-editor-modal",n.innerHTML=`
|
|
1
|
+
"use strict";var mo=Object.create;var ft=Object.defineProperty;var bo=Object.getOwnPropertyDescriptor;var yo=Object.getOwnPropertyNames;var vo=Object.getPrototypeOf,wo=Object.prototype.hasOwnProperty;var ne=(t,e)=>()=>(t&&(e=t(t=0)),e);var oa=(t,e)=>{for(var i in e)ft(t,i,{get:e[i],enumerable:!0})},sa=(t,e,i,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let a of yo(e))!wo.call(t,a)&&a!==i&&ft(t,a,{get:()=>e[a],enumerable:!(n=bo(e,a))||n.enumerable});return t};var ae=(t,e,i)=>(i=t!=null?mo(vo(t)):{},sa(e||!t||!t.__esModule?ft(i,"default",{value:t,enumerable:!0}):i,t)),xo=t=>sa(ft({},"__esModule",{value:!0}),t);var re,ii=ne(()=>{"use strict";re=class{static get(e){var i;return(i=this.store.get(e))==null?void 0:i.data}static set(e,i){this.store.set(e,{data:i})}static has(e){return this.store.has(e)}static clear(){this.store.clear()}};re.store=new Map});function ko(){var t,e;try{let i=typeof window!="undefined"&&(document.querySelector('script[src*="inline-assets.js"]')||((e=(t=document.querySelector("script"))==null?void 0:t.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!!(i&&!n)}catch{return!1}}async function Mo(){try{if(typeof window!="undefined"){let t=await fetch("./build-settings.json");if(t.ok){let e=await t.json();return console.log("[AssetLoader] Loaded build settings:",e),e}}}catch{}return null}function Po(){try{if(typeof window!="undefined"){let t=new XMLHttpRequest;if(t.open("GET","./build-settings.json",!1),t.send(),t.status===200&&t.responseText){let e=JSON.parse(t.responseText);return console.log("[AssetLoader] Loaded build settings (sync):",e),e}}}catch{}return null}async function Io(){if(console.log(`[AssetLoader] getInlineAssets() called - Effective mode: ${C}`),Object.keys(oe).length>0)return console.log("[AssetLoader] Returning cached inline assets:",Object.keys(oe)),oe;if(typeof window!="undefined"&&window.INLINE_ASSETS)return console.log("[AssetLoader] Using pre-loaded INLINE_ASSETS from window:",Object.keys(window.INLINE_ASSETS)),oe={...window.INLINE_ASSETS},oe;if(!(C==="publish"&&K!==!1))return console.log("[AssetLoader] Inline assets disabled for this build mode."),oe;if(!ni){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),ni=(async()=>{try{try{let r=await import(e+"?t="+Date.now());if(r.INLINE_ASSETS)return console.log("[AssetLoader] Loaded INLINE_ASSETS via ES module:",Object.keys(r.INLINE_ASSETS)),r.INLINE_ASSETS}catch(r){console.warn("[AssetLoader] ES module import failed, trying text parse:",r)}let i=await fetch(e);if(!i.ok)throw new Error(`HTTP ${i.status}: ${i.statusText}`);let n=await i.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 r=a[1];console.log("[AssetLoader] Found INLINE_ASSETS export, parsing...");let o=new Function("return "+r)();return console.log("[AssetLoader] Parsed inline assets:",Object.keys(o)),o}catch(r){return console.warn("[AssetLoader] Failed to parse inline assets:",r),{}}else return console.warn("[AssetLoader] INLINE_ASSETS export not found in response"),console.log("[AssetLoader] JS code preview:",n.substring(0,500)),{}}catch(i){return console.warn("[AssetLoader] Failed to load inline assets:",i),{}}})()}return oe=await ni,console.log("[AssetLoader] Final inline assets cache:",Object.keys(oe)),oe}function ai(t){return t===null||typeof t!="object"||(Object.freeze(t),Object.values(t).forEach(e=>ai(e))),t}function Oo(t=64,e=64,i=16711680){let n=document.createElement("canvas");n.width=t,n.height=e;let a=n.getContext("2d");return a.fillStyle=`#${i.toString(16).padStart(6,"0")}`,a.fillRect(0,0,t,e),a.strokeStyle="#000",a.strokeRect(0,0,t,e),a.fillStyle="#fff",a.font="10px sans-serif",a.textAlign="center",a.fillText("MISSING",t/2,e/2),se.Texture.from(n)}function ri(t,e){Na.set(t,e)}var se,Ha,Fa,Ee,C,K,he,oe,ni,Na,Se,vt=ne(()=>{"use strict";se=require("pixi.js");ii();Ha=typeof __BUILD_MODE__!="undefined"?__BUILD_MODE__:"undefined",Fa=ko(),Ee=typeof window!="undefined"?window.__BUILD_SETTINGS__:null,C=Fa?"publish":Ha,K=Ee==null?void 0:Ee.assetsInlined;Ee!=null&&Ee.buildMode&&(C=Ee.buildMode,console.log(`[AssetLoader] Build mode overridden by inline settings: ${C}`));he=Po();he!=null&&he.buildMode&&(C=he.buildMode,console.log(`[AssetLoader] Build mode overridden by sync settings: ${C}`));(he==null?void 0:he.assetsInlined)!==void 0&&(K=he.assetsInlined);Mo().then(t=>{t!=null&&t.buildMode&&t.buildMode!==C&&(C=t.buildMode,console.log(`[AssetLoader] Build mode overridden by settings: ${C}`)),(t==null?void 0:t.assetsInlined)!==void 0&&(K=t.assetsInlined)}).catch(()=>{});console.log(`[AssetLoader] MODULE LOADED - Compile: ${Ha}, Runtime: ${Fa?"publish":"dev"}, Effective: ${C}`);oe={},ni=null;Na=new Map;Se=class{static async load(e,i,n,a){let r=`${e}:${i.path}`,o=re.get(r);if(o!==void 0)return o;console.log(`[AssetLoader] Loading asset: ${e}, type: ${i.type}, Effective mode: ${C}`),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 s=await Io(),l=s[e];if(!l&&a&&(l=s[a],l&&console.log(`[AssetLoader] Found inline data for ${e} using configId: ${a}`)),!l&&i.path){let c=i.path.split("/");if(c.length>=2){let g=c[c.length-1].split(".")[0];s[g]&&(l=s[g],console.log(`[AssetLoader] Found inline data for ${e} using assetName: ${g}`))}}if(console.log("[AssetLoader] Inline data for",e,":",l?"FOUND":"NOT FOUND"),C==="publish"&&K!==!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: ${i.path}`);let p=Na.get(i.type);if(p)try{let c=await p(i.path,l,e,n);return re.set(r,c),c}catch(c){return this.handleFailure(e,i.type,c)}try{let c;switch(i.type){case"image":c=await this.loadImage(i.path,l);break;case"json":c=await this.loadJSON(i.path,l),c=ai(c);break;default:throw new Error(`Unknown asset type: ${i.type}`)}return re.set(r,c),c}catch(c){return this.handleFailure(e,i.type,c)}}static async loadImage(e,i){let n=C==="publish",a=n&&K!==!1;if(console.log(`[AssetLoader] loadImage - Effective mode: ${C}, isPublishMode: ${n}, inlineData: ${i?"EXISTS":"MISSING"}`),a){if(console.log("[AssetLoader] PUBLISH MODE ACTIVATED - inline assets are MANDATORY"),!i)throw new Error(`[AssetLoader] Publish mode: inline asset required but not found for object. Path: ${e}`);if(typeof i!="string"||!i.startsWith("data:"))throw new Error(`[AssetLoader] Publish mode: inline asset must be data URI string, got: ${typeof i}`);try{return await se.Assets.load(i)}catch(r){throw console.error("[AssetLoader] Failed to load texture from data URI:",r),r}}if(i&&typeof i=="string"&&i.startsWith("data:"))try{return await se.Assets.load(i)}catch(r){return console.error("[AssetLoader] Failed to load texture from data URI, falling back to path:",r),await se.Assets.load(e)}return await se.Assets.load(e)}static async loadJSON(e,i){let n=C==="publish",a=n&&K!==!1;if(console.log(`[AssetLoader] loadJSON - Effective mode: ${C}, isPublishMode: ${n}, inlineData: ${i?"EXISTS":"MISSING"}`),a){if(console.log("[AssetLoader] PUBLISH MODE ACTIVATED - inline assets are MANDATORY"),!i)throw new Error(`[AssetLoader] Publish mode: inline asset required but not found for path: ${e}`);if(typeof i=="object"&&i!==null)return i;if(typeof i=="string"&&i.startsWith("data:")){let o=atob(i.split(",")[1]);return JSON.parse(o)}return JSON.parse(i)}if(i){if(typeof i=="object"&&i!==null)return i;if(typeof i=="string"&&i.startsWith("data:")){let o=atob(i.split(",")[1]);return JSON.parse(o)}return JSON.parse(i)}let r=await fetch(e);if(!r.ok)throw new Error(`JSON fetch failed: ${e}`);return r.json()}static handleFailure(e,i,n){if(C==="dev"){let r=i==="image"?Oo():ai({__placeholder:!0,type:i});return re.set(e+":"+((n==null?void 0:n.path)||"missing"),r),r}throw n}};ri("image",async(t,e)=>{let i=C==="publish",n=i&&K!==!1,a=C==="brand",r=i&&K===!1;if(console.log(`[AssetLoader] registerType('image') - Effective mode: ${C}, isPublishMode: ${i}, 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: ${t}`);if(typeof e!="string"||!e.startsWith("data:"))throw new Error(`[AssetLoader] Publish mode: inline asset must be data URI string, got: ${typeof e}`);return se.Assets.load(e)}let o=t;return(a||r)&&t&&!t.startsWith("assets/")&&(typeof window!="undefined"&&!document.querySelector('link[href*="assets/"], script[src*="assets/"]')&&!document.querySelector('link[href*="configs/"], script[src*="configs/"]')?(o=t,console.log(`[AssetLoader] BRAND MODE: flattened build, using path "${t}" as-is`)):(o=`assets/${t}`,console.log(`[AssetLoader] BRAND MODE: transformed path "${t}" -> "${o}"`))),se.Assets.load(e||o)});ri("json",async(t,e)=>{let i=C==="publish",n=i&&K!==!1,a=C==="brand",r=i&&K===!1;if(console.log(`[AssetLoader] registerType('json') - Effective mode: ${C}, isPublishMode: ${i}, 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: ${t}`);return typeof e=="object"&&e!==null?e:typeof e=="string"&&e.startsWith("data:")?JSON.parse(atob(e.split(",")[1])):JSON.parse(e)}let o=t;if((a||r)&&t&&!t.startsWith("assets/")&&(typeof window!="undefined"&&!document.querySelector('link[href*="assets/"], script[src*="assets/"]')&&!document.querySelector('link[href*="configs/"], script[src*="configs/"]')?(o=t,console.log(`[AssetLoader] BRAND MODE: flattened build, using path "${t}" as-is`)):(o=`assets/${t}`,console.log(`[AssetLoader] BRAND MODE: transformed path "${t}" -> "${o}"`))),e)return typeof e=="object"&&e!==null?e:typeof e=="string"&&e.startsWith("data:")?JSON.parse(atob(e.split(",")[1])):JSON.parse(e);let s=await fetch(o);if(!s.ok)throw new Error(`JSON fetch failed: ${t}`);return s.json()})});var si,Ho,wt,Ke=ne(()=>{"use strict";vt();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,i){if(this.config===e&&this.app===i&&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=i,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,i=this.app;return this.readyPromise=(async()=>{var o;console.log("[AssetTextures] Loading all assets...");let n=new Set(["background_loading_1"]),a=[],r=[];for(let[s,l]of e.objects.entries()){let d=(o=l.render)==null?void 0:o.asset;if(!d)continue;let p=async()=>{var c;try{let g=(c=l.identity)==null?void 0:c.id;console.log(`[AssetTextures] Loading ${d.type}: ${s} (${g})`);let u=await Se.load(s,d,i,g);this.textures.set(s,u),console.log(`[AssetTextures] \u2713 Loaded: ${s}`)}catch(g){console.error(`[AssetTextures] \u2717 Failed to load: ${s}`,g)}finally{this.attempted.add(s);try{for(let g of Array.from(this.waiters))g()}catch{}}};n.has(s)?a.push(p()):r.push(p())}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(r),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,i={}){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(s=>typeof s=="string"&&s))).filter(s=>{var l,d,p,c;try{let g=(p=(d=(l=this.config)==null?void 0:l.objects)==null?void 0:d.get)==null?void 0:p.call(d,s);return!!((c=g==null?void 0:g.render)!=null&&c.asset)}catch{return!1}});if(a.length===0)return;this.ready().catch(()=>{});let r=()=>a.every(s=>this.textures.has(s)||this.attempted.has(s));if(r())return;let o=typeof i.timeoutMs=="number"?i.timeoutMs:15e3;await new Promise(s=>{let l=!1,d=()=>{l||r()&&(l=!0,this.waiters.delete(d),s())};this.waiters.add(d),d(),o>0&&setTimeout(()=>{l||(l=!0,this.waiters.delete(d),console.warn("[AssetTextures] waitFor timed out; continuing",{ids:a}),s())},o)})}get(e){return this.textures.get(e)}set(e,i){this.textures.set(e,i),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())}},Ho=new si,wt=new Proxy(Ho,{get(t,e){return e in t&&typeof t[e]=="function"?t[e].bind(t):t.get(e)},set(t,e,i){return t.set(e,i),!0}})});var ss,fe=ne(()=>{"use strict";ss="handler_preview_override_mode";if(typeof window!="undefined"){let t=window.localStorage.getItem(ss);window.__enableConfigOverrides=t===null?!0:t==="true"}});var Wa,Te,Ec,pi=ne(()=>{"use strict";fe();Wa=null,Te="dev";if(typeof window!="undefined"){let t=window.__BUILD_SETTINGS__;if(t!=null&&t.buildMode)Wa=t,Te=t.buildMode,console.log("[CONFIG] Loaded inline build settings:",t,"buildMode:",Te);else try{let e=new XMLHttpRequest;if(e.open("GET","./build-settings.json",!1),e.send(),e.status===200&&e.responseText){let i=JSON.parse(e.responseText);Wa=i,Te=i.buildMode||"dev",console.log("[CONFIG] Loaded build settings:",i,"buildMode:",Te)}else console.log("[CONFIG] No build-settings.json found, using default buildMode:",Te)}catch(e){console.log("[CONFIG] Failed to load build-settings.json:",e instanceof Error?e.message:String(e))}}console.log("[CONFIG] Final buildMode:",Te);Ec=Te==="dev"||typeof window!="undefined"&&window.location.search.includes("hot-reload")});var ui=ne(()=>{"use strict"});var Ya=ne(()=>{"use strict";ui();pi()});var gi=ne(()=>{"use strict";pi();ui();Ya()});var tr={};oa(tr,{AssetEditorModal:()=>wi});var wi,xi=ne(()=>{"use strict";wi=class{constructor(){this.modal=null;this.currentObjectId=null;this.currentPath=null;this.currentAsset="";this.onApplyCallback=null}show(e,i,n,a){this.currentObjectId=e,this.currentPath=i,this.currentAsset=n,this.onApplyCallback=a,this.createModal(e,n),document.body.appendChild(this.modal),this.attachModalListeners()}createModal(e,i){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(s=>{s.addEventListener("click",()=>this.close())}),this.modal.querySelectorAll("[data-tab]").forEach(s=>{s.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 r=this.modal.querySelector("[data-modal-apply]");r==null||r.addEventListener("click",()=>{this.apply()}),this.modal.addEventListener("click",s=>{s.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 i=window.__openAiEditor;if(typeof i!="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}`,i(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 Ko={};sa(Ko,{AspectClass:()=>Oi,GameObject:()=>ot,GameObjectManager:()=>Dt,Renderer:()=>st,ResponsiveUISystem:()=>Ge,Transform:()=>rt,animateHandClick:()=>xr,animatePanelEntrance:()=>vr,createBrushTexture:()=>Lr,createEndGamePanel:()=>yr,createHandTutorial:()=>wr,createThreeBase:()=>fr,createTutorialLabel:()=>Er,getAspectClass:()=>zt,getRegisteredFontIds:()=>br,loadAsset:()=>zi,loadCharacterFrames:()=>Tr,registerFont:()=>mr,resolveFont:()=>Z,resolveFontWeight:()=>Q,updateHandAnimation:()=>Sr});module.exports=xs(Ko);var V=ae(require("three"),1);var ge={};function mt(t,e,i=!1){ge[t]||(ge[t]=[]),ge[t].push({fn:e,once:i})}function Kt(t,e){if(ge[t]){if(!e){delete ge[t];return}ge[t]=ge[t].filter(i=>i.fn!==e)}}function bt(t,...e){let i=ge[t];if(i)for(let n of[...i])n.fn(...e),n.once&&Kt(t,n.fn)}function B(t,e){mt(t,e,!0)}var M=null,W=[],Pe=null;function da(t){M=t,W=[],Pe!==null&&(clearTimeout(Pe),Pe=null)}function pa(){var t,e,i;return{endpoint:(M==null?void 0:M.endpoint)||"",transport:(M==null?void 0:M.transport)||"beacon",batchSize:(t=M==null?void 0:M.batchSize)!=null?t:10,flushIntervalMs:(e=M==null?void 0:M.flushIntervalMs)!=null?e:300,maxQueue:(i=M==null?void 0:M.maxQueue)!=null?i:200,debug:!!(M!=null&&M.debug)}}async function la(t,e,i,n){let a=JSON.stringify(e);if(i==="beacon"&&typeof navigator!="undefined"&&typeof navigator.sendBeacon=="function")try{let r=navigator.sendBeacon(t,new Blob([a],{type:"application/json"}));n&&console.log("[handler.telemetry] beacon",r,e);return}catch(r){n&&console.warn("[handler.telemetry] beacon failed, fallback to fetch",r)}try{await fetch(t,{method:"POST",headers:{"Content-Type":"application/json"},body:a,keepalive:!0}),n&&console.log("[handler.telemetry] fetch",e)}catch(r){n&&console.warn("[handler.telemetry] fetch failed",r)}}function Jt(t,e){let i=pa();if(e&&i.endpoint){if(W.push(t),W.length>i.maxQueue&&(W=W.slice(W.length-i.maxQueue)),W.length>=i.batchSize){ca();return}Pe===null&&(Pe=window.setTimeout(()=>{Pe=null,ca()},i.flushIntervalMs))}}async function ca(){let t=pa();if(!t.endpoint||W.length===0)return;let e=W.splice(0,t.batchSize);await la(t.endpoint,{events:e},t.transport,t.debug),W.length>0&&await la(t.endpoint,{events:W.splice(0,t.batchSize)},t.transport,t.debug)}function ua(t){return Math.max(0,Math.min(1,t))}function ws(t){let e=String(t!=null?t:"power2.out");if(e==="linear")return i=>i;if(e==="sine.inOut")return i=>.5-Math.cos(Math.PI*i)/2;if(e==="power2.out"||e==="easeOutQuad")return i=>1-(1-i)*(1-i);if(e.startsWith("back.out")){let i=e.match(/back\.out\(([\d.]+)\)/),n=i?Number(i[1]):1.8;return a=>1+(n+1)*Math.pow(a-1,3)+n*Math.pow(a-1,2)}return i=>1-(1-i)*(1-i)}function Ve(){return typeof performance!="undefined"&&performance.now?performance.now():Date.now()}function Es(t,e){let i=t==null?void 0:t[e];return typeof i=="number"?i:0}function ga(t,e,i){try{t[e]=i}catch{}}function Ss(t){let e=t==null?void 0:t.scale;if(!e)return null;let i=typeof e.x=="number"?e.x:1,n=typeof e.y=="number"?e.y:1;return{x:i,y:n}}function ha(t,e){let i=t==null?void 0:t.scale;if(i)try{typeof i.set=="function"?i.set(e.x,e.y):(typeof i.x=="number"&&(i.x=e.x),typeof i.y=="number"&&(i.y=e.y))}catch{}}function fa(t,e){let i=Ss(t);if(!i)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:i.x,y:i.y},to:{x:n!=null?n:i.x,y:a!=null?a:i.y}}}function ma(){let t=new Set,e=new WeakMap,i=null,n=()=>{if(i!=null)return;i=requestAnimationFrame(()=>{i=null,o(),t.size>0&&n()})},a=p=>{var g;t.add(p);let c=(g=e.get(p.target))!=null?g:new Set;c.add(p),e.set(p.target,c),n()},r=p=>{t.delete(p);let c=e.get(p.target);c&&(c.delete(p),c.size===0&&e.delete(p.target))},s=p=>{p.killed||(p.killed=!0,r(p))},o=()=>{var c,g;let p=Ve();for(let u of Array.from(t)){if(u.killed||u.paused)continue;let b=p-u.startMs-u.delayMs;if(b<0)continue;let h=u.durationMs>0?b/u.durationMs:1,x=ua(h),v=u.repeat>=0?u.repeat+1:1,y=u.repeat>0?Math.min(Math.floor(h),v-1):0;if(u.repeat>0&&h>=1){let E=h-y;x=ua(E)}let f=u.ease(x);u.yoyo&&y%2===1&&(f=1-f);for(let E of u.props)ga(u.target,E.key,E.from+(E.to-E.from)*f);u.scaleFrom&&u.scaleTo&&ha(u.target,{x:u.scaleFrom.x+(u.scaleTo.x-u.scaleFrom.x)*f,y:u.scaleFrom.y+(u.scaleTo.y-u.scaleFrom.y)*f});try{(c=u.onUpdate)==null||c.call(u)}catch{}if(h>=v){s(u);try{(g=u.onComplete)==null||g.call(u)}catch{}}}},l=(p,c,g)=>{var E;let u=Math.max(0,(typeof c.duration=="number"?c.duration:.5)*1e3),b=Math.max(0,(typeof c.delay=="number"?c.delay:0)*1e3+((E=g==null?void 0:g.delayMsOverride)!=null?E:0)),h=ws(c.ease),x=typeof c.repeat=="number"?Math.max(0,c.repeat|0):0,v=c.yoyo===!0,y=new Set(["duration","delay","ease","repeat","yoyo","onUpdate","onComplete","scale","scaleX","scaleY"]),f=[];for(let S of Object.keys(c)){if(y.has(S))continue;let A=c[S];typeof A=="number"&&f.push({key:S,from:Es(p,S),to:A})}let m=fa(p,c);return{target:p,startMs:Ve(),delayMs:b,durationMs:u,ease:h,props:f,scaleFrom:m.from,scaleTo:m.to,repeat:x,yoyo:v,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(p,c){let g=l(p,c);return a(g),{kill:()=>s(g),pause:()=>{g.paused||(g.paused=!0,g.pauseAtMs=Ve())},resume:()=>{var h;if(!g.paused)return;let u=(h=g.pauseAtMs)!=null?h:Ve(),b=Ve()-u;g.startMs+=b,g.paused=!1,g.pauseAtMs=null},isActive:()=>!g.killed&&!g.paused}},fromTo(p,c,g){return d.set(p,c),d.to(p,g)},set(p,c){if(!p||!c)return;for(let u of Object.keys(c)){let b=c[u];u==="scale"||u==="scaleX"||u==="scaleY"||typeof b=="number"&&ga(p,u,b)}let g=fa(p,c);g.to&&ha(p,g.to)},killTweensOf(p){let c=e.get(p);if(c)for(let g of Array.from(c))s(g)},timeline(p={}){let c=[],g=0,u=!1,b=[],h=y=>{if(typeof y=="number")return Math.max(0,y*1e3);let f=typeof y=="string"?y.trim():"";return f.startsWith("+=")?g+Math.max(0,Number(f.slice(2))*1e3||0):f?Math.max(0,Number(f)*1e3||0):g},x=y=>{c.push(y);let f=Math.max(0,(typeof y.vars.duration=="number"?y.vars.duration:.5)*1e3);g=Math.max(g,y.atMs+f)},v={to(y,f,m){return x({kind:"to",target:y,vars:f,atMs:h(m)}),v},fromTo(y,f,m,E){return x({kind:"fromTo",target:y,vars:m,from:f,atMs:h(E)}),v},play(){var y,f;if(u)return v;u=!0,b=[];for(let m of c)m.kind==="fromTo"&&d.set(m.target,(y=m.from)!=null?y:{}),b.push(d.to(m.target,{...m.vars,delay:m.atMs/1e3+((f=m.vars.delay)!=null?f:0)}));return v},pause(){for(let y of b)y.pause();return v},kill(){for(let y of b)y.kill();b=[],u=!1}};return p.paused||v.play(),v}};return d}function ba(){if(typeof window=="undefined")return;let t=window;if(!t.gsap)try{t.gsap=ma()}catch{}}var ya={name:"handler-playable-sdk",version:"0.4.71",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 && 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 && 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 G=0,Cs=G++,va=G++,xa=G++,wa=G++,Ea=G++,Sa=G++,Aa=G++,Ca=G++,Ta=G++,La=G++,_a=G++,ka=G++,T=Cs;function Ma(){return T===va}function Pa(){return T===xa}function Ia(){return T===wa}function Oa(){return T===Ea}function Ie(){return T===Sa}function Oe(){return T===Aa}function Ra(){return T===Ca}function ja(){return T===Ta}function za(){return T===La}function Zt(){return T===_a}function Qt(){return T===ka}function Da(){let t=typeof AD_PROTOCOL!="undefined"?AD_PROTOCOL:"none",e=typeof AD_NETWORK!="undefined"?AD_NETWORK:"web_embed";if(t==="mraid")try{mraid.getState(),T=va;return}catch{}else if(t==="dapi")try{dapi.isReady(),T=xa;return}catch{}if(e==="facebook")try{typeof FbPlayableAd!="undefined"&&(T=wa)}catch{}else if(e==="google")try{typeof ExitApi!="undefined"&&(T=Ea)}catch{}else if(e==="mintegral")window.gameReady&&(T=Sa);else if(e==="tapjoy")window.TJ_API&&(T=Aa);else if(e==="tiktok")window.openAppStore&&(T=Ca);else if(e==="smadex")try{window.smxTracking&&(T=Ta)}catch{}else if(e==="snapchat")try{window.ScPlayableAd&&(T=La)}catch{}else e==="vungle"?T=_a:(t==="nucleo"||e==="nucleo")&&(T=ka)}var yt=ae(require("lottie-web"),1),Ha=yt.default;typeof window!="undefined"&&(window.lottie=yt.default,window.__baseLottie=yt.default);var Ts=require("pixi.js");var ei=require("pixi.js");var Ls=null;function ti(t){Ls=t}vt();ii();var Ye=require("pixi.js");vt();var Os=typeof __BUILD_MODE__!="undefined"?__BUILD_MODE__:"undefined",si=Os;if(typeof window!="undefined")try{let t=new XMLHttpRequest;if(t.open("GET","./build-settings.json",!1),t.send(),t.status===200&&t.responseText){let e=JSON.parse(t.responseText);e!=null&&e.buildMode&&(si=e.buildMode,console.log(`[ObjectFactory] Build mode overridden by settings: ${si}`))}}catch{}function Rs(t){var i,n,a,r,s;if(typeof window!="undefined"&&window.resolveAnchorVec2)return window.resolveAnchorVec2(t);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(t))return{x:(i=t[0])!=null?i:.5,y:(n=t[1])!=null?n:.5};if(t&&typeof t=="object"&&"x"in t&&"y"in t)return{x:(a=t.x)!=null?a:.5,y:(r=t.y)!=null?r:.5};if(typeof t=="string"){let o=t.trim().toLowerCase();return(s=e[o])!=null?s:{x:.5,y:.5}}return null}var Ae=class{static async create(e,i,n){var l,d,p,c,g,u,b;console.log(`[ObjectFactory] create() called for: ${e}, __BUILD_MODE__: ${si}`);let a=(l=i==null?void 0:i.render)==null?void 0:l.asset;if(!a){console.log(`[ObjectFactory] No asset definition for: ${e}, returning empty container`);let h=new Ye.Container;return this.applyTransform(h,i==null?void 0:i.transform,i),h}let r=(d=i==null?void 0:i.identity)==null?void 0:d.id;console.log(`[ObjectFactory] Calling AssetLoader.load() for: ${e}, configId: ${r}, type: ${a.type}, path: ${a.path}`);let s=await Se.load(e,a,n,r);console.log(`[ObjectFactory] AssetLoader.load() completed for: ${e}, rawAsset type: ${(p=s==null?void 0:s.constructor)==null?void 0:p.name}`);let o;if(a.type==="image")console.log("[ObjectFactory] Creating Sprite from texture:",s,"for object:",e),o=new Ye.Sprite(s),console.log("[ObjectFactory] Created object:",o,"type:",(c=o==null?void 0:o.constructor)==null?void 0:c.name),this.applyTransform(o,i==null?void 0:i.transform,i);else if(a.type==="json")if(console.log("[ObjectFactory] JSON asset for",e,"rawAsset type:",(g=s==null?void 0:s.constructor)==null?void 0:g.name,s),s&&(((u=s.constructor)==null?void 0:u.name)==="Container"||s instanceof Ye.Container)){console.warn("[ObjectFactory] JSON asset is Container (from cache), reloading JSON directly");let h=[a.path,`/assets/${a.path}`,`assets/${a.path}`,`../assets/${a.path}`],x=!1;for(let v of h)try{let y=await fetch(v);if(y.ok){o=await y.json(),console.log("[ObjectFactory] Reloaded JSON directly from:",v,"type:",(b=o==null?void 0:o.constructor)==null?void 0:b.name),x=!0;break}}catch{continue}x||(console.error("[ObjectFactory] Failed to reload JSON from any path"),o=s)}else o=s;else o=s,o&&typeof o=="object"&&("x"in o||"position"in o)&&this.applyTransform(o,i==null?void 0:i.transform,i);return o}static applyTransform(e,i,n){var a,r,s,o;if(!(!i||!e)&&(i.position&&("x"in e&&"y"in e?(e.x=(a=i.position.x)!=null?a:0,e.y=(r=i.position.y)!=null?r:0):"position"in e&&e.position&&e.position.set((s=i.position.x)!=null?s:0,(o=i.position.y)!=null?o:0)),i.scale!==void 0&&"scale"in e&&e.scale&&(typeof e.scale=="object"&&"set"in e.scale?e.scale.set(i.scale):e.scale=i.scale),i.rotation!==void 0&&"rotation"in e&&(e.rotation=i.rotation),i.anchor&&"anchor"in e&&e.anchor)){let l=Rs(i.anchor);l&&("set"in e.anchor?e.anchor.set(l.x,l.y):(e.anchor.x=l.x,e.anchor.y=l.y))}}};var Xe=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 Ds=ae(require("pixi.js"),1);typeof window!="undefined"&&(window.__basePixi=Ds);Ke();var wt=require("pixi.js");Ke();var li=class{constructor(){this.instanceCache=new Map;this.readyPromise=null;this.app=null;this.registry=new Xe}init(e,i){this.registry.init(e),this.app=i}updateConfig(e){this.registry.init(e),this.instanceCache.clear(),this.readyPromise=null}async ready(){this.readyPromise&&await this.readyPromise;let i=this.registry.getAllIds().filter(a=>!this.instanceCache.has(a));if(i.length===0)return;let n=async a=>{a.length&&(console.log("[Assets] Loading objects:",a),await Promise.all(a.map(async r=>{var o;let s=this.registry.get(r);if(!s){console.warn("[Assets] No config found for object:",r);return}try{let l=await Ae.create(r,s,this.app);this.instanceCache.set(r,l),console.log("[Assets] Loaded object:",r,(o=l==null?void 0:l.constructor)==null?void 0:o.name)}catch(l){console.error("[Assets] Failed to load object:",r,l)}})))};return this.readyPromise=(async()=>{await n(i);let a=this.registry.getAllIds().filter(r=>!this.instanceCache.has(r));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 i=this.registry.get(e);if(i){let n=await Ae.create(e,i,this.app);this.instanceCache.set(e,n)}}get(e){return this.instanceCache.get(e)}},$s=new li,Fs=new Proxy($s,{get(t,e){if(e in t&&typeof t[e]=="function")return t[e].bind(t);if(t.get(e))return t.get(e)}});Ke();var Ba=require("pixi.js"),le={width:400,height:600,designWidth:400,scaleFactor:1},St={scale:1,position:1},di=[];function Gs(t,e,i,n,a,r,s){di.push({element:t,originalScale:r,positionHelper:e,heightPercent:a}),e(t,i,n,a,r,s,!1)}function Us(){di.forEach(({element:t,originalScale:e,positionHelper:i,heightPercent:n})=>{let a=e*le.scaleFactor;i(t,le.width,le.height,n,a,!0,!1)})}function ci(t,e){console.log(`[SCREEN] updateScreenState called: ${t}x${e}`),le.width=t,le.height=e,le.scaleFactor=Math.min(t/le.designWidth,1.15),St.scale=le.scaleFactor,St.position=1,console.log(`[SCREEN] Global multipliers - scale: ${St.scale.toFixed(3)}`),Us()}var Ze={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 qs(t,e,i){let n=Ze[t];n&&n[e]!==void 0&&(n[e]=i,console.log(`Updated ${t}.${e} = ${i}`))}function Ws(){return Ze}var Vs={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 Et(t,e){return typeof t=="number"&&Number.isFinite(t)?t:e}function At(t,e={x:.5,y:.5}){var i;if(Array.isArray(t))return{x:Et(t[0],e.x),y:Et(t[1],e.y)};if(t&&typeof t=="object"){let n=t;return{x:Et(n.x,e.x),y:Et(n.y,e.y)}}if(typeof t=="string"){let n=t.trim().toLowerCase();return(i=Vs[n])!=null?i:e}return e}function Ga(t,e,i,n={}){var u,b,h,x,v,y;let a=At(i),r=(u=n.inset)!=null?u:{},s=(b=n.padding)!=null?b:{x:0,y:0},o=((h=r.left)!=null?h:0)+s.x,l=((x=r.right)!=null?x:0)+s.x,d=((v=r.top)!=null?v:0)+s.y,p=((y=r.bottom)!=null?y:0)+s.y,c=Math.max(0,t-o-l),g=Math.max(0,e-d-p);return{x:o+c*a.x,y:d+g*a.y}}function Ua(t,e,i,n={}){var h,x,v,y,f,m;let a=(h=n.inset)!=null?h:{},r=(x=n.padding)!=null?x:{x:0,y:0},s=((v=a.left)!=null?v:0)+r.x,o=((y=a.right)!=null?y:0)+r.x,l=((f=a.top)!=null?f:0)+r.y,d=((m=a.bottom)!=null?m:0)+r.y,p=Math.max(0,t-s-o),c=Math.max(0,e-l-d),g=At(i,{x:.5,y:.5}),u=Math.min(Math.max(g.x,0),1),b=Math.min(Math.max(g.y,0),1);return{x:s+p*u,y:l+c*b}}if(typeof window!="undefined"){let t=window.innerWidth,e=window.innerHeight,i=()=>{let n=window.innerWidth,a=window.innerHeight;(n!==t||a!==e)&&(t=n,e=a,ci(n,a))};window.addEventListener("resize",i),window.addEventListener("orientationchange",()=>{setTimeout(i,100)}),window.mraid&&(window.mraid.addEventListener("viewableChange",i),window.mraid.addEventListener("sizeChange",i)),ci(window.innerWidth,window.innerHeight),window.updateDebugConfig=qs,window.getDebugConfig=Ws,window.copyConfig=ao,window.applyConfig=Je,window.applyConfigForRatio=ro,window.positionAtBottom=qa,window.positionAtTop=Ks,window.positionAtCenter=Js,window.positionAtLeft=Zs,window.positionAtRight=Qs,window.positionAtBottomLeft=eo,window.positionAtBottomRight=to,window.positionAtTopLeft=io,window.positionAtTopRight=no,window.applyPositionContract=Xs,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 Ct(t,e,i=0){return t*e+i}function Tt(t,e,i=0){return t*(1-e)+i}function Lt(t,e,i=0){return t*e+i}function _t(t,e,i=0){return t*(1-e)+i}function U(t,e=0){return t/2+e}function Ys(t,e){return t*e}function Xs(t,e,i,n){var s,o,l,d,p,c,g,u,b,h,x,v,y,f,m,E,S,A,k,I;let a=0,r=0;switch(n.type){case"top":a=U(e,(o=(s=n.offset)==null?void 0:s.x)!=null?o:0),r=Ct(i,n.percent,(d=(l=n.offset)==null?void 0:l.y)!=null?d:0);break;case"bottom":a=U(e,(c=(p=n.offset)==null?void 0:p.x)!=null?c:0),r=Tt(i,n.percent,(u=(g=n.offset)==null?void 0:g.y)!=null?u:0);break;case"left":a=Lt(e,n.percent,(h=(b=n.offset)==null?void 0:b.x)!=null?h:0),r=U(i,(v=(x=n.offset)==null?void 0:x.y)!=null?v:0);break;case"right":a=_t(e,n.percent,(f=(y=n.offset)==null?void 0:y.x)!=null?f:0),r=U(i,(E=(m=n.offset)==null?void 0:m.y)!=null?E:0);break;case"center":a=U(e,(A=(S=n.offset)==null?void 0:S.x)!=null?A:0),r=U(i,(I=(k=n.offset)==null?void 0:k.y)!=null?I:0);break}t.position?t.position.set(a,r):(t.x=a,t.y=r),n.scale!==void 0&&n.scale!==1&&t.scale&&(typeof t.scale.set=="function"?t.scale.set(n.scale,n.scale):(t.scale.x=n.scale,t.scale.y=n.scale))}function qa(t,e,i,n=.2,a=1,r=!0,s=!1){let o=Ys(i,n),l=Tt(i,n/2);ce(t,U(e),l);let d=r?a*le.scaleFactor:a;de(t,d),s&&!di.find(p=>p.element===t)&&Gs(t,qa,e,i,n,a,r)}function Ks(t,e,i,n=.1,a=1){ce(t,U(e),Ct(i,n)),de(t,a)}function Js(t,e,i,n=0,a=0,r=1){ce(t,U(e,n),U(i,a)),de(t,r)}function Zs(t,e,i,n=.1,a=1){ce(t,Lt(e,n),U(i)),de(t,a)}function Qs(t,e,i,n=.1,a=1){ce(t,_t(e,n),U(i)),de(t,a)}function eo(t,e,i,n=.05,a=.05,r=1){ce(t,Lt(e,a),Tt(i,n)),de(t,r)}function to(t,e,i,n=.05,a=.05,r=1){ce(t,_t(e,a),Tt(i,n)),de(t,r)}function io(t,e,i,n=.05,a=.05,r=1){ce(t,Lt(e,a),Ct(i,n)),de(t,r)}function no(t,e,i,n=.05,a=.05,r=1){ce(t,_t(e,a),Ct(i,n)),de(t,r)}function ce(t,e,i){t&&t.position?typeof t.position.set=="function"?t.position.set(e,i):(t.position.x=e,t.position.y=i):t&&(t.x=e,t.y=i)}function de(t,e){e!==1&&t&&t.scale&&(typeof t.scale.set=="function"?t.scale.set(e,e):t.scale.x!==void 0&&t.scale.y!==void 0&&(t.scale.x=e,t.scale.y=e))}var Ce={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 ao(t){return t&&Ce[t]?JSON.parse(JSON.stringify(Ce[t])):JSON.parse(JSON.stringify(Ze))}function Je(t){Object.keys(t).forEach(e=>{let i=e;Ze[i]&&t[i]&&Object.assign(Ze[i],t[i])}),console.log("Config applied:",t)}function ro(t,e){let i=t/e;i>1.6?(Je(Ce.wide),console.log("Applied WIDE config for ratio:",i)):i<.7?(Je(Ce.tall),console.log("Applied TALL config for ratio:",i)):i>.8&&i<1.2?(Je(Ce.square),console.log("Applied SQUARE config for ratio:",i)):(Je(Ce.default),console.log("Applied DEFAULT config for ratio:",i))}if(typeof window!="undefined"){let t=window;t.configPresets=Ce,t.resolveAnchorVec2=t.resolveAnchorVec2||At,t.resolveScreenAnchorPoint=t.resolveScreenAnchorPoint||Ga,t.resolveScreenRatioPoint=t.resolveScreenRatioPoint||Ua}gi();function P(t,e){let i=(a,r)=>r===0?a:i(r,a%r),n=i(t,e);return`${t/n}:${e/n}`}var Bc=[{id:"iphone-15-pro-max",label:"iPhone 15 Pro Max",width:430,height:932,category:"iphone",ratio:P(430,932)},{id:"iphone-15-pro",label:"iPhone 15 Pro",width:393,height:852,category:"iphone",ratio:P(393,852)},{id:"iphone-15",label:"iPhone 15",width:393,height:852,category:"iphone",ratio:P(393,852)},{id:"iphone-14",label:"iPhone 14",width:390,height:844,category:"iphone",ratio:P(390,844)},{id:"iphone-se",label:"iPhone SE",width:375,height:667,category:"iphone",ratio:P(375,667)},{id:"iphone-12-mini",label:"iPhone 12 Mini",width:360,height:780,category:"iphone",ratio:P(360,780)}],Gc=[{id:"pixel-8-pro",label:"Pixel 8 Pro",width:448,height:998,category:"android",ratio:P(448,998)},{id:"pixel-8",label:"Pixel 8",width:412,height:915,category:"android",ratio:P(412,915)},{id:"samsung-s24-ultra",label:"Samsung S24 Ultra",width:412,height:915,category:"android",ratio:P(412,915)},{id:"samsung-s24",label:"Samsung S24",width:360,height:780,category:"android",ratio:P(360,780)},{id:"samsung-a54",label:"Samsung A54",width:412,height:915,category:"android",ratio:P(412,915)},{id:"oneplus-12",label:"OnePlus 12",width:412,height:915,category:"android",ratio:P(412,915)}],Uc=[{id:"ipad-pro-12",label:'iPad Pro 12.9"',width:1024,height:1366,category:"tablet",ratio:P(1024,1366)},{id:"ipad-pro-11",label:'iPad Pro 11"',width:834,height:1194,category:"tablet",ratio:P(834,1194)},{id:"ipad-air",label:"iPad Air",width:820,height:1180,category:"tablet",ratio:P(820,1180)},{id:"ipad-mini",label:"iPad Mini",width:768,height:1024,category:"tablet",ratio:P(768,1024)},{id:"samsung-tab-s9",label:"Samsung Tab S9",width:800,height:1280,category:"tablet",ratio:P(800,1280)}],Xa=[{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:P(390,844),mraidScale:.7},{id:"ipad-mini",label:"iPad Mini",width:768,height:1024,category:"playable",ratio:P(768,1024),mraidScale:.7}];var qc=[...Xa];var ho=Xa[0];fe();var xo=ae(require("jszip"),1);function bo(t){return new Promise((e,i)=>{let n=new FileReader;n.onerror=()=>i(new Error("FileReader failed")),n.onload=()=>e(String(n.result||"")),n.readAsDataURL(t)})}function yo(t){var a;let[e,i]=t.split(","),n=e==null?void 0:e.match(/data:(.*?);base64/);return{base64:i!=null?i:"",mimeType:(a=n==null?void 0:n[1])!=null?a:"image/png"}}async function vo(t){return await new Promise(e=>{let i=new Image;i.onload=()=>e({width:i.naturalWidth||i.width,height:i.naturalHeight||i.height}),i.onerror=()=>e(null),i.src=t})}async function hi(t){var e,i;try{console.log("[ImageUtils] Fetching image data from URL:",t);let n=await fetch(t);if(!n.ok)return console.warn("[ImageUtils] Fetch failed with status:",n.status,t),null;let a=await n.blob();console.log("[ImageUtils] Blob received, size:",a.size,"type:",a.type);let r=await bo(a),s=await vo(r),o=yo(r);return console.log("[ImageUtils] Success resolution:",s==null?void 0:s.width,"x",s==null?void 0:s.height,"mime:",o.mimeType),{base64:o.base64,mimeType:o.mimeType,dataUrl:r,width:(e=s==null?void 0:s.width)!=null?e:0,height:(i=s==null?void 0:s.height)!=null?i:0}}catch(n){return console.error("[ImageUtils] Error fetching image data:",n),null}}async function kt(t,e=30){try{console.log("[ImageUtils] Removing background color...");let i=await new Promise((c,g)=>{let u=new Image;u.onload=()=>c(u),u.onerror=()=>g(new Error("Failed to load image")),u.src=t}),n=document.createElement("canvas");n.width=i.width,n.height=i.height;let a=n.getContext("2d");if(!a)return console.error("[ImageUtils] Failed to get canvas context"),t;a.drawImage(i,0,0);let r=a.getImageData(0,0,n.width,n.height),s=r.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:s[c.offset],g:s[c.offset+1],b:s[c.offset+2]})),d=0;for(let c=0;c<s.length;c+=4){let g=s[c],u=s[c+1],b=s[c+2],h=!1;for(let x of l)if(Math.sqrt(Math.pow(g-x.r,2)+Math.pow(u-x.g,2)+Math.pow(b-x.b,2))<e){h=!0;break}h&&(s[c+3]=0,d++)}return console.log(`[ImageUtils] Removed background from ${d} pixels (4-corner sampling, tolerance: ${e})`),a.putImageData(r,0,0),n.toDataURL("image/png")}catch(i){return console.error("[ImageUtils] Error removing background:",i),t}}var Ka=require("@google/genai");async function fi(t,e,i=[],n={}){var a,r,s,o,l,d,p;try{if(!(t!=null&&t.trim()))throw new Error("Gemini API key is required");if(!(e!=null&&e.trim()))throw new Error("Prompt is required");for(let v=0;v<i.length;v++){let y=i[v];if(!y.base64||!y.mimeType)throw new Error(`Image ${v+1} is missing required data`);if(y.base64.length<1e3&&console.warn(`Image ${v+1} data appears very small, may be corrupted`),!y.mimeType.startsWith("image/"))throw new Error(`Image ${v+1} has invalid MIME type: ${y.mimeType}`)}let c=new Ka.GoogleGenAI({apiKey:t}),g="gemini-2.5-flash",u=[e];i.length>0&&i.forEach((v,y)=>{u.push({inlineData:{data:v.base64,mimeType:v.mimeType}}),console.log(`[Gemini] Added image ${y+1}: ${v.mimeType}, size: ${Math.round(v.base64.length/1024)}KB`)}),console.log(`[Gemini] Making request with ${i.length} images and prompt length: ${e.length}`);let b=await c.models.generateContent({model:g,contents:u}),h="",x=(s=(r=(a=b.candidates)==null?void 0:a[0])==null?void 0:r.content)==null?void 0:s.parts;if(x)for(let v of x)v.text&&(h+=v.text);if(!h.trim())throw new Error("Empty response from Gemini API");return console.log(`[Gemini] Response received, length: ${h.length}`),h}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."):(p=c.message)!=null&&p.includes("SAFETY")?new Error("Content was flagged by Gemini safety filters. Please try with different images."):c}}var Ja=require("@google/genai");async function Mt(t,e,i=[],n={}){try{console.info("[GEMINI-REAL-SDK] Initializing GoogleGenAI...");let a=new Ja.GoogleGenAI({apiKey:t}),r=[{text:e}];i.length>0&&i.forEach((o,l)=>{console.info(`[GEMINI-REAL-SDK] Adding image part ${l}`),r.push({inlineData:{mimeType:o.mimeType,data:o.base64}})}),console.info("[GEMINI-REAL-SDK] Calling generateContent with model: gemini-2.5-flash-image");let s=await a.models.generateContent({model:"gemini-2.5-flash-image",contents:r});if(console.info("[GEMINI-REAL-SDK] Received response from model"),!s.candidates||!s.candidates[0]||!s.candidates[0].content||!s.candidates[0].content.parts)throw new Error("Gemini 2.5 Flash Image returned invalid response structure.");for(let o of s.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 wo=require("pixi.js");Ke();fe();var Qa=require("pixi.js");var Eo=require("pixi.js");fe();function ko(t){return new Promise((e,i)=>{let n=new FileReader;n.onerror=()=>i(new Error("FileReader failed")),n.onload=()=>e(String(n.result||"")),n.readAsDataURL(t)})}function Mo(t){var a;let[e,i]=t.split(","),n=e==null?void 0:e.match(/data:(.*?);base64/);return{base64:i!=null?i:"",mimeType:(a=n==null?void 0:n[1])!=null?a:"image/png"}}function Po(t){return`
|
|
46
|
+
`,this.modal=n}attachModalListeners(){if(!this.modal)return;this.modal.querySelectorAll("[data-modal-close]").forEach(o=>{o.addEventListener("click",()=>this.close())}),this.modal.querySelectorAll("[data-tab]").forEach(o=>{o.addEventListener("click",s=>{let d=s.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 r=this.modal.querySelector("[data-modal-apply]");r==null||r.addEventListener("click",()=>{this.apply()}),this.modal.addEventListener("click",o=>{o.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 i=window.__openAiEditor;if(typeof i!="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}`,i(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 Ks={};oa(Ks,{AspectClass:()=>Oi,GameObject:()=>st,GameObjectManager:()=>Dt,Renderer:()=>ot,ResponsiveUISystem:()=>Ge,Transform:()=>rt,animateHandClick:()=>wr,animatePanelEntrance:()=>vr,createBrushTexture:()=>Lr,createEndGamePanel:()=>yr,createHandTutorial:()=>xr,createThreeBase:()=>fr,createTutorialLabel:()=>Er,getAspectClass:()=>zt,getRegisteredFontIds:()=>br,loadAsset:()=>zi,loadCharacterFrames:()=>Tr,registerFont:()=>mr,resolveFont:()=>Z,resolveFontWeight:()=>Q,updateHandAnimation:()=>Sr});module.exports=xo(Ks);var V=ae(require("three"),1);var ge={};function mt(t,e,i=!1){ge[t]||(ge[t]=[]),ge[t].push({fn:e,once:i})}function Kt(t,e){if(ge[t]){if(!e){delete ge[t];return}ge[t]=ge[t].filter(i=>i.fn!==e)}}function bt(t,...e){let i=ge[t];if(i)for(let n of[...i])n.fn(...e),n.once&&Kt(t,n.fn)}function B(t,e){mt(t,e,!0)}var M=null,W=[],Pe=null;function da(t){M=t,W=[],Pe!==null&&(clearTimeout(Pe),Pe=null)}function pa(){var t,e,i;return{endpoint:(M==null?void 0:M.endpoint)||"",transport:(M==null?void 0:M.transport)||"beacon",batchSize:(t=M==null?void 0:M.batchSize)!=null?t:10,flushIntervalMs:(e=M==null?void 0:M.flushIntervalMs)!=null?e:300,maxQueue:(i=M==null?void 0:M.maxQueue)!=null?i:200,debug:!!(M!=null&&M.debug)}}async function la(t,e,i,n){let a=JSON.stringify(e);if(i==="beacon"&&typeof navigator!="undefined"&&typeof navigator.sendBeacon=="function")try{let r=navigator.sendBeacon(t,new Blob([a],{type:"application/json"}));n&&console.log("[handler.telemetry] beacon",r,e);return}catch(r){n&&console.warn("[handler.telemetry] beacon failed, fallback to fetch",r)}try{await fetch(t,{method:"POST",headers:{"Content-Type":"application/json"},body:a,keepalive:!0}),n&&console.log("[handler.telemetry] fetch",e)}catch(r){n&&console.warn("[handler.telemetry] fetch failed",r)}}function Jt(t,e){let i=pa();if(e&&i.endpoint){if(W.push(t),W.length>i.maxQueue&&(W=W.slice(W.length-i.maxQueue)),W.length>=i.batchSize){ca();return}Pe===null&&(Pe=window.setTimeout(()=>{Pe=null,ca()},i.flushIntervalMs))}}async function ca(){let t=pa();if(!t.endpoint||W.length===0)return;let e=W.splice(0,t.batchSize);await la(t.endpoint,{events:e},t.transport,t.debug),W.length>0&&await la(t.endpoint,{events:W.splice(0,t.batchSize)},t.transport,t.debug)}function ua(t){return Math.max(0,Math.min(1,t))}function Eo(t){let e=String(t!=null?t:"power2.out");if(e==="linear")return i=>i;if(e==="sine.inOut")return i=>.5-Math.cos(Math.PI*i)/2;if(e==="power2.out"||e==="easeOutQuad")return i=>1-(1-i)*(1-i);if(e.startsWith("back.out")){let i=e.match(/back\.out\(([\d.]+)\)/),n=i?Number(i[1]):1.8;return a=>1+(n+1)*Math.pow(a-1,3)+n*Math.pow(a-1,2)}return i=>1-(1-i)*(1-i)}function Ve(){return typeof performance!="undefined"&&performance.now?performance.now():Date.now()}function So(t,e){let i=t==null?void 0:t[e];return typeof i=="number"?i:0}function ga(t,e,i){try{t[e]=i}catch{}}function Ao(t){let e=t==null?void 0:t.scale;if(!e)return null;let i=typeof e.x=="number"?e.x:1,n=typeof e.y=="number"?e.y:1;return{x:i,y:n}}function ha(t,e){let i=t==null?void 0:t.scale;if(i)try{typeof i.set=="function"?i.set(e.x,e.y):(typeof i.x=="number"&&(i.x=e.x),typeof i.y=="number"&&(i.y=e.y))}catch{}}function fa(t,e){let i=Ao(t);if(!i)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:i.x,y:i.y},to:{x:n!=null?n:i.x,y:a!=null?a:i.y}}}function ma(){let t=new Set,e=new WeakMap,i=null,n=()=>{if(i!=null)return;i=requestAnimationFrame(()=>{i=null,s(),t.size>0&&n()})},a=p=>{var g;t.add(p);let c=(g=e.get(p.target))!=null?g:new Set;c.add(p),e.set(p.target,c),n()},r=p=>{t.delete(p);let c=e.get(p.target);c&&(c.delete(p),c.size===0&&e.delete(p.target))},o=p=>{p.killed||(p.killed=!0,r(p))},s=()=>{var c,g;let p=Ve();for(let u of Array.from(t)){if(u.killed||u.paused)continue;let b=p-u.startMs-u.delayMs;if(b<0)continue;let h=u.durationMs>0?b/u.durationMs:1,w=ua(h),v=u.repeat>=0?u.repeat+1:1,y=u.repeat>0?Math.min(Math.floor(h),v-1):0;if(u.repeat>0&&h>=1){let E=h-y;w=ua(E)}let f=u.ease(w);u.yoyo&&y%2===1&&(f=1-f);for(let E of u.props)ga(u.target,E.key,E.from+(E.to-E.from)*f);u.scaleFrom&&u.scaleTo&&ha(u.target,{x:u.scaleFrom.x+(u.scaleTo.x-u.scaleFrom.x)*f,y:u.scaleFrom.y+(u.scaleTo.y-u.scaleFrom.y)*f});try{(c=u.onUpdate)==null||c.call(u)}catch{}if(h>=v){o(u);try{(g=u.onComplete)==null||g.call(u)}catch{}}}},l=(p,c,g)=>{var E;let u=Math.max(0,(typeof c.duration=="number"?c.duration:.5)*1e3),b=Math.max(0,(typeof c.delay=="number"?c.delay:0)*1e3+((E=g==null?void 0:g.delayMsOverride)!=null?E:0)),h=Eo(c.ease),w=typeof c.repeat=="number"?Math.max(0,c.repeat|0):0,v=c.yoyo===!0,y=new Set(["duration","delay","ease","repeat","yoyo","onUpdate","onComplete","scale","scaleX","scaleY"]),f=[];for(let S of Object.keys(c)){if(y.has(S))continue;let A=c[S];typeof A=="number"&&f.push({key:S,from:So(p,S),to:A})}let m=fa(p,c);return{target:p,startMs:Ve(),delayMs:b,durationMs:u,ease:h,props:f,scaleFrom:m.from,scaleTo:m.to,repeat:w,yoyo:v,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(p,c){let g=l(p,c);return a(g),{kill:()=>o(g),pause:()=>{g.paused||(g.paused=!0,g.pauseAtMs=Ve())},resume:()=>{var h;if(!g.paused)return;let u=(h=g.pauseAtMs)!=null?h:Ve(),b=Ve()-u;g.startMs+=b,g.paused=!1,g.pauseAtMs=null},isActive:()=>!g.killed&&!g.paused}},fromTo(p,c,g){return d.set(p,c),d.to(p,g)},set(p,c){if(!p||!c)return;for(let u of Object.keys(c)){let b=c[u];u==="scale"||u==="scaleX"||u==="scaleY"||typeof b=="number"&&ga(p,u,b)}let g=fa(p,c);g.to&&ha(p,g.to)},killTweensOf(p){let c=e.get(p);if(c)for(let g of Array.from(c))o(g)},timeline(p={}){let c=[],g=0,u=!1,b=[],h=y=>{if(typeof y=="number")return Math.max(0,y*1e3);let f=typeof y=="string"?y.trim():"";return f.startsWith("+=")?g+Math.max(0,Number(f.slice(2))*1e3||0):f?Math.max(0,Number(f)*1e3||0):g},w=y=>{c.push(y);let f=Math.max(0,(typeof y.vars.duration=="number"?y.vars.duration:.5)*1e3);g=Math.max(g,y.atMs+f)},v={to(y,f,m){return w({kind:"to",target:y,vars:f,atMs:h(m)}),v},fromTo(y,f,m,E){return w({kind:"fromTo",target:y,vars:m,from:f,atMs:h(E)}),v},play(){var y,f;if(u)return v;u=!0,b=[];for(let m of c)m.kind==="fromTo"&&d.set(m.target,(y=m.from)!=null?y:{}),b.push(d.to(m.target,{...m.vars,delay:m.atMs/1e3+((f=m.vars.delay)!=null?f:0)}));return v},pause(){for(let y of b)y.pause();return v},kill(){for(let y of b)y.kill();b=[],u=!1}};return p.paused||v.play(),v}};return d}function ba(){if(typeof window=="undefined")return;let t=window;if(!t.gsap)try{t.gsap=ma()}catch{}}var ya={name:"handler-playable-sdk",version:"0.5.2",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 && 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 && 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 G=0,To=G++,va=G++,wa=G++,xa=G++,Ea=G++,Sa=G++,Aa=G++,Ca=G++,Ta=G++,La=G++,_a=G++,ka=G++,T=To;function Ma(){return T===va}function Pa(){return T===wa}function Ia(){return T===xa}function Oa(){return T===Ea}function Ie(){return T===Sa}function Oe(){return T===Aa}function Ra(){return T===Ca}function ja(){return T===Ta}function za(){return T===La}function Zt(){return T===_a}function Qt(){return T===ka}function Da(){let t=typeof AD_PROTOCOL!="undefined"?AD_PROTOCOL:"none",e=typeof AD_NETWORK!="undefined"?AD_NETWORK:"web_embed";if(t==="mraid")try{mraid.getState(),T=va;return}catch{}else if(t==="dapi")try{dapi.isReady(),T=wa;return}catch{}if(e==="facebook")try{typeof FbPlayableAd!="undefined"&&(T=xa)}catch{}else if(e==="google")try{typeof ExitApi!="undefined"&&(T=Ea)}catch{}else if(e==="mintegral")window.gameReady&&(T=Sa);else if(e==="tapjoy")window.TJ_API&&(T=Aa);else if(e==="tiktok")window.openAppStore&&(T=Ca);else if(e==="smadex")try{window.smxTracking&&(T=Ta)}catch{}else if(e==="snapchat")try{window.ScPlayableAd&&(T=La)}catch{}else e==="vungle"?T=_a:(t==="nucleo"||e==="nucleo")&&(T=ka)}var yt=ae(require("lottie-web"),1),$a=yt.default;typeof window!="undefined"&&(window.lottie=yt.default,window.__baseLottie=yt.default);var Lo=require("pixi.js");var ei=require("pixi.js");var _o=null;function ti(t){_o=t}vt();ii();var Ye=require("pixi.js");vt();var Ro=typeof __BUILD_MODE__!="undefined"?__BUILD_MODE__:"undefined",oi=Ro;if(typeof window!="undefined")try{let t=new XMLHttpRequest;if(t.open("GET","./build-settings.json",!1),t.send(),t.status===200&&t.responseText){let e=JSON.parse(t.responseText);e!=null&&e.buildMode&&(oi=e.buildMode,console.log(`[ObjectFactory] Build mode overridden by settings: ${oi}`))}}catch{}function jo(t){var i,n,a,r,o;if(typeof window!="undefined"&&window.resolveAnchorVec2)return window.resolveAnchorVec2(t);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(t))return{x:(i=t[0])!=null?i:.5,y:(n=t[1])!=null?n:.5};if(t&&typeof t=="object"&&"x"in t&&"y"in t)return{x:(a=t.x)!=null?a:.5,y:(r=t.y)!=null?r:.5};if(typeof t=="string"){let s=t.trim().toLowerCase();return(o=e[s])!=null?o:{x:.5,y:.5}}return null}var Ae=class{static async create(e,i,n){var l,d,p,c,g,u,b;console.log(`[ObjectFactory] create() called for: ${e}, __BUILD_MODE__: ${oi}`);let a=(l=i==null?void 0:i.render)==null?void 0:l.asset;if(!a){console.log(`[ObjectFactory] No asset definition for: ${e}, returning empty container`);let h=new Ye.Container;return this.applyTransform(h,i==null?void 0:i.transform,i),h}let r=(d=i==null?void 0:i.identity)==null?void 0:d.id;console.log(`[ObjectFactory] Calling AssetLoader.load() for: ${e}, configId: ${r}, type: ${a.type}, path: ${a.path}`);let o=await Se.load(e,a,n,r);console.log(`[ObjectFactory] AssetLoader.load() completed for: ${e}, rawAsset type: ${(p=o==null?void 0:o.constructor)==null?void 0:p.name}`);let s;if(a.type==="image")console.log("[ObjectFactory] Creating Sprite from texture:",o,"for object:",e),s=new Ye.Sprite(o),console.log("[ObjectFactory] Created object:",s,"type:",(c=s==null?void 0:s.constructor)==null?void 0:c.name),this.applyTransform(s,i==null?void 0:i.transform,i);else if(a.type==="json")if(console.log("[ObjectFactory] JSON asset for",e,"rawAsset type:",(g=o==null?void 0:o.constructor)==null?void 0:g.name,o),o&&(((u=o.constructor)==null?void 0:u.name)==="Container"||o instanceof Ye.Container)){console.warn("[ObjectFactory] JSON asset is Container (from cache), reloading JSON directly");let h=[a.path,`/assets/${a.path}`,`assets/${a.path}`,`../assets/${a.path}`],w=!1;for(let v of h)try{let y=await fetch(v);if(y.ok){s=await y.json(),console.log("[ObjectFactory] Reloaded JSON directly from:",v,"type:",(b=s==null?void 0:s.constructor)==null?void 0:b.name),w=!0;break}}catch{continue}w||(console.error("[ObjectFactory] Failed to reload JSON from any path"),s=o)}else s=o;else s=o,s&&typeof s=="object"&&("x"in s||"position"in s)&&this.applyTransform(s,i==null?void 0:i.transform,i);return s}static applyTransform(e,i,n){var a,r,o,s;if(!(!i||!e)&&(i.position&&("x"in e&&"y"in e?(e.x=(a=i.position.x)!=null?a:0,e.y=(r=i.position.y)!=null?r:0):"position"in e&&e.position&&e.position.set((o=i.position.x)!=null?o:0,(s=i.position.y)!=null?s:0)),i.scale!==void 0&&"scale"in e&&e.scale&&(typeof e.scale=="object"&&"set"in e.scale?e.scale.set(i.scale):e.scale=i.scale),i.rotation!==void 0&&"rotation"in e&&(e.rotation=i.rotation),i.anchor&&"anchor"in e&&e.anchor)){let l=jo(i.anchor);l&&("set"in e.anchor?e.anchor.set(l.x,l.y):(e.anchor.x=l.x,e.anchor.y=l.y))}}};var Xe=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 $o=ae(require("pixi.js"),1);typeof window!="undefined"&&(window.__basePixi=$o);Ke();var xt=require("pixi.js");Ke();var li=class{constructor(){this.instanceCache=new Map;this.readyPromise=null;this.app=null;this.registry=new Xe}init(e,i){this.registry.init(e),this.app=i}updateConfig(e){this.registry.init(e),this.instanceCache.clear(),this.readyPromise=null}async ready(){this.readyPromise&&await this.readyPromise;let i=this.registry.getAllIds().filter(a=>!this.instanceCache.has(a));if(i.length===0)return;let n=async a=>{a.length&&(console.log("[Assets] Loading objects:",a),await Promise.all(a.map(async r=>{var s;let o=this.registry.get(r);if(!o){console.warn("[Assets] No config found for object:",r);return}try{let l=await Ae.create(r,o,this.app);this.instanceCache.set(r,l),console.log("[Assets] Loaded object:",r,(s=l==null?void 0:l.constructor)==null?void 0:s.name)}catch(l){console.error("[Assets] Failed to load object:",r,l)}})))};return this.readyPromise=(async()=>{await n(i);let a=this.registry.getAllIds().filter(r=>!this.instanceCache.has(r));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 i=this.registry.get(e);if(i){let n=await Ae.create(e,i,this.app);this.instanceCache.set(e,n)}}get(e){return this.instanceCache.get(e)}},Fo=new li,No=new Proxy(Fo,{get(t,e){if(e in t&&typeof t[e]=="function")return t[e].bind(t);if(t.get(e))return t.get(e)}});Ke();var Ba=require("pixi.js"),le={width:400,height:600,designWidth:400,scaleFactor:1},St={scale:1,position:1},di=[];function Uo(t,e,i,n,a,r,o){di.push({element:t,originalScale:r,positionHelper:e,heightPercent:a}),e(t,i,n,a,r,o,!1)}function qo(){di.forEach(({element:t,originalScale:e,positionHelper:i,heightPercent:n})=>{let a=e*le.scaleFactor;i(t,le.width,le.height,n,a,!0,!1)})}function ci(t,e){console.log(`[SCREEN] updateScreenState called: ${t}x${e}`),le.width=t,le.height=e,le.scaleFactor=Math.min(t/le.designWidth,1.15),St.scale=le.scaleFactor,St.position=1,console.log(`[SCREEN] Global multipliers - scale: ${St.scale.toFixed(3)}`),qo()}var Ze={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 Wo(t,e,i){let n=Ze[t];n&&n[e]!==void 0&&(n[e]=i,console.log(`Updated ${t}.${e} = ${i}`))}function Vo(){return Ze}var Yo={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 Et(t,e){return typeof t=="number"&&Number.isFinite(t)?t:e}function At(t,e={x:.5,y:.5}){var i;if(Array.isArray(t))return{x:Et(t[0],e.x),y:Et(t[1],e.y)};if(t&&typeof t=="object"){let n=t;return{x:Et(n.x,e.x),y:Et(n.y,e.y)}}if(typeof t=="string"){let n=t.trim().toLowerCase();return(i=Yo[n])!=null?i:e}return e}function Ga(t,e,i,n={}){var u,b,h,w,v,y;let a=At(i),r=(u=n.inset)!=null?u:{},o=(b=n.padding)!=null?b:{x:0,y:0},s=((h=r.left)!=null?h:0)+o.x,l=((w=r.right)!=null?w:0)+o.x,d=((v=r.top)!=null?v:0)+o.y,p=((y=r.bottom)!=null?y:0)+o.y,c=Math.max(0,t-s-l),g=Math.max(0,e-d-p);return{x:s+c*a.x,y:d+g*a.y}}function Ua(t,e,i,n={}){var h,w,v,y,f,m;let a=(h=n.inset)!=null?h:{},r=(w=n.padding)!=null?w:{x:0,y:0},o=((v=a.left)!=null?v:0)+r.x,s=((y=a.right)!=null?y:0)+r.x,l=((f=a.top)!=null?f:0)+r.y,d=((m=a.bottom)!=null?m:0)+r.y,p=Math.max(0,t-o-s),c=Math.max(0,e-l-d),g=At(i,{x:.5,y:.5}),u=Math.min(Math.max(g.x,0),1),b=Math.min(Math.max(g.y,0),1);return{x:o+p*u,y:l+c*b}}if(typeof window!="undefined"){let t=window.innerWidth,e=window.innerHeight,i=()=>{let n=window.innerWidth,a=window.innerHeight;(n!==t||a!==e)&&(t=n,e=a,ci(n,a))};window.addEventListener("resize",i),window.addEventListener("orientationchange",()=>{setTimeout(i,100)}),window.mraid&&(window.mraid.addEventListener("viewableChange",i),window.mraid.addEventListener("sizeChange",i)),ci(window.innerWidth,window.innerHeight),window.updateDebugConfig=Wo,window.getDebugConfig=Vo,window.copyConfig=rs,window.applyConfig=Je,window.applyConfigForRatio=os,window.positionAtBottom=qa,window.positionAtTop=Jo,window.positionAtCenter=Zo,window.positionAtLeft=Qo,window.positionAtRight=es,window.positionAtBottomLeft=ts,window.positionAtBottomRight=is,window.positionAtTopLeft=ns,window.positionAtTopRight=as,window.applyPositionContract=Ko,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 Ct(t,e,i=0){return t*e+i}function Tt(t,e,i=0){return t*(1-e)+i}function Lt(t,e,i=0){return t*e+i}function _t(t,e,i=0){return t*(1-e)+i}function U(t,e=0){return t/2+e}function Xo(t,e){return t*e}function Ko(t,e,i,n){var o,s,l,d,p,c,g,u,b,h,w,v,y,f,m,E,S,A,k,I;let a=0,r=0;switch(n.type){case"top":a=U(e,(s=(o=n.offset)==null?void 0:o.x)!=null?s:0),r=Ct(i,n.percent,(d=(l=n.offset)==null?void 0:l.y)!=null?d:0);break;case"bottom":a=U(e,(c=(p=n.offset)==null?void 0:p.x)!=null?c:0),r=Tt(i,n.percent,(u=(g=n.offset)==null?void 0:g.y)!=null?u:0);break;case"left":a=Lt(e,n.percent,(h=(b=n.offset)==null?void 0:b.x)!=null?h:0),r=U(i,(v=(w=n.offset)==null?void 0:w.y)!=null?v:0);break;case"right":a=_t(e,n.percent,(f=(y=n.offset)==null?void 0:y.x)!=null?f:0),r=U(i,(E=(m=n.offset)==null?void 0:m.y)!=null?E:0);break;case"center":a=U(e,(A=(S=n.offset)==null?void 0:S.x)!=null?A:0),r=U(i,(I=(k=n.offset)==null?void 0:k.y)!=null?I:0);break}t.position?t.position.set(a,r):(t.x=a,t.y=r),n.scale!==void 0&&n.scale!==1&&t.scale&&(typeof t.scale.set=="function"?t.scale.set(n.scale,n.scale):(t.scale.x=n.scale,t.scale.y=n.scale))}function qa(t,e,i,n=.2,a=1,r=!0,o=!1){let s=Xo(i,n),l=Tt(i,n/2);ce(t,U(e),l);let d=r?a*le.scaleFactor:a;de(t,d),o&&!di.find(p=>p.element===t)&&Uo(t,qa,e,i,n,a,r)}function Jo(t,e,i,n=.1,a=1){ce(t,U(e),Ct(i,n)),de(t,a)}function Zo(t,e,i,n=0,a=0,r=1){ce(t,U(e,n),U(i,a)),de(t,r)}function Qo(t,e,i,n=.1,a=1){ce(t,Lt(e,n),U(i)),de(t,a)}function es(t,e,i,n=.1,a=1){ce(t,_t(e,n),U(i)),de(t,a)}function ts(t,e,i,n=.05,a=.05,r=1){ce(t,Lt(e,a),Tt(i,n)),de(t,r)}function is(t,e,i,n=.05,a=.05,r=1){ce(t,_t(e,a),Tt(i,n)),de(t,r)}function ns(t,e,i,n=.05,a=.05,r=1){ce(t,Lt(e,a),Ct(i,n)),de(t,r)}function as(t,e,i,n=.05,a=.05,r=1){ce(t,_t(e,a),Ct(i,n)),de(t,r)}function ce(t,e,i){t&&t.position?typeof t.position.set=="function"?t.position.set(e,i):(t.position.x=e,t.position.y=i):t&&(t.x=e,t.y=i)}function de(t,e){e!==1&&t&&t.scale&&(typeof t.scale.set=="function"?t.scale.set(e,e):t.scale.x!==void 0&&t.scale.y!==void 0&&(t.scale.x=e,t.scale.y=e))}var Ce={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 rs(t){return t&&Ce[t]?JSON.parse(JSON.stringify(Ce[t])):JSON.parse(JSON.stringify(Ze))}function Je(t){Object.keys(t).forEach(e=>{let i=e;Ze[i]&&t[i]&&Object.assign(Ze[i],t[i])}),console.log("Config applied:",t)}function os(t,e){let i=t/e;i>1.6?(Je(Ce.wide),console.log("Applied WIDE config for ratio:",i)):i<.7?(Je(Ce.tall),console.log("Applied TALL config for ratio:",i)):i>.8&&i<1.2?(Je(Ce.square),console.log("Applied SQUARE config for ratio:",i)):(Je(Ce.default),console.log("Applied DEFAULT config for ratio:",i))}if(typeof window!="undefined"){let t=window;t.configPresets=Ce,t.resolveAnchorVec2=t.resolveAnchorVec2||At,t.resolveScreenAnchorPoint=t.resolveScreenAnchorPoint||Ga,t.resolveScreenRatioPoint=t.resolveScreenRatioPoint||Ua}gi();function P(t,e){let i=(a,r)=>r===0?a:i(r,a%r),n=i(t,e);return`${t/n}:${e/n}`}var Bc=[{id:"iphone-15-pro-max",label:"iPhone 15 Pro Max",width:430,height:932,category:"iphone",ratio:P(430,932)},{id:"iphone-15-pro",label:"iPhone 15 Pro",width:393,height:852,category:"iphone",ratio:P(393,852)},{id:"iphone-15",label:"iPhone 15",width:393,height:852,category:"iphone",ratio:P(393,852)},{id:"iphone-14",label:"iPhone 14",width:390,height:844,category:"iphone",ratio:P(390,844)},{id:"iphone-se",label:"iPhone SE",width:375,height:667,category:"iphone",ratio:P(375,667)},{id:"iphone-12-mini",label:"iPhone 12 Mini",width:360,height:780,category:"iphone",ratio:P(360,780)}],Gc=[{id:"pixel-8-pro",label:"Pixel 8 Pro",width:448,height:998,category:"android",ratio:P(448,998)},{id:"pixel-8",label:"Pixel 8",width:412,height:915,category:"android",ratio:P(412,915)},{id:"samsung-s24-ultra",label:"Samsung S24 Ultra",width:412,height:915,category:"android",ratio:P(412,915)},{id:"samsung-s24",label:"Samsung S24",width:360,height:780,category:"android",ratio:P(360,780)},{id:"samsung-a54",label:"Samsung A54",width:412,height:915,category:"android",ratio:P(412,915)},{id:"oneplus-12",label:"OnePlus 12",width:412,height:915,category:"android",ratio:P(412,915)}],Uc=[{id:"ipad-pro-12",label:'iPad Pro 12.9"',width:1024,height:1366,category:"tablet",ratio:P(1024,1366)},{id:"ipad-pro-11",label:'iPad Pro 11"',width:834,height:1194,category:"tablet",ratio:P(834,1194)},{id:"ipad-air",label:"iPad Air",width:820,height:1180,category:"tablet",ratio:P(820,1180)},{id:"ipad-mini",label:"iPad Mini",width:768,height:1024,category:"tablet",ratio:P(768,1024)},{id:"samsung-tab-s9",label:"Samsung Tab S9",width:800,height:1280,category:"tablet",ratio:P(800,1280)}],Xa=[{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:P(390,844),mraidScale:.7},{id:"ipad-mini",label:"iPad Mini",width:768,height:1024,category:"playable",ratio:P(768,1024),mraidScale:.7}];var qc=[...Xa];var hs=Xa[0];fe();var ws=ae(require("jszip"),1);function bs(t){return new Promise((e,i)=>{let n=new FileReader;n.onerror=()=>i(new Error("FileReader failed")),n.onload=()=>e(String(n.result||"")),n.readAsDataURL(t)})}function ys(t){var a;let[e,i]=t.split(","),n=e==null?void 0:e.match(/data:(.*?);base64/);return{base64:i!=null?i:"",mimeType:(a=n==null?void 0:n[1])!=null?a:"image/png"}}async function vs(t){return await new Promise(e=>{let i=new Image;i.onload=()=>e({width:i.naturalWidth||i.width,height:i.naturalHeight||i.height}),i.onerror=()=>e(null),i.src=t})}async function hi(t){var e,i;try{console.log("[ImageUtils] Fetching image data from URL:",t);let n=await fetch(t);if(!n.ok)return console.warn("[ImageUtils] Fetch failed with status:",n.status,t),null;let a=await n.blob();console.log("[ImageUtils] Blob received, size:",a.size,"type:",a.type);let r=await bs(a),o=await vs(r),s=ys(r);return console.log("[ImageUtils] Success resolution:",o==null?void 0:o.width,"x",o==null?void 0:o.height,"mime:",s.mimeType),{base64:s.base64,mimeType:s.mimeType,dataUrl:r,width:(e=o==null?void 0:o.width)!=null?e:0,height:(i=o==null?void 0:o.height)!=null?i:0}}catch(n){return console.error("[ImageUtils] Error fetching image data:",n),null}}async function kt(t,e=30){try{console.log("[ImageUtils] Removing background color...");let i=await new Promise((c,g)=>{let u=new Image;u.onload=()=>c(u),u.onerror=()=>g(new Error("Failed to load image")),u.src=t}),n=document.createElement("canvas");n.width=i.width,n.height=i.height;let a=n.getContext("2d");if(!a)return console.error("[ImageUtils] Failed to get canvas context"),t;a.drawImage(i,0,0);let r=a.getImageData(0,0,n.width,n.height),o=r.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:o[c.offset],g:o[c.offset+1],b:o[c.offset+2]})),d=0;for(let c=0;c<o.length;c+=4){let g=o[c],u=o[c+1],b=o[c+2],h=!1;for(let w of l)if(Math.sqrt(Math.pow(g-w.r,2)+Math.pow(u-w.g,2)+Math.pow(b-w.b,2))<e){h=!0;break}h&&(o[c+3]=0,d++)}return console.log(`[ImageUtils] Removed background from ${d} pixels (4-corner sampling, tolerance: ${e})`),a.putImageData(r,0,0),n.toDataURL("image/png")}catch(i){return console.error("[ImageUtils] Error removing background:",i),t}}var Ka=require("@google/genai");async function fi(t,e,i=[],n={}){var a,r,o,s,l,d,p;try{if(!(t!=null&&t.trim()))throw new Error("Gemini API key is required");if(!(e!=null&&e.trim()))throw new Error("Prompt is required");for(let v=0;v<i.length;v++){let y=i[v];if(!y.base64||!y.mimeType)throw new Error(`Image ${v+1} is missing required data`);if(y.base64.length<1e3&&console.warn(`Image ${v+1} data appears very small, may be corrupted`),!y.mimeType.startsWith("image/"))throw new Error(`Image ${v+1} has invalid MIME type: ${y.mimeType}`)}let c=new Ka.GoogleGenAI({apiKey:t}),g="gemini-2.5-flash",u=[e];i.length>0&&i.forEach((v,y)=>{u.push({inlineData:{data:v.base64,mimeType:v.mimeType}}),console.log(`[Gemini] Added image ${y+1}: ${v.mimeType}, size: ${Math.round(v.base64.length/1024)}KB`)}),console.log(`[Gemini] Making request with ${i.length} images and prompt length: ${e.length}`);let b=await c.models.generateContent({model:g,contents:u}),h="",w=(o=(r=(a=b.candidates)==null?void 0:a[0])==null?void 0:r.content)==null?void 0:o.parts;if(w)for(let v of w)v.text&&(h+=v.text);if(!h.trim())throw new Error("Empty response from Gemini API");return console.log(`[Gemini] Response received, length: ${h.length}`),h}catch(c){throw console.error("[Gemini] API error:",c),(s=c.message)!=null&&s.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."):(p=c.message)!=null&&p.includes("SAFETY")?new Error("Content was flagged by Gemini safety filters. Please try with different images."):c}}var Ja=require("@google/genai");async function Mt(t,e,i=[],n={}){try{console.info("[GEMINI-REAL-SDK] Initializing GoogleGenAI...");let a=new Ja.GoogleGenAI({apiKey:t}),r=[{text:e}];i.length>0&&i.forEach((s,l)=>{console.info(`[GEMINI-REAL-SDK] Adding image part ${l}`),r.push({inlineData:{mimeType:s.mimeType,data:s.base64}})}),console.info("[GEMINI-REAL-SDK] Calling generateContent with model: gemini-2.5-flash-image");let o=await a.models.generateContent({model:"gemini-2.5-flash-image",contents:r});if(console.info("[GEMINI-REAL-SDK] Received response from model"),!o.candidates||!o.candidates[0]||!o.candidates[0].content||!o.candidates[0].content.parts)throw new Error("Gemini 2.5 Flash Image returned invalid response structure.");for(let s of o.candidates[0].content.parts)if(s.text)console.log(s.text);else if(s.inlineData){let l=s.inlineData.data,d=s.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 xs=require("pixi.js");Ke();fe();var Qa=require("pixi.js");var Es=require("pixi.js");fe();function ks(t){return new Promise((e,i)=>{let n=new FileReader;n.onerror=()=>i(new Error("FileReader failed")),n.onload=()=>e(String(n.result||"")),n.readAsDataURL(t)})}function Ms(t){var a;let[e,i]=t.split(","),n=e==null?void 0:e.match(/data:(.*?);base64/);return{base64:i!=null?i:"",mimeType:(a=n==null?void 0:n[1])!=null?a:"image/png"}}function Ps(t){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
|
${t?`
|
|
61
61
|
ADDITIONAL RULES/NOTES:
|
|
62
62
|
${t}`:""}
|
|
63
|
-
`.trim()}function er(){let t=[],e="",i=null;return{async addSources(n){let a=[];for(let r of n){let
|
|
63
|
+
`.trim()}function er(){let t=[],e="",i=null;return{async addSources(n){let a=[];for(let r of n){let o=await ks(r),s=Ms(o),l={id:`${Date.now()}-${Math.random().toString(16).slice(2)}`,name:r.name,base64:s.base64,mimeType:s.mimeType,dataUrl:o};t.push(l),a.push(l)}return a},getSources(){return t.slice()},async analyze(n,a,r){if(t.length===0)throw new Error("No screenshots to analyze.");let o=Ps(a),s=t.map(g=>({base64:g.base64,mimeType:g.mimeType})),l=await fi(n,o,s,{model:r}),d=e,p=[],c=l.split(`
|
|
64
64
|
`);for(let g of c)if(g.toLowerCase().startsWith("summary:"))d=g.slice(8).trim();else if(g.toLowerCase().includes("palette:")){let u=g.match(/#[0-9A-Fa-f]{6}/g);u&&u.forEach(b=>{p.includes(b.toUpperCase())||p.push(b.toUpperCase())})}return(!d||d===e)&&(d=l.split(`
|
|
65
|
-
Palette:`)[0].replace(/^Summary:\s*/i,"").trim()),i={summary:d,palette:p.slice(0,10)},i},setSummary(n){e=n,i&&(i={...i,summary:n})},getResult(){return i}}}var Le="handler_api_key_";var je=class{static setKey(e,i,n){try{let a={key:this.encryptKey(i),created:Date.now(),lastUsed:Date.now(),label:n||e},r=`${Le}${e}`;localStorage.setItem(r,JSON.stringify(a))}catch(a){console.error("[ApiKeyStorage] Failed to store API key:",a)}}static getKey(e){try{let i=`${Le}${e}`,n=localStorage.getItem(i);if(!n)return null;let a=JSON.parse(n);return a.lastUsed=Date.now(),localStorage.setItem(i,JSON.stringify(a)),this.decryptKey(a.key)}catch(i){return console.error("[ApiKeyStorage] Failed to retrieve API key:",i),null}}static hasKey(e){let i=`${Le}${e}`;return localStorage.getItem(i)!==null}static removeKey(e){try{let i=`${Le}${e}`;localStorage.removeItem(i)}catch(i){console.error("[ApiKeyStorage] Failed to remove API key:",i)}}static getStoredServices(){let e=[];try{for(let i=0;i<localStorage.length;i++){let n=localStorage.key(i);if(n&&n.startsWith(Le)){let a=n.substring(Le.length),r=localStorage.getItem(n);if(r){let
|
|
65
|
+
Palette:`)[0].replace(/^Summary:\s*/i,"").trim()),i={summary:d,palette:p.slice(0,10)},i},setSummary(n){e=n,i&&(i={...i,summary:n})},getResult(){return i}}}var Le="handler_api_key_";var je=class{static setKey(e,i,n){try{let a={key:this.encryptKey(i),created:Date.now(),lastUsed:Date.now(),label:n||e},r=`${Le}${e}`;localStorage.setItem(r,JSON.stringify(a))}catch(a){console.error("[ApiKeyStorage] Failed to store API key:",a)}}static getKey(e){try{let i=`${Le}${e}`,n=localStorage.getItem(i);if(!n)return null;let a=JSON.parse(n);return a.lastUsed=Date.now(),localStorage.setItem(i,JSON.stringify(a)),this.decryptKey(a.key)}catch(i){return console.error("[ApiKeyStorage] Failed to retrieve API key:",i),null}}static hasKey(e){let i=`${Le}${e}`;return localStorage.getItem(i)!==null}static removeKey(e){try{let i=`${Le}${e}`;localStorage.removeItem(i)}catch(i){console.error("[ApiKeyStorage] Failed to remove API key:",i)}}static getStoredServices(){let e=[];try{for(let i=0;i<localStorage.length;i++){let n=localStorage.key(i);if(n&&n.startsWith(Le)){let a=n.substring(Le.length),r=localStorage.getItem(n);if(r){let o=JSON.parse(r);e.push({service:a,label:o.label,created:o.created,lastUsed:o.lastUsed})}}}}catch(i){console.error("[ApiKeyStorage] Failed to get stored services:",i)}return e.sort((i,n)=>n.lastUsed-i.lastUsed)}static clearAll(){try{let e=[];for(let i=0;i<localStorage.length;i++){let n=localStorage.key(i);n&&n.startsWith(Le)&&e.push(n)}e.forEach(i=>localStorage.removeItem(i))}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(i){return console.warn("[ApiKeyStorage] Encryption failed, storing as-is:",i),e}}static decryptKey(e){try{let i=atob(e),n="handler_preview_salt_2024";return i.startsWith(n)?i.substring(n.length):i}catch(i){return console.warn("[ApiKeyStorage] Decryption failed, returning as-is:",i),e}}},mi=()=>je.getKey("gemini"),bi=(t,e)=>je.setKey("gemini",t,e),Is=()=>je.hasKey("gemini");window.ApiKeyStorage=je;window.getGeminiApiKey=mi;window.setGeminiApiKey=bi;window.hasGeminiApiKey=Is;var vi=class{constructor(){this.modal=null;this.options=null;this.analyzer=er();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 i,n;(i=this.promptInput)==null||i.focus(),(n=this.promptInput)==null||n.select()},100)}createModal(){var i;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">
|
|
@@ -141,14 +141,14 @@ Palette:`)[0].replace(/^Summary:\s*/i,"").trim()),i={summary:d,palette:p.slice(0
|
|
|
141
141
|
<button class="ai-btn primary" data-action="apply" disabled>Apply</button>
|
|
142
142
|
</div>
|
|
143
143
|
</div>
|
|
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"]'),i=this.modal.querySelector(".ai-strength-value");e==null||e.addEventListener("input",()=>{i.textContent=e.value}),this.modal.addEventListener("click",a=>{var
|
|
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"]'),i=this.modal.querySelector(".ai-strength-value");e==null||e.addEventListener("input",()=>{i.textContent=e.value}),this.modal.addEventListener("click",a=>{var s;let r=a.target;switch(r.dataset.action||((s=r.closest("[data-action]"))==null?void 0:s.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 r=a.target;if(r.classList.contains("ai-gallery-item")||r.closest(".ai-gallery-item")){let o=r.closest(".ai-gallery-item"),s=parseInt(o.dataset.index||"-1");s>=0&&this.selectImage(s)}}),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 i;let e=(i=this.modal)==null?void 0:i.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,i,n,a;if(!(!this.options||this.isGenerating)){this.isGenerating=!0,this.updateGenerateButton(),(e=this.loadingEl)==null||e.classList.remove("hidden"),(i=this.previewEl)==null||i.classList.add("hidden");try{let r=this.getApiKey();if(!r){alert("Please set your Gemini API key first. You can do this in the AI Creative Suite panel.");return}let
|
|
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,i,n,a;if(!(!this.options||this.isGenerating)){this.isGenerating=!0,this.updateGenerateButton(),(e=this.loadingEl)==null||e.classList.remove("hidden"),(i=this.previewEl)==null||i.classList.add("hidden");try{let r=this.getApiKey();if(!r){alert("Please set your Gemini API key first. You can do this in the AI Creative Suite panel.");return}let o=[];if(this.options.currentValue&&this.options.currentValue.startsWith("data:"))try{let d=await hi(this.options.currentValue);d&&(o=[{base64:d.base64,mimeType:d.mimeType}])}catch(d){console.warn("[AiEditorModal] Failed to load current image:",d)}let s=await Mt(r,this.currentPrompt,o,{aspectRatio:"1:1"}),l=await kt(s);this.generatedImages.push(l||s),this.selectedImageIndex=this.generatedImages.length-1,this.updateGallery(),this.updatePreview(),this.updateApplyButton()}catch(r){console.error("[AiEditorModal] Generation failed:",r),alert(`Generation failed: ${r instanceof Error?r.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((i,n)=>`
|
|
147
147
|
<div class="ai-gallery-item ${n===this.selectedImageIndex?"active":""}" data-index="${n}">
|
|
148
148
|
<img class="ai-gallery-thumb" src="${i}" 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 i;let e=(i=this.modal)==null?void 0:i.querySelector('[data-action="apply"]');e&&(e.disabled=this.selectedImageIndex<0)}applySelectedImage(){var i;if(this.selectedImageIndex<0||!((i=this.options)!=null&&i.onApply))return;let e=this.generatedImages[this.selectedImageIndex];this.options.onApply(e),this.close()}getApiKey(){let e=mi();if(e)return e;try{let i=this.analyzer.getResult();if(i&&i.apiKey)return bi(i.apiKey,"From Brand DNA"),i.apiKey}catch(i){console.warn("[AiEditorModal] Failed to get API key from brand DNA:",i)}return null}close(){this.modal&&this.modal.parentNode&&this.modal.parentNode.removeChild(this.modal),this.modal=null,this.options=null}},yi=null;window.__openAiEditor=function(t,e,i,n){yi||(yi=new vi),yi.open({objectId:t,initialPrompt:e,currentValue:i,path:n==null?void 0:n.path,onApply:a=>{if(n!=null&&n.path){let r=window.updateManager;if(r)r.updateProperty(t,n.path,a);else{let
|
|
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 i;let e=(i=this.modal)==null?void 0:i.querySelector('[data-action="apply"]');e&&(e.disabled=this.selectedImageIndex<0)}applySelectedImage(){var i;if(this.selectedImageIndex<0||!((i=this.options)!=null&&i.onApply))return;let e=this.generatedImages[this.selectedImageIndex];this.options.onApply(e),this.close()}getApiKey(){let e=mi();if(e)return e;try{let i=this.analyzer.getResult();if(i&&i.apiKey)return bi(i.apiKey,"From Brand DNA"),i.apiKey}catch(i){console.warn("[AiEditorModal] Failed to get API key from brand DNA:",i)}return null}close(){this.modal&&this.modal.parentNode&&this.modal.parentNode.removeChild(this.modal),this.modal=null,this.options=null}},yi=null;window.__openAiEditor=function(t,e,i,n){yi||(yi=new vi),yi.open({objectId:t,initialPrompt:e,currentValue:i,path:n==null?void 0:n.path,onApply:a=>{if(n!=null&&n.path){let r=window.updateManager;if(r)r.updateProperty(t,n.path,a);else{let o=window.getEditableObjectConfig,s=o==null?void 0:o(t);if(s){let l=n.path.split("."),d=s;for(let p=0;p<l.length-1;p++)d[l[p]]||(d[l[p]]={}),d=d[l[p]];d[l[l.length-1]]=a}}}window.dispatchEvent(new CustomEvent("inspector:refresh"))}})};xi();var Ei=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:i,objectId:n}=this.options,a=n||"Asset Preview",r=document.createElement("div");r.className="asset-preview-modal",r.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 ${i} 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 i=this.modal.querySelector('[data-action="edit"]');i&&i.addEventListener("click",()=>{this.openAiEditor(),this.close()})}openAssetEditor(){this.options&&Promise.resolve().then(()=>(
|
|
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 ${i} 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 i=this.modal.querySelector('[data-action="edit"]');i&&i.addEventListener("click",()=>{this.openAiEditor(),this.close()})}openAssetEditor(){this.options&&Promise.resolve().then(()=>(xi(),tr)).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:i=>{var n;(n=this.options)!=null&&n.onChange&&this.options.onChange(i)}})}close(){this.modal&&this.modal.parentNode&&this.modal.parentNode.removeChild(this.modal),this.modal=null,this.options=null}};window.openAssetPreview=function(t){new Ei().open(t)};var Si=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,i=this.canvas.width/this.canvas.height;e>i?(this.cropHeight=this.image.height,this.cropWidth=this.cropHeight*i,this.cropX=(this.image.width-this.cropWidth)/2,this.cropY=0):(this.cropWidth=this.image.width,this.cropHeight=this.cropWidth/i,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 i=this.image.width/this.image.height,n=this.cropX+this.cropWidth/2,a=this.cropY+this.cropHeight/2;e>i?(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,i=this.canvas.height/this.cropHeight;this.scale=Math.min(e,i)*.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,i=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,i,n,a),this.ctx.strokeStyle="#ffffff",this.ctx.lineWidth=2,this.ctx.strokeRect(e,i,n,a),this.ctx.fillStyle="#ffffff";let r=8;[[e,i],[e+n-r,i],[e,i+a-r],[e+n-r,i+a-r]].forEach(([o,l])=>{var d;(d=this.ctx)==null||d.fillRect(o,l,r,r)})}updatePreview(){if(!this.modal||!this.image)return;let e=this.modal.querySelector(".asset-crop-preview-canvas");if(!e)return;let i=e.getContext("2d");if(!i)return;let n=150;e.width=n,e.height=n;let a=n/this.cropWidth,r=n/this.cropHeight,s=Math.min(a,r),o=this.cropWidth*s,l=this.cropHeight*s,d=(n-o)/2,p=(n-l)/2;i.drawImage(this.image,this.cropX,this.cropY,this.cropWidth,this.cropHeight,d,p,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 i=this.modal.querySelector(".asset-crop-aspect-select");i==null||i.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 i=e.clientX-this.dragStartX,n=e.clientY-this.dragStartY;this.panX=this.lastPanX+i,this.panY=this.lastPanY+n,this.constrainPan(),this.render()}handleMouseUp(){this.isDragging=!1,this.canvas.style.cursor="grab"}handleWheel(e){e.preventDefault();let i=e.deltaY>0?.9:1.1;this.setZoom(this.scale*i)}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 i=e.touches[0].clientX-this.dragStartX,n=e.touches[0].clientY-this.dragStartY;this.panX=this.lastPanX+i,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 i;switch(e){case"1:1":i=1;break;case"4:3":i=4/3;break;case"16:9":i=16/9;break;case"3:2":i=3/2;break;default:i=void 0}i&&this.applyAspectRatio(i),this.fitToCanvas(),this.render()}updateZoomUI(){if(!this.modal)return;let e=this.modal.querySelector(".asset-crop-zoom-value"),i=this.modal.querySelector(".asset-crop-zoom-slider");e&&(e.textContent=`${this.scale.toFixed(1)}x`),i&&(i.value=this.scale.toString())}constrainPan(){if(!this.canvas)return;let e=this.cropWidth*this.scale,i=this.cropHeight*this.scale;this.panX=Math.max(this.canvas.width-e,Math.min(0,this.panX)),this.panY=Math.max(this.canvas.height-i,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"),i=e.getContext("2d");if(!i)return;e.width=this.cropWidth,e.height=this.cropHeight,i.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(t){new Si().open(t)};fe();fe();var ir=ae(require("lottie-web"),1);ti(Ha);typeof window!="undefined"&&!window.lottie&&(window.lottie=ir.default);gi();fe();var Ai=ya.version,Ro=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"]);ba();var cr={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"},dr=Math.random().toString(36).slice(2),He=null,ze={...cr},pr="web_embed",_i={},et,Ci=!1,Qe=!1,it=!1,ur=!1,Ii=1,It=0,jt=!1,pe=!1,De="",$e=Math.floor(window.innerWidth),Fe=Math.floor(window.innerHeight),ki=$e>Fe,ue=!1,tt=!1,nr=!1,ar=!1,Ti=!1,Ot=null,_e=null,Mi=!1,Pi=!1,Pt=new Map;function gr(){if(!_e)return null;let t=Date.now()-_e;return!Number.isFinite(t)||t<0?null:t}function Li(t){if(Mi)return;let e=gr();e!==null&&(Mi=!0,w("session_time",{duration_ms:e,reason:t}))}function rr(){if(He)return He;let t=document.createElement("div");return t.id="handler-root",t.setAttribute("data-handler-root","true"),document.body.appendChild(t),He=t,t}function Rt(t){switch(t){case"interaction":return"engagement";case"finish":return"complete";case"install":return"cta_click";default:return t}}function hr(t,e){return{event_name:t,ts:Date.now(),session_id:dr,deployment_id:ze.deployment_id,variant_id:ze.variant_id,export_profile_id:ze.profile_id,instance_id:ze.instance_id||"default",env:pr==="mraid"?"mraid":"web",attribution:et,payload:e}}function w(t,e){let i=Rt(t),n=hr(i,e);Jt(n,!!_i.analytics),bt(i,n),i!==t&&bt(t,n)}function nt(){Ot&&(Ot($e,Fe),Ot=null)}function Ne(t){Ii=t,w("volume",t)}function Be(t){t&&(ur=!0),!it&&(it=!0,w("pause"),Ne(0))}function at(t){!t&&ur||it&&(it=!1,w("resume"),Ne(Ii))}function me(t,e){$e=Math.floor(t||window.innerWidth),Fe=Math.floor(e||window.innerHeight),ki=$e>Fe,w("resize",{width:$e,height:Fe})}function jo(){if(Ma())try{let t=mraid.getMaxSize();me(t.width,t.height);let e=()=>{mraid.isViewable()&&mraid.getState()!=="hidden"?at():Be()};if(mraid.addEventListener("viewableChange",e),mraid.addEventListener("stateChange",e),mraid.addEventListener("sizeChange",()=>{let i=mraid.getMaxSize();me(i.width,i.height)}),mraid.getAudioVolume){let i=mraid.getAudioVolume();Ne(i?1:0)}if(mraid.addEventListener("audioVolumeChange",i=>{i!==null&&Ne(i>0?1:0)}),mraid.addEventListener("error",(i,n)=>{console.warn("mraid error:",i,"action:",n)}),jt=!0,mraid.isViewable()&&mraid.getState()!=="hidden")ue=!0,w("boot"),w("view"),w("ready"),pe=!0,nt();else{let i=()=>{ue=!0,w("boot"),w("view"),w("ready"),pe=!0,nt()};mraid.addEventListener("ready",i)}}catch(t){console.warn("MRAID hook skipped",t)}}function zo(){if(Pa())try{let t=dapi.getScreenSize();me(t.width,t.height),dapi.addEventListener("viewableChange",i=>{i.isViewable?at():Be()}),dapi.addEventListener("adResized",i=>{let n=dapi.getScreenSize();me(i.width||n.width,i.height||n.height)});let e=dapi.getAudioVolume();if(Ne(e?1:0),dapi.addEventListener("audioVolumeChange",i=>Ne(i?1:0)),jt=!0,dapi.isViewable())ue=!0,w("boot"),w("view"),w("ready"),pe=!0,nt();else{let i=()=>{ue=!0,w("boot"),w("view"),w("ready"),pe=!0,nt()};dapi.addEventListener("ready",i)}}catch(t){console.warn("DAPI hook skipped",t)}}function sr(){let t=()=>{ue||document.visibilityState==="visible"&&(document.readyState==="complete"||document.readyState==="interactive")&&(ue=!0,w("boot"),w("view"),w("ready"),pe=!0,nt(),tt&&(tt=!1,J.start()))};window.addEventListener("resize",()=>me()),document.addEventListener("visibilitychange",()=>{document.visibilityState==="visible"?(at(),t()):Be()}),document.readyState==="complete"||document.readyState==="interactive"?t():window.addEventListener("load",t),jt=!0}function Do(){let t=e=>{typeof TouchEvent!="undefined"&&e instanceof TouchEvent&&(nr=!0),!(nr&&e instanceof MouseEvent)&&(It+=1,Pi||(Pi=!0,w("first_interaction",{count:It})),w("interaction",It))};document.addEventListener("mousedown",t),document.addEventListener("touchstart",t)}function or(t){var n,a,r,s,o,l,d,p,c,g,u,b;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(t||"");else if(e==="dapi"&&typeof dapi!="undefined")dapi.openStoreUrl();else if(Oe())(r=(a=window.TJ_API)==null?void 0:a.click)==null||r.call(a);else if(Ia())(o=(s=window.FbPlayableAd)==null?void 0:s.onCTAClick)==null||o.call(s);else if(za())(d=(l=window.ScPlayableAd)==null?void 0:l.onCTAClick)==null||d.call(l);else if(ja())try{(c=(p=window.smxTracking)==null?void 0:p.redirect)==null||c.call(p)}catch(h){console.warn("Smadex redirect failed",h)}else if(Oa()){let h=window.ExitApi;h&&typeof h.exit=="function"?h.exit(t||De||""):t&&window.open(t)}else Ie()?(g=window.install)==null||g.call(window):Ra()?(u=window.openAppStore)==null||u.call(window):Zt()?(b=parent==null?void 0:parent.postMessage)==null||b.call(parent,"download","*"):t&&window.open(t)}function Ho(){let t=typeof AD_NETWORK!="undefined"?AD_NETWORK:"web_embed",e=i=>{if(!i)return;let n=new Image;n.src=i};if(t==="bigabid"){let i=window.BIGABID_BIDTIMEMACROS;if(!i)return;B("view",()=>e(i.mraid_viewable)),B("start",()=>e(i.game_viewable)),B("engagement",()=>e(i.engagement));let n=()=>e(i.complete);B("complete",n),mt("engagement",a=>{var r;((r=a==null?void 0:a.payload)==null?void 0:r.count)>3&&n()}),B("cta_click",()=>e(i.click))}else if(t==="inmobi"){let i=window.INMOBI_DSPMACROS;if(!i)return;B("view",()=>e(i.Ad_Load_Start)),B("start",()=>e(i.Ad_Viewable)),B("engagement",()=>e(i.First_Engagement)),B("complete",()=>e(i.Gameplay_Complete)),B("cta_click",()=>e(i.DSP_Click)),B("start",()=>{[5,10,15,20,25,30].forEach(n=>setTimeout(()=>e(i[`Spent_${n}_Seconds`]),n*1e3))})}}function $o(){if(!Oe())return;let t=window.TJ_API;t&&t.setPlayableAPI&&t.setPlayableAPI({skipAd:()=>{try{J.finish()}catch(e){console.warn("Tapjoy skip failed",e)}}})}function lr(){var e,i,n;let t=window.TJ_API;(e=t==null?void 0:t.objectiveComplete)==null||e.call(t),(i=t==null?void 0:t.playableFinished)==null||i.call(t),(n=t==null?void 0:t.gameplayFinished)==null||n.call(t)}function Fo(){Ie()&&(window.mintGameStart=()=>{at(!0),me()},window.mintGameClose=()=>{Be(!0)})}function No(){if(!Qt())return;let t=window.NUC;!t||!t.trigger||(J.on("cta_click",()=>{var e,i;return(i=(e=t.trigger).convert)==null?void 0:i.call(e,De)}),J.on("complete",()=>{var e,i;return(i=(e=t.trigger).tryAgain)==null?void 0:i.call(e)}))}var J={init(t={},e){var i;if(pr=t.profile||"web_embed",_i=t.consent||{},ze={...cr,...t.ids||{}},He=t.rootEl||He,et=void 0,da((i=t.telemetry)!=null&&i.endpoint?t.telemetry:null),_e=null,Mi=!1,Pi=!1,Pt.clear(),De=t.destinationUrl||(/android/i.test(navigator.userAgent)?"https://play.google.com/store":"https://www.apple.com/app-store/"),e&&(Ot=e),w("init"),document.body.oncontextmenu=()=>!1,rr(),Go(He),Da(),jo(),zo(),!jt){if(document.readyState==="complete")sr();else if(!ar){ar=!0;let n=()=>{sr(),window.removeEventListener("load",n),document.removeEventListener("DOMContentLoaded",n)};window.addEventListener("load",n),document.addEventListener("DOMContentLoaded",n)}}Do(),Ho(),$o(),Fo(),No(),console.log(`%c @handler/playable-sdk %c v${Ai} `,"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;"),ue&&!pe&&(w("boot"),w("view"),w("ready"),tt&&(tt=!1,J.start()),pe=!0),pe=ue},getRoot(){return rr()},get version(){return Ai},get maxWidth(){return $e},get maxHeight(){return Fe},get isLandscape(){return ki},get isReady(){return pe},get isStarted(){return Ci},get isPaused(){return it},get isFinished(){return Qe},get volume(){return Ii},get interactions(){return It},on(t,e){mt(Rt(t),e)},off(t,e){Kt(Rt(t),e)},start(){var t,e;if(!Ci){if(!ue){tt=!0;return}if(Ci=!0,_e||(_e=Date.now()),w("start"),me(),Ie())Be(),(t=window.gameReady)==null||t.call(window);else if(Oe()){let i=window.TJ_API;(e=i==null?void 0:i.setPlayableBuild)==null||e.call(i,{orientation:ki?"landscape":"portrait",buildID:Ai})}}},finish(){var t,e;Qe||(Qe=!0,w("complete"),Li("complete"),Ie()?(t=window.gameEnd)==null||t.call(window):Zt()?(e=parent==null?void 0:parent.postMessage)==null||e.call(parent,"complete","*"):Oe()&&lr())},install(t){if(!Qe){Qe=!0,Oe()?(lr(),setTimeout(()=>J.install(t),300)):(w("complete"),setTimeout(()=>J.install(t),0));return}Ti||(Ti=!0,setTimeout(()=>Ti=!1,500),w("cta_click"),w("conversion"),Li("cta"),or(t||De))},emit(t,e){let i=Rt(t);if(!Ro.has(i)&&i!=="resize"&&i!=="volume"&&!i.startsWith("custom."))throw new Error(`Event ${t} must be canonical or namespaced as custom.<mechanic_id>.<event>`);let n=hr(i,e);Jt(n,!!_i.analytics),bt(i,n)},gameStart(){J.start()},gameEnd(){J.finish()},ctaClick(t,e){w("cta_click",{url:t||De,manual:!0}),(e==null?void 0:e.open)!==!1&&or(t||De)},ctaShow(t){w("cta_show",t)},ctaDismiss(t){w("cta_dismiss",t)},getGameTimeMs(){return gr()},endSession(t="manual"){Li(t)},setAttribution(t){et=t},abTest(t,e){if(!t)throw new Error("abTest requires experimentId");if(!Array.isArray(e)||e.length<2)throw new Error("abTest requires at least 2 variants");let i=Math.abs(Bo(`${dr}:${t}`))%e.length,n=e[i];return et={...et||{},experiment_id:t},ze.variant_id=n,w("ab_assign",{experiment_id:t,variant_id:n}),n},levelStart(t,e){_e||(_e=Date.now()),w("level_start",{level_id:t,...e})},levelComplete(t,e){w("level_complete",{level_id:t,...e})},levelFail(t,e){w("level_fail",{level_id:t,...e})},checkpoint(t,e){w("checkpoint",{checkpoint_id:t,...e})},reward(t,e){w("reward",{reward_id:t,...e})},tutorialStart(t,e){w("tutorial_start",{step_id:t,...e})},tutorialComplete(t,e){w("tutorial_complete",{step_id:t,...e})},tutorialSkip(t,e){w("tutorial_skip",{step_id:t,...e})},timerStart(t){t&&Pt.set(t,Date.now())},timerEnd(t,e="custom",i){if(!t)return;let n=Pt.get(t);if(!n)return;Pt.delete(t);let a=Date.now()-n;if(!(!Number.isFinite(a)||a<0)){if(e==="custom"){w("engagement",{action:"timer",key:t,duration_ms:a,...i});return}w(e,{key:t,duration_ms:a,...i})}},fps(t,e){w("fps",{value:t,...e})},memory(t,e){w("memory",{bytes:t,...e})},assetLoadStart(t,e){w("asset_load_start",{asset_id:t,...e})},assetLoadComplete(t,e){w("asset_load_complete",{asset_id:t,...e})},reportError(t,e,i){w("error",{code:t,message:e,...i})},retry(){var t,e,i;if(Ie())(t=window.gameRetry)==null||t.call(window);else if(Qt()){let n=window.NUC;(i=(e=n==null?void 0:n.trigger)==null?void 0:e.tryAgain)==null||i.call(e)}w("engagement",{action:"retry"})},pause(){Be(!0)},resume(){at(!0)},resize(t,e){me(t,e)}},Re=J;function Bo(t){let e=2166136261;for(let i=0;i<t.length;i++)e^=t.charCodeAt(i),e=Math.imul(e,16777619);return e|0}function Go(t){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,i=this.canvas.width/this.canvas.height;e>i?(this.cropHeight=this.image.height,this.cropWidth=this.cropHeight*i,this.cropX=(this.image.width-this.cropWidth)/2,this.cropY=0):(this.cropWidth=this.image.width,this.cropHeight=this.cropWidth/i,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 i=this.image.width/this.image.height,n=this.cropX+this.cropWidth/2,a=this.cropY+this.cropHeight/2;e>i?(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,i=this.canvas.height/this.cropHeight;this.scale=Math.min(e,i)*.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,i=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,i,n,a),this.ctx.strokeStyle="#ffffff",this.ctx.lineWidth=2,this.ctx.strokeRect(e,i,n,a),this.ctx.fillStyle="#ffffff";let r=8;[[e,i],[e+n-r,i],[e,i+a-r],[e+n-r,i+a-r]].forEach(([s,l])=>{var d;(d=this.ctx)==null||d.fillRect(s,l,r,r)})}updatePreview(){if(!this.modal||!this.image)return;let e=this.modal.querySelector(".asset-crop-preview-canvas");if(!e)return;let i=e.getContext("2d");if(!i)return;let n=150;e.width=n,e.height=n;let a=n/this.cropWidth,r=n/this.cropHeight,o=Math.min(a,r),s=this.cropWidth*o,l=this.cropHeight*o,d=(n-s)/2,p=(n-l)/2;i.drawImage(this.image,this.cropX,this.cropY,this.cropWidth,this.cropHeight,d,p,s,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 i=this.modal.querySelector(".asset-crop-aspect-select");i==null||i.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 i=e.clientX-this.dragStartX,n=e.clientY-this.dragStartY;this.panX=this.lastPanX+i,this.panY=this.lastPanY+n,this.constrainPan(),this.render()}handleMouseUp(){this.isDragging=!1,this.canvas.style.cursor="grab"}handleWheel(e){e.preventDefault();let i=e.deltaY>0?.9:1.1;this.setZoom(this.scale*i)}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 i=e.touches[0].clientX-this.dragStartX,n=e.touches[0].clientY-this.dragStartY;this.panX=this.lastPanX+i,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 i;switch(e){case"1:1":i=1;break;case"4:3":i=4/3;break;case"16:9":i=16/9;break;case"3:2":i=3/2;break;default:i=void 0}i&&this.applyAspectRatio(i),this.fitToCanvas(),this.render()}updateZoomUI(){if(!this.modal)return;let e=this.modal.querySelector(".asset-crop-zoom-value"),i=this.modal.querySelector(".asset-crop-zoom-slider");e&&(e.textContent=`${this.scale.toFixed(1)}x`),i&&(i.value=this.scale.toString())}constrainPan(){if(!this.canvas)return;let e=this.cropWidth*this.scale,i=this.cropHeight*this.scale;this.panX=Math.max(this.canvas.width-e,Math.min(0,this.panX)),this.panY=Math.max(this.canvas.height-i,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"),i=e.getContext("2d");if(!i)return;e.width=this.cropWidth,e.height=this.cropHeight,i.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(t){new Si().open(t)};fe();fe();var ir=ae(require("lottie-web"),1);ti($a);typeof window!="undefined"&&!window.lottie&&(window.lottie=ir.default);gi();fe();var Ai=ya.version,Rs=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"]);ba();var cr={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"},dr=Math.random().toString(36).slice(2),$e=null,ze={...cr},pr="web_embed",_i={},et,Ci=!1,Qe=!1,it=!1,ur=!1,Ii=1,It=0,jt=!1,pe=!1,De="",He=Math.floor(window.innerWidth),Fe=Math.floor(window.innerHeight),ki=He>Fe,ue=!1,tt=!1,nr=!1,ar=!1,Ti=!1,Ot=null,_e=null,Mi=!1,Pi=!1,Pt=new Map;function gr(){if(!_e)return null;let t=Date.now()-_e;return!Number.isFinite(t)||t<0?null:t}function Li(t){if(Mi)return;let e=gr();e!==null&&(Mi=!0,x("session_time",{duration_ms:e,reason:t}))}function rr(){if($e)return $e;let t=document.createElement("div");return t.id="handler-root",t.setAttribute("data-handler-root","true"),document.body.appendChild(t),$e=t,t}function Rt(t){switch(t){case"interaction":return"engagement";case"finish":return"complete";case"install":return"cta_click";default:return t}}function hr(t,e){return{event_name:t,ts:Date.now(),session_id:dr,deployment_id:ze.deployment_id,variant_id:ze.variant_id,export_profile_id:ze.profile_id,instance_id:ze.instance_id||"default",env:pr==="mraid"?"mraid":"web",attribution:et,payload:e}}function x(t,e){let i=Rt(t),n=hr(i,e);Jt(n,!!_i.analytics),bt(i,n),i!==t&&bt(t,n)}function nt(){Ot&&(Ot(He,Fe),Ot=null)}function Ne(t){Ii=t,x("volume",t)}function Be(t){t&&(ur=!0),!it&&(it=!0,x("pause"),Ne(0))}function at(t){!t&&ur||it&&(it=!1,x("resume"),Ne(Ii))}function me(t,e){He=Math.floor(t||window.innerWidth),Fe=Math.floor(e||window.innerHeight),ki=He>Fe,x("resize",{width:He,height:Fe})}function js(){if(Ma())try{let t=mraid.getMaxSize();me(t.width,t.height);let e=()=>{mraid.isViewable()&&mraid.getState()!=="hidden"?at():Be()};if(mraid.addEventListener("viewableChange",e),mraid.addEventListener("stateChange",e),mraid.addEventListener("sizeChange",()=>{let i=mraid.getMaxSize();me(i.width,i.height)}),mraid.getAudioVolume){let i=mraid.getAudioVolume();Ne(i?1:0)}if(mraid.addEventListener("audioVolumeChange",i=>{i!==null&&Ne(i>0?1:0)}),mraid.addEventListener("error",(i,n)=>{console.warn("mraid error:",i,"action:",n)}),jt=!0,mraid.isViewable()&&mraid.getState()!=="hidden")ue=!0,x("boot"),x("view"),x("ready"),pe=!0,nt();else{let i=()=>{ue=!0,x("boot"),x("view"),x("ready"),pe=!0,nt()};mraid.addEventListener("ready",i)}}catch(t){console.warn("MRAID hook skipped",t)}}function zs(){if(Pa())try{let t=dapi.getScreenSize();me(t.width,t.height),dapi.addEventListener("viewableChange",i=>{i.isViewable?at():Be()}),dapi.addEventListener("adResized",i=>{let n=dapi.getScreenSize();me(i.width||n.width,i.height||n.height)});let e=dapi.getAudioVolume();if(Ne(e?1:0),dapi.addEventListener("audioVolumeChange",i=>Ne(i?1:0)),jt=!0,dapi.isViewable())ue=!0,x("boot"),x("view"),x("ready"),pe=!0,nt();else{let i=()=>{ue=!0,x("boot"),x("view"),x("ready"),pe=!0,nt()};dapi.addEventListener("ready",i)}}catch(t){console.warn("DAPI hook skipped",t)}}function or(){let t=()=>{ue||document.visibilityState==="visible"&&(document.readyState==="complete"||document.readyState==="interactive")&&(ue=!0,x("boot"),x("view"),x("ready"),pe=!0,nt(),tt&&(tt=!1,J.start()))};window.addEventListener("resize",()=>me()),document.addEventListener("visibilitychange",()=>{document.visibilityState==="visible"?(at(),t()):Be()}),document.readyState==="complete"||document.readyState==="interactive"?t():window.addEventListener("load",t),jt=!0}function Ds(){let t=e=>{typeof TouchEvent!="undefined"&&e instanceof TouchEvent&&(nr=!0),!(nr&&e instanceof MouseEvent)&&(It+=1,Pi||(Pi=!0,x("first_interaction",{count:It})),x("interaction",It))};document.addEventListener("mousedown",t),document.addEventListener("touchstart",t)}function sr(t){var n,a,r,o,s,l,d,p,c,g,u,b;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(t||"");else if(e==="dapi"&&typeof dapi!="undefined")dapi.openStoreUrl();else if(Oe())(r=(a=window.TJ_API)==null?void 0:a.click)==null||r.call(a);else if(Ia())(s=(o=window.FbPlayableAd)==null?void 0:o.onCTAClick)==null||s.call(o);else if(za())(d=(l=window.ScPlayableAd)==null?void 0:l.onCTAClick)==null||d.call(l);else if(ja())try{(c=(p=window.smxTracking)==null?void 0:p.redirect)==null||c.call(p)}catch(h){console.warn("Smadex redirect failed",h)}else if(Oa()){let h=window.ExitApi;h&&typeof h.exit=="function"?h.exit(t||De||""):t&&window.open(t)}else Ie()?(g=window.install)==null||g.call(window):Ra()?(u=window.openAppStore)==null||u.call(window):Zt()?(b=parent==null?void 0:parent.postMessage)==null||b.call(parent,"download","*"):t&&window.open(t)}function $s(){let t=typeof AD_NETWORK!="undefined"?AD_NETWORK:"web_embed",e=i=>{if(!i)return;let n=new Image;n.src=i};if(t==="bigabid"){let i=window.BIGABID_BIDTIMEMACROS;if(!i)return;B("view",()=>e(i.mraid_viewable)),B("start",()=>e(i.game_viewable)),B("engagement",()=>e(i.engagement));let n=()=>e(i.complete);B("complete",n),mt("engagement",a=>{var r;((r=a==null?void 0:a.payload)==null?void 0:r.count)>3&&n()}),B("cta_click",()=>e(i.click))}else if(t==="inmobi"){let i=window.INMOBI_DSPMACROS;if(!i)return;B("view",()=>e(i.Ad_Load_Start)),B("start",()=>e(i.Ad_Viewable)),B("engagement",()=>e(i.First_Engagement)),B("complete",()=>e(i.Gameplay_Complete)),B("cta_click",()=>e(i.DSP_Click)),B("start",()=>{[5,10,15,20,25,30].forEach(n=>setTimeout(()=>e(i[`Spent_${n}_Seconds`]),n*1e3))})}}function Hs(){if(!Oe())return;let t=window.TJ_API;t&&t.setPlayableAPI&&t.setPlayableAPI({skipAd:()=>{try{J.finish()}catch(e){console.warn("Tapjoy skip failed",e)}}})}function lr(){var e,i,n;let t=window.TJ_API;(e=t==null?void 0:t.objectiveComplete)==null||e.call(t),(i=t==null?void 0:t.playableFinished)==null||i.call(t),(n=t==null?void 0:t.gameplayFinished)==null||n.call(t)}function Fs(){Ie()&&(window.mintGameStart=()=>{at(!0),me()},window.mintGameClose=()=>{Be(!0)})}function Ns(){if(!Qt())return;let t=window.NUC;!t||!t.trigger||(J.on("cta_click",()=>{var e,i;return(i=(e=t.trigger).convert)==null?void 0:i.call(e,De)}),J.on("complete",()=>{var e,i;return(i=(e=t.trigger).tryAgain)==null?void 0:i.call(e)}))}var J={init(t={},e){var i;if(pr=t.profile||"web_embed",_i=t.consent||{},ze={...cr,...t.ids||{}},$e=t.rootEl||$e,et=void 0,da((i=t.telemetry)!=null&&i.endpoint?t.telemetry:null),_e=null,Mi=!1,Pi=!1,Pt.clear(),De=t.destinationUrl||(/android/i.test(navigator.userAgent)?"https://play.google.com/store":"https://www.apple.com/app-store/"),e&&(Ot=e),x("init"),document.body.oncontextmenu=()=>!1,rr(),Gs($e),Da(),js(),zs(),!jt){if(document.readyState==="complete")or();else if(!ar){ar=!0;let n=()=>{or(),window.removeEventListener("load",n),document.removeEventListener("DOMContentLoaded",n)};window.addEventListener("load",n),document.addEventListener("DOMContentLoaded",n)}}Ds(),$s(),Hs(),Fs(),Ns(),console.log(`%c @handler/playable-sdk %c v${Ai} `,"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;"),ue&&!pe&&(x("boot"),x("view"),x("ready"),tt&&(tt=!1,J.start()),pe=!0),pe=ue},getRoot(){return rr()},get version(){return Ai},get maxWidth(){return He},get maxHeight(){return Fe},get isLandscape(){return ki},get isReady(){return pe},get isStarted(){return Ci},get isPaused(){return it},get isFinished(){return Qe},get volume(){return Ii},get interactions(){return It},on(t,e){mt(Rt(t),e)},off(t,e){Kt(Rt(t),e)},start(){var t,e;if(!Ci){if(!ue){tt=!0;return}if(Ci=!0,_e||(_e=Date.now()),x("start"),me(),Ie())Be(),(t=window.gameReady)==null||t.call(window);else if(Oe()){let i=window.TJ_API;(e=i==null?void 0:i.setPlayableBuild)==null||e.call(i,{orientation:ki?"landscape":"portrait",buildID:Ai})}}},finish(){var t,e;Qe||(Qe=!0,x("complete"),Li("complete"),Ie()?(t=window.gameEnd)==null||t.call(window):Zt()?(e=parent==null?void 0:parent.postMessage)==null||e.call(parent,"complete","*"):Oe()&&lr())},install(t){if(!Qe){Qe=!0,Oe()?(lr(),setTimeout(()=>J.install(t),300)):(x("complete"),setTimeout(()=>J.install(t),0));return}Ti||(Ti=!0,setTimeout(()=>Ti=!1,500),x("cta_click"),x("conversion"),Li("cta"),sr(t||De))},emit(t,e){let i=Rt(t);if(!Rs.has(i)&&i!=="resize"&&i!=="volume"&&!i.startsWith("custom."))throw new Error(`Event ${t} must be canonical or namespaced as custom.<mechanic_id>.<event>`);let n=hr(i,e);Jt(n,!!_i.analytics),bt(i,n)},gameStart(){J.start()},gameEnd(){J.finish()},ctaClick(t,e){x("cta_click",{url:t||De,manual:!0}),(e==null?void 0:e.open)!==!1&&sr(t||De)},ctaShow(t){x("cta_show",t)},ctaDismiss(t){x("cta_dismiss",t)},getGameTimeMs(){return gr()},endSession(t="manual"){Li(t)},setAttribution(t){et=t},abTest(t,e){if(!t)throw new Error("abTest requires experimentId");if(!Array.isArray(e)||e.length<2)throw new Error("abTest requires at least 2 variants");let i=Math.abs(Bs(`${dr}:${t}`))%e.length,n=e[i];return et={...et||{},experiment_id:t},ze.variant_id=n,x("ab_assign",{experiment_id:t,variant_id:n}),n},levelStart(t,e){_e||(_e=Date.now()),x("level_start",{level_id:t,...e})},levelComplete(t,e){x("level_complete",{level_id:t,...e})},levelFail(t,e){x("level_fail",{level_id:t,...e})},checkpoint(t,e){x("checkpoint",{checkpoint_id:t,...e})},reward(t,e){x("reward",{reward_id:t,...e})},tutorialStart(t,e){x("tutorial_start",{step_id:t,...e})},tutorialComplete(t,e){x("tutorial_complete",{step_id:t,...e})},tutorialSkip(t,e){x("tutorial_skip",{step_id:t,...e})},timerStart(t){t&&Pt.set(t,Date.now())},timerEnd(t,e="custom",i){if(!t)return;let n=Pt.get(t);if(!n)return;Pt.delete(t);let a=Date.now()-n;if(!(!Number.isFinite(a)||a<0)){if(e==="custom"){x("engagement",{action:"timer",key:t,duration_ms:a,...i});return}x(e,{key:t,duration_ms:a,...i})}},fps(t,e){x("fps",{value:t,...e})},memory(t,e){x("memory",{bytes:t,...e})},assetLoadStart(t,e){x("asset_load_start",{asset_id:t,...e})},assetLoadComplete(t,e){x("asset_load_complete",{asset_id:t,...e})},reportError(t,e,i){x("error",{code:t,message:e,...i})},retry(){var t,e,i;if(Ie())(t=window.gameRetry)==null||t.call(window);else if(Qt()){let n=window.NUC;(i=(e=n==null?void 0:n.trigger)==null?void 0:e.tryAgain)==null||i.call(e)}x("engagement",{action:"retry"})},pause(){Be(!0)},resume(){at(!0)},resize(t,e){me(t,e)}},Re=J;function Bs(t){let e=2166136261;for(let i=0;i<t.length;i++)e^=t.charCodeAt(i),e=Math.imul(e,16777619);return e|0}function Gs(t){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,7 +242,7 @@ 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
|
-
`,t.appendChild(e)}var Oi=(n=>(n[n.PHONE_TALL=0]="PHONE_TALL",n[n.TABLET=1]="TABLET",n[n.LANDSCAPE=2]="LANDSCAPE",n))(Oi||{});function zt(t,e){let i=t/e;return i<=.62?0:i<=.85?1:2}var Ge=class{constructor(e,i){this.root=e,this.stage=i,this.uiFrame=document.createElement("div"),this.uiFrame.style.position="absolute",this.uiFrame.style.top="0",this.uiFrame.style.bottom="0",this.uiFrame.style.left="50%",this.uiFrame.style.transform="translateX(-50%)",this.uiFrame.style.width="100%",this.uiFrame.style.maxWidth="420px",this.uiFrame.style.pointerEvents="none",this.stage.appendChild(this.uiFrame),this.uiContainer=document.createElement("div"),this.uiContainer.setAttribute("style",["position:absolute","inset:0","display:flex","flex-direction:column","justify-content:flex-start","gap:12px","pointer-events:none","padding:20px 16px","padding-bottom:clamp(24px, 6vh, 96px)","box-sizing:border-box","z-index:2"].join(";")),this.uiFrame.appendChild(this.uiContainer),this.updateLayout()}getUIFrame(){return this.uiFrame}getUIContainer(){return this.uiContainer}updateLayout(){let e=this.stage.getBoundingClientRect(),i=zt(e.width,e.height);i===0?this.uiFrame.style.maxWidth="420px":i===1?this.uiFrame.style.maxWidth="520px":this.uiFrame.style.maxWidth="640px"}getAspectClass(){let e=this.stage.getBoundingClientRect();return zt(e.width,e.height)}};async function fr(t,e={}){let i=()=>{let f=t.getBoundingClientRect(),m=Math.floor(f.width),E=Math.floor(f.height);return(m<=0||!isFinite(m)||m!==m)&&(m=t.clientWidth||window.innerWidth||320),(E<=0||!isFinite(E)||E!==E)&&(E=t.clientHeight||window.innerHeight||480),(m<=0||!isFinite(m)||m!==m)&&(m=320),(E<=0||!isFinite(E)||E!==E)&&(E=480),console.log("[THREE-BASE] getSize result:",{width:m,height:E,boundingRect:{width:f.width,height:f.height},clientSize:{width:t.clientWidth,height:t.clientHeight},styleWidth:t.style.width,styleHeight:t.style.height,note:"Using boundingRect as primary source (actual rendered size)"}),{width:m,height:E}},n=t.style.width&&!t.style.width.includes("%"),a=t.style.height&&!t.style.height.includes("%");t.style.position||(t.style.position="relative"),t.style.display||(t.style.display="block"),t.style.width=t.style.width||"100%",t.style.height=t.style.height||"100%",t.style.minWidth="100%",t.style.minHeight="100%",t.style.maxWidth="100%",t.style.maxHeight="100%",t.style.boxSizing="border-box",t.style.overflow="hidden",t.style.margin="0",t.style.padding="0",t.style.border="none";let r=e.background||"linear-gradient(160deg, #0d1020, #0f1c2f)";t.style.setProperty("background",r,"important"),t.style.setProperty("background-size","cover","important"),t.style.setProperty("background-position","center","important"),t.style.setProperty("background-repeat","no-repeat","important");let
|
|
245
|
+
`,t.appendChild(e)}var Oi=(n=>(n[n.PHONE_TALL=0]="PHONE_TALL",n[n.TABLET=1]="TABLET",n[n.LANDSCAPE=2]="LANDSCAPE",n))(Oi||{});function zt(t,e){let i=t/e;return i<=.62?0:i<=.85?1:2}var Ge=class{constructor(e,i){this.root=e,this.stage=i,this.uiFrame=document.createElement("div"),this.uiFrame.style.position="absolute",this.uiFrame.style.top="0",this.uiFrame.style.bottom="0",this.uiFrame.style.left="50%",this.uiFrame.style.transform="translateX(-50%)",this.uiFrame.style.width="100%",this.uiFrame.style.maxWidth="420px",this.uiFrame.style.pointerEvents="none",this.stage.appendChild(this.uiFrame),this.uiContainer=document.createElement("div"),this.uiContainer.setAttribute("style",["position:absolute","inset:0","display:flex","flex-direction:column","justify-content:flex-start","gap:12px","pointer-events:none","padding:20px 16px","padding-bottom:clamp(24px, 6vh, 96px)","box-sizing:border-box","z-index:2"].join(";")),this.uiFrame.appendChild(this.uiContainer),this.updateLayout()}getUIFrame(){return this.uiFrame}getUIContainer(){return this.uiContainer}updateLayout(){let e=this.stage.getBoundingClientRect(),i=zt(e.width,e.height);i===0?this.uiFrame.style.maxWidth="420px":i===1?this.uiFrame.style.maxWidth="520px":this.uiFrame.style.maxWidth="640px"}getAspectClass(){let e=this.stage.getBoundingClientRect();return zt(e.width,e.height)}};async function fr(t,e={}){let i=()=>{let f=t.getBoundingClientRect(),m=Math.floor(f.width),E=Math.floor(f.height);return(m<=0||!isFinite(m)||m!==m)&&(m=t.clientWidth||window.innerWidth||320),(E<=0||!isFinite(E)||E!==E)&&(E=t.clientHeight||window.innerHeight||480),(m<=0||!isFinite(m)||m!==m)&&(m=320),(E<=0||!isFinite(E)||E!==E)&&(E=480),console.log("[THREE-BASE] getSize result:",{width:m,height:E,boundingRect:{width:f.width,height:f.height},clientSize:{width:t.clientWidth,height:t.clientHeight},styleWidth:t.style.width,styleHeight:t.style.height,note:"Using boundingRect as primary source (actual rendered size)"}),{width:m,height:E}},n=t.style.width&&!t.style.width.includes("%"),a=t.style.height&&!t.style.height.includes("%");t.style.position||(t.style.position="relative"),t.style.display||(t.style.display="block"),t.style.width=t.style.width||"100%",t.style.height=t.style.height||"100%",t.style.minWidth="100%",t.style.minHeight="100%",t.style.maxWidth="100%",t.style.maxHeight="100%",t.style.boxSizing="border-box",t.style.overflow="hidden",t.style.margin="0",t.style.padding="0",t.style.border="none";let r=e.background||"linear-gradient(160deg, #0d1020, #0f1c2f)";t.style.setProperty("background",r,"important"),t.style.setProperty("background-size","cover","important"),t.style.setProperty("background-position","center","important"),t.style.setProperty("background-repeat","no-repeat","important");let o=document.createElement("div");o.style.cssText=`
|
|
246
246
|
position: absolute !important;
|
|
247
247
|
inset: 0 !important;
|
|
248
248
|
width: 100% !important;
|
|
@@ -263,9 +263,9 @@ Style guidelines: ${n.summary}`;this.promptInput.value=a,this.currentPrompt=a}}c
|
|
|
263
263
|
padding: 0 !important;
|
|
264
264
|
border: none !important;
|
|
265
265
|
overflow: hidden !important;
|
|
266
|
-
`,t.appendChild(
|
|
266
|
+
`,t.appendChild(o);let s=document.createElement("div");s.setAttribute("style",["position:absolute","inset:0","width:100%","height:100%","min-width:100%","min-height:100%","max-width:100%","max-height:100%","pointer-events:auto","box-sizing:border-box","margin:0","padding:0","overflow:hidden"].join(";")),o.appendChild(s);let l=new V.Scene,{width:d,height:p}=i(),c=new V.AmbientLight(16777215,.6);l.add(c);let g=new V.DirectionalLight(16777215,.8);g.position.set(5,5,5),g.castShadow=!1,l.add(g);let u=new V.DirectionalLight(16777215,.3);u.position.set(-5,0,5),l.add(u);let b=new V.PerspectiveCamera(55,d/p,.1,100);b.position.set(0,0,3.2),b.lookAt(0,0,0),b.updateMatrixWorld();let h=new V.WebGLRenderer({antialias:!0,alpha:!0,preserveDrawingBuffer:!0});h.setPixelRatio(window.devicePixelRatio||1),h.setSize(d,p),h.setClearColor(0,0),h.domElement.style.position="absolute",h.domElement.style.top="0",h.domElement.style.left="0",h.domElement.style.right="0",h.domElement.style.bottom="0",h.domElement.style.width="100%",h.domElement.style.height="100%",h.domElement.style.minWidth="100%",h.domElement.style.minHeight="100%",h.domElement.style.maxWidth="100%",h.domElement.style.maxHeight="100%",h.domElement.style.display="block",h.domElement.style.pointerEvents="auto",h.domElement.style.margin="0",h.domElement.style.padding="0",h.domElement.style.boxSizing="border-box",s.appendChild(h.domElement);let w=f=>{var _;let m=t.getBoundingClientRect(),E=window.getComputedStyle(t);console.log("[THREE-BASE] applySize called:",{providedSize:f,rootRect:{width:m.width,height:m.height},clientSize:{width:t.clientWidth,height:t.clientHeight},styleSize:{width:t.style.width,height:t.style.height},computedStyle:{width:E.width,height:E.height,transform:E.transform,scale:E.scale},rendererCurrentSize:{width:h.domElement.width,height:h.domElement.height},rendererStyleSize:{width:h.domElement.style.width,height:h.domElement.style.height},stackTrace:(_=new Error().stack)==null?void 0:_.split(`
|
|
267
267
|
`).slice(1,4).join(`
|
|
268
|
-
`)});let S=m.width,A=m.height;if((S<=0||!isFinite(S))&&(console.warn("[THREE-BASE] Invalid boundingRect.width, using clientWidth fallback",{boundingRectWidth:m.width,clientWidth:t.clientWidth}),S=t.clientWidth||window.innerWidth||320),(A<=0||!isFinite(A))&&(console.warn("[THREE-BASE] Invalid boundingRect.height, using clientHeight fallback",{boundingRectHeight:m.height,clientHeight:t.clientHeight}),A=t.clientHeight||window.innerHeight||480),typeof(f==null?void 0:f.width)=="number"&&f.width>0){let j=Math.abs(f.width-m.width),O=m.width*.1;j>O?console.warn("[THREE-BASE] Provided width ignored (too different from container):",{provided:f.width,container:m.width,difference:j,tolerance:O,willUse:"container size (boundingRect)"}):(S=f.width,console.log("[THREE-BASE] Using provided width (within tolerance):",{provided:f.width,container:m.width}))}if(typeof(f==null?void 0:f.height)=="number"&&f.height>0){let j=Math.abs(f.height-m.height),O=m.height*.1;j>O?console.warn("[THREE-BASE] Provided height ignored (too different from container):",{provided:f.height,container:m.height,difference:j,tolerance:O,willUse:"container size (boundingRect)"}):(A=f.height,console.log("[THREE-BASE] Using provided height (within tolerance):",{provided:f.height,container:m.height}))}(S<=0||A<=0||!isFinite(S)||!isFinite(A))&&(console.warn("[THREE-BASE] Invalid size in applySize, using fallback",{newWidth:S,newHeight:A,size:f,rootRect:m}),S=m.width||t.clientWidth||320,A=m.height||t.clientHeight||480);let k=Math.floor(S),I=Math.floor(A);console.log("[THREE-BASE] applySize setting renderer size:",{finalWidth:k,finalHeight:I,aspectRatio:k/I,beforeRendererSize:{width:h.domElement.width,height:h.domElement.height},beforeRendererStyle:{width:h.domElement.style.width,height:h.domElement.style.height}}),h.setSize(k,I),h.setPixelRatio(window.devicePixelRatio||1),b.aspect=k/I,b.updateProjectionMatrix();let L=t.getBoundingClientRect();console.log("[THREE-BASE] applySize after setting:",{rendererSize:{width:h.domElement.width,height:h.domElement.height},rendererStyle:{width:h.domElement.style.width,height:h.domElement.style.height},containerRect:{width:L.width,height:L.height},cameraAspect:b.aspect,matches:{width:Math.abs(h.domElement.width-L.width)<1,height:Math.abs(h.domElement.height-L.height)<1},sizeDifference:{width:h.domElement.width-L.width,height:h.domElement.height-L.height}})};requestAnimationFrame(()=>{requestAnimationFrame(()=>{
|
|
268
|
+
`)});let S=m.width,A=m.height;if((S<=0||!isFinite(S))&&(console.warn("[THREE-BASE] Invalid boundingRect.width, using clientWidth fallback",{boundingRectWidth:m.width,clientWidth:t.clientWidth}),S=t.clientWidth||window.innerWidth||320),(A<=0||!isFinite(A))&&(console.warn("[THREE-BASE] Invalid boundingRect.height, using clientHeight fallback",{boundingRectHeight:m.height,clientHeight:t.clientHeight}),A=t.clientHeight||window.innerHeight||480),typeof(f==null?void 0:f.width)=="number"&&f.width>0){let j=Math.abs(f.width-m.width),O=m.width*.1;j>O?console.warn("[THREE-BASE] Provided width ignored (too different from container):",{provided:f.width,container:m.width,difference:j,tolerance:O,willUse:"container size (boundingRect)"}):(S=f.width,console.log("[THREE-BASE] Using provided width (within tolerance):",{provided:f.width,container:m.width}))}if(typeof(f==null?void 0:f.height)=="number"&&f.height>0){let j=Math.abs(f.height-m.height),O=m.height*.1;j>O?console.warn("[THREE-BASE] Provided height ignored (too different from container):",{provided:f.height,container:m.height,difference:j,tolerance:O,willUse:"container size (boundingRect)"}):(A=f.height,console.log("[THREE-BASE] Using provided height (within tolerance):",{provided:f.height,container:m.height}))}(S<=0||A<=0||!isFinite(S)||!isFinite(A))&&(console.warn("[THREE-BASE] Invalid size in applySize, using fallback",{newWidth:S,newHeight:A,size:f,rootRect:m}),S=m.width||t.clientWidth||320,A=m.height||t.clientHeight||480);let k=Math.floor(S),I=Math.floor(A);console.log("[THREE-BASE] applySize setting renderer size:",{finalWidth:k,finalHeight:I,aspectRatio:k/I,beforeRendererSize:{width:h.domElement.width,height:h.domElement.height},beforeRendererStyle:{width:h.domElement.style.width,height:h.domElement.style.height}}),h.setSize(k,I),h.setPixelRatio(window.devicePixelRatio||1),b.aspect=k/I,b.updateProjectionMatrix();let L=t.getBoundingClientRect();console.log("[THREE-BASE] applySize after setting:",{rendererSize:{width:h.domElement.width,height:h.domElement.height},rendererStyle:{width:h.domElement.style.width,height:h.domElement.style.height},containerRect:{width:L.width,height:L.height},cameraAspect:b.aspect,matches:{width:Math.abs(h.domElement.width-L.width)<1,height:Math.abs(h.domElement.height-L.height)<1},sizeDifference:{width:h.domElement.width-L.width,height:h.domElement.height-L.height}})};requestAnimationFrame(()=>{requestAnimationFrame(()=>{w()})});let v=!1;Re.on("pause",()=>{v=!0,document.querySelectorAll("audio").forEach(m=>m.pause())}),Re.on("resume",()=>{v=!1,document.querySelectorAll("audio").forEach(m=>{m.currentTime>0&&!m.ended&&m.play().catch(()=>{})})});let y=new Ge(t,o);return Re.on("resize",({payload:f})=>{console.log("[THREE-BASE] Handler resize event received:",{payload:f,timestamp:Date.now(),rootRect:t.getBoundingClientRect()}),w({width:f==null?void 0:f.width,height:f==null?void 0:f.height}),y.updateLayout()}),window.addEventListener("resize",()=>{console.log("[THREE-BASE] Window resize event received:",{timestamp:Date.now(),windowSize:{width:window.innerWidth,height:window.innerHeight},rootRect:t.getBoundingClientRect()}),w(),y.updateLayout()}),{scene:l,camera:b,renderer:h,uiSystem:y,applySize:w}}var z=ae(require("three"),1),rt=class{constructor(e){var i,n;this.position=(e==null?void 0:e.position)||{x:0,y:0},this.scale=(i=e==null?void 0:e.scale)!=null?i:1,this.rotation=(n=e==null?void 0:e.rotation)!=null?n:0}update(e){e.position!==void 0&&(this.position={...e.position}),e.scale!==void 0&&(this.scale=e.scale),e.rotation!==void 0&&(this.rotation=e.rotation)}syncToThree(e){let i=e.position.z,n=i===0||!isFinite(i)?.5:i;e.position.set(this.position.x,this.position.y,n),e.scale.set(this.scale,this.scale,this.scale),e.rotation.z=this.rotation}},ot=class{constructor(e){var i,n,a,r;this.z_index=(i=e==null?void 0:e.z_index)!=null?i: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=(r=e==null?void 0:e.tint)!=null?r: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)}syncToThree(e){if(e.renderOrder=this.z_index,e.visible=this.visible,e instanceof z.Mesh&&e.material&&(Array.isArray(e.material)?e.material.forEach(i=>{i instanceof z.Material&&(i.opacity=this.alpha,i.transparent=this.alpha<1)}):e.material instanceof z.Material&&(e.material.opacity=this.alpha,e.material.transparent=this.alpha<1)),this.tint!==null&&e instanceof z.Mesh&&e.material){let i=typeof this.tint=="string"?new z.Color(this.tint):new z.Color(this.tint);Array.isArray(e.material)?e.material.forEach(n=>{(n instanceof z.MeshBasicMaterial||n instanceof z.MeshStandardMaterial)&&n.color.copy(i)}):(e.material instanceof z.MeshBasicMaterial||e.material instanceof z.MeshStandardMaterial)&&e.material.color.copy(i)}}},st=class{constructor(e,i,n,a){this.instanceId=e,this.objectConfig=i,this.threeObject=n,this._config=a,this.transform=new rt(a.transform),this.renderer=new ot(a.render),this.sync()}sync(){this.transform.syncToThree(this.threeObject),this.renderer.syncToThree(this.threeObject)}updateConfig(e){this._config=e,e.transform&&this.transform.update(e.transform),e.render&&this.renderer.update(e.render),this.sync()}getComponent(e){return this._config[e]}getPosition(){return{...this.transform.position}}setPosition(e,i){this.transform.position={x:e,y:i},this.transform.syncToThree(this.threeObject)}getAlpha(){return this.renderer.alpha}setAlpha(e){this.renderer.alpha=e,this.renderer.syncToThree(this.threeObject)}getVisible(){return this.renderer.visible}setVisible(e){this.renderer.visible=e,this.renderer.syncToThree(this.threeObject)}},Dt=class{constructor(e){this.objects=new Map;this.config=e}create(e,i){let n=this.config.objects.get(e);if(!n)throw new Error(`Object config not found: ${e}`);let a=new st(e,n.object_config||e,i,n);return this.objects.set(e,a),a}get(e){return this.objects.get(e)}updateConfig(e){this.config=e;for(let[i,n]of this.objects.entries()){let a=e.objects.get(i);a&&n.updateConfig(a)}}getAll(){return Array.from(this.objects.values())}remove(e){this.objects.delete(e)}clear(){this.objects.clear()}};var $t={"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 Z(t){let e=$t[t];return e?e.family:(console.warn(`Font ID "${t}" not found in registry, using fallback`),"Arial, sans-serif")}function Q(t){var i;let e=$t[t];return e&&(i=e.weight)!=null?i:"400"}function mr(t,e){$t[t]=e}function br(){return Object.keys($t)}var Ue=ae(require("three"),1);function ke(t){return{element:t,get alpha(){return parseFloat(t.style.opacity||"1")},set alpha(e){t.style.opacity=e.toString()},get visible(){return t.style.display!=="none"},set visible(e){t.style.display=e?"":"none"},position:{set(e,i){t.style.left=`${e}px`,t.style.top=`${i}px`},get x(){return parseFloat(t.style.left||"0")},get y(){return parseFloat(t.style.top||"0")}},scale:{set(e,i){t.style.transform=`scale(${e})`},get x(){let e=t.style.transform.match(/scale\(([^)]+)\)/);return e?parseFloat(e[1]):1}}}}function yr(t,e,i,n){var Zi,Qi,en,tn,nn,an,rn,on,sn,ln,cn,dn,pn,un,gn,hn,fn,mn,bn,yn,vn,wn,xn,En,Sn,An,Cn,Tn,Ln,_n,kn,Mn,Pn,In,On,Rn,jn,zn,Dn,$n,Hn,Fn,Nn,Bn,Gn,Un,qn,Wn,Vn,Yn,Xn,Kn,Jn,Zn,Qn,ea,ta,ia,na,aa,ra;let a=t.objects.get("ui_endgame_1"),r=t.objects.get("ui_endgame_logo_1"),o=t.objects.get("ui_endgame_title_1"),s=t.objects.get("ui_endgame_subtitle_1"),l=t.objects.get("ui_endgame_footer_1"),d=t.objects.get("ui_endgame_cta_1"),p=t.objects.get("ui_endgame_cta_hint_1"),c=t.objects.get("ui_endgame_hand_1"),g=t.engine.runtime||{},u=((Zi=a==null?void 0:a.gameplay)==null?void 0:Zi.tuning)||{},b=(a==null?void 0:a.render)||{},h=n.getBoundingClientRect(),w=h.width>0?h.width*.9:320,v=h.height>0?h.height*.85:400,y=Math.min((Qi=u.panel_width)!=null?Qi:320,w),f=Math.min((en=u.panel_height)!=null?en:400,v),m=(tn=u.panel_padding)!=null?tn:32,E=(nn=u.panel_radius)!=null?nn:24,S=b.background_color||u.panel_bg_color||"#1a0a0a",A=b.background_alpha!==void 0&&b.background_alpha!==null?b.background_alpha:(an=u.panel_bg_alpha)!=null?an:.98,k=b.border_color||u.panel_border_color||"#ffffff",I=(rn=u.panel_border_width)!=null?rn:2,L=(on=u.panel_border_alpha)!=null?on:.3,_=document.createElement("div");_.style.cssText=`
|
|
269
269
|
position: absolute;
|
|
270
270
|
width: ${y}px;
|
|
271
271
|
height: ${f}px;
|
|
@@ -284,7 +284,7 @@ Style guidelines: ${n.summary}`;this.promptInput.value=a,this.currentPrompt=a}}c
|
|
|
284
284
|
z-index: 1000;
|
|
285
285
|
box-sizing: border-box;
|
|
286
286
|
padding: ${m}px;
|
|
287
|
-
`,n.appendChild(_);let j=ke(_);j.element=_;let O=((
|
|
287
|
+
`,n.appendChild(_);let j=ke(_);j.element=_;let O=((sn=r==null?void 0:r.gameplay)==null?void 0:sn.tuning)||{},be=(r==null?void 0:r.transform)||{},q=(ln=O.logo_size)!=null?ln:56,Y=(cn=be.scale)!=null?cn:1,Me=(pn=(dn=be.offset)==null?void 0:dn.y)!=null?pn:-130,lt=(un=O.logo_alpha)!=null?un:1,_r=new Ue.SpriteMaterial({map:i||void 0,transparent:!0,alphaTest:.1}),X=new Ue.Sprite(_r);X.position.set(0,Me,0),X.material.opacity=0;let ct=0,dt=0;if(i){let D=i.image;ct=(D==null?void 0:D.width)||100,dt=(D==null?void 0:D.height)||100}if(ct>0&&dt>0){let D=ct/dt,Yt,Xt;D>1?(Yt=q,Xt=q/D):(Xt=q,Yt=q*D);let ho=Yt/ct*Y,fo=Xt/dt*Y;X.scale.set(ho,fo,1)}else{let D=q/100*Y;X.scale.set(D,D,1)}X.targetAlpha=lt,X.baseScaleX=X.scale.x,X.baseScaleY=X.scale.y;let $=o==null?void 0:o.ui,ee=((gn=o==null?void 0:o.gameplay)==null?void 0:gn.tuning)||{},kr=($==null?void 0:$.text)||"MISSION ACCOMPLISHED",Di=($==null?void 0:$.font)||"brand.heading",Ft=($==null?void 0:$.fontSize)||24,Mr=(hn=$==null?void 0:$.letterSpacing)!=null?hn:1,pt=(fn=o==null?void 0:o.render)==null?void 0:fn.tint,Pr=typeof pt=="string"?pt:pt?`#${pt.toString(16).padStart(6,"0")}`:"#00FF88",Ir=y-m*2-30,Or=ee.font_weight_override?ee.font_weight_override:Q(Di),ye=document.createElement("div");ye.textContent=kr,ye.style.cssText=`
|
|
288
288
|
font-family: ${Z(Di)};
|
|
289
289
|
font-size: ${Ft}px;
|
|
290
290
|
font-weight: ${Or};
|
|
@@ -292,13 +292,13 @@ Style guidelines: ${n.summary}`;this.promptInput.value=a,this.currentPrompt=a}}c
|
|
|
292
292
|
text-align: center;
|
|
293
293
|
letter-spacing: ${Mr}px;
|
|
294
294
|
-webkit-text-stroke: ${(mn=ee.stroke_width)!=null?mn:2}px ${ee.stroke_color||"#000000"};
|
|
295
|
-
text-shadow: ${(bn=ee.shadow_distance)!=null?bn:4}px ${(yn=ee.shadow_distance)!=null?yn:4}px ${(vn=ee.shadow_blur)!=null?vn:8}px rgba(0,0,0,${(
|
|
295
|
+
text-shadow: ${(bn=ee.shadow_distance)!=null?bn:4}px ${(yn=ee.shadow_distance)!=null?yn:4}px ${(vn=ee.shadow_blur)!=null?vn:8}px rgba(0,0,0,${(wn=ee.shadow_alpha)!=null?wn:.9});
|
|
296
296
|
opacity: 0;
|
|
297
297
|
position: absolute;
|
|
298
298
|
transform: translate(-50%, -50%);
|
|
299
299
|
white-space: nowrap;
|
|
300
300
|
max-width: ${Ir}px;
|
|
301
|
-
`;let
|
|
301
|
+
`;let $i=m+30,Rr=((xn=u.title_offset_y)!=null?xn:$i+Ft/2)+((En=ee.animation_start_y_offset)!=null?En:-20);ye.style.top=`${Rr}px`,ye.style.left="50%";let Hi=ke(ye);Hi.element=ye,_.appendChild(ye);let H=s==null?void 0:s.ui,Fi=((Sn=s==null?void 0:s.gameplay)==null?void 0:Sn.tuning)||{},jr=(H==null?void 0:H.text)||"RESCUE COMPLETE",Ni=(H==null?void 0:H.font)||"brand.body",Nt=(H==null?void 0:H.fontSize)||11,zr=(An=H==null?void 0:H.letterSpacing)!=null?An:.5,ut=(Cn=s==null?void 0:s.render)==null?void 0:Cn.tint,Dr=typeof ut=="string"?ut:ut?`#${ut.toString(16).padStart(6,"0")}`:"#B0B0B0",ve=document.createElement("div");ve.textContent=jr,ve.style.cssText=`
|
|
302
302
|
font-family: ${Z(Ni)};
|
|
303
303
|
font-size: ${Nt}px;
|
|
304
304
|
font-weight: ${Q(Ni)};
|
|
@@ -309,7 +309,7 @@ Style guidelines: ${n.summary}`;this.promptInput.value=a,this.currentPrompt=a}}c
|
|
|
309
309
|
position: absolute;
|
|
310
310
|
transform: translate(-50%, -50%);
|
|
311
311
|
white-space: nowrap;
|
|
312
|
-
`;let Bi
|
|
312
|
+
`;let Bi=$i+Ft+15,$r=((Tn=u.subtitle_offset_y)!=null?Tn:Bi+Nt/2)+((Ln=Fi.animation_start_y_offset)!=null?Ln:-10);ve.style.top=`${$r}px`,ve.style.left="50%";let Bt=ke(ve);Bt.element=ve,Bt.animationStartYOffset=(_n=Fi.animation_start_y_offset)!=null?_n:-10,_.appendChild(ve);let te=l==null?void 0:l.ui,Gi=((kn=l==null?void 0:l.gameplay)==null?void 0:kn.tuning)||{},Hr=(te==null?void 0:te.text)||((Mn=g.ui)==null?void 0:Mn.cta_hint)||"Continue the adventure!",Ui=(te==null?void 0:te.font)||"brand.body",qi=(te==null?void 0:te.fontSize)||16,gt=(Pn=l==null?void 0:l.render)==null?void 0:Pn.tint,Fr=typeof gt=="string"?gt:gt?`#${gt.toString(16).padStart(6,"0")}`:"#FFFFFF",Nr=(In=Gi.max_width)!=null?In:y-m*2,Br=(On=Gi.line_height)!=null?On:1.4,we=document.createElement("div");we.textContent=Hr,we.style.cssText=`
|
|
313
313
|
font-family: ${Z(Ui)};
|
|
314
314
|
font-size: ${qi}px;
|
|
315
315
|
font-weight: ${Q(Ui)};
|
|
@@ -321,7 +321,7 @@ Style guidelines: ${n.summary}`;this.promptInput.value=a,this.currentPrompt=a}}c
|
|
|
321
321
|
max-width: ${Nr}px;
|
|
322
322
|
line-height: ${Br};
|
|
323
323
|
word-wrap: break-word;
|
|
324
|
-
`;let Gr=Bi+Nt+30,Ur=(Rn=u.footer_offset_y)!=null?Rn:Gr+qi/2;
|
|
324
|
+
`;let Gr=Bi+Nt+30,Ur=(Rn=u.footer_offset_y)!=null?Rn:Gr+qi/2;we.style.top=`${Ur}px`,we.style.left="50%";let Gt=ke(we);Gt.element=we;let qr=((jn=l==null?void 0:l.render)==null?void 0:jn.alpha)!==void 0&&((zn=l==null?void 0:l.render)==null?void 0:zn.alpha)!==null?l.render.alpha:1;Gt.targetAlpha=qr,_.appendChild(we);let ie=((Dn=d==null?void 0:d.gameplay)==null?void 0:Dn.tuning)||{},F=d==null?void 0:d.ui,Wr=($n=ie.button_width)!=null?$n:260,Wi=(Hn=ie.button_height)!=null?Hn:56,Vr=(Fn=ie.button_radius)!=null?Fn:16,Yr=ie.button_bg_color||((Nn=g.theme)==null?void 0:Nn.cta_background)||"#ffb43b",Xr=(Bn=ie.button_bg_alpha)!=null?Bn:1,Kr=ie.button_border_color||"#ffffff",Jr=(Gn=ie.button_border_width)!=null?Gn:2,Qs=(Un=ie.button_border_alpha)!=null?Un:.2,Ut=(qn=u.cta_offset_y)!=null?qn:f*.7,R=document.createElement("button");R.style.cssText=`
|
|
325
325
|
width: ${Wr}px;
|
|
326
326
|
height: ${Wi}px;
|
|
327
327
|
background: ${Yr};
|
|
@@ -333,21 +333,21 @@ Style guidelines: ${n.summary}`;this.promptInput.value=a,this.currentPrompt=a}}c
|
|
|
333
333
|
position: absolute;
|
|
334
334
|
transform: translate(-50%, -50%);
|
|
335
335
|
box-shadow: inset 0 0 1px rgba(0,0,0,0.15);
|
|
336
|
-
`,R.style.top=`${Ut}px`,R.style.left="50%";let qt=ke(R);qt.element=R,qt.addEventListener=R.addEventListener.bind(R),_.appendChild(R);let Zr=(F==null?void 0:F.text)||((Wn=g.ui)==null?void 0:Wn.cta_label_end)||"DOWNLOAD",Vi=(F==null?void 0:F.font)||"brand.heading",Qr=(F==null?void 0:F.fontSize)||20,
|
|
336
|
+
`,R.style.top=`${Ut}px`,R.style.left="50%";let qt=ke(R);qt.element=R,qt.addEventListener=R.addEventListener.bind(R),_.appendChild(R);let Zr=(F==null?void 0:F.text)||((Wn=g.ui)==null?void 0:Wn.cta_label_end)||"DOWNLOAD",Vi=(F==null?void 0:F.font)||"brand.heading",Qr=(F==null?void 0:F.fontSize)||20,eo=ie.button_text_color||((Vn=g.theme)==null?void 0:Vn.cta_text)||"#1a0a0a";R.textContent=Zr,R.style.fontFamily=Z(Vi),R.style.fontSize=`${Qr}px`,R.style.fontWeight=String(Q(Vi)),R.style.color=eo,R.style.letterSpacing=`${(Yn=F==null?void 0:F.letterSpacing)!=null?Yn:1}px`;let Yi=ke(R);Yi.element=R;let N=p==null?void 0:p.ui,Xi=((Xn=p==null?void 0:p.gameplay)==null?void 0:Xn.tuning)||{},to=(N==null?void 0:N.text)||"Play the full game",Ki=(N==null?void 0:N.font)||"brand.body",io=(N==null?void 0:N.fontSize)||11,no=(Kn=N==null?void 0:N.letterSpacing)!=null?Kn:0,ht=(Jn=p==null?void 0:p.render)==null?void 0:Jn.tint,ao=typeof ht=="string"?ht:ht?`#${ht.toString(16).padStart(6,"0")}`:"#CCCCCC",xe=document.createElement("div");xe.textContent=to,xe.style.cssText=`
|
|
337
337
|
font-family: ${Z(Ki)};
|
|
338
|
-
font-size: ${
|
|
338
|
+
font-size: ${io}px;
|
|
339
339
|
font-weight: ${Q(Ki)};
|
|
340
|
-
color: ${
|
|
340
|
+
color: ${ao};
|
|
341
341
|
text-align: center;
|
|
342
|
-
letter-spacing: ${
|
|
342
|
+
letter-spacing: ${no}px;
|
|
343
343
|
opacity: 0;
|
|
344
344
|
position: absolute;
|
|
345
345
|
transform: translate(-50%, -50%);
|
|
346
346
|
white-space: nowrap;
|
|
347
|
-
`;let
|
|
348
|
-
font-family: ${Z(
|
|
347
|
+
`;let ro=Ut+Wi/2+20,oo=f-m-10,so=Math.min(ro+((Zn=Xi.animation_start_y_offset)!=null?Zn:5),oo);xe.style.top=`${so}px`,xe.style.left="50%";let Wt=ke(xe);Wt.element=xe,Wt.animationStartYOffset=(Qn=Xi.animation_start_y_offset)!=null?Qn:5,_.appendChild(xe);let Vt=((ea=c==null?void 0:c.gameplay)==null?void 0:ea.tuning)||{},lo=(ta=Vt.hand_offset_x)!=null?ta:50,co=(ia=Vt.hand_offset_y)!=null?ia:50,po=(aa=(na=c==null?void 0:c.transform)==null?void 0:na.scale)!=null?aa:.1875,uo=(ra=Vt.hand_scale_multiplier)!=null?ra:2.5,go=new Ue.SpriteMaterial({map:e||void 0,transparent:!0,alphaTest:.1}),We=new Ue.Sprite(go),Ji=po*uo*100;return We.scale.set(Ji,Ji,1),We.position.set(lo,Ut+co,0),We.material.opacity=0,We.visible=!1,{panel:j,logo:X,title:Hi,subtitle:Bt,footer:Gt,ctaButton:qt,ctaText:Yi,ctaHint:Wt,hand:We}}function vr(t,e,i){var S,A,k,I,L,_,j,O;let n=e.objects.get("ui_endgame_1"),a=((S=n==null?void 0:n.gameplay)==null?void 0:S.tuning)||{},r=(A=a.animation_duration_ms)!=null?A:800,o=(k=a.fade_in_duration_ms)!=null?k:600,s=(I=a.scale_animation_intensity)!=null?I:.1,l=(L=a.logo_animation_delay_ms)!=null?L:100,d=(_=a.title_animation_delay_ms)!=null?_:200,p=(j=a.footer_animation_delay_ms)!=null?j:300,c=(O=a.cta_animation_delay_ms)!=null?O:400,{panel:g,logo:u,title:b,subtitle:h,footer:w,ctaButton:v,ctaText:y,ctaHint:f}=t;g.visible=!0,g.element.style.visibility="visible";let m=Date.now(),E=()=>{let be=Date.now()-m,q=Math.min(be/o,1),Y=1-Math.pow(1-q,3);g.alpha=Y,g.element.style.opacity=Y.toString();let Me=1+s*(1-Y);g.element.style.transform=`translate(-50%, -50%) scale(${Me})`,q<1?requestAnimationFrame(E):(setTimeout(()=>Us(u,r,e),l),setTimeout(()=>{qs(b,r),setTimeout(()=>Ws(h,r),50)},d),setTimeout(()=>Vs(w,r),p),setTimeout(()=>{Ys(v,y,r),setTimeout(()=>Xs(f,r),50),i&&i()},c))};E()}function Us(t,e,i){var g,u,b,h,w;let n=i==null?void 0:i.objects.get("ui_endgame_logo_1"),r=(u=(((g=n==null?void 0:n.gameplay)==null?void 0:g.tuning)||{}).animation_start_scale)!=null?u:1.2,o=Date.now(),s=t.material.opacity,l=(b=t.targetAlpha)!=null?b:1,d=(h=t.baseScaleX)!=null?h:t.scale.x,p=(w=t.baseScaleY)!=null?w:t.scale.y,c=()=>{let v=Date.now()-o,y=Math.min(v/e,1),f=1-Math.pow(1-y,2);t.material.opacity=s+(l-s)*f;let m=r+(1-r)*f;t.scale.set(d*m,p*m,1),y<1&&requestAnimationFrame(c)};c()}function qs(t,e){let i=Date.now(),n=parseFloat(t.element.style.opacity||"0"),a=parseFloat(t.element.style.top||"0"),r=()=>{let o=Date.now()-i,s=Math.min(o/e,1),l=1-Math.pow(1-s,2);t.element.style.opacity=(n+(1-n)*l).toString(),t.element.style.top=`${a-20*(1-l)}px`,s<1&&requestAnimationFrame(r)};r()}function Ws(t,e){var s;let i=Date.now(),n=parseFloat(t.element.style.opacity||"0"),a=parseFloat(t.element.style.top||"0"),r=a-((s=t.animationStartYOffset)!=null?s:-10),o=()=>{let l=Date.now()-i,d=Math.min(l/e,1),p=1-Math.pow(1-d,2);t.element.style.opacity=(n+(1-n)*p).toString(),t.element.style.top=`${a+(r-a)*p}px`,d<1&&requestAnimationFrame(o)};o()}function Vs(t,e){var o;let i=Date.now(),n=parseFloat(t.element.style.opacity||"0"),a=(o=t.targetAlpha)!=null?o:1,r=()=>{let s=Date.now()-i,l=Math.min(s/e,1),d=1-Math.pow(1-l,2);t.element.style.opacity=(n+(a-n)*d).toString(),l<1&&requestAnimationFrame(r)};r()}function Ys(t,e,i){let n=Date.now(),a=parseFloat(t.element.style.opacity||"0"),r=()=>{let o=Date.now()-n,s=Math.min(o/i,1),l=1-Math.pow(1-s,2);t.element.style.opacity=(a+(1-a)*l).toString(),e.element.style.opacity=(a+(1-a)*l).toString(),t.element.style.transform=`translate(-50%, -50%) scale(${1+.1*(1-l)})`,s<1&&requestAnimationFrame(r)};r()}function Xs(t,e){var s;let i=Date.now(),n=parseFloat(t.element.style.opacity||"0"),a=parseFloat(t.element.style.top||"0"),r=a-((s=t.animationStartYOffset)!=null?s:5),o=()=>{let l=Date.now()-i,d=Math.min(l/e,1),p=1-Math.pow(1-d,2);t.element.style.opacity=(n+(1-n)*p).toString(),t.element.style.top=`${a+(r-a)*p}px`,d<1&&requestAnimationFrame(o)};o()}function wr(t,e,i,n){var p,c,g,u;let a=i.objects.get("ui_endgame_hand_1"),r=((p=a==null?void 0:a.gameplay)==null?void 0:p.tuning)||{},o=(c=r.click_animation_duration_ms)!=null?c:600,s=(g=r.click_delay_ms)!=null?g:2e3,l=(u=r.click_repeat_delay_ms)!=null?u:3e3,d=()=>{var A,k;t.visible=!0,t.material.opacity=1;let b=t.position.x,h=t.position.y,w=(A=r.hand_offset_x)!=null?A:50,v=(k=r.hand_offset_y)!=null?k:50,y=e.element.getBoundingClientRect(),f=w,m=v,E=Date.now(),S=()=>{var Y,Me,lt;let I=Date.now()-E,L=Math.min(I/o,1),_=L<.5?2*L*L:1-Math.pow(-2*L+2,2)/2;t.position.set(b+(f-b)*_,h+(m-h)*_,0);let j=(Me=(Y=a==null?void 0:a.transform)==null?void 0:Y.scale)!=null?Me:.1875,O=(lt=r.hand_scale_multiplier)!=null?lt:2.5,be=j*O*100,q=be+be*.2*Math.sin(L*Math.PI);t.scale.set(q,q,1),L<1?requestAnimationFrame(S):(e.element.style.transform="translate(-50%, -50%) scale(0.95)",setTimeout(()=>{e.element.style.transform="translate(-50%, -50%) scale(1)",n()},100),setTimeout(()=>{t.material.opacity=0,setTimeout(()=>{t.position.set(b,h,0),d()},l)},500))};S()};setTimeout(d,s)}var Ht=ae(require("three"),1);function xr(t,e,i){var u,b,h,w,v,y,f;let n=e.objects.get("hand_tutorial_1"),a=((u=n==null?void 0:n.gameplay)==null?void 0:u.tuning)||{},r=(n==null?void 0:n.render)||{},o=(n==null?void 0:n.transform)||{},s=new Ht.SpriteMaterial({map:t||void 0,transparent:!0,alphaTest:.1}),l=new Ht.Sprite(s),d=o.position||{},p=(b=d==null?void 0:d.z)!=null?b:0;l.position.set(i.x+((h=d==null?void 0:d.x)!=null?h:0),i.y+((w=d==null?void 0:d.y)!=null?w:0),p),l.material.opacity=r.alpha!==void 0&&r.alpha!==null?r.alpha:0,l.visible=r.visible!==void 0&&r.visible!==null?r.visible:!1;let c=(v=a.hand_scale_multiplier)!=null?v:2.5,g=(y=o.scale)!=null?y:.1875;return l.scale.set(g*c*100,g*c*100,1),l.renderOrder=(f=r.z_index)!=null?f:99999,l}function Er(t){var b,h,w,v,y,f,m,E,S;let e=t.objects.get("ui_tutorial_1"),i=e==null?void 0:e.ui,n=(e==null?void 0:e.render)||{},a=((b=t.engine.runtime)==null?void 0:b.ui_styles)||{},r=((h=t.engine.runtime)==null?void 0:h.ui)||{},o=(i==null?void 0:i.text)||r.tutorial_label||r.label_text||"CLEAN!",s=(i==null?void 0:i.font)||"brand.warning",l=(i==null?void 0:i.fontSize)||a.label_font_size||52,d=(v=i==null?void 0:i.letterSpacing)!=null?v:(w=a.label_letter_spacing)!=null?w:-1,p=(i==null?void 0:i.align)||"center",c=n.tint,g=typeof c=="string"?c:c?`#${c.toString(16).padStart(6,"0")}`:a.label_fill||"#FFF1C1",u=document.createElement("div");return u.textContent=o,u.style.cssText=`
|
|
348
|
+
font-family: ${Z(s)};
|
|
349
349
|
font-size: ${l}px;
|
|
350
|
-
font-weight: ${Q(
|
|
350
|
+
font-weight: ${Q(s)};
|
|
351
351
|
color: ${g};
|
|
352
352
|
text-align: ${p};
|
|
353
353
|
letter-spacing: ${d}px;
|
|
@@ -359,4 +359,4 @@ Style guidelines: ${n.summary}`;this.promptInput.value=a,this.currentPrompt=a}}c
|
|
|
359
359
|
position: absolute;
|
|
360
360
|
transform: translate(-50%, -50%);
|
|
361
361
|
white-space: nowrap;
|
|
362
|
-
`,u}function Sr(t,e,i,n,a){var l,d,p,c,g,u,b;let r=a.objects.get("hand_tutorial_1"),
|
|
362
|
+
`,u}function Sr(t,e,i,n,a){var l,d,p,c,g,u,b;let r=a.objects.get("hand_tutorial_1"),o=((l=r==null?void 0:r.gameplay)==null?void 0:l.tuning)||{},s=(r==null?void 0:r.transform)||{};if(!n){let h=(d=o.animation_duration)!=null?d:1.5,w=i%h/h,v=w<.5?2*w*w:-1+(4-2*w)*w,y=(p=o.x_offset)!=null?p:0,f=(c=o.y_offset)!=null?c:0,m=(g=o.animation_range)!=null?g:40,E=m*.7,S=m,A=e.x+y+E,k=e.y+f+S,I=A+E,L=k+S;t.position.set(A+(I-A)*v,k+(L-k)*v,0);let _=(u=s.scale)!=null?u:.1875,j=(b=o.hand_scale_multiplier)!=null?b:2.5,O=_*j*100;t.scale.set(O,O,1)}}var qe=ae(require("three"),1),Ar=new qe.TextureLoader,Ri=null,ji=null;async function Cr(){if(Ri)return Ri;if(!ji){let i=(()=>{if(typeof window!="undefined")try{return new URL("inline-assets.js",window.location.href).href}catch{return"./inline-assets.js"}return"./inline-assets.js"})();ji=fetch(i).then(n=>{if(!n.ok)throw new Error(`HTTP ${n.status}`);return n.text()}).then(n=>{let a=n.match(/export\s+const\s+INLINE_ASSETS\s*=\s*({[\s\S]*?});?\s*$/m);if(a)return new Function("return "+a[1])();throw new Error("INLINE_ASSETS export not found")}).then(n=>n?n.INLINE_ASSETS?n.INLINE_ASSETS:(console.warn("[assets] Module does not have INLINE_ASSETS export. Module keys:",Object.keys(n)),{}):(console.warn("[assets] Module import returned undefined"),{})).catch(n=>(console.warn("[assets] Failed to load inline-assets.js:",n),{}))}let t=await ji;return Ri=t||{},t||{}}async function zi(t,e,i=16777215,n=!1){try{let r=(await Cr())[t];return await Ar.loadAsync(r||t)}catch{console.warn(`Asset missing: ${t}. Using placeholder.`);let r=document.createElement("canvas");r.width=64,r.height=64;let o=r.getContext("2d");return o&&(o.fillStyle=`#${i.toString(16).padStart(6,"0")}`,n?o.fillRect(0,0,30,60):(o.beginPath(),o.arc(32,32,30,0,Math.PI*2),o.fill(),o.fillRect(27,32,10,40))),new qe.CanvasTexture(r)}}async function Tr(t,e,i){var h,w;let a=(await Cr())[t]||t,r;try{r=await Ar.loadAsync(a),console.log("[character] loaded sheet",{path:t,sourceUsed:a})}catch(v){let m=((i.gameplay.character_sheet||{}).fallback_color||"#ff00ff").replace("#","");r=await zi(t,e,parseInt(m,16),!0),console.warn("[character] fallback loadAsset used",{path:t,err:v})}if(!r)return[];let o=i.gameplay.character_sheet||{},s=(h=o.cols)!=null?h:3,l=(w=o.rows)!=null?w:2,d=r.image,p=(d==null?void 0:d.width)||0,c=(d==null?void 0:d.height)||0,g=p/s,u=c/l;if(!Number.isFinite(g)||!Number.isFinite(u)||g<=0||u<=0)return[r];let b=[];for(let v=0;v<l;v++)for(let y=0;y<s;y++){let f=document.createElement("canvas");f.width=g,f.height=u;let m=f.getContext("2d");m&&d&&m.drawImage(d,y*g,v*u,g,u,0,0,g,u),b.push(new qe.CanvasTexture(f))}return b.length>2&&b.push(...b.slice(1,-1).reverse()),console.log("[character] frames prepared",{count:b.length}),b}function Lr(t,e){var c,g,u,b;let i=e.gameplay.brush||{},n=e.theme.brush_color||"#ffffff",a=(c=i.radius)!=null?c:20,r=(g=i.inner_radius)!=null?g:15,o=(u=i.alpha)!=null?u:.8,s=(b=i.inner_alpha)!=null?b:.3,l=i.inner_color||"#ffffff",d=document.createElement("canvas");d.width=a*2,d.height=a*2;let p=d.getContext("2d");return p&&(p.clearRect(0,0,d.width,d.height),p.beginPath(),p.arc(a,a,a,0,Math.PI*2),p.fillStyle=n,p.globalAlpha=o,p.fill(),p.beginPath(),p.arc(a,a,r,0,Math.PI*2),p.fillStyle=l,p.globalAlpha=s,p.fill()),new qe.CanvasTexture(d)}0&&(module.exports={AspectClass,GameObject,GameObjectManager,Renderer,ResponsiveUISystem,Transform,animateHandClick,animatePanelEntrance,createBrushTexture,createEndGamePanel,createHandTutorial,createThreeBase,createTutorialLabel,getAspectClass,getRegisteredFontIds,loadAsset,loadCharacterFrames,registerFont,resolveFont,resolveFontWeight,updateHandAnimation});
|