design-angular-kit 1.2.2 → 1.3.0
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/assets/i18n/en.json +89 -0
- package/assets/i18n/it.json +89 -0
- package/esm2022/lib/abstracts/abstract-form.component.mjs +19 -6
- package/esm2022/lib/components/core/carousel/carousel/carousel.component.mjs +8 -6
- package/esm2022/lib/components/core/video-player/video-player-i18n.model.mjs +2 -0
- package/esm2022/lib/components/core/video-player/video-player-i18n.service.mjs +130 -0
- package/esm2022/lib/components/core/video-player/video-player.component.mjs +303 -0
- package/esm2022/lib/components/core/video-player/video-player.config.mjs +43 -0
- package/esm2022/lib/components/core/video-player/video-player.cookie.mjs +25 -0
- package/esm2022/lib/components/core/video-player/video-player.model.mjs +3 -0
- package/esm2022/lib/components/core/video-player/video-player.module.mjs +16 -0
- package/esm2022/lib/components/form/autocomplete/autocomplete.component.mjs +144 -78
- package/esm2022/lib/components/form/form.module.mjs +6 -2
- package/esm2022/lib/components/form/input/input.component.mjs +3 -3
- package/esm2022/lib/components/form/search/search.component.mjs +112 -0
- package/esm2022/lib/components/navigation/navscroll/navscroll-list-item.component.mjs +2 -3
- package/esm2022/lib/design-angular-kit.module.mjs +8 -4
- package/esm2022/lib/interfaces/form.mjs +1 -1
- package/esm2022/lib/validators/it-validators.mjs +6 -1
- package/esm2022/public_api.mjs +7 -3
- package/fesm2022/design-angular-kit.mjs +782 -90
- package/fesm2022/design-angular-kit.mjs.map +1 -1
- package/lib/abstracts/abstract-form.component.d.ts +6 -4
- package/lib/components/core/carousel/carousel/carousel.component.d.ts +1 -1
- package/lib/components/core/video-player/video-player-i18n.model.d.ts +179 -0
- package/lib/components/core/video-player/video-player-i18n.service.d.ts +17 -0
- package/lib/components/core/video-player/video-player.component.d.ts +48 -0
- package/lib/components/core/video-player/video-player.config.d.ts +68 -0
- package/lib/components/core/video-player/video-player.cookie.d.ts +6 -0
- package/lib/components/core/video-player/video-player.model.d.ts +44 -0
- package/lib/components/core/video-player/video-player.module.d.ts +7 -0
- package/lib/components/form/autocomplete/autocomplete.component.d.ts +55 -39
- package/lib/components/form/form.module.d.ts +13 -12
- package/lib/components/form/search/search.component.d.ts +59 -0
- package/lib/design-angular-kit.module.d.ts +18 -17
- package/lib/interfaces/form.d.ts +3 -3
- package/lib/validators/it-validators.d.ts +1 -0
- package/package.json +20 -7
- package/public_api.d.ts +6 -2
|
@@ -0,0 +1,130 @@
|
|
|
1
|
+
import { inject, Injectable } from '@angular/core';
|
|
2
|
+
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
3
|
+
import { TranslateService } from '@ngx-translate/core';
|
|
4
|
+
import { tap } from 'rxjs';
|
|
5
|
+
import videojs from 'video.js';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
export class VideoPlayerI18nService {
|
|
8
|
+
#translate = inject(TranslateService);
|
|
9
|
+
init(player, destroyRef) {
|
|
10
|
+
this.#translate.onLangChange
|
|
11
|
+
.pipe(takeUntilDestroyed(destroyRef), tap({
|
|
12
|
+
next: e => {
|
|
13
|
+
const language = e.lang;
|
|
14
|
+
videojs.addLanguage(language, this.getTranslations());
|
|
15
|
+
player.language(language);
|
|
16
|
+
},
|
|
17
|
+
}))
|
|
18
|
+
.subscribe(x => {
|
|
19
|
+
console.log('onLangChange', x);
|
|
20
|
+
});
|
|
21
|
+
}
|
|
22
|
+
getLanguage() {
|
|
23
|
+
const language = this.#translate.currentLang ?? 'it';
|
|
24
|
+
return {
|
|
25
|
+
languages: { [language]: mapToVideoJsTranslation(this.#translate.instant('it.video-player')) },
|
|
26
|
+
language,
|
|
27
|
+
};
|
|
28
|
+
}
|
|
29
|
+
getTranslations() {
|
|
30
|
+
return mapToVideoJsTranslation(this.#translate.instant('it.video-player'));
|
|
31
|
+
}
|
|
32
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: VideoPlayerI18nService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
33
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: VideoPlayerI18nService, providedIn: 'root' }); }
|
|
34
|
+
}
|
|
35
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: VideoPlayerI18nService, decorators: [{
|
|
36
|
+
type: Injectable,
|
|
37
|
+
args: [{ providedIn: 'root' }]
|
|
38
|
+
}] });
|
|
39
|
+
function mapToVideoJsTranslation(translations) {
|
|
40
|
+
return {
|
|
41
|
+
'Audio Player': translations['audio-player'],
|
|
42
|
+
'Video Player': translations['video-player'],
|
|
43
|
+
Play: translations.play,
|
|
44
|
+
Pause: translations.pause,
|
|
45
|
+
Replay: translations.replay,
|
|
46
|
+
'Current Time': translations['current-time'],
|
|
47
|
+
Duration: translations.duration,
|
|
48
|
+
'Remaining Time': translations['remaining-time'],
|
|
49
|
+
'Stream Type': translations['stream-type'],
|
|
50
|
+
LIVE: translations.live,
|
|
51
|
+
Loaded: translations.loaded,
|
|
52
|
+
Progress: translations.progress,
|
|
53
|
+
'Progress Bar': translations['progress-bar'],
|
|
54
|
+
'progress bar timing: currentTime={1} duration={2}': translations['progress-bar-timing:-currenttime={1}-duration={2}'],
|
|
55
|
+
Fullscreen: translations.fullscreen,
|
|
56
|
+
'Exit Fullscreen': translations['exit-fullscreen'],
|
|
57
|
+
Mute: translations.mute,
|
|
58
|
+
Unmute: translations.unmute,
|
|
59
|
+
'Playback Rate': translations['playback-rate'],
|
|
60
|
+
Subtitles: translations.subtitles,
|
|
61
|
+
'subtitles off': translations['subtitles-off'],
|
|
62
|
+
Captions: translations.captions,
|
|
63
|
+
'captions off': translations['captions-off'],
|
|
64
|
+
Chapters: translations.chapters,
|
|
65
|
+
Descriptions: translations.descriptions,
|
|
66
|
+
'descriptions off': translations['descriptions-off'],
|
|
67
|
+
'Audio Track': translations['audio-track'],
|
|
68
|
+
'Volume Level': translations['volume-level'],
|
|
69
|
+
'You aborted the media playback': translations['you-aborted-the-media-playback'],
|
|
70
|
+
'A network error caused the media download to fail part-way.': translations['a-network-error-caused-the-media-download-to-fail-part-way.'],
|
|
71
|
+
'The media could not be loaded, either because the server or network failed or because the format is not supported.': translations['the-media-could-not-be-loaded,-either-because-the-server-or-network-failed-or-because-the-format-is-not-supported.'],
|
|
72
|
+
'The media playback was aborted due to a corruption problem or because the media used features your browser did not support.': translations['the-media-playback-was-aborted-due-to-a-corruption-problem-or-because-the-media-used-features-your-browser-did-not-support.'],
|
|
73
|
+
'No compatible source was found for this media.': translations['no-compatible-source-was-found-for-this-media.'],
|
|
74
|
+
'The media is encrypted and we do not have the keys to decrypt it.': translations['the-media-is-encrypted-and-we-do-not-have-the-keys-to-decrypt-it.'],
|
|
75
|
+
'Play Video': translations['play-video'],
|
|
76
|
+
Close: translations.close,
|
|
77
|
+
'Close Modal Dialog': translations['close-modal-dialog'],
|
|
78
|
+
'Modal Window': translations['modal-window'],
|
|
79
|
+
'This is a modal window': translations['this-is-a-modal-window'],
|
|
80
|
+
'This modal can be closed by pressing the Escape key or activating the close button.': translations['this-modal-can-be-closed-by-pressing-the-escape-key-or-activating-the-close-button.'],
|
|
81
|
+
', opens captions settings dialog': translations[',-opens-captions-settings-dialog'],
|
|
82
|
+
', opens subtitles settings dialog': translations[',-opens-subtitles-settings-dialog'],
|
|
83
|
+
', opens descriptions settings dialog': translations[',-opens-descriptions-settings-dialog'],
|
|
84
|
+
', selected': translations[',-selected'],
|
|
85
|
+
'captions settings': translations['captions-settings'],
|
|
86
|
+
'subtitles settings': translations['subtitles-settings'],
|
|
87
|
+
'descriptions settings': translations['descriptions-settings'],
|
|
88
|
+
Text: translations.text,
|
|
89
|
+
White: translations.white,
|
|
90
|
+
Black: translations.black,
|
|
91
|
+
Red: translations.red,
|
|
92
|
+
Green: translations.green,
|
|
93
|
+
Blue: translations.blue,
|
|
94
|
+
Yellow: translations.yellow,
|
|
95
|
+
Magenta: translations.magenta,
|
|
96
|
+
Cyan: translations.cyan,
|
|
97
|
+
Background: translations.background,
|
|
98
|
+
Window: translations.window,
|
|
99
|
+
Transparent: translations.transparent,
|
|
100
|
+
'Semi-Transparent': translations['semi-transparent'],
|
|
101
|
+
Opaque: translations.opaque,
|
|
102
|
+
'Font Size': translations['font-size'],
|
|
103
|
+
'Text Edge Style': translations['text-edge-style'],
|
|
104
|
+
None: translations.none,
|
|
105
|
+
Uniform: translations.uniform,
|
|
106
|
+
'Drop shadow': translations['drop-shadow'],
|
|
107
|
+
'Font Family': translations['font-family'],
|
|
108
|
+
'Proportional Sans-Serif': translations['proportional-sans-serif'],
|
|
109
|
+
'Monospace Sans-Serif': translations['monospace-sans-serif'],
|
|
110
|
+
'Proportional Serif': translations['proportional-serif'],
|
|
111
|
+
'Monospace Serif': translations['monospace-serif'],
|
|
112
|
+
'Small Caps': translations['small-caps'],
|
|
113
|
+
Reset: translations.reset,
|
|
114
|
+
'restore all settings to the default values': translations['restore-all-settings-to-the-default-values'],
|
|
115
|
+
Done: translations.done,
|
|
116
|
+
'Caption Settings Dialog': translations['caption-settings-dialog'],
|
|
117
|
+
'Beginning of dialog window. Escape will cancel and close the window.': translations['beginning-of-dialog-window.-escape-will-cancel-and-close-the-window.'],
|
|
118
|
+
'End of dialog window.': translations['end-of-dialog-window.'],
|
|
119
|
+
'{1} is loading.': translations['{1}-is-loading.'],
|
|
120
|
+
'Exit Picture-in-Picture': translations['exit-picture-in-picture'],
|
|
121
|
+
'Picture-in-Picture': translations['picture-in-picture'],
|
|
122
|
+
Color: translations.color,
|
|
123
|
+
Opacity: translations.opacity,
|
|
124
|
+
'Text Background': translations['text-background'],
|
|
125
|
+
'Caption Area Background': translations['caption-area-background'],
|
|
126
|
+
'Skip forward {1} seconds': translations['skip-forward-{1}-seconds'],
|
|
127
|
+
'Skip backward {1} seconds': translations['skip-backward-{1}-seconds'],
|
|
128
|
+
};
|
|
129
|
+
}
|
|
130
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"video-player-i18n.service.js","sourceRoot":"","sources":["../../../../../../../projects/design-angular-kit/src/lib/components/core/video-player/video-player-i18n.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { DestroyRef, inject, Injectable } from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { TranslateService } from '@ngx-translate/core';\nimport { tap } from 'rxjs';\nimport videojs from 'video.js';\nimport Player from 'video.js/dist/types/player';\nimport { VideoJsTranslation, VideoPlayerTranslations } from './video-player-i18n.model';\n\n@Injectable({ providedIn: 'root' })\nexport class VideoPlayerI18nService {\n  readonly #translate = inject(TranslateService);\n\n  init(player: Player, destroyRef: DestroyRef) {\n    this.#translate.onLangChange\n      .pipe(\n        takeUntilDestroyed(destroyRef),\n        tap({\n          next: e => {\n            const language = e.lang;\n            videojs.addLanguage(language, this.getTranslations());\n            player.language(language);\n          },\n        })\n      )\n      .subscribe(x => {\n        console.log('onLangChange', x);\n      });\n  }\n\n  getLanguage() {\n    const language = this.#translate.currentLang ?? 'it';\n\n    return {\n      languages: { [language]: mapToVideoJsTranslation(this.#translate.instant('it.video-player')) },\n      language,\n    };\n  }\n\n  private getTranslations() {\n    return mapToVideoJsTranslation(this.#translate.instant('it.video-player'));\n  }\n}\n\nfunction mapToVideoJsTranslation(translations: VideoPlayerTranslations): VideoJsTranslation {\n  return {\n    'Audio Player': translations['audio-player'],\n    'Video Player': translations['video-player'],\n    Play: translations.play,\n    Pause: translations.pause,\n    Replay: translations.replay,\n    'Current Time': translations['current-time'],\n    Duration: translations.duration,\n    'Remaining Time': translations['remaining-time'],\n    'Stream Type': translations['stream-type'],\n    LIVE: translations.live,\n    Loaded: translations.loaded,\n    Progress: translations.progress,\n    'Progress Bar': translations['progress-bar'],\n    'progress bar timing: currentTime={1} duration={2}': translations['progress-bar-timing:-currenttime={1}-duration={2}'],\n    Fullscreen: translations.fullscreen,\n    'Exit Fullscreen': translations['exit-fullscreen'],\n    Mute: translations.mute,\n    Unmute: translations.unmute,\n    'Playback Rate': translations['playback-rate'],\n    Subtitles: translations.subtitles,\n    'subtitles off': translations['subtitles-off'],\n    Captions: translations.captions,\n    'captions off': translations['captions-off'],\n    Chapters: translations.chapters,\n    Descriptions: translations.descriptions,\n    'descriptions off': translations['descriptions-off'],\n    'Audio Track': translations['audio-track'],\n    'Volume Level': translations['volume-level'],\n    'You aborted the media playback': translations['you-aborted-the-media-playback'],\n    'A network error caused the media download to fail part-way.':\n      translations['a-network-error-caused-the-media-download-to-fail-part-way.'],\n    'The media could not be loaded, either because the server or network failed or because the format is not supported.':\n      translations['the-media-could-not-be-loaded,-either-because-the-server-or-network-failed-or-because-the-format-is-not-supported.'],\n    'The media playback was aborted due to a corruption problem or because the media used features your browser did not support.':\n      translations[\n        'the-media-playback-was-aborted-due-to-a-corruption-problem-or-because-the-media-used-features-your-browser-did-not-support.'\n      ],\n    'No compatible source was found for this media.': translations['no-compatible-source-was-found-for-this-media.'],\n    'The media is encrypted and we do not have the keys to decrypt it.':\n      translations['the-media-is-encrypted-and-we-do-not-have-the-keys-to-decrypt-it.'],\n    'Play Video': translations['play-video'],\n    Close: translations.close,\n    'Close Modal Dialog': translations['close-modal-dialog'],\n    'Modal Window': translations['modal-window'],\n    'This is a modal window': translations['this-is-a-modal-window'],\n    'This modal can be closed by pressing the Escape key or activating the close button.':\n      translations['this-modal-can-be-closed-by-pressing-the-escape-key-or-activating-the-close-button.'],\n    ', opens captions settings dialog': translations[',-opens-captions-settings-dialog'],\n    ', opens subtitles settings dialog': translations[',-opens-subtitles-settings-dialog'],\n    ', opens descriptions settings dialog': translations[',-opens-descriptions-settings-dialog'],\n    ', selected': translations[',-selected'],\n    'captions settings': translations['captions-settings'],\n    'subtitles settings': translations['subtitles-settings'],\n    'descriptions settings': translations['descriptions-settings'],\n    Text: translations.text,\n    White: translations.white,\n    Black: translations.black,\n    Red: translations.red,\n    Green: translations.green,\n    Blue: translations.blue,\n    Yellow: translations.yellow,\n    Magenta: translations.magenta,\n    Cyan: translations.cyan,\n    Background: translations.background,\n    Window: translations.window,\n    Transparent: translations.transparent,\n    'Semi-Transparent': translations['semi-transparent'],\n    Opaque: translations.opaque,\n    'Font Size': translations['font-size'],\n    'Text Edge Style': translations['text-edge-style'],\n    None: translations.none,\n    Uniform: translations.uniform,\n    'Drop shadow': translations['drop-shadow'],\n    'Font Family': translations['font-family'],\n    'Proportional Sans-Serif': translations['proportional-sans-serif'],\n    'Monospace Sans-Serif': translations['monospace-sans-serif'],\n    'Proportional Serif': translations['proportional-serif'],\n    'Monospace Serif': translations['monospace-serif'],\n    'Small Caps': translations['small-caps'],\n    Reset: translations.reset,\n    'restore all settings to the default values': translations['restore-all-settings-to-the-default-values'],\n    Done: translations.done,\n    'Caption Settings Dialog': translations['caption-settings-dialog'],\n    'Beginning of dialog window. Escape will cancel and close the window.':\n      translations['beginning-of-dialog-window.-escape-will-cancel-and-close-the-window.'],\n    'End of dialog window.': translations['end-of-dialog-window.'],\n    '{1} is loading.': translations['{1}-is-loading.'],\n    'Exit Picture-in-Picture': translations['exit-picture-in-picture'],\n    'Picture-in-Picture': translations['picture-in-picture'],\n    Color: translations.color,\n    Opacity: translations.opacity,\n    'Text Background': translations['text-background'],\n    'Caption Area Background': translations['caption-area-background'],\n    'Skip forward {1} seconds': translations['skip-forward-{1}-seconds'],\n    'Skip backward {1} seconds': translations['skip-backward-{1}-seconds'],\n  };\n}\n"]}
|
|
@@ -0,0 +1,303 @@
|
|
|
1
|
+
import { AsyncPipe, NgTemplateOutlet } from '@angular/common';
|
|
2
|
+
import { ChangeDetectionStrategy, Component, DestroyRef, inject, Input, ViewChild, ViewEncapsulation, } from '@angular/core';
|
|
3
|
+
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
4
|
+
import { BehaviorSubject, delay, tap } from 'rxjs';
|
|
5
|
+
import videojs from 'video.js';
|
|
6
|
+
import { ItAbstractComponent } from '../../../abstracts/abstract.component';
|
|
7
|
+
import { VideoPlayerI18nService } from './video-player-i18n.service';
|
|
8
|
+
import { cookies } from './video-player.cookie';
|
|
9
|
+
import * as i0 from "@angular/core";
|
|
10
|
+
import * as i1 from "./video-player.config";
|
|
11
|
+
var ViewType;
|
|
12
|
+
(function (ViewType) {
|
|
13
|
+
ViewType["Default"] = "DEFAULT";
|
|
14
|
+
ViewType["Overlay"] = "OVERLAY";
|
|
15
|
+
})(ViewType || (ViewType = {}));
|
|
16
|
+
/**
|
|
17
|
+
* Video Player
|
|
18
|
+
* @description Component that allows playing a video.
|
|
19
|
+
*/
|
|
20
|
+
export class ItVideoPlayerComponent extends ItAbstractComponent {
|
|
21
|
+
#destroyRef;
|
|
22
|
+
get viewType() {
|
|
23
|
+
return this.viewType$.value;
|
|
24
|
+
}
|
|
25
|
+
constructor(config) {
|
|
26
|
+
super();
|
|
27
|
+
this.config = config;
|
|
28
|
+
this.viewTypes = ViewType;
|
|
29
|
+
this.viewType$ = new BehaviorSubject(undefined);
|
|
30
|
+
this.cookieAccepted$ = new BehaviorSubject(false);
|
|
31
|
+
this.i18nService = inject(VideoPlayerI18nService);
|
|
32
|
+
this.#destroyRef = inject(DestroyRef);
|
|
33
|
+
}
|
|
34
|
+
async ngOnInit() {
|
|
35
|
+
const config = this.config.mergeConfig(this.options);
|
|
36
|
+
this.setViewType(config);
|
|
37
|
+
await this.config.configureTech(config);
|
|
38
|
+
if (!this.videoPlayerRef) {
|
|
39
|
+
this.cookieAccepted$
|
|
40
|
+
.pipe(takeUntilDestroyed(this.#destroyRef), delay(0), tap({
|
|
41
|
+
next: value => {
|
|
42
|
+
if (value && !this.player) {
|
|
43
|
+
this.initVideoPlayer();
|
|
44
|
+
}
|
|
45
|
+
},
|
|
46
|
+
}))
|
|
47
|
+
.subscribe();
|
|
48
|
+
return;
|
|
49
|
+
}
|
|
50
|
+
this.initVideoPlayer();
|
|
51
|
+
}
|
|
52
|
+
ngAfterViewInit() {
|
|
53
|
+
if (this.viewType === ViewType.Overlay && cookies.isChoiceRemembered('youtube.com')) {
|
|
54
|
+
this.hideOverlay();
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
ngOnDestroy() {
|
|
58
|
+
if (this.player) {
|
|
59
|
+
this.player.dispose();
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
acceptCookieHandler() {
|
|
63
|
+
this.rememberHandler();
|
|
64
|
+
this.hideOverlay();
|
|
65
|
+
this.cookieAccepted$.next(true);
|
|
66
|
+
}
|
|
67
|
+
initVideoPlayer() {
|
|
68
|
+
const config = this.config.mergeConfig(this.options);
|
|
69
|
+
this.setVideoAttributes(config);
|
|
70
|
+
this.setVideoPlayer();
|
|
71
|
+
}
|
|
72
|
+
setVideoPlayer() {
|
|
73
|
+
const config = this.config.mergeConfig(this.options);
|
|
74
|
+
const onPlayerReadyCb = () => {
|
|
75
|
+
if (!this.player) {
|
|
76
|
+
return;
|
|
77
|
+
}
|
|
78
|
+
this.i18nService.init(this.player, this.#destroyRef);
|
|
79
|
+
};
|
|
80
|
+
if (!this.videoPlayerRef) {
|
|
81
|
+
throw Error('videoPlayerRef is undefined');
|
|
82
|
+
}
|
|
83
|
+
this.player = videojs(this.videoPlayerRef.nativeElement, config, onPlayerReadyCb.bind(this));
|
|
84
|
+
}
|
|
85
|
+
setViewType(config) {
|
|
86
|
+
this.viewType$.next(config.tech === 'youtube' ? ViewType.Overlay : ViewType.Default);
|
|
87
|
+
this.cookieAccepted$.next(this.viewType === ViewType.Overlay && cookies.isChoiceRemembered('youtube.com'));
|
|
88
|
+
}
|
|
89
|
+
hideOverlay() {
|
|
90
|
+
if (!this.acceptOverlayableRef) {
|
|
91
|
+
return;
|
|
92
|
+
}
|
|
93
|
+
const classes = ['show'];
|
|
94
|
+
this.acceptOverlayableRef.nativeElement.classList.remove(...classes);
|
|
95
|
+
if (!this.acceptOveralyRef) {
|
|
96
|
+
return;
|
|
97
|
+
}
|
|
98
|
+
this.acceptOveralyRef.nativeElement.classList.remove(...classes);
|
|
99
|
+
this.acceptOveralyRef.nativeElement.setAttribute('aria-hidden', 'true');
|
|
100
|
+
}
|
|
101
|
+
rememberHandler() {
|
|
102
|
+
if (!this.chrRememberRef) {
|
|
103
|
+
return;
|
|
104
|
+
}
|
|
105
|
+
const remember = this.chrRememberRef.nativeElement.checked;
|
|
106
|
+
cookies.rememberChoice('youtube.com', remember);
|
|
107
|
+
}
|
|
108
|
+
setVideoAttributes(options) {
|
|
109
|
+
if (!this.videoPlayerRef) {
|
|
110
|
+
return;
|
|
111
|
+
}
|
|
112
|
+
const v = this.videoPlayerRef.nativeElement;
|
|
113
|
+
const { autoplay, controls, loop, muted, poster, fluid } = options;
|
|
114
|
+
if (autoplay) {
|
|
115
|
+
v.setAttribute('autoplay', autoplay.toString());
|
|
116
|
+
}
|
|
117
|
+
if (controls) {
|
|
118
|
+
v.setAttribute('controls', '');
|
|
119
|
+
}
|
|
120
|
+
if (loop) {
|
|
121
|
+
v.setAttribute('loop', '');
|
|
122
|
+
}
|
|
123
|
+
if (muted) {
|
|
124
|
+
v.setAttribute('muted', '');
|
|
125
|
+
}
|
|
126
|
+
if (poster) {
|
|
127
|
+
v.setAttribute('poster', poster);
|
|
128
|
+
}
|
|
129
|
+
if (fluid) {
|
|
130
|
+
v.setAttribute('fluid', '');
|
|
131
|
+
}
|
|
132
|
+
v.setAttribute('preload', 'none');
|
|
133
|
+
v.setAttribute('playsinline', '');
|
|
134
|
+
}
|
|
135
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: ItVideoPlayerComponent, deps: [{ token: i1.VideoPlayerConfigService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
136
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.6", type: ItVideoPlayerComponent, isStandalone: true, selector: "it-video-player", inputs: { options: "options" }, viewQueries: [{ propertyName: "videoPlayerRef", first: true, predicate: ["videoPlayer"], descendants: true }, { propertyName: "acceptOveralyRef", first: true, predicate: ["acceptOveraly"], descendants: true }, { propertyName: "acceptOverlayableRef", first: true, predicate: ["acceptOverlayable"], descendants: true }, { propertyName: "chrRememberRef", first: true, predicate: ["chkRemember"], descendants: true }], usesInheritance: true, ngImport: i0, template: `@switch (viewType$ | async) {
|
|
137
|
+
@case (viewTypes.Default) {
|
|
138
|
+
<div class="row">
|
|
139
|
+
<ng-container *ngTemplateOutlet="videoTemplate"></ng-container>
|
|
140
|
+
<ng-container *ngTemplateOutlet="transcriptionTemplate"></ng-container>
|
|
141
|
+
</div>
|
|
142
|
+
}
|
|
143
|
+
@case (viewTypes.Overlay) {
|
|
144
|
+
<div #acceptOverlayable class="acceptoverlayable show">
|
|
145
|
+
<div #acceptOveraly class="acceptoverlay acceptoverlay-primary fade show">
|
|
146
|
+
<div class="acceptoverlay-inner">
|
|
147
|
+
<div class="acceptoverlay-icon">
|
|
148
|
+
<svg class="icon icon-xl"><use href="/bootstrap-italia/dist/svg/sprites.svg#it-video"></use></svg>
|
|
149
|
+
</div>
|
|
150
|
+
<p>
|
|
151
|
+
Accetta i cookie di YouTube per vedere il video. Puoi gestire le preferenze nella
|
|
152
|
+
<a href="#" class="text-white">cookie policy</a>.
|
|
153
|
+
</p>
|
|
154
|
+
<div class="acceptoverlay-buttons bg-dark">
|
|
155
|
+
<button type="button" class="btn btn-primary" (click)="acceptCookieHandler()">Accetta</button>
|
|
156
|
+
<div class="form-check">
|
|
157
|
+
<input id="chk-remember{{ id }}" type="checkbox" #chkRemember />
|
|
158
|
+
<label for="chk-remember{{ id }}">Ricorda per tutti i video</label>
|
|
159
|
+
</div>
|
|
160
|
+
</div>
|
|
161
|
+
</div>
|
|
162
|
+
</div>
|
|
163
|
+
@if (cookieAccepted$ | async) {
|
|
164
|
+
<div>
|
|
165
|
+
<ng-container *ngTemplateOutlet="videoTemplate"></ng-container>
|
|
166
|
+
<ng-container *ngTemplateOutlet="transcriptionTemplate"></ng-container>
|
|
167
|
+
</div>
|
|
168
|
+
}
|
|
169
|
+
</div>
|
|
170
|
+
}
|
|
171
|
+
@default {
|
|
172
|
+
<h1>No video provider</h1>
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
<ng-template #videoTemplate>
|
|
176
|
+
<div>
|
|
177
|
+
<video #videoPlayer class="video-js vjs-theme-bootstrap-italia vjs-fluid vjs-big-play-centered"></video>
|
|
178
|
+
</div>
|
|
179
|
+
</ng-template>
|
|
180
|
+
|
|
181
|
+
<ng-template #transcriptionTemplate>
|
|
182
|
+
<div class="vjs-transcription accordion">
|
|
183
|
+
<div class="accordion-item">
|
|
184
|
+
<h2 class="accordion-header " id="transcription-{{ id }}-head">
|
|
185
|
+
<button
|
|
186
|
+
class="accordion-button collapsed"
|
|
187
|
+
type="button"
|
|
188
|
+
data-bs-toggle="collapse"
|
|
189
|
+
[attr.data-bs-target]="'#transcription-' + id"
|
|
190
|
+
[attr.aria-controls]="'transcription-' + id"
|
|
191
|
+
aria-expanded="true">
|
|
192
|
+
<ng-content select="[transcriptionTitle]">Trascrizione</ng-content>
|
|
193
|
+
</button>
|
|
194
|
+
</h2>
|
|
195
|
+
<div
|
|
196
|
+
id="transcription-{{ id }}"
|
|
197
|
+
class="accordion-collapse collapse"
|
|
198
|
+
role="region"
|
|
199
|
+
[attr.aria-labelledby]="'transcription-' + id + '-head'">
|
|
200
|
+
<div class="accordion-body">
|
|
201
|
+
<ng-content select="[transcriptionText]">-</ng-content>
|
|
202
|
+
</div>
|
|
203
|
+
</div>
|
|
204
|
+
</div>
|
|
205
|
+
</div>
|
|
206
|
+
</ng-template> `, isInline: true, dependencies: [{ kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
207
|
+
}
|
|
208
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: ItVideoPlayerComponent, decorators: [{
|
|
209
|
+
type: Component,
|
|
210
|
+
args: [{
|
|
211
|
+
standalone: true,
|
|
212
|
+
selector: 'it-video-player',
|
|
213
|
+
template: `@switch (viewType$ | async) {
|
|
214
|
+
@case (viewTypes.Default) {
|
|
215
|
+
<div class="row">
|
|
216
|
+
<ng-container *ngTemplateOutlet="videoTemplate"></ng-container>
|
|
217
|
+
<ng-container *ngTemplateOutlet="transcriptionTemplate"></ng-container>
|
|
218
|
+
</div>
|
|
219
|
+
}
|
|
220
|
+
@case (viewTypes.Overlay) {
|
|
221
|
+
<div #acceptOverlayable class="acceptoverlayable show">
|
|
222
|
+
<div #acceptOveraly class="acceptoverlay acceptoverlay-primary fade show">
|
|
223
|
+
<div class="acceptoverlay-inner">
|
|
224
|
+
<div class="acceptoverlay-icon">
|
|
225
|
+
<svg class="icon icon-xl"><use href="/bootstrap-italia/dist/svg/sprites.svg#it-video"></use></svg>
|
|
226
|
+
</div>
|
|
227
|
+
<p>
|
|
228
|
+
Accetta i cookie di YouTube per vedere il video. Puoi gestire le preferenze nella
|
|
229
|
+
<a href="#" class="text-white">cookie policy</a>.
|
|
230
|
+
</p>
|
|
231
|
+
<div class="acceptoverlay-buttons bg-dark">
|
|
232
|
+
<button type="button" class="btn btn-primary" (click)="acceptCookieHandler()">Accetta</button>
|
|
233
|
+
<div class="form-check">
|
|
234
|
+
<input id="chk-remember{{ id }}" type="checkbox" #chkRemember />
|
|
235
|
+
<label for="chk-remember{{ id }}">Ricorda per tutti i video</label>
|
|
236
|
+
</div>
|
|
237
|
+
</div>
|
|
238
|
+
</div>
|
|
239
|
+
</div>
|
|
240
|
+
@if (cookieAccepted$ | async) {
|
|
241
|
+
<div>
|
|
242
|
+
<ng-container *ngTemplateOutlet="videoTemplate"></ng-container>
|
|
243
|
+
<ng-container *ngTemplateOutlet="transcriptionTemplate"></ng-container>
|
|
244
|
+
</div>
|
|
245
|
+
}
|
|
246
|
+
</div>
|
|
247
|
+
}
|
|
248
|
+
@default {
|
|
249
|
+
<h1>No video provider</h1>
|
|
250
|
+
}
|
|
251
|
+
}
|
|
252
|
+
<ng-template #videoTemplate>
|
|
253
|
+
<div>
|
|
254
|
+
<video #videoPlayer class="video-js vjs-theme-bootstrap-italia vjs-fluid vjs-big-play-centered"></video>
|
|
255
|
+
</div>
|
|
256
|
+
</ng-template>
|
|
257
|
+
|
|
258
|
+
<ng-template #transcriptionTemplate>
|
|
259
|
+
<div class="vjs-transcription accordion">
|
|
260
|
+
<div class="accordion-item">
|
|
261
|
+
<h2 class="accordion-header " id="transcription-{{ id }}-head">
|
|
262
|
+
<button
|
|
263
|
+
class="accordion-button collapsed"
|
|
264
|
+
type="button"
|
|
265
|
+
data-bs-toggle="collapse"
|
|
266
|
+
[attr.data-bs-target]="'#transcription-' + id"
|
|
267
|
+
[attr.aria-controls]="'transcription-' + id"
|
|
268
|
+
aria-expanded="true">
|
|
269
|
+
<ng-content select="[transcriptionTitle]">Trascrizione</ng-content>
|
|
270
|
+
</button>
|
|
271
|
+
</h2>
|
|
272
|
+
<div
|
|
273
|
+
id="transcription-{{ id }}"
|
|
274
|
+
class="accordion-collapse collapse"
|
|
275
|
+
role="region"
|
|
276
|
+
[attr.aria-labelledby]="'transcription-' + id + '-head'">
|
|
277
|
+
<div class="accordion-body">
|
|
278
|
+
<ng-content select="[transcriptionText]">-</ng-content>
|
|
279
|
+
</div>
|
|
280
|
+
</div>
|
|
281
|
+
</div>
|
|
282
|
+
</div>
|
|
283
|
+
</ng-template> `,
|
|
284
|
+
imports: [AsyncPipe, NgTemplateOutlet],
|
|
285
|
+
encapsulation: ViewEncapsulation.None,
|
|
286
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
287
|
+
}]
|
|
288
|
+
}], ctorParameters: () => [{ type: i1.VideoPlayerConfigService }], propDecorators: { options: [{
|
|
289
|
+
type: Input
|
|
290
|
+
}], videoPlayerRef: [{
|
|
291
|
+
type: ViewChild,
|
|
292
|
+
args: ['videoPlayer', { static: false }]
|
|
293
|
+
}], acceptOveralyRef: [{
|
|
294
|
+
type: ViewChild,
|
|
295
|
+
args: ['acceptOveraly', { static: false }]
|
|
296
|
+
}], acceptOverlayableRef: [{
|
|
297
|
+
type: ViewChild,
|
|
298
|
+
args: ['acceptOverlayable', { static: false }]
|
|
299
|
+
}], chrRememberRef: [{
|
|
300
|
+
type: ViewChild,
|
|
301
|
+
args: ['chkRemember', { static: false }]
|
|
302
|
+
}] } });
|
|
303
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"video-player.component.js","sourceRoot":"","sources":["../../../../../../../projects/design-angular-kit/src/lib/components/core/video-player/video-player.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AsyncPipe, NgTemplateOutlet } from '@angular/common';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  DestroyRef,\n  ElementRef,\n  inject,\n  Input,\n  OnDestroy,\n  OnInit,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { BehaviorSubject, delay, tap } from 'rxjs';\nimport videojs from 'video.js';\nimport Player from 'video.js/dist/types/player';\nimport { ItAbstractComponent } from '../../../abstracts/abstract.component';\nimport { VideoPlayerI18nService } from './video-player-i18n.service';\nimport { Tech, VideoPlayerConfigService } from './video-player.config';\nimport { cookies } from './video-player.cookie';\nimport { ItVideoPlayerConfig, ItVideoPlayerOptions } from './video-player.model';\n\nenum ViewType {\n  Default = 'DEFAULT',\n  Overlay = 'OVERLAY',\n}\n\n/**\n * Video Player\n * @description Component that allows playing a video.\n */\n@Component({\n  standalone: true,\n  selector: 'it-video-player',\n  template: `@switch (viewType$ | async) {\n      @case (viewTypes.Default) {\n        <div class=\"row\">\n          <ng-container *ngTemplateOutlet=\"videoTemplate\"></ng-container>\n          <ng-container *ngTemplateOutlet=\"transcriptionTemplate\"></ng-container>\n        </div>\n      }\n      @case (viewTypes.Overlay) {\n        <div #acceptOverlayable class=\"acceptoverlayable show\">\n          <div #acceptOveraly class=\"acceptoverlay acceptoverlay-primary fade show\">\n            <div class=\"acceptoverlay-inner\">\n              <div class=\"acceptoverlay-icon\">\n                <svg class=\"icon icon-xl\"><use href=\"/bootstrap-italia/dist/svg/sprites.svg#it-video\"></use></svg>\n              </div>\n              <p>\n                Accetta i cookie di YouTube per vedere il video. Puoi gestire le preferenze nella\n                <a href=\"#\" class=\"text-white\">cookie policy</a>.\n              </p>\n              <div class=\"acceptoverlay-buttons bg-dark\">\n                <button type=\"button\" class=\"btn btn-primary\" (click)=\"acceptCookieHandler()\">Accetta</button>\n                <div class=\"form-check\">\n                  <input id=\"chk-remember{{ id }}\" type=\"checkbox\" #chkRemember />\n                  <label for=\"chk-remember{{ id }}\">Ricorda per tutti i video</label>\n                </div>\n              </div>\n            </div>\n          </div>\n          @if (cookieAccepted$ | async) {\n            <div>\n              <ng-container *ngTemplateOutlet=\"videoTemplate\"></ng-container>\n              <ng-container *ngTemplateOutlet=\"transcriptionTemplate\"></ng-container>\n            </div>\n          }\n        </div>\n      }\n      @default {\n        <h1>No video provider</h1>\n      }\n    }\n    <ng-template #videoTemplate>\n      <div>\n        <video #videoPlayer class=\"video-js vjs-theme-bootstrap-italia vjs-fluid vjs-big-play-centered\"></video>\n      </div>\n    </ng-template>\n\n    <ng-template #transcriptionTemplate>\n      <div class=\"vjs-transcription accordion\">\n        <div class=\"accordion-item\">\n          <h2 class=\"accordion-header \" id=\"transcription-{{ id }}-head\">\n            <button\n              class=\"accordion-button collapsed\"\n              type=\"button\"\n              data-bs-toggle=\"collapse\"\n              [attr.data-bs-target]=\"'#transcription-' + id\"\n              [attr.aria-controls]=\"'transcription-' + id\"\n              aria-expanded=\"true\">\n              <ng-content select=\"[transcriptionTitle]\">Trascrizione</ng-content>\n            </button>\n          </h2>\n          <div\n            id=\"transcription-{{ id }}\"\n            class=\"accordion-collapse collapse\"\n            role=\"region\"\n            [attr.aria-labelledby]=\"'transcription-' + id + '-head'\">\n            <div class=\"accordion-body\">\n              <ng-content select=\"[transcriptionText]\">-</ng-content>\n            </div>\n          </div>\n        </div>\n      </div>\n    </ng-template> `,\n  imports: [AsyncPipe, NgTemplateOutlet],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ItVideoPlayerComponent extends ItAbstractComponent implements OnInit, AfterViewInit, OnDestroy {\n  /**\n   * Options for video player configuration\n   */\n  @Input() options!: ItVideoPlayerOptions;\n\n  @ViewChild('videoPlayer', { static: false }) videoPlayerRef?: ElementRef<HTMLVideoElement>;\n\n  @ViewChild('acceptOveraly', { static: false }) acceptOveralyRef?: ElementRef<HTMLDivElement>;\n\n  @ViewChild('acceptOverlayable', { static: false }) acceptOverlayableRef?: ElementRef<HTMLDivElement>;\n\n  @ViewChild('chkRemember', { static: false }) chrRememberRef?: ElementRef<HTMLInputElement>;\n\n  player?: Player;\n\n  readonly viewTypes = ViewType;\n\n  readonly viewType$ = new BehaviorSubject<ViewType | undefined>(undefined);\n\n  readonly cookieAccepted$ = new BehaviorSubject(false);\n\n  protected readonly i18nService = inject(VideoPlayerI18nService);\n\n  readonly #destroyRef = inject(DestroyRef);\n\n  private get viewType() {\n    return this.viewType$.value;\n  }\n\n  constructor(private config: VideoPlayerConfigService) {\n    super();\n  }\n\n  async ngOnInit() {\n    const config = this.config.mergeConfig(this.options);\n    this.setViewType(config);\n    await this.config.configureTech(config as { tech: Tech });\n\n    if (!this.videoPlayerRef) {\n      this.cookieAccepted$\n        .pipe(\n          takeUntilDestroyed(this.#destroyRef),\n          delay(0),\n          tap({\n            next: value => {\n              if (value && !this.player) {\n                this.initVideoPlayer();\n              }\n            },\n          })\n        )\n        .subscribe();\n      return;\n    }\n\n    this.initVideoPlayer();\n  }\n\n  override ngAfterViewInit() {\n    if (this.viewType === ViewType.Overlay && cookies.isChoiceRemembered('youtube.com')) {\n      this.hideOverlay();\n    }\n  }\n\n  ngOnDestroy() {\n    if (this.player) {\n      this.player.dispose();\n    }\n  }\n\n  acceptCookieHandler() {\n    this.rememberHandler();\n    this.hideOverlay();\n    this.cookieAccepted$.next(true);\n  }\n\n  private initVideoPlayer() {\n    const config = this.config.mergeConfig(this.options);\n    this.setVideoAttributes(config);\n    this.setVideoPlayer();\n  }\n\n  private setVideoPlayer() {\n    const config = this.config.mergeConfig(this.options);\n    const onPlayerReadyCb = () => {\n      if (!this.player) {\n        return;\n      }\n      this.i18nService.init(this.player, this.#destroyRef);\n    };\n\n    if (!this.videoPlayerRef) {\n      throw Error('videoPlayerRef is undefined');\n    }\n\n    this.player = videojs(this.videoPlayerRef.nativeElement, config, onPlayerReadyCb.bind(this));\n  }\n\n  private setViewType(config: ItVideoPlayerConfig) {\n    this.viewType$.next(config.tech === 'youtube' ? ViewType.Overlay : ViewType.Default);\n\n    this.cookieAccepted$.next(this.viewType === ViewType.Overlay && cookies.isChoiceRemembered('youtube.com'));\n  }\n\n  private hideOverlay() {\n    if (!this.acceptOverlayableRef) {\n      return;\n    }\n    const classes = ['show'];\n    this.acceptOverlayableRef.nativeElement.classList.remove(...classes);\n    if (!this.acceptOveralyRef) {\n      return;\n    }\n    this.acceptOveralyRef.nativeElement.classList.remove(...classes);\n    this.acceptOveralyRef.nativeElement.setAttribute('aria-hidden', 'true');\n  }\n\n  private rememberHandler() {\n    if (!this.chrRememberRef) {\n      return;\n    }\n    const remember = this.chrRememberRef.nativeElement.checked;\n    cookies.rememberChoice('youtube.com', remember);\n  }\n\n  private setVideoAttributes(options: ItVideoPlayerOptions) {\n    if (!this.videoPlayerRef) {\n      return;\n    }\n    const v = this.videoPlayerRef.nativeElement;\n\n    const { autoplay, controls, loop, muted, poster, fluid } = options;\n\n    if (autoplay) {\n      v.setAttribute('autoplay', autoplay.toString());\n    }\n\n    if (controls) {\n      v.setAttribute('controls', '');\n    }\n\n    if (loop) {\n      v.setAttribute('loop', '');\n    }\n\n    if (muted) {\n      v.setAttribute('muted', '');\n    }\n\n    if (poster) {\n      v.setAttribute('poster', poster);\n    }\n\n    if (fluid) {\n      v.setAttribute('fluid', '');\n    }\n\n    v.setAttribute('preload', 'none');\n    v.setAttribute('playsinline', '');\n  }\n}\n"]}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { inject, Injectable } from '@angular/core';
|
|
2
|
+
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
|
3
|
+
// @ts-ignore
|
|
4
|
+
import { initYoutubePlugin } from 'bootstrap-italia/dist/plugins/util/youtube-video.js';
|
|
5
|
+
import videojs from 'video.js';
|
|
6
|
+
import { VideoPlayerI18nService } from './video-player-i18n.service';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
const hasYoutubeVideo = (options) => options.source?.type === 'video/youtube';
|
|
9
|
+
export class VideoPlayerConfigService {
|
|
10
|
+
#languageService = inject(VideoPlayerI18nService);
|
|
11
|
+
async configureTech({ tech }) {
|
|
12
|
+
if (tech === 'youtube') {
|
|
13
|
+
initYoutubePlugin(videojs);
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
mergeConfig(o) {
|
|
17
|
+
const options = o;
|
|
18
|
+
const captions = options.captions ? options.captions.map(c => ({ ...c, kind: 'captions' })) : [];
|
|
19
|
+
const chapters = options.chapters ? options.chapters.map(c => ({ ...c, kind: 'chapters' })) : [];
|
|
20
|
+
const isYoutubeVideo = hasYoutubeVideo(options);
|
|
21
|
+
const DEFAULT_CONFIG = this.#languageService.getLanguage();
|
|
22
|
+
const tech = isYoutubeVideo ? 'youtube' : 'html5';
|
|
23
|
+
const techOrder = [tech];
|
|
24
|
+
//https://developer.mozilla.org/en-US/docs/Web/HTML/Element/video#preload
|
|
25
|
+
const preload = options.preload ?? 'metadata';
|
|
26
|
+
const config = { ...DEFAULT_CONFIG, ...options, preload, techOrder, tracks: [...captions, ...chapters], tech: 'html5' };
|
|
27
|
+
return isYoutubeVideo
|
|
28
|
+
? {
|
|
29
|
+
...config,
|
|
30
|
+
sources: [o.source],
|
|
31
|
+
tech: 'youtube',
|
|
32
|
+
youtube: { ytControls: 2, rel: 0, fs: 0, modestbranding: 1 },
|
|
33
|
+
}
|
|
34
|
+
: config;
|
|
35
|
+
}
|
|
36
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: VideoPlayerConfigService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
37
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: VideoPlayerConfigService, providedIn: 'root' }); }
|
|
38
|
+
}
|
|
39
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: VideoPlayerConfigService, decorators: [{
|
|
40
|
+
type: Injectable,
|
|
41
|
+
args: [{ providedIn: 'root' }]
|
|
42
|
+
}] });
|
|
43
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmlkZW8tcGxheWVyLmNvbmZpZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Rlc2lnbi1hbmd1bGFyLWtpdC9zcmMvbGliL2NvbXBvbmVudHMvY29yZS92aWRlby1wbGF5ZXIvdmlkZW8tcGxheWVyLmNvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNuRCw2REFBNkQ7QUFDN0QsYUFBYTtBQUNiLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHFEQUFxRCxDQUFDO0FBQ3hGLE9BQU8sT0FBTyxNQUFNLFVBQVUsQ0FBQztBQUMvQixPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQzs7QUFHckUsTUFBTSxlQUFlLEdBQUcsQ0FBQyxPQUE2QixFQUFFLEVBQUUsQ0FBRSxPQUFxQyxDQUFDLE1BQU0sRUFBRSxJQUFJLEtBQUssZUFBZSxDQUFDO0FBS25JLE1BQU0sT0FBTyx3QkFBd0I7SUFDMUIsZ0JBQWdCLEdBQUcsTUFBTSxDQUFDLHNCQUFzQixDQUFDLENBQUM7SUFFM0QsS0FBSyxDQUFDLGFBQWEsQ0FBQyxFQUFFLElBQUksRUFBa0I7UUFDMUMsSUFBSSxJQUFJLEtBQUssU0FBUyxFQUFFLENBQUM7WUFDdkIsaUJBQWlCLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDN0IsQ0FBQztJQUNILENBQUM7SUFFRCxXQUFXLENBQUMsQ0FBdUI7UUFDakMsTUFBTSxPQUFPLEdBQUcsQ0FBK0IsQ0FBQztRQUNoRCxNQUFNLFFBQVEsR0FBRyxPQUFPLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsRUFBRSxHQUFHLENBQUMsRUFBRSxJQUFJLEVBQUUsVUFBVSxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7UUFDakcsTUFBTSxRQUFRLEdBQUcsT0FBTyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLEVBQUUsR0FBRyxDQUFDLEVBQUUsSUFBSSxFQUFFLFVBQVUsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDO1FBQ2pHLE1BQU0sY0FBYyxHQUFHLGVBQWUsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUNoRCxNQUFNLGNBQWMsR0FBRyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsV0FBVyxFQUFFLENBQUM7UUFDM0QsTUFBTSxJQUFJLEdBQUcsY0FBYyxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQztRQUNsRCxNQUFNLFNBQVMsR0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3pCLHlFQUF5RTtRQUN6RSxNQUFNLE9BQU8sR0FBRyxPQUFPLENBQUMsT0FBTyxJQUFJLFVBQVUsQ0FBQztRQUM5QyxNQUFNLE1BQU0sR0FBRyxFQUFFLEdBQUcsY0FBYyxFQUFFLEdBQUcsT0FBTyxFQUFFLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLENBQUMsR0FBRyxRQUFRLEVBQUUsR0FBRyxRQUFRLENBQUMsRUFBRSxJQUFJLEVBQUUsT0FBTyxFQUFFLENBQUM7UUFDeEgsT0FBTyxjQUFjO1lBQ25CLENBQUMsQ0FBQztnQkFDRSxHQUFHLE1BQU07Z0JBQ1QsT0FBTyxFQUFFLENBQUUsQ0FBK0IsQ0FBQyxNQUFNLENBQUM7Z0JBQ2xELElBQUksRUFBRSxTQUFTO2dCQUNmLE9BQU8sRUFBRSxFQUFFLFVBQVUsRUFBRSxDQUFDLEVBQUUsR0FBRyxFQUFFLENBQUMsRUFBRSxFQUFFLEVBQUUsQ0FBQyxFQUFFLGNBQWMsRUFBRSxDQUFDLEVBQUU7YUFDN0Q7WUFDSCxDQUFDLENBQUMsTUFBTSxDQUFDO0lBQ2IsQ0FBQzs4R0E1QlUsd0JBQXdCO2tIQUF4Qix3QkFBd0IsY0FEWCxNQUFNOzsyRkFDbkIsd0JBQXdCO2tCQURwQyxVQUFVO21CQUFDLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGluamVjdCwgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9iYW4tdHMtY29tbWVudFxuLy8gQHRzLWlnbm9yZVxuaW1wb3J0IHsgaW5pdFlvdXR1YmVQbHVnaW4gfSBmcm9tICdib290c3RyYXAtaXRhbGlhL2Rpc3QvcGx1Z2lucy91dGlsL3lvdXR1YmUtdmlkZW8uanMnO1xuaW1wb3J0IHZpZGVvanMgZnJvbSAndmlkZW8uanMnO1xuaW1wb3J0IHsgVmlkZW9QbGF5ZXJJMThuU2VydmljZSB9IGZyb20gJy4vdmlkZW8tcGxheWVyLWkxOG4uc2VydmljZSc7XG5pbXBvcnQgeyBJdEVtYmVkVmlkZW9QbGF5ZXJPcHRpb25zLCBJdE5hdGl2ZVZpZGVvUGxheWVyT3B0aW9ucywgSXRWaWRlb1BsYXllck9wdGlvbnMgfSBmcm9tICcuL3ZpZGVvLXBsYXllci5tb2RlbCc7XG5cbmNvbnN0IGhhc1lvdXR1YmVWaWRlbyA9IChvcHRpb25zOiBJdFZpZGVvUGxheWVyT3B0aW9ucykgPT4gKG9wdGlvbnMgYXMgSXRFbWJlZFZpZGVvUGxheWVyT3B0aW9ucykuc291cmNlPy50eXBlID09PSAndmlkZW8veW91dHViZSc7XG5cbmV4cG9ydCB0eXBlIFRlY2ggPSAnaHRtbDUnIHwgJ3lvdXR1YmUnO1xuXG5ASW5qZWN0YWJsZSh7IHByb3ZpZGVkSW46ICdyb290JyB9KVxuZXhwb3J0IGNsYXNzIFZpZGVvUGxheWVyQ29uZmlnU2VydmljZSB7XG4gIHJlYWRvbmx5ICNsYW5ndWFnZVNlcnZpY2UgPSBpbmplY3QoVmlkZW9QbGF5ZXJJMThuU2VydmljZSk7XG5cbiAgYXN5bmMgY29uZmlndXJlVGVjaCh7IHRlY2ggfTogeyB0ZWNoOiBUZWNoIH0pIHtcbiAgICBpZiAodGVjaCA9PT0gJ3lvdXR1YmUnKSB7XG4gICAgICBpbml0WW91dHViZVBsdWdpbih2aWRlb2pzKTtcbiAgICB9XG4gIH1cblxuICBtZXJnZUNvbmZpZyhvOiBJdFZpZGVvUGxheWVyT3B0aW9ucykge1xuICAgIGNvbnN0IG9wdGlvbnMgPSBvIGFzIEl0TmF0aXZlVmlkZW9QbGF5ZXJPcHRpb25zO1xuICAgIGNvbnN0IGNhcHRpb25zID0gb3B0aW9ucy5jYXB0aW9ucyA/IG9wdGlvbnMuY2FwdGlvbnMubWFwKGMgPT4gKHsgLi4uYywga2luZDogJ2NhcHRpb25zJyB9KSkgOiBbXTtcbiAgICBjb25zdCBjaGFwdGVycyA9IG9wdGlvbnMuY2hhcHRlcnMgPyBvcHRpb25zLmNoYXB0ZXJzLm1hcChjID0+ICh7IC4uLmMsIGtpbmQ6ICdjaGFwdGVycycgfSkpIDogW107XG4gICAgY29uc3QgaXNZb3V0dWJlVmlkZW8gPSBoYXNZb3V0dWJlVmlkZW8ob3B0aW9ucyk7XG4gICAgY29uc3QgREVGQVVMVF9DT05GSUcgPSB0aGlzLiNsYW5ndWFnZVNlcnZpY2UuZ2V0TGFuZ3VhZ2UoKTtcbiAgICBjb25zdCB0ZWNoID0gaXNZb3V0dWJlVmlkZW8gPyAneW91dHViZScgOiAnaHRtbDUnO1xuICAgIGNvbnN0IHRlY2hPcmRlciA9IFt0ZWNoXTtcbiAgICAvL2h0dHBzOi8vZGV2ZWxvcGVyLm1vemlsbGEub3JnL2VuLVVTL2RvY3MvV2ViL0hUTUwvRWxlbWVudC92aWRlbyNwcmVsb2FkXG4gICAgY29uc3QgcHJlbG9hZCA9IG9wdGlvbnMucHJlbG9hZCA/PyAnbWV0YWRhdGEnO1xuICAgIGNvbnN0IGNvbmZpZyA9IHsgLi4uREVGQVVMVF9DT05GSUcsIC4uLm9wdGlvbnMsIHByZWxvYWQsIHRlY2hPcmRlciwgdHJhY2tzOiBbLi4uY2FwdGlvbnMsIC4uLmNoYXB0ZXJzXSwgdGVjaDogJ2h0bWw1JyB9O1xuICAgIHJldHVybiBpc1lvdXR1YmVWaWRlb1xuICAgICAgPyB7XG4gICAgICAgICAgLi4uY29uZmlnLFxuICAgICAgICAgIHNvdXJjZXM6IFsobyBhcyBJdEVtYmVkVmlkZW9QbGF5ZXJPcHRpb25zKS5zb3VyY2VdLFxuICAgICAgICAgIHRlY2g6ICd5b3V0dWJlJyxcbiAgICAgICAgICB5b3V0dWJlOiB7IHl0Q29udHJvbHM6IDIsIHJlbDogMCwgZnM6IDAsIG1vZGVzdGJyYW5kaW5nOiAxIH0sXG4gICAgICAgIH1cbiAgICAgIDogY29uZmlnO1xuICB9XG59XG4iXX0=
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
const preferencesMap = { ck3: {} };
|
|
2
|
+
const STORAGE_KEY = 'bs-ck3';
|
|
3
|
+
/*
|
|
4
|
+
Possible choices:
|
|
5
|
+
false => Accept once
|
|
6
|
+
true => Accept always
|
|
7
|
+
*/
|
|
8
|
+
const rememberChoice = (service, remember) => {
|
|
9
|
+
preferencesMap.ck3[service] = remember;
|
|
10
|
+
localStorage.setItem(STORAGE_KEY, JSON.stringify(preferencesMap.ck3));
|
|
11
|
+
};
|
|
12
|
+
const isChoiceRemembered = (service) => {
|
|
13
|
+
preferencesMap.ck3 = JSON.parse(localStorage.getItem(STORAGE_KEY) || '{}');
|
|
14
|
+
return Boolean(preferencesMap.ck3[service]) || false;
|
|
15
|
+
};
|
|
16
|
+
const clearAllRememberedChoices = () => {
|
|
17
|
+
localStorage.removeItem(STORAGE_KEY);
|
|
18
|
+
};
|
|
19
|
+
const cookies = {
|
|
20
|
+
rememberChoice,
|
|
21
|
+
isChoiceRemembered,
|
|
22
|
+
clearAllRememberedChoices,
|
|
23
|
+
};
|
|
24
|
+
export { cookies };
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmlkZW8tcGxheWVyLmNvb2tpZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Rlc2lnbi1hbmd1bGFyLWtpdC9zcmMvbGliL2NvbXBvbmVudHMvY29yZS92aWRlby1wbGF5ZXIvdmlkZW8tcGxheWVyLmNvb2tpZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLGNBQWMsR0FJaEIsRUFBRSxHQUFHLEVBQUUsRUFBRSxFQUFFLENBQUM7QUFDaEIsTUFBTSxXQUFXLEdBQUcsUUFBUSxDQUFDO0FBQzdCOzs7O0VBSUU7QUFDRixNQUFNLGNBQWMsR0FBRyxDQUFDLE9BQWUsRUFBRSxRQUFpQixFQUFFLEVBQUU7SUFDNUQsY0FBYyxDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQUMsR0FBRyxRQUFRLENBQUM7SUFDdkMsWUFBWSxDQUFDLE9BQU8sQ0FBQyxXQUFXLEVBQUUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxjQUFjLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQztBQUN4RSxDQUFDLENBQUM7QUFFRixNQUFNLGtCQUFrQixHQUFHLENBQUMsT0FBZSxFQUFFLEVBQUU7SUFDN0MsY0FBYyxDQUFDLEdBQUcsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLFlBQVksQ0FBQyxPQUFPLENBQUMsV0FBVyxDQUFDLElBQUksSUFBSSxDQUFDLENBQUM7SUFDM0UsT0FBTyxPQUFPLENBQUMsY0FBYyxDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQUMsQ0FBQyxJQUFJLEtBQUssQ0FBQztBQUN2RCxDQUFDLENBQUM7QUFFRixNQUFNLHlCQUF5QixHQUFHLEdBQUcsRUFBRTtJQUNyQyxZQUFZLENBQUMsVUFBVSxDQUFDLFdBQVcsQ0FBQyxDQUFDO0FBQ3ZDLENBQUMsQ0FBQztBQUVGLE1BQU0sT0FBTyxHQUFHO0lBQ2QsY0FBYztJQUNkLGtCQUFrQjtJQUNsQix5QkFBeUI7Q0FDMUIsQ0FBQztBQUVGLE9BQU8sRUFBRSxPQUFPLEVBQUUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImNvbnN0IHByZWZlcmVuY2VzTWFwOiB7XG4gIGNrMzoge1xuICAgIFtrZXk6IHN0cmluZ106IGJvb2xlYW47XG4gIH07XG59ID0geyBjazM6IHt9IH07XG5jb25zdCBTVE9SQUdFX0tFWSA9ICdicy1jazMnO1xuLypcbiAgUG9zc2libGUgY2hvaWNlczpcbiAgZmFsc2UgPT4gQWNjZXB0IG9uY2VcbiAgdHJ1ZSA9PiBBY2NlcHQgYWx3YXlzXG4qL1xuY29uc3QgcmVtZW1iZXJDaG9pY2UgPSAoc2VydmljZTogc3RyaW5nLCByZW1lbWJlcjogYm9vbGVhbikgPT4ge1xuICBwcmVmZXJlbmNlc01hcC5jazNbc2VydmljZV0gPSByZW1lbWJlcjtcbiAgbG9jYWxTdG9yYWdlLnNldEl0ZW0oU1RPUkFHRV9LRVksIEpTT04uc3RyaW5naWZ5KHByZWZlcmVuY2VzTWFwLmNrMykpO1xufTtcblxuY29uc3QgaXNDaG9pY2VSZW1lbWJlcmVkID0gKHNlcnZpY2U6IHN0cmluZykgPT4ge1xuICBwcmVmZXJlbmNlc01hcC5jazMgPSBKU09OLnBhcnNlKGxvY2FsU3RvcmFnZS5nZXRJdGVtKFNUT1JBR0VfS0VZKSB8fCAne30nKTtcbiAgcmV0dXJuIEJvb2xlYW4ocHJlZmVyZW5jZXNNYXAuY2szW3NlcnZpY2VdKSB8fCBmYWxzZTtcbn07XG5cbmNvbnN0IGNsZWFyQWxsUmVtZW1iZXJlZENob2ljZXMgPSAoKSA9PiB7XG4gIGxvY2FsU3RvcmFnZS5yZW1vdmVJdGVtKFNUT1JBR0VfS0VZKTtcbn07XG5cbmNvbnN0IGNvb2tpZXMgPSB7XG4gIHJlbWVtYmVyQ2hvaWNlLFxuICBpc0Nob2ljZVJlbWVtYmVyZWQsXG4gIGNsZWFyQWxsUmVtZW1iZXJlZENob2ljZXMsXG59O1xuXG5leHBvcnQgeyBjb29raWVzIH07XG4iXX0=
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
// See options: https://videojs.com/guides/options
|
|
2
|
+
export {};
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmlkZW8tcGxheWVyLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGVzaWduLWFuZ3VsYXIta2l0L3NyYy9saWIvY29tcG9uZW50cy9jb3JlL3ZpZGVvLXBsYXllci92aWRlby1wbGF5ZXIubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsa0RBQWtEIiwic291cmNlc0NvbnRlbnQiOlsiLy8gU2VlIG9wdGlvbnM6IGh0dHBzOi8vdmlkZW9qcy5jb20vZ3VpZGVzL29wdGlvbnNcblxuaW50ZXJmYWNlIFNvdXJjZSB7XG4gIHNyYzogc3RyaW5nO1xuICB0eXBlOiBzdHJpbmc7XG59XG5cbmludGVyZmFjZSBDYXB0aW9uIHtcbiAgbGFuZzogc3RyaW5nO1xuICBzcmM6IHN0cmluZztcbiAgbGFiZWw6IHN0cmluZztcbiAgZGVmYXVsdD86IHRydWU7XG59XG5cbmludGVyZmFjZSBDaGFwdGVyIHtcbiAgbGFuZzogc3RyaW5nO1xuICBzcmM6IHN0cmluZztcbiAgbGFiZWw6IHN0cmluZztcbiAgZGVmYXVsdD86IHRydWU7XG59XG5cbnR5cGUgU291cmNlcyA9IEFycmF5PFNvdXJjZT47XG50eXBlIENhcHRpb25zID0gQXJyYXk8Q2FwdGlvbj47XG50eXBlIENoYXB0ZXJzID0gQXJyYXk8Q2hhcHRlcj47XG50eXBlIFByZWxvYWQgPSAnYXV0bycgfCAnbm9uZScgfCAnbWV0YWRhdGEnIHwgJyc7XG50eXBlIEVtYmVkU291cmNlVHlwZSA9ICd2aWRlby95b3V0dWJlJztcbnR5cGUgVEF1dG9wbGF5ID0gJ211dGVkJyB8ICdwbGF5JyB8ICdhbnknO1xuXG50eXBlIEl0TmF0aXZlVmlkZW9QbGF5ZXJPcHRpb25zID0ge1xuICBhdXRvcGxheT86IGJvb2xlYW4gfCBUQXV0b3BsYXk7XG4gIGNvbnRyb2xzPzogYm9vbGVhbjtcbiAgZmx1aWQ/OiBib29sZWFuO1xuICBsb29wPzogYm9vbGVhbjtcbiAgbXV0ZWQ/OiBib29sZWFuO1xuICBwb3N0ZXI/OiBzdHJpbmc7XG4gIHByZWxvYWQ/OiBQcmVsb2FkO1xuICBzb3VyY2VzOiBTb3VyY2VzO1xuICBjYXB0aW9ucz86IENhcHRpb25zO1xuICBjaGFwdGVycz86IENoYXB0ZXJzO1xufTtcblxudHlwZSBJdEVtYmVkVmlkZW9QbGF5ZXJPcHRpb25zID0gT21pdDxJdE5hdGl2ZVZpZGVvUGxheWVyT3B0aW9ucywgJ3NvdXJjZXMnIHwgJ2NhcHRpb25zJyB8ICdjaGFwdGVycyc+ICYge1xuICBzb3VyY2U6IFNvdXJjZSAmIHsgdHlwZTogRW1iZWRTb3VyY2VUeXBlIH07XG59O1xuXG50eXBlIEl0VmlkZW9QbGF5ZXJPcHRpb25zID0gSXROYXRpdmVWaWRlb1BsYXllck9wdGlvbnMgfCBJdEVtYmVkVmlkZW9QbGF5ZXJPcHRpb25zO1xuXG50eXBlIEl0VmlkZW9QbGF5ZXJDb25maWcgPSBJdFZpZGVvUGxheWVyT3B0aW9ucyAmIHsgdGVjaDogc3RyaW5nIH07XG5cbmV4cG9ydCB0eXBlIHsgQ2FwdGlvbiwgQ2hhcHRlciwgSXRFbWJlZFZpZGVvUGxheWVyT3B0aW9ucywgSXROYXRpdmVWaWRlb1BsYXllck9wdGlvbnMsIEl0VmlkZW9QbGF5ZXJDb25maWcsIEl0VmlkZW9QbGF5ZXJPcHRpb25zLCBTb3VyY2UgfTtcbiJdfQ==
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { ItVideoPlayerComponent } from './video-player.component';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class ItVideoPlayerModule {
|
|
5
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: ItVideoPlayerModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
6
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.0.6", ngImport: i0, type: ItVideoPlayerModule, imports: [ItVideoPlayerComponent], exports: [ItVideoPlayerComponent] }); }
|
|
7
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: ItVideoPlayerModule }); }
|
|
8
|
+
}
|
|
9
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.6", ngImport: i0, type: ItVideoPlayerModule, decorators: [{
|
|
10
|
+
type: NgModule,
|
|
11
|
+
args: [{
|
|
12
|
+
imports: [ItVideoPlayerComponent],
|
|
13
|
+
exports: [ItVideoPlayerComponent],
|
|
14
|
+
}]
|
|
15
|
+
}] });
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmlkZW8tcGxheWVyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Rlc2lnbi1hbmd1bGFyLWtpdC9zcmMvbGliL2NvbXBvbmVudHMvY29yZS92aWRlby1wbGF5ZXIvdmlkZW8tcGxheWVyLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDBCQUEwQixDQUFDOztBQU1sRSxNQUFNLE9BQU8sbUJBQW1COzhHQUFuQixtQkFBbUI7K0dBQW5CLG1CQUFtQixZQUhwQixzQkFBc0IsYUFDdEIsc0JBQXNCOytHQUVyQixtQkFBbUI7OzJGQUFuQixtQkFBbUI7a0JBSi9CLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFLENBQUMsc0JBQXNCLENBQUM7b0JBQ2pDLE9BQU8sRUFBRSxDQUFDLHNCQUFzQixDQUFDO2lCQUNsQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBJdFZpZGVvUGxheWVyQ29tcG9uZW50IH0gZnJvbSAnLi92aWRlby1wbGF5ZXIuY29tcG9uZW50JztcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW0l0VmlkZW9QbGF5ZXJDb21wb25lbnRdLFxuICBleHBvcnRzOiBbSXRWaWRlb1BsYXllckNvbXBvbmVudF0sXG59KVxuZXhwb3J0IGNsYXNzIEl0VmlkZW9QbGF5ZXJNb2R1bGUge31cbiJdfQ==
|