shopar-plugin 0.2.0 → 0.2.1-alpha.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.
- package/README.md +2 -2
- package/dist/shopar-analytics.js +1 -1
- package/dist/shopar-plugin.esm.js +1 -1
- package/dist/shopar-plugin.js +1 -1
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -32,7 +32,7 @@ There are two distinct ways of integrating the plugin: via Script tag and via NP
|
|
|
32
32
|
Add the following script to your HTML.
|
|
33
33
|
|
|
34
34
|
```html
|
|
35
|
-
<script src="https://cdn.jsdelivr.net/npm/shopar-plugin@
|
|
35
|
+
<script src="https://cdn.jsdelivr.net/npm/shopar-plugin@{{VERSION}}/dist/shopar-plugin.js"></script>
|
|
36
36
|
```
|
|
37
37
|
|
|
38
38
|
It is possible to use a different CDN instead of [jsDelivr](https://www.jsdelivr.com/) (e.g. [cdnjs](https://cdnjs.com/), [unpkg](https://www.unpkg.com/)), or even a relative path if the plugin is distributed as a static asset to your app. Just make sure to set the `baseUrl` parameter accordingly (see [setup options](#shoparpluginsetupoptions) for more details).
|
|
@@ -157,7 +157,7 @@ Options used for the plugin setup:
|
|
|
157
157
|
- `baseUrl` (optional)
|
|
158
158
|
- Type: `string`
|
|
159
159
|
- If provided, defines where the additional ShopAR plugin files are fetched from.
|
|
160
|
-
- Default value: `https://cdn.jsdelivr.net/npm/shopar-plugin@
|
|
160
|
+
- Default value: `https://cdn.jsdelivr.net/npm/shopar-plugin@{{VERSION}}/dist`
|
|
161
161
|
- `strings` (optional)
|
|
162
162
|
- Type: `object`
|
|
163
163
|
- If provided, overrides strings in the UI.
|
package/dist/shopar-analytics.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports):"function"==typeof define&&define.amd?define(["exports"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self).ShopAR__analytics={})}(this,(function(t){"use strict";function e(t){return t&&t.__esModule&&Object.prototype.hasOwnProperty.call(t,"default")?t.default:t}function i(t){return Number.isInteger(t)&&t>=0}function n(t){this.name="ArgumentError",this.message=t}var s=e((function(t,e){if(e=e||{},"function"!=typeof t)throw new n("fetch must be a function");if("object"!=typeof e)throw new n("defaults must be an object");if(void 0!==e.retries&&!i(e.retries))throw new n("retries must be a positive integer");if(void 0!==e.retryDelay&&!i(e.retryDelay)&&"function"!=typeof e.retryDelay)throw new n("retryDelay must be a positive integer or a function returning a positive integer");if(void 0!==e.retryOn&&!Array.isArray(e.retryOn)&&"function"!=typeof e.retryOn)throw new n("retryOn property expects an array or function");return e=Object.assign({retries:3,retryDelay:1e3,retryOn:[]},e),function(s,r){var a=e.retries,o=e.retryDelay,c=e.retryOn;if(r&&void 0!==r.retries){if(!i(r.retries))throw new n("retries must be a positive integer");a=r.retries}if(r&&void 0!==r.retryDelay){if(!i(r.retryDelay)&&"function"!=typeof r.retryDelay)throw new n("retryDelay must be a positive integer or a function returning a positive integer");o=r.retryDelay}if(r&&r.retryOn){if(!Array.isArray(r.retryOn)&&"function"!=typeof r.retryOn)throw new n("retryOn property expects an array or function");c=r.retryOn}return new Promise((function(e,i){var n=function(n){var o="undefined"!=typeof Request&&s instanceof Request?s.clone():s;t(o,r).then((function(t){if(Array.isArray(c)&&-1===c.indexOf(t.status))e(t);else if("function"==typeof c)try{return Promise.resolve(c(n,null,t)).then((function(i){i?u(n,null,t):e(t)})).catch(i)}catch(t){i(t)}else n<a?u(n,null,t):e(t)})).catch((function(t){if("function"==typeof c)try{Promise.resolve(c(n,t,null)).then((function(e){e?u(n,t,null):i(t)})).catch((function(t){i(t)}))}catch(t){i(t)}else n<a?u(n,t,null):i(t)}))};function u(t,e,i){var s="function"==typeof o?o(t,e,i):o;setTimeout((function(){n(++t)}),s)}n(0)}))}}));var r,a;!function(t){t.unknown="unknown",t.user="user",t.organization="organization",t.anonymous="anonymous"}(r||(r={})),function(t){t.api="api",t.query="query",t.ingest="ingest"}(a||(a={}));class o{scope;type;value;remaining;reset;constructor(t=r.unknown,e=a.api,i=0,n=-1,s=new Date){this.scope=t,this.type=e,this.value=i,this.remaining=n,this.reset=s}}function c(t,e,i,n,s){let a=new o;const c=t.headers.get(e.toLowerCase())||r.unknown;a.scope=r[c];const u=t.headers.get(i.toLowerCase())||"",h=parseInt(u,10);isNaN(h)||(a.value=h);const l=t.headers.get(n.toLowerCase())||"",f=parseInt(l,10);isNaN(f)||(a.remaining=f);const m=t.headers.get(s.toLowerCase())||"",y=parseInt(m,10);return isNaN(y)||(a.reset=new Date(1e3*y)),a}class u{config;constructor(t){this.config=t}async doReq(t,e,i={},n={}){let r=`${this.config.baseUrl}${t}`;const o=this._prepareSearchParams(n);o&&(r+=`?${o.toString()}`);const u={...this.config.headers,...i.headers},l=await s(fetch)(r,{retries:3,retryDelay:function(t,e,i){return 1e3*Math.pow(2,t)},retryOn:[503,502,504,500],headers:u,method:e,body:i.body?i.body:void 0});if(204===l.status)return l;if(429==l.status){const t=function(t){let e;return t.url?.endsWith("/ingest")?(e=c(t,"","X-IngestLimit-Limit","X-IngestLimit-Remaining","X-IngestLimit-Reset"),e.type=a.ingest):t.url?.endsWith("/query")||t.url?.endsWith("/_apl")?(e=c(t,"","X-QueryLimit-Limit","X-QueryLimit-Remaining","X-QueryLimit-Reset"),e.type=a.query):(e=c(t,"X-RateLimit-Scope","X-RateLimit-Limit","X-RateLimit-Remaining","X-RateLimit-Reset"),e.type=a.api),e}(l);return Promise.reject(new h(t))}if(401===l.status)return Promise.reject(new Error("Forbidden"));if(l.status>=400){const t=await l.json();return Promise.reject(new Error(t.message))}return await l.json()}post(t,e={},i={}){return this.doReq(t,"POST",e,i)}get(t,e={},i={}){return this.doReq(t,"GET",e,i)}put(t,e={},i={}){return this.doReq(t,"PUT",e,i)}delete(t,e={},i={}){return this.doReq(t,"DELETE",e,i)}_prepareSearchParams=t=>{const e=new URLSearchParams;let i=!1;return Object.keys(t).forEach((n=>{t[n]&&(e.append(n,t[n]),i=!0)})),i?e:null}}class h extends Error{limit;shortcircuit;message="";constructor(t,e=!1){super(),this.limit=t,this.shortcircuit=e,Object.setPrototypeOf(this,h.prototype);const i=h.timeUntilReset(t);this.message=`${t.type} limit exceeded, try again in ${i.minutes}m${i.seconds}s`,t.type==a.api&&(this.message=`${t.scope} `+this.message)}static timeUntilReset(t){const e=t.reset.getTime()-(new Date).getTime(),i=Math.floor(e/1e3%60);return{total:e,minutes:Math.floor(e/1e3/60%60),seconds:i}}}class l{client;constructor({orgId:t="",token:e,url:i}){e||console.warn("Missing Axiom token");const n=i??"https://api.axiom.co",s={Accept:"application/json","Content-Type":"application/json",Authorization:"Bearer "+e};"undefined"==typeof window&&(s["User-Agent"]="axiom-js/1.0.0-rc.1"),t&&(s["X-Axiom-Org-Id"]=t),this.client=new u({baseUrl:n,headers:s,timeout:3e3})}}var f,m,y,p,d,g;!function(t){t.TimestampField="_time";t.Service=class extends l{localPath="/v1/datasets";list=()=>this.client.get(this.localPath);get=t=>this.client.get(this.localPath+"/"+t);create=t=>this.client.post(this.localPath,{body:JSON.stringify(t)});update=(t,e)=>this.client.put(this.localPath+"/"+t,{body:JSON.stringify(e)});delete=t=>this.client.delete(this.localPath+"/"+t);trim=(t,e)=>{const i={maxDuration:e};return this.client.post(this.localPath+"/"+t+"/trim",{body:JSON.stringify(i)})}}}(f||(f={})),function(t){t.Service=class extends l{current=()=>this.client.get("/v1/user")}}(m||(m={}));class w{ingestFn;id;options;events=[];activeFlush=Promise.resolve();nextFlush=setTimeout((()=>{}),0);lastFlush=new Date;constructor(t,e,i){this.ingestFn=t,this.id=e,this.options=i}ingest=t=>{Array.isArray(t)?this.events=this.events.concat(t):this.events.push(t),this.events.length>=1e3||this.lastFlush.getTime()<Date.now()-1e3?(clearTimeout(this.nextFlush),this.activeFlush=this.flush()):(clearTimeout(this.nextFlush),this.nextFlush=setTimeout((()=>{this.activeFlush=this.flush()}),1e3))};flush=async()=>{const t=this.events.splice(0,this.events.length);if(clearTimeout(this.nextFlush),await this.activeFlush,0===t.length)return void(this.lastFlush=new Date);const e=await this.ingestFn(this.id,t,this.options);return this.lastFlush=new Date,e}}class v extends l{datasets;users;localPath="/v1";constructor(t){super(t),this.datasets=new f.Service(t),this.users=new m.Service(t)}ingestRaw=(t,e,i=y.JSON,n=p.Identity,s)=>this.client.post(this.localPath+"/datasets/"+t+"/ingest",{headers:{"Content-Type":i,"Content-Encoding":n},body:e},{"timestamp-field":s?.timestampField,"timestamp-format":s?.timestampFormat,"csv-delimiter":s?.csvDelimiter});queryLegacy=(t,e,i)=>this.client.post(this.localPath+"/datasets/"+t+"/query",{body:JSON.stringify(e)},{"streaming-duration":i?.streamingDuration,nocache:i?.noCache});query=(t,e)=>{const i={apl:t};return e?.startTime&&(i.startTime=e?.startTime),e?.endTime&&(i.endTime=e?.endTime),this.client.post(this.localPath+"/datasets/_apl",{body:JSON.stringify(i)},{"streaming-duration":e?.streamingDuration,nocache:e?.noCache,format:"legacy"})};aplQuery=(t,e)=>this.query(t,e)}class
|
|
1
|
+
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports):"function"==typeof define&&define.amd?define(["exports"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self).ShopAR__analytics={})}(this,(function(t){"use strict";function e(t){return t&&t.__esModule&&Object.prototype.hasOwnProperty.call(t,"default")?t.default:t}function i(t){return Number.isInteger(t)&&t>=0}function n(t){this.name="ArgumentError",this.message=t}var s=e((function(t,e){if(e=e||{},"function"!=typeof t)throw new n("fetch must be a function");if("object"!=typeof e)throw new n("defaults must be an object");if(void 0!==e.retries&&!i(e.retries))throw new n("retries must be a positive integer");if(void 0!==e.retryDelay&&!i(e.retryDelay)&&"function"!=typeof e.retryDelay)throw new n("retryDelay must be a positive integer or a function returning a positive integer");if(void 0!==e.retryOn&&!Array.isArray(e.retryOn)&&"function"!=typeof e.retryOn)throw new n("retryOn property expects an array or function");return e=Object.assign({retries:3,retryDelay:1e3,retryOn:[]},e),function(s,r){var a=e.retries,o=e.retryDelay,c=e.retryOn;if(r&&void 0!==r.retries){if(!i(r.retries))throw new n("retries must be a positive integer");a=r.retries}if(r&&void 0!==r.retryDelay){if(!i(r.retryDelay)&&"function"!=typeof r.retryDelay)throw new n("retryDelay must be a positive integer or a function returning a positive integer");o=r.retryDelay}if(r&&r.retryOn){if(!Array.isArray(r.retryOn)&&"function"!=typeof r.retryOn)throw new n("retryOn property expects an array or function");c=r.retryOn}return new Promise((function(e,i){var n=function(n){var o="undefined"!=typeof Request&&s instanceof Request?s.clone():s;t(o,r).then((function(t){if(Array.isArray(c)&&-1===c.indexOf(t.status))e(t);else if("function"==typeof c)try{return Promise.resolve(c(n,null,t)).then((function(i){i?u(n,null,t):e(t)})).catch(i)}catch(t){i(t)}else n<a?u(n,null,t):e(t)})).catch((function(t){if("function"==typeof c)try{Promise.resolve(c(n,t,null)).then((function(e){e?u(n,t,null):i(t)})).catch((function(t){i(t)}))}catch(t){i(t)}else n<a?u(n,t,null):i(t)}))};function u(t,e,i){var s="function"==typeof o?o(t,e,i):o;setTimeout((function(){n(++t)}),s)}n(0)}))}}));var r,a;!function(t){t.unknown="unknown",t.user="user",t.organization="organization",t.anonymous="anonymous"}(r||(r={})),function(t){t.api="api",t.query="query",t.ingest="ingest"}(a||(a={}));class o{scope;type;value;remaining;reset;constructor(t=r.unknown,e=a.api,i=0,n=-1,s=new Date){this.scope=t,this.type=e,this.value=i,this.remaining=n,this.reset=s}}function c(t,e,i,n,s){let a=new o;const c=t.headers.get(e.toLowerCase())||r.unknown;a.scope=r[c];const u=t.headers.get(i.toLowerCase())||"",h=parseInt(u,10);isNaN(h)||(a.value=h);const l=t.headers.get(n.toLowerCase())||"",f=parseInt(l,10);isNaN(f)||(a.remaining=f);const m=t.headers.get(s.toLowerCase())||"",y=parseInt(m,10);return isNaN(y)||(a.reset=new Date(1e3*y)),a}class u{config;constructor(t){this.config=t}async doReq(t,e,i={},n={}){let r=`${this.config.baseUrl}${t}`;const o=this._prepareSearchParams(n);o&&(r+=`?${o.toString()}`);const u={...this.config.headers,...i.headers},l=await s(fetch)(r,{retries:3,retryDelay:function(t,e,i){return 1e3*Math.pow(2,t)},retryOn:[503,502,504,500],headers:u,method:e,body:i.body?i.body:void 0});if(204===l.status)return l;if(429==l.status){const t=function(t){let e;return t.url?.endsWith("/ingest")?(e=c(t,"","X-IngestLimit-Limit","X-IngestLimit-Remaining","X-IngestLimit-Reset"),e.type=a.ingest):t.url?.endsWith("/query")||t.url?.endsWith("/_apl")?(e=c(t,"","X-QueryLimit-Limit","X-QueryLimit-Remaining","X-QueryLimit-Reset"),e.type=a.query):(e=c(t,"X-RateLimit-Scope","X-RateLimit-Limit","X-RateLimit-Remaining","X-RateLimit-Reset"),e.type=a.api),e}(l);return Promise.reject(new h(t))}if(401===l.status)return Promise.reject(new Error("Forbidden"));if(l.status>=400){const t=await l.json();return Promise.reject(new Error(t.message))}return await l.json()}post(t,e={},i={}){return this.doReq(t,"POST",e,i)}get(t,e={},i={}){return this.doReq(t,"GET",e,i)}put(t,e={},i={}){return this.doReq(t,"PUT",e,i)}delete(t,e={},i={}){return this.doReq(t,"DELETE",e,i)}_prepareSearchParams=t=>{const e=new URLSearchParams;let i=!1;return Object.keys(t).forEach((n=>{t[n]&&(e.append(n,t[n]),i=!0)})),i?e:null}}class h extends Error{limit;shortcircuit;message="";constructor(t,e=!1){super(),this.limit=t,this.shortcircuit=e,Object.setPrototypeOf(this,h.prototype);const i=h.timeUntilReset(t);this.message=`${t.type} limit exceeded, try again in ${i.minutes}m${i.seconds}s`,t.type==a.api&&(this.message=`${t.scope} `+this.message)}static timeUntilReset(t){const e=t.reset.getTime()-(new Date).getTime(),i=Math.floor(e/1e3%60);return{total:e,minutes:Math.floor(e/1e3/60%60),seconds:i}}}class l{client;constructor({orgId:t="",token:e,url:i}){e||console.warn("Missing Axiom token");const n=i??"https://api.axiom.co",s={Accept:"application/json","Content-Type":"application/json",Authorization:"Bearer "+e};"undefined"==typeof window&&(s["User-Agent"]="axiom-js/1.0.0-rc.1"),t&&(s["X-Axiom-Org-Id"]=t),this.client=new u({baseUrl:n,headers:s,timeout:3e3})}}var f,m,y,p,d,g;!function(t){t.TimestampField="_time";t.Service=class extends l{localPath="/v1/datasets";list=()=>this.client.get(this.localPath);get=t=>this.client.get(this.localPath+"/"+t);create=t=>this.client.post(this.localPath,{body:JSON.stringify(t)});update=(t,e)=>this.client.put(this.localPath+"/"+t,{body:JSON.stringify(e)});delete=t=>this.client.delete(this.localPath+"/"+t);trim=(t,e)=>{const i={maxDuration:e};return this.client.post(this.localPath+"/"+t+"/trim",{body:JSON.stringify(i)})}}}(f||(f={})),function(t){t.Service=class extends l{current=()=>this.client.get("/v1/user")}}(m||(m={}));class w{ingestFn;id;options;events=[];activeFlush=Promise.resolve();nextFlush=setTimeout((()=>{}),0);lastFlush=new Date;constructor(t,e,i){this.ingestFn=t,this.id=e,this.options=i}ingest=t=>{Array.isArray(t)?this.events=this.events.concat(t):this.events.push(t),this.events.length>=1e3||this.lastFlush.getTime()<Date.now()-1e3?(clearTimeout(this.nextFlush),this.activeFlush=this.flush()):(clearTimeout(this.nextFlush),this.nextFlush=setTimeout((()=>{this.activeFlush=this.flush()}),1e3))};flush=async()=>{const t=this.events.splice(0,this.events.length);if(clearTimeout(this.nextFlush),await this.activeFlush,0===t.length)return void(this.lastFlush=new Date);const e=await this.ingestFn(this.id,t,this.options);return this.lastFlush=new Date,e}}class v extends l{datasets;users;localPath="/v1";constructor(t){super(t),this.datasets=new f.Service(t),this.users=new m.Service(t)}ingestRaw=(t,e,i=y.JSON,n=p.Identity,s)=>this.client.post(this.localPath+"/datasets/"+t+"/ingest",{headers:{"Content-Type":i,"Content-Encoding":n},body:e},{"timestamp-field":s?.timestampField,"timestamp-format":s?.timestampFormat,"csv-delimiter":s?.csvDelimiter});queryLegacy=(t,e,i)=>this.client.post(this.localPath+"/datasets/"+t+"/query",{body:JSON.stringify(e)},{"streaming-duration":i?.streamingDuration,nocache:i?.noCache});query=(t,e)=>{const i={apl:t};return e?.startTime&&(i.startTime=e?.startTime),e?.endTime&&(i.endTime=e?.endTime),this.client.post(this.localPath+"/datasets/_apl",{body:JSON.stringify(i)},{"streaming-duration":e?.streamingDuration,nocache:e?.noCache,format:"legacy"})};aplQuery=(t,e)=>this.query(t,e)}class b extends v{batch={};ingest=(t,e,i)=>{const n=function(t,e){return`${t}:${e?.timestampField||"-"}:${e?.timestampFormat||"-"}:${e?.csvDelimiter||"-"}`}(t,i);return this.batch[n]||(this.batch[n]=new w(((t,e,i)=>{const n=(Array.isArray(e)?e:[e]).map((t=>JSON.stringify(t))).join("\n");return this.ingestRaw(t,n,y.NDJSON,p.Identity,i)}),t,i)),this.batch[n].ingest(e)};flush=async()=>{let t=[];for(const e in this.batch)t.push(this.batch[e].flush());await Promise.all(t)}}let x;!function(t){t.JSON="application/json",t.NDJSON="application/x-ndjson",t.CSV="text/csv"}(y||(y={})),function(t){t.Identity="",t.GZIP="gzip"}(p||(p={})),function(t){t.Count="count",t.Distinct="distinct",t.Sum="sum",t.Avg="avg",t.Min="min",t.Max="max",t.Topk="topk",t.Percentiles="percentiles",t.Histogram="histogram",t.Variance="variance",t.Stdev="stdev",t.ArgMin="argmin",t.ArgMax="argmax",t.MakeSet="makeset",t.MakeSetIf="makesetif",t.CountIf="countif",t.CountDistinctIf="distinctif"}(d||(d={})),function(t){t.And="and",t.Or="or",t.Not="not",t.Equal="==",t.NotEqual="!=",t.Exists="exists",t.NotExists="not-exists",t.GreaterThan=">",t.GreaterThanOrEqualTo=">=",t.LessThan="<",t.LessThanOrEqualTo="<=",t.Gt="gt",t.Gte="gte",t.Lt="lt",t.Lte="lte",t.StartsWith="starts-with",t.NotStartsWith="not-starts-with",t.EndsWith="ends-with",t.NotEndsWith="not-ends-with",t.Contains="contains",t.NotContains="not-contains",t.Regexp="regexp",t.NotRegexp="not-regexp"}(g||(g={})),t.initializeImpl=function(){x=new b({token:"xaat-16d05fdd-4ab9-4990-acba-7cee24974bfb"})},t.trackEventImpl=function(t,e){x.ingest("shopar-plugin-alpha",Object.assign({name:t},e))}}));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
function e(e,t,n,r){return new(n||(n=Promise))((function(o,i){function a(e){try{l(r.next(e))}catch(e){i(e)}}function s(e){try{l(r.throw(e))}catch(e){i(e)}}function l(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(a,s)}l((r=r.apply(e,t||[])).next())}))}!function(){const e={css:".shopar-btn-container{position:absolute;width:100%;bottom:0;padding-bottom:2rem;display:flex;justify-content:center;gap:.5rem;pointer-events:none}.shopar-btn{padding:.5rem .75rem;display:flex;justify-content:center;align-items:center;gap:.25rem;background-color:#fff;border:1px solid #ddd;border-radius:9999px;cursor:pointer;pointer-events:auto}.shopar-btn:hover{background-color:#f5f5f5}.shopar-loading-container{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:1rem;background-color:#fff}.shopar-loading-text{text-align:center}.shopar-loading-bar-bg{width:80%;height:.5rem;background-color:#e5e7eb;border-radius:9999px}.shopar-loading-bar-fg{background-color:#1434f7;border-radius:9999px;transition:none;transform:translateX(-100%);will-change:transform}.shopar-loading-bar-fg.active{transition:transform 5s cubic-bezier(0,0,.2,1);transform:none}.shopar-qr{display:flex;flex-direction:column;justify-content:center;align-items:center;background-color:#fff}.shopar-ar-prompt{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:1rem;background-color:#1e293bb2;transition:.3s ease-in-out opacity}.shopar-ar-prompt-text{text-align:center;color:#fff}.shopar-ar-prompt-img{max-width:80%;max-height:50%;object-fit:contain}"};try{if(process)return process.env=Object.assign({},process.env),void Object.assign(process.env,e)}catch(e){}globalThis.process={env:e}}(),"function"==typeof SuppressedError&&SuppressedError;class t extends Error{constructor(e){super(`ShopAR Plugin: ${e}`)}}const n=[Uint8Array,Uint32Array],r=n.length-2,o=["addEventListener","alert","atob","blur","btoa","cancelAnimationFrame","localStorage","location","locationbar","hash","hasOwnProperty","host","hostname","href","requestAnimationFrame"],i=[2,12,7,1],a=window[o[i[i[r]]]][o[i[i[i.length-1]]]],s=a.charCodeAt(r),l=s^s,c=new n[1]([l]);function u(){const e=(new TextEncoder).encode(a),t=o.map((e=>e.length));for(let n=0;n<e.length;n++)e[n]^=t[n%t.length];return window[o[t[2]]](String.fromCodePoint(...e))}const d=[1e3,2e3,4e3],h=d.length;function f(t,n=0){return e(this,void 0,void 0,(function*(){try{return yield t()}catch(e){if(n>=h)throw e;return yield new Promise((e=>setTimeout(e,d[n]))),f(t,n+1)}}))}const p=["Glasses","Shoes","Watches"],m=["Shoes"];const g="0.2.0";let v=`https://cdn.jsdelivr.net/npm/shopar-plugin@${g}/dist`;const w={update:e=>{null!=e&&(v=e.endsWith("/")?e.substring(0,e.length-1):e)},toString:()=>v};function y(t){return e(this,void 0,void 0,(function*(){if("function"!=typeof importScripts){const e=document.createElement("script");return e.setAttribute("src",t),e.setAttribute("crossorigin","anonymous"),new Promise((t=>{e.addEventListener("load",(()=>t()),!1),e.addEventListener("error",(()=>t()),!1),document.body.appendChild(e)}))}importScripts(t.toString())}))}let b;const E=(()=>{const e=(()=>{var e;if(null===(e=document.documentElement.getAttribute("itemtype"))||void 0===e?void 0:e.includes("schema.org/SearchResultsPage"))return!0;const t=null!=document.head?Array.from(document.head.querySelectorAll("meta")):[];for(const e of t)if("viewport"===e.name)return!0;return!1})();return e||console.warn('No <meta name="viewport"> detected; ShopAR will cap pixel density at 1.'),()=>e?window.devicePixelRatio:1})();let A,R,S;function C(e){const t=function(e){const t=new R.DataTexture(e.data,e.width,e.height,void 0,e.type,void 0,R.ClampToEdgeWrapping,R.ClampToEdgeWrapping,R.LinearFilter,R.LinearFilter,1,R.LinearSRGBColorSpace);return t.flipY=!0,t.generateMipmaps=!1,t.needsUpdate=!0,t}(S.parse(e));return t.mapping=R.EquirectangularReflectionMapping,t.colorSpace=R.LinearSRGBColorSpace,t}const I=45,P=45,x=3,M=1.5,k=1,T=.5;let L,U,$,D,_,N=!1;const j=4,O=.001,F=1e-7,W=10,q=11,G=1/(q-1),z="function"==typeof Float32Array;function Q(e,t,n,r){if(!(0<=e&&e<=1&&0<=n&&n<=1))throw new Error("bezier x values must be in [0, 1] range");if(e===t&&n===r)return Z;const o=z?new Float32Array(q):new Array(q);for(let t=0;t<q;++t)o[t]=H(t*G,e,n);function i(t){let r=0,i=1;const a=q-1;for(;i!==a&&o[i]<=t;++i)r+=G;--i;const s=r+(t-o[i])/(o[i+1]-o[i])*G,l=X(s,e,n);return l>=O?function(e,t,n,r){for(let o=0;o<j;++o){const o=X(t,n,r);if(0===o)return t;t-=(H(t,n,r)-e)/o}return t}(t,s,e,n):0===l?s:function(e,t,n,r,o){let i,a,s=0;do{a=t+(n-t)/2,i=H(a,r,o)-e,i>0?n=a:t=a}while(Math.abs(i)>F&&++s<W);return a}(t,r,r+G,e,n)}return function(e){return 0===e||1===e?e:H(i(e),t,r)}}function V(e,t){return 1-3*t+3*e}function K(e,t){return 3*t-6*e}function B(e){return 3*e}function H(e,t,n){return((V(t,n)*e+K(t,n))*e+B(t))*e}function X(e,t,n){return 3*V(t,n)*e*e+2*K(t,n)*e+B(t)}function Z(e){return e}function Y(e){if("hold"===e.type)return()=>0;if("bezier"===e.type){const t=Q(e.x1,e.y1,e.x2,e.y2);return e=>t(e)}throw new Error(`Unknown interpolation: ${e}`)}function J(e){if(e.length<2)throw new Error("Expected at least two key frames.");const t=e[e.length-1].time,n=[...e].sort(((e,t)=>e.time-t.time)).map((({time:e,value:t,interpolation:n})=>({time:e,value:t,interpolate:Y(n)})));let r=0,o=n[0].value;return{reset:()=>{r=0},update:e=>{for(r+=e;r>=t;)r-=t;for(let e=0;e<n.length-1;e++){const t=n[e],i=n[e+1];if(r>=t.time&&r<i.time){const e=t.interpolate((r-t.time)/(i.time-t.time));o=t.value+e*(i.value-t.value)}}},get:()=>o}}const ee="#",te="time",ne="interpolation",re="yaw",oe="pitch",ie="fov",ae=[te,re,oe,ie,ne],se="s",le="ms",ce=1e3,ue="deg",de="rad",he=Math.PI/180,fe="ease-in-out",pe="cubic-bezier(",me=")";function ge(e){if("string"==typeof e)return function(e){const[t,...n]=function(e){return e.split(/\r?\n/).map((e=>function(e){const t=e.indexOf(ee);return(-1!==t?e.substring(0,t):e).trim()}(e))).filter((e=>""!==e))}(e);if(null==t)throw new Error("Header missing.");const r=function(e){const t=[];for(let n=0;n<e.length;n++){const r=e[n];if(!ae.includes(r))throw new Error(`Invalid token in header: '${r}'.`);if(t.includes(r))throw new Error(`Duplicate token in header: '${r}'.`);t.push(r)}if(!t.includes(te))throw new Error(`Missing required token: '${te}'.`);return t}(t.split(/\s+/)),o={};if(n.length<2)throw new Error("Expected at least two key frames.");for(const e of n){const{theta:t,phi:n,fov:i}=ve(r,e);null!=t&&(null==o.theta&&(o.theta=[]),o.theta.push(t)),null!=n&&(null==o.phi&&(o.phi=[]),o.phi.push(n)),null!=i&&(null==o.fov&&(o.fov=[]),o.fov.push(i))}if(0===Object.values(o).length)throw new Error("At least one parameter should be animated.");return o}(e);if(Array.isArray(e))return function(e){var t;const n={};if(e.length<2)throw new Error("Expected at least two key frames.");for(const r of e){const{time:e,pitch:o,yaw:i,fov:a}=r;if(null==e)throw new Error("Time missing.");const s=ye(null!==(t=r.interpolation)&&void 0!==t?t:fe);null!=i&&(null==n.theta&&(n.theta=[]),n.theta.push({time:e,value:i*he,interpolation:s})),null!=o&&(null==n.phi&&(n.phi=[]),n.phi.push({time:e,value:o*he,interpolation:s})),null!=a&&(null==n.fov&&(n.fov=[]),n.fov.push({time:e,value:a*he,interpolation:s}))}if(0===Object.values(n).length)throw new Error("At least one parameter should be animated.");if(Object.values(n).every((t=>t.length!==e.length)))throw new Error("All parameters should have the same key frame count.");return n}(e);throw new Error("Expected string or key frame config array.")}function ve(e,t){const n=t.match(/[^()\s]+(\(.*?\))?/g);if(null==n||n.length<e.length)throw new Error(`Missing data for fields: '${e.filter((e=>!(null==n?void 0:n.includes(e)))).join(", ")}'.`);if(n.length>e.length)throw new Error(`Excess data: '${n.filter((t=>!e.includes(t))).join(", ")}'.`);const r=e.indexOf(te),o=function(e){if(e.endsWith(le))return Ee(e.substring(0,e.length-le.length));if(e.endsWith(se))return Ee(e.substring(0,e.length-se.length))*ce;return Ee(e)}(n[r]),i=e.indexOf(ne),a=ye(-1===i?fe:n[i]),s={};for(let t=0;t<n.length;t++){if(t===r||t===i)continue;const l=e[t],c=n[t];switch(l){case re:s.theta={time:o,value:we(c),interpolation:a};break;case oe:s.phi={time:o,value:we(c),interpolation:a};break;case ie:s.fov={time:o,value:we(c),interpolation:a};break;default:throw new Error(`Unhandled value for header '${l}'.`)}}return s}function we(e){return e.endsWith(ue)?Ee(e.substring(0,e.length-ue.length))*he:e.endsWith(de)?Ee(e.substring(0,e.length-de.length)):Ee(e)*he}function ye(e){if("hold"===e)return{type:"hold"};if("linear"===e)return be(0,0,1,1);if("sine"===e)return be(.37,0,.63,1);if("sine-in"===e)return be(.12,0,.39,0);if("sine-out"===e)return be(.61,1,.88,1);if("ease"===e)return be(.25,.1,.25,1);if("ease-in"===e)return be(.42,0,1,1);if("ease-out"===e)return be(0,0,.58,1);if("ease-in-out"===e)return be(.42,0,.58,1);if(e.startsWith(pe)&&e.endsWith(me)){const t=e.substring(pe.length,e.length-me.length).split(/\s*,\s*/);if(4!==t.length)throw new Error(`Expected 4 parameters for the Bezier curve, but got '${t}'.`);return{type:"bezier",x1:Ee(t[0]),y1:Ee(t[1]),x2:Ee(t[2]),y2:Ee(t[3])}}throw new Error(`Expected an interpolation token, but found: ${e}`)}function be(e,t,n,r){return{type:"bezier",x1:e,y1:t,x2:n,y2:r}}function Ee(e){const t=Number.parseFloat(e);if(Number.isNaN(t))throw new Error(`Expected a numeric value, but got: ${e}`);return t}const Ae=300,Re=2e3,Se=.05,Ce=2*Math.PI/32,Ie=ye("hold"),Pe=ye("sine"),xe=ye("sine-in"),Me=ye("sine-out");let ke;const Te=0;let Le,Ue,$e,De=!1,_e=1,Ne=1,je=1;const Oe=1;let Fe;const We=new Map;function qe(t,n,r){const o=t.getContext("2d");null==o&&console.warn("2D context missing.");let i,a,s,l,c,u,d,h,f,p,m,g,v,w=!1,y=!0,b=!1,E=!0,k=!1,N=!1,j=0,O=1,F=1,W=1;const q={threeInit:()=>{w||(Ge(),i=new Ue.Scene,a=new Ue.PerspectiveCamera(25,1,.5),s=new Le.OrbitControls(a,t),s.setInteractionEnabled(E),({renderShadow:c,shadowGroup:l}=function(e){const t=new L.WebGLRenderTarget(512,512);t.texture.generateMipmaps=!1;const n=new L.WebGLRenderTarget(512,512);n.texture.generateMipmaps=!1;const r=new L.Group;r.position.y=-.7;const o=new L.PlaneGeometry(I,P).rotateX(Math.PI/2),i=new L.MeshBasicMaterial({map:t.texture,opacity:T,transparent:!0,depthWrite:!1}),a=new L.Mesh(o,i);a.renderOrder=1,a.scale.y=-1,r.add(a);const s=new L.Mesh(o);s.visible=!1,r.add(s);const l=new L.OrthographicCamera(-I/2,I/2,P/2,-P/2,0,x);function c(e){s.visible=!0,D.uniforms.tDiffuse.value=t.texture,D.uniforms.h.value=1*e/256,s.material=D,U.setRenderTarget(n),U.render(s,l),_.uniforms.tDiffuse.value=n.texture,_.uniforms.v.value=1*e/256,s.material=_,U.setRenderTarget(t),U.render(s,l),s.visible=!1}return l.rotation.x=Math.PI/2,r.add(l),{shadowGroup:r,renderShadow:()=>{const n=e.background;e.background=null,e.overrideMaterial=$;const r=U.getClearAlpha();U.setClearAlpha(0),U.setRenderTarget(t),U.render(e,l),e.overrideMaterial=null,c(M),c(.4*M),U.setRenderTarget(null),U.setClearAlpha(r),e.background=n}}}(i)),w=!0)},threeParse:(t,n,r)=>e(this,void 0,void 0,(function*(){return null!=u&&d===r||(yield u,u=(()=>e(this,void 0,void 0,(function*(){var e,r;return R=(e=Le).THREE,S=new e.RGBELoader,i.environment=C(n),function(e,t){const{THREE:n}=t;A=(new t.GLTFLoader).setDRACOLoader((new t.DRACOLoader).setDecoderPath(`https://cdn.jsdelivr.net/npm/three@0.${n.REVISION}.0/examples/jsm/libs/draco/gltf/`)).setKTX2Loader((new t.KTX2Loader).setTranscoderPath(`https://cdn.jsdelivr.net/npm/three@0.${n.REVISION}.0/examples/jsm/libs/basis/`).detectSupport(e)).setMeshoptDecoder(t.MeshoptDecoder)}(Fe,Le),r=t,A.parseAsync(r.buffer,"")})))(),d=r),u})),threeLoad:(e,t)=>{i.clear(),i.add(e.scene);const n=(new Ue.Box3).setFromObject(e.scene);l.position.y=n.min.y-Te,i.add(l),c(),i.traverse((e=>{if(e instanceof Ue.Mesh){const t=e.material;t.depthWrite=!0,t instanceof Ue.MeshPhysicalMaterial&&t.transmissionMap&&(t.transmission=1,t.toneMapped=!1,t.fog=!1,t.needsUpdate=!0)}}));const r=n.min.clone().add(n.max).divideScalar(2),o=Math.sqrt(Le.reduceVertices(e.scene,((e,t)=>Math.max(e,r.distanceToSquared(t))),0));s.reset(r,o,function(e,t){var n;const r={Glasses:new t(67.5,15,90),Shoes:new t(-55,30,30),Watches:new t(0,-10,40),Handbags:new t(40,0,0),Rings:new t(0,0,10)};return(null==e?r.Glasses:null!==(n=r[e])&&void 0!==n?n:r.Glasses).normalize()}(t,Ue.Vector3)),N=!0},threePaused:()=>y,threeResume:()=>{y=!1,Fe.setAnimationLoop(ze),t.style.visibility="visible",j=0,null==f||f.reset(),null==p||p.reset(),null==m||m.reset(),null==g||g.reset(),null==v||v.reset()},threePause:()=>{y=!0,function(){for(const{threePaused:e}of We.values())if(!e())return!1;return!0}()&&Fe.setAnimationLoop(null),t.style.visibility="hidden",n.style.visibility="hidden"},threeSetToneMapping:e=>({ACES:Ue.ACESFilmicToneMapping,Linear:Ue.LinearToneMapping,Neutral:Ue.NeutralToneMapping}[e||"ACES"]||Ue.ACESFilmicToneMapping),threeIsInteractive:()=>E,threeSetInteractive:e=>{E=e,null==s||s.setInteractionEnabled(E)},threeSetOnInteracted:e=>{s.removeEventListener("change",h),h=e,s.addEventListener("change",e)},threeInitPromptAnimation:()=>{var e;e=s.getTheta(),f=J([{time:0,value:e,interpolation:Ie},{time:Ae,value:e,interpolation:Me},{time:Ae+Re/4,value:e+Ce,interpolation:Pe},{time:Ae+3*Re/4,value:e-Ce,interpolation:xe},{time:Ae+Re,value:e,interpolation:Ie},{time:Ae+2*Re,value:e,interpolation:Ie}]),p=null,m=null,g=J([{time:0,value:0,interpolation:Ie},{time:Ae,value:1,interpolation:Ie},{time:Ae+Re,value:0,interpolation:Ie},{time:Ae+2*Re,value:0,interpolation:Ie}]),v=J([{time:0,value:0,interpolation:Ie},{time:Ae,value:0,interpolation:Me},{time:Ae+Re/4,value:-Se,interpolation:Pe},{time:Ae+3*Re/4,value:Se,interpolation:xe},{time:Ae+Re,value:0,interpolation:Ie},{time:Ae+2*Re,value:0,interpolation:Ie}])},threeInitCameraAnimation:e=>{const{theta:t,phi:n,fov:r}=e;f=null!=t?J(t):null,p=null!=n?J(n):null,m=null!=r?J(r):null},preRender_:e=>{if(!w||y)return;e=performance.now();const t=0!==j?e-j:0;j=e,N&&(b=!0,N=!1),k||(s.hasUserInteracted()?(k=!0,f=null,p=null,m=null,g=null,v=null):(null==f||f.update(t),null==p||p.update(t),null==m||m.update(t),null==g||g.update(t),null==v||v.update(t),null!=f&&(s.setTheta(f.get()),b=!0),null!=p&&(s.setPhi(p.get()),b=!0),null!=m&&(s.setFovRadians(m.get()),b=!0))),s.update()&&(b=!0)},shouldRender_:()=>!(!w||y)&&b,render_:()=>{const e=Fe.toneMapping;Fe.setViewport(0,0,t.width,t.height),Fe.render(i,a),Fe.toneMapping=e,b=!1,null!=o&&(o.clearRect(0,0,t.width,t.height),$e.width>0&&$e.height>0&&o.drawImage($e,0,Ne-t.height,t.width,t.height,0,0,t.width,t.height),n.style.visibility=E&&!k?"visible":"hidden",null!=g&&(r.style.opacity=`${g.get()}`),null!=v&&(r.style.transform=`translateX(${v.get()*Math.min(O,F)}px)`))},updateSize_:()=>{const{clientWidth:e,clientHeight:n}=t;e===O&&n===F&&je===W||(t.width=Math.ceil(e*je*Oe),t.height=Math.ceil(n*je*Oe),O=e,F=n,W=je,b=!0)},target_:t};return We.set(t,q),q}function Ge(){if(De)return;Le=window.ShopAR__THREE,Ue=Le.THREE,$e=document.createElement("canvas");var e,t;$e.style.position="block",Fe=new Ue.WebGLRenderer({powerPreference:"high-performance",canvas:$e,antialias:!0,alpha:!0}),Fe.outputColorSpace=Ue.SRGBColorSpace,Fe.toneMapping=Ue.ACESFilmicToneMapping,Fe.setClearColor(new Ue.Color(16777215)),e=Fe,t=Le,N||(L=t.THREE,U=e,$=new L.MeshDepthMaterial,$.userData.darkness={value:k},$.onBeforeCompile=e=>{e.uniforms.darkness=$.userData.darkness;const t=e.fragmentShader.replace("gl_FragColor = vec4( vec3( 1.0 - fragCoordZ ), opacity );","gl_FragColor = vec4( vec3( 0.0 ), ( 1.0 - fragCoordZ ) * darkness );");e.fragmentShader=`uniform float darkness;\n${t}`},$.depthTest=!1,$.depthWrite=!1,D=new L.ShaderMaterial(t.HorizontalBlurShader),D.depthTest=!1,_=new L.ShaderMaterial(t.VerticalBlurShader),_.depthTest=!1,N=!0),Qe(),De=!0}function ze(e){Qe(),Fe.clear();for(const{preRender_:t,shouldRender_:n,render_:r}of We.values())t(e),n()&&r()}function Qe(){let e=0,t=0;for(const{target_:n}of We.values()){const{clientWidth:r,clientHeight:o}=n;e=Math.max(e,r),t=Math.max(t,o)}const n=E();e=Math.ceil(e*n*Oe),t=Math.ceil(t*n*Oe),e===_e&&t===Ne&&n===je||(_e=e,Ne=t,je=n,Fe.setSize(_e,Ne,!1));for(const{updateSize_:e}of We.values())e()}const Ve={"loading.ar":"Loading Try On...","loading.3d":"Loading 3D..."},Ke=Object.keys(Ve);function Be(e){return Ve[e]}const He="shopar-error";function Xe(e,t){const n=document.createElementNS("http://www.w3.org/2000/svg","svg");n.setAttribute("width",e),n.setAttribute("height",e);{const r=document.createElementNS("http://www.w3.org/2000/svg","image");r.setAttributeNS("http://www.w3.org/1999/xlink","xlink:href",t),r.setAttribute("width",e),r.setAttribute("height",e),n.appendChild(r)}return n}function Ze(e,t,n,r){const o=document.createElement("button");o.id=e,o.type="button",o.className="shopar-btn";{const e=Xe("1.75rem",r);o.appendChild(e)}{const e=document.createElement("span");e.textContent=t,o.appendChild(e)}o.ariaLabel=n;return o.style.display="none",o}const Ye="shopar-control";const Je="shopar-deepar-output";function et(e){const t=document.createElement("div");t.classList.add("shopar-loading-container",e);const n=t.style;return n.position="absolute",n.top="0",n.left="0",n.width="100%",n.height="100%",t}function tt(e,t){const n=document.createElement("div");return n.classList.add("shopar-loading-text",e),n.textContent=t,n.style.textAlign="center",n}function nt(e){const t=document.createElement("div");t.classList.add("shopar-loading-bar-bg",e);const n=t.style;return n.position="relative",n.overflow="hidden",t}function rt(e){const t=document.createElement("div");t.classList.add("shopar-loading-bar-fg",e);const n=t.style;return n.width="100%",n.height="100%",t}const ot="shopar-main";const it="shopar-qr-output";const at="shopar-three-output";var st;!function(e){e[e.None=0]="None",e[e.QR=1]="QR",e[e.AR=2]="AR",e[e.Preview=3]="Preview"}(st||(st={}));let lt=!1;function ct(){lt||(!function(){try{const e=document.createElement("style"),t=process.env.css;null!=t&&(e.innerHTML=t);const n=document.head;n.insertBefore(e,n.children[0])}catch(e){console.warn("Failed to write default ShopAR Plugin CSS.")}}(),lt=!0)}function ut(){ct();const e=function(){const e=document.createElement("div");e.id=ot;const t=e.style;return t.position="absolute",t.top="0",t.bottom="0",t.left="0",t.right="0",e}(),t=function(){const e=document.createElement("div");return e.style.textAlign="center",e}(),n=function(){const e=new Image,t=e.style;return t.maxWidth="100%",t.maxHeight="100%",e}(),r=function(e,t){const n=document.createElement("div");n.id=it;const r=n.style;r.position="absolute",r.top="0",r.left="0",r.width="100%",r.height="100%",r.display="none";const o=document.createElement("div");o.className="shopar-qr";const i=o.style;i.position="relative",i.top="0",i.left="0",i.width="100%",i.height="100%",n.appendChild(o),o.appendChild(e);const a=document.createElement("div");return a.appendChild(t),o.appendChild(a),n}(t,n);e.appendChild(r);const o=function(){const e=document.createElement("div");e.id=Je;const t=e.style;return t.position="absolute",t.top="0",t.left="0",t.width="100%",t.height="100%",t.display="none",e}();e.appendChild(o);const i=function(){const e=document.createElement("canvas");e.id=at;const t=e.style;return t.position="absolute",t.top="0",t.left="0",t.width="100%",t.height="100%",t.visibility="hidden",e}();e.appendChild(i);const a=function(){const e=document.createElement("div");return e.className="shopar-ar-prompt-text",e}(),s=function(){const e=new Image;return e.className="shopar-ar-prompt-img",e}(),l=function(e,t){const n=document.createElement("div");n.className="shopar-ar-prompt";const{style:r}=n;return r.position="absolute",r.width="100%",r.height="100%",r.pointerEvents="none",r.opacity="0",n.appendChild(e),n.appendChild(t),n}(a,s);e.appendChild(l);const c=function(){const e=Xe("2rem",`${w}/img/prompt/3d-interaction.svg`),{style:t}=e;return t.transition="opacity 0.3s",t.opacity="0",e}(),u=function(e){const t=document.createElement("div"),{style:n}=t;return n.visibility="hidden",n.position="absolute",n.width="100%",n.height="100%",n.display="flex",n.justifyContent="center",n.alignItems="center",n.pointerEvents="none",t.appendChild(e),t}(c);e.appendChild(u);const d=et("shopar-ar-loading-container"),h=tt("shopar-ar-loading-text",Be("loading.ar"));d.appendChild(h);const f=nt("shopar-ar-loading-bar-bg"),p=rt("shopar-ar-loading-bar-fg");f.appendChild(p),d.appendChild(f),e.appendChild(d);const m=et("shopar-3d-loading-container"),g=tt("shopar-3d-loading-text",Be("loading.3d"));m.appendChild(g);const v=nt("shopar-3d-loading-bar-bg"),y=rt("shopar-3d-loading-bar-fg");v.appendChild(y),m.appendChild(v),e.appendChild(m);const b=function(){const e=document.createElement("div");return e.className="shopar-error-text",e.style.textAlign="center",e}(),E=function(e){const t=document.createElement("div");t.id=He;const n=t.style;n.position="absolute",n.width="100%",n.height="100%",n.display="none";const r=document.createElement("div"),o=r.style;return o.position="absolute",o.width="100%",o.height="100%",o.backgroundColor="#ffffff",o.display="flex",o.flexDirection="column",o.justifyContent="center",o.alignItems="center",t.appendChild(r),r.appendChild(e),t}(b);e.appendChild(E);const A=function(){const e=document.createElement("div");return e.id=Ye,e.role="group",e.ariaLabel="Preview type chooser",e.className="shopar-btn-container",e.style.display="none",e}();e.appendChild(A);const R=Ze("shopar-btn-vto","Try-on","Launch ShopAR virtual try-on","data:image/svg+xml,%3Csvg%20xmlns=%22http://www.w3.org/2000/svg%22/%3E");A.appendChild(R);const S=Ze("shopar-btn-3d","3D","Launch ShopAR 3D preview",`${w}/img/icons/cube.svg`);A.appendChild(S);const C=Ze("shopar-btn-close","Close","Close ShopAR view",`${w}/img/icons/close.svg`);A.append(C);let I,P=st.None,x=!1,M=!1,k=!1,T=!1;function L(){p.classList.remove("active"),d.style.visibility="hidden"}function U(){y.classList.remove("active"),m.style.visibility="hidden"}return{setTargetElement:function(t){t.style.position="relative",t.appendChild(e)},getQRTarget:function(){return r},getQRImage:function(){return n},getDeepARTarget:function(){return o},getDeepARPrompt:function(){return l},getThreeTarget:function(){return i},getThreePrompt:function(){return u},getThreePromptImage:function(){return c},customizeDeepARPrompt:function(e,t){a.textContent=e,s.src=t},customizeCameraError:function(e){b.textContent=null!=e?e:"Please reload page and allow camera access to continue"},customizeQRPrompt:function(e){t.textContent=null!=e?e:"Scan on mobile or tablet to try on"},setVisibilityParameters:function(e,t,n,r,o){var i;x=e,M=t,k=n,T=r,I=o,dt(A,x),dt(R,x&&(k||M)&&P===st.None),dt(S,x&&T&&P===st.None),dt(C,x&&P!==st.None),L(),U(),x||""===(i=E).style.display&&dt(i,!1)},getUIState:function(){return P},setUIState:function(e){P=e,P===st.None?(L(),U(),x&&(dt(E,!1),dt(C,!1),(M||k)&&dt(R,!0),T&&dt(S,!0))):P!==st.QR&&P!==st.AR&&P!==st.Preview||x&&(dt(E,!1),dt(R,!1),dt(S,!1),dt(C,!0))},setDefaultUIActions:function(e,t,n){x&&((M||k)&&(!function(e){const t={Glasses:"glasses.svg",Shoes:"shoe.svg",Watches:"watch.svg"},n=null!=e&&t[e]||t.Glasses,r=`${w}/img/icons/${n}`;R.firstChild.firstChild.setAttributeNS("http://www.w3.org/1999/xlink","xlink:href",r)}(I),R.onclick=e),T&&(S.onclick=t),C.onclick=n)},startDeepARLoading:function(){p.classList.add("active"),d.style.visibility="visible"},stopDeepARLoading:L,startThreeLoading:function(){y.classList.add("active"),m.style.visibility="visible"},stopThreeLoading:U,showCameraError:function(){x&&dt(E,!0)}}}function dt(e,t){e.style.display=t?"":"none"}const ht=new Map;function ft(t){let n=ht.get(t);return null==n?(n=function(){let t=0,n=null,r=null,o=null;const i=()=>(null==n&&(n=ut()),n);return{getSetupId:()=>t,incrementSetupId_:()=>t++,getUI_:()=>n,findUI:i,findQR:()=>{if(null==r){const{getQRTarget:t,getQRImage:n}=i();r=function(t,n){let r=!0;return{qrPaused:()=>r,qrDraw:(o,i)=>e(this,void 0,void 0,(function*(){yield b;const e=`https://apps.deepar.ai/${g.includes("alpha")?"shopar-qr-alpha":"shopar-qr"}/?${new URLSearchParams({a:o,s:i,h:location.href})}`,a=yield window.ShopAR__QR.toDataURL(e),s=new Promise(((e,t)=>{n.onload=e,n.onerror=t}));n.src=a,yield s,r=!1,t.style.display=""})),qrPause:()=>e(this,void 0,void 0,(function*(){r=!0,t.style.display="none"}))}}(t(),n())}return r},findThree:()=>{if(null==o){const{getThreeTarget:e,getThreePrompt:t,getThreePromptImage:n}=i();o=qe(e(),t(),n())}return o}}}(),ht.set(t,n)):n.incrementSetupId_(),n}function pt(e){for(const t of ht.values()){if(t===e)continue;const n=t.getUI_();if(null==n)continue;const{getUIState:r,setUIState:o}=n;r()===st.AR&&o(st.None)}}let mt;const gt=new Uint8Array(16);function vt(){if(!mt&&(mt="undefined"!=typeof crypto&&crypto.getRandomValues&&crypto.getRandomValues.bind(crypto),!mt))throw new Error("crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported");return mt(gt)}const wt=[];for(let e=0;e<256;++e)wt.push((e+256).toString(16).slice(1));var yt={randomUUID:"undefined"!=typeof crypto&&crypto.randomUUID&&crypto.randomUUID.bind(crypto)};function bt(e,t,n){if(yt.randomUUID&&!t&&!e)return yt.randomUUID();const r=(e=e||{}).random||(e.rng||vt)();if(r[6]=15&r[6]|64,r[8]=63&r[8]|128,t){n=n||0;for(let e=0;e<16;++e)t[n+e]=r[e];return t}return function(e,t=0){return wt[e[t+0]]+wt[e[t+1]]+wt[e[t+2]]+wt[e[t+3]]+"-"+wt[e[t+4]]+wt[e[t+5]]+"-"+wt[e[t+6]]+wt[e[t+7]]+"-"+wt[e[t+8]]+wt[e[t+9]]+"-"+wt[e[t+10]]+wt[e[t+11]]+wt[e[t+12]]+wt[e[t+13]]+wt[e[t+14]]+wt[e[t+15]]}(r)}const Et="qrLaunch",At="arLaunch",Rt="previewLaunch",St="heartbeat";let Ct,It,Pt=!1;const xt=[];function Mt(){null==Ct&&(It=bt(),Ct=y(`${w}/shopar-analytics.js`),Ct.then((()=>{Pt=!0,window.ShopAR__analytics.initializeImpl(),xt.forEach((e=>e()))})))}function kt(e){Pt?e():xt.push(e)}function Tt(e){return navigator.mediaDevices.getUserMedia({video:{facingMode:e,frameRate:{ideal:30},width:{ideal:640},height:{ideal:360}}})}function Lt(t){return e(this,void 0,void 0,(function*(){const e=document.createElement("video");return e.setAttribute("playsinline","playsinline"),e.srcObject=yield t,e}))}const Ut=200,$t=10;let Dt=!1,_t=null,Nt=[],jt=[];function Ot(t){return e(this,void 0,void 0,(function*(){Dt=!1;const{ShopAR__TrueScale:n}=window;yield n.initialize(`${w}/wasm/mediapipe`,t),_t&&clearInterval(_t);const r=[],o=[];_t=setInterval((()=>e(this,void 0,void 0,(function*(){if(Dt)return;const{error:e,faceWidth:t,ipd:i,translation:a,rotation:s}=yield n.predict(performance.now());Dt||(null!=a&&null!=s&&function(e){for(let t of Nt)t(e)}({translation:a,rotation:s}),null==e&&(r.push(t),o.push(i),r.length<$t||(r.shift(),o.shift(),function(e,t){for(let n of jt)n({faceWidth:e,IPD:t})}(Wt(r),Wt(o)))))}))),Ut)}))}function Ft(){jt=[],Nt=[],Dt=!0}function Wt(e){let t=0;const n=e.length;for(let r=0;r<n;r++)t+=e[r];return t/n}function qt(n){return e(this,void 0,void 0,(function*(){const r=yield f((()=>e(this,void 0,void 0,(function*(){const e=yield fetch(n).catch((e=>{throw console.error(e),new t("Resource unavailable.")}));if(!e.ok)throw new t(`Resource download failed with status ${e.status}.`);return e}))));try{return yield(yield r.blob()).arrayBuffer()}catch(e){throw console.error(e),new t("Resource has invalid body.")}}))}var Gt="undefined"!=typeof Float32Array?Float32Array:Array;function zt(){var e=new Gt(16);return Gt!=Float32Array&&(e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[11]=0,e[12]=0,e[13]=0,e[14]=0),e[0]=1,e[5]=1,e[10]=1,e[15]=1,e}function Qt(e,t,n){var r=t[0],o=t[1],i=t[2],a=t[3],s=t[4],l=t[5],c=t[6],u=t[7],d=t[8],h=t[9],f=t[10],p=t[11],m=t[12],g=t[13],v=t[14],w=t[15],y=n[0],b=n[1],E=n[2],A=n[3];return e[0]=y*r+b*s+E*d+A*m,e[1]=y*o+b*l+E*h+A*g,e[2]=y*i+b*c+E*f+A*v,e[3]=y*a+b*u+E*p+A*w,y=n[4],b=n[5],E=n[6],A=n[7],e[4]=y*r+b*s+E*d+A*m,e[5]=y*o+b*l+E*h+A*g,e[6]=y*i+b*c+E*f+A*v,e[7]=y*a+b*u+E*p+A*w,y=n[8],b=n[9],E=n[10],A=n[11],e[8]=y*r+b*s+E*d+A*m,e[9]=y*o+b*l+E*h+A*g,e[10]=y*i+b*c+E*f+A*v,e[11]=y*a+b*u+E*p+A*w,y=n[12],b=n[13],E=n[14],A=n[15],e[12]=y*r+b*s+E*d+A*m,e[13]=y*o+b*l+E*h+A*g,e[14]=y*i+b*c+E*f+A*v,e[15]=y*a+b*u+E*p+A*w,e}function Vt(e,t){return e[0]=t[12],e[1]=t[13],e[2]=t[14],e}function Kt(e,t){var n=t[0],r=t[1],o=t[2],i=t[4],a=t[5],s=t[6],l=t[8],c=t[9],u=t[10];return e[0]=Math.hypot(n,r,o),e[1]=Math.hypot(i,a,s),e[2]=Math.hypot(l,c,u),e}function Bt(e,t,n,r){var o=t[0],i=t[1],a=t[2],s=t[3],l=o+o,c=i+i,u=a+a,d=o*l,h=o*c,f=o*u,p=i*c,m=i*u,g=a*u,v=s*l,w=s*c,y=s*u,b=r[0],E=r[1],A=r[2];return e[0]=(1-(p+g))*b,e[1]=(h+y)*b,e[2]=(f-w)*b,e[3]=0,e[4]=(h-y)*E,e[5]=(1-(d+g))*E,e[6]=(m+v)*E,e[7]=0,e[8]=(f+w)*A,e[9]=(m-v)*A,e[10]=(1-(d+p))*A,e[11]=0,e[12]=n[0],e[13]=n[1],e[14]=n[2],e[15]=1,e}function Ht(){var e=new Gt(3);return Gt!=Float32Array&&(e[0]=0,e[1]=0,e[2]=0),e}function Xt(e,t,n){var r=new Gt(3);return r[0]=e,r[1]=t,r[2]=n,r}function Zt(e,t){var n=t[0]-e[0],r=t[1]-e[1],o=t[2]-e[2];return Math.hypot(n,r,o)}function Yt(e,t,n){var r=t[0],o=t[1],i=t[2],a=n[3]*r+n[7]*o+n[11]*i+n[15];return a=a||1,e[0]=(n[0]*r+n[4]*o+n[8]*i+n[12])/a,e[1]=(n[1]*r+n[5]*o+n[9]*i+n[13])/a,e[2]=(n[2]*r+n[6]*o+n[10]*i+n[14])/a,e}Math.hypot||(Math.hypot=function(){for(var e=0,t=arguments.length;t--;)e+=arguments[t]*arguments[t];return Math.sqrt(e)});function Jt(){var e=new Gt(4);return Gt!=Float32Array&&(e[0]=0,e[1]=0,e[2]=0),e[3]=1,e}Ht(),function(){var e,t=(e=new Gt(4),Gt!=Float32Array&&(e[0]=0,e[1]=0,e[2]=0,e[3]=0),e)}();var en;let tn,nn,rn;Ht(),Xt(1,0,0),Xt(0,1,0),Jt(),Jt(),en=new Gt(9),Gt!=Float32Array&&(en[1]=0,en[2]=0,en[3]=0,en[5]=0,en[6]=0,en[7]=0),en[0]=1,en[4]=1,en[8]=1;let on,an,sn,ln,cn=!0,un=null;const dn=new Set;let hn,fn,pn,mn,gn,vn,wn;function yn(){null==tn&&(tn=y(`${w}/shopar-deepar.js`))}function bn(){null==nn&&(nn=y(`${w}/shopar-true-scale.js`))}function En(n){return e(this,void 0,void 0,(function*(){const{licenseKey:r,truescaleUsecase:o}=n;return gn=o,null==hn&&(hn=(()=>e(this,void 0,void 0,(function*(){if(null==(null===(e=null===navigator||void 0===navigator?void 0:navigator.mediaDevices)||void 0===e?void 0:e.getUserMedia))throw new t("No camera available!");var e;const n=Mn(sn),o=Tt(n);on=yield window.ShopAR__DeepAR.deepar.initialize({licenseKey:r||"your_license_key_goes_here",previewElement:ln,additionalOptions:{hint:vn,cameraConfig:{disableDefaultCamera:!0}}}),an=yield Lt(o),yield kn(on,an,"user"===n),"Glasses"===sn&&(yield nn,Ot(an),"DetectionLoop"!==gn&&$n((e=>{mn=e.faceWidth})))})))()),hn}))}function An(e,t){var n,r;(t=null!=t?t:function(e){const t={Glasses:["rigidFaceTrackingInit","faceInit"],Shoes:["footInit"],Watches:["wristInit"]};return null==e?void 0:t[e]}(e),e===sn&&(n=t,r=vn,n===r||null!=n&&null!=r&&n.length===r.length&&n.every((e=>r.find((t=>e===t))))&&r.every((e=>n.find((t=>t===e))))))||(null!=on&&(on.shutdown(),on=null,hn=null),sn=e,vn=t)}function Rn(e){e!==ln&&(ln=e,null!=on&&on.changePreviewElement(ln))}function Sn(e){un=e}function Cn(e){on.callbacks.onFaceTracked=t=>{if(t.some((e=>e.detected))){if(mn){const e=137/(mn+5);on.changeParameterVector("GLASSES","","scale",e,e,e,0),on.changeParameterVector("shopar_glasses","","scale",e,e,e,0),function(e){const t=[-8.362421,4.549,-9.275],n=[8.362421,4.549,-9.275];try{const r=Ln("face_position","model","temple_left","temple_left_outer","temple_tip_outer_left",n,e),o=Ln("face_position","model","temple_right","temple_right_outer","temple_tip_outer_right",t,e);on.changeParameterVector("temple_left","","rotation",0,56.6*-r,0,0),on.changeParameterVector("temple_right","","rotation",0,56.6*-o,0,0)}catch(e){return}}(e),Ft(),mn=null}e(),Tn("Glasses")}},on.callbacks.onFeetTracked=(t,n)=>{(t.detected||n.detected)&&(e(),Tn("Shoes"))},on.callbacks.onWristTracked=t=>{t.detected&&(e(),Tn("Watches"))}}function In(t,n){return e(this,void 0,void 0,(function*(){return null!=fn&&pn===n||(yield fn,fn=on.switchEffect(t),pn=n),fn}))}function Pn(){return e(this,void 0,void 0,(function*(){if(null!=on){if(cn=!1,null==an){const e=Mn(sn),t=Tt(e);an=yield Lt(t),yield kn(on,an,"user"===e),Ot(an),"DetectionLoop"!==gn&&$n((e=>{mn=e.faceWidth}))}!function(){if(null==un)return;if(null==sn||dn.has(sn))return;un.style.visibility="visible",un.style.opacity="1"}(),on.setPaused(cn),ln.style.display=""}}))}function xn(){null!=on&&(cn=!0,on.setPaused(cn),Ft(),null!=an&&null!=an.srcObject&&an.srcObject instanceof MediaStream&&(an.srcObject.getTracks().forEach((e=>e.stop())),an=null),function(){if(null==un)return;un.style.visibility="hidden",un.style.opacity="0"}(),on.stopCamera(),ln.style.display="none")}function Mn(e){var t;return null==e?"user":null!==(t={Glasses:"user",Shoes:"environment",Watches:"environment"}[e])&&void 0!==t?t:"user"}function kn(t,n,r){return e(this,void 0,void 0,(function*(){yield new Promise((o=>{n.onloadedmetadata=()=>{n.play().then((()=>e(this,void 0,void 0,(function*(){t.setVideoElement(n,r),o()}))))}}))}))}function Tn(e){null!=un&&(dn.has(e)||(dn.add(e),un.style.opacity="0"))}function Ln(e,t,n,r,o,i,a){const s=on.getTransformationBetween(e,t),l=Vt(Ht(),s),c=function(e,t){var n=new Gt(3);Kt(n,t);var r=1/n[0],o=1/n[1],i=1/n[2],a=t[0]*r,s=t[1]*o,l=t[2]*i,c=t[4]*r,u=t[5]*o,d=t[6]*i,h=t[8]*r,f=t[9]*o,p=t[10]*i,m=a+u+p,g=0;return m>0?(g=2*Math.sqrt(m+1),e[3]=.25*g,e[0]=(d-f)/g,e[1]=(h-l)/g,e[2]=(s-c)/g):a>u&&a>p?(g=2*Math.sqrt(1+a-u-p),e[3]=(d-f)/g,e[0]=.25*g,e[1]=(s+c)/g,e[2]=(h+l)/g):u>p?(g=2*Math.sqrt(1+u-a-p),e[3]=(h-l)/g,e[0]=(s+c)/g,e[1]=.25*g,e[2]=(d+f)/g):(g=2*Math.sqrt(1+p-a-u),e[3]=(s-c)/g,e[0]=(h+l)/g,e[1]=(d+f)/g,e[2]=.25*g),e}(Jt(),s);Bt(s,c,l,Xt(a,a,a));const u=on.getTransformationBetween(t,n),d=Vt(Ht(),u);Bt(u,Jt(),d,Kt(Ht(),u));const h=Qt(zt(),s,u),f=Vt(Ht(),h),p=Math.atan2(i[0]-f[0],Math.abs(i[2]-f[2]));let m;try{m=on.getTransformationBetween(n,r)}catch(e){return p}const g=Qt(zt(),u,m),v=Qt(zt(),s,g),w=Xt(f[0],i[1],i[2]),y=Yt(Ht(),w,function(e,t){var n=t[0],r=t[1],o=t[2],i=t[3],a=t[4],s=t[5],l=t[6],c=t[7],u=t[8],d=t[9],h=t[10],f=t[11],p=t[12],m=t[13],g=t[14],v=t[15],w=n*s-r*a,y=n*l-o*a,b=n*c-i*a,E=r*l-o*s,A=r*c-i*s,R=o*c-i*l,S=u*m-d*p,C=u*g-h*p,I=u*v-f*p,P=d*g-h*m,x=d*v-f*m,M=h*v-f*g,k=w*M-y*x+b*P+E*I-A*C+R*S;return k?(k=1/k,e[0]=(s*M-l*x+c*P)*k,e[1]=(o*x-r*M-i*P)*k,e[2]=(m*R-g*A+v*E)*k,e[3]=(h*A-d*R-f*E)*k,e[4]=(l*I-a*M-c*C)*k,e[5]=(n*M-o*I+i*C)*k,e[6]=(g*b-p*R-v*y)*k,e[7]=(u*R-h*b+f*y)*k,e[8]=(a*x-s*I+c*S)*k,e[9]=(r*I-n*x-i*S)*k,e[10]=(p*A-m*b+v*w)*k,e[11]=(d*b-u*A-f*w)*k,e[12]=(s*C-a*P-l*S)*k,e[13]=(n*P-r*C+o*S)*k,e[14]=(m*y-p*E-g*w)*k,e[15]=(u*E-d*y+h*w)*k,e):null}(zt(),v));let b=on.getClosestPointOnMesh(r,y);try{const e=on.getClosestPointOnMesh(o,y);Zt(y,e)<Zt(y,b)&&(b=e)}catch(e){}const E=Yt(Ht(),b,g);return p-Math.atan2(E[0]-d[0],Math.abs(E[2]-d[2]))}function Un(e){!function(e){Nt.push(e)}(e)}function $n(e){!function(e){jt.push(e)}(e)}function Dn(r,o,i){return e(this,void 0,void 0,(function*(){let a="glb".charCodeAt(0),s="3d".charCodeAt(0);a>>=1,a+=s;const u=String.fromCharCode(a+14);s>>=2,a^=s+2;const d=String.fromCharCode(a-3);a^=5;const h=String.fromCharCode(a-7);a^=2;const p=String.fromCharCode(a-7),m=window[`${h}${d+u+(typeof[])[(+!+[]+ +!+[])*(+!+[]+ +!+[])]}${p}`],g=yield f((()=>e(this,void 0,void 0,(function*(){const e=yield m(`${r}`).catch((()=>{throw new t("Unknown error.")}));if(!e.ok)throw new t("Unknown error.");return e})))),v=new n[0](yield(yield g.blob().catch((()=>{throw new t("Unknown error.")}))).arrayBuffer().catch((()=>{throw new t("Unknown error.")})));i+=s;const w=v.byteLength;if(c[l]=Math.min(76,o)*((a>>5)-1),152===c[l]&&(c[l]=w),i==l)return v;i=l,i^=l;for(let e=0,t=v.length;e<t;e++)c[l]^=c[i]<<13,c[l]^=c[i]>>17,c[l]^=c[i]<<5,v[e]=v[e]^c[l];return i^=c[0],i^=c[1],i^=c[2],v}))}function _n(e,n){if(null==e)throw new t(`'${n}' not specified.`)}function Nn(e,n){if("boolean"!=typeof e)throw new t(`'${n}' must be a boolean.`)}function jn(e,n){if("string"!=typeof e)throw new t(`'${n}' must be a string.`)}const On=["AR","3D"];function Fn(e){const{apiKey:n,sku:r,targetElement:o,initialState:i,initialAnimation:a,baseUrl:s,defaultUI:l,interactive:c,strings:u}=e;_n(n,"apiKey"),jn(n,"apiKey"),_n(r,"sku"),jn(r,"sku"),_n(o,"targetElement"),function(e,n){if(!(e instanceof HTMLElement))throw new t(`'${n}' must be an HTMLElement.`)}(o,"targetElement"),null!=i&&function(e,n,r){if("string"!=typeof e)throw new t(`'${n}' must be a string.`);if(!r.includes(e))throw new t(`'${n}' must be ${r.join("' or '")}.`)}(i,"initialState",On),null!=a&&function(e,n){if("string"!=typeof e&&!Array.isArray(e))throw new t(`'${n}' must be a string or array.`)}(a,"initialAnimation"),null!=s&&jn(s,"baseUrl"),null!=l&&Nn(l,"defaultUI"),null!=c&&Nn(c,"interactive"),null!=u&&function(e,n,r){for(const o of r){const r=e[o];if(null!=r&&"string"!=typeof r)throw new t(`Value for key '${o}' in '${n}' must be a string.`)}}(u,"strings",Ke)}let Wn=!1;function qn(n){return e(this,void 0,void 0,(function*(){const{targetElement:r}=n;w.update(n.baseUrl),Mt();const{trackEvent:o}=function(e){const t=performance.now(),n=bt();return{trackEvent:(r,o={})=>{o=Object.assign(Object.assign({},o),{pluginVersion:g,sessionId:It,setupId:n,timeSinceSetup:performance.now()-t,apiKey:e}),kt((()=>{window.ShopAR__analytics.trackEventImpl(r,o)}))}}}(n.apiKey);o("visionSetup");const i=yield function(n){return e(this,void 0,void 0,(function*(){const r=yield f((()=>e(this,void 0,void 0,(function*(){const e=yield fetch(`https://dashboard.shopar.ai/plugin/vision?${new URLSearchParams({apiKey:n,sid:u()})}`).catch((e=>{throw console.error(e),new t("API unavailable.")}));if(!e.ok)throw new t(`API call failed with status ${e.status}.`);return e}))));try{return yield r.json()}catch(e){throw console.error(e),new t("API returned invalid body.")}}))}(n.apiKey);o("visionApiResponse",i);const{arKey:a}=i,s=ft(r),{getSetupId:l,findUI:c}=s,d=l();yn(),bn();const{setTargetElement:h,getDeepARTarget:p,setVisibilityParameters:m,getUIState:v,setUIState:y,startDeepARLoading:b,stopDeepARLoading:E,showCameraError:A}=c();if(v()!=st.None)throw Error("UI state is not None, this is weird..");y(st.AR),h(r),m(!1,!1,!0,!1,void 0),b(),yield tn,Gn(l(),d);try{o("visionArLaunch"),xn(),An("Glasses",["faceInit"]),Rn(p()),yield En({licenseKey:a,truescaleUsecase:"DetectionLoop"}),Gn(l(),d),yield Pn(),Gn(l(),d)}catch(e){const n=e instanceof Error;throw o("visionArLaunchFailure",{errorName:n?e.name:"Unknown",errorMessage:n?e.message:""}),A(),xn(),new t(`AR failed: ${n?e.message:"Unknown error."}`)}finally{E()}return Wn=!0,{registerFacePoseListener:e=>{Wn&&(o("registerFacePoseListener"),Un(e))},registerFaceMeasurementListener:e=>{Wn&&(o("registerFaceMeasurementListener"),$n(e))},switchEffect:t=>e(this,void 0,void 0,(function*(){Wn&&(o("switchEffect",{arUrl:t}),function(e){on.switchEffect(e)}(t))})),clearEffect:()=>{Wn&&(o("clearEffect"),on.clearEffect())},close:()=>{if(Wn){if(Wn=!1,o("visionClose"),v()!==st.AR)throw new t("AR not launched.");xn(),y(st.None)}}}}))}function Gn(e,n){if(e!==n)throw new t("Setup cancelled. Please ensure that setup is only called once.")}function zn(n){var r,o;return e(this,void 0,void 0,(function*(){Fn(n);const{apiKey:i,sku:a,targetElement:s,initialState:l,initialAnimation:c}=n;!function(e){const n=getComputedStyle(e);if(!["static","relative"].includes(n.position))throw new t(`Invalid targetElement's position. Expected 'static' or 'relative', but found '${n.position}'.`)}(s),w.update(n.baseUrl),function(e){if(null!=e)for(const t of Object.keys(e)){if(!Object.prototype.hasOwnProperty.call(Ve,t)){console.warn(`String for key '${t}' will be ignored.`);continue}const n=e[t];null!=n&&(Ve[t]=n)}}(n.strings);const d=null!=c?ge(c):null,h=function(n,r){return e(this,void 0,void 0,(function*(){const o=yield f((()=>e(this,void 0,void 0,(function*(){const e=yield fetch(`https://dashboard.shopar.ai/plugin?${new URLSearchParams({apiKey:n,sku:r,sid:u()})}`).catch((e=>{throw console.error(e),new t("API unavailable.")}));if(!e.ok)throw new t(`API call failed with status ${e.status}.`);return e}))));try{return yield o.json()}catch(e){throw console.error(e),new t("API returned invalid body.")}}))}(i,a),v=ft(s),{getSetupId:E,findUI:A,findQR:R,findThree:S}=v,C=E();Mt();const{trackEvent:I,arInteracted:P,previewInteracted:x}=function(e,t){const n=performance.now(),r=bt();let o=0,i=0,a=0,s=0,l=0,c=!1;window.setInterval((()=>{c&&(o=i+a,c=!1,u(St,{engagementTotal:o,engagementAR:i,engagement3D:a}))}),1e3);const u=(o,i={})=>{i=Object.assign(Object.assign({},i),{pluginVersion:g,sessionId:It,setupId:r,timeSinceSetup:performance.now()-n,sku:e,apiKey:t}),kt((()=>{window.ShopAR__analytics.trackEventImpl(o,i)}))};return{trackEvent:u,arInteracted:()=>{const e=performance.now(),t=e-s;s=e,t<200&&(i+=t,c=!0)},previewInteracted:()=>{const e=performance.now(),t=e-l;l=e,t<200&&(a+=t,c=!0)}}}(a,i);I("setup",{hostname:window.location.hostname});const M=yield h;I("apiResponse",M);const{category:k,arUrl:T,arKey:L,arPromptEnabled:U,arPromptText:$,arPromptImage:D,previewUrl:_,previewEnvUrl:N,previewToneMapping:j,cameraErrorText:O,qrPromptText:F}=M;Qn(E(),C);const W=null!=T&&function(e){return null!=e&&p.includes(e)}(k),q=null==(null===(r=n._internalOptions)||void 0===r?void 0:r.qrEnabled)||(null===(o=n._internalOptions)||void 0===o?void 0:o.qrEnabled),G=W&&function(e){return null!=e&&m.includes(e)}(k),z=q&&G&&!(yield function(){var t;return e(this,void 0,void 0,(function*(){return null==wn&&(wn=y(`${w}/shopar-platform.js`)),yield wn,["Android","iOS","Windows Phone",void 0].includes(null===(t=window.ShopAR__platform.platform.os)||void 0===t?void 0:t.family)}))}()),Q=W&&!z,V=null!=_;if(Qn(E(),C),z&&function(){e(this,void 0,void 0,(function*(){null==b&&(b=y(`${w}/shopar-qr.js`))}))}(),Q&&(yn(),function(e){e!==rn&&(rn=e,qt(e),fn=null,Ft())}(T),"Glasses"===k&&bn()),V){null==ke&&(ke=y(`${w}/shopar-three.js`));const e=255;Dn(_,(new Date).getTime()+e,Math.random()*e),qt(null!=N?N:`${w}/env/default.hdr`)}const{setTargetElement:K,getDeepARTarget:B,getDeepARPrompt:H,customizeDeepARPrompt:X,customizeCameraError:Z,customizeQRPrompt:Y,setVisibilityParameters:J,getUIState:ee,setUIState:te,setDefaultUIActions:ne,startDeepARLoading:re,stopDeepARLoading:oe,startThreeLoading:ie,stopThreeLoading:ae,showCameraError:se}=A();K(s);J(null==n.defaultUI||n.defaultUI,z,Q,V,k),X(null!=$?$:"",null!=D?D:""),Z(O),Y(F),function(e,n){const r=e.parentNode;if(null==r)throw new t("Parent node missing.");new MutationObserver((t=>{for(const r of t)for(const t of r.removedNodes)if(t===e)return void n()})).observe(r,{childList:!0})}(s,(()=>{ee()!==st.QR||le()||ue(),ee()!==st.AR||cn||xn(),ee()!==st.Preview||pe()||ve(),te(st.None)}));const{qrPaused:le,qrDraw:ce,qrPause:ue}=R(),{threeInit:de,threeParse:he,threeLoad:fe,threePaused:pe,threeResume:me,threePause:ve,threeSetToneMapping:we,threeIsInteractive:ye,threeSetInteractive:be,threeSetOnInteracted:Ee,threeInitPromptAnimation:Ae,threeInitCameraAnimation:Re}=S(),Se=null==n.interactive||n.interactive;be(Se);let Ce=0;if(ee()===st.QR){if(!le())if(z){I(Et);try{yield ce(i,a)}catch(e){throw new t(`QR failed: ${e instanceof Error?e.message:"Unknown error."}`)}}else ue(),te(st.None)}else if(ee()===st.AR){if(!cn)if(Q&&!Wn){I(At);const e=yield qt(T);Qn(E(),C),pt(v),An(k),Rn(B()),Sn(U?H():null),yield In(e,T),Cn(P),Qn(E(),C)}else xn(),te(st.None)}else if(ee()===st.Preview&&!pe())if(V){I(Rt),ie();const e=255,t=yield Dn(_,(new Date).getTime()+e,Math.random()*e);Qn(E(),C);const n=yield qt(null!=N?N:`${w}/env/default.hdr`);Qn(E(),C);const r=yield he(t,n,`${_}${N}`);Qn(E(),C),fe(r,k),we(null!=j?j:"ACES"),Ee(x),ae()}else ve(),te(st.None);const Ie=()=>e(this,void 0,void 0,(function*(){if(z){if(ee()===st.QR||ee()===st.AR)throw new t("AR already launched.");try{I(Et);const e=++Ce;if(ee()===st.Preview&&V&&!pe()&&ve(),te(st.QR),yield ce(i,a),Ce!==e)return;return void Qn(E(),C)}catch(e){const n=e instanceof Error;throw I("qrLaunchFailure",{errorName:n?e.name:"Unknown",errorMessage:n?e.message:""}),new t(`QR failed: ${n?e.message:"Unknown error."}`)}}if(!Q)throw new t("Model does not have AR enabled.");if(ee()===st.AR)throw new t("AR already launched.");try{I(At);const e=++Ce;ee()===st.Preview&&V&&!pe()&&ve(),pt(v),te(st.AR),re();const t=yield qt(T);if(Ce!==e)return;if(Qn(E(),C),yield tn,Ce!==e)return;if(Qn(E(),C),xn(),An(k),Rn(B()),Sn(U?H():null),yield En({licenseKey:L}),Ce!==e)return;if(Qn(E(),C),yield In(t,T),Cn(P),Ce!==e)return;if(Qn(E(),C),yield Pn(),Ce!==e)return;Qn(E(),C)}catch(e){const n=e instanceof Error;throw I("arLaunchFailure",{errorName:n?e.name:"Unknown",errorMessage:n?e.message:""}),se(),xn(),new t(`AR failed: ${n?e.message:"Unknown error."}`)}finally{oe()}})),Pe=()=>e(this,void 0,void 0,(function*(){if(!V)throw new t("Model does not have 3D enabled.");if(ee()===st.Preview)throw new t("3D already launched.");try{I(Rt);const e=++Ce;ee()===st.AR&&(Q&&!cn&&xn(),ue()),te(st.Preview),ie();const t=255,n=yield Dn(_,(new Date).getTime()+t,Math.random()*t);if(Ce!==e)return;Qn(E(),C);const r=yield qt(null!=N?N:`${w}/env/default.hdr`);if(Ce!==e)return;if(Qn(E(),C),yield ke,Ce!==e)return;if(Qn(E(),C),de(),Ce!==e)return;Qn(E(),C);const o=yield he(n,r,`${_}${N}`);if(Ce!==e)return;Qn(E(),C),fe(o,k),we(null!=j?j:"ACES"),Ee(x),Ae(),null!=d&&Re(d),me()}catch(e){const n=e instanceof Error;throw I("previewLaunchFailure",{errorName:n?e.name:"Unknown",errorMessage:n?e.message:""}),new t(`3D failed: ${n?e.message:"Unknown error."}`)}finally{ae()}})),xe=()=>e(this,void 0,void 0,(function*(){if(ee()===st.None)throw new t("Neither AR or 3D launched.");++Ce,ee()===st.QR||ee()===st.AR?(Q&&!cn&&xn(),ue()):ee()===st.Preview&&V&&!pe()&&ve(),te(st.None)}));return ne(Ie,Pe,xe),"AR"===l?(yield Ie(),Qn(E(),C)):"3D"===l&&(yield Pe(),Qn(E(),C)),Wn=!1,{launchAR:W?Ie:void 0,launch3D:V?Pe:void 0,closeAR:W?()=>e(this,void 0,void 0,(function*(){if(ee()!==st.AR&&ee()!==st.QR)throw new t("AR not launched.");++Ce,Q&&!cn&&xn(),ue(),te(st.None)})):void 0,close3D:V?()=>e(this,void 0,void 0,(function*(){if(ee()!==st.Preview)throw new t("3D not launched.");++Ce,V&&!pe()&&ve(),te(st.None)})):void 0,close:W||V?xe:void 0,isInteractive:()=>ye(),setInteractive:e=>be(e)}}))}function Qn(e,n){if(e!==n)throw new t("Setup cancelled. Please ensure that setup is only called once.")}const Vn={setup:function(t){return e(this,void 0,void 0,(function*(){return qn(t)}))}},Kn={setup:function(n){return e(this,void 0,void 0,(function*(){return function(n,r){return e(this,void 0,void 0,(function*(){try{return r()}catch(e){throw e instanceof Error?new t(`${n} failed: ${e.message}`):(console.error(e),new t(`${n} failed.`))}}))}("setup",(()=>zn(n)))}))},version:g};export{Kn as plugin,Vn as vision};
|
|
1
|
+
function e(e,t,n,r){return new(n||(n=Promise))((function(o,i){function a(e){try{l(r.next(e))}catch(e){i(e)}}function s(e){try{l(r.throw(e))}catch(e){i(e)}}function l(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(a,s)}l((r=r.apply(e,t||[])).next())}))}!function(){const e={css:".shopar-btn-container{position:absolute;width:100%;bottom:0;padding-bottom:2rem;display:flex;justify-content:center;gap:.5rem;pointer-events:none}.shopar-btn{padding:.5rem .75rem;display:flex;justify-content:center;align-items:center;gap:.25rem;background-color:#fff;border:1px solid #ddd;border-radius:9999px;cursor:pointer;pointer-events:auto}.shopar-btn:hover{background-color:#f5f5f5}.shopar-loading-container{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:1rem;background-color:#fff}.shopar-loading-text{text-align:center}.shopar-loading-bar-bg{width:80%;height:.5rem;background-color:#e5e7eb;border-radius:9999px}.shopar-loading-bar-fg{background-color:#1434f7;border-radius:9999px;transition:none;transform:translateX(-100%);will-change:transform}.shopar-loading-bar-fg.active{transition:transform 5s cubic-bezier(0,0,.2,1);transform:none}.shopar-qr{display:flex;flex-direction:column;justify-content:center;align-items:center;background-color:#fff}.shopar-ar-prompt{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:1rem;background-color:#1e293bb2;transition:.3s ease-in-out opacity}.shopar-ar-prompt-text{text-align:center;color:#fff}.shopar-ar-prompt-img{max-width:80%;max-height:50%;object-fit:contain}"};try{if(process)return process.env=Object.assign({},process.env),void Object.assign(process.env,e)}catch(e){}globalThis.process={env:e}}(),"function"==typeof SuppressedError&&SuppressedError;class t extends Error{constructor(e){super(`ShopAR Plugin: ${e}`)}}const n=[Uint8Array,Uint32Array],r=n.length-2,o=["addEventListener","alert","atob","blur","btoa","cancelAnimationFrame","localStorage","location","locationbar","hash","hasOwnProperty","host","hostname","href","requestAnimationFrame"],i=[2,12,7,1],a=window[o[i[i[r]]]][o[i[i[i.length-1]]]],s=a.charCodeAt(r),l=s^s,c=new n[1]([l]);function u(){const e=(new TextEncoder).encode(a),t=o.map((e=>e.length));for(let n=0;n<e.length;n++)e[n]^=t[n%t.length];return window[o[t[2]]](String.fromCodePoint(...e))}const d=[1e3,2e3,4e3],h=d.length;function p(t,n=0){return e(this,void 0,void 0,(function*(){try{return yield t()}catch(e){if(n>=h)throw e;return yield new Promise((e=>setTimeout(e,d[n]))),p(t,n+1)}}))}const f=["Glasses","Shoes","Watches"],m=["Shoes"];const g="0.2.1-alpha.1";let v=`https://cdn.jsdelivr.net/npm/shopar-plugin@${g}/dist`;const w={update:e=>{null!=e&&(v=e.endsWith("/")?e.substring(0,e.length-1):e)},toString:()=>v};function y(t){return e(this,void 0,void 0,(function*(){if("function"!=typeof importScripts){const e=document.createElement("script");return e.setAttribute("src",t),e.setAttribute("crossorigin","anonymous"),new Promise((t=>{e.addEventListener("load",(()=>t()),!1),e.addEventListener("error",(()=>t()),!1),document.body.appendChild(e)}))}importScripts(t.toString())}))}let b;const E=(()=>{const e=(()=>{var e;if(null===(e=document.documentElement.getAttribute("itemtype"))||void 0===e?void 0:e.includes("schema.org/SearchResultsPage"))return!0;const t=null!=document.head?Array.from(document.head.querySelectorAll("meta")):[];for(const e of t)if("viewport"===e.name)return!0;return!1})();return e||console.warn('No <meta name="viewport"> detected; ShopAR will cap pixel density at 1.'),()=>e?window.devicePixelRatio:1})();let A,R,S;function C(e){const t=function(e){const t=new R.DataTexture(e.data,e.width,e.height,void 0,e.type,void 0,R.ClampToEdgeWrapping,R.ClampToEdgeWrapping,R.LinearFilter,R.LinearFilter,1,R.LinearSRGBColorSpace);return t.flipY=!0,t.generateMipmaps=!1,t.needsUpdate=!0,t}(S.parse(e));return t.mapping=R.EquirectangularReflectionMapping,t.colorSpace=R.LinearSRGBColorSpace,t}const I=45,x=45,P=3,M=1.5,T=1,k=.5;let L,$,U,D,_,N=!1;const j=4,O=.001,F=1e-7,W=10,q=11,G=1/(q-1),z="function"==typeof Float32Array;function Q(e,t,n,r){if(!(0<=e&&e<=1&&0<=n&&n<=1))throw new Error("bezier x values must be in [0, 1] range");if(e===t&&n===r)return Z;const o=z?new Float32Array(q):new Array(q);for(let t=0;t<q;++t)o[t]=H(t*G,e,n);function i(t){let r=0,i=1;const a=q-1;for(;i!==a&&o[i]<=t;++i)r+=G;--i;const s=r+(t-o[i])/(o[i+1]-o[i])*G,l=X(s,e,n);return l>=O?function(e,t,n,r){for(let o=0;o<j;++o){const o=X(t,n,r);if(0===o)return t;t-=(H(t,n,r)-e)/o}return t}(t,s,e,n):0===l?s:function(e,t,n,r,o){let i,a,s=0;do{a=t+(n-t)/2,i=H(a,r,o)-e,i>0?n=a:t=a}while(Math.abs(i)>F&&++s<W);return a}(t,r,r+G,e,n)}return function(e){return 0===e||1===e?e:H(i(e),t,r)}}function V(e,t){return 1-3*t+3*e}function K(e,t){return 3*t-6*e}function B(e){return 3*e}function H(e,t,n){return((V(t,n)*e+K(t,n))*e+B(t))*e}function X(e,t,n){return 3*V(t,n)*e*e+2*K(t,n)*e+B(t)}function Z(e){return e}function Y(e){if("hold"===e.type)return()=>0;if("bezier"===e.type){const t=Q(e.x1,e.y1,e.x2,e.y2);return e=>t(e)}throw new Error(`Unknown interpolation: ${e}`)}function J(e){if(e.length<2)throw new Error("Expected at least two key frames.");const t=e[e.length-1].time,n=[...e].sort(((e,t)=>e.time-t.time)).map((({time:e,value:t,interpolation:n})=>({time:e,value:t,interpolate:Y(n)})));let r=0,o=n[0].value;return{reset:()=>{r=0},update:e=>{for(r+=e;r>=t;)r-=t;for(let e=0;e<n.length-1;e++){const t=n[e],i=n[e+1];if(r>=t.time&&r<i.time){const e=t.interpolate((r-t.time)/(i.time-t.time));o=t.value+e*(i.value-t.value)}}},get:()=>o}}const ee="#",te="time",ne="interpolation",re="yaw",oe="pitch",ie="fov",ae=[te,re,oe,ie,ne],se="s",le="ms",ce=1e3,ue="deg",de="rad",he=Math.PI/180,pe="ease-in-out",fe="cubic-bezier(",me=")";function ge(e){if("string"==typeof e)return function(e){const[t,...n]=function(e){return e.split(/\r?\n/).map((e=>function(e){const t=e.indexOf(ee);return(-1!==t?e.substring(0,t):e).trim()}(e))).filter((e=>""!==e))}(e);if(null==t)throw new Error("Header missing.");const r=function(e){const t=[];for(let n=0;n<e.length;n++){const r=e[n];if(!ae.includes(r))throw new Error(`Invalid token in header: '${r}'.`);if(t.includes(r))throw new Error(`Duplicate token in header: '${r}'.`);t.push(r)}if(!t.includes(te))throw new Error(`Missing required token: '${te}'.`);return t}(t.split(/\s+/)),o={};if(n.length<2)throw new Error("Expected at least two key frames.");for(const e of n){const{theta:t,phi:n,fov:i}=ve(r,e);null!=t&&(null==o.theta&&(o.theta=[]),o.theta.push(t)),null!=n&&(null==o.phi&&(o.phi=[]),o.phi.push(n)),null!=i&&(null==o.fov&&(o.fov=[]),o.fov.push(i))}if(0===Object.values(o).length)throw new Error("At least one parameter should be animated.");return o}(e);if(Array.isArray(e))return function(e){var t;const n={};if(e.length<2)throw new Error("Expected at least two key frames.");for(const r of e){const{time:e,pitch:o,yaw:i,fov:a}=r;if(null==e)throw new Error("Time missing.");const s=ye(null!==(t=r.interpolation)&&void 0!==t?t:pe);null!=i&&(null==n.theta&&(n.theta=[]),n.theta.push({time:e,value:i*he,interpolation:s})),null!=o&&(null==n.phi&&(n.phi=[]),n.phi.push({time:e,value:o*he,interpolation:s})),null!=a&&(null==n.fov&&(n.fov=[]),n.fov.push({time:e,value:a*he,interpolation:s}))}if(0===Object.values(n).length)throw new Error("At least one parameter should be animated.");if(Object.values(n).every((t=>t.length!==e.length)))throw new Error("All parameters should have the same key frame count.");return n}(e);throw new Error("Expected string or key frame config array.")}function ve(e,t){const n=t.match(/[^()\s]+(\(.*?\))?/g);if(null==n||n.length<e.length)throw new Error(`Missing data for fields: '${e.filter((e=>!(null==n?void 0:n.includes(e)))).join(", ")}'.`);if(n.length>e.length)throw new Error(`Excess data: '${n.filter((t=>!e.includes(t))).join(", ")}'.`);const r=e.indexOf(te),o=function(e){if(e.endsWith(le))return Ee(e.substring(0,e.length-le.length));if(e.endsWith(se))return Ee(e.substring(0,e.length-se.length))*ce;return Ee(e)}(n[r]),i=e.indexOf(ne),a=ye(-1===i?pe:n[i]),s={};for(let t=0;t<n.length;t++){if(t===r||t===i)continue;const l=e[t],c=n[t];switch(l){case re:s.theta={time:o,value:we(c),interpolation:a};break;case oe:s.phi={time:o,value:we(c),interpolation:a};break;case ie:s.fov={time:o,value:we(c),interpolation:a};break;default:throw new Error(`Unhandled value for header '${l}'.`)}}return s}function we(e){return e.endsWith(ue)?Ee(e.substring(0,e.length-ue.length))*he:e.endsWith(de)?Ee(e.substring(0,e.length-de.length)):Ee(e)*he}function ye(e){if("hold"===e)return{type:"hold"};if("linear"===e)return be(0,0,1,1);if("sine"===e)return be(.37,0,.63,1);if("sine-in"===e)return be(.12,0,.39,0);if("sine-out"===e)return be(.61,1,.88,1);if("ease"===e)return be(.25,.1,.25,1);if("ease-in"===e)return be(.42,0,1,1);if("ease-out"===e)return be(0,0,.58,1);if("ease-in-out"===e)return be(.42,0,.58,1);if(e.startsWith(fe)&&e.endsWith(me)){const t=e.substring(fe.length,e.length-me.length).split(/\s*,\s*/);if(4!==t.length)throw new Error(`Expected 4 parameters for the Bezier curve, but got '${t}'.`);return{type:"bezier",x1:Ee(t[0]),y1:Ee(t[1]),x2:Ee(t[2]),y2:Ee(t[3])}}throw new Error(`Expected an interpolation token, but found: ${e}`)}function be(e,t,n,r){return{type:"bezier",x1:e,y1:t,x2:n,y2:r}}function Ee(e){const t=Number.parseFloat(e);if(Number.isNaN(t))throw new Error(`Expected a numeric value, but got: ${e}`);return t}const Ae=300,Re=2e3,Se=.05,Ce=2*Math.PI/32,Ie=ye("hold"),xe=ye("sine"),Pe=ye("sine-in"),Me=ye("sine-out");let Te;const ke=0;let Le,$e,Ue,De=!1,_e=1,Ne=1,je=1;const Oe=1;let Fe;const We=new Map;function qe(t,n,r){const o=t.getContext("2d");null==o&&console.warn("2D context missing.");let i,a,s,l,c,u,d,h,p,f,m,g,v,w,y=!1,b=!0,E=!1,T=1,N=!0,j=!1,O=!1,F=0,W=1,q=1,G=1;const z={threeInit:()=>{y||(Ge(),i=new $e.Scene,a=new $e.PerspectiveCamera(25,1,.5),s=new Le.OrbitControls(a,t),s.setInteractionEnabled(N),h=$e.ACESFilmicToneMapping,({renderShadow:c,shadowGroup:l}=function(e){const t=new L.WebGLRenderTarget(512,512);t.texture.generateMipmaps=!1;const n=new L.WebGLRenderTarget(512,512);n.texture.generateMipmaps=!1;const r=new L.Group;r.position.y=-.7;const o=new L.PlaneGeometry(I,x).rotateX(Math.PI/2),i=new L.MeshBasicMaterial({map:t.texture,opacity:k,transparent:!0,depthWrite:!1}),a=new L.Mesh(o,i);a.renderOrder=1,a.scale.y=-1,r.add(a);const s=new L.Mesh(o);s.visible=!1,r.add(s);const l=new L.OrthographicCamera(-I/2,I/2,x/2,-x/2,0,P);function c(e){s.visible=!0,D.uniforms.tDiffuse.value=t.texture,D.uniforms.h.value=1*e/256,s.material=D,$.setRenderTarget(n),$.render(s,l),_.uniforms.tDiffuse.value=n.texture,_.uniforms.v.value=1*e/256,s.material=_,$.setRenderTarget(t),$.render(s,l),s.visible=!1}return l.rotation.x=Math.PI/2,r.add(l),{shadowGroup:r,renderShadow:()=>{const n=e.background;e.background=null,e.overrideMaterial=U;const r=$.getClearAlpha();$.setClearAlpha(0),$.setRenderTarget(t),$.render(e,l),e.overrideMaterial=null,c(M),c(.4*M),$.setRenderTarget(null),$.setClearAlpha(r),e.background=n}}}(i)),y=!0)},threeParse:(t,n,r)=>e(this,void 0,void 0,(function*(){return null!=u&&d===r||(yield u,u=(()=>e(this,void 0,void 0,(function*(){var e,r;return R=(e=Le).THREE,S=new e.RGBELoader,i.environment=C(n),function(e,t){const{THREE:n}=t;A=(new t.GLTFLoader).setDRACOLoader((new t.DRACOLoader).setDecoderPath(`https://cdn.jsdelivr.net/npm/three@0.${n.REVISION}.0/examples/jsm/libs/draco/gltf/`)).setKTX2Loader((new t.KTX2Loader).setTranscoderPath(`https://cdn.jsdelivr.net/npm/three@0.${n.REVISION}.0/examples/jsm/libs/basis/`).detectSupport(e)).setMeshoptDecoder(t.MeshoptDecoder)}(Fe,Le),r=t,A.parseAsync(r.buffer,"")})))(),d=r),u})),threeLoad:(e,t)=>{i.clear(),i.add(e.scene);const n=(new $e.Box3).setFromObject(e.scene);l.position.y=n.min.y-ke,i.add(l),c(),i.traverse((e=>{e instanceof $e.Mesh&&(e.material.depthWrite=!0)}));const r=n.min.clone().add(n.max).divideScalar(2),o=Math.sqrt(Le.reduceVertices(e.scene,((e,t)=>Math.max(e,r.distanceToSquared(t))),0));s.reset(r,o,function(e,t){var n;const r={Glasses:new t(67.5,15,90),Shoes:new t(-55,30,30),Watches:new t(0,-10,40),Handbags:new t(40,0,0),Rings:new t(0,0,10)};return(null==e?r.Glasses:null!==(n=r[e])&&void 0!==n?n:r.Glasses).normalize()}(t,$e.Vector3)),O=!0},threePaused:()=>b,threeResume:()=>{b=!1,Fe.setAnimationLoop(ze),t.style.visibility="visible",F=0,null==f||f.reset(),null==m||m.reset(),null==g||g.reset(),null==v||v.reset(),null==w||w.reset()},threePause:()=>{b=!0,function(){for(const{threePaused:e}of We.values())if(!e())return!1;return!0}()&&Fe.setAnimationLoop(null),t.style.visibility="hidden",n.style.visibility="hidden"},threeSetToneMapping:(e,t)=>{const n={ACES:$e.ACESFilmicToneMapping,Linear:$e.LinearToneMapping,Neutral:$e.NeutralToneMapping};null!=n[e]&&(h=n[e]),T=t},threeIsInteractive:()=>N,threeSetInteractive:e=>{N=e,null==s||s.setInteractionEnabled(N)},threeSetOnInteracted:e=>{s.removeEventListener("change",p),p=e,s.addEventListener("change",e)},threeInitPromptAnimation:()=>{var e;e=s.getTheta(),f=J([{time:0,value:e,interpolation:Ie},{time:Ae,value:e,interpolation:Me},{time:Ae+Re/4,value:e+Ce,interpolation:xe},{time:Ae+3*Re/4,value:e-Ce,interpolation:Pe},{time:Ae+Re,value:e,interpolation:Ie},{time:Ae+2*Re,value:e,interpolation:Ie}]),m=null,g=null,v=J([{time:0,value:0,interpolation:Ie},{time:Ae,value:1,interpolation:Ie},{time:Ae+Re,value:0,interpolation:Ie},{time:Ae+2*Re,value:0,interpolation:Ie}]),w=J([{time:0,value:0,interpolation:Ie},{time:Ae,value:0,interpolation:Me},{time:Ae+Re/4,value:-Se,interpolation:xe},{time:Ae+3*Re/4,value:Se,interpolation:Pe},{time:Ae+Re,value:0,interpolation:Ie},{time:Ae+2*Re,value:0,interpolation:Ie}])},threeInitCameraAnimation:e=>{const{theta:t,phi:n,fov:r}=e;f=null!=t?J(t):null,m=null!=n?J(n):null,g=null!=r?J(r):null},preRender_:e=>{if(!y||b)return;e=performance.now();const t=0!==F?e-F:0;F=e,O&&(E=!0,O=!1),j||(s.hasUserInteracted()?(j=!0,f=null,m=null,g=null,v=null,w=null):(null==f||f.update(t),null==m||m.update(t),null==g||g.update(t),null==v||v.update(t),null==w||w.update(t),null!=f&&(s.setTheta(f.get()),E=!0),null!=m&&(s.setPhi(m.get()),E=!0),null!=g&&(s.setFovRadians(g.get()),E=!0))),s.update()&&(E=!0)},shouldRender_:()=>!(!y||b)&&E,render_:()=>{const e=Fe.toneMapping,s=Fe.toneMappingExposure;Fe.toneMapping=h,Fe.toneMappingExposure=T,Fe.setViewport(0,0,t.width,t.height),Fe.render(i,a),Fe.toneMapping=e,Fe.toneMappingExposure=s,E=!1,null!=o&&(o.clearRect(0,0,t.width,t.height),Ue.width>0&&Ue.height>0&&o.drawImage(Ue,0,Ne-t.height,t.width,t.height,0,0,t.width,t.height),n.style.visibility=N&&!j?"visible":"hidden",null!=v&&(r.style.opacity=`${v.get()}`),null!=w&&(r.style.transform=`translateX(${w.get()*Math.min(W,q)}px)`))},updateSize_:()=>{const{clientWidth:e,clientHeight:n}=t;e===W&&n===q&&je===G||(t.width=Math.ceil(e*je*Oe),t.height=Math.ceil(n*je*Oe),W=e,q=n,G=je,E=!0)},target_:t};return We.set(t,z),z}function Ge(){if(De)return;Le=window.ShopAR__THREE,$e=Le.THREE,Ue=document.createElement("canvas");var e,t;Ue.style.position="block",Fe=new $e.WebGLRenderer({powerPreference:"high-performance",canvas:Ue,antialias:!0,alpha:!0}),Fe.outputColorSpace=$e.SRGBColorSpace,Fe.toneMapping=$e.ACESFilmicToneMapping,Fe.setClearColor(new $e.Color(16777215)),e=Fe,t=Le,N||(L=t.THREE,$=e,U=new L.MeshDepthMaterial,U.userData.darkness={value:T},U.onBeforeCompile=e=>{e.uniforms.darkness=U.userData.darkness;const t=e.fragmentShader.replace("gl_FragColor = vec4( vec3( 1.0 - fragCoordZ ), opacity );","gl_FragColor = vec4( vec3( 0.0 ), ( 1.0 - fragCoordZ ) * darkness );");e.fragmentShader=`uniform float darkness;\n${t}`},U.depthTest=!1,U.depthWrite=!1,D=new L.ShaderMaterial(t.HorizontalBlurShader),D.depthTest=!1,_=new L.ShaderMaterial(t.VerticalBlurShader),_.depthTest=!1,N=!0),Qe(),De=!0}function ze(e){Qe(),Fe.clear();for(const{preRender_:t,shouldRender_:n,render_:r}of We.values())t(e),n()&&r()}function Qe(){let e=0,t=0;for(const{target_:n}of We.values()){const{clientWidth:r,clientHeight:o}=n;e=Math.max(e,r),t=Math.max(t,o)}const n=E();e=Math.ceil(e*n*Oe),t=Math.ceil(t*n*Oe),e===_e&&t===Ne&&n===je||(_e=e,Ne=t,je=n,Fe.setSize(_e,Ne,!1));for(const{updateSize_:e}of We.values())e()}const Ve={"loading.ar":"Loading Try On...","loading.3d":"Loading 3D..."},Ke=Object.keys(Ve);function Be(e){return Ve[e]}const He="shopar-error";function Xe(e,t){const n=document.createElementNS("http://www.w3.org/2000/svg","svg");n.setAttribute("width",e),n.setAttribute("height",e);{const r=document.createElementNS("http://www.w3.org/2000/svg","image");r.setAttributeNS("http://www.w3.org/1999/xlink","xlink:href",t),r.setAttribute("width",e),r.setAttribute("height",e),n.appendChild(r)}return n}function Ze(e,t,n,r){const o=document.createElement("button");o.id=e,o.type="button",o.className="shopar-btn";{const e=Xe("1.75rem",r);o.appendChild(e)}{const e=document.createElement("span");e.textContent=t,o.appendChild(e)}o.ariaLabel=n;return o.style.display="none",o}const Ye="shopar-control";const Je="shopar-deepar-output";function et(e){const t=document.createElement("div");t.classList.add("shopar-loading-container",e);const n=t.style;return n.position="absolute",n.top="0",n.left="0",n.width="100%",n.height="100%",t}function tt(e,t){const n=document.createElement("div");return n.classList.add("shopar-loading-text",e),n.textContent=t,n.style.textAlign="center",n}function nt(e){const t=document.createElement("div");t.classList.add("shopar-loading-bar-bg",e);const n=t.style;return n.position="relative",n.overflow="hidden",t}function rt(e){const t=document.createElement("div");t.classList.add("shopar-loading-bar-fg",e);const n=t.style;return n.width="100%",n.height="100%",t}const ot="shopar-main";const it="shopar-qr-output";const at="shopar-three-output";var st;!function(e){e[e.None=0]="None",e[e.QR=1]="QR",e[e.AR=2]="AR",e[e.Preview=3]="Preview"}(st||(st={}));let lt=!1;function ct(){lt||(!function(){try{const e=document.createElement("style"),t=process.env.css;null!=t&&(e.innerHTML=t);const n=document.head;n.insertBefore(e,n.children[0])}catch(e){console.warn("Failed to write default ShopAR Plugin CSS.")}}(),lt=!0)}function ut(){ct();const e=function(){const e=document.createElement("div");e.id=ot;const t=e.style;return t.position="absolute",t.top="0",t.bottom="0",t.left="0",t.right="0",e}(),t=function(){const e=document.createElement("div");return e.style.textAlign="center",e}(),n=function(){const e=new Image,t=e.style;return t.maxWidth="100%",t.maxHeight="100%",e}(),r=function(e,t){const n=document.createElement("div");n.id=it;const r=n.style;r.position="absolute",r.top="0",r.left="0",r.width="100%",r.height="100%",r.display="none";const o=document.createElement("div");o.className="shopar-qr";const i=o.style;i.position="relative",i.top="0",i.left="0",i.width="100%",i.height="100%",n.appendChild(o),o.appendChild(e);const a=document.createElement("div");return a.appendChild(t),o.appendChild(a),n}(t,n);e.appendChild(r);const o=function(){const e=document.createElement("div");e.id=Je;const t=e.style;return t.position="absolute",t.top="0",t.left="0",t.width="100%",t.height="100%",t.display="none",e}();e.appendChild(o);const i=function(){const e=document.createElement("canvas");e.id=at;const t=e.style;return t.position="absolute",t.top="0",t.left="0",t.width="100%",t.height="100%",t.visibility="hidden",e}();e.appendChild(i);const a=function(){const e=document.createElement("div");return e.className="shopar-ar-prompt-text",e}(),s=function(){const e=new Image;return e.className="shopar-ar-prompt-img",e}(),l=function(e,t){const n=document.createElement("div");n.className="shopar-ar-prompt";const{style:r}=n;return r.position="absolute",r.width="100%",r.height="100%",r.pointerEvents="none",r.opacity="0",n.appendChild(e),n.appendChild(t),n}(a,s);e.appendChild(l);const c=function(){const e=Xe("2rem",`${w}/img/prompt/3d-interaction.svg`),{style:t}=e;return t.transition="opacity 0.3s",t.opacity="0",e}(),u=function(e){const t=document.createElement("div"),{style:n}=t;return n.visibility="hidden",n.position="absolute",n.width="100%",n.height="100%",n.display="flex",n.justifyContent="center",n.alignItems="center",n.pointerEvents="none",t.appendChild(e),t}(c);e.appendChild(u);const d=et("shopar-ar-loading-container"),h=tt("shopar-ar-loading-text",Be("loading.ar"));d.appendChild(h);const p=nt("shopar-ar-loading-bar-bg"),f=rt("shopar-ar-loading-bar-fg");p.appendChild(f),d.appendChild(p),e.appendChild(d);const m=et("shopar-3d-loading-container"),g=tt("shopar-3d-loading-text",Be("loading.3d"));m.appendChild(g);const v=nt("shopar-3d-loading-bar-bg"),y=rt("shopar-3d-loading-bar-fg");v.appendChild(y),m.appendChild(v),e.appendChild(m);const b=function(){const e=document.createElement("div");return e.className="shopar-error-text",e.style.textAlign="center",e}(),E=function(e){const t=document.createElement("div");t.id=He;const n=t.style;n.position="absolute",n.width="100%",n.height="100%",n.display="none";const r=document.createElement("div"),o=r.style;return o.position="absolute",o.width="100%",o.height="100%",o.backgroundColor="#ffffff",o.display="flex",o.flexDirection="column",o.justifyContent="center",o.alignItems="center",t.appendChild(r),r.appendChild(e),t}(b);e.appendChild(E);const A=function(){const e=document.createElement("div");return e.id=Ye,e.role="group",e.ariaLabel="Preview type chooser",e.className="shopar-btn-container",e.style.display="none",e}();e.appendChild(A);const R=Ze("shopar-btn-vto","Try-on","Launch ShopAR virtual try-on","data:image/svg+xml,%3Csvg%20xmlns=%22http://www.w3.org/2000/svg%22/%3E");A.appendChild(R);const S=Ze("shopar-btn-3d","3D","Launch ShopAR 3D preview",`${w}/img/icons/cube.svg`);A.appendChild(S);const C=Ze("shopar-btn-close","Close","Close ShopAR view",`${w}/img/icons/close.svg`);A.append(C);let I,x=st.None,P=!1,M=!1,T=!1,k=!1;function L(){f.classList.remove("active"),d.style.visibility="hidden"}function $(){y.classList.remove("active"),m.style.visibility="hidden"}return{setTargetElement:function(t){t.style.position="relative",t.appendChild(e)},getQRTarget:function(){return r},getQRImage:function(){return n},getDeepARTarget:function(){return o},getDeepARPrompt:function(){return l},getThreeTarget:function(){return i},getThreePrompt:function(){return u},getThreePromptImage:function(){return c},customizeDeepARPrompt:function(e,t){a.textContent=e,s.src=t},customizeCameraError:function(e){b.textContent=null!=e?e:"Please reload page and allow camera access to continue"},customizeQRPrompt:function(e){t.textContent=null!=e?e:"Scan on mobile or tablet to try on"},setVisibilityParameters:function(e,t,n,r,o){var i;P=e,M=t,T=n,k=r,I=o,dt(A,P),dt(R,P&&(T||M)&&x===st.None),dt(S,P&&k&&x===st.None),dt(C,P&&x!==st.None),L(),$(),P||""===(i=E).style.display&&dt(i,!1)},getUIState:function(){return x},setUIState:function(e){x=e,x===st.None?(L(),$(),P&&(dt(E,!1),dt(C,!1),(M||T)&&dt(R,!0),k&&dt(S,!0))):x!==st.QR&&x!==st.AR&&x!==st.Preview||P&&(dt(E,!1),dt(R,!1),dt(S,!1),dt(C,!0))},setDefaultUIActions:function(e,t,n){P&&((M||T)&&(!function(e){const t={Glasses:"glasses.svg",Shoes:"shoe.svg",Watches:"watch.svg"},n=null!=e&&t[e]||t.Glasses,r=`${w}/img/icons/${n}`;R.firstChild.firstChild.setAttributeNS("http://www.w3.org/1999/xlink","xlink:href",r)}(I),R.onclick=e),k&&(S.onclick=t),C.onclick=n)},startDeepARLoading:function(){f.classList.add("active"),d.style.visibility="visible"},stopDeepARLoading:L,startThreeLoading:function(){y.classList.add("active"),m.style.visibility="visible"},stopThreeLoading:$,showCameraError:function(){P&&dt(E,!0)}}}function dt(e,t){e.style.display=t?"":"none"}const ht=new Map;function pt(t){let n=ht.get(t);return null==n?(n=function(){let t=0,n=null,r=null,o=null;const i=()=>(null==n&&(n=ut()),n);return{getSetupId:()=>t,incrementSetupId_:()=>t++,getUI_:()=>n,findUI:i,findQR:()=>{if(null==r){const{getQRTarget:t,getQRImage:n}=i();r=function(t,n){let r=!0;return{qrPaused:()=>r,qrDraw:(o,i)=>e(this,void 0,void 0,(function*(){yield b;const e=`https://apps.deepar.ai/${g.includes("alpha")?"shopar-qr-alpha":"shopar-qr"}/?${new URLSearchParams({a:o,s:i,h:location.href})}`,a=yield window.ShopAR__QR.toDataURL(e),s=new Promise(((e,t)=>{n.onload=e,n.onerror=t}));n.src=a,yield s,r=!1,t.style.display=""})),qrPause:()=>e(this,void 0,void 0,(function*(){r=!0,t.style.display="none"}))}}(t(),n())}return r},findThree:()=>{if(null==o){const{getThreeTarget:e,getThreePrompt:t,getThreePromptImage:n}=i();o=qe(e(),t(),n())}return o}}}(),ht.set(t,n)):n.incrementSetupId_(),n}function ft(e){for(const t of ht.values()){if(t===e)continue;const n=t.getUI_();if(null==n)continue;const{getUIState:r,setUIState:o}=n;r()===st.AR&&o(st.None)}}let mt;const gt=new Uint8Array(16);function vt(){if(!mt&&(mt="undefined"!=typeof crypto&&crypto.getRandomValues&&crypto.getRandomValues.bind(crypto),!mt))throw new Error("crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported");return mt(gt)}const wt=[];for(let e=0;e<256;++e)wt.push((e+256).toString(16).slice(1));var yt={randomUUID:"undefined"!=typeof crypto&&crypto.randomUUID&&crypto.randomUUID.bind(crypto)};function bt(e,t,n){if(yt.randomUUID&&!t&&!e)return yt.randomUUID();const r=(e=e||{}).random||(e.rng||vt)();if(r[6]=15&r[6]|64,r[8]=63&r[8]|128,t){n=n||0;for(let e=0;e<16;++e)t[n+e]=r[e];return t}return function(e,t=0){return wt[e[t+0]]+wt[e[t+1]]+wt[e[t+2]]+wt[e[t+3]]+"-"+wt[e[t+4]]+wt[e[t+5]]+"-"+wt[e[t+6]]+wt[e[t+7]]+"-"+wt[e[t+8]]+wt[e[t+9]]+"-"+wt[e[t+10]]+wt[e[t+11]]+wt[e[t+12]]+wt[e[t+13]]+wt[e[t+14]]+wt[e[t+15]]}(r)}const Et="qrLaunch",At="arLaunch",Rt="previewLaunch",St="heartbeat";let Ct,It,xt=!1;const Pt=[];function Mt(){null==Ct&&(It=bt(),Ct=y(`${w}/shopar-analytics.js`),Ct.then((()=>{xt=!0,window.ShopAR__analytics.initializeImpl(),Pt.forEach((e=>e()))})))}function Tt(e){xt?e():Pt.push(e)}function kt(e){return navigator.mediaDevices.getUserMedia({video:{facingMode:e,frameRate:{ideal:30},width:{ideal:640},height:{ideal:360}}})}function Lt(t){return e(this,void 0,void 0,(function*(){const e=document.createElement("video");return e.setAttribute("playsinline","playsinline"),e.srcObject=yield t,e}))}const $t=200,Ut=10;let Dt=!1,_t=null,Nt=[],jt=[];function Ot(t){return e(this,void 0,void 0,(function*(){Dt=!1;const{ShopAR__TrueScale:n}=window;yield n.initialize(`${w}/wasm/mediapipe`,t),_t&&clearInterval(_t);const r=[],o=[];_t=setInterval((()=>e(this,void 0,void 0,(function*(){if(Dt)return;const{error:e,faceWidth:t,ipd:i,translation:a,rotation:s}=yield n.predict(performance.now());Dt||(null!=a&&null!=s&&function(e){for(let t of Nt)t(e)}({translation:a,rotation:s}),null==e&&(r.push(t),o.push(i),r.length<Ut||(r.shift(),o.shift(),function(e,t){for(let n of jt)n({faceWidth:e,IPD:t})}(Wt(r),Wt(o)))))}))),$t)}))}function Ft(){jt=[],Nt=[],Dt=!0}function Wt(e){let t=0;const n=e.length;for(let r=0;r<n;r++)t+=e[r];return t/n}function qt(n){return e(this,void 0,void 0,(function*(){const r=yield p((()=>e(this,void 0,void 0,(function*(){const e=yield fetch(n).catch((e=>{throw console.error(e),new t("Resource unavailable.")}));if(!e.ok)throw new t(`Resource download failed with status ${e.status}.`);return e}))));try{return yield(yield r.blob()).arrayBuffer()}catch(e){throw console.error(e),new t("Resource has invalid body.")}}))}var Gt="undefined"!=typeof Float32Array?Float32Array:Array;function zt(){var e=new Gt(16);return Gt!=Float32Array&&(e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[11]=0,e[12]=0,e[13]=0,e[14]=0),e[0]=1,e[5]=1,e[10]=1,e[15]=1,e}function Qt(e,t,n){var r=t[0],o=t[1],i=t[2],a=t[3],s=t[4],l=t[5],c=t[6],u=t[7],d=t[8],h=t[9],p=t[10],f=t[11],m=t[12],g=t[13],v=t[14],w=t[15],y=n[0],b=n[1],E=n[2],A=n[3];return e[0]=y*r+b*s+E*d+A*m,e[1]=y*o+b*l+E*h+A*g,e[2]=y*i+b*c+E*p+A*v,e[3]=y*a+b*u+E*f+A*w,y=n[4],b=n[5],E=n[6],A=n[7],e[4]=y*r+b*s+E*d+A*m,e[5]=y*o+b*l+E*h+A*g,e[6]=y*i+b*c+E*p+A*v,e[7]=y*a+b*u+E*f+A*w,y=n[8],b=n[9],E=n[10],A=n[11],e[8]=y*r+b*s+E*d+A*m,e[9]=y*o+b*l+E*h+A*g,e[10]=y*i+b*c+E*p+A*v,e[11]=y*a+b*u+E*f+A*w,y=n[12],b=n[13],E=n[14],A=n[15],e[12]=y*r+b*s+E*d+A*m,e[13]=y*o+b*l+E*h+A*g,e[14]=y*i+b*c+E*p+A*v,e[15]=y*a+b*u+E*f+A*w,e}function Vt(e,t){return e[0]=t[12],e[1]=t[13],e[2]=t[14],e}function Kt(e,t){var n=t[0],r=t[1],o=t[2],i=t[4],a=t[5],s=t[6],l=t[8],c=t[9],u=t[10];return e[0]=Math.hypot(n,r,o),e[1]=Math.hypot(i,a,s),e[2]=Math.hypot(l,c,u),e}function Bt(e,t,n,r){var o=t[0],i=t[1],a=t[2],s=t[3],l=o+o,c=i+i,u=a+a,d=o*l,h=o*c,p=o*u,f=i*c,m=i*u,g=a*u,v=s*l,w=s*c,y=s*u,b=r[0],E=r[1],A=r[2];return e[0]=(1-(f+g))*b,e[1]=(h+y)*b,e[2]=(p-w)*b,e[3]=0,e[4]=(h-y)*E,e[5]=(1-(d+g))*E,e[6]=(m+v)*E,e[7]=0,e[8]=(p+w)*A,e[9]=(m-v)*A,e[10]=(1-(d+f))*A,e[11]=0,e[12]=n[0],e[13]=n[1],e[14]=n[2],e[15]=1,e}function Ht(){var e=new Gt(3);return Gt!=Float32Array&&(e[0]=0,e[1]=0,e[2]=0),e}function Xt(e,t,n){var r=new Gt(3);return r[0]=e,r[1]=t,r[2]=n,r}function Zt(e,t){var n=t[0]-e[0],r=t[1]-e[1],o=t[2]-e[2];return Math.hypot(n,r,o)}function Yt(e,t,n){var r=t[0],o=t[1],i=t[2],a=n[3]*r+n[7]*o+n[11]*i+n[15];return a=a||1,e[0]=(n[0]*r+n[4]*o+n[8]*i+n[12])/a,e[1]=(n[1]*r+n[5]*o+n[9]*i+n[13])/a,e[2]=(n[2]*r+n[6]*o+n[10]*i+n[14])/a,e}Math.hypot||(Math.hypot=function(){for(var e=0,t=arguments.length;t--;)e+=arguments[t]*arguments[t];return Math.sqrt(e)});function Jt(){var e=new Gt(4);return Gt!=Float32Array&&(e[0]=0,e[1]=0,e[2]=0),e[3]=1,e}Ht(),function(){var e,t=(e=new Gt(4),Gt!=Float32Array&&(e[0]=0,e[1]=0,e[2]=0,e[3]=0),e)}();var en;let tn,nn,rn;Ht(),Xt(1,0,0),Xt(0,1,0),Jt(),Jt(),en=new Gt(9),Gt!=Float32Array&&(en[1]=0,en[2]=0,en[3]=0,en[5]=0,en[6]=0,en[7]=0),en[0]=1,en[4]=1,en[8]=1;let on,an,sn,ln,cn=!0,un=null;const dn=new Set;let hn,pn,fn,mn,gn,vn,wn;function yn(){null==tn&&(tn=y(`${w}/shopar-deepar.js`))}function bn(){null==nn&&(nn=y(`${w}/shopar-true-scale.js`))}function En(n){return e(this,void 0,void 0,(function*(){const{licenseKey:r,truescaleUsecase:o}=n;return gn=o,null==hn&&(hn=(()=>e(this,void 0,void 0,(function*(){if(null==(null===(e=null===navigator||void 0===navigator?void 0:navigator.mediaDevices)||void 0===e?void 0:e.getUserMedia))throw new t("No camera available!");var e;const n=Mn(sn),o=kt(n);on=yield window.ShopAR__DeepAR.deepar.initialize({licenseKey:r||"your_license_key_goes_here",previewElement:ln,additionalOptions:{hint:vn,cameraConfig:{disableDefaultCamera:!0}}}),an=yield Lt(o),yield Tn(on,an,"user"===n),"Glasses"===sn&&(yield nn,Ot(an),"DetectionLoop"!==gn&&Un((e=>{mn=e.faceWidth})))})))()),hn}))}function An(e,t){var n,r;(t=null!=t?t:function(e){const t={Glasses:["rigidFaceTrackingInit","faceInit"],Shoes:["footInit"],Watches:["wristInit"]};return null==e?void 0:t[e]}(e),e===sn&&(n=t,r=vn,n===r||null!=n&&null!=r&&n.length===r.length&&n.every((e=>r.find((t=>e===t))))&&r.every((e=>n.find((t=>t===e))))))||(null!=on&&(on.shutdown(),on=null,hn=null),sn=e,vn=t)}function Rn(e){e!==ln&&(ln=e,null!=on&&on.changePreviewElement(ln))}function Sn(e){un=e}function Cn(e){on.callbacks.onFaceTracked=t=>{if(t.some((e=>e.detected))){if(mn){const e=137/(mn+5);on.changeParameterVector("GLASSES","","scale",e,e,e,0),on.changeParameterVector("shopar_glasses","","scale",e,e,e,0),function(e){const t=[-8.362421,4.549,-9.275],n=[8.362421,4.549,-9.275];try{const r=Ln("face_position","model","temple_left","temple_left_outer","temple_tip_outer_left",n,e),o=Ln("face_position","model","temple_right","temple_right_outer","temple_tip_outer_right",t,e);on.changeParameterVector("temple_left","","rotation",0,56.6*-r,0,0),on.changeParameterVector("temple_right","","rotation",0,56.6*-o,0,0)}catch(e){return}}(e),Ft(),mn=null}e(),kn("Glasses")}},on.callbacks.onFeetTracked=(t,n)=>{(t.detected||n.detected)&&(e(),kn("Shoes"))},on.callbacks.onWristTracked=t=>{t.detected&&(e(),kn("Watches"))}}function In(t,n){return e(this,void 0,void 0,(function*(){return null!=pn&&fn===n||(yield pn,pn=on.switchEffect(t),fn=n),pn}))}function xn(){return e(this,void 0,void 0,(function*(){if(null!=on){if(cn=!1,null==an){const e=Mn(sn),t=kt(e);an=yield Lt(t),yield Tn(on,an,"user"===e),Ot(an),"DetectionLoop"!==gn&&Un((e=>{mn=e.faceWidth}))}!function(){if(null==un)return;if(null==sn||dn.has(sn))return;un.style.visibility="visible",un.style.opacity="1"}(),on.setPaused(cn),ln.style.display=""}}))}function Pn(){null!=on&&(cn=!0,on.setPaused(cn),Ft(),null!=an&&null!=an.srcObject&&an.srcObject instanceof MediaStream&&(an.srcObject.getTracks().forEach((e=>e.stop())),an=null),function(){if(null==un)return;un.style.visibility="hidden",un.style.opacity="0"}(),on.stopCamera(),ln.style.display="none")}function Mn(e){var t;return null==e?"user":null!==(t={Glasses:"user",Shoes:"environment",Watches:"environment"}[e])&&void 0!==t?t:"user"}function Tn(t,n,r){return e(this,void 0,void 0,(function*(){yield new Promise((o=>{n.onloadedmetadata=()=>{n.play().then((()=>e(this,void 0,void 0,(function*(){t.setVideoElement(n,r),o()}))))}}))}))}function kn(e){null!=un&&(dn.has(e)||(dn.add(e),un.style.opacity="0"))}function Ln(e,t,n,r,o,i,a){const s=on.getTransformationBetween(e,t),l=Vt(Ht(),s),c=function(e,t){var n=new Gt(3);Kt(n,t);var r=1/n[0],o=1/n[1],i=1/n[2],a=t[0]*r,s=t[1]*o,l=t[2]*i,c=t[4]*r,u=t[5]*o,d=t[6]*i,h=t[8]*r,p=t[9]*o,f=t[10]*i,m=a+u+f,g=0;return m>0?(g=2*Math.sqrt(m+1),e[3]=.25*g,e[0]=(d-p)/g,e[1]=(h-l)/g,e[2]=(s-c)/g):a>u&&a>f?(g=2*Math.sqrt(1+a-u-f),e[3]=(d-p)/g,e[0]=.25*g,e[1]=(s+c)/g,e[2]=(h+l)/g):u>f?(g=2*Math.sqrt(1+u-a-f),e[3]=(h-l)/g,e[0]=(s+c)/g,e[1]=.25*g,e[2]=(d+p)/g):(g=2*Math.sqrt(1+f-a-u),e[3]=(s-c)/g,e[0]=(h+l)/g,e[1]=(d+p)/g,e[2]=.25*g),e}(Jt(),s);Bt(s,c,l,Xt(a,a,a));const u=on.getTransformationBetween(t,n),d=Vt(Ht(),u);Bt(u,Jt(),d,Kt(Ht(),u));const h=Qt(zt(),s,u),p=Vt(Ht(),h),f=Math.atan2(i[0]-p[0],Math.abs(i[2]-p[2]));let m;try{m=on.getTransformationBetween(n,r)}catch(e){return f}const g=Qt(zt(),u,m),v=Qt(zt(),s,g),w=Xt(p[0],i[1],i[2]),y=Yt(Ht(),w,function(e,t){var n=t[0],r=t[1],o=t[2],i=t[3],a=t[4],s=t[5],l=t[6],c=t[7],u=t[8],d=t[9],h=t[10],p=t[11],f=t[12],m=t[13],g=t[14],v=t[15],w=n*s-r*a,y=n*l-o*a,b=n*c-i*a,E=r*l-o*s,A=r*c-i*s,R=o*c-i*l,S=u*m-d*f,C=u*g-h*f,I=u*v-p*f,x=d*g-h*m,P=d*v-p*m,M=h*v-p*g,T=w*M-y*P+b*x+E*I-A*C+R*S;return T?(T=1/T,e[0]=(s*M-l*P+c*x)*T,e[1]=(o*P-r*M-i*x)*T,e[2]=(m*R-g*A+v*E)*T,e[3]=(h*A-d*R-p*E)*T,e[4]=(l*I-a*M-c*C)*T,e[5]=(n*M-o*I+i*C)*T,e[6]=(g*b-f*R-v*y)*T,e[7]=(u*R-h*b+p*y)*T,e[8]=(a*P-s*I+c*S)*T,e[9]=(r*I-n*P-i*S)*T,e[10]=(f*A-m*b+v*w)*T,e[11]=(d*b-u*A-p*w)*T,e[12]=(s*C-a*x-l*S)*T,e[13]=(n*x-r*C+o*S)*T,e[14]=(m*y-f*E-g*w)*T,e[15]=(u*E-d*y+h*w)*T,e):null}(zt(),v));let b=on.getClosestPointOnMesh(r,y);try{const e=on.getClosestPointOnMesh(o,y);Zt(y,e)<Zt(y,b)&&(b=e)}catch(e){}const E=Yt(Ht(),b,g);return f-Math.atan2(E[0]-d[0],Math.abs(E[2]-d[2]))}function $n(e){!function(e){Nt.push(e)}(e)}function Un(e){!function(e){jt.push(e)}(e)}function Dn(r,o,i){return e(this,void 0,void 0,(function*(){let a="glb".charCodeAt(0),s="3d".charCodeAt(0);a>>=1,a+=s;const u=String.fromCharCode(a+14);s>>=2,a^=s+2;const d=String.fromCharCode(a-3);a^=5;const h=String.fromCharCode(a-7);a^=2;const f=String.fromCharCode(a-7),m=window[`${h}${d+u+(typeof[])[(+!+[]+ +!+[])*(+!+[]+ +!+[])]}${f}`],g=yield p((()=>e(this,void 0,void 0,(function*(){const e=yield m(`${r}`).catch((()=>{throw new t("Unknown error.")}));if(!e.ok)throw new t("Unknown error.");return e})))),v=new n[0](yield(yield g.blob().catch((()=>{throw new t("Unknown error.")}))).arrayBuffer().catch((()=>{throw new t("Unknown error.")})));i+=s;const w=v.byteLength;if(c[l]=Math.min(76,o)*((a>>5)-1),152===c[l]&&(c[l]=w),i==l)return v;i=l,i^=l;for(let e=0,t=v.length;e<t;e++)c[l]^=c[i]<<13,c[l]^=c[i]>>17,c[l]^=c[i]<<5,v[e]=v[e]^c[l];return i^=c[0],i^=c[1],i^=c[2],v}))}function _n(e,n){if(null==e)throw new t(`'${n}' not specified.`)}function Nn(e,n){if("boolean"!=typeof e)throw new t(`'${n}' must be a boolean.`)}function jn(e,n){if("string"!=typeof e)throw new t(`'${n}' must be a string.`)}const On=["AR","3D"];function Fn(e){const{apiKey:n,sku:r,targetElement:o,initialState:i,initialAnimation:a,baseUrl:s,defaultUI:l,interactive:c,strings:u}=e;_n(n,"apiKey"),jn(n,"apiKey"),_n(r,"sku"),jn(r,"sku"),_n(o,"targetElement"),function(e,n){if(!(e instanceof HTMLElement))throw new t(`'${n}' must be an HTMLElement.`)}(o,"targetElement"),null!=i&&function(e,n,r){if("string"!=typeof e)throw new t(`'${n}' must be a string.`);if(!r.includes(e))throw new t(`'${n}' must be ${r.join("' or '")}.`)}(i,"initialState",On),null!=a&&function(e,n){if("string"!=typeof e&&!Array.isArray(e))throw new t(`'${n}' must be a string or array.`)}(a,"initialAnimation"),null!=s&&jn(s,"baseUrl"),null!=l&&Nn(l,"defaultUI"),null!=c&&Nn(c,"interactive"),null!=u&&function(e,n,r){for(const o of r){const r=e[o];if(null!=r&&"string"!=typeof r)throw new t(`Value for key '${o}' in '${n}' must be a string.`)}}(u,"strings",Ke)}let Wn=!1;function qn(n){return e(this,void 0,void 0,(function*(){const{targetElement:r}=n;w.update(n.baseUrl),Mt();const{trackEvent:o}=function(e){const t=performance.now(),n=bt();return{trackEvent:(r,o={})=>{o=Object.assign(Object.assign({},o),{pluginVersion:g,sessionId:It,setupId:n,timeSinceSetup:performance.now()-t,apiKey:e}),Tt((()=>{window.ShopAR__analytics.trackEventImpl(r,o)}))}}}(n.apiKey);o("visionSetup");const i=yield function(n){return e(this,void 0,void 0,(function*(){const r=yield p((()=>e(this,void 0,void 0,(function*(){const e=yield fetch(`https://dashboard.shopar.ai/plugin/vision?${new URLSearchParams({apiKey:n,sid:u()})}`).catch((e=>{throw console.error(e),new t("API unavailable.")}));if(!e.ok)throw new t(`API call failed with status ${e.status}.`);return e}))));try{return yield r.json()}catch(e){throw console.error(e),new t("API returned invalid body.")}}))}(n.apiKey);o("visionApiResponse",i);const{arKey:a}=i,s=pt(r),{getSetupId:l,findUI:c}=s,d=l();yn(),bn();const{setTargetElement:h,getDeepARTarget:f,setVisibilityParameters:m,getUIState:v,setUIState:y,startDeepARLoading:b,stopDeepARLoading:E,showCameraError:A}=c();if(v()!=st.None)throw Error("UI state is not None, this is weird..");y(st.AR),h(r),m(!1,!1,!0,!1,void 0),b(),yield tn,Gn(l(),d);try{o("visionArLaunch"),Pn(),An("Glasses",["faceInit"]),Rn(f()),yield En({licenseKey:a,truescaleUsecase:"DetectionLoop"}),Gn(l(),d),yield xn(),Gn(l(),d)}catch(e){const n=e instanceof Error;throw o("visionArLaunchFailure",{errorName:n?e.name:"Unknown",errorMessage:n?e.message:""}),A(),Pn(),new t(`AR failed: ${n?e.message:"Unknown error."}`)}finally{E()}return Wn=!0,{registerFacePoseListener:e=>{Wn&&(o("registerFacePoseListener"),$n(e))},registerFaceMeasurementListener:e=>{Wn&&(o("registerFaceMeasurementListener"),Un(e))},switchEffect:t=>e(this,void 0,void 0,(function*(){Wn&&(o("switchEffect",{arUrl:t}),function(e){on.switchEffect(e)}(t))})),clearEffect:()=>{Wn&&(o("clearEffect"),on.clearEffect())},close:()=>{if(Wn){if(Wn=!1,o("visionClose"),v()!==st.AR)throw new t("AR not launched.");Pn(),y(st.None)}}}}))}function Gn(e,n){if(e!==n)throw new t("Setup cancelled. Please ensure that setup is only called once.")}function zn(n){var r,o;return e(this,void 0,void 0,(function*(){Fn(n);const{apiKey:i,sku:a,targetElement:s,initialState:l,initialAnimation:c}=n;!function(e){const n=getComputedStyle(e);if(!["static","relative"].includes(n.position))throw new t(`Invalid targetElement's position. Expected 'static' or 'relative', but found '${n.position}'.`)}(s),w.update(n.baseUrl),function(e){if(null!=e)for(const t of Object.keys(e)){if(!Object.prototype.hasOwnProperty.call(Ve,t)){console.warn(`String for key '${t}' will be ignored.`);continue}const n=e[t];null!=n&&(Ve[t]=n)}}(n.strings);const d=null!=c?ge(c):null,h=function(n,r){return e(this,void 0,void 0,(function*(){const o=yield p((()=>e(this,void 0,void 0,(function*(){const e=yield fetch(`https://dashboard.shopar.ai/plugin?${new URLSearchParams({apiKey:n,sku:r,sid:u()})}`).catch((e=>{throw console.error(e),new t("API unavailable.")}));if(!e.ok)throw new t(`API call failed with status ${e.status}.`);return e}))));try{return yield o.json()}catch(e){throw console.error(e),new t("API returned invalid body.")}}))}(i,a),v=pt(s),{getSetupId:E,findUI:A,findQR:R,findThree:S}=v,C=E();Mt();const{trackEvent:I,arInteracted:x,previewInteracted:P}=function(e,t){const n=performance.now(),r=bt();let o=0,i=0,a=0,s=0,l=0,c=!1;window.setInterval((()=>{c&&(o=i+a,c=!1,u(St,{engagementTotal:o,engagementAR:i,engagement3D:a}))}),1e3);const u=(o,i={})=>{i=Object.assign(Object.assign({},i),{pluginVersion:g,sessionId:It,setupId:r,timeSinceSetup:performance.now()-n,sku:e,apiKey:t}),Tt((()=>{window.ShopAR__analytics.trackEventImpl(o,i)}))};return{trackEvent:u,arInteracted:()=>{const e=performance.now(),t=e-s;s=e,t<200&&(i+=t,c=!0)},previewInteracted:()=>{const e=performance.now(),t=e-l;l=e,t<200&&(a+=t,c=!0)}}}(a,i);I("setup",{hostname:window.location.hostname});const M=yield h;I("apiResponse",M);const{category:T,arUrl:k,arKey:L,arPromptEnabled:$,arPromptText:U,arPromptImage:D,previewUrl:_,previewEnvUrl:N,previewToneMapping:j,previewToneMappingExposure:O,cameraErrorText:F,qrPromptText:W}=M;Qn(E(),C);const q=null!=k&&function(e){return null!=e&&f.includes(e)}(T),G=null==(null===(r=n._internalOptions)||void 0===r?void 0:r.qrEnabled)||(null===(o=n._internalOptions)||void 0===o?void 0:o.qrEnabled),z=q&&function(e){return null!=e&&m.includes(e)}(T),Q=G&&z&&!(yield function(){var t;return e(this,void 0,void 0,(function*(){return null==wn&&(wn=y(`${w}/shopar-platform.js`)),yield wn,["Android","iOS","Windows Phone",void 0].includes(null===(t=window.ShopAR__platform.platform.os)||void 0===t?void 0:t.family)}))}()),V=q&&!Q,K=null!=_;if(Qn(E(),C),Q&&function(){e(this,void 0,void 0,(function*(){null==b&&(b=y(`${w}/shopar-qr.js`))}))}(),V&&(yn(),function(e){e!==rn&&(rn=e,qt(e),pn=null,Ft())}(k),"Glasses"===T&&bn()),K){null==Te&&(Te=y(`${w}/shopar-three.js`));const e=255;Dn(_,(new Date).getTime()+e,Math.random()*e),qt(null!=N?N:`${w}/env/default.hdr`)}const{setTargetElement:B,getDeepARTarget:H,getDeepARPrompt:X,customizeDeepARPrompt:Z,customizeCameraError:Y,customizeQRPrompt:J,setVisibilityParameters:ee,getUIState:te,setUIState:ne,setDefaultUIActions:re,startDeepARLoading:oe,stopDeepARLoading:ie,startThreeLoading:ae,stopThreeLoading:se,showCameraError:le}=A();B(s);ee(null==n.defaultUI||n.defaultUI,Q,V,K,T),Z(null!=U?U:"",null!=D?D:""),Y(F),J(W),function(e,n){const r=e.parentNode;if(null==r)throw new t("Parent node missing.");new MutationObserver((t=>{for(const r of t)for(const t of r.removedNodes)if(t===e)return void n()})).observe(r,{childList:!0})}(s,(()=>{te()!==st.QR||ce()||de(),te()!==st.AR||cn||Pn(),te()!==st.Preview||me()||we(),ne(st.None)}));const{qrPaused:ce,qrDraw:ue,qrPause:de}=R(),{threeInit:he,threeParse:pe,threeLoad:fe,threePaused:me,threeResume:ve,threePause:we,threeSetToneMapping:ye,threeIsInteractive:be,threeSetInteractive:Ee,threeSetOnInteracted:Ae,threeInitPromptAnimation:Re,threeInitCameraAnimation:Se}=S(),Ce=null==n.interactive||n.interactive;Ee(Ce);let Ie=0;if(te()===st.QR){if(!ce())if(Q){I(Et);try{yield ue(i,a)}catch(e){throw new t(`QR failed: ${e instanceof Error?e.message:"Unknown error."}`)}}else de(),ne(st.None)}else if(te()===st.AR){if(!cn)if(V&&!Wn){I(At);const e=yield qt(k);Qn(E(),C),ft(v),An(T),Rn(H()),Sn($?X():null),yield In(e,k),Cn(x),Qn(E(),C)}else Pn(),ne(st.None)}else if(te()===st.Preview&&!me())if(K){I(Rt),ae();const e=255,t=yield Dn(_,(new Date).getTime()+e,Math.random()*e);Qn(E(),C);const n=yield qt(null!=N?N:`${w}/env/default.hdr`);Qn(E(),C);const r=yield pe(t,n,`${_}${N}`);Qn(E(),C),fe(r,T),ye(null!=j?j:"ACES",null!=O?O:1),Ae(P),se()}else we(),ne(st.None);const xe=()=>e(this,void 0,void 0,(function*(){if(Q){if(te()===st.QR||te()===st.AR)throw new t("AR already launched.");try{I(Et);const e=++Ie;if(te()===st.Preview&&K&&!me()&&we(),ne(st.QR),yield ue(i,a),Ie!==e)return;return void Qn(E(),C)}catch(e){const n=e instanceof Error;throw I("qrLaunchFailure",{errorName:n?e.name:"Unknown",errorMessage:n?e.message:""}),new t(`QR failed: ${n?e.message:"Unknown error."}`)}}if(!V)throw new t("Model does not have AR enabled.");if(te()===st.AR)throw new t("AR already launched.");try{I(At);const e=++Ie;te()===st.Preview&&K&&!me()&&we(),ft(v),ne(st.AR),oe();const t=yield qt(k);if(Ie!==e)return;if(Qn(E(),C),yield tn,Ie!==e)return;if(Qn(E(),C),Pn(),An(T),Rn(H()),Sn($?X():null),yield En({licenseKey:L}),Ie!==e)return;if(Qn(E(),C),yield In(t,k),Cn(x),Ie!==e)return;if(Qn(E(),C),yield xn(),Ie!==e)return;Qn(E(),C)}catch(e){const n=e instanceof Error;throw I("arLaunchFailure",{errorName:n?e.name:"Unknown",errorMessage:n?e.message:""}),le(),Pn(),new t(`AR failed: ${n?e.message:"Unknown error."}`)}finally{ie()}})),Pe=()=>e(this,void 0,void 0,(function*(){if(!K)throw new t("Model does not have 3D enabled.");if(te()===st.Preview)throw new t("3D already launched.");try{I(Rt);const e=++Ie;te()===st.AR&&(V&&!cn&&Pn(),de()),ne(st.Preview),ae();const t=255,n=yield Dn(_,(new Date).getTime()+t,Math.random()*t);if(Ie!==e)return;Qn(E(),C);const r=yield qt(null!=N?N:`${w}/env/default.hdr`);if(Ie!==e)return;if(Qn(E(),C),yield Te,Ie!==e)return;if(Qn(E(),C),he(),Ie!==e)return;Qn(E(),C);const o=yield pe(n,r,`${_}${N}`);if(Ie!==e)return;Qn(E(),C),fe(o,T),ye(null!=j?j:"ACES",null!=O?O:1),Ae(P),Re(),null!=d&&Se(d),ve()}catch(e){const n=e instanceof Error;throw I("previewLaunchFailure",{errorName:n?e.name:"Unknown",errorMessage:n?e.message:""}),new t(`3D failed: ${n?e.message:"Unknown error."}`)}finally{se()}})),Me=()=>e(this,void 0,void 0,(function*(){if(te()===st.None)throw new t("Neither AR or 3D launched.");++Ie,te()===st.QR||te()===st.AR?(V&&!cn&&Pn(),de()):te()===st.Preview&&K&&!me()&&we(),ne(st.None)}));return re(xe,Pe,Me),"AR"===l?(yield xe(),Qn(E(),C)):"3D"===l&&(yield Pe(),Qn(E(),C)),Wn=!1,{launchAR:q?xe:void 0,launch3D:K?Pe:void 0,closeAR:q?()=>e(this,void 0,void 0,(function*(){if(te()!==st.AR&&te()!==st.QR)throw new t("AR not launched.");++Ie,V&&!cn&&Pn(),de(),ne(st.None)})):void 0,close3D:K?()=>e(this,void 0,void 0,(function*(){if(te()!==st.Preview)throw new t("3D not launched.");++Ie,K&&!me()&&we(),ne(st.None)})):void 0,close:q||K?Me:void 0,isInteractive:()=>be(),setInteractive:e=>Ee(e)}}))}function Qn(e,n){if(e!==n)throw new t("Setup cancelled. Please ensure that setup is only called once.")}const Vn={setup:function(t){return e(this,void 0,void 0,(function*(){return qn(t)}))}},Kn={setup:function(n){return e(this,void 0,void 0,(function*(){return function(n,r){return e(this,void 0,void 0,(function*(){try{return r()}catch(e){throw e instanceof Error?new t(`${n} failed: ${e.message}`):(console.error(e),new t(`${n} failed.`))}}))}("setup",(()=>zn(n)))}))},version:g};export{Kn as plugin,Vn as vision};
|
package/dist/shopar-plugin.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports):"function"==typeof define&&define.amd?define(["exports"],t):t((e="undefined"!=typeof globalThis?globalThis:e||self).ShopAR={})}(this,(function(e){"use strict";function t(e,t,n,r){return new(n||(n=Promise))((function(o,i){function a(e){try{l(r.next(e))}catch(e){i(e)}}function s(e){try{l(r.throw(e))}catch(e){i(e)}}function l(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(a,s)}l((r=r.apply(e,t||[])).next())}))}!function(){const e={css:".shopar-btn-container{position:absolute;width:100%;bottom:0;padding-bottom:2rem;display:flex;justify-content:center;gap:.5rem;pointer-events:none}.shopar-btn{padding:.5rem .75rem;display:flex;justify-content:center;align-items:center;gap:.25rem;background-color:#fff;border:1px solid #ddd;border-radius:9999px;cursor:pointer;pointer-events:auto}.shopar-btn:hover{background-color:#f5f5f5}.shopar-loading-container{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:1rem;background-color:#fff}.shopar-loading-text{text-align:center}.shopar-loading-bar-bg{width:80%;height:.5rem;background-color:#e5e7eb;border-radius:9999px}.shopar-loading-bar-fg{background-color:#1434f7;border-radius:9999px;transition:none;transform:translateX(-100%);will-change:transform}.shopar-loading-bar-fg.active{transition:transform 5s cubic-bezier(0,0,.2,1);transform:none}.shopar-qr{display:flex;flex-direction:column;justify-content:center;align-items:center;background-color:#fff}.shopar-ar-prompt{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:1rem;background-color:#1e293bb2;transition:.3s ease-in-out opacity}.shopar-ar-prompt-text{text-align:center;color:#fff}.shopar-ar-prompt-img{max-width:80%;max-height:50%;object-fit:contain}"};try{if(process)return process.env=Object.assign({},process.env),void Object.assign(process.env,e)}catch(e){}globalThis.process={env:e}}(),"function"==typeof SuppressedError&&SuppressedError;class n extends Error{constructor(e){super(`ShopAR Plugin: ${e}`)}}const r=[Uint8Array,Uint32Array],o=r.length-2,i=["addEventListener","alert","atob","blur","btoa","cancelAnimationFrame","localStorage","location","locationbar","hash","hasOwnProperty","host","hostname","href","requestAnimationFrame"],a=[2,12,7,1],s=window[i[a[a[o]]]][i[a[a[a.length-1]]]],l=s.charCodeAt(o),c=l^l,u=new r[1]([c]);function d(){const e=(new TextEncoder).encode(s),t=i.map((e=>e.length));for(let n=0;n<e.length;n++)e[n]^=t[n%t.length];return window[i[t[2]]](String.fromCodePoint(...e))}const h=[1e3,2e3,4e3],f=h.length;function p(e,n=0){return t(this,void 0,void 0,(function*(){try{return yield e()}catch(t){if(n>=f)throw t;return yield new Promise((e=>setTimeout(e,h[n]))),p(e,n+1)}}))}const m=["Glasses","Shoes","Watches"],g=["Shoes"];const v="0.2.0";let w=`https://cdn.jsdelivr.net/npm/shopar-plugin@${v}/dist`;const y={update:e=>{null!=e&&(w=e.endsWith("/")?e.substring(0,e.length-1):e)},toString:()=>w};function b(e){return t(this,void 0,void 0,(function*(){if("function"!=typeof importScripts){const t=document.createElement("script");return t.setAttribute("src",e),t.setAttribute("crossorigin","anonymous"),new Promise((e=>{t.addEventListener("load",(()=>e()),!1),t.addEventListener("error",(()=>e()),!1),document.body.appendChild(t)}))}importScripts(e.toString())}))}let E;const A=(()=>{const e=(()=>{var e;if(null===(e=document.documentElement.getAttribute("itemtype"))||void 0===e?void 0:e.includes("schema.org/SearchResultsPage"))return!0;const t=null!=document.head?Array.from(document.head.querySelectorAll("meta")):[];for(const e of t)if("viewport"===e.name)return!0;return!1})();return e||console.warn('No <meta name="viewport"> detected; ShopAR will cap pixel density at 1.'),()=>e?window.devicePixelRatio:1})();let R,S,C;function I(e){const t=function(e){const t=new S.DataTexture(e.data,e.width,e.height,void 0,e.type,void 0,S.ClampToEdgeWrapping,S.ClampToEdgeWrapping,S.LinearFilter,S.LinearFilter,1,S.LinearSRGBColorSpace);return t.flipY=!0,t.generateMipmaps=!1,t.needsUpdate=!0,t}(C.parse(e));return t.mapping=S.EquirectangularReflectionMapping,t.colorSpace=S.LinearSRGBColorSpace,t}const P=45,x=45,M=3,T=1.5,k=1,L=.5;let U,$,D,_,N,j=!1;const O=4,F=.001,W=1e-7,q=10,G=11,z=1/(G-1),Q="function"==typeof Float32Array;function V(e,t,n,r){if(!(0<=e&&e<=1&&0<=n&&n<=1))throw new Error("bezier x values must be in [0, 1] range");if(e===t&&n===r)return Y;const o=Q?new Float32Array(G):new Array(G);for(let t=0;t<G;++t)o[t]=X(t*z,e,n);function i(t){let r=0,i=1;const a=G-1;for(;i!==a&&o[i]<=t;++i)r+=z;--i;const s=r+(t-o[i])/(o[i+1]-o[i])*z,l=Z(s,e,n);return l>=F?function(e,t,n,r){for(let o=0;o<O;++o){const o=Z(t,n,r);if(0===o)return t;t-=(X(t,n,r)-e)/o}return t}(t,s,e,n):0===l?s:function(e,t,n,r,o){let i,a,s=0;do{a=t+(n-t)/2,i=X(a,r,o)-e,i>0?n=a:t=a}while(Math.abs(i)>W&&++s<q);return a}(t,r,r+z,e,n)}return function(e){return 0===e||1===e?e:X(i(e),t,r)}}function K(e,t){return 1-3*t+3*e}function B(e,t){return 3*t-6*e}function H(e){return 3*e}function X(e,t,n){return((K(t,n)*e+B(t,n))*e+H(t))*e}function Z(e,t,n){return 3*K(t,n)*e*e+2*B(t,n)*e+H(t)}function Y(e){return e}function J(e){if("hold"===e.type)return()=>0;if("bezier"===e.type){const t=V(e.x1,e.y1,e.x2,e.y2);return e=>t(e)}throw new Error(`Unknown interpolation: ${e}`)}function ee(e){if(e.length<2)throw new Error("Expected at least two key frames.");const t=e[e.length-1].time,n=[...e].sort(((e,t)=>e.time-t.time)).map((({time:e,value:t,interpolation:n})=>({time:e,value:t,interpolate:J(n)})));let r=0,o=n[0].value;return{reset:()=>{r=0},update:e=>{for(r+=e;r>=t;)r-=t;for(let e=0;e<n.length-1;e++){const t=n[e],i=n[e+1];if(r>=t.time&&r<i.time){const e=t.interpolate((r-t.time)/(i.time-t.time));o=t.value+e*(i.value-t.value)}}},get:()=>o}}const te="#",ne="time",re="interpolation",oe="yaw",ie="pitch",ae="fov",se=[ne,oe,ie,ae,re],le="s",ce="ms",ue=1e3,de="deg",he="rad",fe=Math.PI/180,pe="ease-in-out",me="cubic-bezier(",ge=")";function ve(e){if("string"==typeof e)return function(e){const[t,...n]=function(e){return e.split(/\r?\n/).map((e=>function(e){const t=e.indexOf(te);return(-1!==t?e.substring(0,t):e).trim()}(e))).filter((e=>""!==e))}(e);if(null==t)throw new Error("Header missing.");const r=function(e){const t=[];for(let n=0;n<e.length;n++){const r=e[n];if(!se.includes(r))throw new Error(`Invalid token in header: '${r}'.`);if(t.includes(r))throw new Error(`Duplicate token in header: '${r}'.`);t.push(r)}if(!t.includes(ne))throw new Error(`Missing required token: '${ne}'.`);return t}(t.split(/\s+/)),o={};if(n.length<2)throw new Error("Expected at least two key frames.");for(const e of n){const{theta:t,phi:n,fov:i}=we(r,e);null!=t&&(null==o.theta&&(o.theta=[]),o.theta.push(t)),null!=n&&(null==o.phi&&(o.phi=[]),o.phi.push(n)),null!=i&&(null==o.fov&&(o.fov=[]),o.fov.push(i))}if(0===Object.values(o).length)throw new Error("At least one parameter should be animated.");return o}(e);if(Array.isArray(e))return function(e){var t;const n={};if(e.length<2)throw new Error("Expected at least two key frames.");for(const r of e){const{time:e,pitch:o,yaw:i,fov:a}=r;if(null==e)throw new Error("Time missing.");const s=be(null!==(t=r.interpolation)&&void 0!==t?t:pe);null!=i&&(null==n.theta&&(n.theta=[]),n.theta.push({time:e,value:i*fe,interpolation:s})),null!=o&&(null==n.phi&&(n.phi=[]),n.phi.push({time:e,value:o*fe,interpolation:s})),null!=a&&(null==n.fov&&(n.fov=[]),n.fov.push({time:e,value:a*fe,interpolation:s}))}if(0===Object.values(n).length)throw new Error("At least one parameter should be animated.");if(Object.values(n).every((t=>t.length!==e.length)))throw new Error("All parameters should have the same key frame count.");return n}(e);throw new Error("Expected string or key frame config array.")}function we(e,t){const n=t.match(/[^()\s]+(\(.*?\))?/g);if(null==n||n.length<e.length)throw new Error(`Missing data for fields: '${e.filter((e=>!(null==n?void 0:n.includes(e)))).join(", ")}'.`);if(n.length>e.length)throw new Error(`Excess data: '${n.filter((t=>!e.includes(t))).join(", ")}'.`);const r=e.indexOf(ne),o=function(e){if(e.endsWith(ce))return Ae(e.substring(0,e.length-ce.length));if(e.endsWith(le))return Ae(e.substring(0,e.length-le.length))*ue;return Ae(e)}(n[r]),i=e.indexOf(re),a=be(-1===i?pe:n[i]),s={};for(let t=0;t<n.length;t++){if(t===r||t===i)continue;const l=e[t],c=n[t];switch(l){case oe:s.theta={time:o,value:ye(c),interpolation:a};break;case ie:s.phi={time:o,value:ye(c),interpolation:a};break;case ae:s.fov={time:o,value:ye(c),interpolation:a};break;default:throw new Error(`Unhandled value for header '${l}'.`)}}return s}function ye(e){return e.endsWith(de)?Ae(e.substring(0,e.length-de.length))*fe:e.endsWith(he)?Ae(e.substring(0,e.length-he.length)):Ae(e)*fe}function be(e){if("hold"===e)return{type:"hold"};if("linear"===e)return Ee(0,0,1,1);if("sine"===e)return Ee(.37,0,.63,1);if("sine-in"===e)return Ee(.12,0,.39,0);if("sine-out"===e)return Ee(.61,1,.88,1);if("ease"===e)return Ee(.25,.1,.25,1);if("ease-in"===e)return Ee(.42,0,1,1);if("ease-out"===e)return Ee(0,0,.58,1);if("ease-in-out"===e)return Ee(.42,0,.58,1);if(e.startsWith(me)&&e.endsWith(ge)){const t=e.substring(me.length,e.length-ge.length).split(/\s*,\s*/);if(4!==t.length)throw new Error(`Expected 4 parameters for the Bezier curve, but got '${t}'.`);return{type:"bezier",x1:Ae(t[0]),y1:Ae(t[1]),x2:Ae(t[2]),y2:Ae(t[3])}}throw new Error(`Expected an interpolation token, but found: ${e}`)}function Ee(e,t,n,r){return{type:"bezier",x1:e,y1:t,x2:n,y2:r}}function Ae(e){const t=Number.parseFloat(e);if(Number.isNaN(t))throw new Error(`Expected a numeric value, but got: ${e}`);return t}const Re=300,Se=2e3,Ce=.05,Ie=2*Math.PI/32,Pe=be("hold"),xe=be("sine"),Me=be("sine-in"),Te=be("sine-out");let ke;const Le=0;let Ue,$e,De,_e=!1,Ne=1,je=1,Oe=1;const Fe=1;let We;const qe=new Map;function Ge(e,n,r){const o=e.getContext("2d");null==o&&console.warn("2D context missing.");let i,a,s,l,c,u,d,h,f,p,m,g,v,w=!1,y=!0,b=!1,E=!0,A=!1,k=!1,j=0,O=1,F=1,W=1;const q={threeInit:()=>{w||(ze(),i=new $e.Scene,a=new $e.PerspectiveCamera(25,1,.5),s=new Ue.OrbitControls(a,e),s.setInteractionEnabled(E),({renderShadow:c,shadowGroup:l}=function(e){const t=new U.WebGLRenderTarget(512,512);t.texture.generateMipmaps=!1;const n=new U.WebGLRenderTarget(512,512);n.texture.generateMipmaps=!1;const r=new U.Group;r.position.y=-.7;const o=new U.PlaneGeometry(P,x).rotateX(Math.PI/2),i=new U.MeshBasicMaterial({map:t.texture,opacity:L,transparent:!0,depthWrite:!1}),a=new U.Mesh(o,i);a.renderOrder=1,a.scale.y=-1,r.add(a);const s=new U.Mesh(o);s.visible=!1,r.add(s);const l=new U.OrthographicCamera(-P/2,P/2,x/2,-x/2,0,M);function c(e){s.visible=!0,_.uniforms.tDiffuse.value=t.texture,_.uniforms.h.value=1*e/256,s.material=_,$.setRenderTarget(n),$.render(s,l),N.uniforms.tDiffuse.value=n.texture,N.uniforms.v.value=1*e/256,s.material=N,$.setRenderTarget(t),$.render(s,l),s.visible=!1}return l.rotation.x=Math.PI/2,r.add(l),{shadowGroup:r,renderShadow:()=>{const n=e.background;e.background=null,e.overrideMaterial=D;const r=$.getClearAlpha();$.setClearAlpha(0),$.setRenderTarget(t),$.render(e,l),e.overrideMaterial=null,c(T),c(.4*T),$.setRenderTarget(null),$.setClearAlpha(r),e.background=n}}}(i)),w=!0)},threeParse:(e,n,r)=>t(this,void 0,void 0,(function*(){return null!=u&&d===r||(yield u,u=(()=>t(this,void 0,void 0,(function*(){var t,r;return S=(t=Ue).THREE,C=new t.RGBELoader,i.environment=I(n),function(e,t){const{THREE:n}=t;R=(new t.GLTFLoader).setDRACOLoader((new t.DRACOLoader).setDecoderPath(`https://cdn.jsdelivr.net/npm/three@0.${n.REVISION}.0/examples/jsm/libs/draco/gltf/`)).setKTX2Loader((new t.KTX2Loader).setTranscoderPath(`https://cdn.jsdelivr.net/npm/three@0.${n.REVISION}.0/examples/jsm/libs/basis/`).detectSupport(e)).setMeshoptDecoder(t.MeshoptDecoder)}(We,Ue),r=e,R.parseAsync(r.buffer,"")})))(),d=r),u})),threeLoad:(e,t)=>{i.clear(),i.add(e.scene);const n=(new $e.Box3).setFromObject(e.scene);l.position.y=n.min.y-Le,i.add(l),c(),i.traverse((e=>{if(e instanceof $e.Mesh){const t=e.material;t.depthWrite=!0,t instanceof $e.MeshPhysicalMaterial&&t.transmissionMap&&(t.transmission=1,t.toneMapped=!1,t.fog=!1,t.needsUpdate=!0)}}));const r=n.min.clone().add(n.max).divideScalar(2),o=Math.sqrt(Ue.reduceVertices(e.scene,((e,t)=>Math.max(e,r.distanceToSquared(t))),0));s.reset(r,o,function(e,t){var n;const r={Glasses:new t(67.5,15,90),Shoes:new t(-55,30,30),Watches:new t(0,-10,40),Handbags:new t(40,0,0),Rings:new t(0,0,10)};return(null==e?r.Glasses:null!==(n=r[e])&&void 0!==n?n:r.Glasses).normalize()}(t,$e.Vector3)),k=!0},threePaused:()=>y,threeResume:()=>{y=!1,We.setAnimationLoop(Qe),e.style.visibility="visible",j=0,null==f||f.reset(),null==p||p.reset(),null==m||m.reset(),null==g||g.reset(),null==v||v.reset()},threePause:()=>{y=!0,function(){for(const{threePaused:e}of qe.values())if(!e())return!1;return!0}()&&We.setAnimationLoop(null),e.style.visibility="hidden",n.style.visibility="hidden"},threeSetToneMapping:e=>({ACES:$e.ACESFilmicToneMapping,Linear:$e.LinearToneMapping,Neutral:$e.NeutralToneMapping}[e||"ACES"]||$e.ACESFilmicToneMapping),threeIsInteractive:()=>E,threeSetInteractive:e=>{E=e,null==s||s.setInteractionEnabled(E)},threeSetOnInteracted:e=>{s.removeEventListener("change",h),h=e,s.addEventListener("change",e)},threeInitPromptAnimation:()=>{var e;e=s.getTheta(),f=ee([{time:0,value:e,interpolation:Pe},{time:Re,value:e,interpolation:Te},{time:Re+Se/4,value:e+Ie,interpolation:xe},{time:Re+3*Se/4,value:e-Ie,interpolation:Me},{time:Re+Se,value:e,interpolation:Pe},{time:Re+2*Se,value:e,interpolation:Pe}]),p=null,m=null,g=ee([{time:0,value:0,interpolation:Pe},{time:Re,value:1,interpolation:Pe},{time:Re+Se,value:0,interpolation:Pe},{time:Re+2*Se,value:0,interpolation:Pe}]),v=ee([{time:0,value:0,interpolation:Pe},{time:Re,value:0,interpolation:Te},{time:Re+Se/4,value:-Ce,interpolation:xe},{time:Re+3*Se/4,value:Ce,interpolation:Me},{time:Re+Se,value:0,interpolation:Pe},{time:Re+2*Se,value:0,interpolation:Pe}])},threeInitCameraAnimation:e=>{const{theta:t,phi:n,fov:r}=e;f=null!=t?ee(t):null,p=null!=n?ee(n):null,m=null!=r?ee(r):null},preRender_:e=>{if(!w||y)return;e=performance.now();const t=0!==j?e-j:0;j=e,k&&(b=!0,k=!1),A||(s.hasUserInteracted()?(A=!0,f=null,p=null,m=null,g=null,v=null):(null==f||f.update(t),null==p||p.update(t),null==m||m.update(t),null==g||g.update(t),null==v||v.update(t),null!=f&&(s.setTheta(f.get()),b=!0),null!=p&&(s.setPhi(p.get()),b=!0),null!=m&&(s.setFovRadians(m.get()),b=!0))),s.update()&&(b=!0)},shouldRender_:()=>!(!w||y)&&b,render_:()=>{const t=We.toneMapping;We.setViewport(0,0,e.width,e.height),We.render(i,a),We.toneMapping=t,b=!1,null!=o&&(o.clearRect(0,0,e.width,e.height),De.width>0&&De.height>0&&o.drawImage(De,0,je-e.height,e.width,e.height,0,0,e.width,e.height),n.style.visibility=E&&!A?"visible":"hidden",null!=g&&(r.style.opacity=`${g.get()}`),null!=v&&(r.style.transform=`translateX(${v.get()*Math.min(O,F)}px)`))},updateSize_:()=>{const{clientWidth:t,clientHeight:n}=e;t===O&&n===F&&Oe===W||(e.width=Math.ceil(t*Oe*Fe),e.height=Math.ceil(n*Oe*Fe),O=t,F=n,W=Oe,b=!0)},target_:e};return qe.set(e,q),q}function ze(){if(_e)return;Ue=window.ShopAR__THREE,$e=Ue.THREE,De=document.createElement("canvas");var e,t;De.style.position="block",We=new $e.WebGLRenderer({powerPreference:"high-performance",canvas:De,antialias:!0,alpha:!0}),We.outputColorSpace=$e.SRGBColorSpace,We.toneMapping=$e.ACESFilmicToneMapping,We.setClearColor(new $e.Color(16777215)),e=We,t=Ue,j||(U=t.THREE,$=e,D=new U.MeshDepthMaterial,D.userData.darkness={value:k},D.onBeforeCompile=e=>{e.uniforms.darkness=D.userData.darkness;const t=e.fragmentShader.replace("gl_FragColor = vec4( vec3( 1.0 - fragCoordZ ), opacity );","gl_FragColor = vec4( vec3( 0.0 ), ( 1.0 - fragCoordZ ) * darkness );");e.fragmentShader=`uniform float darkness;\n${t}`},D.depthTest=!1,D.depthWrite=!1,_=new U.ShaderMaterial(t.HorizontalBlurShader),_.depthTest=!1,N=new U.ShaderMaterial(t.VerticalBlurShader),N.depthTest=!1,j=!0),Ve(),_e=!0}function Qe(e){Ve(),We.clear();for(const{preRender_:t,shouldRender_:n,render_:r}of qe.values())t(e),n()&&r()}function Ve(){let e=0,t=0;for(const{target_:n}of qe.values()){const{clientWidth:r,clientHeight:o}=n;e=Math.max(e,r),t=Math.max(t,o)}const n=A();e=Math.ceil(e*n*Fe),t=Math.ceil(t*n*Fe),e===Ne&&t===je&&n===Oe||(Ne=e,je=t,Oe=n,We.setSize(Ne,je,!1));for(const{updateSize_:e}of qe.values())e()}const Ke={"loading.ar":"Loading Try On...","loading.3d":"Loading 3D..."},Be=Object.keys(Ke);function He(e){return Ke[e]}const Xe="shopar-error";function Ze(e,t){const n=document.createElementNS("http://www.w3.org/2000/svg","svg");n.setAttribute("width",e),n.setAttribute("height",e);{const r=document.createElementNS("http://www.w3.org/2000/svg","image");r.setAttributeNS("http://www.w3.org/1999/xlink","xlink:href",t),r.setAttribute("width",e),r.setAttribute("height",e),n.appendChild(r)}return n}function Ye(e,t,n,r){const o=document.createElement("button");o.id=e,o.type="button",o.className="shopar-btn";{const e=Ze("1.75rem",r);o.appendChild(e)}{const e=document.createElement("span");e.textContent=t,o.appendChild(e)}o.ariaLabel=n;return o.style.display="none",o}const Je="shopar-control";const et="shopar-deepar-output";function tt(e){const t=document.createElement("div");t.classList.add("shopar-loading-container",e);const n=t.style;return n.position="absolute",n.top="0",n.left="0",n.width="100%",n.height="100%",t}function nt(e,t){const n=document.createElement("div");return n.classList.add("shopar-loading-text",e),n.textContent=t,n.style.textAlign="center",n}function rt(e){const t=document.createElement("div");t.classList.add("shopar-loading-bar-bg",e);const n=t.style;return n.position="relative",n.overflow="hidden",t}function ot(e){const t=document.createElement("div");t.classList.add("shopar-loading-bar-fg",e);const n=t.style;return n.width="100%",n.height="100%",t}const it="shopar-main";const at="shopar-qr-output";const st="shopar-three-output";var lt;!function(e){e[e.None=0]="None",e[e.QR=1]="QR",e[e.AR=2]="AR",e[e.Preview=3]="Preview"}(lt||(lt={}));let ct=!1;function ut(){ct||(!function(){try{const e=document.createElement("style"),t=process.env.css;null!=t&&(e.innerHTML=t);const n=document.head;n.insertBefore(e,n.children[0])}catch(e){console.warn("Failed to write default ShopAR Plugin CSS.")}}(),ct=!0)}function dt(){ut();const e=function(){const e=document.createElement("div");e.id=it;const t=e.style;return t.position="absolute",t.top="0",t.bottom="0",t.left="0",t.right="0",e}(),t=function(){const e=document.createElement("div");return e.style.textAlign="center",e}(),n=function(){const e=new Image,t=e.style;return t.maxWidth="100%",t.maxHeight="100%",e}(),r=function(e,t){const n=document.createElement("div");n.id=at;const r=n.style;r.position="absolute",r.top="0",r.left="0",r.width="100%",r.height="100%",r.display="none";const o=document.createElement("div");o.className="shopar-qr";const i=o.style;i.position="relative",i.top="0",i.left="0",i.width="100%",i.height="100%",n.appendChild(o),o.appendChild(e);const a=document.createElement("div");return a.appendChild(t),o.appendChild(a),n}(t,n);e.appendChild(r);const o=function(){const e=document.createElement("div");e.id=et;const t=e.style;return t.position="absolute",t.top="0",t.left="0",t.width="100%",t.height="100%",t.display="none",e}();e.appendChild(o);const i=function(){const e=document.createElement("canvas");e.id=st;const t=e.style;return t.position="absolute",t.top="0",t.left="0",t.width="100%",t.height="100%",t.visibility="hidden",e}();e.appendChild(i);const a=function(){const e=document.createElement("div");return e.className="shopar-ar-prompt-text",e}(),s=function(){const e=new Image;return e.className="shopar-ar-prompt-img",e}(),l=function(e,t){const n=document.createElement("div");n.className="shopar-ar-prompt";const{style:r}=n;return r.position="absolute",r.width="100%",r.height="100%",r.pointerEvents="none",r.opacity="0",n.appendChild(e),n.appendChild(t),n}(a,s);e.appendChild(l);const c=function(){const e=Ze("2rem",`${y}/img/prompt/3d-interaction.svg`),{style:t}=e;return t.transition="opacity 0.3s",t.opacity="0",e}(),u=function(e){const t=document.createElement("div"),{style:n}=t;return n.visibility="hidden",n.position="absolute",n.width="100%",n.height="100%",n.display="flex",n.justifyContent="center",n.alignItems="center",n.pointerEvents="none",t.appendChild(e),t}(c);e.appendChild(u);const d=tt("shopar-ar-loading-container"),h=nt("shopar-ar-loading-text",He("loading.ar"));d.appendChild(h);const f=rt("shopar-ar-loading-bar-bg"),p=ot("shopar-ar-loading-bar-fg");f.appendChild(p),d.appendChild(f),e.appendChild(d);const m=tt("shopar-3d-loading-container"),g=nt("shopar-3d-loading-text",He("loading.3d"));m.appendChild(g);const v=rt("shopar-3d-loading-bar-bg"),w=ot("shopar-3d-loading-bar-fg");v.appendChild(w),m.appendChild(v),e.appendChild(m);const b=function(){const e=document.createElement("div");return e.className="shopar-error-text",e.style.textAlign="center",e}(),E=function(e){const t=document.createElement("div");t.id=Xe;const n=t.style;n.position="absolute",n.width="100%",n.height="100%",n.display="none";const r=document.createElement("div"),o=r.style;return o.position="absolute",o.width="100%",o.height="100%",o.backgroundColor="#ffffff",o.display="flex",o.flexDirection="column",o.justifyContent="center",o.alignItems="center",t.appendChild(r),r.appendChild(e),t}(b);e.appendChild(E);const A=function(){const e=document.createElement("div");return e.id=Je,e.role="group",e.ariaLabel="Preview type chooser",e.className="shopar-btn-container",e.style.display="none",e}();e.appendChild(A);const R=Ye("shopar-btn-vto","Try-on","Launch ShopAR virtual try-on","data:image/svg+xml,%3Csvg%20xmlns=%22http://www.w3.org/2000/svg%22/%3E");A.appendChild(R);const S=Ye("shopar-btn-3d","3D","Launch ShopAR 3D preview",`${y}/img/icons/cube.svg`);A.appendChild(S);const C=Ye("shopar-btn-close","Close","Close ShopAR view",`${y}/img/icons/close.svg`);A.append(C);let I,P=lt.None,x=!1,M=!1,T=!1,k=!1;function L(){p.classList.remove("active"),d.style.visibility="hidden"}function U(){w.classList.remove("active"),m.style.visibility="hidden"}return{setTargetElement:function(t){t.style.position="relative",t.appendChild(e)},getQRTarget:function(){return r},getQRImage:function(){return n},getDeepARTarget:function(){return o},getDeepARPrompt:function(){return l},getThreeTarget:function(){return i},getThreePrompt:function(){return u},getThreePromptImage:function(){return c},customizeDeepARPrompt:function(e,t){a.textContent=e,s.src=t},customizeCameraError:function(e){b.textContent=null!=e?e:"Please reload page and allow camera access to continue"},customizeQRPrompt:function(e){t.textContent=null!=e?e:"Scan on mobile or tablet to try on"},setVisibilityParameters:function(e,t,n,r,o){var i;x=e,M=t,T=n,k=r,I=o,ht(A,x),ht(R,x&&(T||M)&&P===lt.None),ht(S,x&&k&&P===lt.None),ht(C,x&&P!==lt.None),L(),U(),x||""===(i=E).style.display&&ht(i,!1)},getUIState:function(){return P},setUIState:function(e){P=e,P===lt.None?(L(),U(),x&&(ht(E,!1),ht(C,!1),(M||T)&&ht(R,!0),k&&ht(S,!0))):P!==lt.QR&&P!==lt.AR&&P!==lt.Preview||x&&(ht(E,!1),ht(R,!1),ht(S,!1),ht(C,!0))},setDefaultUIActions:function(e,t,n){x&&((M||T)&&(!function(e){const t={Glasses:"glasses.svg",Shoes:"shoe.svg",Watches:"watch.svg"},n=null!=e&&t[e]||t.Glasses,r=`${y}/img/icons/${n}`;R.firstChild.firstChild.setAttributeNS("http://www.w3.org/1999/xlink","xlink:href",r)}(I),R.onclick=e),k&&(S.onclick=t),C.onclick=n)},startDeepARLoading:function(){p.classList.add("active"),d.style.visibility="visible"},stopDeepARLoading:L,startThreeLoading:function(){w.classList.add("active"),m.style.visibility="visible"},stopThreeLoading:U,showCameraError:function(){x&&ht(E,!0)}}}function ht(e,t){e.style.display=t?"":"none"}const ft=new Map;function pt(e){let n=ft.get(e);return null==n?(n=function(){let e=0,n=null,r=null,o=null;const i=()=>(null==n&&(n=dt()),n);return{getSetupId:()=>e,incrementSetupId_:()=>e++,getUI_:()=>n,findUI:i,findQR:()=>{if(null==r){const{getQRTarget:e,getQRImage:n}=i();r=function(e,n){let r=!0;return{qrPaused:()=>r,qrDraw:(o,i)=>t(this,void 0,void 0,(function*(){yield E;const t=`https://apps.deepar.ai/${v.includes("alpha")?"shopar-qr-alpha":"shopar-qr"}/?${new URLSearchParams({a:o,s:i,h:location.href})}`,a=yield window.ShopAR__QR.toDataURL(t),s=new Promise(((e,t)=>{n.onload=e,n.onerror=t}));n.src=a,yield s,r=!1,e.style.display=""})),qrPause:()=>t(this,void 0,void 0,(function*(){r=!0,e.style.display="none"}))}}(e(),n())}return r},findThree:()=>{if(null==o){const{getThreeTarget:e,getThreePrompt:t,getThreePromptImage:n}=i();o=Ge(e(),t(),n())}return o}}}(),ft.set(e,n)):n.incrementSetupId_(),n}function mt(e){for(const t of ft.values()){if(t===e)continue;const n=t.getUI_();if(null==n)continue;const{getUIState:r,setUIState:o}=n;r()===lt.AR&&o(lt.None)}}let gt;const vt=new Uint8Array(16);function wt(){if(!gt&&(gt="undefined"!=typeof crypto&&crypto.getRandomValues&&crypto.getRandomValues.bind(crypto),!gt))throw new Error("crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported");return gt(vt)}const yt=[];for(let e=0;e<256;++e)yt.push((e+256).toString(16).slice(1));var bt={randomUUID:"undefined"!=typeof crypto&&crypto.randomUUID&&crypto.randomUUID.bind(crypto)};function Et(e,t,n){if(bt.randomUUID&&!t&&!e)return bt.randomUUID();const r=(e=e||{}).random||(e.rng||wt)();if(r[6]=15&r[6]|64,r[8]=63&r[8]|128,t){n=n||0;for(let e=0;e<16;++e)t[n+e]=r[e];return t}return function(e,t=0){return yt[e[t+0]]+yt[e[t+1]]+yt[e[t+2]]+yt[e[t+3]]+"-"+yt[e[t+4]]+yt[e[t+5]]+"-"+yt[e[t+6]]+yt[e[t+7]]+"-"+yt[e[t+8]]+yt[e[t+9]]+"-"+yt[e[t+10]]+yt[e[t+11]]+yt[e[t+12]]+yt[e[t+13]]+yt[e[t+14]]+yt[e[t+15]]}(r)}const At="qrLaunch",Rt="arLaunch",St="previewLaunch",Ct="heartbeat";let It,Pt,xt=!1;const Mt=[];function Tt(){null==It&&(Pt=Et(),It=b(`${y}/shopar-analytics.js`),It.then((()=>{xt=!0,window.ShopAR__analytics.initializeImpl(),Mt.forEach((e=>e()))})))}function kt(e){xt?e():Mt.push(e)}function Lt(e){return navigator.mediaDevices.getUserMedia({video:{facingMode:e,frameRate:{ideal:30},width:{ideal:640},height:{ideal:360}}})}function Ut(e){return t(this,void 0,void 0,(function*(){const t=document.createElement("video");return t.setAttribute("playsinline","playsinline"),t.srcObject=yield e,t}))}const $t=200,Dt=10;let _t=!1,Nt=null,jt=[],Ot=[];function Ft(e){return t(this,void 0,void 0,(function*(){_t=!1;const{ShopAR__TrueScale:n}=window;yield n.initialize(`${y}/wasm/mediapipe`,e),Nt&&clearInterval(Nt);const r=[],o=[];Nt=setInterval((()=>t(this,void 0,void 0,(function*(){if(_t)return;const{error:e,faceWidth:t,ipd:i,translation:a,rotation:s}=yield n.predict(performance.now());_t||(null!=a&&null!=s&&function(e){for(let t of jt)t(e)}({translation:a,rotation:s}),null==e&&(r.push(t),o.push(i),r.length<Dt||(r.shift(),o.shift(),function(e,t){for(let n of Ot)n({faceWidth:e,IPD:t})}(qt(r),qt(o)))))}))),$t)}))}function Wt(){Ot=[],jt=[],_t=!0}function qt(e){let t=0;const n=e.length;for(let r=0;r<n;r++)t+=e[r];return t/n}function Gt(e){return t(this,void 0,void 0,(function*(){const r=yield p((()=>t(this,void 0,void 0,(function*(){const t=yield fetch(e).catch((e=>{throw console.error(e),new n("Resource unavailable.")}));if(!t.ok)throw new n(`Resource download failed with status ${t.status}.`);return t}))));try{return yield(yield r.blob()).arrayBuffer()}catch(e){throw console.error(e),new n("Resource has invalid body.")}}))}var zt="undefined"!=typeof Float32Array?Float32Array:Array;function Qt(){var e=new zt(16);return zt!=Float32Array&&(e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[11]=0,e[12]=0,e[13]=0,e[14]=0),e[0]=1,e[5]=1,e[10]=1,e[15]=1,e}function Vt(e,t,n){var r=t[0],o=t[1],i=t[2],a=t[3],s=t[4],l=t[5],c=t[6],u=t[7],d=t[8],h=t[9],f=t[10],p=t[11],m=t[12],g=t[13],v=t[14],w=t[15],y=n[0],b=n[1],E=n[2],A=n[3];return e[0]=y*r+b*s+E*d+A*m,e[1]=y*o+b*l+E*h+A*g,e[2]=y*i+b*c+E*f+A*v,e[3]=y*a+b*u+E*p+A*w,y=n[4],b=n[5],E=n[6],A=n[7],e[4]=y*r+b*s+E*d+A*m,e[5]=y*o+b*l+E*h+A*g,e[6]=y*i+b*c+E*f+A*v,e[7]=y*a+b*u+E*p+A*w,y=n[8],b=n[9],E=n[10],A=n[11],e[8]=y*r+b*s+E*d+A*m,e[9]=y*o+b*l+E*h+A*g,e[10]=y*i+b*c+E*f+A*v,e[11]=y*a+b*u+E*p+A*w,y=n[12],b=n[13],E=n[14],A=n[15],e[12]=y*r+b*s+E*d+A*m,e[13]=y*o+b*l+E*h+A*g,e[14]=y*i+b*c+E*f+A*v,e[15]=y*a+b*u+E*p+A*w,e}function Kt(e,t){return e[0]=t[12],e[1]=t[13],e[2]=t[14],e}function Bt(e,t){var n=t[0],r=t[1],o=t[2],i=t[4],a=t[5],s=t[6],l=t[8],c=t[9],u=t[10];return e[0]=Math.hypot(n,r,o),e[1]=Math.hypot(i,a,s),e[2]=Math.hypot(l,c,u),e}function Ht(e,t,n,r){var o=t[0],i=t[1],a=t[2],s=t[3],l=o+o,c=i+i,u=a+a,d=o*l,h=o*c,f=o*u,p=i*c,m=i*u,g=a*u,v=s*l,w=s*c,y=s*u,b=r[0],E=r[1],A=r[2];return e[0]=(1-(p+g))*b,e[1]=(h+y)*b,e[2]=(f-w)*b,e[3]=0,e[4]=(h-y)*E,e[5]=(1-(d+g))*E,e[6]=(m+v)*E,e[7]=0,e[8]=(f+w)*A,e[9]=(m-v)*A,e[10]=(1-(d+p))*A,e[11]=0,e[12]=n[0],e[13]=n[1],e[14]=n[2],e[15]=1,e}function Xt(){var e=new zt(3);return zt!=Float32Array&&(e[0]=0,e[1]=0,e[2]=0),e}function Zt(e,t,n){var r=new zt(3);return r[0]=e,r[1]=t,r[2]=n,r}function Yt(e,t){var n=t[0]-e[0],r=t[1]-e[1],o=t[2]-e[2];return Math.hypot(n,r,o)}function Jt(e,t,n){var r=t[0],o=t[1],i=t[2],a=n[3]*r+n[7]*o+n[11]*i+n[15];return a=a||1,e[0]=(n[0]*r+n[4]*o+n[8]*i+n[12])/a,e[1]=(n[1]*r+n[5]*o+n[9]*i+n[13])/a,e[2]=(n[2]*r+n[6]*o+n[10]*i+n[14])/a,e}Math.hypot||(Math.hypot=function(){for(var e=0,t=arguments.length;t--;)e+=arguments[t]*arguments[t];return Math.sqrt(e)});function en(){var e=new zt(4);return zt!=Float32Array&&(e[0]=0,e[1]=0,e[2]=0),e[3]=1,e}Xt(),function(){var e,t=(e=new zt(4),zt!=Float32Array&&(e[0]=0,e[1]=0,e[2]=0,e[3]=0),e)}();var tn;let nn,rn,on;Xt(),Zt(1,0,0),Zt(0,1,0),en(),en(),tn=new zt(9),zt!=Float32Array&&(tn[1]=0,tn[2]=0,tn[3]=0,tn[5]=0,tn[6]=0,tn[7]=0),tn[0]=1,tn[4]=1,tn[8]=1;let an,sn,ln,cn,un=!0,dn=null;const hn=new Set;let fn,pn,mn,gn,vn,wn,yn;function bn(){null==nn&&(nn=b(`${y}/shopar-deepar.js`))}function En(){null==rn&&(rn=b(`${y}/shopar-true-scale.js`))}function An(e){return t(this,void 0,void 0,(function*(){const{licenseKey:r,truescaleUsecase:o}=e;return vn=o,null==fn&&(fn=(()=>t(this,void 0,void 0,(function*(){if(null==(null===(e=null===navigator||void 0===navigator?void 0:navigator.mediaDevices)||void 0===e?void 0:e.getUserMedia))throw new n("No camera available!");var e;const t=Tn(ln),o=Lt(t);an=yield window.ShopAR__DeepAR.deepar.initialize({licenseKey:r||"your_license_key_goes_here",previewElement:cn,additionalOptions:{hint:wn,cameraConfig:{disableDefaultCamera:!0}}}),sn=yield Ut(o),yield kn(an,sn,"user"===t),"Glasses"===ln&&(yield rn,Ft(sn),"DetectionLoop"!==vn&&Dn((e=>{gn=e.faceWidth})))})))()),fn}))}function Rn(e,t){var n,r;(t=null!=t?t:function(e){const t={Glasses:["rigidFaceTrackingInit","faceInit"],Shoes:["footInit"],Watches:["wristInit"]};return null==e?void 0:t[e]}(e),e===ln&&(n=t,r=wn,n===r||null!=n&&null!=r&&n.length===r.length&&n.every((e=>r.find((t=>e===t))))&&r.every((e=>n.find((t=>t===e))))))||(null!=an&&(an.shutdown(),an=null,fn=null),ln=e,wn=t)}function Sn(e){e!==cn&&(cn=e,null!=an&&an.changePreviewElement(cn))}function Cn(e){dn=e}function In(e){an.callbacks.onFaceTracked=t=>{if(t.some((e=>e.detected))){if(gn){const e=137/(gn+5);an.changeParameterVector("GLASSES","","scale",e,e,e,0),an.changeParameterVector("shopar_glasses","","scale",e,e,e,0),function(e){const t=[-8.362421,4.549,-9.275],n=[8.362421,4.549,-9.275];try{const r=Un("face_position","model","temple_left","temple_left_outer","temple_tip_outer_left",n,e),o=Un("face_position","model","temple_right","temple_right_outer","temple_tip_outer_right",t,e);an.changeParameterVector("temple_left","","rotation",0,56.6*-r,0,0),an.changeParameterVector("temple_right","","rotation",0,56.6*-o,0,0)}catch(e){return}}(e),Wt(),gn=null}e(),Ln("Glasses")}},an.callbacks.onFeetTracked=(t,n)=>{(t.detected||n.detected)&&(e(),Ln("Shoes"))},an.callbacks.onWristTracked=t=>{t.detected&&(e(),Ln("Watches"))}}function Pn(e,n){return t(this,void 0,void 0,(function*(){return null!=pn&&mn===n||(yield pn,pn=an.switchEffect(e),mn=n),pn}))}function xn(){return t(this,void 0,void 0,(function*(){if(null!=an){if(un=!1,null==sn){const e=Tn(ln),t=Lt(e);sn=yield Ut(t),yield kn(an,sn,"user"===e),Ft(sn),"DetectionLoop"!==vn&&Dn((e=>{gn=e.faceWidth}))}!function(){if(null==dn)return;if(null==ln||hn.has(ln))return;dn.style.visibility="visible",dn.style.opacity="1"}(),an.setPaused(un),cn.style.display=""}}))}function Mn(){null!=an&&(un=!0,an.setPaused(un),Wt(),null!=sn&&null!=sn.srcObject&&sn.srcObject instanceof MediaStream&&(sn.srcObject.getTracks().forEach((e=>e.stop())),sn=null),function(){if(null==dn)return;dn.style.visibility="hidden",dn.style.opacity="0"}(),an.stopCamera(),cn.style.display="none")}function Tn(e){var t;return null==e?"user":null!==(t={Glasses:"user",Shoes:"environment",Watches:"environment"}[e])&&void 0!==t?t:"user"}function kn(e,n,r){return t(this,void 0,void 0,(function*(){yield new Promise((o=>{n.onloadedmetadata=()=>{n.play().then((()=>t(this,void 0,void 0,(function*(){e.setVideoElement(n,r),o()}))))}}))}))}function Ln(e){null!=dn&&(hn.has(e)||(hn.add(e),dn.style.opacity="0"))}function Un(e,t,n,r,o,i,a){const s=an.getTransformationBetween(e,t),l=Kt(Xt(),s),c=function(e,t){var n=new zt(3);Bt(n,t);var r=1/n[0],o=1/n[1],i=1/n[2],a=t[0]*r,s=t[1]*o,l=t[2]*i,c=t[4]*r,u=t[5]*o,d=t[6]*i,h=t[8]*r,f=t[9]*o,p=t[10]*i,m=a+u+p,g=0;return m>0?(g=2*Math.sqrt(m+1),e[3]=.25*g,e[0]=(d-f)/g,e[1]=(h-l)/g,e[2]=(s-c)/g):a>u&&a>p?(g=2*Math.sqrt(1+a-u-p),e[3]=(d-f)/g,e[0]=.25*g,e[1]=(s+c)/g,e[2]=(h+l)/g):u>p?(g=2*Math.sqrt(1+u-a-p),e[3]=(h-l)/g,e[0]=(s+c)/g,e[1]=.25*g,e[2]=(d+f)/g):(g=2*Math.sqrt(1+p-a-u),e[3]=(s-c)/g,e[0]=(h+l)/g,e[1]=(d+f)/g,e[2]=.25*g),e}(en(),s);Ht(s,c,l,Zt(a,a,a));const u=an.getTransformationBetween(t,n),d=Kt(Xt(),u);Ht(u,en(),d,Bt(Xt(),u));const h=Vt(Qt(),s,u),f=Kt(Xt(),h),p=Math.atan2(i[0]-f[0],Math.abs(i[2]-f[2]));let m;try{m=an.getTransformationBetween(n,r)}catch(e){return p}const g=Vt(Qt(),u,m),v=Vt(Qt(),s,g),w=Zt(f[0],i[1],i[2]),y=Jt(Xt(),w,function(e,t){var n=t[0],r=t[1],o=t[2],i=t[3],a=t[4],s=t[5],l=t[6],c=t[7],u=t[8],d=t[9],h=t[10],f=t[11],p=t[12],m=t[13],g=t[14],v=t[15],w=n*s-r*a,y=n*l-o*a,b=n*c-i*a,E=r*l-o*s,A=r*c-i*s,R=o*c-i*l,S=u*m-d*p,C=u*g-h*p,I=u*v-f*p,P=d*g-h*m,x=d*v-f*m,M=h*v-f*g,T=w*M-y*x+b*P+E*I-A*C+R*S;return T?(T=1/T,e[0]=(s*M-l*x+c*P)*T,e[1]=(o*x-r*M-i*P)*T,e[2]=(m*R-g*A+v*E)*T,e[3]=(h*A-d*R-f*E)*T,e[4]=(l*I-a*M-c*C)*T,e[5]=(n*M-o*I+i*C)*T,e[6]=(g*b-p*R-v*y)*T,e[7]=(u*R-h*b+f*y)*T,e[8]=(a*x-s*I+c*S)*T,e[9]=(r*I-n*x-i*S)*T,e[10]=(p*A-m*b+v*w)*T,e[11]=(d*b-u*A-f*w)*T,e[12]=(s*C-a*P-l*S)*T,e[13]=(n*P-r*C+o*S)*T,e[14]=(m*y-p*E-g*w)*T,e[15]=(u*E-d*y+h*w)*T,e):null}(Qt(),v));let b=an.getClosestPointOnMesh(r,y);try{const e=an.getClosestPointOnMesh(o,y);Yt(y,e)<Yt(y,b)&&(b=e)}catch(e){}const E=Jt(Xt(),b,g);return p-Math.atan2(E[0]-d[0],Math.abs(E[2]-d[2]))}function $n(e){!function(e){jt.push(e)}(e)}function Dn(e){!function(e){Ot.push(e)}(e)}function _n(e,o,i){return t(this,void 0,void 0,(function*(){let a="glb".charCodeAt(0),s="3d".charCodeAt(0);a>>=1,a+=s;const l=String.fromCharCode(a+14);s>>=2,a^=s+2;const d=String.fromCharCode(a-3);a^=5;const h=String.fromCharCode(a-7);a^=2;const f=String.fromCharCode(a-7),m=window[`${h}${d+l+(typeof[])[(+!+[]+ +!+[])*(+!+[]+ +!+[])]}${f}`],g=yield p((()=>t(this,void 0,void 0,(function*(){const t=yield m(`${e}`).catch((()=>{throw new n("Unknown error.")}));if(!t.ok)throw new n("Unknown error.");return t})))),v=new r[0](yield(yield g.blob().catch((()=>{throw new n("Unknown error.")}))).arrayBuffer().catch((()=>{throw new n("Unknown error.")})));i+=s;const w=v.byteLength;if(u[c]=Math.min(76,o)*((a>>5)-1),152===u[c]&&(u[c]=w),i==c)return v;i=c,i^=c;for(let e=0,t=v.length;e<t;e++)u[c]^=u[i]<<13,u[c]^=u[i]>>17,u[c]^=u[i]<<5,v[e]=v[e]^u[c];return i^=u[0],i^=u[1],i^=u[2],v}))}function Nn(e,t){if(null==e)throw new n(`'${t}' not specified.`)}function jn(e,t){if("boolean"!=typeof e)throw new n(`'${t}' must be a boolean.`)}function On(e,t){if("string"!=typeof e)throw new n(`'${t}' must be a string.`)}const Fn=["AR","3D"];function Wn(e){const{apiKey:t,sku:r,targetElement:o,initialState:i,initialAnimation:a,baseUrl:s,defaultUI:l,interactive:c,strings:u}=e;Nn(t,"apiKey"),On(t,"apiKey"),Nn(r,"sku"),On(r,"sku"),Nn(o,"targetElement"),function(e,t){if(!(e instanceof HTMLElement))throw new n(`'${t}' must be an HTMLElement.`)}(o,"targetElement"),null!=i&&function(e,t,r){if("string"!=typeof e)throw new n(`'${t}' must be a string.`);if(!r.includes(e))throw new n(`'${t}' must be ${r.join("' or '")}.`)}(i,"initialState",Fn),null!=a&&function(e,t){if("string"!=typeof e&&!Array.isArray(e))throw new n(`'${t}' must be a string or array.`)}(a,"initialAnimation"),null!=s&&On(s,"baseUrl"),null!=l&&jn(l,"defaultUI"),null!=c&&jn(c,"interactive"),null!=u&&function(e,t,r){for(const o of r){const r=e[o];if(null!=r&&"string"!=typeof r)throw new n(`Value for key '${o}' in '${t}' must be a string.`)}}(u,"strings",Be)}let qn=!1;function Gn(e){return t(this,void 0,void 0,(function*(){const{targetElement:r}=e;y.update(e.baseUrl),Tt();const{trackEvent:o}=function(e){const t=performance.now(),n=Et();return{trackEvent:(r,o={})=>{o=Object.assign(Object.assign({},o),{pluginVersion:v,sessionId:Pt,setupId:n,timeSinceSetup:performance.now()-t,apiKey:e}),kt((()=>{window.ShopAR__analytics.trackEventImpl(r,o)}))}}}(e.apiKey);o("visionSetup");const i=yield function(e){return t(this,void 0,void 0,(function*(){const r=yield p((()=>t(this,void 0,void 0,(function*(){const t=yield fetch(`https://dashboard.shopar.ai/plugin/vision?${new URLSearchParams({apiKey:e,sid:d()})}`).catch((e=>{throw console.error(e),new n("API unavailable.")}));if(!t.ok)throw new n(`API call failed with status ${t.status}.`);return t}))));try{return yield r.json()}catch(e){throw console.error(e),new n("API returned invalid body.")}}))}(e.apiKey);o("visionApiResponse",i);const{arKey:a}=i,s=pt(r),{getSetupId:l,findUI:c}=s,u=l();bn(),En();const{setTargetElement:h,getDeepARTarget:f,setVisibilityParameters:m,getUIState:g,setUIState:w,startDeepARLoading:b,stopDeepARLoading:E,showCameraError:A}=c();if(g()!=lt.None)throw Error("UI state is not None, this is weird..");w(lt.AR),h(r),m(!1,!1,!0,!1,void 0),b(),yield nn,zn(l(),u);try{o("visionArLaunch"),Mn(),Rn("Glasses",["faceInit"]),Sn(f()),yield An({licenseKey:a,truescaleUsecase:"DetectionLoop"}),zn(l(),u),yield xn(),zn(l(),u)}catch(e){const t=e instanceof Error;throw o("visionArLaunchFailure",{errorName:t?e.name:"Unknown",errorMessage:t?e.message:""}),A(),Mn(),new n(`AR failed: ${t?e.message:"Unknown error."}`)}finally{E()}return qn=!0,{registerFacePoseListener:e=>{qn&&(o("registerFacePoseListener"),$n(e))},registerFaceMeasurementListener:e=>{qn&&(o("registerFaceMeasurementListener"),Dn(e))},switchEffect:e=>t(this,void 0,void 0,(function*(){qn&&(o("switchEffect",{arUrl:e}),function(e){an.switchEffect(e)}(e))})),clearEffect:()=>{qn&&(o("clearEffect"),an.clearEffect())},close:()=>{if(qn){if(qn=!1,o("visionClose"),g()!==lt.AR)throw new n("AR not launched.");Mn(),w(lt.None)}}}}))}function zn(e,t){if(e!==t)throw new n("Setup cancelled. Please ensure that setup is only called once.")}function Qn(e){var r,o;return t(this,void 0,void 0,(function*(){Wn(e);const{apiKey:i,sku:a,targetElement:s,initialState:l,initialAnimation:c}=e;!function(e){const t=getComputedStyle(e);if(!["static","relative"].includes(t.position))throw new n(`Invalid targetElement's position. Expected 'static' or 'relative', but found '${t.position}'.`)}(s),y.update(e.baseUrl),function(e){if(null!=e)for(const t of Object.keys(e)){if(!Object.prototype.hasOwnProperty.call(Ke,t)){console.warn(`String for key '${t}' will be ignored.`);continue}const n=e[t];null!=n&&(Ke[t]=n)}}(e.strings);const u=null!=c?ve(c):null,h=function(e,r){return t(this,void 0,void 0,(function*(){const o=yield p((()=>t(this,void 0,void 0,(function*(){const t=yield fetch(`https://dashboard.shopar.ai/plugin?${new URLSearchParams({apiKey:e,sku:r,sid:d()})}`).catch((e=>{throw console.error(e),new n("API unavailable.")}));if(!t.ok)throw new n(`API call failed with status ${t.status}.`);return t}))));try{return yield o.json()}catch(e){throw console.error(e),new n("API returned invalid body.")}}))}(i,a),f=pt(s),{getSetupId:w,findUI:A,findQR:R,findThree:S}=f,C=w();Tt();const{trackEvent:I,arInteracted:P,previewInteracted:x}=function(e,t){const n=performance.now(),r=Et();let o=0,i=0,a=0,s=0,l=0,c=!1;window.setInterval((()=>{c&&(o=i+a,c=!1,u(Ct,{engagementTotal:o,engagementAR:i,engagement3D:a}))}),1e3);const u=(o,i={})=>{i=Object.assign(Object.assign({},i),{pluginVersion:v,sessionId:Pt,setupId:r,timeSinceSetup:performance.now()-n,sku:e,apiKey:t}),kt((()=>{window.ShopAR__analytics.trackEventImpl(o,i)}))};return{trackEvent:u,arInteracted:()=>{const e=performance.now(),t=e-s;s=e,t<200&&(i+=t,c=!0)},previewInteracted:()=>{const e=performance.now(),t=e-l;l=e,t<200&&(a+=t,c=!0)}}}(a,i);I("setup",{hostname:window.location.hostname});const M=yield h;I("apiResponse",M);const{category:T,arUrl:k,arKey:L,arPromptEnabled:U,arPromptText:$,arPromptImage:D,previewUrl:_,previewEnvUrl:N,previewToneMapping:j,cameraErrorText:O,qrPromptText:F}=M;Vn(w(),C);const W=null!=k&&function(e){return null!=e&&m.includes(e)}(T),q=null==(null===(r=e._internalOptions)||void 0===r?void 0:r.qrEnabled)||(null===(o=e._internalOptions)||void 0===o?void 0:o.qrEnabled),G=W&&function(e){return null!=e&&g.includes(e)}(T),z=q&&G&&!(yield function(){var e;return t(this,void 0,void 0,(function*(){return null==yn&&(yn=b(`${y}/shopar-platform.js`)),yield yn,["Android","iOS","Windows Phone",void 0].includes(null===(e=window.ShopAR__platform.platform.os)||void 0===e?void 0:e.family)}))}()),Q=W&&!z,V=null!=_;if(Vn(w(),C),z&&function(){t(this,void 0,void 0,(function*(){null==E&&(E=b(`${y}/shopar-qr.js`))}))}(),Q&&(bn(),function(e){e!==on&&(on=e,Gt(e),pn=null,Wt())}(k),"Glasses"===T&&En()),V){null==ke&&(ke=b(`${y}/shopar-three.js`));const e=255;_n(_,(new Date).getTime()+e,Math.random()*e),Gt(null!=N?N:`${y}/env/default.hdr`)}const{setTargetElement:K,getDeepARTarget:B,getDeepARPrompt:H,customizeDeepARPrompt:X,customizeCameraError:Z,customizeQRPrompt:Y,setVisibilityParameters:J,getUIState:ee,setUIState:te,setDefaultUIActions:ne,startDeepARLoading:re,stopDeepARLoading:oe,startThreeLoading:ie,stopThreeLoading:ae,showCameraError:se}=A();K(s);J(null==e.defaultUI||e.defaultUI,z,Q,V,T),X(null!=$?$:"",null!=D?D:""),Z(O),Y(F),function(e,t){const r=e.parentNode;if(null==r)throw new n("Parent node missing.");new MutationObserver((n=>{for(const r of n)for(const n of r.removedNodes)if(n===e)return void t()})).observe(r,{childList:!0})}(s,(()=>{ee()!==lt.QR||le()||ue(),ee()!==lt.AR||un||Mn(),ee()!==lt.Preview||pe()||ge(),te(lt.None)}));const{qrPaused:le,qrDraw:ce,qrPause:ue}=R(),{threeInit:de,threeParse:he,threeLoad:fe,threePaused:pe,threeResume:me,threePause:ge,threeSetToneMapping:we,threeIsInteractive:ye,threeSetInteractive:be,threeSetOnInteracted:Ee,threeInitPromptAnimation:Ae,threeInitCameraAnimation:Re}=S(),Se=null==e.interactive||e.interactive;be(Se);let Ce=0;if(ee()===lt.QR){if(!le())if(z){I(At);try{yield ce(i,a)}catch(e){throw new n(`QR failed: ${e instanceof Error?e.message:"Unknown error."}`)}}else ue(),te(lt.None)}else if(ee()===lt.AR){if(!un)if(Q&&!qn){I(Rt);const e=yield Gt(k);Vn(w(),C),mt(f),Rn(T),Sn(B()),Cn(U?H():null),yield Pn(e,k),In(P),Vn(w(),C)}else Mn(),te(lt.None)}else if(ee()===lt.Preview&&!pe())if(V){I(St),ie();const e=255,t=yield _n(_,(new Date).getTime()+e,Math.random()*e);Vn(w(),C);const n=yield Gt(null!=N?N:`${y}/env/default.hdr`);Vn(w(),C);const r=yield he(t,n,`${_}${N}`);Vn(w(),C),fe(r,T),we(null!=j?j:"ACES"),Ee(x),ae()}else ge(),te(lt.None);const Ie=()=>t(this,void 0,void 0,(function*(){if(z){if(ee()===lt.QR||ee()===lt.AR)throw new n("AR already launched.");try{I(At);const e=++Ce;if(ee()===lt.Preview&&V&&!pe()&&ge(),te(lt.QR),yield ce(i,a),Ce!==e)return;return void Vn(w(),C)}catch(e){const t=e instanceof Error;throw I("qrLaunchFailure",{errorName:t?e.name:"Unknown",errorMessage:t?e.message:""}),new n(`QR failed: ${t?e.message:"Unknown error."}`)}}if(!Q)throw new n("Model does not have AR enabled.");if(ee()===lt.AR)throw new n("AR already launched.");try{I(Rt);const e=++Ce;ee()===lt.Preview&&V&&!pe()&&ge(),mt(f),te(lt.AR),re();const t=yield Gt(k);if(Ce!==e)return;if(Vn(w(),C),yield nn,Ce!==e)return;if(Vn(w(),C),Mn(),Rn(T),Sn(B()),Cn(U?H():null),yield An({licenseKey:L}),Ce!==e)return;if(Vn(w(),C),yield Pn(t,k),In(P),Ce!==e)return;if(Vn(w(),C),yield xn(),Ce!==e)return;Vn(w(),C)}catch(e){const t=e instanceof Error;throw I("arLaunchFailure",{errorName:t?e.name:"Unknown",errorMessage:t?e.message:""}),se(),Mn(),new n(`AR failed: ${t?e.message:"Unknown error."}`)}finally{oe()}})),Pe=()=>t(this,void 0,void 0,(function*(){if(!V)throw new n("Model does not have 3D enabled.");if(ee()===lt.Preview)throw new n("3D already launched.");try{I(St);const e=++Ce;ee()===lt.AR&&(Q&&!un&&Mn(),ue()),te(lt.Preview),ie();const t=255,n=yield _n(_,(new Date).getTime()+t,Math.random()*t);if(Ce!==e)return;Vn(w(),C);const r=yield Gt(null!=N?N:`${y}/env/default.hdr`);if(Ce!==e)return;if(Vn(w(),C),yield ke,Ce!==e)return;if(Vn(w(),C),de(),Ce!==e)return;Vn(w(),C);const o=yield he(n,r,`${_}${N}`);if(Ce!==e)return;Vn(w(),C),fe(o,T),we(null!=j?j:"ACES"),Ee(x),Ae(),null!=u&&Re(u),me()}catch(e){const t=e instanceof Error;throw I("previewLaunchFailure",{errorName:t?e.name:"Unknown",errorMessage:t?e.message:""}),new n(`3D failed: ${t?e.message:"Unknown error."}`)}finally{ae()}})),xe=()=>t(this,void 0,void 0,(function*(){if(ee()===lt.None)throw new n("Neither AR or 3D launched.");++Ce,ee()===lt.QR||ee()===lt.AR?(Q&&!un&&Mn(),ue()):ee()===lt.Preview&&V&&!pe()&&ge(),te(lt.None)}));return ne(Ie,Pe,xe),"AR"===l?(yield Ie(),Vn(w(),C)):"3D"===l&&(yield Pe(),Vn(w(),C)),qn=!1,{launchAR:W?Ie:void 0,launch3D:V?Pe:void 0,closeAR:W?()=>t(this,void 0,void 0,(function*(){if(ee()!==lt.AR&&ee()!==lt.QR)throw new n("AR not launched.");++Ce,Q&&!un&&Mn(),ue(),te(lt.None)})):void 0,close3D:V?()=>t(this,void 0,void 0,(function*(){if(ee()!==lt.Preview)throw new n("3D not launched.");++Ce,V&&!pe()&&ge(),te(lt.None)})):void 0,close:W||V?xe:void 0,isInteractive:()=>ye(),setInteractive:e=>be(e)}}))}function Vn(e,t){if(e!==t)throw new n("Setup cancelled. Please ensure that setup is only called once.")}const Kn={setup:function(e){return t(this,void 0,void 0,(function*(){return Gn(e)}))}},Bn={setup:function(e){return t(this,void 0,void 0,(function*(){return function(e,r){return t(this,void 0,void 0,(function*(){try{return r()}catch(t){throw t instanceof Error?new n(`${e} failed: ${t.message}`):(console.error(t),new n(`${e} failed.`))}}))}("setup",(()=>Qn(e)))}))},version:v};e.plugin=Bn,e.vision=Kn}));
|
|
1
|
+
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports):"function"==typeof define&&define.amd?define(["exports"],t):t((e="undefined"!=typeof globalThis?globalThis:e||self).ShopAR={})}(this,(function(e){"use strict";function t(e,t,n,r){return new(n||(n=Promise))((function(o,i){function a(e){try{l(r.next(e))}catch(e){i(e)}}function s(e){try{l(r.throw(e))}catch(e){i(e)}}function l(e){var t;e.done?o(e.value):(t=e.value,t instanceof n?t:new n((function(e){e(t)}))).then(a,s)}l((r=r.apply(e,t||[])).next())}))}!function(){const e={css:".shopar-btn-container{position:absolute;width:100%;bottom:0;padding-bottom:2rem;display:flex;justify-content:center;gap:.5rem;pointer-events:none}.shopar-btn{padding:.5rem .75rem;display:flex;justify-content:center;align-items:center;gap:.25rem;background-color:#fff;border:1px solid #ddd;border-radius:9999px;cursor:pointer;pointer-events:auto}.shopar-btn:hover{background-color:#f5f5f5}.shopar-loading-container{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:1rem;background-color:#fff}.shopar-loading-text{text-align:center}.shopar-loading-bar-bg{width:80%;height:.5rem;background-color:#e5e7eb;border-radius:9999px}.shopar-loading-bar-fg{background-color:#1434f7;border-radius:9999px;transition:none;transform:translateX(-100%);will-change:transform}.shopar-loading-bar-fg.active{transition:transform 5s cubic-bezier(0,0,.2,1);transform:none}.shopar-qr{display:flex;flex-direction:column;justify-content:center;align-items:center;background-color:#fff}.shopar-ar-prompt{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:1rem;background-color:#1e293bb2;transition:.3s ease-in-out opacity}.shopar-ar-prompt-text{text-align:center;color:#fff}.shopar-ar-prompt-img{max-width:80%;max-height:50%;object-fit:contain}"};try{if(process)return process.env=Object.assign({},process.env),void Object.assign(process.env,e)}catch(e){}globalThis.process={env:e}}(),"function"==typeof SuppressedError&&SuppressedError;class n extends Error{constructor(e){super(`ShopAR Plugin: ${e}`)}}const r=[Uint8Array,Uint32Array],o=r.length-2,i=["addEventListener","alert","atob","blur","btoa","cancelAnimationFrame","localStorage","location","locationbar","hash","hasOwnProperty","host","hostname","href","requestAnimationFrame"],a=[2,12,7,1],s=window[i[a[a[o]]]][i[a[a[a.length-1]]]],l=s.charCodeAt(o),c=l^l,u=new r[1]([c]);function d(){const e=(new TextEncoder).encode(s),t=i.map((e=>e.length));for(let n=0;n<e.length;n++)e[n]^=t[n%t.length];return window[i[t[2]]](String.fromCodePoint(...e))}const h=[1e3,2e3,4e3],p=h.length;function f(e,n=0){return t(this,void 0,void 0,(function*(){try{return yield e()}catch(t){if(n>=p)throw t;return yield new Promise((e=>setTimeout(e,h[n]))),f(e,n+1)}}))}const m=["Glasses","Shoes","Watches"],g=["Shoes"];const v="0.2.1-alpha.1";let w=`https://cdn.jsdelivr.net/npm/shopar-plugin@${v}/dist`;const y={update:e=>{null!=e&&(w=e.endsWith("/")?e.substring(0,e.length-1):e)},toString:()=>w};function b(e){return t(this,void 0,void 0,(function*(){if("function"!=typeof importScripts){const t=document.createElement("script");return t.setAttribute("src",e),t.setAttribute("crossorigin","anonymous"),new Promise((e=>{t.addEventListener("load",(()=>e()),!1),t.addEventListener("error",(()=>e()),!1),document.body.appendChild(t)}))}importScripts(e.toString())}))}let E;const A=(()=>{const e=(()=>{var e;if(null===(e=document.documentElement.getAttribute("itemtype"))||void 0===e?void 0:e.includes("schema.org/SearchResultsPage"))return!0;const t=null!=document.head?Array.from(document.head.querySelectorAll("meta")):[];for(const e of t)if("viewport"===e.name)return!0;return!1})();return e||console.warn('No <meta name="viewport"> detected; ShopAR will cap pixel density at 1.'),()=>e?window.devicePixelRatio:1})();let R,S,C;function I(e){const t=function(e){const t=new S.DataTexture(e.data,e.width,e.height,void 0,e.type,void 0,S.ClampToEdgeWrapping,S.ClampToEdgeWrapping,S.LinearFilter,S.LinearFilter,1,S.LinearSRGBColorSpace);return t.flipY=!0,t.generateMipmaps=!1,t.needsUpdate=!0,t}(C.parse(e));return t.mapping=S.EquirectangularReflectionMapping,t.colorSpace=S.LinearSRGBColorSpace,t}const x=45,P=45,M=3,T=1.5,k=1,L=.5;let $,U,D,_,N,j=!1;const O=4,F=.001,W=1e-7,q=10,G=11,z=1/(G-1),Q="function"==typeof Float32Array;function V(e,t,n,r){if(!(0<=e&&e<=1&&0<=n&&n<=1))throw new Error("bezier x values must be in [0, 1] range");if(e===t&&n===r)return Y;const o=Q?new Float32Array(G):new Array(G);for(let t=0;t<G;++t)o[t]=X(t*z,e,n);function i(t){let r=0,i=1;const a=G-1;for(;i!==a&&o[i]<=t;++i)r+=z;--i;const s=r+(t-o[i])/(o[i+1]-o[i])*z,l=Z(s,e,n);return l>=F?function(e,t,n,r){for(let o=0;o<O;++o){const o=Z(t,n,r);if(0===o)return t;t-=(X(t,n,r)-e)/o}return t}(t,s,e,n):0===l?s:function(e,t,n,r,o){let i,a,s=0;do{a=t+(n-t)/2,i=X(a,r,o)-e,i>0?n=a:t=a}while(Math.abs(i)>W&&++s<q);return a}(t,r,r+z,e,n)}return function(e){return 0===e||1===e?e:X(i(e),t,r)}}function K(e,t){return 1-3*t+3*e}function B(e,t){return 3*t-6*e}function H(e){return 3*e}function X(e,t,n){return((K(t,n)*e+B(t,n))*e+H(t))*e}function Z(e,t,n){return 3*K(t,n)*e*e+2*B(t,n)*e+H(t)}function Y(e){return e}function J(e){if("hold"===e.type)return()=>0;if("bezier"===e.type){const t=V(e.x1,e.y1,e.x2,e.y2);return e=>t(e)}throw new Error(`Unknown interpolation: ${e}`)}function ee(e){if(e.length<2)throw new Error("Expected at least two key frames.");const t=e[e.length-1].time,n=[...e].sort(((e,t)=>e.time-t.time)).map((({time:e,value:t,interpolation:n})=>({time:e,value:t,interpolate:J(n)})));let r=0,o=n[0].value;return{reset:()=>{r=0},update:e=>{for(r+=e;r>=t;)r-=t;for(let e=0;e<n.length-1;e++){const t=n[e],i=n[e+1];if(r>=t.time&&r<i.time){const e=t.interpolate((r-t.time)/(i.time-t.time));o=t.value+e*(i.value-t.value)}}},get:()=>o}}const te="#",ne="time",re="interpolation",oe="yaw",ie="pitch",ae="fov",se=[ne,oe,ie,ae,re],le="s",ce="ms",ue=1e3,de="deg",he="rad",pe=Math.PI/180,fe="ease-in-out",me="cubic-bezier(",ge=")";function ve(e){if("string"==typeof e)return function(e){const[t,...n]=function(e){return e.split(/\r?\n/).map((e=>function(e){const t=e.indexOf(te);return(-1!==t?e.substring(0,t):e).trim()}(e))).filter((e=>""!==e))}(e);if(null==t)throw new Error("Header missing.");const r=function(e){const t=[];for(let n=0;n<e.length;n++){const r=e[n];if(!se.includes(r))throw new Error(`Invalid token in header: '${r}'.`);if(t.includes(r))throw new Error(`Duplicate token in header: '${r}'.`);t.push(r)}if(!t.includes(ne))throw new Error(`Missing required token: '${ne}'.`);return t}(t.split(/\s+/)),o={};if(n.length<2)throw new Error("Expected at least two key frames.");for(const e of n){const{theta:t,phi:n,fov:i}=we(r,e);null!=t&&(null==o.theta&&(o.theta=[]),o.theta.push(t)),null!=n&&(null==o.phi&&(o.phi=[]),o.phi.push(n)),null!=i&&(null==o.fov&&(o.fov=[]),o.fov.push(i))}if(0===Object.values(o).length)throw new Error("At least one parameter should be animated.");return o}(e);if(Array.isArray(e))return function(e){var t;const n={};if(e.length<2)throw new Error("Expected at least two key frames.");for(const r of e){const{time:e,pitch:o,yaw:i,fov:a}=r;if(null==e)throw new Error("Time missing.");const s=be(null!==(t=r.interpolation)&&void 0!==t?t:fe);null!=i&&(null==n.theta&&(n.theta=[]),n.theta.push({time:e,value:i*pe,interpolation:s})),null!=o&&(null==n.phi&&(n.phi=[]),n.phi.push({time:e,value:o*pe,interpolation:s})),null!=a&&(null==n.fov&&(n.fov=[]),n.fov.push({time:e,value:a*pe,interpolation:s}))}if(0===Object.values(n).length)throw new Error("At least one parameter should be animated.");if(Object.values(n).every((t=>t.length!==e.length)))throw new Error("All parameters should have the same key frame count.");return n}(e);throw new Error("Expected string or key frame config array.")}function we(e,t){const n=t.match(/[^()\s]+(\(.*?\))?/g);if(null==n||n.length<e.length)throw new Error(`Missing data for fields: '${e.filter((e=>!(null==n?void 0:n.includes(e)))).join(", ")}'.`);if(n.length>e.length)throw new Error(`Excess data: '${n.filter((t=>!e.includes(t))).join(", ")}'.`);const r=e.indexOf(ne),o=function(e){if(e.endsWith(ce))return Ae(e.substring(0,e.length-ce.length));if(e.endsWith(le))return Ae(e.substring(0,e.length-le.length))*ue;return Ae(e)}(n[r]),i=e.indexOf(re),a=be(-1===i?fe:n[i]),s={};for(let t=0;t<n.length;t++){if(t===r||t===i)continue;const l=e[t],c=n[t];switch(l){case oe:s.theta={time:o,value:ye(c),interpolation:a};break;case ie:s.phi={time:o,value:ye(c),interpolation:a};break;case ae:s.fov={time:o,value:ye(c),interpolation:a};break;default:throw new Error(`Unhandled value for header '${l}'.`)}}return s}function ye(e){return e.endsWith(de)?Ae(e.substring(0,e.length-de.length))*pe:e.endsWith(he)?Ae(e.substring(0,e.length-he.length)):Ae(e)*pe}function be(e){if("hold"===e)return{type:"hold"};if("linear"===e)return Ee(0,0,1,1);if("sine"===e)return Ee(.37,0,.63,1);if("sine-in"===e)return Ee(.12,0,.39,0);if("sine-out"===e)return Ee(.61,1,.88,1);if("ease"===e)return Ee(.25,.1,.25,1);if("ease-in"===e)return Ee(.42,0,1,1);if("ease-out"===e)return Ee(0,0,.58,1);if("ease-in-out"===e)return Ee(.42,0,.58,1);if(e.startsWith(me)&&e.endsWith(ge)){const t=e.substring(me.length,e.length-ge.length).split(/\s*,\s*/);if(4!==t.length)throw new Error(`Expected 4 parameters for the Bezier curve, but got '${t}'.`);return{type:"bezier",x1:Ae(t[0]),y1:Ae(t[1]),x2:Ae(t[2]),y2:Ae(t[3])}}throw new Error(`Expected an interpolation token, but found: ${e}`)}function Ee(e,t,n,r){return{type:"bezier",x1:e,y1:t,x2:n,y2:r}}function Ae(e){const t=Number.parseFloat(e);if(Number.isNaN(t))throw new Error(`Expected a numeric value, but got: ${e}`);return t}const Re=300,Se=2e3,Ce=.05,Ie=2*Math.PI/32,xe=be("hold"),Pe=be("sine"),Me=be("sine-in"),Te=be("sine-out");let ke;const Le=0;let $e,Ue,De,_e=!1,Ne=1,je=1,Oe=1;const Fe=1;let We;const qe=new Map;function Ge(e,n,r){const o=e.getContext("2d");null==o&&console.warn("2D context missing.");let i,a,s,l,c,u,d,h,p,f,m,g,v,w,y=!1,b=!0,E=!1,A=1,k=!0,j=!1,O=!1,F=0,W=1,q=1,G=1;const z={threeInit:()=>{y||(ze(),i=new Ue.Scene,a=new Ue.PerspectiveCamera(25,1,.5),s=new $e.OrbitControls(a,e),s.setInteractionEnabled(k),h=Ue.ACESFilmicToneMapping,({renderShadow:c,shadowGroup:l}=function(e){const t=new $.WebGLRenderTarget(512,512);t.texture.generateMipmaps=!1;const n=new $.WebGLRenderTarget(512,512);n.texture.generateMipmaps=!1;const r=new $.Group;r.position.y=-.7;const o=new $.PlaneGeometry(x,P).rotateX(Math.PI/2),i=new $.MeshBasicMaterial({map:t.texture,opacity:L,transparent:!0,depthWrite:!1}),a=new $.Mesh(o,i);a.renderOrder=1,a.scale.y=-1,r.add(a);const s=new $.Mesh(o);s.visible=!1,r.add(s);const l=new $.OrthographicCamera(-x/2,x/2,P/2,-P/2,0,M);function c(e){s.visible=!0,_.uniforms.tDiffuse.value=t.texture,_.uniforms.h.value=1*e/256,s.material=_,U.setRenderTarget(n),U.render(s,l),N.uniforms.tDiffuse.value=n.texture,N.uniforms.v.value=1*e/256,s.material=N,U.setRenderTarget(t),U.render(s,l),s.visible=!1}return l.rotation.x=Math.PI/2,r.add(l),{shadowGroup:r,renderShadow:()=>{const n=e.background;e.background=null,e.overrideMaterial=D;const r=U.getClearAlpha();U.setClearAlpha(0),U.setRenderTarget(t),U.render(e,l),e.overrideMaterial=null,c(T),c(.4*T),U.setRenderTarget(null),U.setClearAlpha(r),e.background=n}}}(i)),y=!0)},threeParse:(e,n,r)=>t(this,void 0,void 0,(function*(){return null!=u&&d===r||(yield u,u=(()=>t(this,void 0,void 0,(function*(){var t,r;return S=(t=$e).THREE,C=new t.RGBELoader,i.environment=I(n),function(e,t){const{THREE:n}=t;R=(new t.GLTFLoader).setDRACOLoader((new t.DRACOLoader).setDecoderPath(`https://cdn.jsdelivr.net/npm/three@0.${n.REVISION}.0/examples/jsm/libs/draco/gltf/`)).setKTX2Loader((new t.KTX2Loader).setTranscoderPath(`https://cdn.jsdelivr.net/npm/three@0.${n.REVISION}.0/examples/jsm/libs/basis/`).detectSupport(e)).setMeshoptDecoder(t.MeshoptDecoder)}(We,$e),r=e,R.parseAsync(r.buffer,"")})))(),d=r),u})),threeLoad:(e,t)=>{i.clear(),i.add(e.scene);const n=(new Ue.Box3).setFromObject(e.scene);l.position.y=n.min.y-Le,i.add(l),c(),i.traverse((e=>{e instanceof Ue.Mesh&&(e.material.depthWrite=!0)}));const r=n.min.clone().add(n.max).divideScalar(2),o=Math.sqrt($e.reduceVertices(e.scene,((e,t)=>Math.max(e,r.distanceToSquared(t))),0));s.reset(r,o,function(e,t){var n;const r={Glasses:new t(67.5,15,90),Shoes:new t(-55,30,30),Watches:new t(0,-10,40),Handbags:new t(40,0,0),Rings:new t(0,0,10)};return(null==e?r.Glasses:null!==(n=r[e])&&void 0!==n?n:r.Glasses).normalize()}(t,Ue.Vector3)),O=!0},threePaused:()=>b,threeResume:()=>{b=!1,We.setAnimationLoop(Qe),e.style.visibility="visible",F=0,null==f||f.reset(),null==m||m.reset(),null==g||g.reset(),null==v||v.reset(),null==w||w.reset()},threePause:()=>{b=!0,function(){for(const{threePaused:e}of qe.values())if(!e())return!1;return!0}()&&We.setAnimationLoop(null),e.style.visibility="hidden",n.style.visibility="hidden"},threeSetToneMapping:(e,t)=>{const n={ACES:Ue.ACESFilmicToneMapping,Linear:Ue.LinearToneMapping,Neutral:Ue.NeutralToneMapping};null!=n[e]&&(h=n[e]),A=t},threeIsInteractive:()=>k,threeSetInteractive:e=>{k=e,null==s||s.setInteractionEnabled(k)},threeSetOnInteracted:e=>{s.removeEventListener("change",p),p=e,s.addEventListener("change",e)},threeInitPromptAnimation:()=>{var e;e=s.getTheta(),f=ee([{time:0,value:e,interpolation:xe},{time:Re,value:e,interpolation:Te},{time:Re+Se/4,value:e+Ie,interpolation:Pe},{time:Re+3*Se/4,value:e-Ie,interpolation:Me},{time:Re+Se,value:e,interpolation:xe},{time:Re+2*Se,value:e,interpolation:xe}]),m=null,g=null,v=ee([{time:0,value:0,interpolation:xe},{time:Re,value:1,interpolation:xe},{time:Re+Se,value:0,interpolation:xe},{time:Re+2*Se,value:0,interpolation:xe}]),w=ee([{time:0,value:0,interpolation:xe},{time:Re,value:0,interpolation:Te},{time:Re+Se/4,value:-Ce,interpolation:Pe},{time:Re+3*Se/4,value:Ce,interpolation:Me},{time:Re+Se,value:0,interpolation:xe},{time:Re+2*Se,value:0,interpolation:xe}])},threeInitCameraAnimation:e=>{const{theta:t,phi:n,fov:r}=e;f=null!=t?ee(t):null,m=null!=n?ee(n):null,g=null!=r?ee(r):null},preRender_:e=>{if(!y||b)return;e=performance.now();const t=0!==F?e-F:0;F=e,O&&(E=!0,O=!1),j||(s.hasUserInteracted()?(j=!0,f=null,m=null,g=null,v=null,w=null):(null==f||f.update(t),null==m||m.update(t),null==g||g.update(t),null==v||v.update(t),null==w||w.update(t),null!=f&&(s.setTheta(f.get()),E=!0),null!=m&&(s.setPhi(m.get()),E=!0),null!=g&&(s.setFovRadians(g.get()),E=!0))),s.update()&&(E=!0)},shouldRender_:()=>!(!y||b)&&E,render_:()=>{const t=We.toneMapping,s=We.toneMappingExposure;We.toneMapping=h,We.toneMappingExposure=A,We.setViewport(0,0,e.width,e.height),We.render(i,a),We.toneMapping=t,We.toneMappingExposure=s,E=!1,null!=o&&(o.clearRect(0,0,e.width,e.height),De.width>0&&De.height>0&&o.drawImage(De,0,je-e.height,e.width,e.height,0,0,e.width,e.height),n.style.visibility=k&&!j?"visible":"hidden",null!=v&&(r.style.opacity=`${v.get()}`),null!=w&&(r.style.transform=`translateX(${w.get()*Math.min(W,q)}px)`))},updateSize_:()=>{const{clientWidth:t,clientHeight:n}=e;t===W&&n===q&&Oe===G||(e.width=Math.ceil(t*Oe*Fe),e.height=Math.ceil(n*Oe*Fe),W=t,q=n,G=Oe,E=!0)},target_:e};return qe.set(e,z),z}function ze(){if(_e)return;$e=window.ShopAR__THREE,Ue=$e.THREE,De=document.createElement("canvas");var e,t;De.style.position="block",We=new Ue.WebGLRenderer({powerPreference:"high-performance",canvas:De,antialias:!0,alpha:!0}),We.outputColorSpace=Ue.SRGBColorSpace,We.toneMapping=Ue.ACESFilmicToneMapping,We.setClearColor(new Ue.Color(16777215)),e=We,t=$e,j||($=t.THREE,U=e,D=new $.MeshDepthMaterial,D.userData.darkness={value:k},D.onBeforeCompile=e=>{e.uniforms.darkness=D.userData.darkness;const t=e.fragmentShader.replace("gl_FragColor = vec4( vec3( 1.0 - fragCoordZ ), opacity );","gl_FragColor = vec4( vec3( 0.0 ), ( 1.0 - fragCoordZ ) * darkness );");e.fragmentShader=`uniform float darkness;\n${t}`},D.depthTest=!1,D.depthWrite=!1,_=new $.ShaderMaterial(t.HorizontalBlurShader),_.depthTest=!1,N=new $.ShaderMaterial(t.VerticalBlurShader),N.depthTest=!1,j=!0),Ve(),_e=!0}function Qe(e){Ve(),We.clear();for(const{preRender_:t,shouldRender_:n,render_:r}of qe.values())t(e),n()&&r()}function Ve(){let e=0,t=0;for(const{target_:n}of qe.values()){const{clientWidth:r,clientHeight:o}=n;e=Math.max(e,r),t=Math.max(t,o)}const n=A();e=Math.ceil(e*n*Fe),t=Math.ceil(t*n*Fe),e===Ne&&t===je&&n===Oe||(Ne=e,je=t,Oe=n,We.setSize(Ne,je,!1));for(const{updateSize_:e}of qe.values())e()}const Ke={"loading.ar":"Loading Try On...","loading.3d":"Loading 3D..."},Be=Object.keys(Ke);function He(e){return Ke[e]}const Xe="shopar-error";function Ze(e,t){const n=document.createElementNS("http://www.w3.org/2000/svg","svg");n.setAttribute("width",e),n.setAttribute("height",e);{const r=document.createElementNS("http://www.w3.org/2000/svg","image");r.setAttributeNS("http://www.w3.org/1999/xlink","xlink:href",t),r.setAttribute("width",e),r.setAttribute("height",e),n.appendChild(r)}return n}function Ye(e,t,n,r){const o=document.createElement("button");o.id=e,o.type="button",o.className="shopar-btn";{const e=Ze("1.75rem",r);o.appendChild(e)}{const e=document.createElement("span");e.textContent=t,o.appendChild(e)}o.ariaLabel=n;return o.style.display="none",o}const Je="shopar-control";const et="shopar-deepar-output";function tt(e){const t=document.createElement("div");t.classList.add("shopar-loading-container",e);const n=t.style;return n.position="absolute",n.top="0",n.left="0",n.width="100%",n.height="100%",t}function nt(e,t){const n=document.createElement("div");return n.classList.add("shopar-loading-text",e),n.textContent=t,n.style.textAlign="center",n}function rt(e){const t=document.createElement("div");t.classList.add("shopar-loading-bar-bg",e);const n=t.style;return n.position="relative",n.overflow="hidden",t}function ot(e){const t=document.createElement("div");t.classList.add("shopar-loading-bar-fg",e);const n=t.style;return n.width="100%",n.height="100%",t}const it="shopar-main";const at="shopar-qr-output";const st="shopar-three-output";var lt;!function(e){e[e.None=0]="None",e[e.QR=1]="QR",e[e.AR=2]="AR",e[e.Preview=3]="Preview"}(lt||(lt={}));let ct=!1;function ut(){ct||(!function(){try{const e=document.createElement("style"),t=process.env.css;null!=t&&(e.innerHTML=t);const n=document.head;n.insertBefore(e,n.children[0])}catch(e){console.warn("Failed to write default ShopAR Plugin CSS.")}}(),ct=!0)}function dt(){ut();const e=function(){const e=document.createElement("div");e.id=it;const t=e.style;return t.position="absolute",t.top="0",t.bottom="0",t.left="0",t.right="0",e}(),t=function(){const e=document.createElement("div");return e.style.textAlign="center",e}(),n=function(){const e=new Image,t=e.style;return t.maxWidth="100%",t.maxHeight="100%",e}(),r=function(e,t){const n=document.createElement("div");n.id=at;const r=n.style;r.position="absolute",r.top="0",r.left="0",r.width="100%",r.height="100%",r.display="none";const o=document.createElement("div");o.className="shopar-qr";const i=o.style;i.position="relative",i.top="0",i.left="0",i.width="100%",i.height="100%",n.appendChild(o),o.appendChild(e);const a=document.createElement("div");return a.appendChild(t),o.appendChild(a),n}(t,n);e.appendChild(r);const o=function(){const e=document.createElement("div");e.id=et;const t=e.style;return t.position="absolute",t.top="0",t.left="0",t.width="100%",t.height="100%",t.display="none",e}();e.appendChild(o);const i=function(){const e=document.createElement("canvas");e.id=st;const t=e.style;return t.position="absolute",t.top="0",t.left="0",t.width="100%",t.height="100%",t.visibility="hidden",e}();e.appendChild(i);const a=function(){const e=document.createElement("div");return e.className="shopar-ar-prompt-text",e}(),s=function(){const e=new Image;return e.className="shopar-ar-prompt-img",e}(),l=function(e,t){const n=document.createElement("div");n.className="shopar-ar-prompt";const{style:r}=n;return r.position="absolute",r.width="100%",r.height="100%",r.pointerEvents="none",r.opacity="0",n.appendChild(e),n.appendChild(t),n}(a,s);e.appendChild(l);const c=function(){const e=Ze("2rem",`${y}/img/prompt/3d-interaction.svg`),{style:t}=e;return t.transition="opacity 0.3s",t.opacity="0",e}(),u=function(e){const t=document.createElement("div"),{style:n}=t;return n.visibility="hidden",n.position="absolute",n.width="100%",n.height="100%",n.display="flex",n.justifyContent="center",n.alignItems="center",n.pointerEvents="none",t.appendChild(e),t}(c);e.appendChild(u);const d=tt("shopar-ar-loading-container"),h=nt("shopar-ar-loading-text",He("loading.ar"));d.appendChild(h);const p=rt("shopar-ar-loading-bar-bg"),f=ot("shopar-ar-loading-bar-fg");p.appendChild(f),d.appendChild(p),e.appendChild(d);const m=tt("shopar-3d-loading-container"),g=nt("shopar-3d-loading-text",He("loading.3d"));m.appendChild(g);const v=rt("shopar-3d-loading-bar-bg"),w=ot("shopar-3d-loading-bar-fg");v.appendChild(w),m.appendChild(v),e.appendChild(m);const b=function(){const e=document.createElement("div");return e.className="shopar-error-text",e.style.textAlign="center",e}(),E=function(e){const t=document.createElement("div");t.id=Xe;const n=t.style;n.position="absolute",n.width="100%",n.height="100%",n.display="none";const r=document.createElement("div"),o=r.style;return o.position="absolute",o.width="100%",o.height="100%",o.backgroundColor="#ffffff",o.display="flex",o.flexDirection="column",o.justifyContent="center",o.alignItems="center",t.appendChild(r),r.appendChild(e),t}(b);e.appendChild(E);const A=function(){const e=document.createElement("div");return e.id=Je,e.role="group",e.ariaLabel="Preview type chooser",e.className="shopar-btn-container",e.style.display="none",e}();e.appendChild(A);const R=Ye("shopar-btn-vto","Try-on","Launch ShopAR virtual try-on","data:image/svg+xml,%3Csvg%20xmlns=%22http://www.w3.org/2000/svg%22/%3E");A.appendChild(R);const S=Ye("shopar-btn-3d","3D","Launch ShopAR 3D preview",`${y}/img/icons/cube.svg`);A.appendChild(S);const C=Ye("shopar-btn-close","Close","Close ShopAR view",`${y}/img/icons/close.svg`);A.append(C);let I,x=lt.None,P=!1,M=!1,T=!1,k=!1;function L(){f.classList.remove("active"),d.style.visibility="hidden"}function $(){w.classList.remove("active"),m.style.visibility="hidden"}return{setTargetElement:function(t){t.style.position="relative",t.appendChild(e)},getQRTarget:function(){return r},getQRImage:function(){return n},getDeepARTarget:function(){return o},getDeepARPrompt:function(){return l},getThreeTarget:function(){return i},getThreePrompt:function(){return u},getThreePromptImage:function(){return c},customizeDeepARPrompt:function(e,t){a.textContent=e,s.src=t},customizeCameraError:function(e){b.textContent=null!=e?e:"Please reload page and allow camera access to continue"},customizeQRPrompt:function(e){t.textContent=null!=e?e:"Scan on mobile or tablet to try on"},setVisibilityParameters:function(e,t,n,r,o){var i;P=e,M=t,T=n,k=r,I=o,ht(A,P),ht(R,P&&(T||M)&&x===lt.None),ht(S,P&&k&&x===lt.None),ht(C,P&&x!==lt.None),L(),$(),P||""===(i=E).style.display&&ht(i,!1)},getUIState:function(){return x},setUIState:function(e){x=e,x===lt.None?(L(),$(),P&&(ht(E,!1),ht(C,!1),(M||T)&&ht(R,!0),k&&ht(S,!0))):x!==lt.QR&&x!==lt.AR&&x!==lt.Preview||P&&(ht(E,!1),ht(R,!1),ht(S,!1),ht(C,!0))},setDefaultUIActions:function(e,t,n){P&&((M||T)&&(!function(e){const t={Glasses:"glasses.svg",Shoes:"shoe.svg",Watches:"watch.svg"},n=null!=e&&t[e]||t.Glasses,r=`${y}/img/icons/${n}`;R.firstChild.firstChild.setAttributeNS("http://www.w3.org/1999/xlink","xlink:href",r)}(I),R.onclick=e),k&&(S.onclick=t),C.onclick=n)},startDeepARLoading:function(){f.classList.add("active"),d.style.visibility="visible"},stopDeepARLoading:L,startThreeLoading:function(){w.classList.add("active"),m.style.visibility="visible"},stopThreeLoading:$,showCameraError:function(){P&&ht(E,!0)}}}function ht(e,t){e.style.display=t?"":"none"}const pt=new Map;function ft(e){let n=pt.get(e);return null==n?(n=function(){let e=0,n=null,r=null,o=null;const i=()=>(null==n&&(n=dt()),n);return{getSetupId:()=>e,incrementSetupId_:()=>e++,getUI_:()=>n,findUI:i,findQR:()=>{if(null==r){const{getQRTarget:e,getQRImage:n}=i();r=function(e,n){let r=!0;return{qrPaused:()=>r,qrDraw:(o,i)=>t(this,void 0,void 0,(function*(){yield E;const t=`https://apps.deepar.ai/${v.includes("alpha")?"shopar-qr-alpha":"shopar-qr"}/?${new URLSearchParams({a:o,s:i,h:location.href})}`,a=yield window.ShopAR__QR.toDataURL(t),s=new Promise(((e,t)=>{n.onload=e,n.onerror=t}));n.src=a,yield s,r=!1,e.style.display=""})),qrPause:()=>t(this,void 0,void 0,(function*(){r=!0,e.style.display="none"}))}}(e(),n())}return r},findThree:()=>{if(null==o){const{getThreeTarget:e,getThreePrompt:t,getThreePromptImage:n}=i();o=Ge(e(),t(),n())}return o}}}(),pt.set(e,n)):n.incrementSetupId_(),n}function mt(e){for(const t of pt.values()){if(t===e)continue;const n=t.getUI_();if(null==n)continue;const{getUIState:r,setUIState:o}=n;r()===lt.AR&&o(lt.None)}}let gt;const vt=new Uint8Array(16);function wt(){if(!gt&&(gt="undefined"!=typeof crypto&&crypto.getRandomValues&&crypto.getRandomValues.bind(crypto),!gt))throw new Error("crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported");return gt(vt)}const yt=[];for(let e=0;e<256;++e)yt.push((e+256).toString(16).slice(1));var bt={randomUUID:"undefined"!=typeof crypto&&crypto.randomUUID&&crypto.randomUUID.bind(crypto)};function Et(e,t,n){if(bt.randomUUID&&!t&&!e)return bt.randomUUID();const r=(e=e||{}).random||(e.rng||wt)();if(r[6]=15&r[6]|64,r[8]=63&r[8]|128,t){n=n||0;for(let e=0;e<16;++e)t[n+e]=r[e];return t}return function(e,t=0){return yt[e[t+0]]+yt[e[t+1]]+yt[e[t+2]]+yt[e[t+3]]+"-"+yt[e[t+4]]+yt[e[t+5]]+"-"+yt[e[t+6]]+yt[e[t+7]]+"-"+yt[e[t+8]]+yt[e[t+9]]+"-"+yt[e[t+10]]+yt[e[t+11]]+yt[e[t+12]]+yt[e[t+13]]+yt[e[t+14]]+yt[e[t+15]]}(r)}const At="qrLaunch",Rt="arLaunch",St="previewLaunch",Ct="heartbeat";let It,xt,Pt=!1;const Mt=[];function Tt(){null==It&&(xt=Et(),It=b(`${y}/shopar-analytics.js`),It.then((()=>{Pt=!0,window.ShopAR__analytics.initializeImpl(),Mt.forEach((e=>e()))})))}function kt(e){Pt?e():Mt.push(e)}function Lt(e){return navigator.mediaDevices.getUserMedia({video:{facingMode:e,frameRate:{ideal:30},width:{ideal:640},height:{ideal:360}}})}function $t(e){return t(this,void 0,void 0,(function*(){const t=document.createElement("video");return t.setAttribute("playsinline","playsinline"),t.srcObject=yield e,t}))}const Ut=200,Dt=10;let _t=!1,Nt=null,jt=[],Ot=[];function Ft(e){return t(this,void 0,void 0,(function*(){_t=!1;const{ShopAR__TrueScale:n}=window;yield n.initialize(`${y}/wasm/mediapipe`,e),Nt&&clearInterval(Nt);const r=[],o=[];Nt=setInterval((()=>t(this,void 0,void 0,(function*(){if(_t)return;const{error:e,faceWidth:t,ipd:i,translation:a,rotation:s}=yield n.predict(performance.now());_t||(null!=a&&null!=s&&function(e){for(let t of jt)t(e)}({translation:a,rotation:s}),null==e&&(r.push(t),o.push(i),r.length<Dt||(r.shift(),o.shift(),function(e,t){for(let n of Ot)n({faceWidth:e,IPD:t})}(qt(r),qt(o)))))}))),Ut)}))}function Wt(){Ot=[],jt=[],_t=!0}function qt(e){let t=0;const n=e.length;for(let r=0;r<n;r++)t+=e[r];return t/n}function Gt(e){return t(this,void 0,void 0,(function*(){const r=yield f((()=>t(this,void 0,void 0,(function*(){const t=yield fetch(e).catch((e=>{throw console.error(e),new n("Resource unavailable.")}));if(!t.ok)throw new n(`Resource download failed with status ${t.status}.`);return t}))));try{return yield(yield r.blob()).arrayBuffer()}catch(e){throw console.error(e),new n("Resource has invalid body.")}}))}var zt="undefined"!=typeof Float32Array?Float32Array:Array;function Qt(){var e=new zt(16);return zt!=Float32Array&&(e[1]=0,e[2]=0,e[3]=0,e[4]=0,e[6]=0,e[7]=0,e[8]=0,e[9]=0,e[11]=0,e[12]=0,e[13]=0,e[14]=0),e[0]=1,e[5]=1,e[10]=1,e[15]=1,e}function Vt(e,t,n){var r=t[0],o=t[1],i=t[2],a=t[3],s=t[4],l=t[5],c=t[6],u=t[7],d=t[8],h=t[9],p=t[10],f=t[11],m=t[12],g=t[13],v=t[14],w=t[15],y=n[0],b=n[1],E=n[2],A=n[3];return e[0]=y*r+b*s+E*d+A*m,e[1]=y*o+b*l+E*h+A*g,e[2]=y*i+b*c+E*p+A*v,e[3]=y*a+b*u+E*f+A*w,y=n[4],b=n[5],E=n[6],A=n[7],e[4]=y*r+b*s+E*d+A*m,e[5]=y*o+b*l+E*h+A*g,e[6]=y*i+b*c+E*p+A*v,e[7]=y*a+b*u+E*f+A*w,y=n[8],b=n[9],E=n[10],A=n[11],e[8]=y*r+b*s+E*d+A*m,e[9]=y*o+b*l+E*h+A*g,e[10]=y*i+b*c+E*p+A*v,e[11]=y*a+b*u+E*f+A*w,y=n[12],b=n[13],E=n[14],A=n[15],e[12]=y*r+b*s+E*d+A*m,e[13]=y*o+b*l+E*h+A*g,e[14]=y*i+b*c+E*p+A*v,e[15]=y*a+b*u+E*f+A*w,e}function Kt(e,t){return e[0]=t[12],e[1]=t[13],e[2]=t[14],e}function Bt(e,t){var n=t[0],r=t[1],o=t[2],i=t[4],a=t[5],s=t[6],l=t[8],c=t[9],u=t[10];return e[0]=Math.hypot(n,r,o),e[1]=Math.hypot(i,a,s),e[2]=Math.hypot(l,c,u),e}function Ht(e,t,n,r){var o=t[0],i=t[1],a=t[2],s=t[3],l=o+o,c=i+i,u=a+a,d=o*l,h=o*c,p=o*u,f=i*c,m=i*u,g=a*u,v=s*l,w=s*c,y=s*u,b=r[0],E=r[1],A=r[2];return e[0]=(1-(f+g))*b,e[1]=(h+y)*b,e[2]=(p-w)*b,e[3]=0,e[4]=(h-y)*E,e[5]=(1-(d+g))*E,e[6]=(m+v)*E,e[7]=0,e[8]=(p+w)*A,e[9]=(m-v)*A,e[10]=(1-(d+f))*A,e[11]=0,e[12]=n[0],e[13]=n[1],e[14]=n[2],e[15]=1,e}function Xt(){var e=new zt(3);return zt!=Float32Array&&(e[0]=0,e[1]=0,e[2]=0),e}function Zt(e,t,n){var r=new zt(3);return r[0]=e,r[1]=t,r[2]=n,r}function Yt(e,t){var n=t[0]-e[0],r=t[1]-e[1],o=t[2]-e[2];return Math.hypot(n,r,o)}function Jt(e,t,n){var r=t[0],o=t[1],i=t[2],a=n[3]*r+n[7]*o+n[11]*i+n[15];return a=a||1,e[0]=(n[0]*r+n[4]*o+n[8]*i+n[12])/a,e[1]=(n[1]*r+n[5]*o+n[9]*i+n[13])/a,e[2]=(n[2]*r+n[6]*o+n[10]*i+n[14])/a,e}Math.hypot||(Math.hypot=function(){for(var e=0,t=arguments.length;t--;)e+=arguments[t]*arguments[t];return Math.sqrt(e)});function en(){var e=new zt(4);return zt!=Float32Array&&(e[0]=0,e[1]=0,e[2]=0),e[3]=1,e}Xt(),function(){var e,t=(e=new zt(4),zt!=Float32Array&&(e[0]=0,e[1]=0,e[2]=0,e[3]=0),e)}();var tn;let nn,rn,on;Xt(),Zt(1,0,0),Zt(0,1,0),en(),en(),tn=new zt(9),zt!=Float32Array&&(tn[1]=0,tn[2]=0,tn[3]=0,tn[5]=0,tn[6]=0,tn[7]=0),tn[0]=1,tn[4]=1,tn[8]=1;let an,sn,ln,cn,un=!0,dn=null;const hn=new Set;let pn,fn,mn,gn,vn,wn,yn;function bn(){null==nn&&(nn=b(`${y}/shopar-deepar.js`))}function En(){null==rn&&(rn=b(`${y}/shopar-true-scale.js`))}function An(e){return t(this,void 0,void 0,(function*(){const{licenseKey:r,truescaleUsecase:o}=e;return vn=o,null==pn&&(pn=(()=>t(this,void 0,void 0,(function*(){if(null==(null===(e=null===navigator||void 0===navigator?void 0:navigator.mediaDevices)||void 0===e?void 0:e.getUserMedia))throw new n("No camera available!");var e;const t=Tn(ln),o=Lt(t);an=yield window.ShopAR__DeepAR.deepar.initialize({licenseKey:r||"your_license_key_goes_here",previewElement:cn,additionalOptions:{hint:wn,cameraConfig:{disableDefaultCamera:!0}}}),sn=yield $t(o),yield kn(an,sn,"user"===t),"Glasses"===ln&&(yield rn,Ft(sn),"DetectionLoop"!==vn&&Dn((e=>{gn=e.faceWidth})))})))()),pn}))}function Rn(e,t){var n,r;(t=null!=t?t:function(e){const t={Glasses:["rigidFaceTrackingInit","faceInit"],Shoes:["footInit"],Watches:["wristInit"]};return null==e?void 0:t[e]}(e),e===ln&&(n=t,r=wn,n===r||null!=n&&null!=r&&n.length===r.length&&n.every((e=>r.find((t=>e===t))))&&r.every((e=>n.find((t=>t===e))))))||(null!=an&&(an.shutdown(),an=null,pn=null),ln=e,wn=t)}function Sn(e){e!==cn&&(cn=e,null!=an&&an.changePreviewElement(cn))}function Cn(e){dn=e}function In(e){an.callbacks.onFaceTracked=t=>{if(t.some((e=>e.detected))){if(gn){const e=137/(gn+5);an.changeParameterVector("GLASSES","","scale",e,e,e,0),an.changeParameterVector("shopar_glasses","","scale",e,e,e,0),function(e){const t=[-8.362421,4.549,-9.275],n=[8.362421,4.549,-9.275];try{const r=$n("face_position","model","temple_left","temple_left_outer","temple_tip_outer_left",n,e),o=$n("face_position","model","temple_right","temple_right_outer","temple_tip_outer_right",t,e);an.changeParameterVector("temple_left","","rotation",0,56.6*-r,0,0),an.changeParameterVector("temple_right","","rotation",0,56.6*-o,0,0)}catch(e){return}}(e),Wt(),gn=null}e(),Ln("Glasses")}},an.callbacks.onFeetTracked=(t,n)=>{(t.detected||n.detected)&&(e(),Ln("Shoes"))},an.callbacks.onWristTracked=t=>{t.detected&&(e(),Ln("Watches"))}}function xn(e,n){return t(this,void 0,void 0,(function*(){return null!=fn&&mn===n||(yield fn,fn=an.switchEffect(e),mn=n),fn}))}function Pn(){return t(this,void 0,void 0,(function*(){if(null!=an){if(un=!1,null==sn){const e=Tn(ln),t=Lt(e);sn=yield $t(t),yield kn(an,sn,"user"===e),Ft(sn),"DetectionLoop"!==vn&&Dn((e=>{gn=e.faceWidth}))}!function(){if(null==dn)return;if(null==ln||hn.has(ln))return;dn.style.visibility="visible",dn.style.opacity="1"}(),an.setPaused(un),cn.style.display=""}}))}function Mn(){null!=an&&(un=!0,an.setPaused(un),Wt(),null!=sn&&null!=sn.srcObject&&sn.srcObject instanceof MediaStream&&(sn.srcObject.getTracks().forEach((e=>e.stop())),sn=null),function(){if(null==dn)return;dn.style.visibility="hidden",dn.style.opacity="0"}(),an.stopCamera(),cn.style.display="none")}function Tn(e){var t;return null==e?"user":null!==(t={Glasses:"user",Shoes:"environment",Watches:"environment"}[e])&&void 0!==t?t:"user"}function kn(e,n,r){return t(this,void 0,void 0,(function*(){yield new Promise((o=>{n.onloadedmetadata=()=>{n.play().then((()=>t(this,void 0,void 0,(function*(){e.setVideoElement(n,r),o()}))))}}))}))}function Ln(e){null!=dn&&(hn.has(e)||(hn.add(e),dn.style.opacity="0"))}function $n(e,t,n,r,o,i,a){const s=an.getTransformationBetween(e,t),l=Kt(Xt(),s),c=function(e,t){var n=new zt(3);Bt(n,t);var r=1/n[0],o=1/n[1],i=1/n[2],a=t[0]*r,s=t[1]*o,l=t[2]*i,c=t[4]*r,u=t[5]*o,d=t[6]*i,h=t[8]*r,p=t[9]*o,f=t[10]*i,m=a+u+f,g=0;return m>0?(g=2*Math.sqrt(m+1),e[3]=.25*g,e[0]=(d-p)/g,e[1]=(h-l)/g,e[2]=(s-c)/g):a>u&&a>f?(g=2*Math.sqrt(1+a-u-f),e[3]=(d-p)/g,e[0]=.25*g,e[1]=(s+c)/g,e[2]=(h+l)/g):u>f?(g=2*Math.sqrt(1+u-a-f),e[3]=(h-l)/g,e[0]=(s+c)/g,e[1]=.25*g,e[2]=(d+p)/g):(g=2*Math.sqrt(1+f-a-u),e[3]=(s-c)/g,e[0]=(h+l)/g,e[1]=(d+p)/g,e[2]=.25*g),e}(en(),s);Ht(s,c,l,Zt(a,a,a));const u=an.getTransformationBetween(t,n),d=Kt(Xt(),u);Ht(u,en(),d,Bt(Xt(),u));const h=Vt(Qt(),s,u),p=Kt(Xt(),h),f=Math.atan2(i[0]-p[0],Math.abs(i[2]-p[2]));let m;try{m=an.getTransformationBetween(n,r)}catch(e){return f}const g=Vt(Qt(),u,m),v=Vt(Qt(),s,g),w=Zt(p[0],i[1],i[2]),y=Jt(Xt(),w,function(e,t){var n=t[0],r=t[1],o=t[2],i=t[3],a=t[4],s=t[5],l=t[6],c=t[7],u=t[8],d=t[9],h=t[10],p=t[11],f=t[12],m=t[13],g=t[14],v=t[15],w=n*s-r*a,y=n*l-o*a,b=n*c-i*a,E=r*l-o*s,A=r*c-i*s,R=o*c-i*l,S=u*m-d*f,C=u*g-h*f,I=u*v-p*f,x=d*g-h*m,P=d*v-p*m,M=h*v-p*g,T=w*M-y*P+b*x+E*I-A*C+R*S;return T?(T=1/T,e[0]=(s*M-l*P+c*x)*T,e[1]=(o*P-r*M-i*x)*T,e[2]=(m*R-g*A+v*E)*T,e[3]=(h*A-d*R-p*E)*T,e[4]=(l*I-a*M-c*C)*T,e[5]=(n*M-o*I+i*C)*T,e[6]=(g*b-f*R-v*y)*T,e[7]=(u*R-h*b+p*y)*T,e[8]=(a*P-s*I+c*S)*T,e[9]=(r*I-n*P-i*S)*T,e[10]=(f*A-m*b+v*w)*T,e[11]=(d*b-u*A-p*w)*T,e[12]=(s*C-a*x-l*S)*T,e[13]=(n*x-r*C+o*S)*T,e[14]=(m*y-f*E-g*w)*T,e[15]=(u*E-d*y+h*w)*T,e):null}(Qt(),v));let b=an.getClosestPointOnMesh(r,y);try{const e=an.getClosestPointOnMesh(o,y);Yt(y,e)<Yt(y,b)&&(b=e)}catch(e){}const E=Jt(Xt(),b,g);return f-Math.atan2(E[0]-d[0],Math.abs(E[2]-d[2]))}function Un(e){!function(e){jt.push(e)}(e)}function Dn(e){!function(e){Ot.push(e)}(e)}function _n(e,o,i){return t(this,void 0,void 0,(function*(){let a="glb".charCodeAt(0),s="3d".charCodeAt(0);a>>=1,a+=s;const l=String.fromCharCode(a+14);s>>=2,a^=s+2;const d=String.fromCharCode(a-3);a^=5;const h=String.fromCharCode(a-7);a^=2;const p=String.fromCharCode(a-7),m=window[`${h}${d+l+(typeof[])[(+!+[]+ +!+[])*(+!+[]+ +!+[])]}${p}`],g=yield f((()=>t(this,void 0,void 0,(function*(){const t=yield m(`${e}`).catch((()=>{throw new n("Unknown error.")}));if(!t.ok)throw new n("Unknown error.");return t})))),v=new r[0](yield(yield g.blob().catch((()=>{throw new n("Unknown error.")}))).arrayBuffer().catch((()=>{throw new n("Unknown error.")})));i+=s;const w=v.byteLength;if(u[c]=Math.min(76,o)*((a>>5)-1),152===u[c]&&(u[c]=w),i==c)return v;i=c,i^=c;for(let e=0,t=v.length;e<t;e++)u[c]^=u[i]<<13,u[c]^=u[i]>>17,u[c]^=u[i]<<5,v[e]=v[e]^u[c];return i^=u[0],i^=u[1],i^=u[2],v}))}function Nn(e,t){if(null==e)throw new n(`'${t}' not specified.`)}function jn(e,t){if("boolean"!=typeof e)throw new n(`'${t}' must be a boolean.`)}function On(e,t){if("string"!=typeof e)throw new n(`'${t}' must be a string.`)}const Fn=["AR","3D"];function Wn(e){const{apiKey:t,sku:r,targetElement:o,initialState:i,initialAnimation:a,baseUrl:s,defaultUI:l,interactive:c,strings:u}=e;Nn(t,"apiKey"),On(t,"apiKey"),Nn(r,"sku"),On(r,"sku"),Nn(o,"targetElement"),function(e,t){if(!(e instanceof HTMLElement))throw new n(`'${t}' must be an HTMLElement.`)}(o,"targetElement"),null!=i&&function(e,t,r){if("string"!=typeof e)throw new n(`'${t}' must be a string.`);if(!r.includes(e))throw new n(`'${t}' must be ${r.join("' or '")}.`)}(i,"initialState",Fn),null!=a&&function(e,t){if("string"!=typeof e&&!Array.isArray(e))throw new n(`'${t}' must be a string or array.`)}(a,"initialAnimation"),null!=s&&On(s,"baseUrl"),null!=l&&jn(l,"defaultUI"),null!=c&&jn(c,"interactive"),null!=u&&function(e,t,r){for(const o of r){const r=e[o];if(null!=r&&"string"!=typeof r)throw new n(`Value for key '${o}' in '${t}' must be a string.`)}}(u,"strings",Be)}let qn=!1;function Gn(e){return t(this,void 0,void 0,(function*(){const{targetElement:r}=e;y.update(e.baseUrl),Tt();const{trackEvent:o}=function(e){const t=performance.now(),n=Et();return{trackEvent:(r,o={})=>{o=Object.assign(Object.assign({},o),{pluginVersion:v,sessionId:xt,setupId:n,timeSinceSetup:performance.now()-t,apiKey:e}),kt((()=>{window.ShopAR__analytics.trackEventImpl(r,o)}))}}}(e.apiKey);o("visionSetup");const i=yield function(e){return t(this,void 0,void 0,(function*(){const r=yield f((()=>t(this,void 0,void 0,(function*(){const t=yield fetch(`https://dashboard.shopar.ai/plugin/vision?${new URLSearchParams({apiKey:e,sid:d()})}`).catch((e=>{throw console.error(e),new n("API unavailable.")}));if(!t.ok)throw new n(`API call failed with status ${t.status}.`);return t}))));try{return yield r.json()}catch(e){throw console.error(e),new n("API returned invalid body.")}}))}(e.apiKey);o("visionApiResponse",i);const{arKey:a}=i,s=ft(r),{getSetupId:l,findUI:c}=s,u=l();bn(),En();const{setTargetElement:h,getDeepARTarget:p,setVisibilityParameters:m,getUIState:g,setUIState:w,startDeepARLoading:b,stopDeepARLoading:E,showCameraError:A}=c();if(g()!=lt.None)throw Error("UI state is not None, this is weird..");w(lt.AR),h(r),m(!1,!1,!0,!1,void 0),b(),yield nn,zn(l(),u);try{o("visionArLaunch"),Mn(),Rn("Glasses",["faceInit"]),Sn(p()),yield An({licenseKey:a,truescaleUsecase:"DetectionLoop"}),zn(l(),u),yield Pn(),zn(l(),u)}catch(e){const t=e instanceof Error;throw o("visionArLaunchFailure",{errorName:t?e.name:"Unknown",errorMessage:t?e.message:""}),A(),Mn(),new n(`AR failed: ${t?e.message:"Unknown error."}`)}finally{E()}return qn=!0,{registerFacePoseListener:e=>{qn&&(o("registerFacePoseListener"),Un(e))},registerFaceMeasurementListener:e=>{qn&&(o("registerFaceMeasurementListener"),Dn(e))},switchEffect:e=>t(this,void 0,void 0,(function*(){qn&&(o("switchEffect",{arUrl:e}),function(e){an.switchEffect(e)}(e))})),clearEffect:()=>{qn&&(o("clearEffect"),an.clearEffect())},close:()=>{if(qn){if(qn=!1,o("visionClose"),g()!==lt.AR)throw new n("AR not launched.");Mn(),w(lt.None)}}}}))}function zn(e,t){if(e!==t)throw new n("Setup cancelled. Please ensure that setup is only called once.")}function Qn(e){var r,o;return t(this,void 0,void 0,(function*(){Wn(e);const{apiKey:i,sku:a,targetElement:s,initialState:l,initialAnimation:c}=e;!function(e){const t=getComputedStyle(e);if(!["static","relative"].includes(t.position))throw new n(`Invalid targetElement's position. Expected 'static' or 'relative', but found '${t.position}'.`)}(s),y.update(e.baseUrl),function(e){if(null!=e)for(const t of Object.keys(e)){if(!Object.prototype.hasOwnProperty.call(Ke,t)){console.warn(`String for key '${t}' will be ignored.`);continue}const n=e[t];null!=n&&(Ke[t]=n)}}(e.strings);const u=null!=c?ve(c):null,h=function(e,r){return t(this,void 0,void 0,(function*(){const o=yield f((()=>t(this,void 0,void 0,(function*(){const t=yield fetch(`https://dashboard.shopar.ai/plugin?${new URLSearchParams({apiKey:e,sku:r,sid:d()})}`).catch((e=>{throw console.error(e),new n("API unavailable.")}));if(!t.ok)throw new n(`API call failed with status ${t.status}.`);return t}))));try{return yield o.json()}catch(e){throw console.error(e),new n("API returned invalid body.")}}))}(i,a),p=ft(s),{getSetupId:w,findUI:A,findQR:R,findThree:S}=p,C=w();Tt();const{trackEvent:I,arInteracted:x,previewInteracted:P}=function(e,t){const n=performance.now(),r=Et();let o=0,i=0,a=0,s=0,l=0,c=!1;window.setInterval((()=>{c&&(o=i+a,c=!1,u(Ct,{engagementTotal:o,engagementAR:i,engagement3D:a}))}),1e3);const u=(o,i={})=>{i=Object.assign(Object.assign({},i),{pluginVersion:v,sessionId:xt,setupId:r,timeSinceSetup:performance.now()-n,sku:e,apiKey:t}),kt((()=>{window.ShopAR__analytics.trackEventImpl(o,i)}))};return{trackEvent:u,arInteracted:()=>{const e=performance.now(),t=e-s;s=e,t<200&&(i+=t,c=!0)},previewInteracted:()=>{const e=performance.now(),t=e-l;l=e,t<200&&(a+=t,c=!0)}}}(a,i);I("setup",{hostname:window.location.hostname});const M=yield h;I("apiResponse",M);const{category:T,arUrl:k,arKey:L,arPromptEnabled:$,arPromptText:U,arPromptImage:D,previewUrl:_,previewEnvUrl:N,previewToneMapping:j,previewToneMappingExposure:O,cameraErrorText:F,qrPromptText:W}=M;Vn(w(),C);const q=null!=k&&function(e){return null!=e&&m.includes(e)}(T),G=null==(null===(r=e._internalOptions)||void 0===r?void 0:r.qrEnabled)||(null===(o=e._internalOptions)||void 0===o?void 0:o.qrEnabled),z=q&&function(e){return null!=e&&g.includes(e)}(T),Q=G&&z&&!(yield function(){var e;return t(this,void 0,void 0,(function*(){return null==yn&&(yn=b(`${y}/shopar-platform.js`)),yield yn,["Android","iOS","Windows Phone",void 0].includes(null===(e=window.ShopAR__platform.platform.os)||void 0===e?void 0:e.family)}))}()),V=q&&!Q,K=null!=_;if(Vn(w(),C),Q&&function(){t(this,void 0,void 0,(function*(){null==E&&(E=b(`${y}/shopar-qr.js`))}))}(),V&&(bn(),function(e){e!==on&&(on=e,Gt(e),fn=null,Wt())}(k),"Glasses"===T&&En()),K){null==ke&&(ke=b(`${y}/shopar-three.js`));const e=255;_n(_,(new Date).getTime()+e,Math.random()*e),Gt(null!=N?N:`${y}/env/default.hdr`)}const{setTargetElement:B,getDeepARTarget:H,getDeepARPrompt:X,customizeDeepARPrompt:Z,customizeCameraError:Y,customizeQRPrompt:J,setVisibilityParameters:ee,getUIState:te,setUIState:ne,setDefaultUIActions:re,startDeepARLoading:oe,stopDeepARLoading:ie,startThreeLoading:ae,stopThreeLoading:se,showCameraError:le}=A();B(s);ee(null==e.defaultUI||e.defaultUI,Q,V,K,T),Z(null!=U?U:"",null!=D?D:""),Y(F),J(W),function(e,t){const r=e.parentNode;if(null==r)throw new n("Parent node missing.");new MutationObserver((n=>{for(const r of n)for(const n of r.removedNodes)if(n===e)return void t()})).observe(r,{childList:!0})}(s,(()=>{te()!==lt.QR||ce()||de(),te()!==lt.AR||un||Mn(),te()!==lt.Preview||me()||we(),ne(lt.None)}));const{qrPaused:ce,qrDraw:ue,qrPause:de}=R(),{threeInit:he,threeParse:pe,threeLoad:fe,threePaused:me,threeResume:ge,threePause:we,threeSetToneMapping:ye,threeIsInteractive:be,threeSetInteractive:Ee,threeSetOnInteracted:Ae,threeInitPromptAnimation:Re,threeInitCameraAnimation:Se}=S(),Ce=null==e.interactive||e.interactive;Ee(Ce);let Ie=0;if(te()===lt.QR){if(!ce())if(Q){I(At);try{yield ue(i,a)}catch(e){throw new n(`QR failed: ${e instanceof Error?e.message:"Unknown error."}`)}}else de(),ne(lt.None)}else if(te()===lt.AR){if(!un)if(V&&!qn){I(Rt);const e=yield Gt(k);Vn(w(),C),mt(p),Rn(T),Sn(H()),Cn($?X():null),yield xn(e,k),In(x),Vn(w(),C)}else Mn(),ne(lt.None)}else if(te()===lt.Preview&&!me())if(K){I(St),ae();const e=255,t=yield _n(_,(new Date).getTime()+e,Math.random()*e);Vn(w(),C);const n=yield Gt(null!=N?N:`${y}/env/default.hdr`);Vn(w(),C);const r=yield pe(t,n,`${_}${N}`);Vn(w(),C),fe(r,T),ye(null!=j?j:"ACES",null!=O?O:1),Ae(P),se()}else we(),ne(lt.None);const xe=()=>t(this,void 0,void 0,(function*(){if(Q){if(te()===lt.QR||te()===lt.AR)throw new n("AR already launched.");try{I(At);const e=++Ie;if(te()===lt.Preview&&K&&!me()&&we(),ne(lt.QR),yield ue(i,a),Ie!==e)return;return void Vn(w(),C)}catch(e){const t=e instanceof Error;throw I("qrLaunchFailure",{errorName:t?e.name:"Unknown",errorMessage:t?e.message:""}),new n(`QR failed: ${t?e.message:"Unknown error."}`)}}if(!V)throw new n("Model does not have AR enabled.");if(te()===lt.AR)throw new n("AR already launched.");try{I(Rt);const e=++Ie;te()===lt.Preview&&K&&!me()&&we(),mt(p),ne(lt.AR),oe();const t=yield Gt(k);if(Ie!==e)return;if(Vn(w(),C),yield nn,Ie!==e)return;if(Vn(w(),C),Mn(),Rn(T),Sn(H()),Cn($?X():null),yield An({licenseKey:L}),Ie!==e)return;if(Vn(w(),C),yield xn(t,k),In(x),Ie!==e)return;if(Vn(w(),C),yield Pn(),Ie!==e)return;Vn(w(),C)}catch(e){const t=e instanceof Error;throw I("arLaunchFailure",{errorName:t?e.name:"Unknown",errorMessage:t?e.message:""}),le(),Mn(),new n(`AR failed: ${t?e.message:"Unknown error."}`)}finally{ie()}})),Pe=()=>t(this,void 0,void 0,(function*(){if(!K)throw new n("Model does not have 3D enabled.");if(te()===lt.Preview)throw new n("3D already launched.");try{I(St);const e=++Ie;te()===lt.AR&&(V&&!un&&Mn(),de()),ne(lt.Preview),ae();const t=255,n=yield _n(_,(new Date).getTime()+t,Math.random()*t);if(Ie!==e)return;Vn(w(),C);const r=yield Gt(null!=N?N:`${y}/env/default.hdr`);if(Ie!==e)return;if(Vn(w(),C),yield ke,Ie!==e)return;if(Vn(w(),C),he(),Ie!==e)return;Vn(w(),C);const o=yield pe(n,r,`${_}${N}`);if(Ie!==e)return;Vn(w(),C),fe(o,T),ye(null!=j?j:"ACES",null!=O?O:1),Ae(P),Re(),null!=u&&Se(u),ge()}catch(e){const t=e instanceof Error;throw I("previewLaunchFailure",{errorName:t?e.name:"Unknown",errorMessage:t?e.message:""}),new n(`3D failed: ${t?e.message:"Unknown error."}`)}finally{se()}})),Me=()=>t(this,void 0,void 0,(function*(){if(te()===lt.None)throw new n("Neither AR or 3D launched.");++Ie,te()===lt.QR||te()===lt.AR?(V&&!un&&Mn(),de()):te()===lt.Preview&&K&&!me()&&we(),ne(lt.None)}));return re(xe,Pe,Me),"AR"===l?(yield xe(),Vn(w(),C)):"3D"===l&&(yield Pe(),Vn(w(),C)),qn=!1,{launchAR:q?xe:void 0,launch3D:K?Pe:void 0,closeAR:q?()=>t(this,void 0,void 0,(function*(){if(te()!==lt.AR&&te()!==lt.QR)throw new n("AR not launched.");++Ie,V&&!un&&Mn(),de(),ne(lt.None)})):void 0,close3D:K?()=>t(this,void 0,void 0,(function*(){if(te()!==lt.Preview)throw new n("3D not launched.");++Ie,K&&!me()&&we(),ne(lt.None)})):void 0,close:q||K?Me:void 0,isInteractive:()=>be(),setInteractive:e=>Ee(e)}}))}function Vn(e,t){if(e!==t)throw new n("Setup cancelled. Please ensure that setup is only called once.")}const Kn={setup:function(e){return t(this,void 0,void 0,(function*(){return Gn(e)}))}},Bn={setup:function(e){return t(this,void 0,void 0,(function*(){return function(e,r){return t(this,void 0,void 0,(function*(){try{return r()}catch(t){throw t instanceof Error?new n(`${e} failed: ${t.message}`):(console.error(t),new n(`${e} failed.`))}}))}("setup",(()=>Qn(e)))}))},version:v};e.plugin=Bn,e.vision=Kn}));
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "shopar-plugin",
|
|
3
|
-
"version": "0.2.
|
|
3
|
+
"version": "0.2.1-alpha.1",
|
|
4
4
|
"description": "Plugin for the Web that seamlessly integrates into your webpage to create embedded virtual try-on and 3D preview capabilities.",
|
|
5
5
|
"main": "dist/shopar-plugin.esm.js",
|
|
6
6
|
"module": "dist/shopar-plugin.esm.js",
|