@vouchfor/embeds 0.0.0-experiment.eb79200 → 0.0.0-experiment.f0c2382
Sign up to get free protection for your applications and to get access to all the features.
- package/dist/es/embeds.js +1025 -1084
- package/dist/es/embeds.js.map +1 -1
- package/dist/es/src/components/DialogEmbed/DialogOverlay.d.ts +20 -0
- package/dist/es/src/components/DialogEmbed/DialogPortal.d.ts +36 -0
- package/dist/es/src/components/DialogEmbed/index.d.ts +38 -0
- package/dist/es/{components/Embed → src/components/PlayerEmbed}/controllers/event-forwarder.d.ts +6 -5
- package/dist/es/src/components/PlayerEmbed/controllers/fetcher.d.ts +14 -0
- package/dist/es/src/components/PlayerEmbed/controllers/tracking/index.d.ts +36 -0
- package/dist/es/src/components/PlayerEmbed/controllers/tracking/utils.d.ts +17 -0
- package/dist/es/src/components/PlayerEmbed/index.d.ts +75 -0
- package/dist/es/src/components/PlayerEmbed/tests/data.d.ts +4 -0
- package/dist/es/src/components/PlayerEmbed/tests/media-data.d.ts +19 -0
- package/dist/es/src/index.d.ts +2 -0
- package/dist/es/src/utils/env.d.ts +12 -0
- package/dist/iife/dialog-embed/embed.iife.js +4045 -0
- package/dist/iife/dialog-embed/embed.iife.js.map +1 -0
- package/dist/iife/embeds.iife.js +2996 -432
- package/dist/iife/embeds.iife.js.map +1 -1
- package/dist/iife/player-embed/embed.iife.js +3907 -0
- package/dist/iife/player-embed/embed.iife.js.map +1 -0
- package/package.json +46 -33
- package/src/components/DialogEmbed/Dialog.stories.ts +91 -0
- package/src/components/DialogEmbed/DialogOverlay.ts +131 -0
- package/src/components/DialogEmbed/DialogPortal.ts +126 -0
- package/src/components/DialogEmbed/index.ts +97 -0
- package/src/components/PlayerEmbed/MultiEmbed.stories.ts +135 -0
- package/src/components/{Embed/Embed.stories.ts → PlayerEmbed/PlayerEmbed.stories.ts} +41 -30
- package/src/components/{Embed → PlayerEmbed}/controllers/event-forwarder.ts +6 -5
- package/src/components/PlayerEmbed/controllers/fetcher.ts +152 -0
- package/src/components/PlayerEmbed/controllers/tracking/index.ts +224 -0
- package/src/components/PlayerEmbed/controllers/tracking/utils.ts +95 -0
- package/src/components/PlayerEmbed/index.ts +262 -0
- package/src/components/PlayerEmbed/tests/PlayerEmbed.spec.ts +87 -0
- package/src/components/PlayerEmbed/tests/data.ts +227 -0
- package/src/components/PlayerEmbed/tests/media-data.ts +22 -0
- package/src/index.ts +2 -1
- package/src/utils/env.ts +18 -32
- package/dist/es/components/Embed/controllers/fetcher.d.ts +0 -8
- package/dist/es/components/Embed/controllers/tracking.d.ts +0 -28
- package/dist/es/components/Embed/index.d.ts +0 -65
- package/dist/es/index.d.ts +0 -1
- package/dist/es/utils/env.d.ts +0 -18
- package/src/components/Embed/controllers/fetcher.ts +0 -43
- package/src/components/Embed/controllers/tracking.ts +0 -268
- package/src/components/Embed/index.ts +0 -204
- /package/dist/es/{utils → src/utils}/events.d.ts +0 -0
package/dist/es/embeds.js
CHANGED
@@ -1,1038 +1,553 @@
|
|
1
|
-
import {
|
2
|
-
import {
|
3
|
-
import {
|
4
|
-
import {
|
1
|
+
import { css, LitElement, html } from "lit";
|
2
|
+
import { property, state, customElement } from "lit/decorators.js";
|
3
|
+
import { ifDefined } from "lit/directives/if-defined.js";
|
4
|
+
import { createRef, ref } from "lit/directives/ref.js";
|
5
|
+
import { Task } from "@lit/task";
|
6
|
+
import { v4 } from "uuid";
|
7
|
+
import { TEMPLATE_VERSION } from "@vouchfor/canvas-video";
|
5
8
|
import "@vouchfor/media-player";
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
this.cssText = t, this.t = e;
|
17
|
-
}
|
18
|
-
get styleSheet() {
|
19
|
-
let t = this.o;
|
20
|
-
const e = this.t;
|
21
|
-
if (mt && t === void 0) {
|
22
|
-
const i = e !== void 0 && e.length === 1;
|
23
|
-
i && (t = ft.get(e)), t === void 0 && ((this.o = t = new CSSStyleSheet()).replaceSync(this.cssText), i && ft.set(e, t));
|
24
|
-
}
|
25
|
-
return t;
|
26
|
-
}
|
27
|
-
toString() {
|
28
|
-
return this.cssText;
|
29
|
-
}
|
30
|
-
};
|
31
|
-
const ie = (n) => new ee(typeof n == "string" ? n : n + "", void 0, jt), se = (n, t) => {
|
32
|
-
mt ? n.adoptedStyleSheets = t.map((e) => e instanceof CSSStyleSheet ? e : e.styleSheet) : t.forEach((e) => {
|
33
|
-
const i = document.createElement("style"), s = Z.litNonce;
|
34
|
-
s !== void 0 && i.setAttribute("nonce", s), i.textContent = e.cssText, n.appendChild(i);
|
35
|
-
});
|
36
|
-
}, yt = mt ? (n) => n : (n) => n instanceof CSSStyleSheet ? ((t) => {
|
37
|
-
let e = "";
|
38
|
-
for (const i of t.cssRules)
|
39
|
-
e += i.cssText;
|
40
|
-
return ie(e);
|
41
|
-
})(n) : n;
|
42
|
-
/**
|
43
|
-
* @license
|
44
|
-
* Copyright 2017 Google LLC
|
45
|
-
* SPDX-License-Identifier: BSD-3-Clause
|
46
|
-
*/
|
47
|
-
var et;
|
48
|
-
const F = window, At = F.trustedTypes, ne = At ? At.emptyScript : "", Et = F.reactiveElementPolyfillSupport, dt = { toAttribute(n, t) {
|
49
|
-
switch (t) {
|
50
|
-
case Boolean:
|
51
|
-
n = n ? ne : null;
|
52
|
-
break;
|
53
|
-
case Object:
|
54
|
-
case Array:
|
55
|
-
n = n == null ? n : JSON.stringify(n);
|
56
|
-
}
|
57
|
-
return n;
|
58
|
-
}, fromAttribute(n, t) {
|
59
|
-
let e = n;
|
60
|
-
switch (t) {
|
61
|
-
case Boolean:
|
62
|
-
e = n !== null;
|
63
|
-
break;
|
64
|
-
case Number:
|
65
|
-
e = n === null ? null : Number(n);
|
66
|
-
break;
|
67
|
-
case Object:
|
68
|
-
case Array:
|
69
|
-
try {
|
70
|
-
e = JSON.parse(n);
|
71
|
-
} catch {
|
72
|
-
e = null;
|
73
|
-
}
|
74
|
-
}
|
75
|
-
return e;
|
76
|
-
} }, Bt = (n, t) => t !== n && (t == t || n == n), it = { attribute: !0, type: String, converter: dt, reflect: !1, hasChanged: Bt }, ct = "finalized";
|
77
|
-
let T = class extends HTMLElement {
|
78
|
-
constructor() {
|
79
|
-
super(), this._$Ei = /* @__PURE__ */ new Map(), this.isUpdatePending = !1, this.hasUpdated = !1, this._$El = null, this.u();
|
80
|
-
}
|
81
|
-
static addInitializer(t) {
|
82
|
-
var e;
|
83
|
-
this.finalize(), ((e = this.h) !== null && e !== void 0 ? e : this.h = []).push(t);
|
84
|
-
}
|
85
|
-
static get observedAttributes() {
|
86
|
-
this.finalize();
|
87
|
-
const t = [];
|
88
|
-
return this.elementProperties.forEach((e, i) => {
|
89
|
-
const s = this._$Ep(i, e);
|
90
|
-
s !== void 0 && (this._$Ev.set(s, i), t.push(s));
|
91
|
-
}), t;
|
92
|
-
}
|
93
|
-
static createProperty(t, e = it) {
|
94
|
-
if (e.state && (e.attribute = !1), this.finalize(), this.elementProperties.set(t, e), !e.noAccessor && !this.prototype.hasOwnProperty(t)) {
|
95
|
-
const i = typeof t == "symbol" ? Symbol() : "__" + t, s = this.getPropertyDescriptor(t, i, e);
|
96
|
-
s !== void 0 && Object.defineProperty(this.prototype, t, s);
|
97
|
-
}
|
98
|
-
}
|
99
|
-
static getPropertyDescriptor(t, e, i) {
|
100
|
-
return { get() {
|
101
|
-
return this[e];
|
102
|
-
}, set(s) {
|
103
|
-
const o = this[t];
|
104
|
-
this[e] = s, this.requestUpdate(t, o, i);
|
105
|
-
}, configurable: !0, enumerable: !0 };
|
106
|
-
}
|
107
|
-
static getPropertyOptions(t) {
|
108
|
-
return this.elementProperties.get(t) || it;
|
109
|
-
}
|
110
|
-
static finalize() {
|
111
|
-
if (this.hasOwnProperty(ct))
|
112
|
-
return !1;
|
113
|
-
this[ct] = !0;
|
114
|
-
const t = Object.getPrototypeOf(this);
|
115
|
-
if (t.finalize(), t.h !== void 0 && (this.h = [...t.h]), this.elementProperties = new Map(t.elementProperties), this._$Ev = /* @__PURE__ */ new Map(), this.hasOwnProperty("properties")) {
|
116
|
-
const e = this.properties, i = [...Object.getOwnPropertyNames(e), ...Object.getOwnPropertySymbols(e)];
|
117
|
-
for (const s of i)
|
118
|
-
this.createProperty(s, e[s]);
|
119
|
-
}
|
120
|
-
return this.elementStyles = this.finalizeStyles(this.styles), !0;
|
121
|
-
}
|
122
|
-
static finalizeStyles(t) {
|
123
|
-
const e = [];
|
124
|
-
if (Array.isArray(t)) {
|
125
|
-
const i = new Set(t.flat(1 / 0).reverse());
|
126
|
-
for (const s of i)
|
127
|
-
e.unshift(yt(s));
|
128
|
-
} else
|
129
|
-
t !== void 0 && e.push(yt(t));
|
130
|
-
return e;
|
131
|
-
}
|
132
|
-
static _$Ep(t, e) {
|
133
|
-
const i = e.attribute;
|
134
|
-
return i === !1 ? void 0 : typeof i == "string" ? i : typeof t == "string" ? t.toLowerCase() : void 0;
|
135
|
-
}
|
136
|
-
u() {
|
137
|
-
var t;
|
138
|
-
this._$E_ = new Promise((e) => this.enableUpdating = e), this._$AL = /* @__PURE__ */ new Map(), this._$Eg(), this.requestUpdate(), (t = this.constructor.h) === null || t === void 0 || t.forEach((e) => e(this));
|
139
|
-
}
|
140
|
-
addController(t) {
|
141
|
-
var e, i;
|
142
|
-
((e = this._$ES) !== null && e !== void 0 ? e : this._$ES = []).push(t), this.renderRoot !== void 0 && this.isConnected && ((i = t.hostConnected) === null || i === void 0 || i.call(t));
|
143
|
-
}
|
144
|
-
removeController(t) {
|
145
|
-
var e;
|
146
|
-
(e = this._$ES) === null || e === void 0 || e.splice(this._$ES.indexOf(t) >>> 0, 1);
|
147
|
-
}
|
148
|
-
_$Eg() {
|
149
|
-
this.constructor.elementProperties.forEach((t, e) => {
|
150
|
-
this.hasOwnProperty(e) && (this._$Ei.set(e, this[e]), delete this[e]);
|
151
|
-
});
|
152
|
-
}
|
153
|
-
createRenderRoot() {
|
154
|
-
var t;
|
155
|
-
const e = (t = this.shadowRoot) !== null && t !== void 0 ? t : this.attachShadow(this.constructor.shadowRootOptions);
|
156
|
-
return se(e, this.constructor.elementStyles), e;
|
157
|
-
}
|
158
|
-
connectedCallback() {
|
159
|
-
var t;
|
160
|
-
this.renderRoot === void 0 && (this.renderRoot = this.createRenderRoot()), this.enableUpdating(!0), (t = this._$ES) === null || t === void 0 || t.forEach((e) => {
|
161
|
-
var i;
|
162
|
-
return (i = e.hostConnected) === null || i === void 0 ? void 0 : i.call(e);
|
163
|
-
});
|
164
|
-
}
|
165
|
-
enableUpdating(t) {
|
166
|
-
}
|
167
|
-
disconnectedCallback() {
|
168
|
-
var t;
|
169
|
-
(t = this._$ES) === null || t === void 0 || t.forEach((e) => {
|
170
|
-
var i;
|
171
|
-
return (i = e.hostDisconnected) === null || i === void 0 ? void 0 : i.call(e);
|
172
|
-
});
|
173
|
-
}
|
174
|
-
attributeChangedCallback(t, e, i) {
|
175
|
-
this._$AK(t, i);
|
176
|
-
}
|
177
|
-
_$EO(t, e, i = it) {
|
178
|
-
var s;
|
179
|
-
const o = this.constructor._$Ep(t, i);
|
180
|
-
if (o !== void 0 && i.reflect === !0) {
|
181
|
-
const r = (((s = i.converter) === null || s === void 0 ? void 0 : s.toAttribute) !== void 0 ? i.converter : dt).toAttribute(e, i.type);
|
182
|
-
this._$El = t, r == null ? this.removeAttribute(o) : this.setAttribute(o, r), this._$El = null;
|
183
|
-
}
|
184
|
-
}
|
185
|
-
_$AK(t, e) {
|
186
|
-
var i;
|
187
|
-
const s = this.constructor, o = s._$Ev.get(t);
|
188
|
-
if (o !== void 0 && this._$El !== o) {
|
189
|
-
const r = s.getPropertyOptions(o), d = typeof r.converter == "function" ? { fromAttribute: r.converter } : ((i = r.converter) === null || i === void 0 ? void 0 : i.fromAttribute) !== void 0 ? r.converter : dt;
|
190
|
-
this._$El = o, this[o] = d.fromAttribute(e, r.type), this._$El = null;
|
191
|
-
}
|
192
|
-
}
|
193
|
-
requestUpdate(t, e, i) {
|
194
|
-
let s = !0;
|
195
|
-
t !== void 0 && (((i = i || this.constructor.getPropertyOptions(t)).hasChanged || Bt)(this[t], e) ? (this._$AL.has(t) || this._$AL.set(t, e), i.reflect === !0 && this._$El !== t && (this._$EC === void 0 && (this._$EC = /* @__PURE__ */ new Map()), this._$EC.set(t, i))) : s = !1), !this.isUpdatePending && s && (this._$E_ = this._$Ej());
|
196
|
-
}
|
197
|
-
async _$Ej() {
|
198
|
-
this.isUpdatePending = !0;
|
199
|
-
try {
|
200
|
-
await this._$E_;
|
201
|
-
} catch (e) {
|
202
|
-
Promise.reject(e);
|
203
|
-
}
|
204
|
-
const t = this.scheduleUpdate();
|
205
|
-
return t != null && await t, !this.isUpdatePending;
|
206
|
-
}
|
207
|
-
scheduleUpdate() {
|
208
|
-
return this.performUpdate();
|
209
|
-
}
|
210
|
-
performUpdate() {
|
211
|
-
var t;
|
212
|
-
if (!this.isUpdatePending)
|
213
|
-
return;
|
214
|
-
this.hasUpdated, this._$Ei && (this._$Ei.forEach((s, o) => this[o] = s), this._$Ei = void 0);
|
215
|
-
let e = !1;
|
216
|
-
const i = this._$AL;
|
217
|
-
try {
|
218
|
-
e = this.shouldUpdate(i), e ? (this.willUpdate(i), (t = this._$ES) === null || t === void 0 || t.forEach((s) => {
|
219
|
-
var o;
|
220
|
-
return (o = s.hostUpdate) === null || o === void 0 ? void 0 : o.call(s);
|
221
|
-
}), this.update(i)) : this._$Ek();
|
222
|
-
} catch (s) {
|
223
|
-
throw e = !1, this._$Ek(), s;
|
224
|
-
}
|
225
|
-
e && this._$AE(i);
|
226
|
-
}
|
227
|
-
willUpdate(t) {
|
228
|
-
}
|
229
|
-
_$AE(t) {
|
230
|
-
var e;
|
231
|
-
(e = this._$ES) === null || e === void 0 || e.forEach((i) => {
|
232
|
-
var s;
|
233
|
-
return (s = i.hostUpdated) === null || s === void 0 ? void 0 : s.call(i);
|
234
|
-
}), this.hasUpdated || (this.hasUpdated = !0, this.firstUpdated(t)), this.updated(t);
|
235
|
-
}
|
236
|
-
_$Ek() {
|
237
|
-
this._$AL = /* @__PURE__ */ new Map(), this.isUpdatePending = !1;
|
238
|
-
}
|
239
|
-
get updateComplete() {
|
240
|
-
return this.getUpdateComplete();
|
241
|
-
}
|
242
|
-
getUpdateComplete() {
|
243
|
-
return this._$E_;
|
244
|
-
}
|
245
|
-
shouldUpdate(t) {
|
246
|
-
return !0;
|
247
|
-
}
|
248
|
-
update(t) {
|
249
|
-
this._$EC !== void 0 && (this._$EC.forEach((e, i) => this._$EO(i, this[i], e)), this._$EC = void 0), this._$Ek();
|
250
|
-
}
|
251
|
-
updated(t) {
|
252
|
-
}
|
253
|
-
firstUpdated(t) {
|
254
|
-
}
|
255
|
-
};
|
256
|
-
T[ct] = !0, T.elementProperties = /* @__PURE__ */ new Map(), T.elementStyles = [], T.shadowRootOptions = { mode: "open" }, Et == null || Et({ ReactiveElement: T }), ((et = F.reactiveElementVersions) !== null && et !== void 0 ? et : F.reactiveElementVersions = []).push("1.6.2");
|
257
|
-
/**
|
258
|
-
* @license
|
259
|
-
* Copyright 2017 Google LLC
|
260
|
-
* SPDX-License-Identifier: BSD-3-Clause
|
261
|
-
*/
|
262
|
-
var st;
|
263
|
-
const J = window, x = J.trustedTypes, bt = x ? x.createPolicy("lit-html", { createHTML: (n) => n }) : void 0, ut = "$lit$", E = `lit$${(Math.random() + "").slice(9)}$`, zt = "?" + E, re = `<${zt}>`, C = document, G = () => C.createComment(""), D = (n) => n === null || typeof n != "object" && typeof n != "function", Wt = Array.isArray, oe = (n) => Wt(n) || typeof (n == null ? void 0 : n[Symbol.iterator]) == "function", nt = `[
|
264
|
-
\f\r]`, V = /<(?:(!--|\/[^a-zA-Z])|(\/?[a-zA-Z][^>\s]*)|(\/?$))/g, wt = /-->/g, St = />/g, w = RegExp(`>|${nt}(?:([^\\s"'>=/]+)(${nt}*=${nt}*(?:[^
|
265
|
-
\f\r"'\`<>=]|("|')|))|$)`, "g"), Pt = /'/g, Ut = /"/g, qt = /^(?:script|style|textarea|title)$/i, j = Symbol.for("lit-noChange"), v = Symbol.for("lit-nothing"), Ct = /* @__PURE__ */ new WeakMap(), P = C.createTreeWalker(C, 129, null, !1);
|
266
|
-
function Kt(n, t) {
|
267
|
-
if (!Array.isArray(n) || !n.hasOwnProperty("raw"))
|
268
|
-
throw Error("invalid template strings array");
|
269
|
-
return bt !== void 0 ? bt.createHTML(t) : t;
|
270
|
-
}
|
271
|
-
const le = (n, t) => {
|
272
|
-
const e = n.length - 1, i = [];
|
273
|
-
let s, o = t === 2 ? "<svg>" : "", r = V;
|
274
|
-
for (let d = 0; d < e; d++) {
|
275
|
-
const l = n[d];
|
276
|
-
let a, u, h = -1, c = 0;
|
277
|
-
for (; c < l.length && (r.lastIndex = c, u = r.exec(l), u !== null); )
|
278
|
-
c = r.lastIndex, r === V ? u[1] === "!--" ? r = wt : u[1] !== void 0 ? r = St : u[2] !== void 0 ? (qt.test(u[2]) && (s = RegExp("</" + u[2], "g")), r = w) : u[3] !== void 0 && (r = w) : r === w ? u[0] === ">" ? (r = s ?? V, h = -1) : u[1] === void 0 ? h = -2 : (h = r.lastIndex - u[2].length, a = u[1], r = u[3] === void 0 ? w : u[3] === '"' ? Ut : Pt) : r === Ut || r === Pt ? r = w : r === wt || r === St ? r = V : (r = w, s = void 0);
|
279
|
-
const p = r === w && n[d + 1].startsWith("/>") ? " " : "";
|
280
|
-
o += r === V ? l + re : h >= 0 ? (i.push(a), l.slice(0, h) + ut + l.slice(h) + E + p) : l + E + (h === -2 ? (i.push(void 0), d) : p);
|
281
|
-
}
|
282
|
-
return [Kt(n, o + (n[e] || "<?>") + (t === 2 ? "</svg>" : "")), i];
|
283
|
-
};
|
284
|
-
let pt = class Zt {
|
285
|
-
constructor({ strings: t, _$litType$: e }, i) {
|
286
|
-
let s;
|
287
|
-
this.parts = [];
|
288
|
-
let o = 0, r = 0;
|
289
|
-
const d = t.length - 1, l = this.parts, [a, u] = le(t, e);
|
290
|
-
if (this.el = Zt.createElement(a, i), P.currentNode = this.el.content, e === 2) {
|
291
|
-
const h = this.el.content, c = h.firstChild;
|
292
|
-
c.remove(), h.append(...c.childNodes);
|
293
|
-
}
|
294
|
-
for (; (s = P.nextNode()) !== null && l.length < d; ) {
|
295
|
-
if (s.nodeType === 1) {
|
296
|
-
if (s.hasAttributes()) {
|
297
|
-
const h = [];
|
298
|
-
for (const c of s.getAttributeNames())
|
299
|
-
if (c.endsWith(ut) || c.startsWith(E)) {
|
300
|
-
const p = u[r++];
|
301
|
-
if (h.push(c), p !== void 0) {
|
302
|
-
const A = s.getAttribute(p.toLowerCase() + ut).split(E), f = /([.?@])?(.*)/.exec(p);
|
303
|
-
l.push({ type: 1, index: o, name: f[2], strings: A, ctor: f[1] === "." ? he : f[1] === "?" ? ce : f[1] === "@" ? ue : Y });
|
304
|
-
} else
|
305
|
-
l.push({ type: 6, index: o });
|
306
|
-
}
|
307
|
-
for (const c of h)
|
308
|
-
s.removeAttribute(c);
|
309
|
-
}
|
310
|
-
if (qt.test(s.tagName)) {
|
311
|
-
const h = s.textContent.split(E), c = h.length - 1;
|
312
|
-
if (c > 0) {
|
313
|
-
s.textContent = x ? x.emptyScript : "";
|
314
|
-
for (let p = 0; p < c; p++)
|
315
|
-
s.append(h[p], G()), P.nextNode(), l.push({ type: 2, index: ++o });
|
316
|
-
s.append(h[c], G());
|
317
|
-
}
|
318
|
-
}
|
319
|
-
} else if (s.nodeType === 8)
|
320
|
-
if (s.data === zt)
|
321
|
-
l.push({ type: 2, index: o });
|
322
|
-
else {
|
323
|
-
let h = -1;
|
324
|
-
for (; (h = s.data.indexOf(E, h + 1)) !== -1; )
|
325
|
-
l.push({ type: 7, index: o }), h += E.length - 1;
|
326
|
-
}
|
327
|
-
o++;
|
328
|
-
}
|
329
|
-
}
|
330
|
-
static createElement(t, e) {
|
331
|
-
const i = C.createElement("template");
|
332
|
-
return i.innerHTML = t, i;
|
333
|
-
}
|
334
|
-
};
|
335
|
-
function H(n, t, e = n, i) {
|
336
|
-
var s, o, r, d;
|
337
|
-
if (t === j)
|
338
|
-
return t;
|
339
|
-
let l = i !== void 0 ? (s = e._$Co) === null || s === void 0 ? void 0 : s[i] : e._$Cl;
|
340
|
-
const a = D(t) ? void 0 : t._$litDirective$;
|
341
|
-
return (l == null ? void 0 : l.constructor) !== a && ((o = l == null ? void 0 : l._$AO) === null || o === void 0 || o.call(l, !1), a === void 0 ? l = void 0 : (l = new a(n), l._$AT(n, e, i)), i !== void 0 ? ((r = (d = e)._$Co) !== null && r !== void 0 ? r : d._$Co = [])[i] = l : e._$Cl = l), l !== void 0 && (t = H(n, l._$AS(n, t.values), l, i)), t;
|
342
|
-
}
|
343
|
-
let ae = class {
|
344
|
-
constructor(t, e) {
|
345
|
-
this._$AV = [], this._$AN = void 0, this._$AD = t, this._$AM = e;
|
346
|
-
}
|
347
|
-
get parentNode() {
|
348
|
-
return this._$AM.parentNode;
|
349
|
-
}
|
350
|
-
get _$AU() {
|
351
|
-
return this._$AM._$AU;
|
352
|
-
}
|
353
|
-
u(t) {
|
354
|
-
var e;
|
355
|
-
const { el: { content: i }, parts: s } = this._$AD, o = ((e = t == null ? void 0 : t.creationScope) !== null && e !== void 0 ? e : C).importNode(i, !0);
|
356
|
-
P.currentNode = o;
|
357
|
-
let r = P.nextNode(), d = 0, l = 0, a = s[0];
|
358
|
-
for (; a !== void 0; ) {
|
359
|
-
if (d === a.index) {
|
360
|
-
let u;
|
361
|
-
a.type === 2 ? u = new Ft(r, r.nextSibling, this, t) : a.type === 1 ? u = new a.ctor(r, a.name, a.strings, this, t) : a.type === 6 && (u = new pe(r, this, t)), this._$AV.push(u), a = s[++l];
|
362
|
-
}
|
363
|
-
d !== (a == null ? void 0 : a.index) && (r = P.nextNode(), d++);
|
364
|
-
}
|
365
|
-
return P.currentNode = C, o;
|
366
|
-
}
|
367
|
-
v(t) {
|
368
|
-
let e = 0;
|
369
|
-
for (const i of this._$AV)
|
370
|
-
i !== void 0 && (i.strings !== void 0 ? (i._$AI(t, i, e), e += i.strings.length - 2) : i._$AI(t[e])), e++;
|
371
|
-
}
|
372
|
-
}, Ft = class Jt {
|
373
|
-
constructor(t, e, i, s) {
|
374
|
-
var o;
|
375
|
-
this.type = 2, this._$AH = v, this._$AN = void 0, this._$AA = t, this._$AB = e, this._$AM = i, this.options = s, this._$Cp = (o = s == null ? void 0 : s.isConnected) === null || o === void 0 || o;
|
376
|
-
}
|
377
|
-
get _$AU() {
|
378
|
-
var t, e;
|
379
|
-
return (e = (t = this._$AM) === null || t === void 0 ? void 0 : t._$AU) !== null && e !== void 0 ? e : this._$Cp;
|
380
|
-
}
|
381
|
-
get parentNode() {
|
382
|
-
let t = this._$AA.parentNode;
|
383
|
-
const e = this._$AM;
|
384
|
-
return e !== void 0 && (t == null ? void 0 : t.nodeType) === 11 && (t = e.parentNode), t;
|
385
|
-
}
|
386
|
-
get startNode() {
|
387
|
-
return this._$AA;
|
388
|
-
}
|
389
|
-
get endNode() {
|
390
|
-
return this._$AB;
|
391
|
-
}
|
392
|
-
_$AI(t, e = this) {
|
393
|
-
t = H(this, t, e), D(t) ? t === v || t == null || t === "" ? (this._$AH !== v && this._$AR(), this._$AH = v) : t !== this._$AH && t !== j && this._(t) : t._$litType$ !== void 0 ? this.g(t) : t.nodeType !== void 0 ? this.$(t) : oe(t) ? this.T(t) : this._(t);
|
394
|
-
}
|
395
|
-
k(t) {
|
396
|
-
return this._$AA.parentNode.insertBefore(t, this._$AB);
|
397
|
-
}
|
398
|
-
$(t) {
|
399
|
-
this._$AH !== t && (this._$AR(), this._$AH = this.k(t));
|
400
|
-
}
|
401
|
-
_(t) {
|
402
|
-
this._$AH !== v && D(this._$AH) ? this._$AA.nextSibling.data = t : this.$(C.createTextNode(t)), this._$AH = t;
|
403
|
-
}
|
404
|
-
g(t) {
|
405
|
-
var e;
|
406
|
-
const { values: i, _$litType$: s } = t, o = typeof s == "number" ? this._$AC(t) : (s.el === void 0 && (s.el = pt.createElement(Kt(s.h, s.h[0]), this.options)), s);
|
407
|
-
if (((e = this._$AH) === null || e === void 0 ? void 0 : e._$AD) === o)
|
408
|
-
this._$AH.v(i);
|
409
|
-
else {
|
410
|
-
const r = new ae(o, this), d = r.u(this.options);
|
411
|
-
r.v(i), this.$(d), this._$AH = r;
|
412
|
-
}
|
413
|
-
}
|
414
|
-
_$AC(t) {
|
415
|
-
let e = Ct.get(t.strings);
|
416
|
-
return e === void 0 && Ct.set(t.strings, e = new pt(t)), e;
|
417
|
-
}
|
418
|
-
T(t) {
|
419
|
-
Wt(this._$AH) || (this._$AH = [], this._$AR());
|
420
|
-
const e = this._$AH;
|
421
|
-
let i, s = 0;
|
422
|
-
for (const o of t)
|
423
|
-
s === e.length ? e.push(i = new Jt(this.k(G()), this.k(G()), this, this.options)) : i = e[s], i._$AI(o), s++;
|
424
|
-
s < e.length && (this._$AR(i && i._$AB.nextSibling, s), e.length = s);
|
425
|
-
}
|
426
|
-
_$AR(t = this._$AA.nextSibling, e) {
|
427
|
-
var i;
|
428
|
-
for ((i = this._$AP) === null || i === void 0 || i.call(this, !1, !0, e); t && t !== this._$AB; ) {
|
429
|
-
const s = t.nextSibling;
|
430
|
-
t.remove(), t = s;
|
431
|
-
}
|
432
|
-
}
|
433
|
-
setConnected(t) {
|
434
|
-
var e;
|
435
|
-
this._$AM === void 0 && (this._$Cp = t, (e = this._$AP) === null || e === void 0 || e.call(this, t));
|
436
|
-
}
|
437
|
-
}, Y = class {
|
438
|
-
constructor(t, e, i, s, o) {
|
439
|
-
this.type = 1, this._$AH = v, this._$AN = void 0, this.element = t, this.name = e, this._$AM = s, this.options = o, i.length > 2 || i[0] !== "" || i[1] !== "" ? (this._$AH = Array(i.length - 1).fill(new String()), this.strings = i) : this._$AH = v;
|
440
|
-
}
|
441
|
-
get tagName() {
|
442
|
-
return this.element.tagName;
|
443
|
-
}
|
444
|
-
get _$AU() {
|
445
|
-
return this._$AM._$AU;
|
446
|
-
}
|
447
|
-
_$AI(t, e = this, i, s) {
|
448
|
-
const o = this.strings;
|
449
|
-
let r = !1;
|
450
|
-
if (o === void 0)
|
451
|
-
t = H(this, t, e, 0), r = !D(t) || t !== this._$AH && t !== j, r && (this._$AH = t);
|
452
|
-
else {
|
453
|
-
const d = t;
|
454
|
-
let l, a;
|
455
|
-
for (t = o[0], l = 0; l < o.length - 1; l++)
|
456
|
-
a = H(this, d[i + l], e, l), a === j && (a = this._$AH[l]), r || (r = !D(a) || a !== this._$AH[l]), a === v ? t = v : t !== v && (t += (a ?? "") + o[l + 1]), this._$AH[l] = a;
|
457
|
-
}
|
458
|
-
r && !s && this.j(t);
|
459
|
-
}
|
460
|
-
j(t) {
|
461
|
-
t === v ? this.element.removeAttribute(this.name) : this.element.setAttribute(this.name, t ?? "");
|
462
|
-
}
|
463
|
-
}, he = class extends Y {
|
464
|
-
constructor() {
|
465
|
-
super(...arguments), this.type = 3;
|
466
|
-
}
|
467
|
-
j(t) {
|
468
|
-
this.element[this.name] = t === v ? void 0 : t;
|
469
|
-
}
|
470
|
-
};
|
471
|
-
const de = x ? x.emptyScript : "";
|
472
|
-
let ce = class extends Y {
|
473
|
-
constructor() {
|
474
|
-
super(...arguments), this.type = 4;
|
475
|
-
}
|
476
|
-
j(t) {
|
477
|
-
t && t !== v ? this.element.setAttribute(this.name, de) : this.element.removeAttribute(this.name);
|
478
|
-
}
|
479
|
-
}, ue = class extends Y {
|
480
|
-
constructor(t, e, i, s, o) {
|
481
|
-
super(t, e, i, s, o), this.type = 5;
|
482
|
-
}
|
483
|
-
_$AI(t, e = this) {
|
484
|
-
var i;
|
485
|
-
if ((t = (i = H(this, t, e, 0)) !== null && i !== void 0 ? i : v) === j)
|
486
|
-
return;
|
487
|
-
const s = this._$AH, o = t === v && s !== v || t.capture !== s.capture || t.once !== s.once || t.passive !== s.passive, r = t !== v && (s === v || o);
|
488
|
-
o && this.element.removeEventListener(this.name, this, s), r && this.element.addEventListener(this.name, this, t), this._$AH = t;
|
489
|
-
}
|
490
|
-
handleEvent(t) {
|
491
|
-
var e, i;
|
492
|
-
typeof this._$AH == "function" ? this._$AH.call((i = (e = this.options) === null || e === void 0 ? void 0 : e.host) !== null && i !== void 0 ? i : this.element, t) : this._$AH.handleEvent(t);
|
493
|
-
}
|
494
|
-
};
|
495
|
-
class pe {
|
496
|
-
constructor(t, e, i) {
|
497
|
-
this.element = t, this.type = 6, this._$AN = void 0, this._$AM = e, this.options = i;
|
498
|
-
}
|
499
|
-
get _$AU() {
|
500
|
-
return this._$AM._$AU;
|
501
|
-
}
|
502
|
-
_$AI(t) {
|
503
|
-
H(this, t);
|
504
|
-
}
|
505
|
-
}
|
506
|
-
const Rt = J.litHtmlPolyfillSupport;
|
507
|
-
Rt == null || Rt(pt, Ft), ((st = J.litHtmlVersions) !== null && st !== void 0 ? st : J.litHtmlVersions = []).push("2.8.0");
|
508
|
-
/**
|
509
|
-
* @license
|
510
|
-
* Copyright 2017 Google LLC
|
511
|
-
* SPDX-License-Identifier: BSD-3-Clause
|
512
|
-
*/
|
513
|
-
var rt;
|
514
|
-
const X = window, N = X.trustedTypes, Tt = N ? N.createPolicy("lit-html", { createHTML: (n) => n }) : void 0, vt = "$lit$", b = `lit$${(Math.random() + "").slice(9)}$`, Gt = "?" + b, ve = `<${Gt}>`, R = document, B = () => R.createComment(""), z = (n) => n === null || typeof n != "object" && typeof n != "function", Xt = Array.isArray, _e = (n) => Xt(n) || typeof (n == null ? void 0 : n[Symbol.iterator]) == "function", ot = `[
|
515
|
-
\f\r]`, O = /<(?:(!--|\/[^a-zA-Z])|(\/?[a-zA-Z][^>\s]*)|(\/?$))/g, xt = /-->/g, Ht = />/g, S = RegExp(`>|${ot}(?:([^\\s"'>=/]+)(${ot}*=${ot}*(?:[^
|
516
|
-
\f\r"'\`<>=]|("|')|))|$)`, "g"), Nt = /'/g, It = /"/g, Yt = /^(?:script|style|textarea|title)$/i, $e = (n) => (t, ...e) => ({ _$litType$: n, strings: t, values: e }), me = $e(1), I = Symbol.for("lit-noChange"), _ = Symbol.for("lit-nothing"), kt = /* @__PURE__ */ new WeakMap(), U = R.createTreeWalker(R, 129, null, !1), ge = (n, t) => {
|
517
|
-
const e = n.length - 1, i = [];
|
518
|
-
let s, o = t === 2 ? "<svg>" : "", r = O;
|
519
|
-
for (let l = 0; l < e; l++) {
|
520
|
-
const a = n[l];
|
521
|
-
let u, h, c = -1, p = 0;
|
522
|
-
for (; p < a.length && (r.lastIndex = p, h = r.exec(a), h !== null); )
|
523
|
-
p = r.lastIndex, r === O ? h[1] === "!--" ? r = xt : h[1] !== void 0 ? r = Ht : h[2] !== void 0 ? (Yt.test(h[2]) && (s = RegExp("</" + h[2], "g")), r = S) : h[3] !== void 0 && (r = S) : r === S ? h[0] === ">" ? (r = s ?? O, c = -1) : h[1] === void 0 ? c = -2 : (c = r.lastIndex - h[2].length, u = h[1], r = h[3] === void 0 ? S : h[3] === '"' ? It : Nt) : r === It || r === Nt ? r = S : r === xt || r === Ht ? r = O : (r = S, s = void 0);
|
524
|
-
const A = r === S && n[l + 1].startsWith("/>") ? " " : "";
|
525
|
-
o += r === O ? a + ve : c >= 0 ? (i.push(u), a.slice(0, c) + vt + a.slice(c) + b + A) : a + b + (c === -2 ? (i.push(void 0), l) : A);
|
526
|
-
}
|
527
|
-
const d = o + (n[e] || "<?>") + (t === 2 ? "</svg>" : "");
|
528
|
-
if (!Array.isArray(n) || !n.hasOwnProperty("raw"))
|
529
|
-
throw Error("invalid template strings array");
|
530
|
-
return [Tt !== void 0 ? Tt.createHTML(d) : d, i];
|
531
|
-
};
|
532
|
-
class W {
|
533
|
-
constructor({ strings: t, _$litType$: e }, i) {
|
534
|
-
let s;
|
535
|
-
this.parts = [];
|
536
|
-
let o = 0, r = 0;
|
537
|
-
const d = t.length - 1, l = this.parts, [a, u] = ge(t, e);
|
538
|
-
if (this.el = W.createElement(a, i), U.currentNode = this.el.content, e === 2) {
|
539
|
-
const h = this.el.content, c = h.firstChild;
|
540
|
-
c.remove(), h.append(...c.childNodes);
|
541
|
-
}
|
542
|
-
for (; (s = U.nextNode()) !== null && l.length < d; ) {
|
543
|
-
if (s.nodeType === 1) {
|
544
|
-
if (s.hasAttributes()) {
|
545
|
-
const h = [];
|
546
|
-
for (const c of s.getAttributeNames())
|
547
|
-
if (c.endsWith(vt) || c.startsWith(b)) {
|
548
|
-
const p = u[r++];
|
549
|
-
if (h.push(c), p !== void 0) {
|
550
|
-
const A = s.getAttribute(p.toLowerCase() + vt).split(b), f = /([.?@])?(.*)/.exec(p);
|
551
|
-
l.push({ type: 1, index: o, name: f[2], strings: A, ctor: f[1] === "." ? ye : f[1] === "?" ? Ee : f[1] === "@" ? be : Q });
|
552
|
-
} else
|
553
|
-
l.push({ type: 6, index: o });
|
554
|
-
}
|
555
|
-
for (const c of h)
|
556
|
-
s.removeAttribute(c);
|
557
|
-
}
|
558
|
-
if (Yt.test(s.tagName)) {
|
559
|
-
const h = s.textContent.split(b), c = h.length - 1;
|
560
|
-
if (c > 0) {
|
561
|
-
s.textContent = N ? N.emptyScript : "";
|
562
|
-
for (let p = 0; p < c; p++)
|
563
|
-
s.append(h[p], B()), U.nextNode(), l.push({ type: 2, index: ++o });
|
564
|
-
s.append(h[c], B());
|
565
|
-
}
|
566
|
-
}
|
567
|
-
} else if (s.nodeType === 8)
|
568
|
-
if (s.data === Gt)
|
569
|
-
l.push({ type: 2, index: o });
|
570
|
-
else {
|
571
|
-
let h = -1;
|
572
|
-
for (; (h = s.data.indexOf(b, h + 1)) !== -1; )
|
573
|
-
l.push({ type: 7, index: o }), h += b.length - 1;
|
574
|
-
}
|
575
|
-
o++;
|
576
|
-
}
|
577
|
-
}
|
578
|
-
static createElement(t, e) {
|
579
|
-
const i = R.createElement("template");
|
580
|
-
return i.innerHTML = t, i;
|
581
|
-
}
|
582
|
-
}
|
583
|
-
function k(n, t, e = n, i) {
|
584
|
-
var s, o, r, d;
|
585
|
-
if (t === I)
|
586
|
-
return t;
|
587
|
-
let l = i !== void 0 ? (s = e._$Co) === null || s === void 0 ? void 0 : s[i] : e._$Cl;
|
588
|
-
const a = z(t) ? void 0 : t._$litDirective$;
|
589
|
-
return (l == null ? void 0 : l.constructor) !== a && ((o = l == null ? void 0 : l._$AO) === null || o === void 0 || o.call(l, !1), a === void 0 ? l = void 0 : (l = new a(n), l._$AT(n, e, i)), i !== void 0 ? ((r = (d = e)._$Co) !== null && r !== void 0 ? r : d._$Co = [])[i] = l : e._$Cl = l), l !== void 0 && (t = k(n, l._$AS(n, t.values), l, i)), t;
|
590
|
-
}
|
591
|
-
class fe {
|
592
|
-
constructor(t, e) {
|
593
|
-
this._$AV = [], this._$AN = void 0, this._$AD = t, this._$AM = e;
|
594
|
-
}
|
595
|
-
get parentNode() {
|
596
|
-
return this._$AM.parentNode;
|
597
|
-
}
|
598
|
-
get _$AU() {
|
599
|
-
return this._$AM._$AU;
|
600
|
-
}
|
601
|
-
u(t) {
|
602
|
-
var e;
|
603
|
-
const { el: { content: i }, parts: s } = this._$AD, o = ((e = t == null ? void 0 : t.creationScope) !== null && e !== void 0 ? e : R).importNode(i, !0);
|
604
|
-
U.currentNode = o;
|
605
|
-
let r = U.nextNode(), d = 0, l = 0, a = s[0];
|
606
|
-
for (; a !== void 0; ) {
|
607
|
-
if (d === a.index) {
|
608
|
-
let u;
|
609
|
-
a.type === 2 ? u = new q(r, r.nextSibling, this, t) : a.type === 1 ? u = new a.ctor(r, a.name, a.strings, this, t) : a.type === 6 && (u = new we(r, this, t)), this._$AV.push(u), a = s[++l];
|
610
|
-
}
|
611
|
-
d !== (a == null ? void 0 : a.index) && (r = U.nextNode(), d++);
|
612
|
-
}
|
613
|
-
return U.currentNode = R, o;
|
614
|
-
}
|
615
|
-
v(t) {
|
616
|
-
let e = 0;
|
617
|
-
for (const i of this._$AV)
|
618
|
-
i !== void 0 && (i.strings !== void 0 ? (i._$AI(t, i, e), e += i.strings.length - 2) : i._$AI(t[e])), e++;
|
619
|
-
}
|
620
|
-
}
|
621
|
-
class q {
|
622
|
-
constructor(t, e, i, s) {
|
623
|
-
var o;
|
624
|
-
this.type = 2, this._$AH = _, this._$AN = void 0, this._$AA = t, this._$AB = e, this._$AM = i, this.options = s, this._$Cp = (o = s == null ? void 0 : s.isConnected) === null || o === void 0 || o;
|
625
|
-
}
|
626
|
-
get _$AU() {
|
627
|
-
var t, e;
|
628
|
-
return (e = (t = this._$AM) === null || t === void 0 ? void 0 : t._$AU) !== null && e !== void 0 ? e : this._$Cp;
|
629
|
-
}
|
630
|
-
get parentNode() {
|
631
|
-
let t = this._$AA.parentNode;
|
632
|
-
const e = this._$AM;
|
633
|
-
return e !== void 0 && (t == null ? void 0 : t.nodeType) === 11 && (t = e.parentNode), t;
|
634
|
-
}
|
635
|
-
get startNode() {
|
636
|
-
return this._$AA;
|
637
|
-
}
|
638
|
-
get endNode() {
|
639
|
-
return this._$AB;
|
640
|
-
}
|
641
|
-
_$AI(t, e = this) {
|
642
|
-
t = k(this, t, e), z(t) ? t === _ || t == null || t === "" ? (this._$AH !== _ && this._$AR(), this._$AH = _) : t !== this._$AH && t !== I && this._(t) : t._$litType$ !== void 0 ? this.g(t) : t.nodeType !== void 0 ? this.$(t) : _e(t) ? this.T(t) : this._(t);
|
643
|
-
}
|
644
|
-
k(t) {
|
645
|
-
return this._$AA.parentNode.insertBefore(t, this._$AB);
|
646
|
-
}
|
647
|
-
$(t) {
|
648
|
-
this._$AH !== t && (this._$AR(), this._$AH = this.k(t));
|
649
|
-
}
|
650
|
-
_(t) {
|
651
|
-
this._$AH !== _ && z(this._$AH) ? this._$AA.nextSibling.data = t : this.$(R.createTextNode(t)), this._$AH = t;
|
652
|
-
}
|
653
|
-
g(t) {
|
654
|
-
var e;
|
655
|
-
const { values: i, _$litType$: s } = t, o = typeof s == "number" ? this._$AC(t) : (s.el === void 0 && (s.el = W.createElement(s.h, this.options)), s);
|
656
|
-
if (((e = this._$AH) === null || e === void 0 ? void 0 : e._$AD) === o)
|
657
|
-
this._$AH.v(i);
|
658
|
-
else {
|
659
|
-
const r = new fe(o, this), d = r.u(this.options);
|
660
|
-
r.v(i), this.$(d), this._$AH = r;
|
661
|
-
}
|
662
|
-
}
|
663
|
-
_$AC(t) {
|
664
|
-
let e = kt.get(t.strings);
|
665
|
-
return e === void 0 && kt.set(t.strings, e = new W(t)), e;
|
666
|
-
}
|
667
|
-
T(t) {
|
668
|
-
Xt(this._$AH) || (this._$AH = [], this._$AR());
|
669
|
-
const e = this._$AH;
|
670
|
-
let i, s = 0;
|
671
|
-
for (const o of t)
|
672
|
-
s === e.length ? e.push(i = new q(this.k(B()), this.k(B()), this, this.options)) : i = e[s], i._$AI(o), s++;
|
673
|
-
s < e.length && (this._$AR(i && i._$AB.nextSibling, s), e.length = s);
|
674
|
-
}
|
675
|
-
_$AR(t = this._$AA.nextSibling, e) {
|
676
|
-
var i;
|
677
|
-
for ((i = this._$AP) === null || i === void 0 || i.call(this, !1, !0, e); t && t !== this._$AB; ) {
|
678
|
-
const s = t.nextSibling;
|
679
|
-
t.remove(), t = s;
|
680
|
-
}
|
681
|
-
}
|
682
|
-
setConnected(t) {
|
683
|
-
var e;
|
684
|
-
this._$AM === void 0 && (this._$Cp = t, (e = this._$AP) === null || e === void 0 || e.call(this, t));
|
685
|
-
}
|
686
|
-
}
|
687
|
-
class Q {
|
688
|
-
constructor(t, e, i, s, o) {
|
689
|
-
this.type = 1, this._$AH = _, this._$AN = void 0, this.element = t, this.name = e, this._$AM = s, this.options = o, i.length > 2 || i[0] !== "" || i[1] !== "" ? (this._$AH = Array(i.length - 1).fill(new String()), this.strings = i) : this._$AH = _;
|
690
|
-
}
|
691
|
-
get tagName() {
|
692
|
-
return this.element.tagName;
|
693
|
-
}
|
694
|
-
get _$AU() {
|
695
|
-
return this._$AM._$AU;
|
696
|
-
}
|
697
|
-
_$AI(t, e = this, i, s) {
|
698
|
-
const o = this.strings;
|
699
|
-
let r = !1;
|
700
|
-
if (o === void 0)
|
701
|
-
t = k(this, t, e, 0), r = !z(t) || t !== this._$AH && t !== I, r && (this._$AH = t);
|
702
|
-
else {
|
703
|
-
const d = t;
|
704
|
-
let l, a;
|
705
|
-
for (t = o[0], l = 0; l < o.length - 1; l++)
|
706
|
-
a = k(this, d[i + l], e, l), a === I && (a = this._$AH[l]), r || (r = !z(a) || a !== this._$AH[l]), a === _ ? t = _ : t !== _ && (t += (a ?? "") + o[l + 1]), this._$AH[l] = a;
|
707
|
-
}
|
708
|
-
r && !s && this.j(t);
|
709
|
-
}
|
710
|
-
j(t) {
|
711
|
-
t === _ ? this.element.removeAttribute(this.name) : this.element.setAttribute(this.name, t ?? "");
|
712
|
-
}
|
713
|
-
}
|
714
|
-
class ye extends Q {
|
715
|
-
constructor() {
|
716
|
-
super(...arguments), this.type = 3;
|
717
|
-
}
|
718
|
-
j(t) {
|
719
|
-
this.element[this.name] = t === _ ? void 0 : t;
|
720
|
-
}
|
721
|
-
}
|
722
|
-
const Ae = N ? N.emptyScript : "";
|
723
|
-
class Ee extends Q {
|
724
|
-
constructor() {
|
725
|
-
super(...arguments), this.type = 4;
|
726
|
-
}
|
727
|
-
j(t) {
|
728
|
-
t && t !== _ ? this.element.setAttribute(this.name, Ae) : this.element.removeAttribute(this.name);
|
729
|
-
}
|
730
|
-
}
|
731
|
-
class be extends Q {
|
732
|
-
constructor(t, e, i, s, o) {
|
733
|
-
super(t, e, i, s, o), this.type = 5;
|
734
|
-
}
|
735
|
-
_$AI(t, e = this) {
|
736
|
-
var i;
|
737
|
-
if ((t = (i = k(this, t, e, 0)) !== null && i !== void 0 ? i : _) === I)
|
738
|
-
return;
|
739
|
-
const s = this._$AH, o = t === _ && s !== _ || t.capture !== s.capture || t.once !== s.once || t.passive !== s.passive, r = t !== _ && (s === _ || o);
|
740
|
-
o && this.element.removeEventListener(this.name, this, s), r && this.element.addEventListener(this.name, this, t), this._$AH = t;
|
741
|
-
}
|
742
|
-
handleEvent(t) {
|
743
|
-
var e, i;
|
744
|
-
typeof this._$AH == "function" ? this._$AH.call((i = (e = this.options) === null || e === void 0 ? void 0 : e.host) !== null && i !== void 0 ? i : this.element, t) : this._$AH.handleEvent(t);
|
745
|
-
}
|
746
|
-
}
|
747
|
-
class we {
|
748
|
-
constructor(t, e, i) {
|
749
|
-
this.element = t, this.type = 6, this._$AN = void 0, this._$AM = e, this.options = i;
|
750
|
-
}
|
751
|
-
get _$AU() {
|
752
|
-
return this._$AM._$AU;
|
753
|
-
}
|
754
|
-
_$AI(t) {
|
755
|
-
k(this, t);
|
756
|
-
}
|
757
|
-
}
|
758
|
-
const Vt = X.litHtmlPolyfillSupport;
|
759
|
-
Vt == null || Vt(W, q), ((rt = X.litHtmlVersions) !== null && rt !== void 0 ? rt : X.litHtmlVersions = []).push("2.7.4");
|
760
|
-
const Se = (n, t, e) => {
|
761
|
-
var i, s;
|
762
|
-
const o = (i = e == null ? void 0 : e.renderBefore) !== null && i !== void 0 ? i : t;
|
763
|
-
let r = o._$litPart$;
|
764
|
-
if (r === void 0) {
|
765
|
-
const d = (s = e == null ? void 0 : e.renderBefore) !== null && s !== void 0 ? s : null;
|
766
|
-
o._$litPart$ = r = new q(t.insertBefore(B(), d), d, void 0, e ?? {});
|
767
|
-
}
|
768
|
-
return r._$AI(n), r;
|
769
|
-
};
|
770
|
-
/**
|
771
|
-
* @license
|
772
|
-
* Copyright 2017 Google LLC
|
773
|
-
* SPDX-License-Identifier: BSD-3-Clause
|
774
|
-
*/
|
775
|
-
var lt, at;
|
776
|
-
class L extends T {
|
777
|
-
constructor() {
|
778
|
-
super(...arguments), this.renderOptions = { host: this }, this._$Do = void 0;
|
779
|
-
}
|
780
|
-
createRenderRoot() {
|
781
|
-
var t, e;
|
782
|
-
const i = super.createRenderRoot();
|
783
|
-
return (t = (e = this.renderOptions).renderBefore) !== null && t !== void 0 || (e.renderBefore = i.firstChild), i;
|
784
|
-
}
|
785
|
-
update(t) {
|
786
|
-
const e = this.render();
|
787
|
-
this.hasUpdated || (this.renderOptions.isConnected = this.isConnected), super.update(t), this._$Do = Se(e, this.renderRoot, this.renderOptions);
|
788
|
-
}
|
789
|
-
connectedCallback() {
|
790
|
-
var t;
|
791
|
-
super.connectedCallback(), (t = this._$Do) === null || t === void 0 || t.setConnected(!0);
|
792
|
-
}
|
793
|
-
disconnectedCallback() {
|
794
|
-
var t;
|
795
|
-
super.disconnectedCallback(), (t = this._$Do) === null || t === void 0 || t.setConnected(!1);
|
796
|
-
}
|
797
|
-
render() {
|
798
|
-
return I;
|
799
|
-
}
|
800
|
-
}
|
801
|
-
L.finalized = !0, L._$litElement$ = !0, (lt = globalThis.litElementHydrateSupport) === null || lt === void 0 || lt.call(globalThis, { LitElement: L });
|
802
|
-
const Ot = globalThis.litElementPolyfillSupport;
|
803
|
-
Ot == null || Ot({ LitElement: L });
|
804
|
-
((at = globalThis.litElementVersions) !== null && at !== void 0 ? at : globalThis.litElementVersions = []).push("3.3.2");
|
805
|
-
function Pe(n, t, e) {
|
806
|
-
function i(s) {
|
807
|
-
e.dispatchEvent(new CustomEvent(s.type, s));
|
808
|
-
}
|
809
|
-
return t.addEventListener(n, i), () => {
|
810
|
-
t.removeEventListener(n, i);
|
9
|
+
import { styleMap } from "lit/directives/style-map.js";
|
10
|
+
import { classMap } from "lit/directives/class-map.js";
|
11
|
+
import "@a11y/focus-trap";
|
12
|
+
function forwardEvent(type2, fromElement, toElement) {
|
13
|
+
function forwarder(event) {
|
14
|
+
toElement.dispatchEvent(new CustomEvent(event.type, event));
|
15
|
+
}
|
16
|
+
fromElement.addEventListener(type2, forwarder);
|
17
|
+
return () => {
|
18
|
+
fromElement.removeEventListener(type2, forwarder);
|
811
19
|
};
|
812
20
|
}
|
813
|
-
class
|
814
|
-
constructor(
|
815
|
-
this._events = []
|
21
|
+
class EventForwardController {
|
22
|
+
constructor(host, events) {
|
23
|
+
this._events = [];
|
24
|
+
this._cleanup = [];
|
25
|
+
this._forwardElementRef = createRef();
|
26
|
+
this.host = host;
|
27
|
+
this._events = events;
|
28
|
+
host.addController(this);
|
816
29
|
}
|
817
30
|
register() {
|
818
|
-
return
|
31
|
+
return ref(this._forwardElementRef);
|
819
32
|
}
|
820
33
|
hostConnected() {
|
821
34
|
requestAnimationFrame(() => {
|
822
|
-
this._events.forEach((
|
823
|
-
|
35
|
+
this._events.forEach((event) => {
|
36
|
+
if (this._forwardElementRef.value) {
|
37
|
+
this._cleanup.push(forwardEvent(event, this._forwardElementRef.value, this.host));
|
38
|
+
}
|
824
39
|
});
|
825
40
|
});
|
826
41
|
}
|
827
42
|
hostDisconnected() {
|
828
|
-
this._cleanup.forEach((
|
829
|
-
|
830
|
-
})
|
43
|
+
this._cleanup.forEach((fn) => {
|
44
|
+
fn();
|
45
|
+
});
|
46
|
+
this._cleanup = [];
|
831
47
|
}
|
832
48
|
}
|
833
|
-
const
|
834
|
-
|
835
|
-
|
836
|
-
|
837
|
-
|
49
|
+
const devVideoUrl = "https://d2rxhdlm2q91uk.cloudfront.net";
|
50
|
+
const stagingVideoUrl = "https://d1ix11aj5kfygl.cloudfront.net";
|
51
|
+
const prodVideoUrl = "https://d157jlwnudd93d.cloudfront.net";
|
52
|
+
const devPublicApiUrl = "https://bshyfw4h5a.execute-api.ap-southeast-2.amazonaws.com/dev";
|
53
|
+
const stagingPublicApiUrl = "https://gyzw7rpbq3.execute-api.ap-southeast-2.amazonaws.com/staging";
|
54
|
+
const prodPublicApiUrl = "https://vfcjuim1l3.execute-api.ap-southeast-2.amazonaws.com/prod";
|
55
|
+
const localEmbedApiUrl = "http://localhost:6060/v2";
|
56
|
+
const devEmbedApiUrl = "https://embed-dev.vouchfor.com/v2";
|
57
|
+
const stagingEmbedApiUrl = "https://embed-staging.vouchfor.com/v2";
|
58
|
+
const prodEmbedApiUrl = "https://embed.vouchfor.com/v2";
|
59
|
+
function getEnvUrls(env) {
|
60
|
+
if (!["local", "dev", "staging", "prod"].includes(env)) {
|
61
|
+
throw new Error(`Unknown environment: ${env}`);
|
62
|
+
}
|
63
|
+
if (env === "local") {
|
64
|
+
return {
|
65
|
+
videoUrl: devVideoUrl,
|
66
|
+
publicApiUrl: devPublicApiUrl,
|
67
|
+
embedApiUrl: localEmbedApiUrl
|
68
|
+
};
|
69
|
+
}
|
70
|
+
if (env === "dev") {
|
838
71
|
return {
|
839
|
-
|
840
|
-
|
841
|
-
|
842
|
-
embedApiUrl: Ie,
|
843
|
-
publicRecorderUrl: Oe
|
72
|
+
videoUrl: devVideoUrl,
|
73
|
+
publicApiUrl: devPublicApiUrl,
|
74
|
+
embedApiUrl: devEmbedApiUrl
|
844
75
|
};
|
845
|
-
|
76
|
+
}
|
77
|
+
if (env === "staging") {
|
846
78
|
return {
|
847
|
-
|
848
|
-
|
849
|
-
|
850
|
-
embedApiUrl: ke,
|
851
|
-
publicRecorderUrl: Me
|
79
|
+
videoUrl: stagingVideoUrl,
|
80
|
+
publicApiUrl: stagingPublicApiUrl,
|
81
|
+
embedApiUrl: stagingEmbedApiUrl
|
852
82
|
};
|
853
|
-
|
83
|
+
}
|
84
|
+
if (env === "prod") {
|
854
85
|
return {
|
855
|
-
|
856
|
-
|
857
|
-
|
858
|
-
embedApiUrl: Ve,
|
859
|
-
publicRecorderUrl: Le
|
86
|
+
videoUrl: prodVideoUrl,
|
87
|
+
publicApiUrl: prodPublicApiUrl,
|
88
|
+
embedApiUrl: prodEmbedApiUrl
|
860
89
|
};
|
90
|
+
}
|
861
91
|
}
|
862
|
-
class
|
863
|
-
constructor(
|
864
|
-
this.
|
92
|
+
class FetcherController {
|
93
|
+
constructor(host) {
|
94
|
+
this._fetching = false;
|
95
|
+
this.getVouch = async (env, apiKey, vouchId) => {
|
96
|
+
var _a;
|
97
|
+
const { embedApiUrl } = getEnvUrls(env);
|
98
|
+
const cacheCheck = v4();
|
99
|
+
const res = await fetch(`${embedApiUrl}/vouches/${vouchId}`, {
|
100
|
+
method: "GET",
|
101
|
+
headers: [
|
102
|
+
["X-Api-Key", apiKey],
|
103
|
+
["X-Cache-Check", cacheCheck]
|
104
|
+
]
|
105
|
+
});
|
106
|
+
const vouch = await res.json();
|
107
|
+
this.host.dispatchEvent(new CustomEvent("vouch:loaded", { detail: vouch == null ? void 0 : vouch.id }));
|
108
|
+
const resCacheCheck = (_a = res == null ? void 0 : res.headers) == null ? void 0 : _a.get("X-Cache-Check");
|
109
|
+
if (resCacheCheck !== cacheCheck) {
|
110
|
+
fetch(`${embedApiUrl}/vouches/${vouchId}`, {
|
111
|
+
method: "GET",
|
112
|
+
headers: [
|
113
|
+
["X-Api-Key", apiKey],
|
114
|
+
["Cache-Control", "max-age=0"]
|
115
|
+
]
|
116
|
+
});
|
117
|
+
}
|
118
|
+
return vouch;
|
119
|
+
};
|
120
|
+
this.getTemplate = async (env, apiKey, templateId) => {
|
121
|
+
var _a;
|
122
|
+
const { embedApiUrl } = getEnvUrls(env);
|
123
|
+
const cacheCheck = v4();
|
124
|
+
const res = await fetch(`${embedApiUrl}/templates/${templateId}`, {
|
125
|
+
method: "GET",
|
126
|
+
headers: [
|
127
|
+
["X-Api-Key", apiKey],
|
128
|
+
["X-Cache-Check", cacheCheck]
|
129
|
+
]
|
130
|
+
});
|
131
|
+
const template = await res.json();
|
132
|
+
const resCacheCheck = (_a = res == null ? void 0 : res.headers) == null ? void 0 : _a.get("X-Cache-Check");
|
133
|
+
if (resCacheCheck !== cacheCheck) {
|
134
|
+
fetch(`${embedApiUrl}/templates/${templateId}`, {
|
135
|
+
method: "GET",
|
136
|
+
headers: [
|
137
|
+
["X-Api-Key", apiKey],
|
138
|
+
["Cache-Control", "max-age=0"]
|
139
|
+
]
|
140
|
+
});
|
141
|
+
}
|
142
|
+
return template;
|
143
|
+
};
|
144
|
+
this.host = host;
|
145
|
+
new Task(
|
865
146
|
this.host,
|
866
|
-
async ([
|
867
|
-
var
|
147
|
+
async ([env, apiKey, data, vouchId, templateId]) => {
|
148
|
+
var _a, _b, _c, _d;
|
868
149
|
try {
|
869
|
-
|
870
|
-
|
871
|
-
|
872
|
-
|
873
|
-
|
874
|
-
|
875
|
-
|
150
|
+
host.vouch = void 0;
|
151
|
+
host.template = void 0;
|
152
|
+
if (data) {
|
153
|
+
let template;
|
154
|
+
if (templateId) {
|
155
|
+
this.fetching = true;
|
156
|
+
template = await this.getTemplate(env, apiKey, templateId);
|
157
|
+
}
|
158
|
+
this._vouch = data;
|
159
|
+
host.template = template ?? ((_b = (_a = data == null ? void 0 : data.settings) == null ? void 0 : _a.template) == null ? void 0 : _b.instance);
|
160
|
+
} else if (vouchId) {
|
161
|
+
this.fetching = true;
|
162
|
+
const [vouch, template] = await Promise.all([
|
163
|
+
this.getVouch(env, apiKey, vouchId),
|
164
|
+
templateId ? this.getTemplate(env, apiKey, templateId) : null
|
165
|
+
]);
|
166
|
+
this._vouch = vouch;
|
167
|
+
host.template = template ?? ((_d = (_c = vouch == null ? void 0 : vouch.settings) == null ? void 0 : _c.template) == null ? void 0 : _d.instance);
|
876
168
|
}
|
877
169
|
} finally {
|
878
|
-
|
170
|
+
this.fetching = false;
|
879
171
|
}
|
880
172
|
},
|
881
|
-
() => [
|
173
|
+
() => [host.env, host.apiKey, host.data, host.vouchId, host.templateId]
|
174
|
+
);
|
175
|
+
new Task(
|
176
|
+
this.host,
|
177
|
+
([vouch, questions]) => {
|
178
|
+
host.vouch = vouch ? {
|
179
|
+
...vouch,
|
180
|
+
questions: {
|
181
|
+
items: vouch == null ? void 0 : vouch.questions.items.filter((_, index) => !(questions == null ? void 0 : questions.length) || (questions == null ? void 0 : questions.includes(index + 1)))
|
182
|
+
}
|
183
|
+
} : void 0;
|
184
|
+
},
|
185
|
+
() => [this._vouch, host.questions]
|
882
186
|
);
|
883
187
|
}
|
188
|
+
set fetching(value) {
|
189
|
+
if (this._fetching !== value) {
|
190
|
+
this._fetching = value;
|
191
|
+
this.host.requestUpdate();
|
192
|
+
}
|
193
|
+
}
|
194
|
+
get fetching() {
|
195
|
+
return this._fetching;
|
196
|
+
}
|
884
197
|
}
|
885
|
-
|
886
|
-
const
|
887
|
-
|
888
|
-
|
889
|
-
|
890
|
-
|
198
|
+
const name = "@vouchfor/embeds";
|
199
|
+
const version = "0.0.0-experiment.f0c2382";
|
200
|
+
const license = "MIT";
|
201
|
+
const author = "Aaron Williams";
|
202
|
+
const main = "dist/es/embeds.js";
|
203
|
+
const module = "dist/es/embeds.js";
|
204
|
+
const type = "module";
|
205
|
+
const types = "dist/es/src/index.d.ts";
|
206
|
+
const exports = {
|
207
|
+
".": "./dist/es/embeds.js"
|
208
|
+
};
|
209
|
+
const files = [
|
210
|
+
"dist",
|
211
|
+
"src"
|
212
|
+
];
|
213
|
+
const publishConfig = {
|
214
|
+
tag: "experiment",
|
215
|
+
access: "public"
|
216
|
+
};
|
217
|
+
const engines = {
|
218
|
+
node: ">=18.18.0"
|
219
|
+
};
|
220
|
+
const scripts = {
|
221
|
+
build: "rm -rf dist && tsc && yarn build:self",
|
222
|
+
"build:deps": "yarn --cwd ../media-player build",
|
223
|
+
"build:self": "vite build --mode iife && vite build --mode es && node scripts/build.cjs",
|
224
|
+
"build:package": "yarn build",
|
225
|
+
"build:storybook": "yarn prebuild && storybook build",
|
226
|
+
"generate:manifest": "wca src --outFile custom-elements.json",
|
227
|
+
lint: "eslint . --quiet",
|
228
|
+
"lint:fix": "eslint . --fix",
|
229
|
+
"lint:staged": "lint-staged",
|
230
|
+
prepublishOnly: "yarn build",
|
231
|
+
size: "size-limit",
|
232
|
+
storybook: "yarn prebuild && storybook dev -p 6007",
|
233
|
+
prebuild: "yarn build:deps && yarn generate:manifest",
|
234
|
+
test: "rm -rf test/lib && yarn prebuild && vite build --mode test && web-test-runner",
|
235
|
+
"test:ci": "yarn test --config web-test-runner.ci.config.js",
|
236
|
+
"test:watch": "yarn test --watch"
|
237
|
+
};
|
238
|
+
const dependencies = {
|
239
|
+
"@a11y/focus-trap": "^1.0.5",
|
240
|
+
"@lit/task": "^1.0.0",
|
241
|
+
"@vouchfor/canvas-video": "0.0.0-experiment.f0c2382",
|
242
|
+
"@vouchfor/media-player": "0.0.0-experiment.f0c2382",
|
243
|
+
uuid: "^9.0.1"
|
244
|
+
};
|
245
|
+
const peerDependencies = {
|
246
|
+
lit: "^3.1.2"
|
247
|
+
};
|
248
|
+
const devDependencies = {
|
249
|
+
"@esm-bundle/chai": "^4.3.4-fix.0",
|
250
|
+
"@open-wc/testing": "^4.0.0",
|
251
|
+
"@storybook/addon-essentials": "^8.0.4",
|
252
|
+
"@storybook/addon-links": "^8.0.4",
|
253
|
+
"@storybook/blocks": "^8.0.4",
|
254
|
+
"@storybook/web-components": "^8.0.4",
|
255
|
+
"@storybook/web-components-vite": "^8.0.4",
|
256
|
+
"@svgr/core": "^8.1.0",
|
257
|
+
"@types/flat": "^5.0.5",
|
258
|
+
"@types/mocha": "^10.0.6",
|
259
|
+
"@vouchfor/eslint-config": "^1.0.1",
|
260
|
+
"@vouchfor/prettier-config": "^1.0.1",
|
261
|
+
"@vouchfor/video-utils": "0.0.0-experiment.f0c2382",
|
262
|
+
"@web/dev-server-esbuild": "^1.0.2",
|
263
|
+
"@web/test-runner": "^0.18.1",
|
264
|
+
"@web/test-runner-browserstack": "^0.7.1",
|
265
|
+
"@web/test-runner-mocha": "^0.9.0",
|
266
|
+
"@web/test-runner-playwright": "^0.11.0",
|
267
|
+
glob: "^10.3.10",
|
268
|
+
"lint-staged": "^15.2.2",
|
269
|
+
lit: "^3.1.2",
|
270
|
+
lodash: "^4.17.21",
|
271
|
+
react: "^18.2.0",
|
272
|
+
"react-dom": "^18.2.0",
|
273
|
+
"rollup-plugin-tla": "^0.0.2",
|
274
|
+
sinon: "^17.0.1",
|
275
|
+
storybook: "^8.0.4",
|
276
|
+
svgson: "^5.3.1",
|
277
|
+
typescript: "^5.4.3",
|
278
|
+
vite: "^5.2.2",
|
279
|
+
"vite-plugin-commonjs": "^0.10.1",
|
280
|
+
"vite-plugin-dts": "^3.7.3",
|
281
|
+
"web-component-analyzer": "^2.0.0"
|
282
|
+
};
|
283
|
+
const packageJson = {
|
284
|
+
name,
|
285
|
+
version,
|
286
|
+
license,
|
287
|
+
author,
|
288
|
+
main,
|
289
|
+
module,
|
290
|
+
type,
|
291
|
+
types,
|
292
|
+
exports,
|
293
|
+
files,
|
294
|
+
publishConfig,
|
295
|
+
engines,
|
296
|
+
scripts,
|
297
|
+
"lint-staged": {
|
298
|
+
"**/*.{ts,tsx,js}": "eslint --fix --quiet",
|
299
|
+
"**/*.{md,json,yml}": "prettier --write"
|
300
|
+
},
|
301
|
+
dependencies,
|
302
|
+
peerDependencies,
|
303
|
+
devDependencies
|
304
|
+
};
|
305
|
+
function createVisitor(env) {
|
306
|
+
const { publicApiUrl } = getEnvUrls(env);
|
307
|
+
const visitorId = v4();
|
308
|
+
navigator.sendBeacon(`${publicApiUrl}/api/visitor`, JSON.stringify({ visitorId }));
|
309
|
+
return visitorId;
|
891
310
|
}
|
892
|
-
|
893
|
-
|
894
|
-
|
895
|
-
|
896
|
-
|
311
|
+
function getUids(env) {
|
312
|
+
var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j, _k, _l;
|
313
|
+
if (typeof window === "undefined") {
|
314
|
+
return {
|
315
|
+
client: null,
|
316
|
+
tab: null,
|
317
|
+
request: v4()
|
318
|
+
};
|
319
|
+
}
|
320
|
+
let visitorId = (_b = (_a = window.localStorage) == null ? void 0 : _a.getItem) == null ? void 0 : _b.call(_a, "vouch-uid-visitor");
|
321
|
+
let clientId = (_d = (_c = window.localStorage) == null ? void 0 : _c.getItem) == null ? void 0 : _d.call(_c, "vouch-uid-client");
|
322
|
+
let tabId = (_f = (_e = window.sessionStorage) == null ? void 0 : _e.getItem) == null ? void 0 : _f.call(_e, "vouch-uid-tab");
|
323
|
+
const requestId = v4();
|
324
|
+
if (!visitorId) {
|
325
|
+
visitorId = createVisitor(env);
|
326
|
+
(_h = (_g = window.localStorage) == null ? void 0 : _g.setItem) == null ? void 0 : _h.call(_g, "vouch-uid-visitor", visitorId);
|
327
|
+
}
|
328
|
+
if (!clientId) {
|
329
|
+
clientId = v4();
|
330
|
+
(_j = (_i = window.localStorage) == null ? void 0 : _i.setItem) == null ? void 0 : _j.call(_i, "vouch-uid-client", clientId);
|
331
|
+
}
|
332
|
+
if (!tabId) {
|
333
|
+
tabId = v4();
|
334
|
+
(_l = (_k = window.sessionStorage) == null ? void 0 : _k.setItem) == null ? void 0 : _l.call(_k, "vouch-uid-tab", tabId);
|
335
|
+
}
|
336
|
+
return {
|
337
|
+
client: clientId,
|
338
|
+
tab: tabId,
|
339
|
+
request: requestId,
|
340
|
+
visitor: visitorId
|
341
|
+
};
|
897
342
|
}
|
898
|
-
|
899
|
-
|
900
|
-
|
901
|
-
function M(n, t, e) {
|
902
|
-
if (Mt.randomUUID && !t && !n)
|
903
|
-
return Mt.randomUUID();
|
904
|
-
n = n || {};
|
905
|
-
const i = n.random || (n.rng || Be)();
|
906
|
-
if (i[6] = i[6] & 15 | 64, i[8] = i[8] & 63 | 128, t) {
|
907
|
-
e = e || 0;
|
908
|
-
for (let s = 0; s < 16; ++s)
|
909
|
-
t[e + s] = i[s];
|
910
|
-
return t;
|
343
|
+
function findVouchId(payload, vouch) {
|
344
|
+
if (payload && "vouchId" in payload) {
|
345
|
+
return payload.vouchId;
|
911
346
|
}
|
912
|
-
return
|
347
|
+
return (vouch == null ? void 0 : vouch.id) ?? null;
|
348
|
+
}
|
349
|
+
function getReportingMetadata(source = "embedded_player") {
|
350
|
+
var _a, _b;
|
351
|
+
const [country, region] = ((_b = (_a = Intl.DateTimeFormat().resolvedOptions().timeZone) == null ? void 0 : _a.split) == null ? void 0 : _b.call(_a, "/")) ?? [];
|
352
|
+
const utmParams = {};
|
353
|
+
[...new URLSearchParams(location.search).entries()].forEach(([key, value]) => {
|
354
|
+
if (/utm/.test(key)) {
|
355
|
+
const param = key.toLowerCase().replace(/[-_][a-z0-9]/g, (group) => group.slice(-1).toUpperCase());
|
356
|
+
utmParams[param] = value;
|
357
|
+
}
|
358
|
+
});
|
359
|
+
return {
|
360
|
+
source,
|
361
|
+
time: /* @__PURE__ */ new Date(),
|
362
|
+
region,
|
363
|
+
country,
|
364
|
+
screenHeight: window.screen.height,
|
365
|
+
screenWidth: window.screen.width,
|
366
|
+
referrer: document.referrer,
|
367
|
+
currentUrl: location.href,
|
368
|
+
embedType: "media-player-embed",
|
369
|
+
embedVersion: packageJson.version,
|
370
|
+
templateVersion: TEMPLATE_VERSION,
|
371
|
+
...utmParams
|
372
|
+
};
|
913
373
|
}
|
914
|
-
const
|
915
|
-
class
|
916
|
-
constructor(
|
917
|
-
this.
|
918
|
-
|
919
|
-
|
920
|
-
|
921
|
-
|
922
|
-
|
923
|
-
|
924
|
-
|
925
|
-
|
926
|
-
|
927
|
-
|
374
|
+
const MINIMUM_SEND_THRESHOLD = 1;
|
375
|
+
class TrackingController {
|
376
|
+
constructor(host) {
|
377
|
+
this._batchedEvents = [];
|
378
|
+
this._hasPlayed = false;
|
379
|
+
this._hasLoaded = {};
|
380
|
+
this._answersViewed = {};
|
381
|
+
this._streamStartTime = {};
|
382
|
+
this._streamLatestTime = {};
|
383
|
+
this._currentlyPlayingVideo = null;
|
384
|
+
this._createTrackingEvent = (event, payload) => {
|
385
|
+
const vouchId = findVouchId(payload, this.host.vouch);
|
386
|
+
if (!vouchId || this.host.disableTracking) {
|
387
|
+
return;
|
388
|
+
}
|
389
|
+
this._batchedEvents.push({
|
390
|
+
event,
|
391
|
+
payload: {
|
392
|
+
...payload,
|
393
|
+
vouchId,
|
394
|
+
time: (/* @__PURE__ */ new Date()).toISOString()
|
928
395
|
}
|
929
|
-
})
|
930
|
-
|
931
|
-
|
932
|
-
|
933
|
-
|
934
|
-
|
935
|
-
|
936
|
-
|
937
|
-
|
938
|
-
|
939
|
-
...s
|
940
|
-
};
|
941
|
-
}, this._sendTrackingEvent = (e, i) => {
|
942
|
-
const { publicApiUrl: s } = _t(this.host.env), { client: o, tab: r, request: d, visitor: l } = this._getUids();
|
943
|
-
this.host.enableTracking && this.host.trackingSource && navigator.sendBeacon(
|
944
|
-
`${s}/api/events`,
|
396
|
+
});
|
397
|
+
};
|
398
|
+
this._sendTrackingEvent = () => {
|
399
|
+
if (this._batchedEvents.length <= 0) {
|
400
|
+
return;
|
401
|
+
}
|
402
|
+
const { publicApiUrl } = getEnvUrls(this.host.env);
|
403
|
+
const { client, tab, request, visitor } = getUids(this.host.env);
|
404
|
+
navigator.sendBeacon(
|
405
|
+
`${publicApiUrl}/api/batchevents`,
|
945
406
|
JSON.stringify({
|
946
|
-
|
947
|
-
|
407
|
+
payload: {
|
408
|
+
events: this._batchedEvents
|
409
|
+
},
|
948
410
|
context: {
|
949
|
-
"x-uid-client":
|
950
|
-
"x-uid-tab":
|
951
|
-
"x-uid-request":
|
952
|
-
"x-uid-visitor":
|
953
|
-
"x-reporting-metadata": this.
|
411
|
+
"x-uid-client": client,
|
412
|
+
"x-uid-tab": tab,
|
413
|
+
"x-uid-request": request,
|
414
|
+
"x-uid-visitor": visitor,
|
415
|
+
"x-reporting-metadata": getReportingMetadata(this.host.trackingSource)
|
954
416
|
}
|
955
417
|
})
|
956
418
|
);
|
957
|
-
|
958
|
-
|
959
|
-
|
960
|
-
|
961
|
-
|
962
|
-
|
963
|
-
|
964
|
-
|
965
|
-
|
966
|
-
|
967
|
-
|
968
|
-
|
969
|
-
|
970
|
-
|
971
|
-
|
972
|
-
|
973
|
-
|
974
|
-
|
975
|
-
const s = this._findVouchId();
|
976
|
-
if (!s)
|
419
|
+
this._batchedEvents = [];
|
420
|
+
};
|
421
|
+
this._streamEnded = () => {
|
422
|
+
if (this._currentlyPlayingVideo) {
|
423
|
+
const { id, key } = this._currentlyPlayingVideo;
|
424
|
+
if (this._streamLatestTime[key] > this._streamStartTime[key] + MINIMUM_SEND_THRESHOLD) {
|
425
|
+
this._createTrackingEvent("VIDEO_STREAMED", {
|
426
|
+
answerId: id,
|
427
|
+
streamStart: this._streamStartTime[key],
|
428
|
+
streamEnd: this._streamLatestTime[key]
|
429
|
+
});
|
430
|
+
}
|
431
|
+
delete this._streamStartTime[key];
|
432
|
+
delete this._streamLatestTime[key];
|
433
|
+
}
|
434
|
+
};
|
435
|
+
this._handleVouchLoaded = ({ detail: vouchId }) => {
|
436
|
+
if (!vouchId) {
|
977
437
|
return;
|
978
|
-
|
979
|
-
!this.
|
980
|
-
|
981
|
-
|
982
|
-
|
983
|
-
answerId: e,
|
984
|
-
streamStart: this._streamedTime[e],
|
985
|
-
streamEnd: i.currentTime
|
986
|
-
}), this._streamedTime[e] = i.currentTime, this._streamedPrevTimestamp[e] = o);
|
987
|
-
}, this._handleVideoPause = ({ detail: { id: e, node: i } }) => {
|
988
|
-
const s = this._findVouchId();
|
989
|
-
s && (this._sendTrackingEvent("VIDEO_STREAMED", {
|
990
|
-
vouchId: s,
|
991
|
-
answerId: e,
|
992
|
-
streamStart: this._streamedTime[e],
|
993
|
-
streamEnd: i.currentTime
|
994
|
-
}), delete this._streamedTime[e], delete this._streamedPrevTimestamp[e]);
|
995
|
-
}, this.host = t, t.addController(this);
|
996
|
-
}
|
997
|
-
_findVouchId() {
|
998
|
-
if (this.host.data)
|
999
|
-
return "uuid" in this.host.data ? this.host.data.uuid : this.host.data.id;
|
1000
|
-
}
|
1001
|
-
_getUids() {
|
1002
|
-
var o, r, d, l, a, u, h, c, p, A, f, gt;
|
1003
|
-
if (typeof window > "u")
|
1004
|
-
return {
|
1005
|
-
client: null,
|
1006
|
-
tab: null,
|
1007
|
-
request: M()
|
1008
|
-
};
|
1009
|
-
const t = this._visitorId || ((r = (o = window.localStorage) == null ? void 0 : o.getItem) == null ? void 0 : r.call(o, "vouch-uid-visitor")) || this._createVisitor(M()), e = this._clientId || ((l = (d = window.localStorage) == null ? void 0 : d.getItem) == null ? void 0 : l.call(d, "vouch-uid-client")) || M(), i = this._tabId || ((u = (a = window.sessionStorage) == null ? void 0 : a.getItem) == null ? void 0 : u.call(a, "vouch-uid-tab")) || M(), s = M();
|
1010
|
-
return t !== this._visitorId && (this._visitorId = t, (c = (h = window.localStorage) == null ? void 0 : h.setItem) == null || c.call(h, "vouch-uid-visitor", t)), e !== this._clientId && (this._clientId = e, (A = (p = window.localStorage) == null ? void 0 : p.setItem) == null || A.call(p, "vouch-uid-client", e)), i !== this._tabId && (this._tabId = i, (gt = (f = window.sessionStorage) == null ? void 0 : f.setItem) == null || gt.call(f, "vouch-uid-tab", i)), {
|
1011
|
-
client: e,
|
1012
|
-
tab: i,
|
1013
|
-
request: s,
|
1014
|
-
visitor: t
|
438
|
+
}
|
439
|
+
if (!this._hasLoaded[vouchId]) {
|
440
|
+
this._createTrackingEvent("VOUCH_LOADED", { vouchId });
|
441
|
+
this._hasLoaded[vouchId] = true;
|
442
|
+
}
|
1015
443
|
};
|
444
|
+
this._handlePlay = () => {
|
445
|
+
if (!this._hasPlayed) {
|
446
|
+
this._createTrackingEvent("VIDEO_PLAYED", {
|
447
|
+
streamStart: this.host.currentTime
|
448
|
+
});
|
449
|
+
this._hasPlayed = true;
|
450
|
+
}
|
451
|
+
};
|
452
|
+
this._handleVideoPlay = ({ detail: { id, key } }) => {
|
453
|
+
if (!this._answersViewed[key]) {
|
454
|
+
this._createTrackingEvent("VOUCH_RESPONSE_VIEWED", {
|
455
|
+
answerId: id
|
456
|
+
});
|
457
|
+
this._answersViewed[key] = true;
|
458
|
+
}
|
459
|
+
};
|
460
|
+
this._handleVideoTimeUpdate = ({ detail: { id, key, node } }) => {
|
461
|
+
if (
|
462
|
+
// We only want to count any time that the video is actually playing
|
463
|
+
!this.host.paused
|
464
|
+
) {
|
465
|
+
this._currentlyPlayingVideo = { id, key, node };
|
466
|
+
this._streamLatestTime[key] = node.currentTime;
|
467
|
+
if (!this._streamStartTime[key]) {
|
468
|
+
this._streamStartTime[key] = node.currentTime;
|
469
|
+
this._streamLatestTime[key] = node.currentTime;
|
470
|
+
}
|
471
|
+
}
|
472
|
+
};
|
473
|
+
this._handleVideoPause = ({ detail: { id, key } }) => {
|
474
|
+
if (this._streamLatestTime[key] > this._streamStartTime[key] + MINIMUM_SEND_THRESHOLD) {
|
475
|
+
this._createTrackingEvent("VIDEO_STREAMED", {
|
476
|
+
answerId: id,
|
477
|
+
streamStart: this._streamStartTime[key],
|
478
|
+
streamEnd: this._streamLatestTime[key]
|
479
|
+
});
|
480
|
+
}
|
481
|
+
delete this._streamStartTime[key];
|
482
|
+
delete this._streamLatestTime[key];
|
483
|
+
};
|
484
|
+
this._pageUnloading = () => {
|
485
|
+
this._streamEnded();
|
486
|
+
this._sendTrackingEvent();
|
487
|
+
};
|
488
|
+
this._handleVisibilityChange = () => {
|
489
|
+
if (document.visibilityState === "hidden") {
|
490
|
+
this._pageUnloading();
|
491
|
+
}
|
492
|
+
};
|
493
|
+
this._handlePageHide = () => {
|
494
|
+
this._pageUnloading();
|
495
|
+
};
|
496
|
+
this.host = host;
|
497
|
+
host.addController(this);
|
1016
498
|
}
|
1017
499
|
hostConnected() {
|
1018
|
-
|
1019
|
-
var
|
1020
|
-
|
500
|
+
requestAnimationFrame(() => {
|
501
|
+
var _a, _b, _c, _d;
|
502
|
+
if ("onvisibilitychange" in document) {
|
503
|
+
document.addEventListener("visibilitychange", this._handleVisibilityChange);
|
504
|
+
} else {
|
505
|
+
window.addEventListener("pagehide", this._handlePageHide);
|
506
|
+
}
|
507
|
+
this.host.addEventListener("vouch:loaded", this._handleVouchLoaded);
|
508
|
+
(_a = this.host.mediaPlayer) == null ? void 0 : _a.addEventListener("play", this._handlePlay);
|
509
|
+
(_b = this.host.mediaPlayer) == null ? void 0 : _b.addEventListener("video:play", this._handleVideoPlay);
|
510
|
+
(_c = this.host.mediaPlayer) == null ? void 0 : _c.addEventListener("video:pause", this._handleVideoPause);
|
511
|
+
(_d = this.host.mediaPlayer) == null ? void 0 : _d.addEventListener("video:timeupdate", this._handleVideoTimeUpdate);
|
1021
512
|
});
|
1022
513
|
}
|
1023
514
|
hostDisconnected() {
|
1024
|
-
var
|
1025
|
-
this.
|
515
|
+
var _a, _b, _c, _d;
|
516
|
+
this._pageUnloading();
|
517
|
+
if ("onvisibilitychange" in document) {
|
518
|
+
document.removeEventListener("visibilitychange", this._handleVisibilityChange);
|
519
|
+
} else {
|
520
|
+
window.removeEventListener("pagehide", this._handlePageHide);
|
521
|
+
}
|
522
|
+
this.host.removeEventListener("vouch:loaded", this._handleVouchLoaded);
|
523
|
+
(_a = this.host.mediaPlayer) == null ? void 0 : _a.removeEventListener("play", this._handlePlay);
|
524
|
+
(_b = this.host.mediaPlayer) == null ? void 0 : _b.removeEventListener("video:play", this._handleVideoPlay);
|
525
|
+
(_c = this.host.mediaPlayer) == null ? void 0 : _c.removeEventListener("video:pause", this._handleVideoPause);
|
526
|
+
(_d = this.host.mediaPlayer) == null ? void 0 : _d.removeEventListener("video:timeupdate", this._handleVideoTimeUpdate);
|
1026
527
|
}
|
1027
528
|
}
|
1028
|
-
var
|
1029
|
-
|
1030
|
-
|
1031
|
-
|
529
|
+
var __defProp$3 = Object.defineProperty;
|
530
|
+
var __getOwnPropDesc$3 = Object.getOwnPropertyDescriptor;
|
531
|
+
var __decorateClass$3 = (decorators, target, key, kind) => {
|
532
|
+
var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$3(target, key) : target;
|
533
|
+
for (var i = decorators.length - 1, decorator; i >= 0; i--)
|
534
|
+
if (decorator = decorators[i])
|
535
|
+
result = (kind ? decorator(target, key, result) : decorator(result)) || result;
|
536
|
+
if (kind && result)
|
537
|
+
__defProp$3(target, key, result);
|
538
|
+
return result;
|
1032
539
|
};
|
1033
|
-
let
|
540
|
+
let PlayerEmbed = class extends LitElement {
|
1034
541
|
constructor() {
|
1035
|
-
super(...arguments)
|
542
|
+
super(...arguments);
|
543
|
+
this.env = "prod";
|
544
|
+
this.apiKey = "";
|
545
|
+
this.disableTracking = false;
|
546
|
+
this.trackingSource = "embedded_player";
|
547
|
+
this.preload = "auto";
|
548
|
+
this.autoplay = false;
|
549
|
+
this.aspectRatio = 0;
|
550
|
+
this.eventController = new EventForwardController(this, [
|
1036
551
|
"durationchange",
|
1037
552
|
"ended",
|
1038
553
|
"error",
|
@@ -1043,12 +558,15 @@ let m = class extends L {
|
|
1043
558
|
"playing",
|
1044
559
|
"ratechange",
|
1045
560
|
"scenechange",
|
561
|
+
"scenesupdate",
|
1046
562
|
"seeking",
|
1047
563
|
"seeked",
|
1048
564
|
"timeupdate",
|
1049
565
|
"volumechange",
|
566
|
+
"processing",
|
1050
567
|
"waiting",
|
1051
568
|
"video:loadeddata",
|
569
|
+
"video:seeking",
|
1052
570
|
"video:seeked",
|
1053
571
|
"video:play",
|
1054
572
|
"video:playing",
|
@@ -1057,150 +575,573 @@ let m = class extends L {
|
|
1057
575
|
"video:timeupdate",
|
1058
576
|
"video:ended",
|
1059
577
|
"video:error"
|
1060
|
-
])
|
578
|
+
]);
|
579
|
+
this._fetcherController = new FetcherController(this);
|
580
|
+
this._trackingController = new TrackingController(this);
|
581
|
+
this._mediaPlayerRef = createRef();
|
582
|
+
}
|
583
|
+
get fetching() {
|
584
|
+
return this._fetcherController.fetching;
|
1061
585
|
}
|
1062
586
|
get waiting() {
|
1063
|
-
var
|
1064
|
-
return (
|
587
|
+
var _a;
|
588
|
+
return (_a = this._mediaPlayerRef.value) == null ? void 0 : _a.waiting;
|
589
|
+
}
|
590
|
+
get initialised() {
|
591
|
+
var _a;
|
592
|
+
return (_a = this._mediaPlayerRef.value) == null ? void 0 : _a.initialised;
|
1065
593
|
}
|
1066
594
|
get seeking() {
|
1067
|
-
var
|
1068
|
-
return (
|
595
|
+
var _a;
|
596
|
+
return (_a = this._mediaPlayerRef.value) == null ? void 0 : _a.seeking;
|
1069
597
|
}
|
1070
598
|
get paused() {
|
1071
|
-
var
|
1072
|
-
return (
|
599
|
+
var _a;
|
600
|
+
return (_a = this._mediaPlayerRef.value) == null ? void 0 : _a.paused;
|
1073
601
|
}
|
1074
602
|
get captions() {
|
1075
|
-
var
|
1076
|
-
return (
|
603
|
+
var _a;
|
604
|
+
return (_a = this._mediaPlayerRef.value) == null ? void 0 : _a.captions;
|
1077
605
|
}
|
1078
606
|
get fullscreen() {
|
1079
|
-
var
|
1080
|
-
return (
|
607
|
+
var _a;
|
608
|
+
return (_a = this._mediaPlayerRef.value) == null ? void 0 : _a.fullscreen;
|
1081
609
|
}
|
1082
610
|
get duration() {
|
1083
|
-
var
|
1084
|
-
return (
|
611
|
+
var _a;
|
612
|
+
return (_a = this._mediaPlayerRef.value) == null ? void 0 : _a.duration;
|
1085
613
|
}
|
1086
|
-
set currentTime(
|
1087
|
-
|
614
|
+
set currentTime(value) {
|
615
|
+
if (this._mediaPlayerRef.value) {
|
616
|
+
this._mediaPlayerRef.value.currentTime = value;
|
617
|
+
}
|
1088
618
|
}
|
1089
619
|
get currentTime() {
|
1090
|
-
var
|
1091
|
-
return ((
|
620
|
+
var _a;
|
621
|
+
return ((_a = this._mediaPlayerRef.value) == null ? void 0 : _a.currentTime) ?? 0;
|
1092
622
|
}
|
1093
|
-
set playbackRate(
|
1094
|
-
|
623
|
+
set playbackRate(value) {
|
624
|
+
if (this._mediaPlayerRef.value) {
|
625
|
+
this._mediaPlayerRef.value.playbackRate = value;
|
626
|
+
}
|
1095
627
|
}
|
1096
628
|
get playbackRate() {
|
1097
|
-
var
|
1098
|
-
return ((
|
629
|
+
var _a;
|
630
|
+
return ((_a = this._mediaPlayerRef.value) == null ? void 0 : _a.playbackRate) ?? 1;
|
1099
631
|
}
|
1100
|
-
set volume(
|
1101
|
-
|
632
|
+
set volume(value) {
|
633
|
+
if (this._mediaPlayerRef.value) {
|
634
|
+
this._mediaPlayerRef.value.volume = value;
|
635
|
+
}
|
1102
636
|
}
|
1103
637
|
get volume() {
|
1104
|
-
var
|
1105
|
-
return ((
|
638
|
+
var _a;
|
639
|
+
return ((_a = this._mediaPlayerRef.value) == null ? void 0 : _a.volume) ?? 1;
|
1106
640
|
}
|
1107
|
-
set muted(
|
1108
|
-
|
641
|
+
set muted(value) {
|
642
|
+
if (this._mediaPlayerRef.value) {
|
643
|
+
this._mediaPlayerRef.value.muted = value;
|
644
|
+
}
|
1109
645
|
}
|
1110
646
|
get muted() {
|
1111
|
-
var
|
1112
|
-
return ((
|
1113
|
-
}
|
1114
|
-
get scene() {
|
1115
|
-
|
1116
|
-
|
1117
|
-
|
1118
|
-
|
1119
|
-
|
1120
|
-
|
1121
|
-
|
647
|
+
var _a;
|
648
|
+
return ((_a = this._mediaPlayerRef.value) == null ? void 0 : _a.muted) ?? false;
|
649
|
+
}
|
650
|
+
// get scene(): Scene | null {
|
651
|
+
// return this._mediaPlayerRef.value?.scene ?? null;
|
652
|
+
// }
|
653
|
+
// get scenes(): Scene[] {
|
654
|
+
// return this._mediaPlayerRef.value?.scenes ?? [];
|
655
|
+
// }
|
656
|
+
// get sceneConfig(): Scenes | null {
|
657
|
+
// return this._mediaPlayerRef.value?.sceneConfig ?? null;
|
658
|
+
// }
|
1122
659
|
get videoState() {
|
1123
|
-
var
|
1124
|
-
return (
|
660
|
+
var _a;
|
661
|
+
return (_a = this._mediaPlayerRef.value) == null ? void 0 : _a.videoState;
|
1125
662
|
}
|
1126
663
|
get mediaPlayer() {
|
1127
664
|
return this._mediaPlayerRef.value;
|
1128
665
|
}
|
1129
666
|
play() {
|
1130
|
-
var
|
1131
|
-
(
|
667
|
+
var _a;
|
668
|
+
(_a = this._mediaPlayerRef.value) == null ? void 0 : _a.play();
|
1132
669
|
}
|
1133
670
|
pause() {
|
1134
|
-
var
|
1135
|
-
(
|
671
|
+
var _a;
|
672
|
+
(_a = this._mediaPlayerRef.value) == null ? void 0 : _a.pause();
|
673
|
+
}
|
674
|
+
reset(time = 0, play = false) {
|
675
|
+
var _a;
|
676
|
+
(_a = this._mediaPlayerRef.value) == null ? void 0 : _a.reset(time, play);
|
677
|
+
}
|
678
|
+
// setScene(index: number) {
|
679
|
+
// this._mediaPlayerRef.value?.setScene(index);
|
680
|
+
// }
|
681
|
+
_renderStyles() {
|
682
|
+
if (!this.aspectRatio) {
|
683
|
+
return html`
|
684
|
+
<style>
|
685
|
+
:host {
|
686
|
+
width: 100%;
|
687
|
+
height: 100%;
|
688
|
+
}
|
689
|
+
</style>
|
690
|
+
`;
|
691
|
+
}
|
692
|
+
if (typeof this.aspectRatio === "number") {
|
693
|
+
return html`
|
694
|
+
<style>
|
695
|
+
:host {
|
696
|
+
aspect-ratio: ${this.aspectRatio};
|
697
|
+
}
|
698
|
+
</style>
|
699
|
+
`;
|
700
|
+
}
|
701
|
+
return null;
|
1136
702
|
}
|
1137
|
-
|
1138
|
-
|
1139
|
-
|
703
|
+
willUpdate(changedProperties) {
|
704
|
+
if (changedProperties.has("vouchId") && this.vouchId !== changedProperties.get("vouchId")) {
|
705
|
+
this.reset(0, false);
|
706
|
+
}
|
1140
707
|
}
|
1141
708
|
render() {
|
1142
|
-
return
|
709
|
+
return html`
|
710
|
+
${this._renderStyles()}
|
1143
711
|
<vmp-media-player
|
1144
|
-
${
|
712
|
+
${ref(this._mediaPlayerRef)}
|
1145
713
|
${this.eventController.register()}
|
1146
714
|
?autoplay=${this.autoplay}
|
1147
715
|
?loading=${this.fetching}
|
1148
|
-
|
1149
|
-
|
1150
|
-
|
1151
|
-
aspectRatio=${tt(this.aspectRatio)}
|
1152
|
-
preload=${tt(this.preload)}
|
716
|
+
aspectRatio=${ifDefined(this.aspectRatio)}
|
717
|
+
preload=${ifDefined(this.preload)}
|
718
|
+
language=${ifDefined(this.language)}
|
1153
719
|
.controls=${this.controls}
|
1154
720
|
></vmp-media-player>
|
1155
721
|
`;
|
1156
722
|
}
|
1157
723
|
};
|
1158
|
-
|
1159
|
-
|
1160
|
-
|
1161
|
-
|
1162
|
-
|
1163
|
-
|
1164
|
-
|
1165
|
-
|
1166
|
-
|
1167
|
-
|
1168
|
-
|
1169
|
-
|
1170
|
-
|
1171
|
-
|
1172
|
-
|
1173
|
-
|
1174
|
-
|
1175
|
-
|
1176
|
-
|
1177
|
-
|
1178
|
-
|
1179
|
-
|
1180
|
-
|
1181
|
-
|
1182
|
-
|
1183
|
-
|
1184
|
-
|
1185
|
-
|
1186
|
-
|
1187
|
-
|
1188
|
-
|
1189
|
-
|
1190
|
-
|
1191
|
-
|
1192
|
-
|
1193
|
-
|
1194
|
-
|
1195
|
-
|
1196
|
-
|
1197
|
-
|
1198
|
-
|
1199
|
-
|
1200
|
-
|
1201
|
-
|
1202
|
-
|
724
|
+
PlayerEmbed.styles = [
|
725
|
+
css`
|
726
|
+
:host {
|
727
|
+
display: flex;
|
728
|
+
}
|
729
|
+
`
|
730
|
+
];
|
731
|
+
__decorateClass$3([
|
732
|
+
property({ type: Object })
|
733
|
+
], PlayerEmbed.prototype, "data", 2);
|
734
|
+
__decorateClass$3([
|
735
|
+
property({ type: String })
|
736
|
+
], PlayerEmbed.prototype, "vouchId", 2);
|
737
|
+
__decorateClass$3([
|
738
|
+
property({ type: String })
|
739
|
+
], PlayerEmbed.prototype, "templateId", 2);
|
740
|
+
__decorateClass$3([
|
741
|
+
property({ type: Array })
|
742
|
+
], PlayerEmbed.prototype, "questions", 2);
|
743
|
+
__decorateClass$3([
|
744
|
+
property({ type: String })
|
745
|
+
], PlayerEmbed.prototype, "env", 2);
|
746
|
+
__decorateClass$3([
|
747
|
+
property({ type: String })
|
748
|
+
], PlayerEmbed.prototype, "apiKey", 2);
|
749
|
+
__decorateClass$3([
|
750
|
+
property({ type: Boolean })
|
751
|
+
], PlayerEmbed.prototype, "disableTracking", 2);
|
752
|
+
__decorateClass$3([
|
753
|
+
property({ type: String })
|
754
|
+
], PlayerEmbed.prototype, "trackingSource", 2);
|
755
|
+
__decorateClass$3([
|
756
|
+
property({ type: Array })
|
757
|
+
], PlayerEmbed.prototype, "controls", 2);
|
758
|
+
__decorateClass$3([
|
759
|
+
property({ type: String })
|
760
|
+
], PlayerEmbed.prototype, "preload", 2);
|
761
|
+
__decorateClass$3([
|
762
|
+
property({ type: Boolean })
|
763
|
+
], PlayerEmbed.prototype, "autoplay", 2);
|
764
|
+
__decorateClass$3([
|
765
|
+
property({ type: Number })
|
766
|
+
], PlayerEmbed.prototype, "aspectRatio", 2);
|
767
|
+
__decorateClass$3([
|
768
|
+
property({ type: String })
|
769
|
+
], PlayerEmbed.prototype, "language", 2);
|
770
|
+
__decorateClass$3([
|
771
|
+
state()
|
772
|
+
], PlayerEmbed.prototype, "vouch", 2);
|
773
|
+
__decorateClass$3([
|
774
|
+
state()
|
775
|
+
], PlayerEmbed.prototype, "template", 2);
|
776
|
+
PlayerEmbed = __decorateClass$3([
|
777
|
+
customElement("vouch-embed-player")
|
778
|
+
], PlayerEmbed);
|
779
|
+
var __defProp$2 = Object.defineProperty;
|
780
|
+
var __getOwnPropDesc$2 = Object.getOwnPropertyDescriptor;
|
781
|
+
var __decorateClass$2 = (decorators, target, key, kind) => {
|
782
|
+
var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$2(target, key) : target;
|
783
|
+
for (var i = decorators.length - 1, decorator; i >= 0; i--)
|
784
|
+
if (decorator = decorators[i])
|
785
|
+
result = (kind ? decorator(target, key, result) : decorator(result)) || result;
|
786
|
+
if (kind && result)
|
787
|
+
__defProp$2(target, key, result);
|
788
|
+
return result;
|
789
|
+
};
|
790
|
+
let DialogOverlay = class extends LitElement {
|
791
|
+
constructor() {
|
792
|
+
super(...arguments);
|
793
|
+
this.open = false;
|
794
|
+
this.aspectRatio = 0;
|
795
|
+
}
|
796
|
+
render() {
|
797
|
+
return html`
|
798
|
+
<div
|
799
|
+
class=${classMap({
|
800
|
+
container: true,
|
801
|
+
hidden: !this.open
|
802
|
+
})}
|
803
|
+
>
|
804
|
+
<div
|
805
|
+
class="background"
|
806
|
+
@click=${() => this.dispatchEvent(new CustomEvent("overlay:click", { bubbles: true, composed: true }))}
|
807
|
+
></div>
|
808
|
+
<focus-trap>
|
809
|
+
<div
|
810
|
+
class=${classMap({
|
811
|
+
"video-frame": true,
|
812
|
+
grow: this.aspectRatio === 0
|
813
|
+
})}
|
814
|
+
style=${styleMap({
|
815
|
+
aspectRatio: this.aspectRatio
|
816
|
+
})}
|
817
|
+
>
|
818
|
+
<slot></slot>
|
819
|
+
<vmp-icon-button
|
820
|
+
icon="close"
|
821
|
+
rounded="full"
|
822
|
+
weight="heavy"
|
823
|
+
@click=${() => this.dispatchEvent(new CustomEvent("close:click", { bubbles: true, composed: true }))}
|
824
|
+
></vmp-icon-button>
|
825
|
+
</div>
|
826
|
+
</focus-trap>
|
827
|
+
</div>
|
828
|
+
`;
|
829
|
+
}
|
830
|
+
};
|
831
|
+
DialogOverlay.styles = [
|
832
|
+
css`
|
833
|
+
:host {
|
834
|
+
--vouch-media-player-border-radius: var(--vu-media-player-border-radius, 12px);
|
835
|
+
--overlay-background-color: var(--vu-overlay-background-color, black);
|
836
|
+
--overlay-background-opacity: var(--vu-overlay-background-opacity, 0.4);
|
837
|
+
|
838
|
+
--dialog-width: var(--vu-dialog-width, 890px);
|
839
|
+
--dialog-height: var(--vu-dialog-height, 500px);
|
840
|
+
}
|
841
|
+
|
842
|
+
.container {
|
843
|
+
position: fixed;
|
844
|
+
display: flex;
|
845
|
+
inset: 0;
|
846
|
+
opacity: 1;
|
847
|
+
z-index: 2147483647;
|
848
|
+
align-items: center;
|
849
|
+
justify-content: center;
|
850
|
+
transition: opacity 100ms ease-in;
|
851
|
+
}
|
852
|
+
|
853
|
+
.hidden {
|
854
|
+
opacity: 0;
|
855
|
+
pointer-events: none;
|
856
|
+
}
|
857
|
+
|
858
|
+
.background {
|
859
|
+
position: absolute;
|
860
|
+
inset: 0;
|
861
|
+
opacity: var(--overlay-background-opacity);
|
862
|
+
background-color: var(--overlay-background-color);
|
863
|
+
}
|
864
|
+
|
865
|
+
focus-trap {
|
866
|
+
display: flex;
|
867
|
+
align-items: center;
|
868
|
+
justify-content: center;
|
869
|
+
margin: 40px;
|
870
|
+
width: var(--dialog-width);
|
871
|
+
height: var(--dialog-height);
|
872
|
+
max-width: calc(100% - 80px);
|
873
|
+
max-height: calc(100% - 80px);
|
874
|
+
}
|
875
|
+
|
876
|
+
.video-frame {
|
877
|
+
position: relative;
|
878
|
+
display: flex;
|
879
|
+
align-items: center;
|
880
|
+
justify-content: center;
|
881
|
+
max-width: 100%;
|
882
|
+
max-height: 100%;
|
883
|
+
}
|
884
|
+
|
885
|
+
.video-frame.grow {
|
886
|
+
width: 100%;
|
887
|
+
height: 100%;
|
888
|
+
}
|
889
|
+
|
890
|
+
vmp-icon-button {
|
891
|
+
position: absolute;
|
892
|
+
top: 0;
|
893
|
+
right: 0;
|
894
|
+
margin: 10px;
|
895
|
+
}
|
896
|
+
`
|
897
|
+
];
|
898
|
+
__decorateClass$2([
|
899
|
+
property({ type: Boolean })
|
900
|
+
], DialogOverlay.prototype, "open", 2);
|
901
|
+
__decorateClass$2([
|
902
|
+
property({ type: Number })
|
903
|
+
], DialogOverlay.prototype, "aspectRatio", 2);
|
904
|
+
DialogOverlay = __decorateClass$2([
|
905
|
+
customElement("vouch-embed-dialog-overlay")
|
906
|
+
], DialogOverlay);
|
907
|
+
var __defProp$1 = Object.defineProperty;
|
908
|
+
var __getOwnPropDesc$1 = Object.getOwnPropertyDescriptor;
|
909
|
+
var __decorateClass$1 = (decorators, target, key, kind) => {
|
910
|
+
var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc$1(target, key) : target;
|
911
|
+
for (var i = decorators.length - 1, decorator; i >= 0; i--)
|
912
|
+
if (decorator = decorators[i])
|
913
|
+
result = (kind ? decorator(target, key, result) : decorator(result)) || result;
|
914
|
+
if (kind && result)
|
915
|
+
__defProp$1(target, key, result);
|
916
|
+
return result;
|
917
|
+
};
|
918
|
+
let DialogPortal = class extends LitElement {
|
919
|
+
constructor() {
|
920
|
+
super(...arguments);
|
921
|
+
this.env = "prod";
|
922
|
+
this.apiKey = "";
|
923
|
+
this.disableTracking = false;
|
924
|
+
this.trackingSource = "embedded_player";
|
925
|
+
this.preload = "none";
|
926
|
+
this.disableAutoplay = false;
|
927
|
+
this.aspectRatio = 0;
|
928
|
+
this._mediaPlayerRef = createRef();
|
929
|
+
this.open = false;
|
930
|
+
this._handleToggle = ({ detail }) => {
|
931
|
+
var _a, _b, _c;
|
932
|
+
if (this.id === detail) {
|
933
|
+
this.open = !this.open;
|
934
|
+
if (this.open) {
|
935
|
+
if (!this.disableAutoplay && ((_a = this._mediaPlayerRef) == null ? void 0 : _a.value)) {
|
936
|
+
this._mediaPlayerRef.value.muted = false;
|
937
|
+
this._mediaPlayerRef.value.play();
|
938
|
+
}
|
939
|
+
} else {
|
940
|
+
(_c = (_b = this._mediaPlayerRef) == null ? void 0 : _b.value) == null ? void 0 : _c.pause();
|
941
|
+
}
|
942
|
+
}
|
943
|
+
};
|
944
|
+
this._handleClose = () => {
|
945
|
+
var _a, _b;
|
946
|
+
this.open = false;
|
947
|
+
(_b = (_a = this._mediaPlayerRef) == null ? void 0 : _a.value) == null ? void 0 : _b.pause();
|
948
|
+
};
|
949
|
+
this._handleDocumentKeyUp = (e) => {
|
950
|
+
if (e.key === "Escape") {
|
951
|
+
this._handleClose();
|
952
|
+
}
|
953
|
+
};
|
954
|
+
}
|
955
|
+
connectedCallback() {
|
956
|
+
super.connectedCallback();
|
957
|
+
document.addEventListener("dialogembed:click", this._handleToggle);
|
958
|
+
document.addEventListener("keyup", this._handleDocumentKeyUp);
|
959
|
+
document.addEventListener("close:click", this._handleClose);
|
960
|
+
document.addEventListener("overlay:click", this._handleClose);
|
961
|
+
}
|
962
|
+
disconnectedCallback() {
|
963
|
+
super.disconnectedCallback();
|
964
|
+
document.removeEventListener("dialogembed:click", this._handleToggle);
|
965
|
+
document.removeEventListener("keyup", this._handleDocumentKeyUp);
|
966
|
+
document.removeEventListener("close:click", this._handleClose);
|
967
|
+
document.removeEventListener("overlay:click", this._handleClose);
|
968
|
+
}
|
969
|
+
createRenderRoot() {
|
970
|
+
const newNode = document.createElement("div");
|
971
|
+
document.body.appendChild(newNode);
|
972
|
+
return newNode;
|
973
|
+
}
|
974
|
+
render() {
|
975
|
+
return html`
|
976
|
+
<vouch-embed-dialog-overlay ?open=${this.open} aspectRatio=${this.aspectRatio}>
|
977
|
+
<vouch-embed-player
|
978
|
+
${ref(this._mediaPlayerRef)}
|
979
|
+
style=${styleMap({
|
980
|
+
maxWidth: "100%",
|
981
|
+
maxHeight: "100%"
|
982
|
+
})}
|
983
|
+
?autoplay=${false}
|
984
|
+
vouchId=${ifDefined(this.vouchId)}
|
985
|
+
templateId=${ifDefined(this.templateId)}
|
986
|
+
.questions=${this.questions}
|
987
|
+
.controls=${this.controls}
|
988
|
+
env=${ifDefined(this.env)}
|
989
|
+
apiKey=${ifDefined(this.apiKey)}
|
990
|
+
?disableTracking=${this.disableTracking}
|
991
|
+
trackingSource=${ifDefined(this.trackingSource)}
|
992
|
+
preload=${ifDefined(this.preload)}
|
993
|
+
aspectRatio=${this.aspectRatio}
|
994
|
+
></vouch-embed-player>
|
995
|
+
</vouch-embed-dialog-overlay>
|
996
|
+
`;
|
997
|
+
}
|
998
|
+
};
|
999
|
+
__decorateClass$1([
|
1000
|
+
property({ type: String })
|
1001
|
+
], DialogPortal.prototype, "vouchId", 2);
|
1002
|
+
__decorateClass$1([
|
1003
|
+
property({ type: String })
|
1004
|
+
], DialogPortal.prototype, "templateId", 2);
|
1005
|
+
__decorateClass$1([
|
1006
|
+
property({ type: Array })
|
1007
|
+
], DialogPortal.prototype, "questions", 2);
|
1008
|
+
__decorateClass$1([
|
1009
|
+
property({ type: String })
|
1010
|
+
], DialogPortal.prototype, "env", 2);
|
1011
|
+
__decorateClass$1([
|
1012
|
+
property({ type: String })
|
1013
|
+
], DialogPortal.prototype, "apiKey", 2);
|
1014
|
+
__decorateClass$1([
|
1015
|
+
property({ type: Boolean })
|
1016
|
+
], DialogPortal.prototype, "disableTracking", 2);
|
1017
|
+
__decorateClass$1([
|
1018
|
+
property({ type: String })
|
1019
|
+
], DialogPortal.prototype, "trackingSource", 2);
|
1020
|
+
__decorateClass$1([
|
1021
|
+
property({ type: Array })
|
1022
|
+
], DialogPortal.prototype, "controls", 2);
|
1023
|
+
__decorateClass$1([
|
1024
|
+
property({ type: String })
|
1025
|
+
], DialogPortal.prototype, "preload", 2);
|
1026
|
+
__decorateClass$1([
|
1027
|
+
property({ type: Boolean })
|
1028
|
+
], DialogPortal.prototype, "disableAutoplay", 2);
|
1029
|
+
__decorateClass$1([
|
1030
|
+
property({ type: Number })
|
1031
|
+
], DialogPortal.prototype, "aspectRatio", 2);
|
1032
|
+
__decorateClass$1([
|
1033
|
+
state()
|
1034
|
+
], DialogPortal.prototype, "open", 2);
|
1035
|
+
DialogPortal = __decorateClass$1([
|
1036
|
+
customElement("vouch-embed-dialog-portal")
|
1037
|
+
], DialogPortal);
|
1038
|
+
var __defProp = Object.defineProperty;
|
1039
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
1040
|
+
var __decorateClass = (decorators, target, key, kind) => {
|
1041
|
+
var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc(target, key) : target;
|
1042
|
+
for (var i = decorators.length - 1, decorator; i >= 0; i--)
|
1043
|
+
if (decorator = decorators[i])
|
1044
|
+
result = (kind ? decorator(target, key, result) : decorator(result)) || result;
|
1045
|
+
if (kind && result)
|
1046
|
+
__defProp(target, key, result);
|
1047
|
+
return result;
|
1048
|
+
};
|
1049
|
+
let DialogEmbed = class extends LitElement {
|
1050
|
+
constructor() {
|
1051
|
+
super(...arguments);
|
1052
|
+
this.env = "prod";
|
1053
|
+
this.apiKey = "";
|
1054
|
+
this.disableTracking = false;
|
1055
|
+
this.trackingSource = "embedded_player";
|
1056
|
+
this.preload = "none";
|
1057
|
+
this.disableAutoplay = false;
|
1058
|
+
this.aspectRatio = 0;
|
1059
|
+
this._id = v4();
|
1060
|
+
this._handleRootClick = () => {
|
1061
|
+
this.dispatchEvent(new CustomEvent("dialogembed:click", { detail: this._id, bubbles: true, composed: true }));
|
1062
|
+
};
|
1063
|
+
}
|
1064
|
+
connectedCallback() {
|
1065
|
+
super.connectedCallback();
|
1066
|
+
this.addEventListener("click", this._handleRootClick);
|
1067
|
+
}
|
1068
|
+
disconnectedCallback() {
|
1069
|
+
super.disconnectedCallback();
|
1070
|
+
this.removeEventListener("click", this._handleRootClick);
|
1071
|
+
}
|
1072
|
+
render() {
|
1073
|
+
return html`
|
1074
|
+
<slot>
|
1075
|
+
<vmp-button size="large">Play</vmp-button>
|
1076
|
+
</slot>
|
1077
|
+
<vouch-embed-dialog-portal
|
1078
|
+
id=${this._id}
|
1079
|
+
?autoplay=${false}
|
1080
|
+
vouchId=${ifDefined(this.vouchId)}
|
1081
|
+
templateId=${ifDefined(this.templateId)}
|
1082
|
+
.questions=${this.questions}
|
1083
|
+
.controls=${this.controls}
|
1084
|
+
env=${ifDefined(this.env)}
|
1085
|
+
apiKey=${ifDefined(this.apiKey)}
|
1086
|
+
?disableTracking=${this.disableTracking}
|
1087
|
+
trackingSource=${ifDefined(this.trackingSource)}
|
1088
|
+
preload=${ifDefined(this.preload)}
|
1089
|
+
aspectRatio=${this.aspectRatio}
|
1090
|
+
></vouch-embed-dialog-portal>
|
1091
|
+
`;
|
1092
|
+
}
|
1093
|
+
};
|
1094
|
+
DialogEmbed.styles = [
|
1095
|
+
css`
|
1096
|
+
:host {
|
1097
|
+
--vu-button-padding: 10px 20px;
|
1098
|
+
--vu-button-background: #287179;
|
1099
|
+
--vu-button-background-hover: #4faab2;
|
1100
|
+
|
1101
|
+
display: flex;
|
1102
|
+
width: fit-content;
|
1103
|
+
height: fit-content;
|
1104
|
+
}
|
1105
|
+
`
|
1106
|
+
];
|
1107
|
+
__decorateClass([
|
1108
|
+
property({ type: String })
|
1109
|
+
], DialogEmbed.prototype, "vouchId", 2);
|
1110
|
+
__decorateClass([
|
1111
|
+
property({ type: String })
|
1112
|
+
], DialogEmbed.prototype, "templateId", 2);
|
1113
|
+
__decorateClass([
|
1114
|
+
property({ type: Array })
|
1115
|
+
], DialogEmbed.prototype, "questions", 2);
|
1116
|
+
__decorateClass([
|
1117
|
+
property({ type: String })
|
1118
|
+
], DialogEmbed.prototype, "env", 2);
|
1119
|
+
__decorateClass([
|
1120
|
+
property({ type: String })
|
1121
|
+
], DialogEmbed.prototype, "apiKey", 2);
|
1122
|
+
__decorateClass([
|
1123
|
+
property({ type: Boolean })
|
1124
|
+
], DialogEmbed.prototype, "disableTracking", 2);
|
1125
|
+
__decorateClass([
|
1126
|
+
property({ type: String })
|
1127
|
+
], DialogEmbed.prototype, "trackingSource", 2);
|
1128
|
+
__decorateClass([
|
1129
|
+
property({ type: Array })
|
1130
|
+
], DialogEmbed.prototype, "controls", 2);
|
1131
|
+
__decorateClass([
|
1132
|
+
property({ type: String })
|
1133
|
+
], DialogEmbed.prototype, "preload", 2);
|
1134
|
+
__decorateClass([
|
1135
|
+
property({ type: Boolean })
|
1136
|
+
], DialogEmbed.prototype, "disableAutoplay", 2);
|
1137
|
+
__decorateClass([
|
1138
|
+
property({ type: Number })
|
1139
|
+
], DialogEmbed.prototype, "aspectRatio", 2);
|
1140
|
+
DialogEmbed = __decorateClass([
|
1141
|
+
customElement("vouch-embed-dialog")
|
1142
|
+
], DialogEmbed);
|
1203
1143
|
export {
|
1204
|
-
|
1144
|
+
DialogEmbed,
|
1145
|
+
PlayerEmbed
|
1205
1146
|
};
|
1206
1147
|
//# sourceMappingURL=embeds.js.map
|