@vonage/ml-transformers 1.0.1

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.
Files changed (33) hide show
  1. package/README.md +9 -0
  2. package/dist/docs/.nojekyll +1 -0
  3. package/dist/docs/assets/highlight.css +85 -0
  4. package/dist/docs/assets/icons.css +1043 -0
  5. package/dist/docs/assets/icons.png +0 -0
  6. package/dist/docs/assets/icons@2x.png +0 -0
  7. package/dist/docs/assets/main.js +52 -0
  8. package/dist/docs/assets/search.js +1 -0
  9. package/dist/docs/assets/style.css +1413 -0
  10. package/dist/docs/assets/widgets.png +0 -0
  11. package/dist/docs/assets/widgets@2x.png +0 -0
  12. package/dist/docs/enums/BlurRadius.html +7 -0
  13. package/dist/docs/index.html +15 -0
  14. package/dist/docs/modules.html +30 -0
  15. package/dist/ml-transformers.es.js +1254 -0
  16. package/dist/ml-transformers.umd.js +2 -0
  17. package/dist/models/selfie_segmentation_landscape.tflite +0 -0
  18. package/dist/tflite-simd.wasm +0 -0
  19. package/dist/types/main.d.ts +95 -0
  20. package/dist/types/src/transformers/BackgroundTransformer.d.ts +34 -0
  21. package/dist/types/src/transformers/BlurPostProcess.d.ts +10 -0
  22. package/dist/types/src/transformers/PostProcessInterface.d.ts +5 -0
  23. package/dist/types/src/transformers/Queue.d.ts +13 -0
  24. package/dist/types/src/transformers/SilueteBlurPostProcess.d.ts +10 -0
  25. package/dist/types/src/transformers/VideoPostProcess.d.ts +11 -0
  26. package/dist/types/src/transformers/VirtualPostProcess.d.ts +11 -0
  27. package/dist/types/src/transformers/VonageTFLite.d.ts +28 -0
  28. package/dist/types/src/transformers/VonageTransformerConfig.d.ts +1 -0
  29. package/dist/types/src/types.d.ts +65 -0
  30. package/dist/types/src/utils/utils.d.ts +6 -0
  31. package/dist/types/src/vonage/VonageMediaProcessorThread.d.ts +1 -0
  32. package/dist/types/src/vonage/VonageMediaProcessorWorker.d.ts +10 -0
  33. package/package.json +65 -0
@@ -0,0 +1,2 @@
1
+ (function(s,K){typeof exports=="object"&&typeof module!="undefined"?K(exports):typeof define=="function"&&define.amd?define(["exports"],K):(s=typeof globalThis!="undefined"?globalThis:s||self,K(s["ml-transformers"]={}))})(this,function(s){"use strict";function K(){return new Promise((Z,l)=>{typeof MediaStreamTrackProcessor=="undefined"||typeof MediaStreamTrackGenerator=="undefined"?l("Your browser does not support the MediaStreamTrack API for Insertable Streams of Media."):Z()})}var D={exports:{}},A=function(l,d){return function(){for(var c=new Array(arguments.length),m=0;m<c.length;m++)c[m]=arguments[m];return l.apply(d,c)}},Yl=A,y=Object.prototype.toString;function k(Z){return Array.isArray(Z)}function U(Z){return typeof Z=="undefined"}function Jl(Z){return Z!==null&&!U(Z)&&Z.constructor!==null&&!U(Z.constructor)&&typeof Z.constructor.isBuffer=="function"&&Z.constructor.isBuffer(Z)}function _(Z){return y.call(Z)==="[object ArrayBuffer]"}function Il(Z){return y.call(Z)==="[object FormData]"}function Kl(Z){var l;return typeof ArrayBuffer!="undefined"&&ArrayBuffer.isView?l=ArrayBuffer.isView(Z):l=Z&&Z.buffer&&_(Z.buffer),l}function Nl(Z){return typeof Z=="string"}function Hl(Z){return typeof Z=="number"}function q(Z){return Z!==null&&typeof Z=="object"}function H(Z){if(y.call(Z)!=="[object Object]")return!1;var l=Object.getPrototypeOf(Z);return l===null||l===Object.prototype}function Sl(Z){return y.call(Z)==="[object Date]"}function vl(Z){return y.call(Z)==="[object File]"}function Ll(Z){return y.call(Z)==="[object Blob]"}function $(Z){return y.call(Z)==="[object Function]"}function Fl(Z){return q(Z)&&$(Z.pipe)}function zl(Z){return y.call(Z)==="[object URLSearchParams]"}function fl(Z){return Z.trim?Z.trim():Z.replace(/^\s+|\s+$/g,"")}function xl(){return typeof navigator!="undefined"&&(navigator.product==="ReactNative"||navigator.product==="NativeScript"||navigator.product==="NS")?!1:typeof window!="undefined"&&typeof document!="undefined"}function B(Z,l){if(!(Z===null||typeof Z=="undefined"))if(typeof Z!="object"&&(Z=[Z]),k(Z))for(var d=0,b=Z.length;d<b;d++)l.call(null,Z[d],d,Z);else for(var c in Z)Object.prototype.hasOwnProperty.call(Z,c)&&l.call(null,Z[c],c,Z)}function T(){var Z={};function l(c,m){H(Z[m])&&H(c)?Z[m]=T(Z[m],c):H(c)?Z[m]=T({},c):k(c)?Z[m]=c.slice():Z[m]=c}for(var d=0,b=arguments.length;d<b;d++)B(arguments[d],l);return Z}function Cl(Z,l,d){return B(l,function(c,m){d&&typeof c=="function"?Z[m]=Yl(c,d):Z[m]=c}),Z}function kl(Z){return Z.charCodeAt(0)===65279&&(Z=Z.slice(1)),Z}var W={isArray:k,isArrayBuffer:_,isBuffer:Jl,isFormData:Il,isArrayBufferView:Kl,isString:Nl,isNumber:Hl,isObject:q,isPlainObject:H,isUndefined:U,isDate:Sl,isFile:vl,isBlob:Ll,isFunction:$,isStream:Fl,isURLSearchParams:zl,isStandardBrowserEnv:xl,forEach:B,merge:T,extend:Cl,trim:fl,stripBOM:kl},R=W;function ll(Z){return encodeURIComponent(Z).replace(/%3A/gi,":").replace(/%24/g,"$").replace(/%2C/gi,",").replace(/%20/g,"+").replace(/%5B/gi,"[").replace(/%5D/gi,"]")}var Zl=function(l,d,b){if(!d)return l;var c;if(b)c=b(d);else if(R.isURLSearchParams(d))c=d.toString();else{var m=[];R.forEach(d,function(e,X){e===null||typeof e=="undefined"||(R.isArray(e)?X=X+"[]":e=[e],R.forEach(e,function(u){R.isDate(u)?u=u.toISOString():R.isObject(u)&&(u=JSON.stringify(u)),m.push(ll(X)+"="+ll(u))}))}),c=m.join("&")}if(c){var t=l.indexOf("#");t!==-1&&(l=l.slice(0,t)),l+=(l.indexOf("?")===-1?"?":"&")+c}return l},Ul=W;function S(){this.handlers=[]}S.prototype.use=function(l,d,b){return this.handlers.push({fulfilled:l,rejected:d,synchronous:b?b.synchronous:!1,runWhen:b?b.runWhen:null}),this.handlers.length-1},S.prototype.eject=function(l){this.handlers[l]&&(this.handlers[l]=null)},S.prototype.forEach=function(l){Ul.forEach(this.handlers,function(b){b!==null&&l(b)})};var Bl=S,Tl=W,gl=function(l,d){Tl.forEach(l,function(c,m){m!==d&&m.toUpperCase()===d.toUpperCase()&&(l[d]=c,delete l[m])})},dl=function(l,d,b,c,m){return l.config=d,b&&(l.code=b),l.request=c,l.response=m,l.isAxiosError=!0,l.toJSON=function(){return{message:this.message,name:this.name,description:this.description,number:this.number,fileName:this.fileName,lineNumber:this.lineNumber,columnNumber:this.columnNumber,stack:this.stack,config:this.config,code:this.code,status:this.response&&this.response.status?this.response.status:null}},l},wl=dl,cl=function(l,d,b,c,m){var t=new Error(l);return wl(t,d,b,c,m)},Ql=cl,Pl=function(l,d,b){var c=b.config.validateStatus;!b.status||!c||c(b.status)?l(b):d(Ql("Request failed with status code "+b.status,b.config,null,b.request,b))},v=W,jl=v.isStandardBrowserEnv()?function(){return{write:function(d,b,c,m,t,i){var e=[];e.push(d+"="+encodeURIComponent(b)),v.isNumber(c)&&e.push("expires="+new Date(c).toGMTString()),v.isString(m)&&e.push("path="+m),v.isString(t)&&e.push("domain="+t),i===!0&&e.push("secure"),document.cookie=e.join("; ")},read:function(d){var b=document.cookie.match(new RegExp("(^|;\\s*)("+d+")=([^;]*)"));return b?decodeURIComponent(b[3]):null},remove:function(d){this.write(d,"",Date.now()-864e5)}}}():function(){return{write:function(){},read:function(){return null},remove:function(){}}}(),Ml=function(l){return/^([a-z][a-z\d+\-.]*:)?\/\//i.test(l)},El=function(l,d){return d?l.replace(/\/+$/,"")+"/"+d.replace(/^\/+/,""):l},Ol=Ml,Dl=El,Al=function(l,d){return l&&!Ol(d)?Dl(l,d):d},g=W,_l=["age","authorization","content-length","content-type","etag","expires","from","host","if-modified-since","if-unmodified-since","last-modified","location","max-forwards","proxy-authorization","referer","retry-after","user-agent"],ql=function(l){var d={},b,c,m;return l&&g.forEach(l.split(`
2
+ `),function(i){if(m=i.indexOf(":"),b=g.trim(i.substr(0,m)).toLowerCase(),c=g.trim(i.substr(m+1)),b){if(d[b]&&_l.indexOf(b)>=0)return;b==="set-cookie"?d[b]=(d[b]?d[b]:[]).concat([c]):d[b]=d[b]?d[b]+", "+c:c}}),d},bl=W,$l=bl.isStandardBrowserEnv()?function(){var l=/(msie|trident)/i.test(navigator.userAgent),d=document.createElement("a"),b;function c(m){var t=m;return l&&(d.setAttribute("href",t),t=d.href),d.setAttribute("href",t),{href:d.href,protocol:d.protocol?d.protocol.replace(/:$/,""):"",host:d.host,search:d.search?d.search.replace(/^\?/,""):"",hash:d.hash?d.hash.replace(/^#/,""):"",hostname:d.hostname,port:d.port,pathname:d.pathname.charAt(0)==="/"?d.pathname:"/"+d.pathname}}return b=c(window.location.href),function(t){var i=bl.isString(t)?c(t):t;return i.protocol===b.protocol&&i.host===b.host}}():function(){return function(){return!0}}();function w(Z){this.message=Z}w.prototype.toString=function(){return"Cancel"+(this.message?": "+this.message:"")},w.prototype.__CANCEL__=!0;var L=w,F=W,lZ=Pl,ZZ=jl,dZ=Zl,cZ=Al,bZ=ql,mZ=$l,Q=cl,nZ=f,tZ=L,ml=function(l){return new Promise(function(b,c){var m=l.data,t=l.headers,i=l.responseType,e;function X(){l.cancelToken&&l.cancelToken.unsubscribe(e),l.signal&&l.signal.removeEventListener("abort",e)}F.isFormData(m)&&delete t["Content-Type"];var n=new XMLHttpRequest;if(l.auth){var u=l.auth.username||"",p=l.auth.password?unescape(encodeURIComponent(l.auth.password)):"";t.Authorization="Basic "+btoa(u+":"+p)}var o=cZ(l.baseURL,l.url);n.open(l.method.toUpperCase(),dZ(o,l.params,l.paramsSerializer),!0),n.timeout=l.timeout;function rl(){if(!!n){var h="getAllResponseHeaders"in n?bZ(n.getAllResponseHeaders()):null,I=!i||i==="text"||i==="json"?n.responseText:n.response,r={data:I,status:n.status,statusText:n.statusText,headers:h,config:l,request:n};lZ(function(O){b(O),X()},function(O){c(O),X()},r),n=null}}if("onloadend"in n?n.onloadend=rl:n.onreadystatechange=function(){!n||n.readyState!==4||n.status===0&&!(n.responseURL&&n.responseURL.indexOf("file:")===0)||setTimeout(rl)},n.onabort=function(){!n||(c(Q("Request aborted",l,"ECONNABORTED",n)),n=null)},n.onerror=function(){c(Q("Network Error",l,null,n)),n=null},n.ontimeout=function(){var I=l.timeout?"timeout of "+l.timeout+"ms exceeded":"timeout exceeded",r=l.transitional||nZ.transitional;l.timeoutErrorMessage&&(I=l.timeoutErrorMessage),c(Q(I,l,r.clarifyTimeoutError?"ETIMEDOUT":"ECONNABORTED",n)),n=null},F.isStandardBrowserEnv()){var Rl=(l.withCredentials||mZ(o))&&l.xsrfCookieName?ZZ.read(l.xsrfCookieName):void 0;Rl&&(t[l.xsrfHeaderName]=Rl)}"setRequestHeader"in n&&F.forEach(t,function(I,r){typeof m=="undefined"&&r.toLowerCase()==="content-type"?delete t[r]:n.setRequestHeader(r,I)}),F.isUndefined(l.withCredentials)||(n.withCredentials=!!l.withCredentials),i&&i!=="json"&&(n.responseType=l.responseType),typeof l.onDownloadProgress=="function"&&n.addEventListener("progress",l.onDownloadProgress),typeof l.onUploadProgress=="function"&&n.upload&&n.upload.addEventListener("progress",l.onUploadProgress),(l.cancelToken||l.signal)&&(e=function(h){!n||(c(!h||h&&h.type?new tZ("canceled"):h),n.abort(),n=null)},l.cancelToken&&l.cancelToken.subscribe(e),l.signal&&(l.signal.aborted?e():l.signal.addEventListener("abort",e))),m||(m=null),n.send(m)})},a=W,nl=gl,iZ=dl,eZ={"Content-Type":"application/x-www-form-urlencoded"};function tl(Z,l){!a.isUndefined(Z)&&a.isUndefined(Z["Content-Type"])&&(Z["Content-Type"]=l)}function uZ(){var Z;return(typeof XMLHttpRequest!="undefined"||typeof process!="undefined"&&Object.prototype.toString.call(process)==="[object process]")&&(Z=ml),Z}function XZ(Z,l,d){if(a.isString(Z))try{return(l||JSON.parse)(Z),a.trim(Z)}catch(b){if(b.name!=="SyntaxError")throw b}return(d||JSON.stringify)(Z)}var z={transitional:{silentJSONParsing:!0,forcedJSONParsing:!0,clarifyTimeoutError:!1},adapter:uZ(),transformRequest:[function(l,d){return nl(d,"Accept"),nl(d,"Content-Type"),a.isFormData(l)||a.isArrayBuffer(l)||a.isBuffer(l)||a.isStream(l)||a.isFile(l)||a.isBlob(l)?l:a.isArrayBufferView(l)?l.buffer:a.isURLSearchParams(l)?(tl(d,"application/x-www-form-urlencoded;charset=utf-8"),l.toString()):a.isObject(l)||d&&d["Content-Type"]==="application/json"?(tl(d,"application/json"),XZ(l)):l}],transformResponse:[function(l){var d=this.transitional||z.transitional,b=d&&d.silentJSONParsing,c=d&&d.forcedJSONParsing,m=!b&&this.responseType==="json";if(m||c&&a.isString(l)&&l.length)try{return JSON.parse(l)}catch(t){if(m)throw t.name==="SyntaxError"?iZ(t,this,"E_JSON_PARSE"):t}return l}],timeout:0,xsrfCookieName:"XSRF-TOKEN",xsrfHeaderName:"X-XSRF-TOKEN",maxContentLength:-1,maxBodyLength:-1,validateStatus:function(l){return l>=200&&l<300},headers:{common:{Accept:"application/json, text/plain, */*"}}};a.forEach(["delete","get","head"],function(l){z.headers[l]={}}),a.forEach(["post","put","patch"],function(l){z.headers[l]=a.merge(eZ)});var f=z,aZ=W,WZ=f,oZ=function(l,d,b){var c=this||WZ;return aZ.forEach(b,function(t){l=t.call(c,l,d)}),l},il=function(l){return!!(l&&l.__CANCEL__)},el=W,P=oZ,GZ=il,sZ=f,hZ=L;function j(Z){if(Z.cancelToken&&Z.cancelToken.throwIfRequested(),Z.signal&&Z.signal.aborted)throw new hZ("canceled")}var VZ=function(l){j(l),l.headers=l.headers||{},l.data=P.call(l,l.data,l.headers,l.transformRequest),l.headers=el.merge(l.headers.common||{},l.headers[l.method]||{},l.headers),el.forEach(["delete","get","head","post","put","patch","common"],function(c){delete l.headers[c]});var d=l.adapter||sZ.adapter;return d(l).then(function(c){return j(l),c.data=P.call(l,c.data,c.headers,l.transformResponse),c},function(c){return GZ(c)||(j(l),c&&c.response&&(c.response.data=P.call(l,c.response.data,c.response.headers,l.transformResponse))),Promise.reject(c)})},G=W,ul=function(l,d){d=d||{};var b={};function c(n,u){return G.isPlainObject(n)&&G.isPlainObject(u)?G.merge(n,u):G.isPlainObject(u)?G.merge({},u):G.isArray(u)?u.slice():u}function m(n){if(G.isUndefined(d[n])){if(!G.isUndefined(l[n]))return c(void 0,l[n])}else return c(l[n],d[n])}function t(n){if(!G.isUndefined(d[n]))return c(void 0,d[n])}function i(n){if(G.isUndefined(d[n])){if(!G.isUndefined(l[n]))return c(void 0,l[n])}else return c(void 0,d[n])}function e(n){if(n in d)return c(l[n],d[n]);if(n in l)return c(void 0,l[n])}var X={url:t,method:t,data:t,baseURL:i,transformRequest:i,transformResponse:i,paramsSerializer:i,timeout:i,timeoutMessage:i,withCredentials:i,adapter:i,responseType:i,xsrfCookieName:i,xsrfHeaderName:i,onUploadProgress:i,onDownloadProgress:i,decompress:i,maxContentLength:i,maxBodyLength:i,transport:i,httpAgent:i,httpsAgent:i,cancelToken:i,socketPath:i,responseEncoding:i,validateStatus:e};return G.forEach(Object.keys(l).concat(Object.keys(d)),function(u){var p=X[u]||m,o=p(u);G.isUndefined(o)&&p!==e||(b[u]=o)}),b},Xl={version:"0.25.0"},pZ=Xl.version,M={};["object","boolean","number","function","string","symbol"].forEach(function(Z,l){M[Z]=function(b){return typeof b===Z||"a"+(l<1?"n ":" ")+Z}});var al={};M.transitional=function(l,d,b){function c(m,t){return"[Axios v"+pZ+"] Transitional option '"+m+"'"+t+(b?". "+b:"")}return function(m,t,i){if(l===!1)throw new Error(c(t," has been removed"+(d?" in "+d:"")));return d&&!al[t]&&(al[t]=!0,console.warn(c(t," has been deprecated since v"+d+" and will be removed in the near future"))),l?l(m,t,i):!0}};function yZ(Z,l,d){if(typeof Z!="object")throw new TypeError("options must be an object");for(var b=Object.keys(Z),c=b.length;c-- >0;){var m=b[c],t=l[m];if(t){var i=Z[m],e=i===void 0||t(i,m,Z);if(e!==!0)throw new TypeError("option "+m+" must be "+e);continue}if(d!==!0)throw Error("Unknown option "+m)}}var rZ={assertOptions:yZ,validators:M},Wl=W,RZ=Zl,ol=Bl,Gl=VZ,x=ul,sl=rZ,Y=sl.validators;function N(Z){this.defaults=Z,this.interceptors={request:new ol,response:new ol}}N.prototype.request=function(l,d){if(typeof l=="string"?(d=d||{},d.url=l):d=l||{},!d.url)throw new Error("Provided config url is not valid");d=x(this.defaults,d),d.method?d.method=d.method.toLowerCase():this.defaults.method?d.method=this.defaults.method.toLowerCase():d.method="get";var b=d.transitional;b!==void 0&&sl.assertOptions(b,{silentJSONParsing:Y.transitional(Y.boolean),forcedJSONParsing:Y.transitional(Y.boolean),clarifyTimeoutError:Y.transitional(Y.boolean)},!1);var c=[],m=!0;this.interceptors.request.forEach(function(o){typeof o.runWhen=="function"&&o.runWhen(d)===!1||(m=m&&o.synchronous,c.unshift(o.fulfilled,o.rejected))});var t=[];this.interceptors.response.forEach(function(o){t.push(o.fulfilled,o.rejected)});var i;if(!m){var e=[Gl,void 0];for(Array.prototype.unshift.apply(e,c),e=e.concat(t),i=Promise.resolve(d);e.length;)i=i.then(e.shift(),e.shift());return i}for(var X=d;c.length;){var n=c.shift(),u=c.shift();try{X=n(X)}catch(p){u(p);break}}try{i=Gl(X)}catch(p){return Promise.reject(p)}for(;t.length;)i=i.then(t.shift(),t.shift());return i},N.prototype.getUri=function(l){if(!l.url)throw new Error("Provided config url is not valid");return l=x(this.defaults,l),RZ(l.url,l.params,l.paramsSerializer).replace(/^\?/,"")},Wl.forEach(["delete","get","head","options"],function(l){N.prototype[l]=function(d,b){return this.request(x(b||{},{method:l,url:d,data:(b||{}).data}))}}),Wl.forEach(["post","put","patch"],function(l){N.prototype[l]=function(d,b,c){return this.request(x(c||{},{method:l,url:d,data:b}))}});var YZ=N,JZ=L;function J(Z){if(typeof Z!="function")throw new TypeError("executor must be a function.");var l;this.promise=new Promise(function(c){l=c});var d=this;this.promise.then(function(b){if(!!d._listeners){var c,m=d._listeners.length;for(c=0;c<m;c++)d._listeners[c](b);d._listeners=null}}),this.promise.then=function(b){var c,m=new Promise(function(t){d.subscribe(t),c=t}).then(b);return m.cancel=function(){d.unsubscribe(c)},m},Z(function(c){d.reason||(d.reason=new JZ(c),l(d.reason))})}J.prototype.throwIfRequested=function(){if(this.reason)throw this.reason},J.prototype.subscribe=function(l){if(this.reason){l(this.reason);return}this._listeners?this._listeners.push(l):this._listeners=[l]},J.prototype.unsubscribe=function(l){if(!!this._listeners){var d=this._listeners.indexOf(l);d!==-1&&this._listeners.splice(d,1)}},J.source=function(){var l,d=new J(function(c){l=c});return{token:d,cancel:l}};var IZ=J,KZ=function(l){return function(b){return l.apply(null,b)}},NZ=W,HZ=function(l){return NZ.isObject(l)&&l.isAxiosError===!0},hl=W,SZ=A,C=YZ,vZ=ul,LZ=f;function Vl(Z){var l=new C(Z),d=SZ(C.prototype.request,l);return hl.extend(d,C.prototype,l),hl.extend(d,l),d.create=function(c){return Vl(vZ(Z,c))},d}var V=Vl(LZ);V.Axios=C,V.Cancel=L,V.CancelToken=IZ,V.isCancel=il,V.VERSION=Xl.version,V.all=function(l){return Promise.all(l)},V.spread=KZ,V.isAxiosError=HZ,D.exports=V,D.exports.default=V;for(var FZ=[],E=0;E<256;++E)FZ.push((E+256).toString(16).substr(1));class zZ{constructor(){this.processor_=null,this.generator_=null}init(l){return new Promise((d,b)=>{try{this.processor_=new MediaStreamTrackProcessor(l)}catch(c){console.log(`[InsertableStreamHelper] MediaStreamTrackProcessor failed: ${c}`),b(c)}try{l.kind==="audio"?this.generator_=new MediaStreamTrackGenerator({kind:"audio"}):l.kind==="video"?this.generator_=new MediaStreamTrackGenerator({kind:"video"}):b("kind not supported")}catch(c){console.log(`[InsertableStreamHelper] MediaStreamTrackGenerator failed: ${c}`),b(c)}d()})}getReadable(){return this.processor_.readable}getWriteable(){return this.generator_.writable}getProccesorTrack(){return this.generator_}}class fZ{constructor(l){this.insertableStreamHelper_=new zZ,this.mediaProcessor_=l}setTrack(l){return new Promise((d,b)=>{this.insertableStreamHelper_.init(l).then(()=>{this.mediaProcessor_.transform(this.insertableStreamHelper_.getReadable(),this.insertableStreamHelper_.getWriteable()).then(()=>{d(this.insertableStreamHelper_.getProccesorTrack())}).catch(c=>{b(c)})}).catch(c=>{b(c)})})}destroy(){return new Promise((l,d)=>{this.mediaProcessor_?this.mediaProcessor_.destroy().then(()=>{l()}).catch(b=>{d(b)}):d("no processor")})}}const pl="(function(){"use strict";class D{}D.updates={transformer_new:"New transformer",transformer_null:"Null transformer"},D.errors={transformer_none:"No transformers provided",transformer_start:"Cannot start transformer",transformer_transform:"Cannot transform frame",transformer_flush:"Cannot flush transformer"};var _e={exports:{}},xe=function(e,t){return function(){for(var s=new Array(arguments.length),a=0;a<s.length;a++)s[a]=arguments[a];return e.apply(t,s)}},mt=xe,k=Object.prototype.toString;function ge(r){return Array.isArray(r)}function ve(r){return typeof r=="undefined"}function _t(r){return r!==null&&!ve(r)&&r.constructor!==null&&!ve(r.constructor)&&typeof r.constructor.isBuffer=="function"&&r.constructor.isBuffer(r)}function Ne(r){return k.call(r)==="[object ArrayBuffer]"}function gt(r){return k.call(r)==="[object FormData]"}function vt(r){var e;return typeof ArrayBuffer!="undefined"&&ArrayBuffer.isView?e=ArrayBuffer.isView(r):e=r&&r.buffer&&Ne(r.buffer),e}function yt(r){return typeof r=="string"}function wt(r){return typeof r=="number"}function Le(r){return r!==null&&typeof r=="object"}function K(r){if(k.call(r)!=="[object Object]")return!1;var e=Object.getPrototypeOf(r);return e===null||e===Object.prototype}function Ct(r){return k.call(r)==="[object Date]"}function bt(r){return k.call(r)==="[object File]"}function Tt(r){return k.call(r)==="[object Blob]"}function Ue(r){return k.call(r)==="[object Function]"}function Et(r){return Le(r)&&Ue(r.pipe)}function Rt(r){return k.call(r)==="[object URLSearchParams]"}function Pt(r){return r.trim?r.trim():r.replace(/^\s+|\s+$/g,"")}function Ot(){return typeof navigator!="undefined"&&(navigator.product==="ReactNative"||navigator.product==="NativeScript"||navigator.product==="NS")?!1:typeof window!="undefined"&&typeof document!="undefined"}function ye(r,e){if(!(r===null||typeof r=="undefined"))if(typeof r!="object"&&(r=[r]),ge(r))for(var t=0,n=r.length;t<n;t++)e.call(null,r[t],t,r);else for(var s in r)Object.prototype.hasOwnProperty.call(r,s)&&e.call(null,r[s],s,r)}function we(){var r={};function e(s,a){K(r[a])&&K(s)?r[a]=we(r[a],s):K(s)?r[a]=we({},s):ge(s)?r[a]=s.slice():r[a]=s}for(var t=0,n=arguments.length;t<n;t++)ye(arguments[t],e);return r}function St(r,e,t){return ye(e,function(s,a){t&&typeof s=="function"?r[a]=mt(s,t):r[a]=s}),r}function It(r){return r.charCodeAt(0)===65279&&(r=r.slice(1)),r}var P={isArray:ge,isArrayBuffer:Ne,isBuffer:_t,isFormData:gt,isArrayBufferView:vt,isString:yt,isNumber:wt,isObject:Le,isPlainObject:K,isUndefined:ve,isDate:Ct,isFile:bt,isBlob:Tt,isFunction:Ue,isStream:Et,isURLSearchParams:Rt,isStandardBrowserEnv:Ot,forEach:ye,merge:we,extend:St,trim:Pt,stripBOM:It},W=P;function Be(r){return encodeURIComponent(r).replace(/%3A/gi,":").replace(/%24/g,"$").replace(/%2C/gi,",").replace(/%20/g,"+").replace(/%5B/gi,"[").replace(/%5D/gi,"]")}var ke=function(e,t,n){if(!t)return e;var s;if(n)s=n(t);else if(W.isURLSearchParams(t))s=t.toString();else{var a=[];W.forEach(t,function(h,g){h===null||typeof h=="undefined"||(W.isArray(h)?g=g+"[]":h=[h],W.forEach(h,function(p){W.isDate(p)?p=p.toISOString():W.isObject(p)&&(p=JSON.stringify(p)),a.push(Be(g)+"="+Be(p))}))}),s=a.join("&")}if(s){var f=e.indexOf("#");f!==-1&&(e=e.slice(0,f)),e+=(e.indexOf("?")===-1?"?":"&")+s}return e},Mt=P;function Y(){this.handlers=[]}Y.prototype.use=function(e,t,n){return this.handlers.push({fulfilled:e,rejected:t,synchronous:n?n.synchronous:!1,runWhen:n?n.runWhen:null}),this.handlers.length-1},Y.prototype.eject=function(e){this.handlers[e]&&(this.handlers[e]=null)},Y.prototype.forEach=function(e){Mt.forEach(this.handlers,function(n){n!==null&&e(n)})};var At=Y,Ft=P,xt=function(e,t){Ft.forEach(e,function(s,a){a!==t&&a.toUpperCase()===t.toUpperCase()&&(e[t]=s,delete e[a])})},He=function(e,t,n,s,a){return e.config=t,n&&(e.code=n),e.request=s,e.response=a,e.isAxiosError=!0,e.toJSON=function(){return{message:this.message,name:this.name,description:this.description,number:this.number,fileName:this.fileName,lineNumber:this.lineNumber,columnNumber:this.columnNumber,stack:this.stack,config:this.config,code:this.code,status:this.response&&this.response.status?this.response.status:null}},e},Nt=He,De=function(e,t,n,s,a){var f=new Error(e);return Nt(f,t,n,s,a)},Lt=De,Ut=function(e,t,n){var s=n.config.validateStatus;!n.status||!s||s(n.status)?e(n):t(Lt("Request failed with status code "+n.status,n.config,null,n.request,n))},Z=P,Bt=Z.isStandardBrowserEnv()?function(){return{write:function(t,n,s,a,f,l){var h=[];h.push(t+"="+encodeURIComponent(n)),Z.isNumber(s)&&h.push("expires="+new Date(s).toGMTString()),Z.isString(a)&&h.push("path="+a),Z.isString(f)&&h.push("domain="+f),l===!0&&h.push("secure"),document.cookie=h.join("; ")},read:function(t){var n=document.cookie.match(new RegExp("(^|;\\s*)("+t+")=([^;]*)"));return n?decodeURIComponent(n[3]):null},remove:function(t){this.write(t,"",Date.now()-864e5)}}}():function(){return{write:function(){},read:function(){return null},remove:function(){}}}(),kt=function(e){return/^([a-z][a-z\d+\-.]*:)?\/\//i.test(e)},Ht=function(e,t){return t?e.replace(/\/+$/,"")+"/"+t.replace(/^\/+/,""):e},Dt=kt,$t=Ht,Wt=function(e,t){return e&&!Dt(t)?$t(e,t):t},Ce=P,qt=["age","authorization","content-length","content-type","etag","expires","from","host","if-modified-since","if-unmodified-since","last-modified","location","max-forwards","proxy-authorization","referer","retry-after","user-agent"],jt=function(e){var t={},n,s,a;return e&&Ce.forEach(e.split(`
`),function(l){if(a=l.indexOf(":"),n=Ce.trim(l.substr(0,a)).toLowerCase(),s=Ce.trim(l.substr(a+1)),n){if(t[n]&&qt.indexOf(n)>=0)return;n==="set-cookie"?t[n]=(t[n]?t[n]:[]).concat([s]):t[n]=t[n]?t[n]+", "+s:s}}),t},$e=P,Vt=$e.isStandardBrowserEnv()?function(){var e=/(msie|trident)/i.test(navigator.userAgent),t=document.createElement("a"),n;function s(a){var f=a;return e&&(t.setAttribute("href",f),f=t.href),t.setAttribute("href",f),{href:t.href,protocol:t.protocol?t.protocol.replace(/:$/,""):"",host:t.host,search:t.search?t.search.replace(/^\?/,""):"",hash:t.hash?t.hash.replace(/^#/,""):"",hostname:t.hostname,port:t.port,pathname:t.pathname.charAt(0)==="/"?t.pathname:"/"+t.pathname}}return n=s(window.location.href),function(f){var l=$e.isString(f)?s(f):f;return l.protocol===n.protocol&&l.host===n.host}}():function(){return function(){return!0}}();function be(r){this.message=r}be.prototype.toString=function(){return"Cancel"+(this.message?": "+this.message:"")},be.prototype.__CANCEL__=!0;var ee=be,te=P,zt=Ut,Gt=Bt,Jt=ke,Qt=Wt,Xt=jt,Kt=Vt,Te=De,Yt=ne,Zt=ee,We=function(e){return new Promise(function(n,s){var a=e.data,f=e.headers,l=e.responseType,h;function g(){e.cancelToken&&e.cancelToken.unsubscribe(h),e.signal&&e.signal.removeEventListener("abort",h)}te.isFormData(a)&&delete f["Content-Type"];var o=new XMLHttpRequest;if(e.auth){var p=e.auth.username||"",R=e.auth.password?unescape(encodeURIComponent(e.auth.password)):"";f.Authorization="Basic "+btoa(p+":"+R)}var y=Qt(e.baseURL,e.url);o.open(e.method.toUpperCase(),Jt(y,e.params,e.paramsSerializer),!0),o.timeout=e.timeout;function S(){if(!!o){var T="getAllResponseHeaders"in o?Xt(o.getAllResponseHeaders()):null,M=!l||l==="text"||l==="json"?o.responseText:o.response,A={data:M,status:o.status,statusText:o.statusText,headers:T,config:e,request:o};zt(function(z){n(z),g()},function(z){s(z),g()},A),o=null}}if("onloadend"in o?o.onloadend=S:o.onreadystatechange=function(){!o||o.readyState!==4||o.status===0&&!(o.responseURL&&o.responseURL.indexOf("file:")===0)||setTimeout(S)},o.onabort=function(){!o||(s(Te("Request aborted",e,"ECONNABORTED",o)),o=null)},o.onerror=function(){s(Te("Network Error",e,null,o)),o=null},o.ontimeout=function(){var M=e.timeout?"timeout of "+e.timeout+"ms exceeded":"timeout exceeded",A=e.transitional||Yt.transitional;e.timeoutErrorMessage&&(M=e.timeoutErrorMessage),s(Te(M,e,A.clarifyTimeoutError?"ETIMEDOUT":"ECONNABORTED",o)),o=null},te.isStandardBrowserEnv()){var I=(e.withCredentials||Kt(y))&&e.xsrfCookieName?Gt.read(e.xsrfCookieName):void 0;I&&(f[e.xsrfHeaderName]=I)}"setRequestHeader"in o&&te.forEach(f,function(M,A){typeof a=="undefined"&&A.toLowerCase()==="content-type"?delete f[A]:o.setRequestHeader(A,M)}),te.isUndefined(e.withCredentials)||(o.withCredentials=!!e.withCredentials),l&&l!=="json"&&(o.responseType=e.responseType),typeof e.onDownloadProgress=="function"&&o.addEventListener("progress",e.onDownloadProgress),typeof e.onUploadProgress=="function"&&o.upload&&o.upload.addEventListener("progress",e.onUploadProgress),(e.cancelToken||e.signal)&&(h=function(T){!o||(s(!T||T&&T.type?new Zt("canceled"):T),o.abort(),o=null)},e.cancelToken&&e.cancelToken.subscribe(h),e.signal&&(e.signal.aborted?h():e.signal.addEventListener("abort",h))),a||(a=null),o.send(a)})},w=P,qe=xt,er=He,tr={"Content-Type":"application/x-www-form-urlencoded"};function je(r,e){!w.isUndefined(r)&&w.isUndefined(r["Content-Type"])&&(r["Content-Type"]=e)}function rr(){var r;return(typeof XMLHttpRequest!="undefined"||typeof process!="undefined"&&Object.prototype.toString.call(process)==="[object process]")&&(r=We),r}function nr(r,e,t){if(w.isString(r))try{return(e||JSON.parse)(r),w.trim(r)}catch(n){if(n.name!=="SyntaxError")throw n}return(t||JSON.stringify)(r)}var re={transitional:{silentJSONParsing:!0,forcedJSONParsing:!0,clarifyTimeoutError:!1},adapter:rr(),transformRequest:[function(e,t){return qe(t,"Accept"),qe(t,"Content-Type"),w.isFormData(e)||w.isArrayBuffer(e)||w.isBuffer(e)||w.isStream(e)||w.isFile(e)||w.isBlob(e)?e:w.isArrayBufferView(e)?e.buffer:w.isURLSearchParams(e)?(je(t,"application/x-www-form-urlencoded;charset=utf-8"),e.toString()):w.isObject(e)||t&&t["Content-Type"]==="application/json"?(je(t,"application/json"),nr(e)):e}],transformResponse:[function(e){var t=this.transitional||re.transitional,n=t&&t.silentJSONParsing,s=t&&t.forcedJSONParsing,a=!n&&this.responseType==="json";if(a||s&&w.isString(e)&&e.length)try{return JSON.parse(e)}catch(f){if(a)throw f.name==="SyntaxError"?er(f,this,"E_JSON_PARSE"):f}return e}],timeout:0,xsrfCookieName:"XSRF-TOKEN",xsrfHeaderName:"X-XSRF-TOKEN",maxContentLength:-1,maxBodyLength:-1,validateStatus:function(e){return e>=200&&e<300},headers:{common:{Accept:"application/json, text/plain, */*"}}};w.forEach(["delete","get","head"],function(e){re.headers[e]={}}),w.forEach(["post","put","patch"],function(e){re.headers[e]=w.merge(tr)});var ne=re,sr=P,ir=ne,or=function(e,t,n){var s=this||ir;return sr.forEach(n,function(f){e=f.call(s,e,t)}),e},Ve=function(e){return!!(e&&e.__CANCEL__)},ze=P,Ee=or,ar=Ve,ur=ne,fr=ee;function Re(r){if(r.cancelToken&&r.cancelToken.throwIfRequested(),r.signal&&r.signal.aborted)throw new fr("canceled")}var lr=function(e){Re(e),e.headers=e.headers||{},e.data=Ee.call(e,e.data,e.headers,e.transformRequest),e.headers=ze.merge(e.headers.common||{},e.headers[e.method]||{},e.headers),ze.forEach(["delete","get","head","post","put","patch","common"],function(s){delete e.headers[s]});var t=e.adapter||ur.adapter;return t(e).then(function(s){return Re(e),s.data=Ee.call(e,s.data,s.headers,e.transformResponse),s},function(s){return ar(s)||(Re(e),s&&s.response&&(s.response.data=Ee.call(e,s.response.data,s.response.headers,e.transformResponse))),Promise.reject(s)})},O=P,Ge=function(e,t){t=t||{};var n={};function s(o,p){return O.isPlainObject(o)&&O.isPlainObject(p)?O.merge(o,p):O.isPlainObject(p)?O.merge({},p):O.isArray(p)?p.slice():p}function a(o){if(O.isUndefined(t[o])){if(!O.isUndefined(e[o]))return s(void 0,e[o])}else return s(e[o],t[o])}function f(o){if(!O.isUndefined(t[o]))return s(void 0,t[o])}function l(o){if(O.isUndefined(t[o])){if(!O.isUndefined(e[o]))return s(void 0,e[o])}else return s(void 0,t[o])}function h(o){if(o in t)return s(e[o],t[o]);if(o in e)return s(void 0,e[o])}var g={url:f,method:f,data:f,baseURL:l,transformRequest:l,transformResponse:l,paramsSerializer:l,timeout:l,timeoutMessage:l,withCredentials:l,adapter:l,responseType:l,xsrfCookieName:l,xsrfHeaderName:l,onUploadProgress:l,onDownloadProgress:l,decompress:l,maxContentLength:l,maxBodyLength:l,transport:l,httpAgent:l,httpsAgent:l,cancelToken:l,socketPath:l,responseEncoding:l,validateStatus:h};return O.forEach(Object.keys(e).concat(Object.keys(t)),function(p){var R=g[p]||a,y=R(p);O.isUndefined(y)&&R!==h||(n[p]=y)}),n},Je={version:"0.25.0"},cr=Je.version,Pe={};["object","boolean","number","function","string","symbol"].forEach(function(r,e){Pe[r]=function(n){return typeof n===r||"a"+(e<1?"n ":" ")+r}});var Qe={};Pe.transitional=function(e,t,n){function s(a,f){return"[Axios v"+cr+"] Transitional option '"+a+"'"+f+(n?". "+n:"")}return function(a,f,l){if(e===!1)throw new Error(s(f," has been removed"+(t?" in "+t:"")));return t&&!Qe[f]&&(Qe[f]=!0,console.warn(s(f," has been deprecated since v"+t+" and will be removed in the near future"))),e?e(a,f,l):!0}};function hr(r,e,t){if(typeof r!="object")throw new TypeError("options must be an object");for(var n=Object.keys(r),s=n.length;s-- >0;){var a=n[s],f=e[a];if(f){var l=r[a],h=l===void 0||f(l,a,r);if(h!==!0)throw new TypeError("option "+a+" must be "+h);continue}if(t!==!0)throw Error("Unknown option "+a)}}var dr={assertOptions:hr,validators:Pe},Xe=P,pr=ke,Ke=At,Ye=lr,se=Ge,Ze=dr,q=Ze.validators;function G(r){this.defaults=r,this.interceptors={request:new Ke,response:new Ke}}G.prototype.request=function(e,t){if(typeof e=="string"?(t=t||{},t.url=e):t=e||{},!t.url)throw new Error("Provided config url is not valid");t=se(this.defaults,t),t.method?t.method=t.method.toLowerCase():this.defaults.method?t.method=this.defaults.method.toLowerCase():t.method="get";var n=t.transitional;n!==void 0&&Ze.assertOptions(n,{silentJSONParsing:q.transitional(q.boolean),forcedJSONParsing:q.transitional(q.boolean),clarifyTimeoutError:q.transitional(q.boolean)},!1);var s=[],a=!0;this.interceptors.request.forEach(function(y){typeof y.runWhen=="function"&&y.runWhen(t)===!1||(a=a&&y.synchronous,s.unshift(y.fulfilled,y.rejected))});var f=[];this.interceptors.response.forEach(function(y){f.push(y.fulfilled,y.rejected)});var l;if(!a){var h=[Ye,void 0];for(Array.prototype.unshift.apply(h,s),h=h.concat(f),l=Promise.resolve(t);h.length;)l=l.then(h.shift(),h.shift());return l}for(var g=t;s.length;){var o=s.shift(),p=s.shift();try{g=o(g)}catch(R){p(R);break}}try{l=Ye(g)}catch(R){return Promise.reject(R)}for(;f.length;)l=l.then(f.shift(),f.shift());return l},G.prototype.getUri=function(e){if(!e.url)throw new Error("Provided config url is not valid");return e=se(this.defaults,e),pr(e.url,e.params,e.paramsSerializer).replace(/^\?/,"")},Xe.forEach(["delete","get","head","options"],function(e){G.prototype[e]=function(t,n){return this.request(se(n||{},{method:e,url:t,data:(n||{}).data}))}}),Xe.forEach(["post","put","patch"],function(e){G.prototype[e]=function(t,n,s){return this.request(se(s||{},{method:e,url:t,data:n}))}});var mr=G,_r=ee;function j(r){if(typeof r!="function")throw new TypeError("executor must be a function.");var e;this.promise=new Promise(function(s){e=s});var t=this;this.promise.then(function(n){if(!!t._listeners){var s,a=t._listeners.length;for(s=0;s<a;s++)t._listeners[s](n);t._listeners=null}}),this.promise.then=function(n){var s,a=new Promise(function(f){t.subscribe(f),s=f}).then(n);return a.cancel=function(){t.unsubscribe(s)},a},r(function(s){t.reason||(t.reason=new _r(s),e(t.reason))})}j.prototype.throwIfRequested=function(){if(this.reason)throw this.reason},j.prototype.subscribe=function(e){if(this.reason){e(this.reason);return}this._listeners?this._listeners.push(e):this._listeners=[e]},j.prototype.unsubscribe=function(e){if(!!this._listeners){var t=this._listeners.indexOf(e);t!==-1&&this._listeners.splice(t,1)}},j.source=function(){var e,t=new j(function(s){e=s});return{token:t,cancel:e}};var gr=j,vr=function(e){return function(n){return e.apply(null,n)}},yr=P,wr=function(e){return yr.isObject(e)&&e.isAxiosError===!0},et=P,Cr=xe,ie=mr,br=Ge,Tr=ne;function tt(r){var e=new ie(r),t=Cr(ie.prototype.request,e);return et.extend(t,ie.prototype,e),et.extend(t,e),t.create=function(s){return tt(br(r,s))},t}var N=tt(Tr);N.Axios=ie,N.Cancel=ee,N.CancelToken=gr,N.isCancel=Ve,N.VERSION=Je.version,N.all=function(e){return Promise.all(e)},N.spread=vr,N.isAxiosError=wr,_e.exports=N,_e.exports.default=N;var Er=_e.exports;class d{isEmpty(){return!this.isPresent()}static of(e){if(e!=null)return new rt(e);throw new TypeError("The passed value was null or undefined.")}static ofNonNull(e){return d.of(e)}static ofNullable(e){return e!=null?new rt(e):new nt}static empty(){return new nt}static from(e){switch(e.kind){case"present":return d.of(e.value);case"empty":return d.empty();default:throw new TypeError("The passed value was not an Option type.")}}}class rt extends d{constructor(e){super();this.payload=e}isPresent(){return!0}get(){return this.payload}ifPresent(e){e(this.payload)}ifPresentOrElse(e,t){e(this.payload)}filter(e){return e(this.payload)?this:d.empty()}map(e){const t=e(this.payload);return d.ofNullable(t)}flatMap(e){return e(this.payload)}or(e){return this}orElse(e){return this.payload}orElseGet(e){return this.payload}orElseThrow(e){return this.payload}orNull(){return this.payload}orUndefined(){return this.payload}toOption(){return{kind:"present",value:this.payload}}matches(e){return e.present(this.payload)}toJSON(e){return this.payload}}class nt extends d{isPresent(){return!1}constructor(){super()}get(){throw new TypeError("The optional is not present.")}ifPresent(e){}ifPresentOrElse(e,t){t()}filter(e){return this}map(e){return d.empty()}flatMap(e){return d.empty()}or(e){return e()}orElse(e){return e}orElseGet(e){return this.orElse(e())}orElseThrow(e){throw e()}orNull(){return null}orUndefined(){}toOption(){return{kind:"empty"}}matches(e){return e.empty()}toJSON(e){return null}}const Rr="1.0.1";class L{constructor(){this._report={action:d.empty(),applicationId:d.ofNullable(null),timestamp:Date.now(),fps:d.empty(),framesTransformed:d.empty(),guid:d.empty(),highestFrameTransformCpu:d.empty(),message:d.empty(),source:d.ofNullable(null),transformedFps:d.empty(),transformerType:d.empty(),variation:d.empty(),videoHeight:d.empty(),videoWidth:d.empty(),version:Rr}}action(e){return this._report.action=d.ofNullable(e),this}framesTransformed(e){return this._report.framesTransformed=d.ofNullable(e),this}fps(e){return this._report.fps=d.ofNullable(e),this}guid(e){return this._report.guid=d.ofNullable(e),this}message(e){return this._report.message=d.ofNullable(e),this}transformedFps(e){return this._report.transformedFps=d.ofNullable(e),this}transformerType(e){return this._report.transformerType=d.ofNullable(e),this}variation(e){return this._report.variation=d.ofNullable(e),this}videoHeight(e){return this._report.videoHeight=d.ofNullable(e),this}videoWidth(e){return this._report.videoWidth=d.ofNullable(e),this}build(){return this._report}}const Pr=r=>JSON.stringify(r,(e,t)=>{if(t!==null)return t});class U{static report(e){return new Promise((t,n)=>{let s=Er.create(),a={timeout:1e4,timeoutErrorMessage:"Request timeout",headers:{"Content-Type":"application/json"}};const f="https://hlg.dev.tokbox.com/dev/logging/vcp_webrtc";s.post(f,Pr(e),a).then(l=>{console.log(l),t("success")}).catch(l=>{console.log(l),n(l)})})}}var oe,Or=new Uint8Array(16);function Sr(){if(!oe&&(oe=typeof crypto!="undefined"&&crypto.getRandomValues&&crypto.getRandomValues.bind(crypto)||typeof msCrypto!="undefined"&&typeof msCrypto.getRandomValues=="function"&&msCrypto.getRandomValues.bind(msCrypto),!oe))throw new Error("crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported");return oe(Or)}var Ir=/^(?:[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}|00000000-0000-0000-0000-000000000000)$/i;function Mr(r){return typeof r=="string"&&Ir.test(r)}for(var C=[],Oe=0;Oe<256;++Oe)C.push((Oe+256).toString(16).substr(1));function Ar(r){var e=arguments.length>1&&arguments[1]!==void 0?arguments[1]:0,t=(C[r[e+0]]+C[r[e+1]]+C[r[e+2]]+C[r[e+3]]+"-"+C[r[e+4]]+C[r[e+5]]+"-"+C[r[e+6]]+C[r[e+7]]+"-"+C[r[e+8]]+C[r[e+9]]+"-"+C[r[e+10]]+C[r[e+11]]+C[r[e+12]]+C[r[e+13]]+C[r[e+14]]+C[r[e+15]]).toLowerCase();if(!Mr(t))throw TypeError("Stringified UUID is invalid");return t}function st(r,e,t){r=r||{};var n=r.random||(r.rng||Sr)();if(n[6]=n[6]&15|64,n[8]=n[8]&63|128,e){t=t||0;for(var s=0;s<16;++s)e[t+s]=n[s];return e}return Ar(n)}const Fr=500;class xr{constructor(e){this.uuid_=st(),this.framesTransformed_=0,this.transformer_=e,this.shouldStop_=!1,this.isFlashed_=!1,this.framesFromSource_=0,this.fps_=0,this.mediaTransformerQosReportStartTimestamp_=0,this.videoHeight_=0,this.videoWidth_=0,this.transformerType_="Custom","getTransformerType"in e&&(this.transformerType_=e.getTransformerType());const t=new L().action("MediaTransformer").guid(this.uuid_).transformerType(this.transformerType_).variation("Create").build();U.report(t)}async start(e){if(this.transformer_&&typeof this.transformer_.start=="function")try{await this.transformer_.start(e)}catch{const n=new L().action("MediaTransformer").guid(this.uuid_).message(D.errors.transformer_start).transformerType(this.transformerType_).variation("Error").build();U.report(n)}}async transform(e,t){var n,s,a,f;if(this.mediaTransformerQosReportStartTimestamp_===0&&(this.mediaTransformerQosReportStartTimestamp_=Date.now()),this.videoHeight_=(n=e==null?void 0:e.displayHeight)!=null?n:0,this.videoWidth_=(s=e==null?void 0:e.displayWidth)!=null?s:0,++this.framesFromSource_,this.transformer_)if(this.shouldStop_)e.close(),this.flush(t),t.terminate();else try{await((f=(a=this.transformer_).transform)==null?void 0:f.call(a,e,t)),++this.framesTransformed_,this.framesTransformed_===Fr&&this.mediaTransformerQosReport()}catch{const h=new L().action("MediaTransformer").guid(this.uuid_).message(D.errors.transformer_transform).transformerType(this.transformerType_).variation("Error").build();U.report(h)}}async flush(e){if(this.transformer_&&typeof this.transformer_.flush=="function"&&!this.isFlashed_){this.isFlashed_=!0;try{await this.transformer_.flush(e)}catch{const s=new L().action("MediaTransformer").guid(this.uuid_).message(D.errors.transformer_transform).transformerType(this.transformerType_).variation("Error").build();U.report(s)}}this.mediaTransformerQosReport();const t=new L().action("MediaTransformer").guid(this.uuid_).transformerType(this.transformerType_).variation("Delete").build();U.report(t)}stop(){console.log("[Pipeline] Stop stream."),this.shouldStop_=!0}mediaTransformerQosReport(){let e=(Date.now()-this.mediaTransformerQosReportStartTimestamp_)/1e3,t=this.framesFromSource_/e,n=this.framesTransformed_/e;const s=new L().action("MediaTransformer").fps(t).transformedFps(n).framesTransformed(this.framesTransformed_).guid(this.uuid_).transformerType(this.transformerType_).videoHeight(this.videoHeight_).videoWidth(this.videoWidth_).variation("QoS").build();U.report(s),this.mediaTransformerQosReportStartTimestamp_=0,this.framesFromSource_=0,this.framesTransformed_=0}}class Nr{constructor(e){this.transformers_=[];for(let t of e)this.transformers_.push(new xr(t))}async start(e,t){if(!this.transformers_||this.transformers_.length===0){console.log("[Pipeline] No transformers.");return}try{let n=e;for(let s of this.transformers_)e=e.pipeThrough(new TransformStream(s));e.pipeTo(t).then(async()=>{console.log("[Pipeline] Setup."),await t.abort(),await n.cancel()}).catch(async s=>{e.cancel().then(()=>{console.log("[Pipeline] Shutting down streams after abort.")}).catch(a=>{console.error("[Pipeline] Error from stream transform:",a)}),await t.abort(s),await n.cancel(s)})}catch{this.destroy();return}console.log("[Pipeline] Pipeline started.")}async destroy(){console.log("[Pipeline] Destroying Pipeline.");for(let e of this.transformers_)e.stop()}}class Lr{constructor(){this.uuid_=st();const e=new L().action("MediaProcessor").guid(this.uuid_).variation("Create").build();U.report(e)}transform(e,t){return this.readable_=e,this.writable_=t,this.transformInternal()}transformInternal(){return new Promise((e,t)=>{if(!this.transformers_||this.transformers_.length===0){const n=new L().action("MediaProcessor").guid(this.uuid_).message(D.errors.transformer_none).variation("Error").build();U.report(n),t("[MediaProcessor] Need to set transformers.")}this.pipeline_&&this.pipeline_.destroy(),this.pipeline_=new Nr(this.transformers_),this.pipeline_.start(this.readable_,this.writable_).then(()=>{e()}).catch(n=>{t(n)})})}setTransformers(e){const t=new L().action("MediaProcessor").guid(this.uuid_).message(D.updates.transformer_new).variation("Update").build();return U.report(t),this.transformers_=e,this.readable_&&this.writable_?this.transformInternal():Promise.resolve()}destroy(){return new Promise(e=>{this.pipeline_&&this.pipeline_.destroy();const t=new L().action("MediaProcessor").guid(this.uuid_).variation("Delete").build();U.report(t),e()})}}var ae;(function(r){r.Low="Low",r.High="High"})(ae||(ae={}));class it{constructor(e){this.blurFilter_=e===ae.High?"blur(15px)":"blur(5px)"}runPostProcessing(e,t){try{e.globalCompositeOperation="destination-over",e.filter=this.blurFilter_,e.drawImage(t,0,0,t.width,t.height)}catch(n){console.log("[BlurPostProcess] Failed to draw canvas",n)}}}class Ur{constructor(e){if(this.imageCanvas_=new OffscreenCanvas(1,1),this.imageCtx_=this.imageCanvas_.getContext("2d",{alpha:!1,willReadFrequently:!0,desynchronized:!0}),!this.imageCtx_)throw new Error("Unable to create OffscreenCanvasRenderingContext2D");this.imageBlob_=void 0,fetch(e).then(t=>{t.blob().then(n=>{this.imageBlob_=n}).catch(n=>{console.error("blob error",n)})}).catch(t=>{console.error("fetch error",t)})}runPostProcessing(e,t){try{if(typeof this.imageBlob_!="undefined"&&(this.imageCanvas_.width!=t.width||this.imageCanvas_.height!=t.height)){this.imageCanvas_.width=t.width,this.imageCanvas_.height=t.height;const n="high",s={resizeWidth:t.width,resizeHeight:t.height,resizeQuality:n},a=createImageBitmap(this.imageBlob_,s).then(f=>{this.imageCtx_.drawImage(f,0,0)}).catch(f=>{console.error("error createImageBitmap",f)})}e.globalCompositeOperation="destination-over",e.drawImage(this.imageCanvas_,0,0,this.imageCanvas_.width,this.imageCanvas_.height)}catch(n){console.log("[VirtualPostProcess] Failed to draw canvas",n)}}}class Br{constructor(e=1/0){this.capacity=e,this.storage=[]}enqueue(e){if(this.size()===this.capacity)throw Error("Queue has reached max capacity, you cannot add more items");this.storage.push(e)}dequeue(){return this.storage.shift()}size(){return this.storage.length}}class kr{constructor(e){console.log("[VideoPostProcess] Ctor"),this.queue_=new Br,e&&(this.frameReader_=e.getReader(),this.frameReader_.read().then(this.processFrame.bind(this)).catch(t=>console.error(t)))}processFrame(e){e.done||(this.queue_.enqueue(e.value),this.frameReader_.read().then(this.processFrame.bind(this)).catch(t=>console.error(t)))}runPostProcessing(e,t){try{if(e.globalCompositeOperation="destination-over",this.queue_.size()>0){const n=this.queue_.dequeue();e.drawImage(n,0,0,t.width,t.height),n.close()}else e.drawImage(t,0,0,t.width,t.height)}catch(n){console.log("[VideoPostProcess] Failed to draw canvas",n)}}}function Hr(){return"selfie_segmentation_landscape"}var ue=function(){var r=typeof document!="undefined"&&document.currentScript?document.currentScript.src:void 0;return function(e){e=e||{};var t=typeof e!="undefined"?e:{},n,s;t.ready=new Promise(function(i,u){n=i,s=u});var a={},f;for(f in t)t.hasOwnProperty(f)&&(a[f]=t[f]);var l="./this.program",h=function(i,u){throw u},g=!0,o="";function p(i){return t.locateFile?t.locateFile(i,o):o+i}var R;typeof document!="undefined"&&document.currentScript&&(o=document.currentScript.src),r&&(o=r),o.indexOf("blob:")!==0?o=o.substr(0,o.replace(/[?#].*/,"").lastIndexOf("/")+1):o="";var y=t.print||console.log.bind(console),S=t.printErr||console.warn.bind(console);for(f in a)a.hasOwnProperty(f)&&(t[f]=a[f]);a=null,t.arguments,t.thisProgram&&(l=t.thisProgram),t.quit&&(h=t.quit);var I;t.wasmBinary&&(I=t.wasmBinary);var T=t.noExitRuntime||!0;typeof WebAssembly!="object"&&H("no native wasm support detected");var M,A=!1,fe=typeof TextDecoder!="undefined"?new TextDecoder("utf8"):void 0;function z(i,u,c){for(var m=u+c,v=u;i[v]&&!(v>=m);)++v;if(v-u>16&&i.subarray&&fe)return fe.decode(i.subarray(u,v));for(var b="";u<v;){var _=i[u++];if(!(_&128)){b+=String.fromCharCode(_);continue}var E=i[u++]&63;if((_&224)==192){b+=String.fromCharCode((_&31)<<6|E);continue}var B=i[u++]&63;if((_&240)==224?_=(_&15)<<12|E<<6|B:_=(_&7)<<18|E<<12|B<<6|i[u++]&63,_<65536)b+=String.fromCharCode(_);else{var pt=_-65536;b+=String.fromCharCode(55296|pt>>10,56320|pt&1023)}}return b}function le(i,u){return i?z(J,i,u):""}function qr(i,u,c){for(var m=0;m<i.length;++m)ce[u++>>0]=i.charCodeAt(m);c||(ce[u>>0]=0)}function jr(i,u){return i%u>0&&(i+=u-i%u),i}var ot,ce,J,F;function at(i){ot=i,t.HEAP8=ce=new Int8Array(i),t.HEAP16=new Int16Array(i),t.HEAP32=F=new Int32Array(i),t.HEAPU8=J=new Uint8Array(i),t.HEAPU16=new Uint16Array(i),t.HEAPU32=new Uint32Array(i),t.HEAPF32=new Float32Array(i),t.HEAPF64=new Float64Array(i)}t.INITIAL_MEMORY;var Ie,ut=[],ft=[],lt=[],Vr=0;function zr(){return T||Vr>0}function Gr(){if(t.preRun)for(typeof t.preRun=="function"&&(t.preRun=[t.preRun]);t.preRun.length;)Xr(t.preRun.shift());Me(ut)}function Jr(){Me(ft)}function Qr(){if(t.postRun)for(typeof t.postRun=="function"&&(t.postRun=[t.postRun]);t.postRun.length;)Yr(t.postRun.shift());Me(lt)}function Xr(i){ut.unshift(i)}function Kr(i){ft.unshift(i)}function Yr(i){lt.unshift(i)}var $=0,Q=null;function Zr(i){$++,t.monitorRunDependencies&&t.monitorRunDependencies($)}function en(i){if($--,t.monitorRunDependencies&&t.monitorRunDependencies($),$==0&&Q){var u=Q;Q=null,u()}}t.preloadedImages={},t.preloadedAudios={};function H(i){t.onAbort&&t.onAbort(i),i="Aborted("+i+")",S(i),A=!0,i+=". Build with -s ASSERTIONS=1 for more info.";var u=new WebAssembly.RuntimeError(i);throw s(u),u}var tn="data:application/octet-stream;base64,";function ct(i){return i.startsWith(tn)}var x;x="tflite-simd.wasm",ct(x)||(x=p(x));function ht(i){try{if(i==x&&I)return new Uint8Array(I);if(!R)throw"both async and sync fetching of the wasm failed"}catch(u){H(u)}}function rn(){return!I&&g&&typeof fetch=="function"?fetch(x,{credentials:"same-origin"}).then(function(i){if(!i.ok)throw"failed to load wasm binary file at '"+x+"'";return i.arrayBuffer()}).catch(function(){return ht(x)}):Promise.resolve().then(function(){return ht(x)})}function nn(){var i={a:Rn};function u(_,E){var B=_.exports;t.asm=B,M=t.asm.q,at(M.buffer),Ie=t.asm.D,Kr(t.asm.r),en()}Zr();function c(_){u(_.instance)}function m(_){return rn().then(function(E){return WebAssembly.instantiate(E,i)}).then(function(E){return E}).then(_,function(E){S("failed to asynchronously prepare wasm: "+E),H(E)})}function v(){return!I&&typeof WebAssembly.instantiateStreaming=="function"&&!ct(x)&&typeof fetch=="function"?fetch(x,{credentials:"same-origin"}).then(function(_){var E=WebAssembly.instantiateStreaming(_,i);return E.then(c,function(B){return S("wasm streaming compile failed: "+B),S("falling back to ArrayBuffer instantiation"),m(c)})}):m(c)}if(t.instantiateWasm)try{var b=t.instantiateWasm(i,u);return b}catch(_){return S("Module.instantiateWasm callback failed with error: "+_),!1}return v().catch(s),{}}function Me(i){for(;i.length>0;){var u=i.shift();if(typeof u=="function"){u(t);continue}var c=u.func;typeof c=="number"?u.arg===void 0?Ie.get(c)():Ie.get(c)(u.arg):c(u.arg===void 0?null:u.arg)}}function sn(i,u,c,m){H("Assertion failed: "+le(i)+", at: "+[u?le(u):"unknown filename",c,m?le(m):"unknown function"])}function on(i,u){H("To use dlopen, you need to use Emscripten's linking support, see https://github.com/emscripten-core/emscripten/wiki/Linking")}function an(i,u){H("To use dlopen, you need to use Emscripten's linking support, see https://github.com/emscripten-core/emscripten/wiki/Linking")}function un(){H("")}var he;he=function(){return performance.now()};var fn=!0;function ln(i){return F[dt()>>2]=i,i}function cn(i,u){var c;if(i===0)c=Date.now();else if((i===1||i===4)&&fn)c=he();else return ln(28),-1;return F[u>>2]=c/1e3|0,F[u+4>>2]=c%1e3*1e3*1e3|0,0}function hn(){return 2147483648}function dn(i,u,c){J.copyWithin(i,u,u+c)}function pn(i){try{return M.grow(i-ot.byteLength+65535>>>16),at(M.buffer),1}catch{}}function mn(i){var u=J.length;i=i>>>0;var c=2147483648;if(i>c)return!1;for(var m=1;m<=4;m*=2){var v=u*(1+.2/m);v=Math.min(v,i+100663296);var b=Math.min(c,jr(Math.max(i,v),65536)),_=pn(b);if(_)return!0}return!1}function _n(i){for(var u=he();he()-u<i;);}var Ae={};function gn(){return l||"./this.program"}function X(){if(!X.strings){var i=(typeof navigator=="object"&&navigator.languages&&navigator.languages[0]||"C").replace("-","_")+".UTF-8",u={USER:"web_user",LOGNAME:"web_user",PATH:"/",PWD:"/",HOME:"/home/web_user",LANG:i,_:gn()};for(var c in Ae)Ae[c]===void 0?delete u[c]:u[c]=Ae[c];var m=[];for(var c in u)m.push(c+"="+u[c]);X.strings=m}return X.strings}var de={mappings:{},buffers:[null,[],[]],printChar:function(i,u){var c=de.buffers[i];u===0||u===10?((i===1?y:S)(z(c,0)),c.length=0):c.push(u)},varargs:void 0,get:function(){de.varargs+=4;var i=F[de.varargs-4>>2];return i},getStr:function(i){var u=le(i);return u},get64:function(i,u){return i}};function vn(i,u){var c=0;return X().forEach(function(m,v){var b=u+c;F[i+v*4>>2]=b,qr(m,b),c+=m.length+1}),0}function yn(i,u){var c=X();F[i>>2]=c.length;var m=0;return c.forEach(function(v){m+=v.length+1}),F[u>>2]=m,0}function wn(i){On(i)}function Cn(i){return 0}function bn(i,u,c,m,v){}function Tn(i,u,c,m){for(var v=0,b=0;b<c;b++){for(var _=F[u+b*8>>2],E=F[u+(b*8+4)>>2],B=0;B<E;B++)de.printChar(i,J[_+B]);v+=E}return F[m>>2]=v,0}function En(){if(typeof crypto=="object"&&typeof crypto.getRandomValues=="function"){var i=new Uint8Array(1);return function(){return crypto.getRandomValues(i),i[0]}}else return function(){H("randomDevice")}}function pe(i,u){pe.randomDevice||(pe.randomDevice=En());for(var c=0;c<u;c++)ce[i+c>>0]=pe.randomDevice();return 0}var Rn={a:sn,e:on,d:an,b:un,n:cn,h:hn,l:dn,m:mn,p:_n,f:vn,g:yn,j:wn,i:Cn,k:bn,c:Tn,o:pe};nn(),t.___wasm_call_ctors=function(){return(t.___wasm_call_ctors=t.asm.r).apply(null,arguments)},t._getModelBufferMemoryOffset=function(){return(t._getModelBufferMemoryOffset=t.asm.s).apply(null,arguments)},t._getInputMemoryOffset=function(){return(t._getInputMemoryOffset=t.asm.t).apply(null,arguments)},t._getInputHeight=function(){return(t._getInputHeight=t.asm.u).apply(null,arguments)},t._getInputWidth=function(){return(t._getInputWidth=t.asm.v).apply(null,arguments)},t._getInputChannelCount=function(){return(t._getInputChannelCount=t.asm.w).apply(null,arguments)},t._getOutputMemoryOffset=function(){return(t._getOutputMemoryOffset=t.asm.x).apply(null,arguments)},t._getOutputHeight=function(){return(t._getOutputHeight=t.asm.y).apply(null,arguments)},t._getOutputWidth=function(){return(t._getOutputWidth=t.asm.z).apply(null,arguments)},t._getOutputChannelCount=function(){return(t._getOutputChannelCount=t.asm.A).apply(null,arguments)},t._loadModel=function(){return(t._loadModel=t.asm.B).apply(null,arguments)},t._runInference=function(){return(t._runInference=t.asm.C).apply(null,arguments)};var dt=t.___errno_location=function(){return(dt=t.___errno_location=t.asm.E).apply(null,arguments)},me;function Pn(i){this.name="ExitStatus",this.message="Program terminated with exit("+i+")",this.status=i}Q=function i(){me||Fe(),me||(Q=i)};function Fe(i){if($>0||(Gr(),$>0))return;function u(){me||(me=!0,t.calledRun=!0,!A&&(Jr(),n(t),t.onRuntimeInitialized&&t.onRuntimeInitialized(),Qr()))}t.setStatus?(t.setStatus("Running..."),setTimeout(function(){setTimeout(function(){t.setStatus("")},1),u()},1)):u()}t.run=Fe;function On(i,u){Sn(i)}function Sn(i){zr()||(t.onExit&&t.onExit(i),A=!0),h(i,new Pn(i))}if(t.preInit)for(typeof t.preInit=="function"&&(t.preInit=[t.preInit]);t.preInit.length>0;)t.preInit.pop()();return Fe(),e.ready}}();typeof exports=="object"&&typeof module=="object"?module.exports=ue:typeof define=="function"&&define.amd?define([],function(){return ue}):typeof exports=="object"&&(exports.createVonageTFLiteSimdModule=ue);class Dr{constructor(){this.isSIMDSupported_=!1,this.isThreadsSupported_=!1,this.inputWidth_=0,this.inputHeight_=0,this.inputChannelCount_=0,this.inputMemoryOffset_=0,this.outputWidth_=0,this.outputHeight_=0,this.outputChannelCount_=0,this.outputMemoryOffset_=0}}async function $r(r){let e=new Dr;var t=new Promise(function(n,s){async function a(){return ue({locateFile:function(h){return r+h}})}async function f(l){return new Promise(async(h,g)=>{const o=l;if(typeof o=="undefined")return g("TFLite backend unavailable: wasmSimd");const p=Hr();console.log("Loading tflite model:",p);let R=r+`models/${p}.tflite`;console.log("TFLite modelUrl: "+R);try{const S=await(await fetch(R)).arrayBuffer();console.log("Model buffer size:",S.byteLength);const I=o._getModelBufferMemoryOffset();console.log("Model buffer memory offset:",I),console.log("Loading model buffer..."),o.HEAPU8.set(new Uint8Array(S),I);const T=o._loadModel(S.byteLength);if(console.log("Load model result:",T),T!==0){g("Cannot load model");return}e.inputWidth_=o._getInputWidth(),e.inputHeight_=o._getInputHeight(),e.inputChannelCount_=o._getInputChannelCount(),e.inputMemoryOffset_=o._getInputMemoryOffset(),console.log("Input memory offset:",e.inputMemoryOffset_),console.log("Input height:",e.inputHeight_),console.log("Input width:",e.inputWidth_),console.log("Input channels:",e.inputChannelCount_),e.outputMemoryOffset_=o._getOutputMemoryOffset(),e.outputWidth_=o._getOutputWidth(),e.outputHeight_=o._getOutputHeight(),e.outputChannelCount_=o._getOutputChannelCount(),console.log("Output memory offset:",e.outputMemoryOffset_),console.log("Output height:",e.outputHeight_),console.log("Output width:",e.outputWidth_),console.log("Output channels:",e.outputChannelCount_),e.selectedTFLite_=o}catch(y){g(y);return}h()})}a().then(l=>{if(l===null)throw console.error("loadTFLite null"),"loadTFLite null";f(l).then(h=>{n(e)}).catch(h=>{console.error("loadTFLiteModel error"),s("loadTFLiteModel error")})}).catch(l=>{console.error("loadTFLite error:",l),s("loadTFLite error:"+l)})});return t}class Wr{constructor(e){this.blurFilter_=e===ae.High?"blur(15px)":"blur(5px)"}runPostProcessing(e,t){try{e.globalCompositeOperation="source-in",e.filter=this.blurFilter_,e.drawImage(t,0,0,t.width,t.height),e.globalCompositeOperation="destination-over",e.filter="blur(0px)",e.drawImage(t,0,0,t.width,t.height)}catch(n){console.log("[BlurPostProcess] Failed to draw canvas",n)}}}const V=class{constructor(r){if(this.config_=r,this.frameCounter_=0,this.lastProcessedTimestamp_=0,this.resultCanvas_=new OffscreenCanvas(1,1),this.resultCtx_=this.resultCanvas_.getContext("2d",{alpha:!1,desynchronized:!0}),!this.resultCtx_)throw new Error("Unable to create OffscreenCanvasRenderingContext2D");if(this.segmentationMaskCanvas_=new OffscreenCanvas(1,1),this.segmentationMaskCtx_=this.segmentationMaskCanvas_.getContext("2d",{alpha:!1,desynchronized:!0}),!this.segmentationMaskCtx_)throw new Error("Unable to create OffscreenCanvasRenderingContext2D");if(this.segmentationMaskFrameCanvas_=new OffscreenCanvas(1,1),this.segmentationMaskFrameCtx_=this.segmentationMaskFrameCanvas_.getContext("2d",{alpha:!1,desynchronized:!0}),!this.segmentationMaskFrameCtx_)throw new Error("Unable to create OffscreenCanvasRenderingContext2D");this.segmentationPixelCount_=0,this.inputMemoryOffset_=0,this.outputMemoryOffset_=0,r.transformerType==="VirtualBackground"?(this.timerGap_=V.VIRTUAL_PROCESS_GAP_MICRO_SECOND,this.postProcessInterface_=new Ur(r.backgroundAssetUri)):r.transformerType==="BackgroundBlur"?(this.timerGap_=V.BLUR_PROCESS_GAP_MICRO_SECOND,this.postProcessInterface_=new it(r.radius)):r.transformerType==="VideoBackground"?this.timerGap_=V.BLUR_PROCESS_GAP_MICRO_SECOND:r.transformerType==="SilueteBlur"?(this.timerGap_=V.BLUR_PROCESS_GAP_MICRO_SECOND,this.postProcessInterface_=new Wr(r.radius)):(this.timerGap_=V.BLUR_PROCESS_GAP_MICRO_SECOND,this.postProcessInterface_=new it)}async start(){await $r(this.config_.wasmAssetUriPath).then(r=>{r&&(this.voangeTFLiteInfo_=r,this.segmentationMaskCanvas_.width=this.voangeTFLiteInfo_.inputWidth_,this.segmentationMaskCanvas_.height=this.voangeTFLiteInfo_.inputHeight_,this.segmentationPixelCount_=this.voangeTFLiteInfo_.inputWidth_*this.voangeTFLiteInfo_.inputHeight_,this.segmentationMask_=new ImageData(this.voangeTFLiteInfo_.inputWidth_,this.voangeTFLiteInfo_.inputHeight_),this.inputMemoryOffset_=this.voangeTFLiteInfo_.inputMemoryOffset_/4,this.outputMemoryOffset_=this.voangeTFLiteInfo_.outputMemoryOffset_/4)}).catch(r=>{console.log("error useTFLite:",r)})}async transform(r,e){(this.resultCanvas_.width!=r.displayWidth||this.resultCanvas_.height!=r.displayHeight)&&(this.resultCanvas_.width=r.displayWidth,this.resultCanvas_.height=r.displayHeight),(this.segmentationMaskFrameCanvas_.width!=r.displayWidth||this.segmentationMaskFrameCanvas_.height!=r.displayHeight)&&(this.segmentationMaskFrameCanvas_.width=r.displayWidth,this.segmentationMaskFrameCanvas_.height=r.displayHeight);const t=r.timestamp;createImageBitmap(r).then(n=>{r.close(),this.processFrame(e,n,t)}).catch(n=>{console.error("createImageBitmap",n),e.enqueue(r)})}processFrame(r,e,t){t-this.lastProcessedTimestamp_>=this.timerGap_&&(this.lastProcessedTimestamp_=t,this.processSource(e)),this.resultCtx_.globalCompositeOperation="copy",this.resultCtx_.drawImage(this.segmentationMaskFrameCanvas_,0,0,this.segmentationMaskFrameCanvas_.width,this.segmentationMaskFrameCanvas_.height),this.resultCtx_.globalCompositeOperation="source-atop",this.resultCtx_.filter="none",this.resultCtx_.drawImage(e,0,0,e.width,e.height),this.postProcessInterface_&&this.postProcessInterface_.runPostProcessing(this.resultCtx_,e),r.enqueue(new VideoFrame(this.resultCanvas_,{timestamp:t,alpha:"discard"})),this.frameCounter_++}processSource(r){this.segmentationMaskCtx_.globalCompositeOperation="copy",this.segmentationMaskCtx_.drawImage(r,0,0,r.width,r.height,0,0,this.voangeTFLiteInfo_.inputWidth_,this.voangeTFLiteInfo_.inputHeight_);let e=this.segmentationMaskCtx_.getImageData(0,0,this.voangeTFLiteInfo_.inputWidth_,this.voangeTFLiteInfo_.inputHeight_);for(let t=0;t<this.segmentationPixelCount_;t++)this.voangeTFLiteInfo_.selectedTFLite_.HEAPF32[this.inputMemoryOffset_+t*3]=e.data[t*4]/255,this.voangeTFLiteInfo_.selectedTFLite_.HEAPF32[this.inputMemoryOffset_+t*3+1]=e.data[t*4+1]/255,this.voangeTFLiteInfo_.selectedTFLite_.HEAPF32[this.inputMemoryOffset_+t*3+2]=e.data[t*4+2]/255;this.voangeTFLiteInfo_.selectedTFLite_._runInference();for(let t=0;t<this.segmentationPixelCount_;t++){const n=this.voangeTFLiteInfo_.selectedTFLite_.HEAPF32[this.outputMemoryOffset_+t];this.segmentationMask_.data[t*4+3]=255*n}this.segmentationMaskCtx_.putImageData(this.segmentationMask_,0,0),this.segmentationMaskFrameCtx_.globalCompositeOperation="copy",this.segmentationMaskFrameCtx_.drawImage(this.segmentationMaskCanvas_,0,0,this.voangeTFLiteInfo_.inputWidth_,this.voangeTFLiteInfo_.inputHeight_,0,0,this.segmentationMaskFrameCanvas_.width,this.segmentationMaskFrameCanvas_.height)}flush(){}getTransformerType(){return"BackgroundTransformer"}setVideoBGReadable(r){this.config_.transformerType==="VideoBackground"&&(this.postProcessInterface_=new kr(r))}};let Se=V;if(Se.BLUR_PROCESS_GAP_MICRO_SECOND=2e5,Se.VIRTUAL_PROCESS_GAP_MICRO_SECOND=15e4,typeof importScripts=="function"){let r=new Lr;onmessage=async e=>{const{operation:t}=e.data;if(console.log("operation=",t),t==="transform"){const{readable:n,writable:s,config:a,videoBGReadable:f}=e.data;let l=[];const h=new Se(JSON.parse(a));h.setVideoBGReadable(f),l.push(h),r.setTransformers(l).then(()=>{r.transform(n,s).then(()=>{postMessage("success")}).catch(g=>{postMessage("error:"+g)})}).catch(g=>{postMessage("error:"+g)})}else t==="destroy"&&r.destroy().then(()=>{postMessage("success")}).catch(n=>{postMessage("error:"+n)})}}})();
",yl=typeof window!="undefined"&&window.Blob&&new Blob([atob(pl)],{type:"text/javascript;charset=utf-8"});function xZ(){const Z=yl&&(window.URL||window.webkitURL).createObjectURL(yl);try{return Z?new Worker(Z):new Worker("data:application/javascript;base64,"+pl,{type:"module"})}finally{Z&&(window.URL||window.webkitURL).revokeObjectURL(Z)}}class CZ{constructor(l){this.config_=l,this.worker_=new xZ}transform(l,d){return new Promise(async(b,c)=>{console.log("Created a worker thread.");const m=new Promise((t,i)=>{this.worker_.addEventListener("message",function(X){X.data==="success"?t():i(X.data)})});if(this.config_.transformerType==="VideoBackground"){const t=document.createElement("video");t.src=this.config_.backgroundAssetUri,t.muted=!0;try{await t.play()}catch(n){c(n);return}const i=t.captureStream().getVideoTracks()[0],X=new MediaStreamTrackProcessor(i).readable;this.worker_.postMessage({operation:"transform",readable:l,writable:d,config:JSON.stringify(this.config_),videoBGReadable:X},[l,d,X])}else this.worker_.postMessage({operation:"transform",readable:l,writable:d,config:JSON.stringify(this.config_)},[l,d]);m.then(()=>{console.log("Worker inited"),b()}).catch(t=>{console.log("Worker inited error"),c(t)})})}destroy(){return new Promise(async(l,d)=>{console.log("destroy a worker thread.");const b=new Promise((c,m)=>{this.worker_.addEventListener("message",function(i){i.data==="success"?c():m(i.data)})});this.worker_.postMessage({operation:"destroy"}),b.then(()=>{console.log("Worker destroyed"),l()}).catch(c=>{console.log("Worker destroy error"),d(c)})})}}s.BlurRadius=void 0,function(Z){Z.Low="Low",Z.High="High"}(s.BlurRadius||(s.BlurRadius={}));const kZ=async()=>WebAssembly.validate(new Uint8Array([0,97,115,109,1,0,0,0,1,5,1,96,0,1,123,3,2,1,0,10,10,1,8,0,65,0,253,15,253,98,11]));function UZ(){return new Promise(async(Z,l)=>{try{await K()}catch(d){l(d);return}kZ().then(d=>{if(d===!1){l("Your browser does not support WebAssembly features.");return}Z()}).catch(d=>{l(d)})})}function BZ(Z){return new Promise(async(l,d)=>{const b=new fZ(new CZ(Z));l(b)})}s.createVonageMediaProcessorConnector=BZ,s.isSupported=UZ,Object.defineProperty(s,"__esModule",{value:!0}),s[Symbol.toStringTag]="Module"});
Binary file
@@ -0,0 +1,95 @@
1
+ import { MediaProcessorConnectorInterface } from '@vonage/media-processor';
2
+ import { BlurRadius, BackgroundBlurConfig, VirtualBackgroundConfig, AssetBackgroundConfig, VideoBackgroundConfig, MediaProcessorBaseConfig, SilueteBlurConfig } from './src/types';
3
+ import { isSupported } from './src/utils/utils';
4
+ /**
5
+ * MediaProcessorConfig specifies the transformer logic to be performed.
6
+ *
7
+ * @example
8
+ *
9
+ * ```ts
10
+ * let config: MediaProcessorConfig;
11
+ * if(typeType === 'blur'){
12
+ * config = {
13
+ * wasmAssetUriPath: location.href
14
+ * transformerType: 'BackgroundBlur',
15
+ * radius: blurLevelType === 'low' ? BlurRadius.Low : BlurRadius.High,
16
+ * };
17
+ * } else if(typeType === 'virtual'){
18
+ * config = {
19
+ * wasmAssetUriPath: location.href,
20
+ * transformerType: 'VirtualBackground',
21
+ * backgroundAssetUri: location.href + "images/vonage.jpeg"
22
+ * }
23
+ * } else if(typeType === 'video') {
24
+ * config = {
25
+ * wasmAssetUriPath: location.href,
26
+ * transformerType: 'VideoBackground',
27
+ * backgroundAssetUri: location.href + 'videos/bbb.mp4'
28
+ * };
29
+ * } else if(typeType === 'siluete') {
30
+ * config = {
31
+ * wasmAssetUriPath: location.href,
32
+ * transformerType: 'SilueteBlur',
33
+ * radius: blurLevelType === 'low' ? BlurRadius.Low : BlurRadius.High,
34
+ * };
35
+ * }
36
+ * ```
37
+ */
38
+ declare type MediaProcessorConfig = MediaProcessorBaseConfig & (BackgroundBlurConfig | ((VirtualBackgroundConfig | VideoBackgroundConfig) & AssetBackgroundConfig) | SilueteBlurConfig);
39
+ /**
40
+ * Factory function to create new MediaProcessorConnectorInterface instances.
41
+ *
42
+ * @param config Specifies the transformer logic that the MediaProcessorConnectorInterface instance will be enabled with.
43
+ * @returns A promise that is resolved with a given MediaProcessorConnectorInterface instance.
44
+ *
45
+ * @example
46
+ *
47
+ * ```ts
48
+ * createVonageMediaProcessorConnector(config).then(mediaProcessorConnector => {
49
+ * setMediaProcessorConnector(mediaProcessorConnector);
50
+ * })
51
+ * .catch(e => {
52
+ * console.error(e)
53
+ * });
54
+ *
55
+ * // ..
56
+ *
57
+ * setMediaProcessorConnector(mediaProcessorConnector: MediaProcessorConnectorInterface): Promise<void> {
58
+ * return new Promise<void>(async (resolve, reject) => {
59
+ * this.mediaProcessorConnector_ = mediaProcessorConnector;
60
+ * if (!this.stream_)
61
+ * {
62
+ * console.log('[CameraSource] Requesting camera.');
63
+ * reject("no stream")
64
+ * }
65
+ * this.mediaProcessorConnector_.setTrack(this.videoTrack_).then(newTrack => {
66
+ * let processedStream = new MediaStream();
67
+ * processedStream.addTrack(newTrack);
68
+ * this.sink_.setMediaStream(processedStream);
69
+ * resolve();
70
+ * })
71
+ * .catch(e => {
72
+ * reject(e)
73
+ * })
74
+ * });
75
+ * }
76
+ *
77
+ * // ..
78
+ *
79
+ * async stopMediaProcessorConnector() {
80
+ * if(this.mediaProcessorConnector_){
81
+ * this.mediaProcessorConnector_.destroy().then(() => {
82
+ * let processedStream = new MediaStream();
83
+ * processedStream.addTrack(this.videoTrack_);
84
+ * this.sink_.setMediaStream(processedStream);
85
+ * })
86
+ * .catch(e => {
87
+ * console.error(e);
88
+ * });
89
+ * }
90
+ * }
91
+ * ```
92
+ */
93
+ declare function createVonageMediaProcessorConnector(config: MediaProcessorConfig): Promise<MediaProcessorConnectorInterface>;
94
+ export type { MediaProcessorBaseConfig, BackgroundBlurConfig, VirtualBackgroundConfig, VideoBackgroundConfig, AssetBackgroundConfig, SilueteBlurConfig, MediaProcessorConfig };
95
+ export { BlurRadius, createVonageMediaProcessorConnector, isSupported, };
@@ -0,0 +1,34 @@
1
+ /// <reference types="dom-webcodecs" />
2
+ /// <reference types="offscreencanvas" />
3
+ import { MediaProcessorConfig } from '../../main';
4
+ import { PostProcessInterface } from './PostProcessInterface';
5
+ import { VonageTFLiteInfo } from './VonageTFLite';
6
+ declare class BackgroundTransformer {
7
+ static BLUR_PROCESS_GAP_MICRO_SECOND: number;
8
+ static VIRTUAL_PROCESS_GAP_MICRO_SECOND: number;
9
+ voangeTFLiteInfo_: VonageTFLiteInfo;
10
+ frameCounter_: number;
11
+ lastProcessedTimestamp_: number;
12
+ timerGap_: number;
13
+ segmentationMaskCanvas_: OffscreenCanvas;
14
+ segmentationMaskCtx_: OffscreenCanvasRenderingContext2D | null;
15
+ segmentationPixelCount_: number;
16
+ segmentationMask_: ImageData;
17
+ segmentationMaskFrameCanvas_: OffscreenCanvas;
18
+ segmentationMaskFrameCtx_: OffscreenCanvasRenderingContext2D | null;
19
+ resultCanvas_: OffscreenCanvas;
20
+ resultCtx_: OffscreenCanvasRenderingContext2D | null;
21
+ inputMemoryOffset_: number;
22
+ outputMemoryOffset_: number;
23
+ postProcessInterface_?: PostProcessInterface;
24
+ config_: MediaProcessorConfig;
25
+ constructor(config: MediaProcessorConfig);
26
+ start(): Promise<void>;
27
+ transform(frame: any, controller: TransformStreamDefaultController): Promise<void>;
28
+ processFrame(controller: TransformStreamDefaultController, image: ImageBitmap, timestamp: number): void;
29
+ processSource(image: ImageBitmap): void;
30
+ flush(): void;
31
+ getTransformerType(): string;
32
+ setVideoBGReadable(videoBGReadable: ReadableStream): void;
33
+ }
34
+ export default BackgroundTransformer;
@@ -0,0 +1,10 @@
1
+ /// <reference types="dom-webcodecs" />
2
+ /// <reference types="offscreencanvas" />
3
+ import { PostProcessInterface } from "./PostProcessInterface";
4
+ import { BlurRadius } from "../types";
5
+ declare class BlurPostProcess implements PostProcessInterface {
6
+ blurFilter_: string;
7
+ constructor(radius?: BlurRadius);
8
+ runPostProcessing(resultCtx: OffscreenCanvasRenderingContext2D | null, image: ImageBitmap): void;
9
+ }
10
+ export default BlurPostProcess;
@@ -0,0 +1,5 @@
1
+ /// <reference types="dom-webcodecs" />
2
+ /// <reference types="offscreencanvas" />
3
+ export interface PostProcessInterface {
4
+ runPostProcessing(resultCtx: OffscreenCanvasRenderingContext2D | null, image: ImageBitmap): void;
5
+ }
@@ -0,0 +1,13 @@
1
+ export interface IQueue<T> {
2
+ enqueue(item: T): void;
3
+ dequeue(): T | undefined;
4
+ size(): number;
5
+ }
6
+ export declare class Queue<T> implements IQueue<T> {
7
+ private capacity;
8
+ private storage;
9
+ constructor(capacity?: number);
10
+ enqueue(item: T): void;
11
+ dequeue(): T | undefined;
12
+ size(): number;
13
+ }
@@ -0,0 +1,10 @@
1
+ /// <reference types="dom-webcodecs" />
2
+ /// <reference types="offscreencanvas" />
3
+ import { PostProcessInterface } from './PostProcessInterface';
4
+ import { BlurRadius } from '../types';
5
+ declare class SilueteBlurPostProcess implements PostProcessInterface {
6
+ blurFilter_: string;
7
+ constructor(radius?: BlurRadius);
8
+ runPostProcessing(resultCtx: OffscreenCanvasRenderingContext2D | null, image: ImageBitmap): void;
9
+ }
10
+ export default SilueteBlurPostProcess;
@@ -0,0 +1,11 @@
1
+ /// <reference types="dom-webcodecs" />
2
+ /// <reference types="offscreencanvas" />
3
+ import { PostProcessInterface } from './PostProcessInterface';
4
+ import { Queue } from './Queue';
5
+ export declare class VideoPostProcess implements PostProcessInterface {
6
+ queue_: Queue<any>;
7
+ frameReader_: any;
8
+ constructor(videoBGReadable: ReadableStream);
9
+ processFrame(result: any): void;
10
+ runPostProcessing(resultCtx: OffscreenCanvasRenderingContext2D | null, image: ImageBitmap): void;
11
+ }
@@ -0,0 +1,11 @@
1
+ /// <reference types="dom-webcodecs" />
2
+ /// <reference types="offscreencanvas" />
3
+ import { PostProcessInterface } from "./PostProcessInterface";
4
+ declare class VirtualPostProcess implements PostProcessInterface {
5
+ imageCanvas_: OffscreenCanvas;
6
+ imageCtx_: OffscreenCanvasRenderingContext2D | null;
7
+ imageBlob_: any;
8
+ constructor(imageUri: string);
9
+ runPostProcessing(resultCtx: OffscreenCanvasRenderingContext2D | null, image: ImageBitmap): void;
10
+ }
11
+ export default VirtualPostProcess;
@@ -0,0 +1,28 @@
1
+ /// <reference types="emscripten" />
2
+ export interface TFLite extends EmscriptenModule {
3
+ _getModelBufferMemoryOffset(): number;
4
+ _getInputMemoryOffset(): number;
5
+ _getInputHeight(): number;
6
+ _getInputWidth(): number;
7
+ _getInputChannelCount(): number;
8
+ _getOutputMemoryOffset(): number;
9
+ _getOutputHeight(): number;
10
+ _getOutputWidth(): number;
11
+ _getOutputChannelCount(): number;
12
+ _loadModel(bufferSize: number): number;
13
+ _runInference(): number;
14
+ }
15
+ export declare class VonageTFLiteInfo {
16
+ selectedTFLite_: TFLite;
17
+ isSIMDSupported_: boolean;
18
+ isThreadsSupported_: boolean;
19
+ inputWidth_: number;
20
+ inputHeight_: number;
21
+ inputChannelCount_: number;
22
+ inputMemoryOffset_: number;
23
+ outputWidth_: number;
24
+ outputHeight_: number;
25
+ outputChannelCount_: number;
26
+ outputMemoryOffset_: number;
27
+ }
28
+ export declare function VonageTFLite(uri: string): Promise<VonageTFLiteInfo>;
@@ -0,0 +1 @@
1
+ export declare function getVonageTFLiteModelFileName(): string;
@@ -0,0 +1,65 @@
1
+ /**
2
+ * VonageTransformerType which type of transformer to create.
3
+ */
4
+ export declare type VonageTransformerType = 'BackgroundBlur' | 'VirtualBackground' | 'VideoBackground' | 'SilueteBlur';
5
+ /**
6
+ * BlurRadius specifies how much bluring filter to apply by a given transformer.
7
+ */
8
+ export declare enum BlurRadius {
9
+ /**
10
+ * Low bluring filtering.
11
+ */
12
+ Low = "Low",
13
+ /**
14
+ * High bluring filtering.
15
+ */
16
+ High = "High"
17
+ }
18
+ /**
19
+ * MediaProcessorBaseConfig specifies the absolute URL for the path where the Wasm modules used by the transformers from this library are stored. ML models files must be located under a folder called `models` under this same path.
20
+ *
21
+ * @example
22
+ *
23
+ * ```ts
24
+ * {
25
+ * wasmAssetUriPath: 'http://localhost:8080/assets'
26
+ * }
27
+ * ```
28
+ *
29
+ * Wasm modules must be found under *assets/* folder as well as the ML models files under *assets/models* folder.
30
+ */
31
+ export declare type MediaProcessorBaseConfig = {
32
+ wasmAssetUriPath: string;
33
+ };
34
+ /**
35
+ * BackgroundBlurConfig specifies the configuration for a transformer logic that performs background blurring.
36
+ */
37
+ export declare type BackgroundBlurConfig = {
38
+ transformerType: 'BackgroundBlur';
39
+ radius?: BlurRadius;
40
+ };
41
+ /**
42
+ * AssetBackgroundConfig specifies the absolute URL to the image or video file used for background replacement.
43
+ */
44
+ export declare type AssetBackgroundConfig = {
45
+ backgroundAssetUri: string;
46
+ };
47
+ /**
48
+ * VirtualBackgroundConfig specifies the configuration for a transformer logic that performs background replacement with a given image.
49
+ */
50
+ export declare type VirtualBackgroundConfig = {
51
+ transformerType: 'VirtualBackground';
52
+ };
53
+ /**
54
+ * VirtualBackgroundConfig specifies the configuration for a transformer logic that performs background replacement with a given video.
55
+ */
56
+ export declare type VideoBackgroundConfig = {
57
+ transformerType: 'VideoBackground';
58
+ };
59
+ /**
60
+ * BackgroundBlurConfig specifies the configuration for a transformer logic that performs siluete blurring.
61
+ */
62
+ export declare type SilueteBlurConfig = {
63
+ transformerType: 'SilueteBlur';
64
+ radius?: BlurRadius;
65
+ };
@@ -0,0 +1,6 @@
1
+ /**
2
+ * Check if the current browser is officially supported by the library.
3
+ *
4
+ * @returns The promise will resolve or reject depending whether the browser is supported or not.
5
+ */
6
+ export declare function isSupported(): Promise<void>;
@@ -0,0 +1,10 @@
1
+ import { MediaProcessorInterface } from '@vonage/media-processor';
2
+ import { MediaProcessorConfig } from '../../main';
3
+ declare class VonageMediaProcessorWorker implements MediaProcessorInterface {
4
+ worker_: any;
5
+ config_: MediaProcessorConfig;
6
+ constructor(config: MediaProcessorConfig);
7
+ transform(readable: ReadableStream, writable: WritableStream): Promise<void>;
8
+ destroy(): Promise<void>;
9
+ }
10
+ export default VonageMediaProcessorWorker;
package/package.json ADDED
@@ -0,0 +1,65 @@
1
+ {
2
+ "name": "@vonage/ml-transformers",
3
+ "version": "1.0.1",
4
+ "author": "Guy Mininberg <guy.mininberg@vonage.com>",
5
+ "contributors": [
6
+ "Guy Mininberg <guy.mininberg@vonage.com>",
7
+ "Jose Olivera <joseantonio.oliveraortega@vonage.com>"
8
+ ],
9
+ "keywords": [
10
+ "vonage",
11
+ "vonage api",
12
+ "client",
13
+ "media processing",
14
+ "insertable streams",
15
+ "transformers",
16
+ "machine learning",
17
+ "background blur",
18
+ "virtual background",
19
+ "video background",
20
+ "face masking",
21
+ "opentok",
22
+ "nexmo"
23
+ ],
24
+ "scripts": {
25
+ "build": "npm-run-all build:js doc",
26
+ "build:js": "tsc && vite build && tsc --declaration --emitDeclarationOnly --outDir dist/types",
27
+ "doc": "typedoc --excludePrivate --excludeProtected --disableSources --out dist/docs lib/main.ts",
28
+ "dev": "vite",
29
+ "preview": "vite preview"
30
+ },
31
+ "dependencies": {
32
+ "@types/emscripten": "^1.39.6",
33
+ "wasm-feature-detect": "^1.2.11",
34
+ "@types/offscreencanvas": "^2019.6.4",
35
+ "@types/dom-mediacapture-transform": "^0.1.2",
36
+ "@types/node": "^17.0.10",
37
+ "axios": "^0.25.0",
38
+ "uuid": "^8.3.2",
39
+ "typescript-optional": "3.0.0-alpha.3",
40
+ "@vonage/media-processor": "1.0.1"
41
+ },
42
+ "files": [
43
+ "dist"
44
+ ],
45
+ "types": "./dist/types/main.d.ts",
46
+ "main": "./dist/ml-transformers.umd.js",
47
+ "module": "./dist/ml-transformers.es.js",
48
+ "exports": {
49
+ ".": {
50
+ "import": "./dist/ml-transformers.es.js",
51
+ "require": "./dist/ml-transformers.umd.js"
52
+ }
53
+ },
54
+ "devDependencies": {
55
+ "@tsconfig/node12": "^1.0.1",
56
+ "typescript": "^4.5.4",
57
+ "vite": "^2.7.2",
58
+ "npm-run-all": "^4.1.5",
59
+ "typedoc": "^0.22.12"
60
+ },
61
+ "repository": "https://github.com/vonage/ml-transformers",
62
+ "publishConfig": {
63
+ "registry": "https://registry.npmjs.org"
64
+ }
65
+ }