@vouchfor/embeds 0.0.0-experiment.df12bef → 0.0.0-experiment.e7e20dd
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 +979 -1453
- 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/src/components/PlayerEmbed/controllers/event-forwarder.d.ts +15 -0
- package/dist/es/src/components/{Embed → PlayerEmbed}/controllers/fetcher.d.ts +5 -4
- package/dist/es/src/components/{Embed/controllers/tracking.d.ts → PlayerEmbed/controllers/tracking/index.d.ts} +14 -11
- package/dist/es/src/components/PlayerEmbed/controllers/tracking/utils.d.ts +17 -0
- package/dist/es/src/components/{Embed → PlayerEmbed}/index.d.ts +28 -21
- package/dist/es/src/components/PlayerEmbed/tests/data.d.ts +3 -0
- package/dist/es/src/index.d.ts +2 -1
- package/dist/iife/dialog-embed/embed.iife.js +1750 -0
- package/dist/iife/dialog-embed/embed.iife.js.map +1 -0
- package/dist/iife/embeds.iife.js +662 -457
- package/dist/iife/embeds.iife.js.map +1 -1
- package/dist/iife/player-embed/embed.iife.js +1612 -0
- package/dist/iife/player-embed/embed.iife.js.map +1 -0
- package/package.json +43 -31
- 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/{Embed/Embed.stories.ts → PlayerEmbed/PlayerEmbed.stories.ts} +26 -14
- package/src/components/{Embed → PlayerEmbed}/controllers/event-forwarder.ts +6 -5
- package/src/components/{Embed → PlayerEmbed}/controllers/fetcher.ts +33 -14
- package/src/components/{Embed/controllers/tracking.ts → PlayerEmbed/controllers/tracking/index.ts} +47 -115
- package/src/components/PlayerEmbed/controllers/tracking/utils.ts +95 -0
- package/src/components/{Embed → PlayerEmbed}/index.ts +71 -27
- package/src/components/PlayerEmbed/tests/PlayerEmbed.spec.ts +80 -0
- package/src/components/PlayerEmbed/tests/data.ts +183 -0
- package/src/index.ts +2 -1
| @@ -0,0 +1,80 @@ | |
| 1 | 
            +
            /* eslint-disable @typescript-eslint/ban-ts-comment */
         | 
| 2 | 
            +
            import { expect, fixture, waitUntil } from '@open-wc/testing';
         | 
| 3 | 
            +
            import { html } from 'lit';
         | 
| 4 | 
            +
            import sinon from 'sinon';
         | 
| 5 | 
            +
             | 
| 6 | 
            +
            import type { PlayerEmbed } from '../index.js';
         | 
| 7 | 
            +
            import type { VideoMap } from '@vouchfor/media-player';
         | 
| 8 | 
            +
             | 
| 9 | 
            +
            import { data } from './data.js';
         | 
| 10 | 
            +
             | 
| 11 | 
            +
            // Can't use typescript aliases with esbuild file transforms apparently
         | 
| 12 | 
            +
            // No idea what a good way to actually build before testing is, the examples give nothing
         | 
| 13 | 
            +
            // https://modern-web.dev/guides/test-runner/typescript/
         | 
| 14 | 
            +
            import '../../../test/lib/embeds.js';
         | 
| 15 | 
            +
             | 
| 16 | 
            +
            function getVideo(videos: VideoMap) {
         | 
| 17 | 
            +
              return Object.values(videos)[0];
         | 
| 18 | 
            +
            }
         | 
| 19 | 
            +
             | 
| 20 | 
            +
            function playerLoaded(player: PlayerEmbed) {
         | 
| 21 | 
            +
              return waitUntil(
         | 
| 22 | 
            +
                () => {
         | 
| 23 | 
            +
                  return player.mediaPlayer?.initialised;
         | 
| 24 | 
            +
                },
         | 
| 25 | 
            +
                'Player has not loaded video',
         | 
| 26 | 
            +
                { timeout: 20000 }
         | 
| 27 | 
            +
              );
         | 
| 28 | 
            +
            }
         | 
| 29 | 
            +
             | 
| 30 | 
            +
            describe('Embeds', () => {
         | 
| 31 | 
            +
              it('passes', async () => {
         | 
| 32 | 
            +
                const player = await fixture<PlayerEmbed>(
         | 
| 33 | 
            +
                  html`<vouch-embed-player env="dev" .data=${data} aspectratio=${1}></vouch-embed-player>`
         | 
| 34 | 
            +
                );
         | 
| 35 | 
            +
                // @ts-ignore - accessing private property
         | 
| 36 | 
            +
                const sendTrackingSpy = sinon.spy(player._trackingController, '_sendTrackingEvent');
         | 
| 37 | 
            +
                // @ts-ignore - accessing private property
         | 
| 38 | 
            +
                const createTrackingSpy = sinon.spy(player._trackingController, '_createTrackingEvent');
         | 
| 39 | 
            +
             | 
| 40 | 
            +
                await playerLoaded(player);
         | 
| 41 | 
            +
                // Have to mute the player because we can't programmatically play videos with sound
         | 
| 42 | 
            +
                player.muted = true;
         | 
| 43 | 
            +
                player.play();
         | 
| 44 | 
            +
                expect(player.paused).eq(false);
         | 
| 45 | 
            +
                await waitUntil(
         | 
| 46 | 
            +
                  () => {
         | 
| 47 | 
            +
                    // Video plays for 3 seconds
         | 
| 48 | 
            +
                    return (getVideo(player.mediaPlayer!.videos)?.node?.currentTime ?? 0) > 3;
         | 
| 49 | 
            +
                  },
         | 
| 50 | 
            +
                  'Video did not play for 3 seconds',
         | 
| 51 | 
            +
                  { timeout: 20000 }
         | 
| 52 | 
            +
                );
         | 
| 53 | 
            +
                expect(getVideo(player.mediaPlayer!.videos)?.node?.paused).eq(false);
         | 
| 54 | 
            +
                player.pause();
         | 
| 55 | 
            +
                expect(getVideo(player.mediaPlayer!.videos)?.node?.paused).eq(true);
         | 
| 56 | 
            +
                expect(sendTrackingSpy.callCount).to.be.eq(0);
         | 
| 57 | 
            +
                // Destroy node because events are sent when node is removed from the document
         | 
| 58 | 
            +
                player.remove();
         | 
| 59 | 
            +
                expect(sendTrackingSpy.callCount).to.be.eq(1);
         | 
| 60 | 
            +
                expect(createTrackingSpy.args[0]).to.eql([
         | 
| 61 | 
            +
                  'VIDEO_PLAYED',
         | 
| 62 | 
            +
                  {
         | 
| 63 | 
            +
                    streamStart: 0
         | 
| 64 | 
            +
                  }
         | 
| 65 | 
            +
                ]);
         | 
| 66 | 
            +
                expect(createTrackingSpy.args[1]).to.eql([
         | 
| 67 | 
            +
                  'VOUCH_RESPONSE_VIEWED',
         | 
| 68 | 
            +
                  {
         | 
| 69 | 
            +
                    answerId: '5c66bb3a-ed68-41a0-a601-a49865104418'
         | 
| 70 | 
            +
                  }
         | 
| 71 | 
            +
                ]);
         | 
| 72 | 
            +
                expect(createTrackingSpy.args[2][0]).to.eq('VIDEO_STREAMED');
         | 
| 73 | 
            +
                // Remove streamStart and streamEnd as these are non-deterministic
         | 
| 74 | 
            +
                expect({ ...createTrackingSpy.args[2][1], streamStart: undefined, streamEnd: undefined }).to.eql({
         | 
| 75 | 
            +
                  answerId: '5c66bb3a-ed68-41a0-a601-a49865104418',
         | 
| 76 | 
            +
                  streamStart: undefined,
         | 
| 77 | 
            +
                  streamEnd: undefined
         | 
| 78 | 
            +
                });
         | 
| 79 | 
            +
              });
         | 
| 80 | 
            +
            });
         | 
| @@ -0,0 +1,183 @@ | |
| 1 | 
            +
            import type { Vouch } from '@vouchfor/video-utils';
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            /* eslint-disable max-lines */
         | 
| 4 | 
            +
            const data = {
         | 
| 5 | 
            +
              id: '85a7f7fb-897c-41a4-be7b-2636cf991f2c',
         | 
| 6 | 
            +
              hashId: '6JQEIPeStt',
         | 
| 7 | 
            +
              questions: {
         | 
| 8 | 
            +
                items: [
         | 
| 9 | 
            +
                  {
         | 
| 10 | 
            +
                    id: '5c66bb3a-ed68-41a0-a601-a49865104418',
         | 
| 11 | 
            +
                    title: `"Emoji": 🇯🇵 🙏
         | 
| 12 | 
            +
                      Arabic: خَرَجَ الوَلَدُ.
         | 
| 13 | 
            +
                      Chinese: 简化字不讲理
         | 
| 14 | 
            +
                      Hebrew: עִבְרִית
         | 
| 15 | 
            +
                      Japanese Kanji: 漢字
         | 
| 16 | 
            +
                      Japanese Hiragana: 平仮名
         | 
| 17 | 
            +
                      Japanese Katakana: 片仮名
         | 
| 18 | 
            +
                      Devangari Hindi: ॳॴॶॷऎऒऔ
         | 
| 19 | 
            +
                      Korean Hangul: 정음/正音
         | 
| 20 | 
            +
                      Cyrillic: АБВГДЕЖЗИКЛМН
         | 
| 21 | 
            +
                      Greek: αβγδ`,
         | 
| 22 | 
            +
                    answer: {
         | 
| 23 | 
            +
                      id: '5c66bb3a-ed68-41a0-a601-a49865104418',
         | 
| 24 | 
            +
                      label: null,
         | 
| 25 | 
            +
                      metadata: {
         | 
| 26 | 
            +
                        duration: 18.5
         | 
| 27 | 
            +
                      },
         | 
| 28 | 
            +
                      settings: {
         | 
| 29 | 
            +
                        endOffset: 0,
         | 
| 30 | 
            +
                        startOffset: 0
         | 
| 31 | 
            +
                      },
         | 
| 32 | 
            +
                      media: {
         | 
| 33 | 
            +
                        input:
         | 
| 34 | 
            +
                          'https://d2rxhdlm2q91uk.cloudfront.net/TVik9uTMgE/6JQEIPeStt/5c66bb3a-ed68-41a0-a601-a49865104418/5c66bb3a-ed68-41a0-a601-a49865104418_input.mp4?Policy=eyJTdGF0ZW1lbnQiOlt7IlJlc291cmNlIjoiaHR0cHM6Ly9kMnJ4aGRsbTJxOTF1ay5jbG91ZGZyb250Lm5ldC9UVmlrOXVUTWdFLyoiLCJDb25kaXRpb24iOnsiRGF0ZUxlc3NUaGFuIjp7IkFXUzpFcG9jaFRpbWUiOjIwMTQ1NDI2MzV9fX1dfQ__&Key-Pair-Id=K2SWKOH0FA5F6M&Signature=vh-ZjBnHDhIIKRe4vr8GHppegY2VIRwXvC~QdX8aV9b5eylmQ~I~EmQ2MKwLOWuQ14DHOF~GU8oAfjXTMWgmZdeu1YzHkDHpQzi1b~NLgipJmpYe9-9OR67MC8jvNTva6OQ5PKsdN6tQBn9vWbBOP5gXEMZLtBP1tsopNu7ZpaUduyPiSVIH5VlWi~KRvMRZnQpHWxfVvnvvxifuk8bODDHh1Ba7MJxrAkdoskzP7xVYO3NbROscTPZ5tKnK9SVt2tnpdW0Aqxj1e2kH6WJhqwgxFfCDqDojMEesx-om71R99U0hMjwDHUF~EDEk6L6wrmD0OfXxbeKd-g5FoTPdJg__',
         | 
| 35 | 
            +
                        video:
         | 
| 36 | 
            +
                          'https://d2rxhdlm2q91uk.cloudfront.net/TVik9uTMgE/6JQEIPeStt/5c66bb3a-ed68-41a0-a601-a49865104418/5c66bb3a-ed68-41a0-a601-a49865104418.mp4?Policy=eyJTdGF0ZW1lbnQiOlt7IlJlc291cmNlIjoiaHR0cHM6Ly9kMnJ4aGRsbTJxOTF1ay5jbG91ZGZyb250Lm5ldC9UVmlrOXVUTWdFLyoiLCJDb25kaXRpb24iOnsiRGF0ZUxlc3NUaGFuIjp7IkFXUzpFcG9jaFRpbWUiOjIwMTQ1NDI2MzV9fX1dfQ__&Key-Pair-Id=K2SWKOH0FA5F6M&Signature=vh-ZjBnHDhIIKRe4vr8GHppegY2VIRwXvC~QdX8aV9b5eylmQ~I~EmQ2MKwLOWuQ14DHOF~GU8oAfjXTMWgmZdeu1YzHkDHpQzi1b~NLgipJmpYe9-9OR67MC8jvNTva6OQ5PKsdN6tQBn9vWbBOP5gXEMZLtBP1tsopNu7ZpaUduyPiSVIH5VlWi~KRvMRZnQpHWxfVvnvvxifuk8bODDHh1Ba7MJxrAkdoskzP7xVYO3NbROscTPZ5tKnK9SVt2tnpdW0Aqxj1e2kH6WJhqwgxFfCDqDojMEesx-om71R99U0hMjwDHUF~EDEk6L6wrmD0OfXxbeKd-g5FoTPdJg__',
         | 
| 37 | 
            +
                        playlist:
         | 
| 38 | 
            +
                          'https://d2rxhdlm2q91uk.cloudfront.net/TVik9uTMgE/6JQEIPeStt/5c66bb3a-ed68-41a0-a601-a49865104418/5c66bb3a-ed68-41a0-a601-a49865104418.m3u8?Policy=eyJTdGF0ZW1lbnQiOlt7IlJlc291cmNlIjoiaHR0cHM6Ly9kMnJ4aGRsbTJxOTF1ay5jbG91ZGZyb250Lm5ldC9UVmlrOXVUTWdFLyoiLCJDb25kaXRpb24iOnsiRGF0ZUxlc3NUaGFuIjp7IkFXUzpFcG9jaFRpbWUiOjIwMTQ1NDI2MzV9fX1dfQ__&Key-Pair-Id=K2SWKOH0FA5F6M&Signature=vh-ZjBnHDhIIKRe4vr8GHppegY2VIRwXvC~QdX8aV9b5eylmQ~I~EmQ2MKwLOWuQ14DHOF~GU8oAfjXTMWgmZdeu1YzHkDHpQzi1b~NLgipJmpYe9-9OR67MC8jvNTva6OQ5PKsdN6tQBn9vWbBOP5gXEMZLtBP1tsopNu7ZpaUduyPiSVIH5VlWi~KRvMRZnQpHWxfVvnvvxifuk8bODDHh1Ba7MJxrAkdoskzP7xVYO3NbROscTPZ5tKnK9SVt2tnpdW0Aqxj1e2kH6WJhqwgxFfCDqDojMEesx-om71R99U0hMjwDHUF~EDEk6L6wrmD0OfXxbeKd-g5FoTPdJg__',
         | 
| 39 | 
            +
                        thumbnail:
         | 
| 40 | 
            +
                          'https://d2rxhdlm2q91uk.cloudfront.net/TVik9uTMgE/6JQEIPeStt/5c66bb3a-ed68-41a0-a601-a49865104418/5c66bb3a-ed68-41a0-a601-a49865104418_poster.0000001.jpg?Policy=eyJTdGF0ZW1lbnQiOlt7IlJlc291cmNlIjoiaHR0cHM6Ly9kMnJ4aGRsbTJxOTF1ay5jbG91ZGZyb250Lm5ldC9UVmlrOXVUTWdFLyoiLCJDb25kaXRpb24iOnsiRGF0ZUxlc3NUaGFuIjp7IkFXUzpFcG9jaFRpbWUiOjIwMTYzMjM0Mjl9fX1dfQ__&Key-Pair-Id=K2SWKOH0FA5F6M&Signature=SGA54MFpy4jaqKJHKEuxRfjk-~NBFAh1tdW9Y6uYJwc0LFjDDgX1sraerSyohmVhj~-QVIrglY5BvglDIhrFcLJWGTkgj4vhyLprk1a7EDckv0HBgp-k1ZKvoDtt3wBOzrL4GicfXBkuMpIu5jv5MY3xemlJj2a6V~h65XJuLO4u-xS~McH6rS3mRxoNl4GcYUVm4upre1DGQx-5Suy6Ateoxl6xxoF8kg5EL02KxkIGiRpwXJTvVmUuVF0rpBj-IE40MfmhLBQ1NNSXiqb3-HjpkKwhYPvB5APVh23mzGmqJ0P3jbr2F1cU4Jvlqsjb6GVP61wGOz9ITeWPZkOy8A__'
         | 
| 41 | 
            +
                      },
         | 
| 42 | 
            +
                      client: {
         | 
| 43 | 
            +
                        id: '03540d70-1c75-4867-a235-bac842ed6ce4',
         | 
| 44 | 
            +
                        name: 'Not Supplied',
         | 
| 45 | 
            +
                        logoSrc: 'https://logo.clearbit.com/vouchfor.com?size=260'
         | 
| 46 | 
            +
                      },
         | 
| 47 | 
            +
                      contact: {
         | 
| 48 | 
            +
                        id: 'b62f62a3-0cd4-4512-9b52-121cb2f3e72f',
         | 
| 49 | 
            +
                        name: 'Aaron Williams'
         | 
| 50 | 
            +
                      },
         | 
| 51 | 
            +
                      captions: {
         | 
| 52 | 
            +
                        current:
         | 
| 53 | 
            +
                          'WEBVTT\n\n1\n00:00:01.549 --> 00:00:05.920\n🇯🇵 🙏 こんにちは 藤森 章 です 。 え ? 今 日本 の え ? 東京 に 住ん で\n\n2\n00:00:05.929 --> 00:00:11.359\nいる 高校 三 年 生 です 。 えっと 父親 が 日本 人 で 母親 が は\n\n3\n00:00:11.619 --> 00:00:13.130\nえー 中国 人 な ん です けれど も 。\n\n4\n00:00:13.939 --> 00:00:17.889\nえ ? 上海 に 行っ た 時 に 国際 学校 に 通っ て い た の で 。\n\n5\n00:00:17.899 --> 00:00:20.389\nえー 英語 を 日本 語 、 中国 語 、 三 語 を しゃ ます\n\n6\n00:00:21.030 --> 00:00:23.549\nえー で 、 その 中 で 経験 し た こと な ん です けれど も 、\n\n7\n00:00:24.040 --> 00:00:26.700\n日本 語 の 素晴らしい ところ って いう の は 、\n\n8\n00:00:27.260 --> 00:00:27.809\nやっぱり\n\n9\n00:00:28.489 --> 00:00:31.540\n和歌 に も 見 られる よう な 多彩 な 表現 力 と\n\n10\n00:00:32.349 --> 00:00:33.819\nえ 奥深い\n\n11\n00:00:34.770 --> 00:00:38.520\nえー 、 感情 表現 など に ある と 思い ます 。 えー これ を 見 て\n\n12\n00:00:38.759 --> 00:00:41.599\n日本 語 に 興味 を 持っ た 方 は 、 是非 その\n\n13\n00:00:43.180 --> 00:00:43.770\n奥深い\n\n14\n00:00:44.299 --> 00:00:45.630\n表現 など を え 、\n\n15\n00:00:46.299 --> 00:00:49.209\n見 て 、 感じ て えー 、 触れ て み て ください 。 ありがとう\n\n16\n00:00:49.220 --> 00:00:49.599\nござい まし た 。\n'
         | 
| 54 | 
            +
                      }
         | 
| 55 | 
            +
                    }
         | 
| 56 | 
            +
                  },
         | 
| 57 | 
            +
                  {
         | 
| 58 | 
            +
                    id: '5c66bb3a-ed68-41a0-a601-a49865104418',
         | 
| 59 | 
            +
                    // title: "What is the business problem you're trying to solve?",
         | 
| 60 | 
            +
                    answer: {
         | 
| 61 | 
            +
                      id: '5c66bb3a-ed68-41a0-a601-a49865104418',
         | 
| 62 | 
            +
                      label: 'Hello this label is overridden',
         | 
| 63 | 
            +
                      metadata: {
         | 
| 64 | 
            +
                        duration: 18.5
         | 
| 65 | 
            +
                      },
         | 
| 66 | 
            +
                      settings: {
         | 
| 67 | 
            +
                        endOffset: 0.385945945945946,
         | 
| 68 | 
            +
                        startOffset: 0.3037837837837838,
         | 
| 69 | 
            +
                        crop: {
         | 
| 70 | 
            +
                          x: 0.4,
         | 
| 71 | 
            +
                          y: 0.4,
         | 
| 72 | 
            +
                          width: 0.4,
         | 
| 73 | 
            +
                          height: 0.4
         | 
| 74 | 
            +
                        }
         | 
| 75 | 
            +
                      },
         | 
| 76 | 
            +
                      media: {
         | 
| 77 | 
            +
                        input:
         | 
| 78 | 
            +
                          'https://d2rxhdlm2q91uk.cloudfront.net/TVik9uTMgE/6JQEIPeStt/5c66bb3a-ed68-41a0-a601-a49865104418/5c66bb3a-ed68-41a0-a601-a49865104418_input.mp4?Policy=eyJTdGF0ZW1lbnQiOlt7IlJlc291cmNlIjoiaHR0cHM6Ly9kMnJ4aGRsbTJxOTF1ay5jbG91ZGZyb250Lm5ldC9UVmlrOXVUTWdFLyoiLCJDb25kaXRpb24iOnsiRGF0ZUxlc3NUaGFuIjp7IkFXUzpFcG9jaFRpbWUiOjIwMTQ1NDI2MzV9fX1dfQ__&Key-Pair-Id=K2SWKOH0FA5F6M&Signature=vh-ZjBnHDhIIKRe4vr8GHppegY2VIRwXvC~QdX8aV9b5eylmQ~I~EmQ2MKwLOWuQ14DHOF~GU8oAfjXTMWgmZdeu1YzHkDHpQzi1b~NLgipJmpYe9-9OR67MC8jvNTva6OQ5PKsdN6tQBn9vWbBOP5gXEMZLtBP1tsopNu7ZpaUduyPiSVIH5VlWi~KRvMRZnQpHWxfVvnvvxifuk8bODDHh1Ba7MJxrAkdoskzP7xVYO3NbROscTPZ5tKnK9SVt2tnpdW0Aqxj1e2kH6WJhqwgxFfCDqDojMEesx-om71R99U0hMjwDHUF~EDEk6L6wrmD0OfXxbeKd-g5FoTPdJg__',
         | 
| 79 | 
            +
                        video:
         | 
| 80 | 
            +
                          'https://d2rxhdlm2q91uk.cloudfront.net/TVik9uTMgE/6JQEIPeStt/5c66bb3a-ed68-41a0-a601-a49865104418/5c66bb3a-ed68-41a0-a601-a49865104418.mp4?Policy=eyJTdGF0ZW1lbnQiOlt7IlJlc291cmNlIjoiaHR0cHM6Ly9kMnJ4aGRsbTJxOTF1ay5jbG91ZGZyb250Lm5ldC9UVmlrOXVUTWdFLyoiLCJDb25kaXRpb24iOnsiRGF0ZUxlc3NUaGFuIjp7IkFXUzpFcG9jaFRpbWUiOjIwMTQ1NDI2MzV9fX1dfQ__&Key-Pair-Id=K2SWKOH0FA5F6M&Signature=vh-ZjBnHDhIIKRe4vr8GHppegY2VIRwXvC~QdX8aV9b5eylmQ~I~EmQ2MKwLOWuQ14DHOF~GU8oAfjXTMWgmZdeu1YzHkDHpQzi1b~NLgipJmpYe9-9OR67MC8jvNTva6OQ5PKsdN6tQBn9vWbBOP5gXEMZLtBP1tsopNu7ZpaUduyPiSVIH5VlWi~KRvMRZnQpHWxfVvnvvxifuk8bODDHh1Ba7MJxrAkdoskzP7xVYO3NbROscTPZ5tKnK9SVt2tnpdW0Aqxj1e2kH6WJhqwgxFfCDqDojMEesx-om71R99U0hMjwDHUF~EDEk6L6wrmD0OfXxbeKd-g5FoTPdJg__',
         | 
| 81 | 
            +
                        playlist:
         | 
| 82 | 
            +
                          'https://d2rxhdlm2q91uk.cloudfront.net/TVik9uTMgE/6JQEIPeStt/5c66bb3a-ed68-41a0-a601-a49865104418/5c66bb3a-ed68-41a0-a601-a49865104418.m3u8?Policy=eyJTdGF0ZW1lbnQiOlt7IlJlc291cmNlIjoiaHR0cHM6Ly9kMnJ4aGRsbTJxOTF1ay5jbG91ZGZyb250Lm5ldC9UVmlrOXVUTWdFLyoiLCJDb25kaXRpb24iOnsiRGF0ZUxlc3NUaGFuIjp7IkFXUzpFcG9jaFRpbWUiOjIwMTQ1NDI2MzV9fX1dfQ__&Key-Pair-Id=K2SWKOH0FA5F6M&Signature=vh-ZjBnHDhIIKRe4vr8GHppegY2VIRwXvC~QdX8aV9b5eylmQ~I~EmQ2MKwLOWuQ14DHOF~GU8oAfjXTMWgmZdeu1YzHkDHpQzi1b~NLgipJmpYe9-9OR67MC8jvNTva6OQ5PKsdN6tQBn9vWbBOP5gXEMZLtBP1tsopNu7ZpaUduyPiSVIH5VlWi~KRvMRZnQpHWxfVvnvvxifuk8bODDHh1Ba7MJxrAkdoskzP7xVYO3NbROscTPZ5tKnK9SVt2tnpdW0Aqxj1e2kH6WJhqwgxFfCDqDojMEesx-om71R99U0hMjwDHUF~EDEk6L6wrmD0OfXxbeKd-g5FoTPdJg__',
         | 
| 83 | 
            +
                        thumbnail:
         | 
| 84 | 
            +
                          'https://d2rxhdlm2q91uk.cloudfront.net/TVik9uTMgE/6JQEIPeStt/5c66bb3a-ed68-41a0-a601-a49865104418/5c66bb3a-ed68-41a0-a601-a49865104418_poster.0000001.jpg?Policy=eyJTdGF0ZW1lbnQiOlt7IlJlc291cmNlIjoiaHR0cHM6Ly9kMnJ4aGRsbTJxOTF1ay5jbG91ZGZyb250Lm5ldC9UVmlrOXVUTWdFLyoiLCJDb25kaXRpb24iOnsiRGF0ZUxlc3NUaGFuIjp7IkFXUzpFcG9jaFRpbWUiOjIwMTYzMjM0Mjl9fX1dfQ__&Key-Pair-Id=K2SWKOH0FA5F6M&Signature=SGA54MFpy4jaqKJHKEuxRfjk-~NBFAh1tdW9Y6uYJwc0LFjDDgX1sraerSyohmVhj~-QVIrglY5BvglDIhrFcLJWGTkgj4vhyLprk1a7EDckv0HBgp-k1ZKvoDtt3wBOzrL4GicfXBkuMpIu5jv5MY3xemlJj2a6V~h65XJuLO4u-xS~McH6rS3mRxoNl4GcYUVm4upre1DGQx-5Suy6Ateoxl6xxoF8kg5EL02KxkIGiRpwXJTvVmUuVF0rpBj-IE40MfmhLBQ1NNSXiqb3-HjpkKwhYPvB5APVh23mzGmqJ0P3jbr2F1cU4Jvlqsjb6GVP61wGOz9ITeWPZkOy8A__'
         | 
| 85 | 
            +
                      },
         | 
| 86 | 
            +
                      client: {
         | 
| 87 | 
            +
                        id: '03540d70-1c75-4867-a235-bac842ed6ce4',
         | 
| 88 | 
            +
                        logoSrc: 'https://logo.clearbit.com/vouchfor.com?size=260'
         | 
| 89 | 
            +
                      },
         | 
| 90 | 
            +
                      contact: {
         | 
| 91 | 
            +
                        id: 'b62f62a3-0cd4-4512-9b52-121cb2f3e72f',
         | 
| 92 | 
            +
                        name: 'Aaron Williams',
         | 
| 93 | 
            +
                        roleTitle: 'Software Engineer'
         | 
| 94 | 
            +
                      },
         | 
| 95 | 
            +
                      captions: {
         | 
| 96 | 
            +
                        current:
         | 
| 97 | 
            +
                          "WEBVTT\r\n\r\n1\r\n00:00:01.710 --> 00:00:05.250\r\nwe are trying to solve, uh, world hunger.\r\n\r\n2\r\n00:00:05.420 --> 00:00:08.369\r\nI think it's an important goal. Uh, we\r\n\r\n3\r\n00:00:08.380 --> 00:00:09.489\r\nalso would like to get rid of\r\n\r\n4\r\n00:00:09.500 --> 00:00:12.050\r\ntuberculosis. Um, in general. And\r\n\r\n5\r\n00:00:12.060 --> 00:00:15.329\r\nprobably malaria, too. Uh, it's gonna be\r\n\r\n6\r\n00:00:15.340 --> 00:00:17.180\r\na couple of weeks, but I think we can do\r\n\r\n7\r\n00:00:17.190 --> 00:00:17.319\r\nit.\r\n"
         | 
| 98 | 
            +
                      }
         | 
| 99 | 
            +
                    }
         | 
| 100 | 
            +
                  },
         | 
| 101 | 
            +
                  {
         | 
| 102 | 
            +
                    id: 'e77c81a7-f6ef-4eae-91fc-b620d092d8d6',
         | 
| 103 | 
            +
                    title: 'What are the priorities for your business/team this quarter?',
         | 
| 104 | 
            +
                    answer: {
         | 
| 105 | 
            +
                      id: 'e77c81a7-f6ef-4eae-91fc-b620d092d8d6',
         | 
| 106 | 
            +
                      label: null,
         | 
| 107 | 
            +
                      metadata: {
         | 
| 108 | 
            +
                        duration: 16.167
         | 
| 109 | 
            +
                      },
         | 
| 110 | 
            +
                      settings: {
         | 
| 111 | 
            +
                        endOffset: 0,
         | 
| 112 | 
            +
                        startOffset: 0
         | 
| 113 | 
            +
                      },
         | 
| 114 | 
            +
                      media: {
         | 
| 115 | 
            +
                        input:
         | 
| 116 | 
            +
                          'https://d2rxhdlm2q91uk.cloudfront.net/TVik9uTMgE/6JQEIPeStt/e77c81a7-f6ef-4eae-91fc-b620d092d8d6/e77c81a7-f6ef-4eae-91fc-b620d092d8d6_input.mp4?Policy=eyJTdGF0ZW1lbnQiOlt7IlJlc291cmNlIjoiaHR0cHM6Ly9kMnJ4aGRsbTJxOTF1ay5jbG91ZGZyb250Lm5ldC9UVmlrOXVUTWdFLyoiLCJDb25kaXRpb24iOnsiRGF0ZUxlc3NUaGFuIjp7IkFXUzpFcG9jaFRpbWUiOjIwMTQ1NDI2MzV9fX1dfQ__&Key-Pair-Id=K2SWKOH0FA5F6M&Signature=vh-ZjBnHDhIIKRe4vr8GHppegY2VIRwXvC~QdX8aV9b5eylmQ~I~EmQ2MKwLOWuQ14DHOF~GU8oAfjXTMWgmZdeu1YzHkDHpQzi1b~NLgipJmpYe9-9OR67MC8jvNTva6OQ5PKsdN6tQBn9vWbBOP5gXEMZLtBP1tsopNu7ZpaUduyPiSVIH5VlWi~KRvMRZnQpHWxfVvnvvxifuk8bODDHh1Ba7MJxrAkdoskzP7xVYO3NbROscTPZ5tKnK9SVt2tnpdW0Aqxj1e2kH6WJhqwgxFfCDqDojMEesx-om71R99U0hMjwDHUF~EDEk6L6wrmD0OfXxbeKd-g5FoTPdJg__',
         | 
| 117 | 
            +
                        video:
         | 
| 118 | 
            +
                          'https://d2rxhdlm2q91uk.cloudfront.net/TVik9uTMgE/6JQEIPeStt/e77c81a7-f6ef-4eae-91fc-b620d092d8d6/e77c81a7-f6ef-4eae-91fc-b620d092d8d6.mp4?Policy=eyJTdGF0ZW1lbnQiOlt7IlJlc291cmNlIjoiaHR0cHM6Ly9kMnJ4aGRsbTJxOTF1ay5jbG91ZGZyb250Lm5ldC9UVmlrOXVUTWdFLyoiLCJDb25kaXRpb24iOnsiRGF0ZUxlc3NUaGFuIjp7IkFXUzpFcG9jaFRpbWUiOjIwMTQ1NDI2MzV9fX1dfQ__&Key-Pair-Id=K2SWKOH0FA5F6M&Signature=vh-ZjBnHDhIIKRe4vr8GHppegY2VIRwXvC~QdX8aV9b5eylmQ~I~EmQ2MKwLOWuQ14DHOF~GU8oAfjXTMWgmZdeu1YzHkDHpQzi1b~NLgipJmpYe9-9OR67MC8jvNTva6OQ5PKsdN6tQBn9vWbBOP5gXEMZLtBP1tsopNu7ZpaUduyPiSVIH5VlWi~KRvMRZnQpHWxfVvnvvxifuk8bODDHh1Ba7MJxrAkdoskzP7xVYO3NbROscTPZ5tKnK9SVt2tnpdW0Aqxj1e2kH6WJhqwgxFfCDqDojMEesx-om71R99U0hMjwDHUF~EDEk6L6wrmD0OfXxbeKd-g5FoTPdJg__',
         | 
| 119 | 
            +
                        playlist:
         | 
| 120 | 
            +
                          'https://d2rxhdlm2q91uk.cloudfront.net/TVik9uTMgE/6JQEIPeStt/e77c81a7-f6ef-4eae-91fc-b620d092d8d6/e77c81a7-f6ef-4eae-91fc-b620d092d8d6.m3u8?Policy=eyJTdGF0ZW1lbnQiOlt7IlJlc291cmNlIjoiaHR0cHM6Ly9kMnJ4aGRsbTJxOTF1ay5jbG91ZGZyb250Lm5ldC9UVmlrOXVUTWdFLyoiLCJDb25kaXRpb24iOnsiRGF0ZUxlc3NUaGFuIjp7IkFXUzpFcG9jaFRpbWUiOjIwMTQ1NDI2MzV9fX1dfQ__&Key-Pair-Id=K2SWKOH0FA5F6M&Signature=vh-ZjBnHDhIIKRe4vr8GHppegY2VIRwXvC~QdX8aV9b5eylmQ~I~EmQ2MKwLOWuQ14DHOF~GU8oAfjXTMWgmZdeu1YzHkDHpQzi1b~NLgipJmpYe9-9OR67MC8jvNTva6OQ5PKsdN6tQBn9vWbBOP5gXEMZLtBP1tsopNu7ZpaUduyPiSVIH5VlWi~KRvMRZnQpHWxfVvnvvxifuk8bODDHh1Ba7MJxrAkdoskzP7xVYO3NbROscTPZ5tKnK9SVt2tnpdW0Aqxj1e2kH6WJhqwgxFfCDqDojMEesx-om71R99U0hMjwDHUF~EDEk6L6wrmD0OfXxbeKd-g5FoTPdJg__',
         | 
| 121 | 
            +
                        thumbnail:
         | 
| 122 | 
            +
                          'https://d2rxhdlm2q91uk.cloudfront.net/TVik9uTMgE/6JQEIPeStt/e77c81a7-f6ef-4eae-91fc-b620d092d8d6/e77c81a7-f6ef-4eae-91fc-b620d092d8d6_poster.0000001.jpg?Policy=eyJTdGF0ZW1lbnQiOlt7IlJlc291cmNlIjoiaHR0cHM6Ly9kMnJ4aGRsbTJxOTF1ay5jbG91ZGZyb250Lm5ldC9UVmlrOXVUTWdFLyoiLCJDb25kaXRpb24iOnsiRGF0ZUxlc3NUaGFuIjp7IkFXUzpFcG9jaFRpbWUiOjIwMTYzMjM0Mjl9fX1dfQ__&Key-Pair-Id=K2SWKOH0FA5F6M&Signature=SGA54MFpy4jaqKJHKEuxRfjk-~NBFAh1tdW9Y6uYJwc0LFjDDgX1sraerSyohmVhj~-QVIrglY5BvglDIhrFcLJWGTkgj4vhyLprk1a7EDckv0HBgp-k1ZKvoDtt3wBOzrL4GicfXBkuMpIu5jv5MY3xemlJj2a6V~h65XJuLO4u-xS~McH6rS3mRxoNl4GcYUVm4upre1DGQx-5Suy6Ateoxl6xxoF8kg5EL02KxkIGiRpwXJTvVmUuVF0rpBj-IE40MfmhLBQ1NNSXiqb3-HjpkKwhYPvB5APVh23mzGmqJ0P3jbr2F1cU4Jvlqsjb6GVP61wGOz9ITeWPZkOy8A__'
         | 
| 123 | 
            +
                      },
         | 
| 124 | 
            +
                      client: {
         | 
| 125 | 
            +
                        id: '03540d70-1c75-4867-a235-bac842ed6ce4',
         | 
| 126 | 
            +
                        name: 'Vouch',
         | 
| 127 | 
            +
                        logoSrc: 'https://logo.clearbit.com/vouchfor.com?size=260'
         | 
| 128 | 
            +
                      },
         | 
| 129 | 
            +
                      contact: {
         | 
| 130 | 
            +
                        id: 'b62f62a3-0cd4-4512-9b52-121cb2f3e72f',
         | 
| 131 | 
            +
                        name: 'Aaron Williams',
         | 
| 132 | 
            +
                        roleTitle: 'Software Engineer'
         | 
| 133 | 
            +
                      },
         | 
| 134 | 
            +
                      captions: {
         | 
| 135 | 
            +
                        current:
         | 
| 136 | 
            +
                          'WEBVTT\r\n\r\n1\r\n00:00:00.709 --> 00:00:03.059\r\npriorities for this business. Uh, for\r\n\r\n2\r\n00:00:03.069 --> 00:00:06.010\r\nthis quarter, uh, to make more money,\r\n\r\n3\r\n00:00:06.019 --> 00:00:09.050\r\nmore profits, Uh, get everything, uh,\r\n\r\n4\r\n00:00:09.069 --> 00:00:13.439\r\nswept away. All our heuristics should be\r\n\r\n5\r\n00:00:13.529 --> 00:00:15.119\r\ntop of the line.\r\n'
         | 
| 137 | 
            +
                      }
         | 
| 138 | 
            +
                    }
         | 
| 139 | 
            +
                  },
         | 
| 140 | 
            +
                  {
         | 
| 141 | 
            +
                    id: '39fd188d-a4dc-43b9-bac8-32fd71bfbc90',
         | 
| 142 | 
            +
                    title: 'What are your biggest pain points?',
         | 
| 143 | 
            +
                    answer: {
         | 
| 144 | 
            +
                      id: '39fd188d-a4dc-43b9-bac8-32fd71bfbc90',
         | 
| 145 | 
            +
                      label: null,
         | 
| 146 | 
            +
                      metadata: {
         | 
| 147 | 
            +
                        duration: 13.792
         | 
| 148 | 
            +
                      },
         | 
| 149 | 
            +
                      settings: {
         | 
| 150 | 
            +
                        endOffset: 0,
         | 
| 151 | 
            +
                        startOffset: 0
         | 
| 152 | 
            +
                      },
         | 
| 153 | 
            +
                      media: {
         | 
| 154 | 
            +
                        input:
         | 
| 155 | 
            +
                          'https://d2rxhdlm2q91uk.cloudfront.net/TVik9uTMgE/6JQEIPeStt/39fd188d-a4dc-43b9-bac8-32fd71bfbc90/39fd188d-a4dc-43b9-bac8-32fd71bfbc90_input.mp4?Policy=eyJTdGF0ZW1lbnQiOlt7IlJlc291cmNlIjoiaHR0cHM6Ly9kMnJ4aGRsbTJxOTF1ay5jbG91ZGZyb250Lm5ldC9UVmlrOXVUTWdFLyoiLCJDb25kaXRpb24iOnsiRGF0ZUxlc3NUaGFuIjp7IkFXUzpFcG9jaFRpbWUiOjIwMTQ1NDI2MzV9fX1dfQ__&Key-Pair-Id=K2SWKOH0FA5F6M&Signature=vh-ZjBnHDhIIKRe4vr8GHppegY2VIRwXvC~QdX8aV9b5eylmQ~I~EmQ2MKwLOWuQ14DHOF~GU8oAfjXTMWgmZdeu1YzHkDHpQzi1b~NLgipJmpYe9-9OR67MC8jvNTva6OQ5PKsdN6tQBn9vWbBOP5gXEMZLtBP1tsopNu7ZpaUduyPiSVIH5VlWi~KRvMRZnQpHWxfVvnvvxifuk8bODDHh1Ba7MJxrAkdoskzP7xVYO3NbROscTPZ5tKnK9SVt2tnpdW0Aqxj1e2kH6WJhqwgxFfCDqDojMEesx-om71R99U0hMjwDHUF~EDEk6L6wrmD0OfXxbeKd-g5FoTPdJg__',
         | 
| 156 | 
            +
                        video:
         | 
| 157 | 
            +
                          'https://d2rxhdlm2q91uk.cloudfront.net/TVik9uTMgE/6JQEIPeStt/39fd188d-a4dc-43b9-bac8-32fd71bfbc90/39fd188d-a4dc-43b9-bac8-32fd71bfbc90.mp4?Policy=eyJTdGF0ZW1lbnQiOlt7IlJlc291cmNlIjoiaHR0cHM6Ly9kMnJ4aGRsbTJxOTF1ay5jbG91ZGZyb250Lm5ldC9UVmlrOXVUTWdFLyoiLCJDb25kaXRpb24iOnsiRGF0ZUxlc3NUaGFuIjp7IkFXUzpFcG9jaFRpbWUiOjIwMTQ1NDI2MzV9fX1dfQ__&Key-Pair-Id=K2SWKOH0FA5F6M&Signature=vh-ZjBnHDhIIKRe4vr8GHppegY2VIRwXvC~QdX8aV9b5eylmQ~I~EmQ2MKwLOWuQ14DHOF~GU8oAfjXTMWgmZdeu1YzHkDHpQzi1b~NLgipJmpYe9-9OR67MC8jvNTva6OQ5PKsdN6tQBn9vWbBOP5gXEMZLtBP1tsopNu7ZpaUduyPiSVIH5VlWi~KRvMRZnQpHWxfVvnvvxifuk8bODDHh1Ba7MJxrAkdoskzP7xVYO3NbROscTPZ5tKnK9SVt2tnpdW0Aqxj1e2kH6WJhqwgxFfCDqDojMEesx-om71R99U0hMjwDHUF~EDEk6L6wrmD0OfXxbeKd-g5FoTPdJg__',
         | 
| 158 | 
            +
                        playlist:
         | 
| 159 | 
            +
                          'https://d2rxhdlm2q91uk.cloudfront.net/TVik9uTMgE/6JQEIPeStt/39fd188d-a4dc-43b9-bac8-32fd71bfbc90/39fd188d-a4dc-43b9-bac8-32fd71bfbc90.m3u8?Policy=eyJTdGF0ZW1lbnQiOlt7IlJlc291cmNlIjoiaHR0cHM6Ly9kMnJ4aGRsbTJxOTF1ay5jbG91ZGZyb250Lm5ldC9UVmlrOXVUTWdFLyoiLCJDb25kaXRpb24iOnsiRGF0ZUxlc3NUaGFuIjp7IkFXUzpFcG9jaFRpbWUiOjIwMTQ1NDI2MzV9fX1dfQ__&Key-Pair-Id=K2SWKOH0FA5F6M&Signature=vh-ZjBnHDhIIKRe4vr8GHppegY2VIRwXvC~QdX8aV9b5eylmQ~I~EmQ2MKwLOWuQ14DHOF~GU8oAfjXTMWgmZdeu1YzHkDHpQzi1b~NLgipJmpYe9-9OR67MC8jvNTva6OQ5PKsdN6tQBn9vWbBOP5gXEMZLtBP1tsopNu7ZpaUduyPiSVIH5VlWi~KRvMRZnQpHWxfVvnvvxifuk8bODDHh1Ba7MJxrAkdoskzP7xVYO3NbROscTPZ5tKnK9SVt2tnpdW0Aqxj1e2kH6WJhqwgxFfCDqDojMEesx-om71R99U0hMjwDHUF~EDEk6L6wrmD0OfXxbeKd-g5FoTPdJg__',
         | 
| 160 | 
            +
                        thumbnail:
         | 
| 161 | 
            +
                          'https://d2rxhdlm2q91uk.cloudfront.net/TVik9uTMgE/6JQEIPeStt/39fd188d-a4dc-43b9-bac8-32fd71bfbc90/39fd188d-a4dc-43b9-bac8-32fd71bfbc90_poster.0000001.jpg?Policy=eyJTdGF0ZW1lbnQiOlt7IlJlc291cmNlIjoiaHR0cHM6Ly9kMnJ4aGRsbTJxOTF1ay5jbG91ZGZyb250Lm5ldC9UVmlrOXVUTWdFLyoiLCJDb25kaXRpb24iOnsiRGF0ZUxlc3NUaGFuIjp7IkFXUzpFcG9jaFRpbWUiOjIwMTYzMjM0Mjl9fX1dfQ__&Key-Pair-Id=K2SWKOH0FA5F6M&Signature=SGA54MFpy4jaqKJHKEuxRfjk-~NBFAh1tdW9Y6uYJwc0LFjDDgX1sraerSyohmVhj~-QVIrglY5BvglDIhrFcLJWGTkgj4vhyLprk1a7EDckv0HBgp-k1ZKvoDtt3wBOzrL4GicfXBkuMpIu5jv5MY3xemlJj2a6V~h65XJuLO4u-xS~McH6rS3mRxoNl4GcYUVm4upre1DGQx-5Suy6Ateoxl6xxoF8kg5EL02KxkIGiRpwXJTvVmUuVF0rpBj-IE40MfmhLBQ1NNSXiqb3-HjpkKwhYPvB5APVh23mzGmqJ0P3jbr2F1cU4Jvlqsjb6GVP61wGOz9ITeWPZkOy8A__'
         | 
| 162 | 
            +
                      },
         | 
| 163 | 
            +
                      client: {
         | 
| 164 | 
            +
                        id: '03540d70-1c75-4867-a235-bac842ed6ce4',
         | 
| 165 | 
            +
                        name: 'Vouch',
         | 
| 166 | 
            +
                        logoSrc: 'https://logo.clearbit.com/vouchfor.com?size=260'
         | 
| 167 | 
            +
                      },
         | 
| 168 | 
            +
                      contact: {
         | 
| 169 | 
            +
                        id: 'b62f62a3-0cd4-4512-9b52-121cb2f3e72f',
         | 
| 170 | 
            +
                        name: 'Aaron Williams',
         | 
| 171 | 
            +
                        roleTitle: 'Software Engineer'
         | 
| 172 | 
            +
                      },
         | 
| 173 | 
            +
                      captions: {
         | 
| 174 | 
            +
                        current:
         | 
| 175 | 
            +
                          "WEBVTT\r\n\r\n1\r\n00:00:00.790 --> 00:00:03.269\r\nuh, the biggest pain points this this\r\n\r\n2\r\n00:00:03.279 --> 00:00:07.170\r\nquarter. Um, Jerry has been doing the\r\n\r\n3\r\n00:00:07.179 --> 00:00:09.180\r\nworst work that he's ever been doing.\r\n\r\n4\r\n00:00:09.390 --> 00:00:11.680\r\nAnd we must fire him, Jerry. Goodbye,\r\n\r\n5\r\n00:00:11.689 --> 00:00:12.149\r\nJerry.\r\n"
         | 
| 176 | 
            +
                      }
         | 
| 177 | 
            +
                    }
         | 
| 178 | 
            +
                  }
         | 
| 179 | 
            +
                ]
         | 
| 180 | 
            +
              }
         | 
| 181 | 
            +
            } as Vouch;
         | 
| 182 | 
            +
             | 
| 183 | 
            +
            export { data };
         | 
    
        package/src/index.ts
    CHANGED
    
    | @@ -1 +1,2 @@ | |
| 1 | 
            -
            export {  | 
| 1 | 
            +
            export { PlayerEmbed } from '~/components/PlayerEmbed';
         | 
| 2 | 
            +
            export { DialogEmbed } from '~/components/DialogEmbed';
         |