@dcl/wearable-preview 2.15.1 → 2.15.2-27762338849.commit-2ed460d
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/{static-local/assets/Preview-BcI1c3PG.css → assets/Preview-1QMr_55d.css} +1 -1
- package/{static-local/assets/Preview-DirIS6ek.js → assets/Preview-DzgqBNMi.js} +470 -463
- package/assets/UnityPreview-DSZZDffP.js +1 -0
- package/assets/babylon.inspector.bundle.max-BvAiNd9o.js +2553 -0
- package/assets/{emote-events-BX6KqMpm.js → emote-events-CX6D6_1X.js} +1 -1
- package/assets/{index-B818RqYE.js → index-B1wDfGPg.js} +3 -3
- package/index.html +3 -3
- package/package.json +3 -3
- package/{assets/Preview-BcI1c3PG.css → static-local/assets/Preview-1QMr_55d.css} +1 -1
- package/{assets/Preview-BXgZMph6.js → static-local/assets/Preview-D5dVYaUl.js} +470 -463
- package/static-local/assets/{UnityPreview-CyUCz4bI.js → UnityPreview-D7Whkxuv.js} +1 -1
- package/static-local/assets/babylon.inspector.bundle.max-phi5yTE6.js +2553 -0
- package/static-local/assets/{emote-events-BPT0lBP-.js → emote-events-CCo6yXyZ.js} +1 -1
- package/static-local/assets/{index-D4vp_VAp.js → index-DxPv7n4y.js} +2 -2
- package/static-local/index.html +1 -1
- package/static-local/package.json +1 -1
- package/assets/UnityPreview-CzM-APKR.js +0 -1
- package/assets/babylon.inspector.bundle.max-DaeWtyC9.js +0 -2560
- package/static-local/assets/babylon.inspector.bundle.max-COjAeG6j.js +0 -2560
|
@@ -1 +1 @@
|
|
|
1
|
-
import{c as k,a as j,r as c,b as W,R as ie,j as U}from"./index-D4vp_VAp.js";import{m as le,i as K,d,L as de,a as ce,b as te,g as ue,u as re,s as Se,f as me,c as Ee,e as ge,h as ye,j as pe,k as $,l as G,n as fe,o as we,p as he,q as Re,r as F,t as L,v as Pe}from"./emote-events-BPT0lBP-.js";var x=(e=>(e.SET_MODE="SetMode",e.SET_PROFILE="SetProfile",e.SET_EMOTE="SetEmote",e.SET_URNS="SetUrns",e.SET_BACKGROUND="SetBackground",e.SET_SKIN_COLOR="SetSkinColor",e.SET_HAIR_COLOR="SetHairColor",e.SET_EYE_COLOR="SetEyeColor",e.SET_BODY_SHAPE="SetBodyShape",e.SET_SHOW_ANIMATION_REFERENCE="SetShowAnimationReference",e.SET_PROJECTION="SetProjection",e.ADD_BASE64="AddBase64",e.CLEAR_BASE64="ClearBase64",e.SET_CONTRACT="SetContract",e.SET_ITEM_ID="SetItemID",e.SET_TOKEN_ID="SetTokenID",e.SET_DISABLE_LOADER="SetDisableLoader",e.RELOAD="Reload",e.CLEANUP="Cleanup",e.GET_ELEMENT_BOUNDS="GetElementBounds",e.SET_SPRING_BONES_PARAMS="SetSpringBonesParams",e))(x||{});const Ie={unityMode:"SetMode",profile:"SetProfile",emote:"SetEmote",urns:"SetUrns",background:"SetBackground",skin:"SetSkinColor",hair:"SetHairColor",eyes:"SetEyeColor",bodyShape:"SetBodyShape",showAnimationReference:"SetShowAnimationReference",projection:"SetProjection",base64s:"AddBase64",contractAddress:"SetContract",itemId:"SetItemID",tokenId:"SetTokenID",disableLoader:"SetDisableLoader"},Ae={unityMode:e=>String(e),profile:e=>String(e),emote:e=>String(e),urns:e=>Array.isArray(e)?e.join(","):String(e),background:e=>typeof e=="string"?e.replace("#",""):String(e),skin:e=>typeof e=="string"?e.replace("#",""):String(e),hair:e=>typeof e=="string"?e.replace("#",""):String(e),eyes:e=>typeof e=="string"?e.replace("#",""):String(e),bodyShape:e=>String(e),showAnimationReference:e=>String(e),projection:e=>String(e),contractAddress:e=>String(e),itemId:e=>String(e),tokenId:e=>String(e),disableLoader:e=>String(e)},C=(e,t,a)=>{if(e)try{const r=String(t);Object.values(x).includes(r)||(console.warn(`Unknown Unity method: ${r}. Sending anyway...`),k(`Unknown Unity method: ${r}`,{method:r,value:a})),a!==void 0?e.SendMessage("JSBridge",r,a):e.SendMessage("JSBridge",r)}catch(r){console.error(`Failed to send Unity message ${t}:`,r),j(r,{method:String(t),value:a})}else console.warn(`Unity instance not ready, cannot send message: ${t}`),k(`Unity instance not ready, cannot send message: ${t}`,{method:String(t)})},Te=(e,t,a)=>{if(!e){console.warn("Unity instance not available, cannot send override messages"),k("Unity instance not available, cannot send override messages");return}let r=0;t.base64s!==void 0&&a.base64s&&(C(e,"ClearBase64"),r++,Array.isArray(t.base64s)&&t.base64s.length>0&&t.base64s.forEach(n=>{C(e,"AddBase64",n),r++})),Object.entries(t).forEach(([n,s])=>{if(n!=="base64s"&&a[n]&&s!==void 0){const o=Ie[n];if(o){const i=Ae[n],E=i?i(s):String(s);C(e,o,E),r++}else console.warn(`No Unity method mapping found for property: ${n}`),k(`No Unity method mapping found for property: ${n}`,{property:n,value:s})}}),r>0&&C(e,"Reload")};var be={VITE_BASE_URL:""};const V=new Map,_=(e,t)=>t;function ve(e){if(V.has(e))return V.get(e);const t=new Promise((a,r)=>{const n=document.querySelector(`script[src="${e}"]`);if(n){n.addEventListener("load",()=>a(n)),n.addEventListener("error",o=>r(o));return}const s=document.createElement("script");s.src=e,s.async=!0,s.onload=()=>a(s),s.onerror=o=>r(o),document.body.appendChild(s)});return V.set(e,t),t}const Oe=async(e,t,a,r,n,s,o,i,E,m,S,g)=>{try{const u=be.VITE_BASE_URL||"";return await ve(_(u,t)),await createUnityInstance(e,{dataUrl:_(u,a),frameworkUrl:_(u,r),codeUrl:_(u,n),streamingAssetsUrl:_(u,o),symbolUrl:_(u,s),companyName:i,productName:E,productVersion:m,matchWebGLToCanvasSize:S,arguments:g})}catch(u){throw console.error("❌ Failed to load Unity instance:",u),u}},Le="data:image/png;base64,";function _e(e){return{getScreenshot:()=>new Promise(t=>{if(!e){t("");return}e.SendMessage("JSBridge","TakeScreenshot",""),window.addEventListener("message",function a(r){if(r.data.type==="unity-renderer"){const{type:n,payload:s}=r.data.payload;n==="screenshot"&&(window.removeEventListener("message",a),t(Le+s))}})}),getMetrics:()=>new Promise(t=>{if(!e){t({triangles:0,materials:0,textures:0,meshes:0,bodies:0,entities:0});return}e.SendMessage("JSBridge","GetMetrics",""),window.addEventListener("message",function a(r){if(r.data.type==="unity-renderer"){const{type:n,payload:s}=r.data.payload;n==="metrics"&&(window.removeEventListener("message",a),t(s))}})}),changeZoom:async t=>{e&&e.SendMessage("JSBridge","SetZoom",t.toString())},panCamera:async t=>{if(!e)return;const a=t.x??0,r=t.y??0,n=t.z??0;e.SendMessage("JSBridge","SetOffset",`${a},${r},${n}`)},changeCameraPosition:async t=>{if(!e)return;const a=t.alpha??0,r=t.beta??0,n=t.radius??0;e.SendMessage("JSBridge","SetCameraPosition",`${a},${r},${n}`)},setUsername:async t=>{e&&e.SendMessage("JSBridge","SetUsername",t)},cleanup:async()=>{e&&e.SendMessage("JSBridge","Cleanup","")}}}function Ne(e,t,a,r){const n=le();let s=0,o=0,i="stopped",E=null,m=0;const S=()=>{var l;return a?a.loop:!!((l=t==null?void 0:t.emoteDataADR74)!=null&&l.loop||r&&de.includes(r))},g=()=>{u(),m=Date.now(),E=setInterval(()=>{if(i!=="playing")return;const l=Date.now(),y=(l-m)/1e3;if(m=l,o+=y,s>0&&o>=s)if(S())o=o%s,n.emit(d.PreviewEmoteEventType.ANIMATION_LOOP);else{o=s,u(),i="stopped",e.SendMessage("JSBridge","StopEmote",""),n.emit(d.PreviewEmoteEventType.ANIMATION_PLAYING,{length:o}),n.emit(d.PreviewEmoteEventType.ANIMATION_END);return}n.emit(d.PreviewEmoteEventType.ANIMATION_PLAYING,{length:o})},15)},u=()=>{E!==null&&(clearInterval(E),E=null)},p=(l,y,f)=>new Promise(v=>{if(!e){v(f);return}const T=R=>{if(R.data.type==="unity-renderer"){const{type:I,payload:w}=R.data.payload;I===y&&(window.removeEventListener("message",T),v(w))}};window.addEventListener("message",T),l()});return{getLength:async()=>await p(()=>e.SendMessage("JSBridge","GetEmoteLength",""),"emoteLength",0)??0,isPlaying:async()=>p(()=>e.SendMessage("JSBridge","IsEmotePlaying",""),"isEmotePlaying",!1),goTo:async l=>{e&&(o=l,e.SendMessage("JSBridge","GoToEmote",l.toString()),n.emit(d.PreviewEmoteEventType.ANIMATION_PLAYING,{length:l}))},play:async()=>{e&&(s<=0&&(s=await p(()=>e.SendMessage("JSBridge","GetEmoteLength",""),"emoteLength",0)),i==="stopped"&&(o=0),i="playing",e.SendMessage("JSBridge","PlayEmote",""),g(),n.emit(d.PreviewEmoteEventType.ANIMATION_PLAY))},pause:async()=>{e&&(i="paused",u(),e.SendMessage("JSBridge","PauseEmote",""),n.emit(d.PreviewEmoteEventType.ANIMATION_PAUSE))},stop:async()=>{e&&(i="stopped",o=0,u(),e.SendMessage("JSBridge","StopEmote",""),n.emit(d.PreviewEmoteEventType.ANIMATION_END))},enableSound:async()=>{e&&e.SendMessage("JSBridge","EnableSound","")},disableSound:async()=>{e&&e.SendMessage("JSBridge","DisableSound","")},hasSound:async()=>p(()=>e.SendMessage("JSBridge","HasSound",""),"hasSound",!1),isSocialEmote:async()=>K(t),getSocialEmoteAnimations:async()=>!t||!K(t)?null:[{title:"Start Animation",...t.emoteDataADR74.startAnimation},...t.emoteDataADR74.outcomes.map(l=>({title:l.title,loop:l.loop,audio:l.audio,...l.clips}))],getPlayingSocialEmoteAnimation:async()=>a??null,emote:t,events:n}}function Ce(e){return{setSpringBonesParams:async(t,a)=>{e&&e.SendMessage("JSBridge",x.SET_SPRING_BONES_PARAMS,JSON.stringify({itemId:t,params:a}))}}}const Me={dataUrl:"/unity/Build/aang-renderer.data.br",frameworkUrl:"/unity/Build/aang-renderer.framework.js.br",codeUrl:"/unity/Build/aang-renderer.wasm.br",symbolUrl:"/unity/Build/aang-renderer.symbols.json.br"};function De(){return Me}async function Ue(e,t){let a=null;try{const r=De();if(a=await Oe(e,"/unity/Build/aang-renderer.loader.js",r.dataUrl,r.frameworkUrl,r.codeUrl,r.symbolUrl,"/emotes","Decentraland","AangRenderer","2.2.2",!0,[]),!a)throw new Error("Failed to load Unity instance");const n=t!=null&&t.itemDefinition&&ce(t.itemDefinition)?t.itemDefinition:null,s=(t==null?void 0:t.socialEmote)||void 0,o=(t==null?void 0:t.emote)||null,i=_e(a),E=Ne(a,n,s,o),m=Ce(a);if(t!=null&&t.itemDefinition&&t.bodyShape&&te(t.itemDefinition)){const S=ue(t.itemDefinition,t.bodyShape);S&&m.setSpringBonesParams(t.itemDefinition.id,S)}return{scene:i,emote:E,physics:m,unity:a}}catch(r){if(console.error("Unity render failed:",r),a!=null&&a.Quit)try{a.Quit()}catch(n){console.error("Error quitting Unity instance:",n),j(n,{phase:"unityQuit"})}throw r}}const Be=()=>Math.floor(Math.random()*159)+1,ne=()=>`default${Be()}`,ke=(e,t)=>{var a,r,n,s,o,i;return{eyes:$(t.eyes||((r=(a=e==null?void 0:e.avatar)==null?void 0:a.eyes)==null?void 0:r.color)&&G(e.avatar.eyes.color)||"#000000"),hair:$(t.hair||((s=(n=e==null?void 0:e.avatar)==null?void 0:n.hair)==null?void 0:s.color)&&G(e.avatar.hair.color)||"#000000"),skin:$(t.skin||((i=(o=e==null?void 0:e.avatar)==null?void 0:o.skin)==null?void 0:i.color)&&G(e.avatar.skin.color)||"#cc9b76")}},N=e=>e||"",X=e=>e||[],B=e=>e.replace("#","");function Z(e){const t=new URL(window.location.href);Object.entries(e).forEach(([a,r])=>{t.searchParams.delete(a),Array.isArray(r)?r.forEach(n=>{n!==""&&t.searchParams.append(a,n)}):r!==""&&t.searchParams.set(a,r)}),window.history.replaceState({},"",t.toString())}function je(){const{options:e,overrideSources:t}=re(),[a,r]=c.useState(null),[n,s]=c.useState(!0),[o,i]=c.useState(null),E=c.useRef(null),m=c.useRef(e),S=c.useRef(!0);return c.useEffect(()=>{const g=JSON.stringify(e),u=JSON.stringify(m.current);if(!S.current&&g===u)return;S.current=!1,m.current=e,(async()=>{var l,y;try{s(!0),i(null);const f=e.peerUrl||W.get("PEER_URL"),v=e.marketplaceServerUrl||e.nftServerUrl||W.get("MARKETPLACE_SERVER_URL");let T=d.PreviewType.WEARABLE,R={color:e.background||"#4b4852",transparent:e.disableBackground===!0};const I=Se(e.profile);let w=I==null?void 0:I.value;w==="default"&&(w=ne());const P=w&&I?I.type==="address"?await me(w,f):await Ee(w,f):null,A=e.bodyShape||((l=P==null?void 0:P.avatar)==null?void 0:l.bodyShape)||d.BodyShape.MALE;let h=null;if(e.contractAddress&&(h=await ge({contractAddress:e.contractAddress,tokenId:e.tokenId,itemId:e.itemId,peerUrl:f,marketplaceServerUrl:v}),h&&te(h))){R={...R,image:h.thumbnail};const D=ye(h);pe(D)&&(T=d.PreviewType.TEXTURE)}const{eyes:b,hair:H,skin:Y}=ke(P,{eyes:e.eyes,hair:e.hair,skin:e.skin}),M=e.unityMode||null,ae=e.camera&&Object.values(d.PreviewCamera).includes(e.camera)?e.camera:d.PreviewCamera.INTERACTIVE,Q=e.projection&&Object.values(d.PreviewProjection).includes(e.projection)?e.projection:d.PreviewProjection.PERSPECTIVE,O=e.disableDefaultEmotes?null:e.emote&&Object.values(d.PreviewEmote).includes(e.emote)?e.emote:d.PreviewEmote.IDLE,J={background:R,bodyShape:A,mode:M,projection:Q,type:T,base64:((y=e.base64s)==null?void 0:y[0])||null,contract:e.contractAddress||null,disableLoader:e.disableLoader||!1,emote:(O==null?void 0:O.toString())||null,eyeColor:b.replace("#",""),hairColor:H.replace("#",""),item:e.itemId||null,profile:w||null,skinColor:Y.replace("#",""),token:e.tokenId||null,urn:e.urns||null,showAnimationReference:null,itemDefinition:h,socialEmote:e.socialEmote||null},se=JSON.stringify(J),oe=JSON.stringify(E.current);if(se!==oe){if(E.current=J,Object.keys(t).length===0){const D=X(e.urns),q=X(e.base64s);if(M===d.PreviewUnityMode.CONFIG){const z={mode:N(M||"")};Z(z)}else{const z={background:R.transparent?"":B(R.color),disableLoader:e.disableLoader?"true":"",profile:N(w||""),bodyShape:N(A||""),eyeColor:B(b||""),hairColor:B(H||""),skinColor:B(Y||""),mode:N(M||""),camera:ae,projection:Q,emote:N((O==null?void 0:O.toString())||""),urn:D.length>0?D:[""],base64:q.length>0?q:[""]};Z(z)}}r(J)}s(!1)}catch(f){console.error("[useUnityConfig] Failed to load config:",f),i(f instanceof Error?f.message:"Failed to load config"),s(!1)}})()},[e,t]),[a,n,o]}const xe="unity-renderer",Je="unity-canvas",ee=1,ze="Failed to load Unity";var $e=(e=>(e.LOADED="loaded",e.ERROR="error",e.SCREENSHOT="screenshot",e.CUSTOMIZATION_DONE="customization-done",e.CUSTOMIZATION_STEP="avatar-customization-step",e.ELEMENT_BOUNDS="element-bounds",e))($e||{});const Ge="get_element_bounds",Fe="element_bounds_response",Ve=(e,t,a,r)=>{const[n,s]=c.useState({isLoaded:!1,isInitialized:!1,error:null}),o=c.useRef(null),i=c.useCallback(m=>{if(m.data.type===xe){const{type:S,payload:g}=m.data.payload;S==="loaded"&&(g===!0||g==="true")?(s(u=>({...u,isLoaded:!0,isInitialized:!0})),d.sendMessage(L(),d.PreviewMessageType.LOAD,{renderer:d.PreviewRenderer.UNITY}),t.current&&t.current.emote.play()):S==="customization-done"?d.sendMessage(L(),d.PreviewMessageType.CONTROLLER_RESPONSE,{id:"customization-done",ok:!0,result:JSON.parse(m.data.payload.payload)}):S==="avatar-customization-step"?d.sendMessage(L(),d.PreviewMessageType.CONTROLLER_RESPONSE,{id:"avatar-customization-step",ok:!0,result:{step:m.data.payload.payload}}):S==="element-bounds"?d.sendMessage(L(),Fe,g):S==="error"&&(j(new Error(g),{component:"UnityPreview",phase:"unityMessage"}),s(u=>({...u,error:g})),d.sendMessage(L(),d.PreviewMessageType.ERROR,{message:"Error loading the wearable. Please try again."}))}},[]),E=c.useCallback(async m=>{if(!(!e.canvas.current||e.isInitializing.current||e.unityInstance.current)){e.isInitializing.current=!0,s(S=>({...S,isLoaded:!1,error:null}));try{const{unity:S,...g}=await Ue(e.canvas.current,m);e.unityInstance.current=S,t.current=g,o.current&&o.current(),o.current=Pe(t.current),s(u=>({...u,isInitialized:!0}))}catch(S){const g=S instanceof Error?S.message:ze;console.error("Unity init failed:",S),j(S,{component:"UnityPreview",phase:"initializeUnity"}),s(u=>({...u,error:g})),d.sendMessage(L(),d.PreviewMessageType.ERROR,{message:g})}finally{e.isInitializing.current=!1}}},[e,t]);return c.useEffect(()=>{n.isInitialized||r||!a||E(a)},[a,r,n.isInitialized,E]),c.useEffect(()=>()=>{o.current&&o.current()},[]),c.useEffect(()=>{if(a)return window.addEventListener("message",i,!1),()=>{window.removeEventListener("message",i,!1)}},[a,i]),n},He=e=>{const[t,a]=c.useState({pixelRatio:window.devicePixelRatio||ee,is3D:!0,backgroundImage:""});return c.useEffect(()=>{const r=()=>{a(s=>({...s,pixelRatio:window.devicePixelRatio||ee}))},n=window.matchMedia(`(resolution: ${t.pixelRatio}dppx)`);return n.addEventListener("change",r),()=>{n.removeEventListener("change",r)}},[t.pixelRatio]),c.useEffect(()=>{e&&a(r=>({...r,backgroundImage:e.background.image||"",is3D:e.type!==d.PreviewType.TEXTURE}))},[e]),t},Ye=(e,t,a,r,n)=>{const s=c.useMemo(()=>{const o={};for(const i of Object.keys(n))n[i]&&r[i]!==void 0&&(o[i]=r[i]);return o},[n,r]);c.useEffect(()=>{if(!(!a.isInitialized||!a.isLoaded||!e.current)){if(s.profile==="default"){const o=t.current.profile;s.profile=o!=null&&o.match(/^default\d+$/)?o:ne()}Object.keys(s).length>0&&(Te(e.current,s,n),t.current=s)}},[a.isInitialized,a.isLoaded,s,n,e,t])},Qe=()=>{const{width:e=window.innerWidth,height:t=window.innerHeight}=fe(),a=c.useRef(null),r=c.useRef(null),n=c.useRef(!1),s=c.useRef({}),o=we(),[i,E,m]=je(),{options:S,overrideSources:g}=re(),u=c.useMemo(()=>({canvas:a,unityInstance:r,isInitializing:n,lastSentOverrides:s}),[]);he(P=>{var A,h;if(((A=P.data)==null?void 0:A.type)===Ge&&r.current){const b=(h=P.data.payload)==null?void 0:h.elementName;b&&C(r.current,x.GET_ELEMENT_BOUNDS,b)}});const p=Ve(u,o,i,E),l=He(i);Ye(u.unityInstance,u.lastSentOverrides,p,S,g),Re();const y=c.useMemo(()=>{const P=p.error||m,A=!p.isLoaded&&!P,h=!!l.backgroundImage&&!l.is3D&&!A,b=l.is3D&&!A;return{error:P,isLoading:A,showImage:h,showCanvas:b}},[p.error,p.isLoaded,m,l.backgroundImage,l.is3D]),f=c.useMemo(()=>({opacity:1,backgroundColor:!(i!=null&&i.background.transparent)&&(i==null?void 0:i.type)===d.PreviewType.TEXTURE?i.background.color:void 0}),[i]),v=c.useMemo(()=>({width:`${e}px`,height:`${t}px`}),[e,t]),T=c.useMemo(()=>({width:Math.round(e*l.pixelRatio),height:Math.round(t*l.pixelRatio)}),[e,t,l.pixelRatio]),R=c.useMemo(()=>F("Preview",{"is-loading":y.isLoading,"is-loaded":p.isLoaded,"is-3d":l.is3D,"has-error":!!y.error}),[y.isLoading,p.isLoaded,l.is3D,y.error]),I=c.useMemo(()=>F("thumbnail",{"is-visible":y.showImage}),[y.showImage]),w=c.useMemo(()=>F({"is-visible":y.showCanvas}),[y.showCanvas]);return U.jsxs("div",{className:R,style:f,children:[U.jsx("img",{src:l.backgroundImage,className:I,alt:"preview"}),U.jsx("canvas",{ref:u.canvas,id:Je,className:w,width:T.width,height:T.height,style:v}),y.error&&U.jsx("div",{className:"error",children:y.error})]})},Ke=ie.memo(Qe);export{$e as UnityMessageType,Ke as default};
|
|
1
|
+
import{c as k,a as j,r as c,b as W,R as ie,j as U}from"./index-DxPv7n4y.js";import{m as le,i as K,d,L as de,a as ce,b as te,g as ue,u as re,s as Se,f as me,c as Ee,e as ge,h as ye,j as pe,k as $,l as G,n as fe,o as we,p as he,q as Re,r as F,t as L,v as Pe}from"./emote-events-CCo6yXyZ.js";var x=(e=>(e.SET_MODE="SetMode",e.SET_PROFILE="SetProfile",e.SET_EMOTE="SetEmote",e.SET_URNS="SetUrns",e.SET_BACKGROUND="SetBackground",e.SET_SKIN_COLOR="SetSkinColor",e.SET_HAIR_COLOR="SetHairColor",e.SET_EYE_COLOR="SetEyeColor",e.SET_BODY_SHAPE="SetBodyShape",e.SET_SHOW_ANIMATION_REFERENCE="SetShowAnimationReference",e.SET_PROJECTION="SetProjection",e.ADD_BASE64="AddBase64",e.CLEAR_BASE64="ClearBase64",e.SET_CONTRACT="SetContract",e.SET_ITEM_ID="SetItemID",e.SET_TOKEN_ID="SetTokenID",e.SET_DISABLE_LOADER="SetDisableLoader",e.RELOAD="Reload",e.CLEANUP="Cleanup",e.GET_ELEMENT_BOUNDS="GetElementBounds",e.SET_SPRING_BONES_PARAMS="SetSpringBonesParams",e))(x||{});const Ie={unityMode:"SetMode",profile:"SetProfile",emote:"SetEmote",urns:"SetUrns",background:"SetBackground",skin:"SetSkinColor",hair:"SetHairColor",eyes:"SetEyeColor",bodyShape:"SetBodyShape",showAnimationReference:"SetShowAnimationReference",projection:"SetProjection",base64s:"AddBase64",contractAddress:"SetContract",itemId:"SetItemID",tokenId:"SetTokenID",disableLoader:"SetDisableLoader"},Ae={unityMode:e=>String(e),profile:e=>String(e),emote:e=>String(e),urns:e=>Array.isArray(e)?e.join(","):String(e),background:e=>typeof e=="string"?e.replace("#",""):String(e),skin:e=>typeof e=="string"?e.replace("#",""):String(e),hair:e=>typeof e=="string"?e.replace("#",""):String(e),eyes:e=>typeof e=="string"?e.replace("#",""):String(e),bodyShape:e=>String(e),showAnimationReference:e=>String(e),projection:e=>String(e),contractAddress:e=>String(e),itemId:e=>String(e),tokenId:e=>String(e),disableLoader:e=>String(e)},C=(e,t,a)=>{if(e)try{const r=String(t);Object.values(x).includes(r)||(console.warn(`Unknown Unity method: ${r}. Sending anyway...`),k(`Unknown Unity method: ${r}`,{method:r,value:a})),a!==void 0?e.SendMessage("JSBridge",r,a):e.SendMessage("JSBridge",r)}catch(r){console.error(`Failed to send Unity message ${t}:`,r),j(r,{method:String(t),value:a})}else console.warn(`Unity instance not ready, cannot send message: ${t}`),k(`Unity instance not ready, cannot send message: ${t}`,{method:String(t)})},Te=(e,t,a)=>{if(!e){console.warn("Unity instance not available, cannot send override messages"),k("Unity instance not available, cannot send override messages");return}let r=0;t.base64s!==void 0&&a.base64s&&(C(e,"ClearBase64"),r++,Array.isArray(t.base64s)&&t.base64s.length>0&&t.base64s.forEach(n=>{C(e,"AddBase64",n),r++})),Object.entries(t).forEach(([n,s])=>{if(n!=="base64s"&&a[n]&&s!==void 0){const o=Ie[n];if(o){const i=Ae[n],E=i?i(s):String(s);C(e,o,E),r++}else console.warn(`No Unity method mapping found for property: ${n}`),k(`No Unity method mapping found for property: ${n}`,{property:n,value:s})}}),r>0&&C(e,"Reload")};var be={VITE_BASE_URL:""};const V=new Map,_=(e,t)=>t;function ve(e){if(V.has(e))return V.get(e);const t=new Promise((a,r)=>{const n=document.querySelector(`script[src="${e}"]`);if(n){n.addEventListener("load",()=>a(n)),n.addEventListener("error",o=>r(o));return}const s=document.createElement("script");s.src=e,s.async=!0,s.onload=()=>a(s),s.onerror=o=>r(o),document.body.appendChild(s)});return V.set(e,t),t}const Oe=async(e,t,a,r,n,s,o,i,E,m,S,g)=>{try{const u=be.VITE_BASE_URL||"";return await ve(_(u,t)),await createUnityInstance(e,{dataUrl:_(u,a),frameworkUrl:_(u,r),codeUrl:_(u,n),streamingAssetsUrl:_(u,o),symbolUrl:_(u,s),companyName:i,productName:E,productVersion:m,matchWebGLToCanvasSize:S,arguments:g})}catch(u){throw console.error("❌ Failed to load Unity instance:",u),u}},Le="data:image/png;base64,";function _e(e){return{getScreenshot:()=>new Promise(t=>{if(!e){t("");return}e.SendMessage("JSBridge","TakeScreenshot",""),window.addEventListener("message",function a(r){if(r.data.type==="unity-renderer"){const{type:n,payload:s}=r.data.payload;n==="screenshot"&&(window.removeEventListener("message",a),t(Le+s))}})}),getMetrics:()=>new Promise(t=>{if(!e){t({triangles:0,materials:0,textures:0,meshes:0,bodies:0,entities:0});return}e.SendMessage("JSBridge","GetMetrics",""),window.addEventListener("message",function a(r){if(r.data.type==="unity-renderer"){const{type:n,payload:s}=r.data.payload;n==="metrics"&&(window.removeEventListener("message",a),t(s))}})}),changeZoom:async t=>{e&&e.SendMessage("JSBridge","SetZoom",t.toString())},panCamera:async t=>{if(!e)return;const a=t.x??0,r=t.y??0,n=t.z??0;e.SendMessage("JSBridge","SetOffset",`${a},${r},${n}`)},changeCameraPosition:async t=>{if(!e)return;const a=t.alpha??0,r=t.beta??0,n=t.radius??0;e.SendMessage("JSBridge","SetCameraPosition",`${a},${r},${n}`)},setUsername:async t=>{e&&e.SendMessage("JSBridge","SetUsername",t)},cleanup:async()=>{e&&e.SendMessage("JSBridge","Cleanup","")}}}function Ne(e,t,a,r){const n=le();let s=0,o=0,i="stopped",E=null,m=0;const S=()=>{var l;return a?a.loop:!!((l=t==null?void 0:t.emoteDataADR74)!=null&&l.loop||r&&de.includes(r))},g=()=>{u(),m=Date.now(),E=setInterval(()=>{if(i!=="playing")return;const l=Date.now(),y=(l-m)/1e3;if(m=l,o+=y,s>0&&o>=s)if(S())o=o%s,n.emit(d.PreviewEmoteEventType.ANIMATION_LOOP);else{o=s,u(),i="stopped",e.SendMessage("JSBridge","StopEmote",""),n.emit(d.PreviewEmoteEventType.ANIMATION_PLAYING,{length:o}),n.emit(d.PreviewEmoteEventType.ANIMATION_END);return}n.emit(d.PreviewEmoteEventType.ANIMATION_PLAYING,{length:o})},15)},u=()=>{E!==null&&(clearInterval(E),E=null)},p=(l,y,f)=>new Promise(v=>{if(!e){v(f);return}const T=R=>{if(R.data.type==="unity-renderer"){const{type:I,payload:w}=R.data.payload;I===y&&(window.removeEventListener("message",T),v(w))}};window.addEventListener("message",T),l()});return{getLength:async()=>await p(()=>e.SendMessage("JSBridge","GetEmoteLength",""),"emoteLength",0)??0,isPlaying:async()=>p(()=>e.SendMessage("JSBridge","IsEmotePlaying",""),"isEmotePlaying",!1),goTo:async l=>{e&&(o=l,e.SendMessage("JSBridge","GoToEmote",l.toString()),n.emit(d.PreviewEmoteEventType.ANIMATION_PLAYING,{length:l}))},play:async()=>{e&&(s<=0&&(s=await p(()=>e.SendMessage("JSBridge","GetEmoteLength",""),"emoteLength",0)),i==="stopped"&&(o=0),i="playing",e.SendMessage("JSBridge","PlayEmote",""),g(),n.emit(d.PreviewEmoteEventType.ANIMATION_PLAY))},pause:async()=>{e&&(i="paused",u(),e.SendMessage("JSBridge","PauseEmote",""),n.emit(d.PreviewEmoteEventType.ANIMATION_PAUSE))},stop:async()=>{e&&(i="stopped",o=0,u(),e.SendMessage("JSBridge","StopEmote",""),n.emit(d.PreviewEmoteEventType.ANIMATION_END))},enableSound:async()=>{e&&e.SendMessage("JSBridge","EnableSound","")},disableSound:async()=>{e&&e.SendMessage("JSBridge","DisableSound","")},hasSound:async()=>p(()=>e.SendMessage("JSBridge","HasSound",""),"hasSound",!1),isSocialEmote:async()=>K(t),getSocialEmoteAnimations:async()=>!t||!K(t)?null:[{title:"Start Animation",...t.emoteDataADR74.startAnimation},...t.emoteDataADR74.outcomes.map(l=>({title:l.title,loop:l.loop,audio:l.audio,...l.clips}))],getPlayingSocialEmoteAnimation:async()=>a??null,emote:t,events:n}}function Ce(e){return{setSpringBonesParams:async(t,a)=>{e&&e.SendMessage("JSBridge",x.SET_SPRING_BONES_PARAMS,JSON.stringify({itemId:t,params:a}))}}}const Me={dataUrl:"/unity/Build/aang-renderer.data.br",frameworkUrl:"/unity/Build/aang-renderer.framework.js.br",codeUrl:"/unity/Build/aang-renderer.wasm.br",symbolUrl:"/unity/Build/aang-renderer.symbols.json.br"};function De(){return Me}async function Ue(e,t){let a=null;try{const r=De();if(a=await Oe(e,"/unity/Build/aang-renderer.loader.js",r.dataUrl,r.frameworkUrl,r.codeUrl,r.symbolUrl,"/emotes","Decentraland","AangRenderer","2.2.2",!0,[]),!a)throw new Error("Failed to load Unity instance");const n=t!=null&&t.itemDefinition&&ce(t.itemDefinition)?t.itemDefinition:null,s=(t==null?void 0:t.socialEmote)||void 0,o=(t==null?void 0:t.emote)||null,i=_e(a),E=Ne(a,n,s,o),m=Ce(a);if(t!=null&&t.itemDefinition&&t.bodyShape&&te(t.itemDefinition)){const S=ue(t.itemDefinition,t.bodyShape);S&&m.setSpringBonesParams(t.itemDefinition.id,S)}return{scene:i,emote:E,physics:m,unity:a}}catch(r){if(console.error("Unity render failed:",r),a!=null&&a.Quit)try{a.Quit()}catch(n){console.error("Error quitting Unity instance:",n),j(n,{phase:"unityQuit"})}throw r}}const Be=()=>Math.floor(Math.random()*159)+1,ne=()=>`default${Be()}`,ke=(e,t)=>{var a,r,n,s,o,i;return{eyes:$(t.eyes||((r=(a=e==null?void 0:e.avatar)==null?void 0:a.eyes)==null?void 0:r.color)&&G(e.avatar.eyes.color)||"#000000"),hair:$(t.hair||((s=(n=e==null?void 0:e.avatar)==null?void 0:n.hair)==null?void 0:s.color)&&G(e.avatar.hair.color)||"#000000"),skin:$(t.skin||((i=(o=e==null?void 0:e.avatar)==null?void 0:o.skin)==null?void 0:i.color)&&G(e.avatar.skin.color)||"#cc9b76")}},N=e=>e||"",X=e=>e||[],B=e=>e.replace("#","");function Z(e){const t=new URL(window.location.href);Object.entries(e).forEach(([a,r])=>{t.searchParams.delete(a),Array.isArray(r)?r.forEach(n=>{n!==""&&t.searchParams.append(a,n)}):r!==""&&t.searchParams.set(a,r)}),window.history.replaceState({},"",t.toString())}function je(){const{options:e,overrideSources:t}=re(),[a,r]=c.useState(null),[n,s]=c.useState(!0),[o,i]=c.useState(null),E=c.useRef(null),m=c.useRef(e),S=c.useRef(!0);return c.useEffect(()=>{const g=JSON.stringify(e),u=JSON.stringify(m.current);if(!S.current&&g===u)return;S.current=!1,m.current=e,(async()=>{var l,y;try{s(!0),i(null);const f=e.peerUrl||W.get("PEER_URL"),v=e.marketplaceServerUrl||e.nftServerUrl||W.get("MARKETPLACE_SERVER_URL");let T=d.PreviewType.WEARABLE,R={color:e.background||"#4b4852",transparent:e.disableBackground===!0};const I=Se(e.profile);let w=I==null?void 0:I.value;w==="default"&&(w=ne());const P=w&&I?I.type==="address"?await me(w,f):await Ee(w,f):null,A=e.bodyShape||((l=P==null?void 0:P.avatar)==null?void 0:l.bodyShape)||d.BodyShape.MALE;let h=null;if(e.contractAddress&&(h=await ge({contractAddress:e.contractAddress,tokenId:e.tokenId,itemId:e.itemId,peerUrl:f,marketplaceServerUrl:v}),h&&te(h))){R={...R,image:h.thumbnail};const D=ye(h);pe(D)&&(T=d.PreviewType.TEXTURE)}const{eyes:b,hair:H,skin:Y}=ke(P,{eyes:e.eyes,hair:e.hair,skin:e.skin}),M=e.unityMode||null,ae=e.camera&&Object.values(d.PreviewCamera).includes(e.camera)?e.camera:d.PreviewCamera.INTERACTIVE,Q=e.projection&&Object.values(d.PreviewProjection).includes(e.projection)?e.projection:d.PreviewProjection.PERSPECTIVE,O=e.disableDefaultEmotes?null:e.emote&&Object.values(d.PreviewEmote).includes(e.emote)?e.emote:d.PreviewEmote.IDLE,J={background:R,bodyShape:A,mode:M,projection:Q,type:T,base64:((y=e.base64s)==null?void 0:y[0])||null,contract:e.contractAddress||null,disableLoader:e.disableLoader||!1,emote:(O==null?void 0:O.toString())||null,eyeColor:b.replace("#",""),hairColor:H.replace("#",""),item:e.itemId||null,profile:w||null,skinColor:Y.replace("#",""),token:e.tokenId||null,urn:e.urns||null,showAnimationReference:null,itemDefinition:h,socialEmote:e.socialEmote||null},se=JSON.stringify(J),oe=JSON.stringify(E.current);if(se!==oe){if(E.current=J,Object.keys(t).length===0){const D=X(e.urns),q=X(e.base64s);if(M===d.PreviewUnityMode.CONFIG){const z={mode:N(M||"")};Z(z)}else{const z={background:R.transparent?"":B(R.color),disableLoader:e.disableLoader?"true":"",profile:N(w||""),bodyShape:N(A||""),eyeColor:B(b||""),hairColor:B(H||""),skinColor:B(Y||""),mode:N(M||""),camera:ae,projection:Q,emote:N((O==null?void 0:O.toString())||""),urn:D.length>0?D:[""],base64:q.length>0?q:[""]};Z(z)}}r(J)}s(!1)}catch(f){console.error("[useUnityConfig] Failed to load config:",f),i(f instanceof Error?f.message:"Failed to load config"),s(!1)}})()},[e,t]),[a,n,o]}const xe="unity-renderer",Je="unity-canvas",ee=1,ze="Failed to load Unity";var $e=(e=>(e.LOADED="loaded",e.ERROR="error",e.SCREENSHOT="screenshot",e.CUSTOMIZATION_DONE="customization-done",e.CUSTOMIZATION_STEP="avatar-customization-step",e.ELEMENT_BOUNDS="element-bounds",e))($e||{});const Ge="get_element_bounds",Fe="element_bounds_response",Ve=(e,t,a,r)=>{const[n,s]=c.useState({isLoaded:!1,isInitialized:!1,error:null}),o=c.useRef(null),i=c.useCallback(m=>{if(m.data.type===xe){const{type:S,payload:g}=m.data.payload;S==="loaded"&&(g===!0||g==="true")?(s(u=>({...u,isLoaded:!0,isInitialized:!0})),d.sendMessage(L(),d.PreviewMessageType.LOAD,{renderer:d.PreviewRenderer.UNITY}),t.current&&t.current.emote.play()):S==="customization-done"?d.sendMessage(L(),d.PreviewMessageType.CONTROLLER_RESPONSE,{id:"customization-done",ok:!0,result:JSON.parse(m.data.payload.payload)}):S==="avatar-customization-step"?d.sendMessage(L(),d.PreviewMessageType.CONTROLLER_RESPONSE,{id:"avatar-customization-step",ok:!0,result:{step:m.data.payload.payload}}):S==="element-bounds"?d.sendMessage(L(),Fe,g):S==="error"&&(j(new Error(g),{component:"UnityPreview",phase:"unityMessage"}),s(u=>({...u,error:g})),d.sendMessage(L(),d.PreviewMessageType.ERROR,{message:"Error loading the wearable. Please try again."}))}},[]),E=c.useCallback(async m=>{if(!(!e.canvas.current||e.isInitializing.current||e.unityInstance.current)){e.isInitializing.current=!0,s(S=>({...S,isLoaded:!1,error:null}));try{const{unity:S,...g}=await Ue(e.canvas.current,m);e.unityInstance.current=S,t.current=g,o.current&&o.current(),o.current=Pe(t.current),s(u=>({...u,isInitialized:!0}))}catch(S){const g=S instanceof Error?S.message:ze;console.error("Unity init failed:",S),j(S,{component:"UnityPreview",phase:"initializeUnity"}),s(u=>({...u,error:g})),d.sendMessage(L(),d.PreviewMessageType.ERROR,{message:g})}finally{e.isInitializing.current=!1}}},[e,t]);return c.useEffect(()=>{n.isInitialized||r||!a||E(a)},[a,r,n.isInitialized,E]),c.useEffect(()=>()=>{o.current&&o.current()},[]),c.useEffect(()=>{if(a)return window.addEventListener("message",i,!1),()=>{window.removeEventListener("message",i,!1)}},[a,i]),n},He=e=>{const[t,a]=c.useState({pixelRatio:window.devicePixelRatio||ee,is3D:!0,backgroundImage:""});return c.useEffect(()=>{const r=()=>{a(s=>({...s,pixelRatio:window.devicePixelRatio||ee}))},n=window.matchMedia(`(resolution: ${t.pixelRatio}dppx)`);return n.addEventListener("change",r),()=>{n.removeEventListener("change",r)}},[t.pixelRatio]),c.useEffect(()=>{e&&a(r=>({...r,backgroundImage:e.background.image||"",is3D:e.type!==d.PreviewType.TEXTURE}))},[e]),t},Ye=(e,t,a,r,n)=>{const s=c.useMemo(()=>{const o={};for(const i of Object.keys(n))n[i]&&r[i]!==void 0&&(o[i]=r[i]);return o},[n,r]);c.useEffect(()=>{if(!(!a.isInitialized||!a.isLoaded||!e.current)){if(s.profile==="default"){const o=t.current.profile;s.profile=o!=null&&o.match(/^default\d+$/)?o:ne()}Object.keys(s).length>0&&(Te(e.current,s,n),t.current=s)}},[a.isInitialized,a.isLoaded,s,n,e,t])},Qe=()=>{const{width:e=window.innerWidth,height:t=window.innerHeight}=fe(),a=c.useRef(null),r=c.useRef(null),n=c.useRef(!1),s=c.useRef({}),o=we(),[i,E,m]=je(),{options:S,overrideSources:g}=re(),u=c.useMemo(()=>({canvas:a,unityInstance:r,isInitializing:n,lastSentOverrides:s}),[]);he(P=>{var A,h;if(((A=P.data)==null?void 0:A.type)===Ge&&r.current){const b=(h=P.data.payload)==null?void 0:h.elementName;b&&C(r.current,x.GET_ELEMENT_BOUNDS,b)}});const p=Ve(u,o,i,E),l=He(i);Ye(u.unityInstance,u.lastSentOverrides,p,S,g),Re();const y=c.useMemo(()=>{const P=p.error||m,A=!p.isLoaded&&!P,h=!!l.backgroundImage&&!l.is3D&&!A,b=l.is3D&&!A;return{error:P,isLoading:A,showImage:h,showCanvas:b}},[p.error,p.isLoaded,m,l.backgroundImage,l.is3D]),f=c.useMemo(()=>({opacity:1,backgroundColor:!(i!=null&&i.background.transparent)&&(i==null?void 0:i.type)===d.PreviewType.TEXTURE?i.background.color:void 0}),[i]),v=c.useMemo(()=>({width:`${e}px`,height:`${t}px`}),[e,t]),T=c.useMemo(()=>({width:Math.round(e*l.pixelRatio),height:Math.round(t*l.pixelRatio)}),[e,t,l.pixelRatio]),R=c.useMemo(()=>F("Preview",{"is-loading":y.isLoading,"is-loaded":p.isLoaded,"is-3d":l.is3D,"has-error":!!y.error}),[y.isLoading,p.isLoaded,l.is3D,y.error]),I=c.useMemo(()=>F("thumbnail",{"is-visible":y.showImage}),[y.showImage]),w=c.useMemo(()=>F({"is-visible":y.showCanvas}),[y.showCanvas]);return U.jsxs("div",{className:R,style:f,children:[U.jsx("img",{src:l.backgroundImage,className:I,alt:"preview"}),U.jsx("canvas",{ref:u.canvas,id:Je,className:w,width:T.width,height:T.height,style:v}),y.error&&U.jsx("div",{className:"error",children:y.error})]})},Ke=ie.memo(Qe);export{$e as UnityMessageType,Ke as default};
|