@dcl/wearable-preview 2.14.3-25444956462.commit-5b89589 → 2.15.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.
- package/assets/{Preview-QTJIIukY.js → Preview-Bvb8TMrC.js} +3 -3
- package/assets/UnityPreview-Drp5T8PB.js +1 -0
- package/assets/{babylon.inspector.bundle.max-DUWb0siv.js → babylon.inspector.bundle.max-UM_jwDGd.js} +1 -1
- package/{static-local/assets/emote-events-C6rvUEZZ.js → assets/emote-events-DVwasSMJ.js} +1 -1
- package/assets/{index-CCC3RPkz.js → index-Nv1UBvZt.js} +3 -3
- package/index.html +3 -3
- package/package.json +2 -2
- package/static-local/assets/{Preview-DE8Jus1b.js → Preview-MbRQyQb2.js} +3 -3
- package/static-local/assets/{UnityPreview-Cs2Es0i8.js → UnityPreview-_te4zBbL.js} +1 -1
- package/static-local/assets/{babylon.inspector.bundle.max-Dz_2_Xi4.js → babylon.inspector.bundle.max-DivnAw34.js} +1 -1
- package/{assets/emote-events-D-nHcxAJ.js → static-local/assets/emote-events-DG-ap14Y.js} +1 -1
- package/static-local/assets/{index-CDMtUtZv.js → index-B_uViT-O.js} +2 -2
- package/static-local/index.html +1 -1
- package/static-local/package.json +1 -1
- package/assets/UnityPreview-BMoYzfgj.js +0 -1
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{c as k,a as j,r as c,b as W,R as ie,j as B}from"./index-CCC3RPkz.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 pe,j as ye,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-D-nHcxAJ.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,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)})},Te=(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=Ie[a];if(o){const i=Ae[a],E=i?i(s):String(s);C(e,o,E),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 be={VITE_BASE_URL:"https://cdn.decentraland.org/@dcl/wearable-preview/2.14.3-25444956462.commit-5b89589"};const V=new Map,_=(e,t)=>{if(!t)return e;const n=e.replace(/\/$/,""),r=t.replace(/^\//,"");return`${n}/${r}`};function ve(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 Oe=async(e,t,n,r,a,s,o,i,E,m,S,g)=>{try{const u=be.VITE_BASE_URL||"";return await ve(_(u,t)),await createUnityInstance(e,{dataUrl:_(u,n),frameworkUrl:_(u,r),codeUrl:_(u,a),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 n(r){if(r.data.type==="unity-renderer"){const{type:a,payload:s}=r.data.payload;a==="screenshot"&&(window.removeEventListener("message",n),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 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 Ne(e,t,n,r){const a=le();let s=0,o=0,i="stopped",E=null,m=0;const S=()=>{var l;return n?n.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(),p=(l-m)/1e3;if(m=l,o+=p,s>0&&o>=s)if(S())o=o%s,a.emit(d.PreviewEmoteEventType.ANIMATION_LOOP);else{o=s,u(),i="stopped",e.SendMessage("JSBridge","StopEmote",""),a.emit(d.PreviewEmoteEventType.ANIMATION_PLAYING,{length:o}),a.emit(d.PreviewEmoteEventType.ANIMATION_END);return}a.emit(d.PreviewEmoteEventType.ANIMATION_PLAYING,{length:o})},15)},u=()=>{E!==null&&(clearInterval(E),E=null)},y=(l,p,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===p&&(window.removeEventListener("message",T),v(w))}};window.addEventListener("message",T),l()});return{getLength:async()=>await y(()=>e.SendMessage("JSBridge","GetEmoteLength",""),"emoteLength",0)??0,isPlaying:async()=>y(()=>e.SendMessage("JSBridge","IsEmotePlaying",""),"isEmotePlaying",!1),goTo:async l=>{e&&(o=l,e.SendMessage("JSBridge","GoToEmote",l.toString()),a.emit(d.PreviewEmoteEventType.ANIMATION_PLAYING,{length:l}))},play:async()=>{e&&(s<=0&&(s=await y(()=>e.SendMessage("JSBridge","GetEmoteLength",""),"emoteLength",0)),i==="stopped"&&(o=0),i="playing",e.SendMessage("JSBridge","PlayEmote",""),g(),a.emit(d.PreviewEmoteEventType.ANIMATION_PLAY))},pause:async()=>{e&&(i="paused",u(),e.SendMessage("JSBridge","PauseEmote",""),a.emit(d.PreviewEmoteEventType.ANIMATION_PAUSE))},stop:async()=>{e&&(i="stopped",o=0,u(),e.SendMessage("JSBridge","StopEmote",""),a.emit(d.PreviewEmoteEventType.ANIMATION_END))},enableSound:async()=>{e&&e.SendMessage("JSBridge","EnableSound","")},disableSound:async()=>{e&&e.SendMessage("JSBridge","DisableSound","")},hasSound:async()=>y(()=>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 Ce(e){return{setSpringBonesParams:async(t,n)=>{e&&e.SendMessage("JSBridge",x.SET_SPRING_BONES_PARAMS,JSON.stringify({itemId:t,params:n}))}}}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 Be(e,t){let n=null;try{const r=De();if(n=await Oe(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=_e(n),E=Ne(n,a,s,o),m=Ce(n);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: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,ne=()=>`default${Ue()}`,ke=(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||[],U=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 je(){const{options:e,overrideSources:t}=re(),[n,r]=c.useState(null),[a,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,p;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=pe(h);ye(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:((p=e.base64s)==null?void 0:p[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?"":U(R.color),disableLoader:e.disableLoader?"true":"",profile:N(w||""),bodyShape:N(A||""),eyeColor:U(b||""),hairColor:U(H||""),skinColor:U(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]),[n,a,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,n,r)=>{const[a,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 Be(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(()=>{a.isInitialized||r||!n||E(n)},[n,r,a.isInitialized,E]),c.useEffect(()=>()=>{o.current&&o.current()},[]),c.useEffect(()=>{if(n)return window.addEventListener("message",i,!1),()=>{window.removeEventListener("message",i,!1)}},[n,i]),a},He=e=>{const[t,n]=c.useState({pixelRatio:window.devicePixelRatio||ee,is3D:!0,backgroundImage:""});return c.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]),c.useEffect(()=>{e&&n(r=>({...r,backgroundImage:e.background.image||"",is3D:e.type!==d.PreviewType.TEXTURE}))},[e]),t},Ye=(e,t,n,r,a)=>{const s=c.useMemo(()=>{const o={};for(const i of Object.keys(a))a[i]&&r[i]!==void 0&&(o[i]=r[i]);return o},[a,r]);c.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:ne()}Object.keys(s).length>0&&(Te(e.current,s,a),t.current=s)}},[n.isInitialized,n.isLoaded,s,a,e,t])},Qe=()=>{const{width:e=window.innerWidth,height:t=window.innerHeight}=fe(),n=c.useRef(null),r=c.useRef(null),a=c.useRef(!1),s=c.useRef({}),o=we(),[i,E,m]=je(),{options:S,overrideSources:g}=re(),u=c.useMemo(()=>({canvas:n,unityInstance:r,isInitializing:a,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 y=Ve(u,o,i,E),l=He(i);Ye(u.unityInstance,u.lastSentOverrides,y,S,g),Re();const p=c.useMemo(()=>{const P=y.error||m,A=!y.isLoaded&&!P,h=!!l.backgroundImage&&!l.is3D&&!A,b=l.is3D&&!A;return{error:P,isLoading:A,showImage:h,showCanvas:b}},[y.error,y.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":p.isLoading,"is-loaded":y.isLoaded,"is-3d":l.is3D,"has-error":!!p.error}),[p.isLoading,y.isLoaded,l.is3D,p.error]),I=c.useMemo(()=>F("thumbnail",{"is-visible":p.showImage}),[p.showImage]),w=c.useMemo(()=>F({"is-visible":p.showCanvas}),[p.showCanvas]);return B.jsxs("div",{className:R,style:f,children:[B.jsx("img",{src:l.backgroundImage,className:I,alt:"preview"}),B.jsx("canvas",{ref:u.canvas,id:Je,className:w,width:T.width,height:T.height,style:v}),p.error&&B.jsx("div",{className:"error",children:p.error})]})},Ke=ie.memo(Qe);export{$e as UnityMessageType,Ke as default};
|