@vouchfor/embeds 0.0.0-experiment.8cafed9 → 0.0.0-experiment.8d72879
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/dist/es/embeds.js +1042 -1
- package/dist/es/embeds.js.map +1 -1
- package/dist/es/src/components/DialogEmbed/DialogOverlay.d.ts +4 -4
- package/dist/es/src/components/DialogEmbed/DialogPortal.d.ts +3 -3
- package/dist/es/src/components/DialogEmbed/index.d.ts +4 -5
- package/dist/es/src/components/PlayerEmbed/controllers/event-forwarder.d.ts +4 -3
- package/dist/es/src/components/PlayerEmbed/controllers/fetcher.d.ts +3 -2
- package/dist/es/src/components/PlayerEmbed/controllers/tracking/index.d.ts +4 -2
- package/dist/es/src/components/PlayerEmbed/controllers/tracking/utils.d.ts +4 -3
- package/dist/es/src/components/PlayerEmbed/index.d.ts +15 -13
- package/dist/es/src/components/PlayerEmbed/tests/data.d.ts +4 -2
- package/dist/es/src/components/PlayerEmbed/tests/media-data.d.ts +19 -0
- package/dist/iife/dialog-embed/embed.iife.js +2647 -319
- package/dist/iife/dialog-embed/embed.iife.js.map +1 -1
- package/dist/iife/embeds.iife.js +2647 -319
- package/dist/iife/embeds.iife.js.map +1 -1
- package/dist/iife/player-embed/embed.iife.js +2624 -296
- package/dist/iife/player-embed/embed.iife.js.map +1 -1
- package/package.json +30 -28
- package/src/components/PlayerEmbed/MultiEmbed.stories.ts +135 -0
- package/src/components/PlayerEmbed/PlayerEmbed.stories.ts +18 -2
- package/src/components/PlayerEmbed/controllers/tracking/index.ts +10 -10
- package/src/components/PlayerEmbed/index.ts +33 -18
- package/src/components/PlayerEmbed/tests/PlayerEmbed.spec.ts +14 -7
- package/src/components/PlayerEmbed/tests/data.ts +120 -76
- package/src/components/PlayerEmbed/tests/media-data.ts +22 -0
- package/dist/es/browser-DfO9Pnu7.js +0 -921
- package/dist/es/browser-DfO9Pnu7.js.map +0 -1
- package/dist/es/index-5G8orrrP.js +0 -2609
- package/dist/es/index-5G8orrrP.js.map +0 -1
- package/dist/iife/dialog-embed/browser-DCzTItVw.js +0 -429
- package/dist/iife/dialog-embed/browser-DCzTItVw.js.map +0 -1
- package/dist/iife/dialog-embed/embed.js +0 -5
- package/dist/iife/dialog-embed/embed.js.map +0 -1
- package/dist/iife/dialog-embed/index-CgdXxP5z.js +0 -27698
- package/dist/iife/dialog-embed/index-CgdXxP5z.js.map +0 -1
- package/dist/iife/dialog-embed/src/components/DialogEmbed/DialogOverlay.d.ts +0 -20
- package/dist/iife/dialog-embed/src/components/DialogEmbed/DialogPortal.d.ts +0 -36
- package/dist/iife/dialog-embed/src/components/DialogEmbed/index.d.ts +0 -38
- package/dist/iife/dialog-embed/src/components/PlayerEmbed/controllers/event-forwarder.d.ts +0 -15
- package/dist/iife/dialog-embed/src/components/PlayerEmbed/controllers/fetcher.d.ts +0 -14
- package/dist/iife/dialog-embed/src/components/PlayerEmbed/controllers/tracking/index.d.ts +0 -36
- package/dist/iife/dialog-embed/src/components/PlayerEmbed/controllers/tracking/utils.d.ts +0 -17
- package/dist/iife/dialog-embed/src/components/PlayerEmbed/index.d.ts +0 -74
- package/dist/iife/dialog-embed/src/components/PlayerEmbed/tests/data.d.ts +0 -3
- package/dist/iife/dialog-embed/src/index.d.ts +0 -2
- package/dist/iife/dialog-embed/src/utils/env.d.ts +0 -12
- package/dist/iife/dialog-embed/src/utils/events.d.ts +0 -2
- package/dist/iife/player-embed/browser-BBSMddCs.js +0 -429
- package/dist/iife/player-embed/browser-BBSMddCs.js.map +0 -1
- package/dist/iife/player-embed/embed.js +0 -5
- package/dist/iife/player-embed/embed.js.map +0 -1
- package/dist/iife/player-embed/index-BGZl_iqR.js +0 -27255
- package/dist/iife/player-embed/index-BGZl_iqR.js.map +0 -1
- package/dist/iife/player-embed/src/components/DialogEmbed/DialogOverlay.d.ts +0 -20
- package/dist/iife/player-embed/src/components/DialogEmbed/DialogPortal.d.ts +0 -36
- package/dist/iife/player-embed/src/components/DialogEmbed/index.d.ts +0 -38
- package/dist/iife/player-embed/src/components/PlayerEmbed/controllers/event-forwarder.d.ts +0 -15
- package/dist/iife/player-embed/src/components/PlayerEmbed/controllers/fetcher.d.ts +0 -14
- package/dist/iife/player-embed/src/components/PlayerEmbed/controllers/tracking/index.d.ts +0 -36
- package/dist/iife/player-embed/src/components/PlayerEmbed/controllers/tracking/utils.d.ts +0 -17
- package/dist/iife/player-embed/src/components/PlayerEmbed/index.d.ts +0 -74
- package/dist/iife/player-embed/src/components/PlayerEmbed/tests/data.d.ts +0 -3
- package/dist/iife/player-embed/src/index.d.ts +0 -2
- package/dist/iife/player-embed/src/utils/env.d.ts +0 -12
- package/dist/iife/player-embed/src/utils/events.d.ts +0 -2
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@vouchfor/embeds",
|
|
3
|
-
"version": "0.0.0-experiment.
|
|
3
|
+
"version": "0.0.0-experiment.8d72879",
|
|
4
4
|
"license": "MIT",
|
|
5
5
|
"author": "Aaron Williams",
|
|
6
6
|
"main": "dist/es/embeds.js",
|
|
@@ -31,9 +31,11 @@
|
|
|
31
31
|
"prepublishOnly": "yarn build",
|
|
32
32
|
"size": "size-limit",
|
|
33
33
|
"storybook": "yarn prebuild && storybook dev -p 6007",
|
|
34
|
-
"prebuild": "yarn
|
|
34
|
+
"prebuild": "yarn generate:manifest",
|
|
35
35
|
"test": "rm -rf test/lib && yarn prebuild && vite build --mode test && web-test-runner",
|
|
36
|
-
"test:ci": "yarn test --config web-test-runner.ci.config.js"
|
|
36
|
+
"test:ci": "yarn test --config web-test-runner.ci.config.js",
|
|
37
|
+
"test:watch": "yarn test --watch",
|
|
38
|
+
"typecheck": "tsc --noEmit"
|
|
37
39
|
},
|
|
38
40
|
"lint-staged": {
|
|
39
41
|
"**/*.{ts,tsx,js}": "eslint --fix --quiet",
|
|
@@ -41,47 +43,47 @@
|
|
|
41
43
|
},
|
|
42
44
|
"dependencies": {
|
|
43
45
|
"@a11y/focus-trap": "^1.0.5",
|
|
44
|
-
"@lit/task": "^1.0.
|
|
45
|
-
"@vouchfor/
|
|
46
|
+
"@lit/task": "^1.0.2",
|
|
47
|
+
"@vouchfor/canvas-video": "0.0.0-experiment.8d72879",
|
|
48
|
+
"@vouchfor/media-player": "0.0.0-experiment.8d72879",
|
|
46
49
|
"uuid": "^9.0.1"
|
|
47
50
|
},
|
|
48
51
|
"peerDependencies": {
|
|
49
52
|
"lit": "^3.1.2"
|
|
50
53
|
},
|
|
51
54
|
"devDependencies": {
|
|
52
|
-
"@esm-bundle/chai": "^4.3.4
|
|
55
|
+
"@esm-bundle/chai": "^4.3.4",
|
|
53
56
|
"@open-wc/testing": "^4.0.0",
|
|
54
|
-
"@storybook/addon-essentials": "^8.
|
|
55
|
-
"@storybook/addon-links": "^8.
|
|
56
|
-
"@storybook/blocks": "^8.
|
|
57
|
-
"@storybook/web-components": "^8.
|
|
58
|
-
"@storybook/web-components-vite": "^8.
|
|
57
|
+
"@storybook/addon-essentials": "^8.6.12",
|
|
58
|
+
"@storybook/addon-links": "^8.6.12",
|
|
59
|
+
"@storybook/blocks": "^8.6.12",
|
|
60
|
+
"@storybook/web-components": "^8.6.12",
|
|
61
|
+
"@storybook/web-components-vite": "^8.6.12",
|
|
59
62
|
"@svgr/core": "^8.1.0",
|
|
60
63
|
"@types/flat": "^5.0.5",
|
|
61
|
-
"@types/mocha": "^10.0.
|
|
62
|
-
"@vouchfor/eslint-config": "^1.0.
|
|
64
|
+
"@types/mocha": "^10.0.10",
|
|
65
|
+
"@vouchfor/eslint-config": "^1.0.5",
|
|
63
66
|
"@vouchfor/prettier-config": "^1.0.1",
|
|
64
|
-
"@vouchfor/video-utils": "0.0.0-experiment.
|
|
65
|
-
"@web/dev-server-esbuild": "^1.0.
|
|
66
|
-
"@web/test-runner": "^0.
|
|
67
|
-
"@web/test-runner-browserstack": "^0.
|
|
67
|
+
"@vouchfor/video-utils": "0.0.0-experiment.8d72879",
|
|
68
|
+
"@web/dev-server-esbuild": "^1.0.4",
|
|
69
|
+
"@web/test-runner": "^0.20.1",
|
|
70
|
+
"@web/test-runner-browserstack": "^0.8.0",
|
|
68
71
|
"@web/test-runner-mocha": "^0.9.0",
|
|
69
72
|
"@web/test-runner-playwright": "^0.11.0",
|
|
70
|
-
"glob": "^10.
|
|
71
|
-
"lint-staged": "^15.
|
|
72
|
-
"lit": "^3.
|
|
73
|
+
"glob": "^10.4.5",
|
|
74
|
+
"lint-staged": "^15.5.1",
|
|
75
|
+
"lit": "^3.3.0",
|
|
73
76
|
"lodash": "^4.17.21",
|
|
74
|
-
"react": "^18.
|
|
75
|
-
"react-dom": "^18.
|
|
76
|
-
"rollup-plugin-internal": "^1.0.4",
|
|
77
|
+
"react": "^18.3.1",
|
|
78
|
+
"react-dom": "^18.3.1",
|
|
77
79
|
"rollup-plugin-tla": "^0.0.2",
|
|
78
80
|
"sinon": "^17.0.1",
|
|
79
|
-
"storybook": "^8.
|
|
81
|
+
"storybook": "^8.6.12",
|
|
80
82
|
"svgson": "^5.3.1",
|
|
81
|
-
"typescript": "^5.
|
|
82
|
-
"vite": "^5.
|
|
83
|
-
"vite-plugin-commonjs": "^0.10.
|
|
84
|
-
"vite-plugin-dts": "^3.
|
|
83
|
+
"typescript": "^5.8.3",
|
|
84
|
+
"vite": "^5.4.18",
|
|
85
|
+
"vite-plugin-commonjs": "^0.10.4",
|
|
86
|
+
"vite-plugin-dts": "^3.9.1",
|
|
85
87
|
"web-component-analyzer": "^2.0.0"
|
|
86
88
|
}
|
|
87
89
|
}
|
|
@@ -0,0 +1,135 @@
|
|
|
1
|
+
import { html } from 'lit';
|
|
2
|
+
import { ifDefined } from 'lit/directives/if-defined.js';
|
|
3
|
+
|
|
4
|
+
import type { PlayerEmbedProps } from '.';
|
|
5
|
+
import type { Meta, StoryObj } from '@storybook/web-components';
|
|
6
|
+
|
|
7
|
+
import '.';
|
|
8
|
+
|
|
9
|
+
type MultiEmbedArgs = PlayerEmbedProps & {
|
|
10
|
+
apiKey1?: string;
|
|
11
|
+
apiKey2?: string;
|
|
12
|
+
apiKey3?: string;
|
|
13
|
+
vouchId1?: string;
|
|
14
|
+
vouchId2?: string;
|
|
15
|
+
vouchId3?: string;
|
|
16
|
+
showVouch?: boolean;
|
|
17
|
+
};
|
|
18
|
+
|
|
19
|
+
const _MultiEmbed = ({
|
|
20
|
+
vouchId1,
|
|
21
|
+
vouchId2,
|
|
22
|
+
vouchId3,
|
|
23
|
+
templateId,
|
|
24
|
+
questions,
|
|
25
|
+
preload,
|
|
26
|
+
autoplay,
|
|
27
|
+
env,
|
|
28
|
+
apiKey1,
|
|
29
|
+
apiKey2,
|
|
30
|
+
apiKey3,
|
|
31
|
+
controls,
|
|
32
|
+
aspectRatio
|
|
33
|
+
}: MultiEmbedArgs) => {
|
|
34
|
+
return html`
|
|
35
|
+
<div style="height: 33vh">
|
|
36
|
+
<vouch-embed-player
|
|
37
|
+
env=${ifDefined(env)}
|
|
38
|
+
apiKey=${ifDefined(apiKey1)}
|
|
39
|
+
vouchId=${ifDefined(vouchId1)}
|
|
40
|
+
templateId=${ifDefined(templateId)}
|
|
41
|
+
.questions=${questions}
|
|
42
|
+
.controls=${controls}
|
|
43
|
+
?autoplay=${autoplay}
|
|
44
|
+
preload=${ifDefined(preload)}
|
|
45
|
+
aspectRatio=${ifDefined(aspectRatio)}
|
|
46
|
+
@error=${console.log}
|
|
47
|
+
></vouch-embed-player>
|
|
48
|
+
</div>
|
|
49
|
+
<div style="height: 33vh">
|
|
50
|
+
<vouch-embed-player
|
|
51
|
+
env=${ifDefined(env)}
|
|
52
|
+
apiKey=${ifDefined(apiKey2)}
|
|
53
|
+
vouchId=${ifDefined(vouchId2)}
|
|
54
|
+
templateId=${ifDefined(templateId)}
|
|
55
|
+
.questions=${questions}
|
|
56
|
+
.controls=${controls}
|
|
57
|
+
?autoplay=${autoplay}
|
|
58
|
+
preload=${ifDefined(preload)}
|
|
59
|
+
aspectRatio=${ifDefined(aspectRatio)}
|
|
60
|
+
@error=${console.log}
|
|
61
|
+
></vouch-embed-player>
|
|
62
|
+
</div>
|
|
63
|
+
<div style="height: 33vh">
|
|
64
|
+
<vouch-embed-player
|
|
65
|
+
env=${ifDefined(env)}
|
|
66
|
+
apiKey=${ifDefined(apiKey3)}
|
|
67
|
+
vouchId=${ifDefined(vouchId3)}
|
|
68
|
+
templateId=${ifDefined(templateId)}
|
|
69
|
+
.questions=${questions}
|
|
70
|
+
.controls=${controls}
|
|
71
|
+
?autoplay=${autoplay}
|
|
72
|
+
preload=${ifDefined(preload)}
|
|
73
|
+
aspectRatio=${ifDefined(aspectRatio)}
|
|
74
|
+
@error=${console.log}
|
|
75
|
+
></vouch-embed-player>
|
|
76
|
+
</div>
|
|
77
|
+
`;
|
|
78
|
+
};
|
|
79
|
+
|
|
80
|
+
// More on how to set up stories at: https://storybook.js.org/docs/web-components/writing-stories/introduction
|
|
81
|
+
const meta = {
|
|
82
|
+
title: 'Embeds',
|
|
83
|
+
tags: ['autodocs'],
|
|
84
|
+
render: (args) => _MultiEmbed(args),
|
|
85
|
+
component: 'vouch-embed-player'
|
|
86
|
+
} satisfies Meta<PlayerEmbedProps>;
|
|
87
|
+
|
|
88
|
+
type Story = StoryObj<MultiEmbedArgs>;
|
|
89
|
+
|
|
90
|
+
const MultiPlayer: Story = {
|
|
91
|
+
args: {
|
|
92
|
+
env: 'dev',
|
|
93
|
+
apiKey1: 'TVik9uTMgE-PD25UTHIS6gyl0hMBWC7AT4dkpdlLBT4VIfDWZJrQiCk6Ak7m1',
|
|
94
|
+
vouchId1: '6JQEIPeStt',
|
|
95
|
+
apiKey2: 'TVik9uTMgE-PD25UTHIS6gyl0hMBWC7AT4dkpdlLBT4VIfDWZJrQiCk6Ak7m1',
|
|
96
|
+
vouchId2: '6JQEIPeStt',
|
|
97
|
+
apiKey3: 'TVik9uTMgE-PD25UTHIS6gyl0hMBWC7AT4dkpdlLBT4VIfDWZJrQiCk6Ak7m1',
|
|
98
|
+
vouchId3: '6JQEIPeStt',
|
|
99
|
+
templateId: '357fc118-e179-4171-9446-ff2b8e9d1b29',
|
|
100
|
+
questions: [],
|
|
101
|
+
aspectRatio: 0,
|
|
102
|
+
preload: 'none',
|
|
103
|
+
autoplay: false,
|
|
104
|
+
controls: [
|
|
105
|
+
'progress',
|
|
106
|
+
'play-large',
|
|
107
|
+
'navigation',
|
|
108
|
+
'play',
|
|
109
|
+
'volume',
|
|
110
|
+
'current-time',
|
|
111
|
+
'duration',
|
|
112
|
+
'speed',
|
|
113
|
+
'captions',
|
|
114
|
+
'fullscreen',
|
|
115
|
+
'preview',
|
|
116
|
+
'languages'
|
|
117
|
+
]
|
|
118
|
+
},
|
|
119
|
+
argTypes: {
|
|
120
|
+
env: {
|
|
121
|
+
control: 'radio',
|
|
122
|
+
options: ['local', 'dev', 'staging', 'prod']
|
|
123
|
+
},
|
|
124
|
+
preload: {
|
|
125
|
+
control: 'radio',
|
|
126
|
+
options: ['auto', 'none']
|
|
127
|
+
}
|
|
128
|
+
},
|
|
129
|
+
parameters: {
|
|
130
|
+
layout: 'fullscreen'
|
|
131
|
+
}
|
|
132
|
+
};
|
|
133
|
+
|
|
134
|
+
export default meta;
|
|
135
|
+
export { MultiPlayer };
|
|
@@ -19,7 +19,8 @@ const _PlayerEmbed = ({
|
|
|
19
19
|
env,
|
|
20
20
|
apiKey,
|
|
21
21
|
controls,
|
|
22
|
-
aspectRatio
|
|
22
|
+
aspectRatio,
|
|
23
|
+
senderId
|
|
23
24
|
}: PlayerEmbedArgs) => {
|
|
24
25
|
return html`
|
|
25
26
|
<div style="height: 100vh">
|
|
@@ -33,6 +34,7 @@ const _PlayerEmbed = ({
|
|
|
33
34
|
?autoplay=${autoplay}
|
|
34
35
|
preload=${ifDefined(preload)}
|
|
35
36
|
aspectRatio=${ifDefined(aspectRatio)}
|
|
37
|
+
senderId=${ifDefined(senderId)}
|
|
36
38
|
@error=${console.log}
|
|
37
39
|
></vouch-embed-player>
|
|
38
40
|
</div>
|
|
@@ -58,7 +60,21 @@ const Player: Story = {
|
|
|
58
60
|
questions: [],
|
|
59
61
|
aspectRatio: 0,
|
|
60
62
|
preload: 'none',
|
|
61
|
-
autoplay: false
|
|
63
|
+
autoplay: false,
|
|
64
|
+
controls: [
|
|
65
|
+
'progress',
|
|
66
|
+
'play-large',
|
|
67
|
+
'navigation',
|
|
68
|
+
'play',
|
|
69
|
+
'volume',
|
|
70
|
+
'current-time',
|
|
71
|
+
'duration',
|
|
72
|
+
'speed',
|
|
73
|
+
'captions',
|
|
74
|
+
'fullscreen',
|
|
75
|
+
'preview',
|
|
76
|
+
'languages'
|
|
77
|
+
]
|
|
62
78
|
},
|
|
63
79
|
argTypes: {
|
|
64
80
|
env: {
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import type { PlayerEmbed } from '../..';
|
|
2
|
-
import type {
|
|
2
|
+
import type { MediaEventDetail } from '@vouchfor/media-player';
|
|
3
3
|
import type { ReactiveController, ReactiveControllerHost } from 'lit';
|
|
4
4
|
|
|
5
5
|
import { findVouchId, getReportingMetadata, getUids } from './utils';
|
|
@@ -15,6 +15,7 @@ type TrackingPayload = {
|
|
|
15
15
|
answerId?: string;
|
|
16
16
|
streamStart?: number;
|
|
17
17
|
streamEnd?: number;
|
|
18
|
+
senderId?: string;
|
|
18
19
|
};
|
|
19
20
|
|
|
20
21
|
type BatchEvent = {
|
|
@@ -41,7 +42,7 @@ class TrackingController implements ReactiveController {
|
|
|
41
42
|
private _answersViewed: BooleanMap = {};
|
|
42
43
|
private _streamStartTime: TimeMap = {};
|
|
43
44
|
private _streamLatestTime: TimeMap = {};
|
|
44
|
-
private _currentlyPlayingVideo:
|
|
45
|
+
private _currentlyPlayingVideo: MediaEventDetail | null = null;
|
|
45
46
|
|
|
46
47
|
constructor(host: PlayerEmbedHost) {
|
|
47
48
|
this.host = host;
|
|
@@ -59,6 +60,7 @@ class TrackingController implements ReactiveController {
|
|
|
59
60
|
event,
|
|
60
61
|
payload: {
|
|
61
62
|
...payload,
|
|
63
|
+
senderId: this.host.senderId,
|
|
62
64
|
vouchId,
|
|
63
65
|
time: new Date().toISOString()
|
|
64
66
|
}
|
|
@@ -127,14 +129,12 @@ class TrackingController implements ReactiveController {
|
|
|
127
129
|
private _handlePlay = () => {
|
|
128
130
|
// Only send the video played event once per session
|
|
129
131
|
if (!this._hasPlayed) {
|
|
130
|
-
this._createTrackingEvent('VIDEO_PLAYED', {
|
|
131
|
-
streamStart: this.host.currentTime
|
|
132
|
-
});
|
|
132
|
+
this._createTrackingEvent('VIDEO_PLAYED', { streamStart: this.host.currentTime });
|
|
133
133
|
this._hasPlayed = true;
|
|
134
134
|
}
|
|
135
135
|
};
|
|
136
136
|
|
|
137
|
-
private _handleVideoPlay = ({ detail: { id, key } }: CustomEvent<
|
|
137
|
+
private _handleVideoPlay = ({ detail: { id, key } }: CustomEvent<MediaEventDetail>) => {
|
|
138
138
|
// Only increment play count once per session
|
|
139
139
|
if (!this._answersViewed[key]) {
|
|
140
140
|
this._createTrackingEvent('VOUCH_RESPONSE_VIEWED', {
|
|
@@ -144,12 +144,12 @@ class TrackingController implements ReactiveController {
|
|
|
144
144
|
}
|
|
145
145
|
};
|
|
146
146
|
|
|
147
|
-
private _handleVideoTimeUpdate = ({ detail: { id, key, node } }: CustomEvent<
|
|
147
|
+
private _handleVideoTimeUpdate = ({ detail: { id, key, node } }: CustomEvent<MediaEventDetail>) => {
|
|
148
148
|
if (
|
|
149
149
|
// We only want to count any time that the video is actually playing
|
|
150
|
-
!this.host.paused
|
|
150
|
+
!this.host.paused
|
|
151
151
|
// Only update the latest time if this event fires for the currently active video
|
|
152
|
-
id === this.host.scene?.video?.id
|
|
152
|
+
// id === this.host.scene?.video?.id
|
|
153
153
|
) {
|
|
154
154
|
this._currentlyPlayingVideo = { id, key, node };
|
|
155
155
|
this._streamLatestTime[key] = node.currentTime;
|
|
@@ -161,7 +161,7 @@ class TrackingController implements ReactiveController {
|
|
|
161
161
|
}
|
|
162
162
|
};
|
|
163
163
|
|
|
164
|
-
private _handleVideoPause = ({ detail: { id, key } }: CustomEvent<
|
|
164
|
+
private _handleVideoPause = ({ detail: { id, key } }: CustomEvent<MediaEventDetail>) => {
|
|
165
165
|
if (this._streamLatestTime[key] > this._streamStartTime[key] + MINIMUM_SEND_THRESHOLD) {
|
|
166
166
|
this._createTrackingEvent('VIDEO_STREAMED', {
|
|
167
167
|
answerId: id,
|
|
@@ -3,8 +3,10 @@ import { customElement, property, state } from 'lit/decorators.js';
|
|
|
3
3
|
import { ifDefined } from 'lit/directives/if-defined.js';
|
|
4
4
|
import { createRef, ref } from 'lit/directives/ref.js';
|
|
5
5
|
|
|
6
|
-
import type {
|
|
6
|
+
import type { TemplateInstance } from '@vouchfor/canvas-video';
|
|
7
7
|
import type { MediaPlayer, MediaPlayerProps } from '@vouchfor/media-player';
|
|
8
|
+
import type { Vouch } from '@vouchfor/video-utils';
|
|
9
|
+
import type { PropertyValueMap } from 'lit';
|
|
8
10
|
import type { Environment } from '~/utils/env';
|
|
9
11
|
|
|
10
12
|
import { EventForwardController } from './controllers/event-forwarder';
|
|
@@ -13,7 +15,8 @@ import { TrackingController } from './controllers/tracking';
|
|
|
13
15
|
|
|
14
16
|
import '@vouchfor/media-player';
|
|
15
17
|
|
|
16
|
-
type PlayerEmbedProps = Pick<MediaPlayerProps, '
|
|
18
|
+
type PlayerEmbedProps = Pick<MediaPlayerProps, 'aspectRatio' | 'language' | 'preload' | 'autoplay' | 'controls'> & {
|
|
19
|
+
data?: Vouch;
|
|
17
20
|
env: Environment;
|
|
18
21
|
apiKey: string;
|
|
19
22
|
disableTracking?: boolean;
|
|
@@ -22,6 +25,7 @@ type PlayerEmbedProps = Pick<MediaPlayerProps, 'data' | 'aspectRatio' | 'preload
|
|
|
22
25
|
templateId?: string;
|
|
23
26
|
// Index of the questions to include starting from 1
|
|
24
27
|
questions?: number[];
|
|
28
|
+
senderId?: string;
|
|
25
29
|
};
|
|
26
30
|
|
|
27
31
|
@customElement('vouch-embed-player')
|
|
@@ -48,6 +52,8 @@ class PlayerEmbed extends LitElement {
|
|
|
48
52
|
@property({ type: String }) preload: PlayerEmbedProps['preload'] = 'auto';
|
|
49
53
|
@property({ type: Boolean }) autoplay: PlayerEmbedProps['autoplay'] = false;
|
|
50
54
|
@property({ type: Number }) aspectRatio: PlayerEmbedProps['aspectRatio'] = 0;
|
|
55
|
+
@property({ type: String }) language?: MediaPlayerProps['language'];
|
|
56
|
+
@property({ type: String }) senderId?: PlayerEmbedProps['senderId'];
|
|
51
57
|
|
|
52
58
|
private eventController = new EventForwardController(this, [
|
|
53
59
|
'durationchange',
|
|
@@ -60,10 +66,12 @@ class PlayerEmbed extends LitElement {
|
|
|
60
66
|
'playing',
|
|
61
67
|
'ratechange',
|
|
62
68
|
'scenechange',
|
|
69
|
+
'scenesupdate',
|
|
63
70
|
'seeking',
|
|
64
71
|
'seeked',
|
|
65
72
|
'timeupdate',
|
|
66
73
|
'volumechange',
|
|
74
|
+
'processing',
|
|
67
75
|
'waiting',
|
|
68
76
|
|
|
69
77
|
'video:loadeddata',
|
|
@@ -72,6 +80,7 @@ class PlayerEmbed extends LitElement {
|
|
|
72
80
|
'video:play',
|
|
73
81
|
'video:playing',
|
|
74
82
|
'video:pause',
|
|
83
|
+
'video:waiting',
|
|
75
84
|
'video:stalled',
|
|
76
85
|
'video:timeupdate',
|
|
77
86
|
'video:ended',
|
|
@@ -155,20 +164,20 @@ class PlayerEmbed extends LitElement {
|
|
|
155
164
|
return this._mediaPlayerRef.value?.muted ?? false;
|
|
156
165
|
}
|
|
157
166
|
|
|
158
|
-
get scene(): Scene | null {
|
|
159
|
-
|
|
160
|
-
}
|
|
167
|
+
// get scene(): Scene | null {
|
|
168
|
+
// return this._mediaPlayerRef.value?.scene ?? null;
|
|
169
|
+
// }
|
|
161
170
|
|
|
162
|
-
get scenes(): Scene[] {
|
|
163
|
-
|
|
164
|
-
}
|
|
171
|
+
// get scenes(): Scene[] {
|
|
172
|
+
// return this._mediaPlayerRef.value?.scenes ?? [];
|
|
173
|
+
// }
|
|
165
174
|
|
|
166
|
-
get sceneConfig(): Scenes | null {
|
|
167
|
-
|
|
168
|
-
}
|
|
175
|
+
// get sceneConfig(): Scenes | null {
|
|
176
|
+
// return this._mediaPlayerRef.value?.sceneConfig ?? null;
|
|
177
|
+
// }
|
|
169
178
|
|
|
170
|
-
get
|
|
171
|
-
return this._mediaPlayerRef.value?.
|
|
179
|
+
get mediaState() {
|
|
180
|
+
return this._mediaPlayerRef.value?.mediaState;
|
|
172
181
|
}
|
|
173
182
|
|
|
174
183
|
get mediaPlayer() {
|
|
@@ -187,9 +196,9 @@ class PlayerEmbed extends LitElement {
|
|
|
187
196
|
this._mediaPlayerRef.value?.reset(time, play);
|
|
188
197
|
}
|
|
189
198
|
|
|
190
|
-
setScene(index: number) {
|
|
191
|
-
|
|
192
|
-
}
|
|
199
|
+
// setScene(index: number) {
|
|
200
|
+
// this._mediaPlayerRef.value?.setScene(index);
|
|
201
|
+
// }
|
|
193
202
|
|
|
194
203
|
private _renderStyles() {
|
|
195
204
|
if (!this.aspectRatio) {
|
|
@@ -216,6 +225,13 @@ class PlayerEmbed extends LitElement {
|
|
|
216
225
|
return null;
|
|
217
226
|
}
|
|
218
227
|
|
|
228
|
+
protected willUpdate(changedProperties: PropertyValueMap<PlayerEmbedProps>) {
|
|
229
|
+
// If the vouch this embed is pointing to changes then reset the player
|
|
230
|
+
if (changedProperties.has('vouchId') && this.vouchId !== changedProperties.get('vouchId')) {
|
|
231
|
+
this.reset(0, false);
|
|
232
|
+
}
|
|
233
|
+
}
|
|
234
|
+
|
|
219
235
|
render() {
|
|
220
236
|
return html`
|
|
221
237
|
${this._renderStyles()}
|
|
@@ -224,10 +240,9 @@ class PlayerEmbed extends LitElement {
|
|
|
224
240
|
${this.eventController.register()}
|
|
225
241
|
?autoplay=${this.autoplay}
|
|
226
242
|
?loading=${this.fetching}
|
|
227
|
-
.data=${this.vouch}
|
|
228
|
-
.template=${this.template}
|
|
229
243
|
aspectRatio=${ifDefined(this.aspectRatio)}
|
|
230
244
|
preload=${ifDefined(this.preload)}
|
|
245
|
+
language=${ifDefined(this.language)}
|
|
231
246
|
.controls=${this.controls}
|
|
232
247
|
></vmp-media-player>
|
|
233
248
|
`;
|
|
@@ -4,7 +4,7 @@ import { html } from 'lit';
|
|
|
4
4
|
import sinon from 'sinon';
|
|
5
5
|
|
|
6
6
|
import type { PlayerEmbed } from '../index.js';
|
|
7
|
-
import type {
|
|
7
|
+
import type { MediaMap } from '@vouchfor/media-player';
|
|
8
8
|
|
|
9
9
|
import { data } from './data.js';
|
|
10
10
|
|
|
@@ -13,7 +13,7 @@ import { data } from './data.js';
|
|
|
13
13
|
// https://modern-web.dev/guides/test-runner/typescript/
|
|
14
14
|
import '../../../test/lib/embeds.js';
|
|
15
15
|
|
|
16
|
-
function getVideo(videos:
|
|
16
|
+
function getVideo(videos: MediaMap) {
|
|
17
17
|
return Object.values(videos)[0];
|
|
18
18
|
}
|
|
19
19
|
|
|
@@ -27,8 +27,8 @@ function playerLoaded(player: PlayerEmbed) {
|
|
|
27
27
|
);
|
|
28
28
|
}
|
|
29
29
|
|
|
30
|
-
describe('Embeds', () => {
|
|
31
|
-
it('
|
|
30
|
+
describe.skip('Embeds', () => {
|
|
31
|
+
it('Sends correct tracking events', async () => {
|
|
32
32
|
const player = await fixture<PlayerEmbed>(
|
|
33
33
|
html`<vouch-embed-player env="dev" .data=${data} aspectratio=${1}></vouch-embed-player>`
|
|
34
34
|
);
|
|
@@ -45,17 +45,24 @@ describe('Embeds', () => {
|
|
|
45
45
|
await waitUntil(
|
|
46
46
|
() => {
|
|
47
47
|
// Video plays for 3 seconds
|
|
48
|
-
return (getVideo(player.mediaPlayer!.
|
|
48
|
+
return (getVideo(player.mediaPlayer!.media)?.node?.currentTime ?? 0) > 3;
|
|
49
49
|
},
|
|
50
50
|
'Video did not play for 3 seconds',
|
|
51
51
|
{ timeout: 20000 }
|
|
52
52
|
);
|
|
53
|
-
expect(getVideo(player.mediaPlayer!.
|
|
53
|
+
expect(getVideo(player.mediaPlayer!.media)?.node?.paused).eq(false);
|
|
54
54
|
player.pause();
|
|
55
|
-
expect(getVideo(player.mediaPlayer!.
|
|
55
|
+
expect(getVideo(player.mediaPlayer!.media)?.node?.paused).eq(true);
|
|
56
56
|
expect(sendTrackingSpy.callCount).to.be.eq(0);
|
|
57
57
|
// Destroy node because events are sent when node is removed from the document
|
|
58
58
|
player.remove();
|
|
59
|
+
await waitUntil(
|
|
60
|
+
() => {
|
|
61
|
+
return createTrackingSpy.args[2];
|
|
62
|
+
},
|
|
63
|
+
'Cleanup event has not fired',
|
|
64
|
+
{ timeout: 5000 }
|
|
65
|
+
);
|
|
59
66
|
expect(sendTrackingSpy.callCount).to.be.eq(1);
|
|
60
67
|
expect(createTrackingSpy.args[0]).to.eql([
|
|
61
68
|
'VIDEO_PLAYED',
|