@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.
Files changed (66) hide show
  1. package/dist/es/embeds.js +1042 -1
  2. package/dist/es/embeds.js.map +1 -1
  3. package/dist/es/src/components/DialogEmbed/DialogOverlay.d.ts +4 -4
  4. package/dist/es/src/components/DialogEmbed/DialogPortal.d.ts +3 -3
  5. package/dist/es/src/components/DialogEmbed/index.d.ts +4 -5
  6. package/dist/es/src/components/PlayerEmbed/controllers/event-forwarder.d.ts +4 -3
  7. package/dist/es/src/components/PlayerEmbed/controllers/fetcher.d.ts +3 -2
  8. package/dist/es/src/components/PlayerEmbed/controllers/tracking/index.d.ts +4 -2
  9. package/dist/es/src/components/PlayerEmbed/controllers/tracking/utils.d.ts +4 -3
  10. package/dist/es/src/components/PlayerEmbed/index.d.ts +15 -13
  11. package/dist/es/src/components/PlayerEmbed/tests/data.d.ts +4 -2
  12. package/dist/es/src/components/PlayerEmbed/tests/media-data.d.ts +19 -0
  13. package/dist/iife/dialog-embed/embed.iife.js +2647 -319
  14. package/dist/iife/dialog-embed/embed.iife.js.map +1 -1
  15. package/dist/iife/embeds.iife.js +2647 -319
  16. package/dist/iife/embeds.iife.js.map +1 -1
  17. package/dist/iife/player-embed/embed.iife.js +2624 -296
  18. package/dist/iife/player-embed/embed.iife.js.map +1 -1
  19. package/package.json +30 -28
  20. package/src/components/PlayerEmbed/MultiEmbed.stories.ts +135 -0
  21. package/src/components/PlayerEmbed/PlayerEmbed.stories.ts +18 -2
  22. package/src/components/PlayerEmbed/controllers/tracking/index.ts +10 -10
  23. package/src/components/PlayerEmbed/index.ts +33 -18
  24. package/src/components/PlayerEmbed/tests/PlayerEmbed.spec.ts +14 -7
  25. package/src/components/PlayerEmbed/tests/data.ts +120 -76
  26. package/src/components/PlayerEmbed/tests/media-data.ts +22 -0
  27. package/dist/es/browser-DfO9Pnu7.js +0 -921
  28. package/dist/es/browser-DfO9Pnu7.js.map +0 -1
  29. package/dist/es/index-5G8orrrP.js +0 -2609
  30. package/dist/es/index-5G8orrrP.js.map +0 -1
  31. package/dist/iife/dialog-embed/browser-DCzTItVw.js +0 -429
  32. package/dist/iife/dialog-embed/browser-DCzTItVw.js.map +0 -1
  33. package/dist/iife/dialog-embed/embed.js +0 -5
  34. package/dist/iife/dialog-embed/embed.js.map +0 -1
  35. package/dist/iife/dialog-embed/index-CgdXxP5z.js +0 -27698
  36. package/dist/iife/dialog-embed/index-CgdXxP5z.js.map +0 -1
  37. package/dist/iife/dialog-embed/src/components/DialogEmbed/DialogOverlay.d.ts +0 -20
  38. package/dist/iife/dialog-embed/src/components/DialogEmbed/DialogPortal.d.ts +0 -36
  39. package/dist/iife/dialog-embed/src/components/DialogEmbed/index.d.ts +0 -38
  40. package/dist/iife/dialog-embed/src/components/PlayerEmbed/controllers/event-forwarder.d.ts +0 -15
  41. package/dist/iife/dialog-embed/src/components/PlayerEmbed/controllers/fetcher.d.ts +0 -14
  42. package/dist/iife/dialog-embed/src/components/PlayerEmbed/controllers/tracking/index.d.ts +0 -36
  43. package/dist/iife/dialog-embed/src/components/PlayerEmbed/controllers/tracking/utils.d.ts +0 -17
  44. package/dist/iife/dialog-embed/src/components/PlayerEmbed/index.d.ts +0 -74
  45. package/dist/iife/dialog-embed/src/components/PlayerEmbed/tests/data.d.ts +0 -3
  46. package/dist/iife/dialog-embed/src/index.d.ts +0 -2
  47. package/dist/iife/dialog-embed/src/utils/env.d.ts +0 -12
  48. package/dist/iife/dialog-embed/src/utils/events.d.ts +0 -2
  49. package/dist/iife/player-embed/browser-BBSMddCs.js +0 -429
  50. package/dist/iife/player-embed/browser-BBSMddCs.js.map +0 -1
  51. package/dist/iife/player-embed/embed.js +0 -5
  52. package/dist/iife/player-embed/embed.js.map +0 -1
  53. package/dist/iife/player-embed/index-BGZl_iqR.js +0 -27255
  54. package/dist/iife/player-embed/index-BGZl_iqR.js.map +0 -1
  55. package/dist/iife/player-embed/src/components/DialogEmbed/DialogOverlay.d.ts +0 -20
  56. package/dist/iife/player-embed/src/components/DialogEmbed/DialogPortal.d.ts +0 -36
  57. package/dist/iife/player-embed/src/components/DialogEmbed/index.d.ts +0 -38
  58. package/dist/iife/player-embed/src/components/PlayerEmbed/controllers/event-forwarder.d.ts +0 -15
  59. package/dist/iife/player-embed/src/components/PlayerEmbed/controllers/fetcher.d.ts +0 -14
  60. package/dist/iife/player-embed/src/components/PlayerEmbed/controllers/tracking/index.d.ts +0 -36
  61. package/dist/iife/player-embed/src/components/PlayerEmbed/controllers/tracking/utils.d.ts +0 -17
  62. package/dist/iife/player-embed/src/components/PlayerEmbed/index.d.ts +0 -74
  63. package/dist/iife/player-embed/src/components/PlayerEmbed/tests/data.d.ts +0 -3
  64. package/dist/iife/player-embed/src/index.d.ts +0 -2
  65. package/dist/iife/player-embed/src/utils/env.d.ts +0 -12
  66. 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.8cafed9",
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 build:deps && yarn generate:manifest",
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.0",
45
- "@vouchfor/media-player": "0.0.0-experiment.8cafed9",
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-fix.0",
55
+ "@esm-bundle/chai": "^4.3.4",
53
56
  "@open-wc/testing": "^4.0.0",
54
- "@storybook/addon-essentials": "^8.0.2",
55
- "@storybook/addon-links": "^8.0.2",
56
- "@storybook/blocks": "^8.0.2",
57
- "@storybook/web-components": "^8.0.2",
58
- "@storybook/web-components-vite": "^8.0.2",
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.6",
62
- "@vouchfor/eslint-config": "^1.0.1",
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.8cafed9",
65
- "@web/dev-server-esbuild": "^1.0.2",
66
- "@web/test-runner": "^0.18.1",
67
- "@web/test-runner-browserstack": "^0.7.1",
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.3.10",
71
- "lint-staged": "^15.2.2",
72
- "lit": "^3.1.2",
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.2.0",
75
- "react-dom": "^18.2.0",
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.0.2",
81
+ "storybook": "^8.6.12",
80
82
  "svgson": "^5.3.1",
81
- "typescript": "^5.4.3",
82
- "vite": "^5.2.2",
83
- "vite-plugin-commonjs": "^0.10.1",
84
- "vite-plugin-dts": "^3.7.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 { VideoEventDetail } from '@vouchfor/media-player';
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: VideoEventDetail | null = null;
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<VideoEventDetail>) => {
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<VideoEventDetail>) => {
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<VideoEventDetail>) => {
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 { Scene, Scenes, TemplateInstance } from '@vouchfor/canvas-video';
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, 'data' | 'aspectRatio' | 'preload' | 'autoplay' | 'controls'> & {
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
- return this._mediaPlayerRef.value?.scene ?? null;
160
- }
167
+ // get scene(): Scene | null {
168
+ // return this._mediaPlayerRef.value?.scene ?? null;
169
+ // }
161
170
 
162
- get scenes(): Scene[] {
163
- return this._mediaPlayerRef.value?.scenes ?? [];
164
- }
171
+ // get scenes(): Scene[] {
172
+ // return this._mediaPlayerRef.value?.scenes ?? [];
173
+ // }
165
174
 
166
- get sceneConfig(): Scenes | null {
167
- return this._mediaPlayerRef.value?.sceneConfig ?? null;
168
- }
175
+ // get sceneConfig(): Scenes | null {
176
+ // return this._mediaPlayerRef.value?.sceneConfig ?? null;
177
+ // }
169
178
 
170
- get videoState() {
171
- return this._mediaPlayerRef.value?.videoState;
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
- this._mediaPlayerRef.value?.setScene(index);
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 { VideoMap } from '@vouchfor/media-player';
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: VideoMap) {
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('passes', async () => {
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!.videos)?.node?.currentTime ?? 0) > 3;
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!.videos)?.node?.paused).eq(false);
53
+ expect(getVideo(player.mediaPlayer!.media)?.node?.paused).eq(false);
54
54
  player.pause();
55
- expect(getVideo(player.mediaPlayer!.videos)?.node?.paused).eq(true);
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',