@dcl/wearable-preview 2.13.1-24410653218.commit-8b6f171 → 2.14.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1 +0,0 @@
1
- import{c as k,a as j,r as d,b as W,R as oe,j as U}from"./index-aZg7tiGL.js";import{m as ie,i as K,d as c,L as le,a as ce,u as te,s as de,f as ue,b as Se,c as me,e as ge,g as Ee,h as ye,j as $,k as G,l as fe,n as pe,o as we,p as he,q as F,r as L,t as Re}from"./emote-events-B6LmURzM.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 Pe={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"},Ie={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,n)=>{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:n})),n!==void 0?e.SendMessage("JSBridge",r,n):e.SendMessage("JSBridge",r)}catch(r){console.error(`Failed to send Unity message ${t}:`,r),j(r,{method:String(t),value:n})}else console.warn(`Unity instance not ready, cannot send message: ${t}`),k(`Unity instance not ready, cannot send message: ${t}`,{method:String(t)})},Ae=(e,t,n)=>{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&&n.base64s&&(C(e,"ClearBase64"),r++,Array.isArray(t.base64s)&&t.base64s.length>0&&t.base64s.forEach(a=>{C(e,"AddBase64",a),r++})),Object.entries(t).forEach(([a,s])=>{if(a!=="base64s"&&n[a]&&s!==void 0){const o=Pe[a];if(o){const i=Ie[a],g=i?i(s):String(s);C(e,o,g),r++}else console.warn(`No Unity method mapping found for property: ${a}`),k(`No Unity method mapping found for property: ${a}`,{property:a,value:s})}}),r>0&&C(e,"Reload")};var Te={VITE_BASE_URL:"https://cdn.decentraland.org/@dcl/wearable-preview/2.13.1-24410653218.commit-8b6f171"};const V=new Map,_=(e,t)=>{if(!t)return e;const n=e.replace(/\/$/,""),r=t.replace(/^\//,"");return`${n}/${r}`};function be(e){if(V.has(e))return V.get(e);const t=new Promise((n,r)=>{const a=document.querySelector(`script[src="${e}"]`);if(a){a.addEventListener("load",()=>n(a)),a.addEventListener("error",o=>r(o));return}const s=document.createElement("script");s.src=e,s.async=!0,s.onload=()=>n(s),s.onerror=o=>r(o),document.body.appendChild(s)});return V.set(e,t),t}const ve=async(e,t,n,r,a,s,o,i,g,m,S,E)=>{try{const u=Te.VITE_BASE_URL||"";return await be(_(u,t)),await createUnityInstance(e,{dataUrl:_(u,n),frameworkUrl:_(u,r),codeUrl:_(u,a),streamingAssetsUrl:_(u,o),symbolUrl:_(u,s),companyName:i,productName:g,productVersion:m,matchWebGLToCanvasSize:S,arguments:E})}catch(u){throw console.error("❌ Failed to load Unity instance:",u),u}},Oe="data:image/png;base64,";function Le(e){return{getScreenshot:()=>new Promise(t=>{if(!e){t("");return}e.SendMessage("JSBridge","TakeScreenshot",""),window.addEventListener("message",function n(r){if(r.data.type==="unity-renderer"){const{type:a,payload:s}=r.data.payload;a==="screenshot"&&(window.removeEventListener("message",n),t(Oe+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 n(r){if(r.data.type==="unity-renderer"){const{type:a,payload:s}=r.data.payload;a==="metrics"&&(window.removeEventListener("message",n),t(s))}})}),changeZoom:async t=>{e&&e.SendMessage("JSBridge","SetZoom",t.toString())},panCamera:async t=>{if(!e)return;const n=t.x??0,r=t.y??0,a=t.z??0;e.SendMessage("JSBridge","SetOffset",`${n},${r},${a}`)},changeCameraPosition:async t=>{if(!e)return;const n=t.alpha??0,r=t.beta??0,a=t.radius??0;e.SendMessage("JSBridge","SetCameraPosition",`${n},${r},${a}`)},setUsername:async t=>{e&&e.SendMessage("JSBridge","SetUsername",t)},cleanup:async()=>{e&&e.SendMessage("JSBridge","Cleanup","")}}}function _e(e,t,n,r){const a=ie();let s=0,o=0,i="stopped",g=null,m=0;const S=()=>{var l;return n?n.loop:!!((l=t==null?void 0:t.emoteDataADR74)!=null&&l.loop||r&&le.includes(r))},E=()=>{u(),m=Date.now(),g=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,a.emit(c.PreviewEmoteEventType.ANIMATION_LOOP);else{o=s,u(),i="stopped",e.SendMessage("JSBridge","StopEmote",""),a.emit(c.PreviewEmoteEventType.ANIMATION_PLAYING,{length:o}),a.emit(c.PreviewEmoteEventType.ANIMATION_END);return}a.emit(c.PreviewEmoteEventType.ANIMATION_PLAYING,{length:o})},15)},u=()=>{g!==null&&(clearInterval(g),g=null)},f=(l,y,p)=>new Promise(v=>{if(!e){v(p);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 f(()=>e.SendMessage("JSBridge","GetEmoteLength",""),"emoteLength",0)??0,isPlaying:async()=>f(()=>e.SendMessage("JSBridge","IsEmotePlaying",""),"isEmotePlaying",!1),goTo:async l=>{e&&(o=l,e.SendMessage("JSBridge","GoToEmote",l.toString()),a.emit(c.PreviewEmoteEventType.ANIMATION_PLAYING,{length:l}))},play:async()=>{e&&(s<=0&&(s=await f(()=>e.SendMessage("JSBridge","GetEmoteLength",""),"emoteLength",0)),i==="stopped"&&(o=0),i="playing",e.SendMessage("JSBridge","PlayEmote",""),E(),a.emit(c.PreviewEmoteEventType.ANIMATION_PLAY))},pause:async()=>{e&&(i="paused",u(),e.SendMessage("JSBridge","PauseEmote",""),a.emit(c.PreviewEmoteEventType.ANIMATION_PAUSE))},stop:async()=>{e&&(i="stopped",o=0,u(),e.SendMessage("JSBridge","StopEmote",""),a.emit(c.PreviewEmoteEventType.ANIMATION_END))},enableSound:async()=>{e&&e.SendMessage("JSBridge","EnableSound","")},disableSound:async()=>{e&&e.SendMessage("JSBridge","DisableSound","")},hasSound:async()=>f(()=>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()=>n??null,emote:t,events:a}}function Ne(e){return{setSpringBonesParams:async(t,n)=>{e&&e.SendMessage("JSBridge",x.SET_SPRING_BONES_PARAMS,JSON.stringify({itemHash:t,params:n}))}}}const Ce={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 Me(){return Ce}async function De(e,t){let n=null;try{const r=Me();if(n=await ve(e,"/unity/Build/aang-renderer.loader.js",r.dataUrl,r.frameworkUrl,r.codeUrl,r.symbolUrl,"/emotes","Decentraland","AangRenderer","2.2.2",!0,[]),!n)throw new Error("Failed to load Unity instance");const a=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=Le(n),g=_e(n,a,s,o),m=Ne(n);return{scene:i,emote:g,physics:m,unity:n}}catch(r){if(console.error("Unity render failed:",r),n!=null&&n.Quit)try{n.Quit()}catch(a){console.error("Error quitting Unity instance:",a),j(a,{phase:"unityQuit"})}throw r}}const Ue=()=>Math.floor(Math.random()*159)+1,re=()=>`default${Ue()}`,Be=(e,t)=>{var n,r,a,s,o,i;return{eyes:$(t.eyes||((r=(n=e==null?void 0:e.avatar)==null?void 0:n.eyes)==null?void 0:r.color)&&G(e.avatar.eyes.color)||"#000000"),hair:$(t.hair||((s=(a=e==null?void 0:e.avatar)==null?void 0:a.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(([n,r])=>{t.searchParams.delete(n),Array.isArray(r)?r.forEach(a=>{a!==""&&t.searchParams.append(n,a)}):r!==""&&t.searchParams.set(n,r)}),window.history.replaceState({},"",t.toString())}function ke(){const{options:e,overrideSources:t}=te(),[n,r]=d.useState(null),[a,s]=d.useState(!0),[o,i]=d.useState(null),g=d.useRef(null),m=d.useRef(e),S=d.useRef(!0);return d.useEffect(()=>{const E=JSON.stringify(e),u=JSON.stringify(m.current);if(!S.current&&E===u)return;S.current=!1,m.current=e,(async()=>{var l,y;try{s(!0),i(null);const p=e.peerUrl||W.get("PEER_URL"),v=e.marketplaceServerUrl||e.nftServerUrl||W.get("MARKETPLACE_SERVER_URL");let T=c.PreviewType.WEARABLE,R={color:e.background||"#4b4852",transparent:e.disableBackground===!0};const I=de(e.profile);let w=I==null?void 0:I.value;w==="default"&&(w=re());const P=w&&I?I.type==="address"?await ue(w,p):await Se(w,p):null,A=e.bodyShape||((l=P==null?void 0:P.avatar)==null?void 0:l.bodyShape)||c.BodyShape.MALE;let h=null;if(e.contractAddress&&(h=await me({contractAddress:e.contractAddress,tokenId:e.tokenId,itemId:e.itemId,peerUrl:p,marketplaceServerUrl:v}),h&&ge(h))){R={...R,image:h.thumbnail};const D=Ee(h);ye(D)&&(T=c.PreviewType.TEXTURE)}const{eyes:b,hair:H,skin:Y}=Be(P,{eyes:e.eyes,hair:e.hair,skin:e.skin}),M=e.unityMode||null,ne=e.camera&&Object.values(c.PreviewCamera).includes(e.camera)?e.camera:c.PreviewCamera.INTERACTIVE,Q=e.projection&&Object.values(c.PreviewProjection).includes(e.projection)?e.projection:c.PreviewProjection.PERSPECTIVE,O=e.disableDefaultEmotes?null:e.emote&&Object.values(c.PreviewEmote).includes(e.emote)?e.emote:c.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},ae=JSON.stringify(J),se=JSON.stringify(g.current);if(ae!==se){if(g.current=J,Object.keys(t).length===0){const D=X(e.urns),q=X(e.base64s);if(M===c.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:ne,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(p){console.error("[useUnityConfig] Failed to load config:",p),i(p instanceof Error?p.message:"Failed to load config"),s(!1)}})()},[e,t]),[n,a,o]}const je="unity-renderer",xe="unity-canvas",ee=1,Je="Failed to load Unity";var ze=(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))(ze||{});const $e="get_element_bounds",Ge="element_bounds_response",Fe=(e,t,n,r)=>{const[a,s]=d.useState({isLoaded:!1,isInitialized:!1,error:null}),o=d.useRef(null),i=d.useCallback(m=>{if(m.data.type===je){const{type:S,payload:E}=m.data.payload;S==="loaded"&&(E===!0||E==="true")?(s(u=>({...u,isLoaded:!0,isInitialized:!0})),c.sendMessage(L(),c.PreviewMessageType.LOAD,{renderer:c.PreviewRenderer.UNITY}),t.current&&t.current.emote.play()):S==="customization-done"?c.sendMessage(L(),c.PreviewMessageType.CONTROLLER_RESPONSE,{id:"customization-done",ok:!0,result:JSON.parse(m.data.payload.payload)}):S==="avatar-customization-step"?c.sendMessage(L(),c.PreviewMessageType.CONTROLLER_RESPONSE,{id:"avatar-customization-step",ok:!0,result:{step:m.data.payload.payload}}):S==="element-bounds"?c.sendMessage(L(),Ge,E):S==="error"&&(j(new Error(E),{component:"UnityPreview",phase:"unityMessage"}),s(u=>({...u,error:E})),c.sendMessage(L(),c.PreviewMessageType.ERROR,{message:"Error loading the wearable. Please try again."}))}},[]),g=d.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,...E}=await De(e.canvas.current,m);e.unityInstance.current=S,t.current=E,o.current&&o.current(),o.current=Re(t.current),s(u=>({...u,isInitialized:!0}))}catch(S){const E=S instanceof Error?S.message:Je;console.error("Unity init failed:",S),j(S,{component:"UnityPreview",phase:"initializeUnity"}),s(u=>({...u,error:E})),c.sendMessage(L(),c.PreviewMessageType.ERROR,{message:E})}finally{e.isInitializing.current=!1}}},[e,t]);return d.useEffect(()=>{a.isInitialized||r||!n||g(n)},[n,r,a.isInitialized,g]),d.useEffect(()=>()=>{o.current&&o.current()},[]),d.useEffect(()=>{if(n)return window.addEventListener("message",i,!1),()=>{window.removeEventListener("message",i,!1)}},[n,i]),a},Ve=e=>{const[t,n]=d.useState({pixelRatio:window.devicePixelRatio||ee,is3D:!0,backgroundImage:""});return d.useEffect(()=>{const r=()=>{n(s=>({...s,pixelRatio:window.devicePixelRatio||ee}))},a=window.matchMedia(`(resolution: ${t.pixelRatio}dppx)`);return a.addEventListener("change",r),()=>{a.removeEventListener("change",r)}},[t.pixelRatio]),d.useEffect(()=>{e&&n(r=>({...r,backgroundImage:e.background.image||"",is3D:e.type!==c.PreviewType.TEXTURE}))},[e]),t},He=(e,t,n,r,a)=>{const s=d.useMemo(()=>{const o={};for(const i of Object.keys(a))a[i]&&r[i]!==void 0&&(o[i]=r[i]);return o},[a,r]);d.useEffect(()=>{if(!(!n.isInitialized||!n.isLoaded||!e.current)){if(s.profile==="default"){const o=t.current.profile;s.profile=o!=null&&o.match(/^default\d+$/)?o:re()}Object.keys(s).length>0&&(Ae(e.current,s,a),t.current=s)}},[n.isInitialized,n.isLoaded,s,a,e,t])},Ye=()=>{const{width:e=window.innerWidth,height:t=window.innerHeight}=fe(),n=d.useRef(null),r=d.useRef(null),a=d.useRef(!1),s=d.useRef({}),o=pe(),[i,g,m]=ke(),{options:S,overrideSources:E}=te(),u=d.useMemo(()=>({canvas:n,unityInstance:r,isInitializing:a,lastSentOverrides:s}),[]);we(P=>{var A,h;if(((A=P.data)==null?void 0:A.type)===$e&&r.current){const b=(h=P.data.payload)==null?void 0:h.elementName;b&&C(r.current,x.GET_ELEMENT_BOUNDS,b)}});const f=Fe(u,o,i,g),l=Ve(i);He(u.unityInstance,u.lastSentOverrides,f,S,E),he();const y=d.useMemo(()=>{const P=f.error||m,A=!f.isLoaded&&!P,h=!!l.backgroundImage&&!l.is3D&&!A,b=l.is3D&&!A;return{error:P,isLoading:A,showImage:h,showCanvas:b}},[f.error,f.isLoaded,m,l.backgroundImage,l.is3D]),p=d.useMemo(()=>({opacity:1,backgroundColor:!(i!=null&&i.background.transparent)&&(i==null?void 0:i.type)===c.PreviewType.TEXTURE?i.background.color:void 0}),[i]),v=d.useMemo(()=>({width:`${e}px`,height:`${t}px`}),[e,t]),T=d.useMemo(()=>({width:Math.round(e*l.pixelRatio),height:Math.round(t*l.pixelRatio)}),[e,t,l.pixelRatio]),R=d.useMemo(()=>F("Preview",{"is-loading":y.isLoading,"is-loaded":f.isLoaded,"is-3d":l.is3D,"has-error":!!y.error}),[y.isLoading,f.isLoaded,l.is3D,y.error]),I=d.useMemo(()=>F("thumbnail",{"is-visible":y.showImage}),[y.showImage]),w=d.useMemo(()=>F({"is-visible":y.showCanvas}),[y.showCanvas]);return U.jsxs("div",{className:R,style:p,children:[U.jsx("img",{src:l.backgroundImage,className:I,alt:"preview"}),U.jsx("canvas",{ref:u.canvas,id:xe,className:w,width:T.width,height:T.height,style:v}),y.error&&U.jsx("div",{className:"error",children:y.error})]})},We=oe.memo(Ye);export{ze as UnityMessageType,We as default};