handler-playable-sdk 1.0.93 → 1.0.95
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/AssetCropModal-JJSHJZCX.js +1 -0
- package/dist/{ConfigOverride-XECG7H5B.js → ConfigOverride-2HOZGV6G.js} +1 -1
- package/dist/chunk-5IRAZMOA.js +1 -0
- package/dist/{chunk-6676ZMVB.js → chunk-LWADIFXM.js} +126 -126
- package/dist/chunk-NSZ7GCS3.js +52 -0
- package/dist/chunk-SDFKEAA5.js +1 -0
- 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/add-logic.mjs +1 -1
- package/dist/cli/student-helper/add-object.mjs +1 -1
- package/dist/cli/student-helper/arg-parsing.mjs +1 -1
- package/dist/cli/student-helper/asset-registry.mjs +1 -1
- package/dist/cli/student-helper/bullet-system.mjs +1 -1
- package/dist/cli/student-helper/collectable-system.mjs +1 -1
- package/dist/cli/student-helper/constants.mjs +1 -1
- package/dist/cli/student-helper/drag-snap-couples.mjs +1 -1
- package/dist/cli/student-helper/endgame-screen.mjs +1 -1
- package/dist/cli/student-helper/fs-io.mjs +1 -1
- package/dist/cli/student-helper/logic-defaults.mjs +1 -1
- package/dist/cli/student-helper/print-help.mjs +1 -1
- package/dist/cli/student-helper/prompts.mjs +1 -1
- package/dist/cli/student-helper/scratch-card.mjs +1 -1
- package/dist/cli/student-helper/screen-utils.mjs +1 -1
- package/dist/cli/student-helper/snippets.mjs +1 -1
- package/dist/cli/student-helper/start-screen.mjs +1 -1
- package/dist/cli/student-helper/swerve-collect.mjs +1 -1
- package/dist/cli/student-helper/tap-destroy.mjs +1 -1
- package/dist/cli/student-helper/template-packs.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/{config-TFSKV7GO.js → config-VJNOXXCC.js} +1 -1
- package/dist/index.cjs +124 -124
- package/dist/index.js +1 -1
- package/dist/pixi/index.cjs +12 -12
- package/dist/pixi/index.js +1 -1
- package/dist/three/index.cjs +27 -27
- package/dist/three/index.js +1 -1
- package/package.json +1 -1
- package/dist/AssetCropModal-5GIDIW5V.js +0 -1
- package/dist/chunk-EFRB44UC.js +0 -1
- package/dist/chunk-GVZ2445E.js +0 -1
- package/dist/chunk-JYGZ4R4K.js +0 -52
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{a}from"./chunk-NSZ7GCS3.js";import"./chunk-JXBG6UFL.js";export{a as AssetCropModal};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s}from"./chunk-
|
|
1
|
+
import{a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s}from"./chunk-SDFKEAA5.js";import"./chunk-JXBG6UFL.js";export{c as applyConfigOverride,d as applyConfigOverrides,q as applyConfigsToDisk,e as clearConfigOverrides,f as clearConfigOverridesForObject,i as configOverrideManager,n as deepClone,o as exportConfigsAsJSON,h as getConfigOverrides,p as getConfigStateSummary,a as getOverrideMode,k as redoLastConfigChange,g as removeConfigOverride,r as resetToApplied,s as resetToOriginal,b as setOverrideMode,l as trackObjectCreation,m as trackObjectDeletion,j as undoLastConfigChange};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{a as X,d as K,h as Q}from"./chunk-SDFKEAA5.js";var Y=null,d="dev";if(typeof window!="undefined"){let n=window.__BUILD_SETTINGS__;if(n!=null&&n.buildMode)Y=n,d=n.buildMode,console.log("[CONFIG] Loaded inline build settings:",n,"buildMode:",d);else try{let e=new XMLHttpRequest;if(e.open("GET","./build-settings.json",!1),e.send(),e.status===200&&e.responseText){let t=JSON.parse(e.responseText);Y=t,d=t.buildMode||"dev",console.log("[CONFIG] Loaded build settings:",t,"buildMode:",d)}else console.log("[CONFIG] No build-settings.json found, using default buildMode:",d)}catch(e){console.log("[CONFIG] Failed to load build-settings.json:",e instanceof Error?e.message:String(e))}}console.log("[CONFIG] Final buildMode:",d);var H=new Map,P=d==="dev"||typeof window!="undefined"&&window.location.search.includes("hot-reload");function ie(n,e){try{if(typeof n=="object"&&n!==null)return n;if(typeof n!="string")return null;if(n.startsWith("data:")){let o=n.indexOf(",");if(o===-1)return null;let s=n.slice(0,o);if(!s.includes("application/json")&&!s.includes("text/plain"))return null;let a=n.slice(o+1),i=s.includes("base64")?typeof atob=="function"?atob(a):a:decodeURIComponent(a);return JSON.parse(i)}let t=n.trim();return t.startsWith("{")||t.startsWith("[")?JSON.parse(n):null}catch{return null}}function ae(n){if(typeof window=="undefined"||!window.INLINE_ASSETS)return null;let e=window.INLINE_ASSETS,t=n.replace(/^\.\/+/,""),o=t.split("/").pop()||t,s=[t,o,t.replace(/\.json$/,""),o.replace(/\.json$/,"")];for(let a of s){let i=e[a];if(i){let r=ie(i,a);if(r!==null)return r}}return null}async function G(n){if(H.has(n)&&!P)return console.log(`[CONFIG] Using cached config for: "${n}"`),H.get(n);if(console.log(`[CONFIG] loadConfigFile called with: "${n}", MODE: ${d.toUpperCase()}, CACHE: ${P?"DISABLED":"ENABLED"}`),d==="publish"){let o=ae(n);return o?(console.log(`[CONFIG] \u2713 Loaded ${n} via INLINE_ASSETS`),o):(console.log(`[CONFIG] \u2139\uFE0F Optional config ${n} not in INLINE_ASSETS, skipping fetch in publish mode`),{})}d==="brand"||console.log(`[CONFIG] DEV MODE: Trying nested paths first, then flattened for "${n}"`);let e;d==="brand"?e=[`./${n.split("/").pop()||n}`,`./${n}`,`./${n.replace(/^configs\//,"")}`,`./${n.replace(/^configs\//,"").replace(/\//g,".")}`]:e=[`./${n}`,`./${n.replace(/^configs\//,"")}`,`./${n.replace(/^configs\//,"").replace(/\//g,".")}`],e=Array.from(new Set(e.flatMap(o=>o.startsWith("./")?[o,`/${o.slice(2)}`]:o.startsWith("/")?[o]:[o,`/${o}`]))),console.log("[CONFIG] Will try candidates:",e);let t=(async()=>{let o=P?"no-store":"force-cache";for(let s of e)try{let a=await fetch(s,{cache:o});if(!a.ok)continue;let i=await a.json();return console.log(`[CONFIG] \u2713 Loaded ${n} via ${s}`,i),i}catch(a){console.warn(`[CONFIG] \u2717 Failed to load ${s} (mode: ${d}):`,a)}return console.warn(`[CONFIG] \u2717 All attempts failed for ${n}; using defaults`),{}})();return H.set(n,t),t}async function ee(){console.log("[CONFIG] Loading component schemas...");let n=["components/identity.schema.json","components/transform.schema.json","components/render.schema.json","components/motion.schema.json","components/effects.schema.json","components/interaction.schema.json","components/gameplay.rules.schema.json","components/gameplay.tuning.schema.json","components/visibility.schema.json","components/audio.schema.json","components/physics.schema.json","components/ui.schema.json"],e=new Map;for(let t of n)try{let o=d==="publish"||d==="brand"?t.split("/").pop()||t:`configs/${t}`,s=await G(o);s.component&&(e.set(s.component,s),console.log(`[CONFIG] \u2713 Schema loaded: ${s.component} ${d==="publish"||d==="brand"?"(flattened)":"(nested)"}`))}catch(o){console.warn(`[CONFIG] \u2717 Failed to load schema ${t}:`,o)}return console.log(`[CONFIG] Loaded ${e.size} component schemas`),e}async function N(n){console.log(`[CONFIG] Loading object config: ${n}`);let e=d==="publish"||d==="brand"?`${n}.json`:`configs/objects/${n}.json`;return await G(e)}async function ne(n){let e=new Map;if(n.objects&&Array.isArray(n.objects)){for(let t of n.objects)if(t.enabled&&t.object_config)try{let o=t.instance_id;/^(json\.|ui\.|effects\.|engine\.)/.test(o)||(o=`json.${o}`);let s=await N(o);(!s||Object.keys(s).length===0)&&o!==t.instance_id&&(s=await N(t.instance_id)),!s||Object.keys(s).length===0?(console.log(`[CONFIG] No instance snapshot for ${t.instance_id}, using template ${t.object_config}`),s=await N(t.object_config)):console.log(`[CONFIG] \u2713 Loaded instance snapshot for ${t.instance_id}`),e.set(t.instance_id,{...s,instance_id:t.instance_id,object_config:t.object_config})}catch(o){console.warn(`Failed to load object ${t.object_config}:`,o)}}return e}async function te(){console.log("[CONFIG] Loading engine configs...");let n=["runtime","assets","splash","loading","start","tutorial","endgame"],e=await Promise.all(n.map(o=>{let s=`engine.${o}.json`,a=d==="publish"||d==="brand"?s:`configs/engine/${s}`;return G(a)})),t=Object.fromEntries(n.map((o,s)=>[o,e[s]]));return console.log("[CONFIG] Engine configs loaded:",Object.fromEntries(n.map(o=>{var i;let s=(i=t[o])!=null?i:{},a=Object.keys(s);return[o,a.length>0?a:"empty"]}))),t}async function re(){return await G(d==="publish"||d==="brand"?"game.prompt.json":"configs/engine/game.prompt.json")}async function oe(n="scene.main"){console.log(`[CONFIG] Loading scene config: ${n}`);let e=d==="publish"||d==="brand"?`${n}.json`:`configs/scenes/${n}.json`;return await G(e)}function L(n,e){let t=[];if(!n.identity)return t.push("Missing required identity component"),{valid:!1,errors:t};let o=e.get("identity");if(o)for(let s of o.required||[])n.identity[s]||t.push(`Missing required identity field: ${s}`);for(let[s,a]of Object.entries(n)){if(s==="identity")continue;let i=e.get(s);if(i&&a&&typeof a=="object"){let r=a;for(let f of i.required||[])r[f]===void 0&&t.push(`Missing required field in ${s}: ${f}`);if(i.constraints&&typeof i.constraints=="object")for(let[f,u]of Object.entries(i.constraints)){let y=r[f];if(y!==void 0&&u&&typeof u=="object"){let C=u;typeof y=="number"&&(C.min!==void 0&&y<C.min&&t.push(`${s}.${f} value ${y} is below minimum ${C.min}`),C.max!==void 0&&y>C.max&&t.push(`${s}.${f} value ${y} is above maximum ${C.max}`))}}}}return{valid:t.length===0,errors:t}}function M(n,e){let t={...n},o=["identity","transform","render"];for(let[s,a]of e.entries())a.defaults&&Object.keys(a.defaults).length>0&&(o.includes(s)||t[s])&&(t[s]||(t[s]={}),t[s]={...a.defaults,...t[s]});return t}function j(n,e,t,o){return typeof n!="number"||!Number.isFinite(n)?e:Math.min(Math.max(n,t),o)}function Z(n,e){if(Array.isArray(n))return{x:j(n[0],e.x,-2e3,2e3),y:j(n[1],e.y,-2e3,2e3)};if(!n||typeof n!="object")return e;let{x:t,y:o}=n;return{x:j(t,e.x,-2e3,2e3),y:j(o,e.y,-2e3,2e3)}}function ce(n,e){if(Array.isArray(n))return{x:j(n[0],e.x,0,1),y:j(n[1],e.y,0,1)};if(!n||typeof n!="object")return e;let{x:t,y:o}=n;return{x:j(t,e.x,0,1),y:j(o,e.y,0,1)}}function le(n){if(Array.isArray(n))return{x:j(n[0],.5,-10,10),y:j(n[1],.5,-10,10)};if(n&&typeof n=="object"){let{x:e,y:t}=n;return{x:j(e,.5,-10,10),y:j(t,.5,-10,10)}}return typeof n=="string"?n:null}async function R(n="scene.main",e){var u,y,C,$,_,g,c,h,O,v,b,I,F,S,E;console.log("[CONFIG] ===== Starting Object-Centric Config Load =====");let t=await ee(),o=Q(),s=X();console.log(`[CONFIG] Loader: Found ${o.length} persisted overrides, override mode: ${s}`),o.length>0&&console.log("[CONFIG] Override details:",o.map(p=>({objectId:p.objectId,path:p.path,value:typeof p.value=="string"?p.value.substring(0,50):p.value})));let a=await oe(n);console.log(`[CONFIG] Scene config loaded: ${((u=a.objects)==null?void 0:u.length)||0} objects`);let i=await te();console.log("[CONFIG] Loading object configs...");let r=await ne(a);console.log(`[CONFIG] Loaded ${r.size} object configs:`,Array.from(r.keys()));for(let[p,x]of r.entries()){let m=M(x,t),A=L(m,t);A.valid||console.warn(`Object ${p} validation errors:`,A.errors),(y=m.transform)!=null&&y.position&&(m.transform.position=Z(m.transform.position,{x:0,y:0})),(C=m.transform)!=null&&C.offset&&(m.transform.offset=Z(m.transform.offset,{x:0,y:0})),(($=m.transform)==null?void 0:$.anchor)!==void 0&&(m.transform.anchor=le(m.transform.anchor)),((_=m.transform)==null?void 0:_.position_ratio)!==void 0&&m.transform.position_ratio!==null&&(m.transform.position_ratio=ce(m.transform.position_ratio,{x:.5,y:.5})),r.set(p,m)}if(e){if(e.objects)for(let[p,x]of e.objects.entries())r.set(p,x);e.engine&&(i.runtime={...i.runtime,...e.engine.runtime},i.assets={...i.assets,...e.engine.assets},i.splash={...(g=i.splash)!=null?g:{},...(c=e.engine.splash)!=null?c:{}})}let f={objects:r,engine:i,scene:a,schemas:t,theme:{background_color:"#ffffff",text_color:"#000000",square_color:"#cccccc",cta_background:"#007bff",cta_text:"#ffffff"},gameplay:{}};return typeof window!="undefined"&&(window.__editableConfig=f,window.__editableConfigBaseline||(window.__editableConfigBaseline=M(f,t))),o.length>0&&s?(console.log(`[CONFIG] \u2705 Applying ${o.length} persisted overrides on startup`),K(o,{silent:!1,persist:!1}),console.log("[CONFIG] \u2705 Overrides applied. Current config state:",{objectCount:((h=f.objects)==null?void 0:h.size)||0,sampleOverrides:o.slice(0,3).map(p=>`${p.objectId||"engine"}.${p.path} = ${typeof p.value=="string"?p.value.substring(0,30):JSON.stringify(p.value).substring(0,30)}`)})):o.length>0&&!s?console.warn(`[CONFIG] \u26A0\uFE0F Found ${o.length} persisted overrides but override mode is DISABLED. Overrides will NOT be applied.`):o.length===0&&console.log("[CONFIG] No persisted overrides found in localStorage"),console.log("[CONFIG] ===== Object-Centric Config Load Complete ====="),console.log("[CONFIG] Summary:",{schemas:Array.from(t.keys()),objects:Array.from(r.keys()),engine:{runtime:Object.keys((O=i.runtime)!=null?O:{}),assets:Object.keys((v=i.assets)!=null?v:{}),splash:Object.keys((b=i.splash)!=null?b:{}),loading:Object.keys((I=i.loading)!=null?I:{}),start:Object.keys((F=i.start)!=null?F:{}),tutorial:Object.keys((S=i.tutorial)!=null?S:{}),endgame:Object.keys((E=i.endgame)!=null?E:{})},scene:a.scene_id||"unknown"}),f}function fe(n){var t,o,s,a,i,r,f,u,y,C,$,_,g,c,h,O,v,b,I,F,S,E,p,x,m,A,D,W,B,q,U,J,V;let e={gameplay:{},ui:{},theme:{},assets:{}};for(let[se,l]of n.objects.entries()){let w=((t=l.identity)==null?void 0:t.id)||se;w.includes("character")&&(e.gameplay.character_pos=((o=l.transform)==null?void 0:o.position)||{x:0,y:0},e.gameplay.character_scale=((s=l.transform)==null?void 0:s.scale)||1,e.gameplay.character_anim_speed=((i=(a=l.gameplay)==null?void 0:a.tuning)==null?void 0:i.anim_speed)||.003,e.gameplay.character_relief_scale=((f=(r=l.gameplay)==null?void 0:r.tuning)==null?void 0:f.relief_scale)||1.22,e.gameplay.character_relief_speed=((y=(u=l.gameplay)==null?void 0:u.tuning)==null?void 0:y.relief_speed)||.22),(w.includes("gun")||w.includes("flame"))&&(e.gameplay.gun=l.gun||{},e.gameplay.gunmuzzle=((C=l.effects)==null?void 0:C.gunmuzzle)||{},e.gameplay.muzzle_levels=(($=l.effects)==null?void 0:$.muzzle_levels)||{},e.gameplay.flame=((_=l.effects)==null?void 0:_.flame)||{}),w.includes("diamond")&&(e.gameplay.diamond=l),w.includes("ice")&&(e.gameplay.melt=l.melt||{},e.gameplay.melt_anchor=((g=l.transform)==null?void 0:g.melt_anchor)||{x:0,y:0},e.gameplay.melt_pos=((c=l.transform)==null?void 0:c.position)||{x:0,y:0},e.gameplay.hybrid_melting=((h=l.effects)==null?void 0:h.hybrid_melting)||{},e.gameplay.physics_chunks=((O=l.effects)==null?void 0:O.physics_chunks)||{},e.gameplay.melting_particles=((v=l.effects)==null?void 0:v.melting_particles)||{},e.gameplay.hard_ice=l.hard_ice||{}),w.includes("water")&&(e.gameplay.water_drops=l),w.includes("crack")&&(e.gameplay.crack=l),w.includes("hand")&&(e.gameplay.hand=((b=l.gameplay)==null?void 0:b.tuning)||{},e.gameplay.brush_start_pos=((I=l.transform)==null?void 0:I.brush_start_pos)||{x:0,y:-120},e.gameplay.hand_scale=((F=l.transform)==null?void 0:F.scale)||1.5),w.includes("hazard")&&(e.gameplay.hazard=((S=l.gameplay)==null?void 0:S.tuning)||{},e.gameplay.danger_pos=((E=l.transform)==null?void 0:E.danger_pos)||{x:0,y:235},e.gameplay.danger_pulse=((x=(p=l.gameplay)==null?void 0:p.tuning)==null?void 0:x.danger_pulse)||{},e.gameplay.hazard_height=((A=(m=l.gameplay)==null?void 0:m.tuning)==null?void 0:A.hazard_height)||140)}return e.gameplay.timeline=((D=n.engine.runtime)==null?void 0:D.timeline)||{},e.gameplay.drag_surface=((W=n.engine.runtime)==null?void 0:W.drag_surface)||{},e.gameplay.background=((B=n.engine.runtime)==null?void 0:B.background)||{},e.gameplay.ui_styles=((q=n.engine.runtime)==null?void 0:q.ui_styles)||{},e.gameplay.label_pulse=((U=n.engine.runtime)==null?void 0:U.label_pulse)||{},e.ui=((J=n.engine.runtime)==null?void 0:J.ui)||{},e.theme=((V=n.engine.runtime)==null?void 0:V.theme)||{},e.assets=n.engine.assets||{},e}var T=class{shouldFullReload(e){return e.type==="component"||e.type==="scene"}getAffectedObjects(e){return e.type==="object"&&e.objectId?[e.objectId]:[]}},k=class{constructor(e=1e3){this.pollingInterval=null;this.fileHashes=new Map;this.callbacks=new Map;this.intervalMs=e}watch(e,t){this.callbacks.set(e,t),this.pollingInterval===null&&(this.pollingInterval=window.setInterval(()=>{this.checkAllFiles()},this.intervalMs))}async checkAllFiles(){for(let[e,t]of this.callbacks.entries())try{let o=`${e}?t=${Date.now()}&r=${Math.random()}`,s=await fetch(o,{cache:"no-cache",headers:{"Cache-Control":"no-cache"}});if(s.ok){let a=await s.text(),i=this.hashString(a),r=this.fileHashes.get(e);if(r&&r!==i&&console.log(`[HOT-RELOAD] File changed: ${e}`),r&&r!==i){console.log(`[HOT-RELOAD] File changed: ${e}`);let f=this.determineEventType(e);t(f),this.fileHashes.set(e,i)}else r||this.fileHashes.set(e,i)}}catch(o){console.warn(`Failed to check ${e}:`,o)}}determineEventType(e){var t,o;return e.includes("/components/")?{type:"component",path:e,componentName:(t=e.split("/").pop())==null?void 0:t.replace(".schema.json","")}:e.includes("/engine/")?{type:"engine",path:e}:e.includes("/scenes/")?{type:"scene",path:e}:e.includes("/objects/")?{type:"object",path:e,objectId:(o=e.split("/").pop())==null?void 0:o.replace(".json","")}:{type:"object",path:e}}hashString(e){let t=0;for(let o=0;o<e.length;o++){let s=e.charCodeAt(o);t=(t<<5)-t+s,t=t&t}return t.toString()}unwatch(e){this.callbacks.delete(e),this.fileHashes.delete(e)}stop(){this.pollingInterval!==null&&(clearInterval(this.pollingInterval),this.pollingInterval=null),this.callbacks.clear(),this.fileHashes.clear()}};function de(n,e){let t=[];function o(s,a,i=""){if(s!==a){if(typeof s!=typeof a){t.push(`${i}: type changed`);return}if(typeof s=="object"&&s!==null&&a!==null){let r=new Set([...Object.keys(s),...Object.keys(a)]);for(let f of r){let u=i?`${i}.${f}`:f;f in s?f in a?o(s[f],a[f],u):t.push(`${u}: removed`):t.push(`${u}: added`)}}else t.push(`${i}: changed`)}}return o(n,e),t}function ge(n,e,t,o){let s={...t};for(let[a,i]of o.entries())s[a]&&i.defaults&&(s[a]={...i.defaults,...s[a]});return s}var z={};function ue(n){if(typeof window=="undefined")return;let e=typeof z!="undefined"&&!!z.hot,t=window.location.search.includes("hot-reload");if(!(e||t))return;let s=null,a=!1,i=null;if(t){i=new k;let g=window.__configWatcher;g!=null&&g.stop&&g.stop(),window.__configWatcher=i}let r=new Set,f=g=>{var O,v;if(!i)return;let c=new Set;c.add("configs/engine/engine.runtime.json"),c.add("configs/engine/engine.assets.json"),c.add("configs/engine/engine.splash.json"),c.add("configs/scenes/scene.main.json");let h=(v=(O=g.scene)==null?void 0:O.objects)!=null?v:[];for(let b of h)b!=null&&b.object_config&&c.add(`configs/objects/${b.object_config}.json`);for(let b of r)c.has(b)||i.unwatch(b);for(let b of c)r.has(b)||i.watch(b,I=>_(I));r=c},u=new Set,y=!1,C=async g=>{let c=await N(g),h=M(c,n.activeConfig.schemas),O=L(h,n.activeConfig.schemas);O.valid||console.warn(`[HOT-RELOAD] ${g} validation errors:`,O.errors),await n.liveEditBridge.applyObjectConfig(g,h)};async function $(g){if(!a){a=!0;try{if(y||u.size===0){n.audioSystem.destroy();let c=await R("scene.main");n.setActiveConfig(c),n.gameObjectManager.updateConfig(c),n.CustomAssets.updateConfig(c),await n.CustomAssets.ready();let h=n.createAudioSystem(c);n.setAudioSystem(h),window.__audioSystem=h,await h.start(),n.liveEditBridge.rebuildIndexes(),f(c),console.log(`[GAME] Hot-reload complete (${g})`)}else{let c=Array.from(u);u.clear();for(let h of c)await C(h);console.log(`[GAME] Hot-reload updated objects: ${c.join(", ")}`)}}catch(c){console.warn("[GAME] Hot-reload failed:",c)}finally{a=!1,y=!1,u.clear()}}}function _(g){g.type==="object"&&g.objectId?u.add(g.objectId):y=!0,s&&window.clearTimeout(s),s=window.setTimeout(()=>{$(g.type)},120)}e&&z.hot.on("config-change",()=>{_({type:"hmr"})}),t&&(f(n.activeConfig),console.log(`[GAME] Hot-reload watcher enabled (${r.size} files)`))}export{ee as a,N as b,ne as c,te as d,re as e,oe as f,L as g,M as h,R as i,fe as j,T as k,k as l,de as m,ge as n,ue as o};
|