@formant/data-sdk 1.70.0 → 1.71.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.
@@ -31857,6 +31857,19 @@ function defined(e, t) {
31857
31857
  return e;
31858
31858
  throw new Error(t || "Value is undefined");
31859
31859
  }
31860
+ const encodedJs$1 = "var R=Object.defineProperty;var G=(M,b,x)=>b in M?R(M,b,{enumerable:!0,configurable:!0,writable:!0,value:x}):M[b]=x;var I=(M,b,x)=>(G(M,typeof b!="symbol"?b+"":b,x),x);(function(){"use strict";const S={millisecond:1,second:1e3,minute:6e4,hour:36e5,day:864e5,week:6048e5,month:2592e6,year:31536e6};function q(o){}class _{constructor({capacity:t,timeout:n}={}){I(this,"entries",new Map);I(this,"metadata",new Map);I(this,"capacity");I(this,"timeout");this.capacity=t||1e4,this.timeout=n||S.minute}get(t,n){const e=this.keyToCacheKey(t),c=this.entries.get(e),i=this.metadata.get(e);return(c===void 0||i&&(i==null?void 0:i.expiration.getTime())<Date.now())&&!(i!=null&&i.generating)&&n&&this.generate(t,n()),c===void 0&&i&&i.lastValue!==void 0?i.lastValue:c}set(t,n){const e=this.keyToCacheKey(t);this.metadata.set(e,{generating:!1,expiration:new Date(Date.now()+this.timeout),lastValue:n}),this.entries.set(e,n),this.metadata.size>this.capacity&&this.deleteOldestEntry()}clear(){this.entries.clear(),[...this.metadata.values()].forEach(t=>t.generating=!1)}clearKey(t){this.metadata.delete(t),this.entries.delete(t)}keyToCacheKey(t){return JSON.stringify(t)}deleteOldestEntry(){if(this.metadata.size<1)return;const[t]=[...this.metadata.entries()].reduce(([n,e],[c,i])=>i.expiration.getTime()<e.expiration.getTime()?[c,i]:[n,e]);this.clearKey(t)}generate(t,n){const e=this.keyToCacheKey(t),c=this.metadata.get(e)||{};this.metadata.set(e,{...c,generating:!0,expiration:new Date(Date.now()+this.timeout)}),setTimeout(()=>{n.then(i=>{const r=this.metadata.get(e);!(r!=null&&r.generating)||this.set(t,i)})},0)}}/**
 * LZF compression/decompression module. Ported from the C
 * implementation of liblzf, specfically lzf_c.c and lzf_d.c
 * @license BSD-2-Clause
 */function K(o){var t=new Uint8Array(o),n=[],e=0,c=0;do{var i=t[e++];if(i<1<<5){if(i++,e+i>t.length)throw new Error("Invalid input");for(;i--;)n[c++]=t[e++]}else{var r=i>>5,f=c-((i&31)<<8)-1;if(e>=t.length)throw new Error("Invalid input");if(r==7&&(r+=t[e++],e>=t.length))throw new Error("Invalid input");if(f-=t[e++],f<0)throw new Error("Invalid input");r+=2;do n[c++]=n[f++];while(--r)}}while(e<t.length);if(typeof Buffer!="undefined")return new Buffer(n);var u=new Uint8Array(n.length);return u.set(n),u}function O(o){var t=16,n=1<<t,e=1<<13,c=(1<<8)+(1<<3),i=1<<5;function r(v,T){return v[T]<<8|v[T+1]}function f(v,T,P){return v<<8|T[P+2]}function u(v){return v*506832829>>32-t-8&n-1}for(var s=new Uint8Array(o),a=[],d=new Uint32Array(n),y=s.length,h=0,g=r(s,h),p=1,l=0;h<y-2;){g=f(g,o,h);var z=u(g),m=d[z];d[z]=h;var E;if(m<h&&(E=h-m-1)<e&&m>0&&s[m+2]==s[h+2]&&s[m+1]==s[h+1]&&s[m]==s[h]){var w=2,F=y-h-w;F=F>c?c:F,a[p-l-1]=l-1&255,l==0&&(p-=1);do w++;while(w<F&&s[m+w]==s[h+w]);if(w-=2,h++,w<7?a[p++]=(E>>8)+(w<<5)&255:(a[p++]=(E>>8)+(7<<5)&255,a[p++]=w-7&255),a[p++]=E&255,l=0,p++,h+=w+1,h>=y-2)break;--h,--h,g=r(s,h),g=f(g,s,h),d[u(g)]=h++,g=f(g,s,h),d[u(g)]=h++}else l++,a[p++]=s[h++],l==i&&(a[p-l-1]=l-1&255,l=0,p++)}for(;h<y;)l++,a[p++]=s[h++],l==i&&(a[p-l-1]=l-1&255,l=0,p++);if(l!=0&&(a[p-l-1]=l-1&255),typeof Buffer!="undefined")return new Buffer(a);var U=new Uint8Array(a.length);return U.set(a),U}var B={decompress:K,compress:O};const C=(o,t)=>t<=o?[]:new Array(t-o).fill(0).map((n,e)=>e+o),A=!0;function H(o){const t=atob(o),n=t.length,e=new Uint8Array(n);for(let c=0;c<n;c+=1)e[c]=t.charCodeAt(c);return e.buffer}function L(o){const t=new Uint8Array(o);let n="",e=0;for(;e<t.length&&n.search(/[\r\n]DATA\s(\S*)\s/i)===-1;e+=1)n+=String.fromCharCode(t[e]);return{body:o.slice(e),header:n.replace(/#.*/gi,"")}}function V(o){const n=new Uint32Array(o,0,2)[0];return n===0?new ArrayBuffer(0):B.decompress(new Uint8Array(o,8,n)).buffer}function k(o){const{header:t,body:n}=L(o),e=/VERSION (.*)/i.exec(t);if(e===null)throw new Error(`Missing version. Header ${t}`);const c=e[1],i=/FIELDS (.*)/i.exec(t);if(!i)throw new Error("Missing fields");const r=i[1].split(" "),f=/SIZE (.*)/i.exec(t);if(!f)throw new Error("Missing size");const u=f[1].split(" ").map(v=>parseInt(v,10)),s=/TYPE (.*)/i.exec(t);if(!s)throw new Error("Missing type");const a=s[1].split(" "),d=/COUNT (.*)/i.exec(t);let y;d&&(y=d[1].split(" ").map(v=>parseInt(v,10)));const h=y||r.map(v=>1),g=/WIDTH (.*)/i.exec(t);if(!g)throw new Error("Missing width");const p=parseInt(g[1],10),l=/HEIGHT (.*)/i.exec(t);if(!l)throw new Error("Missing height");const z=parseInt(l[1],10),m=/POINTS (.*)/i.exec(t);let E;m&&(E=parseInt(m[1],10));const w=E||p*z,F=/DATA (.*)/i.exec(t);if(!F)throw new Error("Missing data");const U=F[1];return{body:n,header:{count:h,data:U,fields:r,height:z,points:w,size:u,type:a,version:c,width:p}}}function N(o){const t={};return o.fields.reduce(({offsets:n,size:e},c,i)=>{let r=e;return c==="x"&&(n.x=r),c==="y"&&(n.y=r),c==="z"&&(n.z=r),c==="rgb"&&(n.rgb=r),c==="rgba"&&(n.rgba=r),c==="intensity"&&(n.intensity=r),o.data==="ascii"?r+=1:o.data==="binary"?r+=o.size[i]*o.count[i]:o.data==="binary_compressed"&&(r+=o.size[i]*o.count[i]*o.points),{offsets:n,size:r}},{offsets:t,size:0})}function D(o){const{header:t,body:n}=k(o),{offsets:e,size:c}=N(t);let i;e.x!==void 0&&e.y!==void 0&&e.z!==void 0&&(i=new Float32Array(t.points*3));let r;(e.rgb!==void 0||e.rgba!==void 0)&&(r=new Float32Array(t.points*4));let f;if(e.intensity!==void 0&&(f=new Float32Array(t.points)),t.data==="ascii")String.fromCharCode(...new Uint8Array(n)).split(`
`).forEach((a,d)=>{const y=a.split(" ");if(i!==void 0&&(i[d*3+0]=parseFloat(y[e.x||0]),i[d*3+1]=parseFloat(y[e.y||0]),i[d*3+2]=parseFloat(y[e.z||0])),r!==void 0){const h=new Int32Array([parseInt(y[e.rgb||e.rgba||0],10)]),g=new DataView(h.buffer,0);r[d*3+0]=g.getUint8(2)/255,r[d*3+1]=g.getUint8(1)/255,r[d*3+2]=g.getUint8(0)/255}f!==void 0&&(f[d]=parseFloat(y[e.intensity||0]))});else if(t.data==="binary"){const u=new DataView(n);C(0,t.points).forEach(s=>{const a=c*s;if(i!==void 0&&(i[s*3+0]=u.getFloat32(a+(e.x||0),A),i[s*3+1]=u.getFloat32(a+(e.y||0),A),i[s*3+2]=u.getFloat32(a+(e.z||0),A)),r!==void 0){const d=a+(e.rgb||e.rgba||0);d+2<=u.byteLength&&(r[s*4+0]=u.getUint8(d+2)/255,r[s*4+1]=u.getUint8(d+1)/255,r[s*4+2]=u.getUint8(d+0)/255,r[s*4+3]=1)}f!==void 0&&(f[s]=u.getFloat32(a+(e.intensity||0),A))})}else if(t.data==="binary_compressed"){const u=V(n),s=new DataView(u);C(0,t.points).forEach(a=>{if(i!==void 0&&(i[a*3+0]=s.getFloat32((e.x||0)+a*4,A),i[a*3+1]=s.getFloat32((e.y||0)+a*4,A),i[a*3+2]=s.getFloat32((e.z||0)+a*4,A)),r!==void 0){const d=(e.rgb||e.rgba||0)+a*4;d+2<=s.byteLength&&(r[a*4+0]=s.getUint8(d+2)/255,r[a*4+1]=s.getUint8(d+1)/255,r[a*4+2]=s.getUint8(d+0)/255,r[a*4+3]=1)}f!==void 0&&(f[a]=s.getFloat32((e.intensity||0)+a*4,A))})}return{colors:r,header:t,intensity:f,positions:i}}function X(o){return D(H(o))}const Z=new _({capacity:1e3,timeout:1*S.minute});onmessage=async o=>{const{url:t,id:n,pointCloud:e}=o.data;if(t){const c=Z.get(t,async()=>D(await fetch(t,{mode:"cors"}).then(r=>r.arrayBuffer())));c&&postMessage({url:t,pcd:c})}if(n&&e){const c=X(e);postMessage({id:n,pcd:c})}}})();
", blob$1 = typeof window != "undefined" && window.Blob && new Blob([atob(encodedJs$1)], { type: "text/javascript;charset=utf-8" });
31861
+ function WorkerWrapper$1() {
31862
+ let e;
31863
+ try {
31864
+ if (e = blob$1 && (window.URL || window.webkitURL).createObjectURL(blob$1), !e)
31865
+ throw "";
31866
+ return new Worker(e);
31867
+ } catch {
31868
+ return new Worker("data:application/javascript;base64," + encodedJs$1);
31869
+ } finally {
31870
+ e && (window.URL || window.webkitURL).revokeObjectURL(e);
31871
+ }
31872
+ }
31860
31873
  class LiveUniverseData extends BasicUniverseDataConnector {
31861
31874
  constructor() {
31862
31875
  super();
@@ -32095,105 +32108,98 @@ class LiveUniverseData extends BasicUniverseDataConnector {
32095
32108
  };
32096
32109
  }
32097
32110
  subscribeToPointCloud(t, n, r) {
32098
- const o = new Worker(
32099
- new URL("/assets/PcdLoaderWorker-eaac0b31.js", self.location),
32100
- {
32101
- name: "liveuniverseDataPCD"
32102
- }
32103
- );
32104
- if (n.sourceType === "telemetry" && n.streamType !== "localization")
32105
- return this.addRemovableTelemetrySubscription(
32106
- t,
32107
- n,
32108
- async (s) => {
32109
- let g, l;
32110
- for (let u = 0; u < s.length; u += 1) {
32111
- const c = s[u];
32112
- if (c.deviceId === t && c.name === n.streamName && c.type === "point cloud") {
32113
- const [d, B] = c.points[c.points.length - 1];
32114
- g = B;
32115
- break;
32116
- }
32111
+ let o;
32112
+ const s = new WorkerWrapper$1();
32113
+ if (n.sourceType === "telemetry" && n.streamType !== "localization" && (o = this.addRemovableTelemetrySubscription(
32114
+ t,
32115
+ n,
32116
+ async (g) => {
32117
+ let l, u;
32118
+ for (let c = 0; c < g.length; c += 1) {
32119
+ const d = g[c];
32120
+ if (d.deviceId === t && d.name === n.streamName && d.type === "point cloud") {
32121
+ const [B, Q] = d.points[d.points.length - 1];
32122
+ l = Q;
32123
+ break;
32117
32124
  }
32118
- if (g) {
32119
- const { url: u } = g;
32120
- l = await new Promise((c) => {
32121
- o.postMessage({ url: u }), o.onmessage = (d) => {
32122
- d.data.url === u && c(d.data.pcd);
32123
- };
32124
- });
32125
+ }
32126
+ if (l) {
32127
+ const { url: c } = l;
32128
+ u = await new Promise((d) => {
32129
+ s.postMessage({ url: c }), s.onmessage = (B) => {
32130
+ B.data.url === c && d(B.data.pcd);
32131
+ };
32132
+ });
32133
+ }
32134
+ return {
32135
+ deviceId: t,
32136
+ sourceId: n.id,
32137
+ data: {
32138
+ worldToLocal: l == null ? void 0 : l.worldToLocal,
32139
+ pcd: u
32125
32140
  }
32126
- return {
32127
- deviceId: t,
32128
- sourceId: n.id,
32129
- data: {
32130
- worldToLocal: g == null ? void 0 : g.worldToLocal,
32131
- pcd: l
32132
- }
32133
- };
32134
- },
32135
- r
32136
- );
32137
- if (n.sourceType === "telemetry" && n.streamType === "localization")
32138
- return this.addRemovableTelemetrySubscription(
32139
- t,
32140
- n,
32141
- async (s) => {
32142
- let g, l;
32143
- for (let u = 0; u < s.length; u += 1) {
32144
- const c = s[u];
32145
- if (c.deviceId === t && c.name === n.streamName && c.type === "localization") {
32146
- const [d, B] = c.points[c.points.length - 1];
32147
- g = B;
32148
- break;
32149
- }
32141
+ };
32142
+ },
32143
+ r
32144
+ )), n.sourceType === "telemetry" && n.streamType === "localization" && (o = this.addRemovableTelemetrySubscription(
32145
+ t,
32146
+ n,
32147
+ async (g) => {
32148
+ let l, u;
32149
+ for (let c = 0; c < g.length; c += 1) {
32150
+ const d = g[c];
32151
+ if (d.deviceId === t && d.name === n.streamName && d.type === "localization") {
32152
+ const [B, Q] = d.points[d.points.length - 1];
32153
+ l = Q;
32154
+ break;
32150
32155
  }
32151
- if (g && g.pointClouds) {
32152
- const { url: u } = g.pointClouds[0];
32153
- l = await new Promise((c) => {
32154
- o.postMessage({ url: u }), o.onmessage = (d) => {
32155
- d.data.url === u && c(d.data.pcd);
32156
- };
32157
- });
32156
+ }
32157
+ if (l && l.pointClouds) {
32158
+ const { url: c } = l.pointClouds[0];
32159
+ u = await new Promise((d) => {
32160
+ s.postMessage({ url: c }), s.onmessage = (B) => {
32161
+ B.data.url === c && d(B.data.pcd);
32162
+ };
32163
+ });
32164
+ }
32165
+ return {
32166
+ deviceId: t,
32167
+ sourceId: n.id,
32168
+ data: {
32169
+ worldToLocal: l && (l != null && l.pointClouds) && (l != null && l.pointClouds[0]) ? l.pointClouds[0].worldToLocal : void 0,
32170
+ pcd: u
32158
32171
  }
32159
- return {
32160
- deviceId: t,
32161
- sourceId: n.id,
32162
- data: {
32163
- worldToLocal: g && (g != null && g.pointClouds) && (g != null && g.pointClouds[0]) ? g.pointClouds[0].worldToLocal : void 0,
32164
- pcd: l
32165
- }
32166
- };
32167
- },
32168
- r
32169
- );
32170
- if (n.sourceType === "realtime") {
32171
- const s = async (g, l) => {
32172
- var u;
32173
- if (l.payload.pointCloud) {
32174
- const c = Math.random(), d = await new Promise((B) => {
32175
- o.postMessage({
32176
- id: c,
32177
- pointCloud: defined(l.payload.pointCloud).data
32178
- }), o.onmessage = (Q) => {
32179
- Q.data.id === c && B(Q.data.pcd);
32172
+ };
32173
+ },
32174
+ r
32175
+ )), n.sourceType === "realtime") {
32176
+ const g = async (l, u) => {
32177
+ var c;
32178
+ if (u.payload.pointCloud) {
32179
+ const d = Math.random(), B = await new Promise((Q) => {
32180
+ s.postMessage({
32181
+ id: d,
32182
+ pointCloud: defined(u.payload.pointCloud).data
32183
+ }), s.onmessage = (f) => {
32184
+ f.data.id === d && Q(f.data.pcd);
32180
32185
  };
32181
32186
  });
32182
32187
  r({
32183
- worldToLocal: (u = l.payload.pointCloud) == null ? void 0 : u.world_to_local,
32184
- pcd: d
32188
+ worldToLocal: (c = u.payload.pointCloud) == null ? void 0 : c.world_to_local,
32189
+ pcd: B
32185
32190
  });
32186
32191
  }
32187
32192
  };
32188
- return this.subscribeToRealtimeMessages(t, n.rosTopicName, s), () => {
32189
- o.terminate(), this.unsubscribeToRealtimeMessages(
32193
+ return this.subscribeToRealtimeMessages(t, n.rosTopicName, g), () => {
32194
+ s.terminate(), this.unsubscribeToRealtimeMessages(
32190
32195
  t,
32191
32196
  n.rosTopicName,
32192
- s
32197
+ g
32193
32198
  );
32194
32199
  };
32195
32200
  }
32196
32201
  return () => {
32202
+ s.terminate(), o == null || o();
32197
32203
  };
32198
32204
  }
32199
32205
  subscribeToGeometry(t, n, r) {
@@ -32359,20 +32365,7 @@ class LiveUniverseData extends BasicUniverseDataConnector {
32359
32365
  throw new Error("Not implemented");
32360
32366
  }
32361
32367
  }
32362
- const NoData = Symbol("no_data"), LoadingData = Symbol("loading_data"), FailedData = Symbol("failed_data"), encodedJs$1 = "dmFyIGw9T2JqZWN0LmRlZmluZVByb3BlcnR5O3ZhciBnPShjLG4sbyk9Pm4gaW4gYz9sKGMsbix7ZW51bWVyYWJsZTohMCxjb25maWd1cmFibGU6ITAsd3JpdGFibGU6ITAsdmFsdWU6b30pOmNbbl09bzt2YXIgcj0oYyxuLG8pPT4oZyhjLHR5cGVvZiBuIT0ic3ltYm9sIj9uKyIiOm4sbyksbyk7KGZ1bmN0aW9uKCl7InVzZSBzdHJpY3QiO2NvbnN0IHU9e21pbGxpc2Vjb25kOjEsc2Vjb25kOjFlMyxtaW51dGU6NmU0LGhvdXI6MzZlNSxkYXk6ODY0ZTUsd2Vlazo2MDQ4ZTUsbW9udGg6MjU5MmU2LHllYXI6MzE1MzZlNn07ZnVuY3Rpb24geChoKXt9Y2xhc3MgbXtjb25zdHJ1Y3Rvcih7Y2FwYWNpdHk6ZSx0aW1lb3V0OnN9PXt9KXtyKHRoaXMsImVudHJpZXMiLG5ldyBNYXApO3IodGhpcywibWV0YWRhdGEiLG5ldyBNYXApO3IodGhpcywiY2FwYWNpdHkiKTtyKHRoaXMsInRpbWVvdXQiKTt0aGlzLmNhcGFjaXR5PWV8fDFlNCx0aGlzLnRpbWVvdXQ9c3x8dS5taW51dGV9Z2V0KGUscyl7Y29uc3QgYT10aGlzLmtleVRvQ2FjaGVLZXkoZSksaT10aGlzLmVudHJpZXMuZ2V0KGEpLHQ9dGhpcy5tZXRhZGF0YS5nZXQoYSk7cmV0dXJuKGk9PT12b2lkIDB8fHQmJih0PT1udWxsP3ZvaWQgMDp0LmV4cGlyYXRpb24uZ2V0VGltZSgpKTxEYXRlLm5vdygpKSYmISh0IT1udWxsJiZ0LmdlbmVyYXRpbmcpJiZzJiZ0aGlzLmdlbmVyYXRlKGUscygpKSxpPT09dm9pZCAwJiZ0JiZ0Lmxhc3RWYWx1ZSE9PXZvaWQgMD90Lmxhc3RWYWx1ZTppfXNldChlLHMpe2NvbnN0IGE9dGhpcy5rZXlUb0NhY2hlS2V5KGUpO3RoaXMubWV0YWRhdGEuc2V0KGEse2dlbmVyYXRpbmc6ITEsZXhwaXJhdGlvbjpuZXcgRGF0ZShEYXRlLm5vdygpK3RoaXMudGltZW91dCksbGFzdFZhbHVlOnN9KSx0aGlzLmVudHJpZXMuc2V0KGEscyksdGhpcy5tZXRhZGF0YS5zaXplPnRoaXMuY2FwYWNpdHkmJnRoaXMuZGVsZXRlT2xkZXN0RW50cnkoKX1jbGVhcigpe3RoaXMuZW50cmllcy5jbGVhcigpLFsuLi50aGlzLm1ldGFkYXRhLnZhbHVlcygpXS5mb3JFYWNoKGU9PmUuZ2VuZXJhdGluZz0hMSl9Y2xlYXJLZXkoZSl7dGhpcy5tZXRhZGF0YS5kZWxldGUoZSksdGhpcy5lbnRyaWVzLmRlbGV0ZShlKX1rZXlUb0NhY2hlS2V5KGUpe3JldHVybiBKU09OLnN0cmluZ2lmeShlKX1kZWxldGVPbGRlc3RFbnRyeSgpe2lmKHRoaXMubWV0YWRhdGEuc2l6ZTwxKXJldHVybjtjb25zdFtlXT1bLi4udGhpcy5tZXRhZGF0YS5lbnRyaWVzKCldLnJlZHVjZSgoW3MsYV0sW2ksdF0pPT50LmV4cGlyYXRpb24uZ2V0VGltZSgpPGEuZXhwaXJhdGlvbi5nZXRUaW1lKCk/W2ksdF06W3MsYV0pO3RoaXMuY2xlYXJLZXkoZSl9Z2VuZXJhdGUoZSxzKXtjb25zdCBhPXRoaXMua2V5VG9DYWNoZUtleShlKSxpPXRoaXMubWV0YWRhdGEuZ2V0KGEpfHx7fTt0aGlzLm1ldGFkYXRhLnNldChhLHsuLi5pLGdlbmVyYXRpbmc6ITAsZXhwaXJhdGlvbjpuZXcgRGF0ZShEYXRlLm5vdygpK3RoaXMudGltZW91dCl9KSxzZXRUaW1lb3V0KCgpPT57cy50aGVuKHQ9Pntjb25zdCBkPXRoaXMubWV0YWRhdGEuZ2V0KGEpOyEoZCE9bnVsbCYmZC5nZW5lcmF0aW5nKXx8dGhpcy5zZXQoZSx0KX0pfSwwKX19Y29uc3QgeT1uZXcgbSh7Y2FwYWNpdHk6MWUzLHRpbWVvdXQ6MSp1Lm1pbnV0ZX0pO29ubWVzc2FnZT1hc3luYyBoPT57Y29uc3R7dXJsOmV9PWguZGF0YTtpZihlKXtjb25zdCBzPXkuZ2V0KGUsYXN5bmMoKT0+YXdhaXQgZmV0Y2goZSx7bW9kZToiY29ycyJ9KS50aGVuKGk9PmkuanNvbigpKSk7cyYmcG9zdE1lc3NhZ2Uoe3VybDplLHJlc3BvbnNlOnN9KX19fSkoKTsK", blob$1 = typeof window != "undefined" && window.Blob && new Blob([atob(encodedJs$1)], { type: "text/javascript;charset=utf-8" });
32363
- function WorkerWrapper$1() {
32364
- let e;
32365
- try {
32366
- if (e = blob$1 && (window.URL || window.webkitURL).createObjectURL(blob$1), !e)
32367
- throw "";
32368
- return new Worker(e);
32369
- } catch {
32370
- return new Worker("data:application/javascript;base64," + encodedJs$1);
32371
- } finally {
32372
- e && (window.URL || window.webkitURL).revokeObjectURL(e);
32373
- }
32374
- }
32375
- const encodedJs = "var R=Object.defineProperty;var G=(M,b,x)=>b in M?R(M,b,{enumerable:!0,configurable:!0,writable:!0,value:x}):M[b]=x;var I=(M,b,x)=>(G(M,typeof b!="symbol"?b+"":b,x),x);(function(){"use strict";const S={millisecond:1,second:1e3,minute:6e4,hour:36e5,day:864e5,week:6048e5,month:2592e6,year:31536e6};function q(o){}class _{constructor({capacity:t,timeout:n}={}){I(this,"entries",new Map);I(this,"metadata",new Map);I(this,"capacity");I(this,"timeout");this.capacity=t||1e4,this.timeout=n||S.minute}get(t,n){const e=this.keyToCacheKey(t),c=this.entries.get(e),i=this.metadata.get(e);return(c===void 0||i&&(i==null?void 0:i.expiration.getTime())<Date.now())&&!(i!=null&&i.generating)&&n&&this.generate(t,n()),c===void 0&&i&&i.lastValue!==void 0?i.lastValue:c}set(t,n){const e=this.keyToCacheKey(t);this.metadata.set(e,{generating:!1,expiration:new Date(Date.now()+this.timeout),lastValue:n}),this.entries.set(e,n),this.metadata.size>this.capacity&&this.deleteOldestEntry()}clear(){this.entries.clear(),[...this.metadata.values()].forEach(t=>t.generating=!1)}clearKey(t){this.metadata.delete(t),this.entries.delete(t)}keyToCacheKey(t){return JSON.stringify(t)}deleteOldestEntry(){if(this.metadata.size<1)return;const[t]=[...this.metadata.entries()].reduce(([n,e],[c,i])=>i.expiration.getTime()<e.expiration.getTime()?[c,i]:[n,e]);this.clearKey(t)}generate(t,n){const e=this.keyToCacheKey(t),c=this.metadata.get(e)||{};this.metadata.set(e,{...c,generating:!0,expiration:new Date(Date.now()+this.timeout)}),setTimeout(()=>{n.then(i=>{const r=this.metadata.get(e);!(r!=null&&r.generating)||this.set(t,i)})},0)}}/**
 * LZF compression/decompression module. Ported from the C
 * implementation of liblzf, specfically lzf_c.c and lzf_d.c
 * @license BSD-2-Clause
 */function K(o){var t=new Uint8Array(o),n=[],e=0,c=0;do{var i=t[e++];if(i<1<<5){if(i++,e+i>t.length)throw new Error("Invalid input");for(;i--;)n[c++]=t[e++]}else{var r=i>>5,f=c-((i&31)<<8)-1;if(e>=t.length)throw new Error("Invalid input");if(r==7&&(r+=t[e++],e>=t.length))throw new Error("Invalid input");if(f-=t[e++],f<0)throw new Error("Invalid input");r+=2;do n[c++]=n[f++];while(--r)}}while(e<t.length);if(typeof Buffer!="undefined")return new Buffer(n);var u=new Uint8Array(n.length);return u.set(n),u}function O(o){var t=16,n=1<<t,e=1<<13,c=(1<<8)+(1<<3),i=1<<5;function r(v,T){return v[T]<<8|v[T+1]}function f(v,T,P){return v<<8|T[P+2]}function u(v){return v*506832829>>32-t-8&n-1}for(var s=new Uint8Array(o),a=[],d=new Uint32Array(n),y=s.length,h=0,g=r(s,h),p=1,l=0;h<y-2;){g=f(g,o,h);var z=u(g),m=d[z];d[z]=h;var E;if(m<h&&(E=h-m-1)<e&&m>0&&s[m+2]==s[h+2]&&s[m+1]==s[h+1]&&s[m]==s[h]){var w=2,F=y-h-w;F=F>c?c:F,a[p-l-1]=l-1&255,l==0&&(p-=1);do w++;while(w<F&&s[m+w]==s[h+w]);if(w-=2,h++,w<7?a[p++]=(E>>8)+(w<<5)&255:(a[p++]=(E>>8)+(7<<5)&255,a[p++]=w-7&255),a[p++]=E&255,l=0,p++,h+=w+1,h>=y-2)break;--h,--h,g=r(s,h),g=f(g,s,h),d[u(g)]=h++,g=f(g,s,h),d[u(g)]=h++}else l++,a[p++]=s[h++],l==i&&(a[p-l-1]=l-1&255,l=0,p++)}for(;h<y;)l++,a[p++]=s[h++],l==i&&(a[p-l-1]=l-1&255,l=0,p++);if(l!=0&&(a[p-l-1]=l-1&255),typeof Buffer!="undefined")return new Buffer(a);var U=new Uint8Array(a.length);return U.set(a),U}var B={decompress:K,compress:O};const C=(o,t)=>t<=o?[]:new Array(t-o).fill(0).map((n,e)=>e+o),A=!0;function H(o){const t=atob(o),n=t.length,e=new Uint8Array(n);for(let c=0;c<n;c+=1)e[c]=t.charCodeAt(c);return e.buffer}function L(o){const t=new Uint8Array(o);let n="",e=0;for(;e<t.length&&n.search(/[\r\n]DATA\s(\S*)\s/i)===-1;e+=1)n+=String.fromCharCode(t[e]);return{body:o.slice(e),header:n.replace(/#.*/gi,"")}}function V(o){const n=new Uint32Array(o,0,2)[0];return n===0?new ArrayBuffer(0):B.decompress(new Uint8Array(o,8,n)).buffer}function k(o){const{header:t,body:n}=L(o),e=/VERSION (.*)/i.exec(t);if(e===null)throw new Error(`Missing version. Header ${t}`);const c=e[1],i=/FIELDS (.*)/i.exec(t);if(!i)throw new Error("Missing fields");const r=i[1].split(" "),f=/SIZE (.*)/i.exec(t);if(!f)throw new Error("Missing size");const u=f[1].split(" ").map(v=>parseInt(v,10)),s=/TYPE (.*)/i.exec(t);if(!s)throw new Error("Missing type");const a=s[1].split(" "),d=/COUNT (.*)/i.exec(t);let y;d&&(y=d[1].split(" ").map(v=>parseInt(v,10)));const h=y||r.map(v=>1),g=/WIDTH (.*)/i.exec(t);if(!g)throw new Error("Missing width");const p=parseInt(g[1],10),l=/HEIGHT (.*)/i.exec(t);if(!l)throw new Error("Missing height");const z=parseInt(l[1],10),m=/POINTS (.*)/i.exec(t);let E;m&&(E=parseInt(m[1],10));const w=E||p*z,F=/DATA (.*)/i.exec(t);if(!F)throw new Error("Missing data");const U=F[1];return{body:n,header:{count:h,data:U,fields:r,height:z,points:w,size:u,type:a,version:c,width:p}}}function N(o){const t={};return o.fields.reduce(({offsets:n,size:e},c,i)=>{let r=e;return c==="x"&&(n.x=r),c==="y"&&(n.y=r),c==="z"&&(n.z=r),c==="rgb"&&(n.rgb=r),c==="rgba"&&(n.rgba=r),c==="intensity"&&(n.intensity=r),o.data==="ascii"?r+=1:o.data==="binary"?r+=o.size[i]*o.count[i]:o.data==="binary_compressed"&&(r+=o.size[i]*o.count[i]*o.points),{offsets:n,size:r}},{offsets:t,size:0})}function D(o){const{header:t,body:n}=k(o),{offsets:e,size:c}=N(t);let i;e.x!==void 0&&e.y!==void 0&&e.z!==void 0&&(i=new Float32Array(t.points*3));let r;(e.rgb!==void 0||e.rgba!==void 0)&&(r=new Float32Array(t.points*4));let f;if(e.intensity!==void 0&&(f=new Float32Array(t.points)),t.data==="ascii")String.fromCharCode(...new Uint8Array(n)).split(`
`).forEach((a,d)=>{const y=a.split(" ");if(i!==void 0&&(i[d*3+0]=parseFloat(y[e.x||0]),i[d*3+1]=parseFloat(y[e.y||0]),i[d*3+2]=parseFloat(y[e.z||0])),r!==void 0){const h=new Int32Array([parseInt(y[e.rgb||e.rgba||0],10)]),g=new DataView(h.buffer,0);r[d*3+0]=g.getUint8(2)/255,r[d*3+1]=g.getUint8(1)/255,r[d*3+2]=g.getUint8(0)/255}f!==void 0&&(f[d]=parseFloat(y[e.intensity||0]))});else if(t.data==="binary"){const u=new DataView(n);C(0,t.points).forEach(s=>{const a=c*s;if(i!==void 0&&(i[s*3+0]=u.getFloat32(a+(e.x||0),A),i[s*3+1]=u.getFloat32(a+(e.y||0),A),i[s*3+2]=u.getFloat32(a+(e.z||0),A)),r!==void 0){const d=a+(e.rgb||e.rgba||0);d+2<=u.byteLength&&(r[s*4+0]=u.getUint8(d+2)/255,r[s*4+1]=u.getUint8(d+1)/255,r[s*4+2]=u.getUint8(d+0)/255,r[s*4+3]=1)}f!==void 0&&(f[s]=u.getFloat32(a+(e.intensity||0),A))})}else if(t.data==="binary_compressed"){const u=V(n),s=new DataView(u);C(0,t.points).forEach(a=>{if(i!==void 0&&(i[a*3+0]=s.getFloat32((e.x||0)+a*4,A),i[a*3+1]=s.getFloat32((e.y||0)+a*4,A),i[a*3+2]=s.getFloat32((e.z||0)+a*4,A)),r!==void 0){const d=(e.rgb||e.rgba||0)+a*4;d+2<=s.byteLength&&(r[a*4+0]=s.getUint8(d+2)/255,r[a*4+1]=s.getUint8(d+1)/255,r[a*4+2]=s.getUint8(d+0)/255,r[a*4+3]=1)}f!==void 0&&(f[a]=s.getFloat32((e.intensity||0)+a*4,A))})}return{colors:r,header:t,intensity:f,positions:i}}function X(o){return D(H(o))}const Z=new _({capacity:1e3,timeout:1*S.minute});onmessage=async o=>{const{url:t,id:n,pointCloud:e}=o.data;if(t){const c=Z.get(t,async()=>D(await fetch(t,{mode:"cors"}).then(r=>r.arrayBuffer())));c&&postMessage({url:t,pcd:c})}if(n&&e){const c=X(e);postMessage({id:n,pcd:c})}}})();
", blob = typeof window != "undefined" && window.Blob && new Blob([atob(encodedJs)], { type: "text/javascript;charset=utf-8" });
32368
+ const NoData = Symbol("no_data"), LoadingData = Symbol("loading_data"), FailedData = Symbol("failed_data"), encodedJs = "dmFyIGw9T2JqZWN0LmRlZmluZVByb3BlcnR5O3ZhciBnPShjLG4sbyk9Pm4gaW4gYz9sKGMsbix7ZW51bWVyYWJsZTohMCxjb25maWd1cmFibGU6ITAsd3JpdGFibGU6ITAsdmFsdWU6b30pOmNbbl09bzt2YXIgcj0oYyxuLG8pPT4oZyhjLHR5cGVvZiBuIT0ic3ltYm9sIj9uKyIiOm4sbyksbyk7KGZ1bmN0aW9uKCl7InVzZSBzdHJpY3QiO2NvbnN0IHU9e21pbGxpc2Vjb25kOjEsc2Vjb25kOjFlMyxtaW51dGU6NmU0LGhvdXI6MzZlNSxkYXk6ODY0ZTUsd2Vlazo2MDQ4ZTUsbW9udGg6MjU5MmU2LHllYXI6MzE1MzZlNn07ZnVuY3Rpb24geChoKXt9Y2xhc3MgbXtjb25zdHJ1Y3Rvcih7Y2FwYWNpdHk6ZSx0aW1lb3V0OnN9PXt9KXtyKHRoaXMsImVudHJpZXMiLG5ldyBNYXApO3IodGhpcywibWV0YWRhdGEiLG5ldyBNYXApO3IodGhpcywiY2FwYWNpdHkiKTtyKHRoaXMsInRpbWVvdXQiKTt0aGlzLmNhcGFjaXR5PWV8fDFlNCx0aGlzLnRpbWVvdXQ9c3x8dS5taW51dGV9Z2V0KGUscyl7Y29uc3QgYT10aGlzLmtleVRvQ2FjaGVLZXkoZSksaT10aGlzLmVudHJpZXMuZ2V0KGEpLHQ9dGhpcy5tZXRhZGF0YS5nZXQoYSk7cmV0dXJuKGk9PT12b2lkIDB8fHQmJih0PT1udWxsP3ZvaWQgMDp0LmV4cGlyYXRpb24uZ2V0VGltZSgpKTxEYXRlLm5vdygpKSYmISh0IT1udWxsJiZ0LmdlbmVyYXRpbmcpJiZzJiZ0aGlzLmdlbmVyYXRlKGUscygpKSxpPT09dm9pZCAwJiZ0JiZ0Lmxhc3RWYWx1ZSE9PXZvaWQgMD90Lmxhc3RWYWx1ZTppfXNldChlLHMpe2NvbnN0IGE9dGhpcy5rZXlUb0NhY2hlS2V5KGUpO3RoaXMubWV0YWRhdGEuc2V0KGEse2dlbmVyYXRpbmc6ITEsZXhwaXJhdGlvbjpuZXcgRGF0ZShEYXRlLm5vdygpK3RoaXMudGltZW91dCksbGFzdFZhbHVlOnN9KSx0aGlzLmVudHJpZXMuc2V0KGEscyksdGhpcy5tZXRhZGF0YS5zaXplPnRoaXMuY2FwYWNpdHkmJnRoaXMuZGVsZXRlT2xkZXN0RW50cnkoKX1jbGVhcigpe3RoaXMuZW50cmllcy5jbGVhcigpLFsuLi50aGlzLm1ldGFkYXRhLnZhbHVlcygpXS5mb3JFYWNoKGU9PmUuZ2VuZXJhdGluZz0hMSl9Y2xlYXJLZXkoZSl7dGhpcy5tZXRhZGF0YS5kZWxldGUoZSksdGhpcy5lbnRyaWVzLmRlbGV0ZShlKX1rZXlUb0NhY2hlS2V5KGUpe3JldHVybiBKU09OLnN0cmluZ2lmeShlKX1kZWxldGVPbGRlc3RFbnRyeSgpe2lmKHRoaXMubWV0YWRhdGEuc2l6ZTwxKXJldHVybjtjb25zdFtlXT1bLi4udGhpcy5tZXRhZGF0YS5lbnRyaWVzKCldLnJlZHVjZSgoW3MsYV0sW2ksdF0pPT50LmV4cGlyYXRpb24uZ2V0VGltZSgpPGEuZXhwaXJhdGlvbi5nZXRUaW1lKCk/W2ksdF06W3MsYV0pO3RoaXMuY2xlYXJLZXkoZSl9Z2VuZXJhdGUoZSxzKXtjb25zdCBhPXRoaXMua2V5VG9DYWNoZUtleShlKSxpPXRoaXMubWV0YWRhdGEuZ2V0KGEpfHx7fTt0aGlzLm1ldGFkYXRhLnNldChhLHsuLi5pLGdlbmVyYXRpbmc6ITAsZXhwaXJhdGlvbjpuZXcgRGF0ZShEYXRlLm5vdygpK3RoaXMudGltZW91dCl9KSxzZXRUaW1lb3V0KCgpPT57cy50aGVuKHQ9Pntjb25zdCBkPXRoaXMubWV0YWRhdGEuZ2V0KGEpOyEoZCE9bnVsbCYmZC5nZW5lcmF0aW5nKXx8dGhpcy5zZXQoZSx0KX0pfSwwKX19Y29uc3QgeT1uZXcgbSh7Y2FwYWNpdHk6MWUzLHRpbWVvdXQ6MSp1Lm1pbnV0ZX0pO29ubWVzc2FnZT1hc3luYyBoPT57Y29uc3R7dXJsOmV9PWguZGF0YTtpZihlKXtjb25zdCBzPXkuZ2V0KGUsYXN5bmMoKT0+YXdhaXQgZmV0Y2goZSx7bW9kZToiY29ycyJ9KS50aGVuKGk9PmkuanNvbigpKSk7cyYmcG9zdE1lc3NhZ2Uoe3VybDplLHJlc3BvbnNlOnN9KX19fSkoKTsK", blob = typeof window != "undefined" && window.Blob && new Blob([atob(encodedJs)], { type: "text/javascript;charset=utf-8" });
32376
32369
  function WorkerWrapper() {
32377
32370
  let e;
32378
32371
  try {
@@ -32401,7 +32394,7 @@ class TelemetryUniverseData extends BasicUniverseDataConnector {
32401
32394
  subscribeToPath(n, r, o) {
32402
32395
  if (r.sourceType !== "telemetry")
32403
32396
  throw new Error("Telemetry sources only supported");
32404
- const s = new WorkerWrapper$1();
32397
+ const s = new WorkerWrapper();
32405
32398
  let g = 0, l = 0;
32406
32399
  const u = this.subscribeTelemetry(
32407
32400
  n,
@@ -32511,7 +32504,7 @@ class TelemetryUniverseData extends BasicUniverseDataConnector {
32511
32504
  subscribeToPointCloud(n, r, o) {
32512
32505
  if (r.sourceType !== "telemetry")
32513
32506
  throw new Error("Telemetry sources only supported");
32514
- const s = new WorkerWrapper(), g = new WorkerWrapper$1();
32507
+ const s = new WorkerWrapper$1(), g = new WorkerWrapper();
32515
32508
  let l = () => {
32516
32509
  }, u = () => {
32517
32510
  };
@@ -32566,7 +32559,7 @@ class TelemetryUniverseData extends BasicUniverseDataConnector {
32566
32559
  subscribeToOdometry(n, r, o, s = 0) {
32567
32560
  if (r.sourceType !== "telemetry")
32568
32561
  throw new Error("Telemetry sources only supported");
32569
- const g = new WorkerWrapper$1();
32562
+ const g = new WorkerWrapper();
32570
32563
  let l = 0, u = 0;
32571
32564
  const c = this.subscribeTelemetry(
32572
32565
  n,
@@ -32635,7 +32628,7 @@ class TelemetryUniverseData extends BasicUniverseDataConnector {
32635
32628
  }
32636
32629
  subscribeToGeometry(n, r, o) {
32637
32630
  if (r.sourceType === "telemetry") {
32638
- const s = new WorkerWrapper$1(), g = this.subscribeTelemetry(
32631
+ const s = new WorkerWrapper(), g = this.subscribeTelemetry(
32639
32632
  n,
32640
32633
  r,
32641
32634
  "json",
@@ -32663,7 +32656,7 @@ class TelemetryUniverseData extends BasicUniverseDataConnector {
32663
32656
  const s = {};
32664
32657
  if (r.sourceType !== "telemetry")
32665
32658
  throw new Error("Telemetry sources only supported");
32666
- const g = new WorkerWrapper$1(), l = this.subscribeTelemetry(
32659
+ const g = new WorkerWrapper(), l = this.subscribeTelemetry(
32667
32660
  n,
32668
32661
  r,
32669
32662
  "localization",