ctt-babylon 0.1.273 → 0.1.274

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.
@@ -1,9 +1,8 @@
1
1
  import { CommonModule, isPlatformBrowser } from '@angular/common';
2
2
  import { ChangeDetectionStrategy, Component, effect, inject, Input, PLATFORM_ID, Renderer2, } from '@angular/core';
3
- import { Subject, switchMap, tap } from 'rxjs';
3
+ import { Subject } from 'rxjs';
4
4
  import { ScreenSizerService } from '../../../services/screen-sizer';
5
5
  import { Utils } from '../../../utils';
6
- import { take, takeUntil } from 'rxjs/operators';
7
6
  import * as i0 from "@angular/core";
8
7
  export class BabylonTopSliderVideoComponent {
9
8
  constructor() {
@@ -55,24 +54,20 @@ export class BabylonTopSliderVideoComponent {
55
54
  }
56
55
  /* CASO DESKTOP/TABLET: no hace nada aquí ---------------------- */
57
56
  }
58
- loadVideoPlayer() {
59
- Utils.loadScript$('assets/babylon/js/jquery.min.js')
60
- .pipe(switchMap(() => Utils.loadScript$('assets/babylon/js/jquery.mb.YTPlayer.min.js')), tap(() => {
61
- if (this.hasPlayerInitialized) {
62
- return;
63
- }
64
- const videoEl = $('#bgndVideo');
65
- if (videoEl.length &&
66
- window.jQuery?.fn?.YTPlayer) {
67
- this.hasPlayerInitialized = true;
68
- videoEl.YTPlayer(this.getVideoDataProperty());
69
- const img = document.querySelector('.babylon__topslidervideo img');
70
- if (img) {
71
- img.style.display = 'none';
72
- }
73
- }
74
- }), take(1), takeUntil(this.destroy$))
75
- .subscribe();
57
+ async loadVideoPlayer() {
58
+ if (!isPlatformBrowser(this.platform))
59
+ return;
60
+ if (this.hasPlayerInitialized)
61
+ return;
62
+ if (!window.jQuery?.fn?.YTPlayer) {
63
+ await Utils.loadScript$('assets/babylon/js/jquery.mb.YTPlayer.min.js');
64
+ }
65
+ const videoEl = $('#bgndVideo');
66
+ if (videoEl.length) {
67
+ this.hasPlayerInitialized = true;
68
+ videoEl.YTPlayer(this.getVideoDataProperty());
69
+ this.renderer.setStyle(document.querySelector('.babylon__topslidervideo img'), 'display', 'none');
70
+ }
76
71
  }
77
72
  getVideoDataProperty() {
78
73
  return {
@@ -102,4 +97,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
102
97
  }], img: [{
103
98
  type: Input
104
99
  }] } });
105
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"babylon-top-slider-video.component.js","sourceRoot":"","sources":["../../../../../../../projects/babylon/src/lib/components/core/babylon-top-slider-video/babylon-top-slider-video.component.ts","../../../../../../../projects/babylon/src/lib/components/core/babylon-top-slider-video/babylon-top-slider-video.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;AAClE,OAAO,EAEH,uBAAuB,EACvB,SAAS,EACT,MAAM,EACN,MAAM,EACN,KAAK,EAEL,WAAW,EACX,SAAS,GACZ,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,GAAG,EAAE,MAAM,MAAM,CAAC;AAG/C,OAAO,EAAE,kBAAkB,EAAE,MAAM,gCAAgC,CAAC;AACpE,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AAGvC,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;;AAUjD,MAAM,OAAO,8BAA8B;IAiBvC;QATQ,yBAAoB,GAAG,KAAK,CAAC;QAGpB,gBAAW,GAAG,MAAM,CAAC,kBAAkB,CAAC,CAAC;QACzC,aAAQ,GAAG,MAAM,CAAC,SAAS,CAAC,CAAC;QAC7B,aAAQ,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC;QAExC,aAAQ,GAAG,IAAI,OAAO,EAAQ,CAAC;QAGnC,MAAM,CAAC,GAAG,EAAE;YACR,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC9B,CAAC,CAAC,CAAC;IACP,CAAC;IAED,eAAe;QACX,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE;YACnC,OAAO;SACV;QAED,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,eAAe,EAAE,EAAE;YACrC,OAAO;SACV;QAED,MAAM,MAAM,GAAG,QAAQ,CAAC,aAAa,CAAC,aAAa,CAAC,CAAC;QACrD,IAAI,MAAM,EAAE;YACR,IAAI,CAAC,QAAQ,GAAG,IAAI,oBAAoB,CACpC,CAAC,OAAO,EAAE,EAAE;gBACR,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE;oBAClB,IAAI,CAAC,CAAC,cAAc,IAAI,CAAC,IAAI,CAAC,oBAAoB,EAAE;wBAChD,IAAI,CAAC,eAAe,EAAE,CAAC;wBACvB,IAAI,CAAC,QAAQ,EAAE,UAAU,EAAE,CAAC;qBAC/B;gBACL,CAAC,CAAC,CAAC;YACP,CAAC,EACD,EAAE,UAAU,EAAE,WAAW,EAAE,CAC9B,CAAC;YACF,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;SACjC;IACL,CAAC;IAED,WAAW;QACP,IAAI,CAAC,QAAQ,EAAE,UAAU,EAAE,CAAC;QAC5B,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACrB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;IAC7B,CAAC;IAEO,kBAAkB;QACtB,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE;YACnC,OAAO;SACV;QAED,kEAAkE;QAClE,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,eAAe,EAAE,EAAE;YACrC,MAAM,OAAO,GAAG,QAAQ,CAAC,aAAa,CAAC,oBAAoB,CAAC,CAAC;YAC7D,IAAI,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,OAAO,EAAE;gBAC1B,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,OAAO,EAAE,SAAS,EAAE,MAAM,CAAC,CAAC;gBACnD,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAClB,QAAQ,CAAC,aAAa,CAAC,aAAa,CAAC,EACrC,aAAa,EACb,OAAO,CACV,CAAC;aACL;SACJ;QACD,mEAAmE;IACvE,CAAC;IAEO,eAAe;QACnB,KAAK,CAAC,WAAW,CAAC,iCAAiC,CAAC;aAC/C,IAAI,CACD,SAAS,CAAC,GAAG,EAAE,CACX,KAAK,CAAC,WAAW,CACb,6CAA6C,CAChD,CACJ,EACD,GAAG,CAAC,GAAG,EAAE;YACL,IAAI,IAAI,CAAC,oBAAoB,EAAE;gBAC3B,OAAO;aACV;YACD,MAAM,OAAO,GAAG,CAAC,CAAC,YAAY,CAAQ,CAAC;YACvC,IACI,OAAO,CAAC,MAAM;gBACb,MAAc,CAAC,MAAM,EAAE,EAAE,EAAE,QAAQ,EACtC;gBACE,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC;gBAEjC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,oBAAoB,EAAE,CAAC,CAAC;gBAE9C,MAAM,GAAG,GAAG,QAAQ,CAAC,aAAa,CAC9B,8BAA8B,CACN,CAAC;gBAC7B,IAAI,GAAG,EAAE;oBACL,GAAG,CAAC,KAAK,CAAC,OAAO,GAAG,MAAM,CAAC;iBAC9B;aACJ;QACL,CAAC,CAAC,EACF,IAAI,CAAC,CAAC,CAAC,EACP,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAC3B;aACA,SAAS,EAAE,CAAC;IACrB,CAAC;IAED,oBAAoB;QAChB,OAAO;YACH,QAAQ,EAAE,IAAI,CAAC,SAAS,EAAE,GAAG;YAC7B,WAAW,EAAE,aAAa;YAC1B,QAAQ,EAAE,IAAI;YACd,IAAI,EAAE,IAAI;YACV,OAAO,EAAE,CAAC;YACV,OAAO,EAAE,CAAC;YACV,YAAY,EAAE,KAAK;YACnB,IAAI,EAAE,IAAI;YACV,eAAe,EAAE,KAAK;SACzB,CAAC;IACN,CAAC;+GA1HQ,8BAA8B;mGAA9B,8BAA8B,oLC9B3C,ytDA2CA,01vBDlBc,YAAY;;4FAKb,8BAA8B;kBAR1C,SAAS;+BACI,8BAA8B,cAC5B,IAAI,WACP,CAAC,YAAY,CAAC,mBAGN,uBAAuB,CAAC,MAAM;wDAKtC,UAAU;sBAAlB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,GAAG;sBAAX,KAAK","sourcesContent":["import { CommonModule, isPlatformBrowser } from '@angular/common';\nimport {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    Component,\n    effect,\n    inject,\n    Input,\n    OnDestroy,\n    PLATFORM_ID,\n    Renderer2,\n} from '@angular/core';\n\nimport { Subject, switchMap, tap } from 'rxjs';\nimport { BabylonImageI } from '../../../interfaces';\nimport { BabylonButtonI } from '../../../interfaces/babylon-button.interface';\nimport { ScreenSizerService } from '../../../services/screen-sizer';\nimport { Utils } from '../../../utils';\nimport { BabylonVideoSourceI } from './babylon-video-source.interface';\n\nimport { take, takeUntil } from 'rxjs/operators';\n\n@Component({\n    selector: 'lib-babylon-top-slider-video',\n    standalone: true,\n    imports: [CommonModule],\n    templateUrl: './babylon-top-slider-video.component.html',\n    styleUrl: './babylon-top-slider-video.component.scss',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class BabylonTopSliderVideoComponent\n    implements AfterViewInit, OnDestroy\n{\n    @Input() labelInfos?: BabylonLabelInfo;\n    @Input() videoData?: BabylonVideoSourceI;\n    @Input() button?: BabylonButtonI;\n    @Input() img?: BabylonImageI;\n\n    private hasPlayerInitialized = false;\n    private observer?: IntersectionObserver;\n\n    private readonly screenSizer = inject(ScreenSizerService);\n    private readonly renderer = inject(Renderer2);\n    private readonly platform = inject(PLATFORM_ID);\n\n    private destroy$ = new Subject<void>();\n\n    constructor() {\n        effect(() => {\n            this.manageVideoOrImage();\n        });\n    }\n\n    ngAfterViewInit() {\n        if (!isPlatformBrowser(this.platform)) {\n            return;\n        }\n\n        if (!this.screenSizer.minMediumTablet()) {\n            return;\n        }\n\n        const target = document.querySelector('.youtube-bg');\n        if (target) {\n            this.observer = new IntersectionObserver(\n                (entries) => {\n                    entries.forEach((e) => {\n                        if (e.isIntersecting && !this.hasPlayerInitialized) {\n                            this.loadVideoPlayer();\n                            this.observer?.disconnect();\n                        }\n                    });\n                },\n                { rootMargin: '200px 0px' }\n            );\n            this.observer.observe(target);\n        }\n    }\n\n    ngOnDestroy(): void {\n        this.observer?.disconnect();\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n\n    private manageVideoOrImage(): void {\n        if (!isPlatformBrowser(this.platform)) {\n            return;\n        }\n\n        /* CASO MÓVIL: muestra imagen y oculta wrapper ---------------- */\n        if (!this.screenSizer.minMediumTablet()) {\n            const wrapper = document.querySelector('#wrapper_bgndVideo');\n            if (this.img?.src && wrapper) {\n                this.renderer.setStyle(wrapper, 'display', 'none');\n                this.renderer.setStyle(\n                    document.querySelector('.youtube-bg'),\n                    'padding-top',\n                    '110px'\n                );\n            }\n        }\n        /* CASO DESKTOP/TABLET: no hace nada aquí ---------------------- */\n    }\n\n    private loadVideoPlayer(): void {\n        Utils.loadScript$('assets/babylon/js/jquery.min.js')\n            .pipe(\n                switchMap(() =>\n                    Utils.loadScript$(\n                        'assets/babylon/js/jquery.mb.YTPlayer.min.js'\n                    )\n                ),\n                tap(() => {\n                    if (this.hasPlayerInitialized) {\n                        return;\n                    }\n                    const videoEl = $('#bgndVideo') as any;\n                    if (\n                        videoEl.length &&\n                        (window as any).jQuery?.fn?.YTPlayer\n                    ) {\n                        this.hasPlayerInitialized = true;\n\n                        videoEl.YTPlayer(this.getVideoDataProperty());\n\n                        const img = document.querySelector(\n                            '.babylon__topslidervideo img'\n                        ) as HTMLImageElement | null;\n                        if (img) {\n                            img.style.display = 'none';\n                        }\n                    }\n                }),\n                take(1),\n                takeUntil(this.destroy$)\n            )\n            .subscribe();\n    }\n\n    getVideoDataProperty(): any {\n        return {\n            videoURL: this.videoData?.src,\n            containment: '.youtube-bg',\n            autoPlay: true,\n            mute: true,\n            startAt: 1,\n            opacity: 1,\n            showControls: false,\n            loop: true,\n            stopMovieOnBlur: false,\n        };\n    }\n}\n\nexport interface BabylonLabelInfo {\n    title: string;\n    pretitle: string;\n}\n","<section class=\"babylon__topslidervideo margin-main-botom\">\n    <div\n        class=\"cs_hero cs_style_4 cs_primary_bg cs_bg_filed text-center position-relative youtube-bg\"\n    >\n        @if (videoData?.src) {\n            <div id=\"bgndVideo\" class=\"player\"></div>\n        }\n\n        @if (img && img.src) {\n            <img [src]=\"img.src\" [alt]=\"img.alt\" loading=\"lazy\" />\n        }\n        <div\n            class=\"cs_hero_text_wrap cs_center wow fadeIn\"\n            data-wow-duration=\"0.8s\"\n            data-wow-delay=\"0.2s\"\n        >\n            <div class=\"container position-relative cs_zindex_3\">\n                <div class=\"cs_hero_text\">\n                    @if (labelInfos?.pretitle) {\n                        <h1 class=\"cs_hero_subtitle pretitle_carrusel\">\n                            {{ labelInfos?.pretitle }}\n                        </h1>\n                    }\n                    @if (labelInfos?.title) {\n                        <h1 class=\"title_carrusel\">{{ labelInfos?.title }}</h1>\n                    }\n                    @if (button?.url) {\n                        <div class=\"btns__box align--center\">\n                            <a\n                                [attr.aria-label]=\"button?.label\"\n                                [href]=\"button?.url\"\n                                class=\"btn btn_primary btn--light\"\n                            >\n                                <b>{{ button?.label }}</b>\n                                <span class=\"babylon-arrow-right-big\"></span>\n                            </a>\n                        </div>\n                    }\n                </div>\n            </div>\n        </div>\n    </div>\n</section>\n"]}
100
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"babylon-top-slider-video.component.js","sourceRoot":"","sources":["../../../../../../../projects/babylon/src/lib/components/core/babylon-top-slider-video/babylon-top-slider-video.component.ts","../../../../../../../projects/babylon/src/lib/components/core/babylon-top-slider-video/babylon-top-slider-video.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule, isPlatformBrowser } from '@angular/common';\nimport {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    Component,\n    effect,\n    inject,\n    Input,\n    OnDestroy,\n    PLATFORM_ID,\n    Renderer2,\n} from '@angular/core';\n\nimport { Subject } from 'rxjs';\nimport { BabylonImageI } from '../../../interfaces';\nimport { BabylonButtonI } from '../../../interfaces/babylon-button.interface';\nimport { ScreenSizerService } from '../../../services/screen-sizer';\nimport { Utils } from '../../../utils';\nimport { BabylonVideoSourceI } from './babylon-video-source.interface';\n\ndeclare const $: any;\n\n@Component({\n    selector: 'lib-babylon-top-slider-video',\n    standalone: true,\n    imports: [CommonModule],\n    templateUrl: './babylon-top-slider-video.component.html',\n    styleUrl: './babylon-top-slider-video.component.scss',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class BabylonTopSliderVideoComponent\n    implements AfterViewInit, OnDestroy\n{\n    @Input() labelInfos?: BabylonLabelInfo;\n    @Input() videoData?: BabylonVideoSourceI;\n    @Input() button?: BabylonButtonI;\n    @Input() img?: BabylonImageI;\n\n    private hasPlayerInitialized = false;\n    private observer?: IntersectionObserver;\n\n    private readonly screenSizer = inject(ScreenSizerService);\n    private readonly renderer = inject(Renderer2);\n    private readonly platform = inject(PLATFORM_ID);\n\n    private destroy$ = new Subject<void>();\n\n    constructor() {\n        effect(() => {\n            this.manageVideoOrImage();\n        });\n    }\n\n    ngAfterViewInit() {\n        if (!isPlatformBrowser(this.platform)) {\n            return;\n        }\n\n        if (!this.screenSizer.minMediumTablet()) {\n            return;\n        }\n\n        const target = document.querySelector('.youtube-bg');\n        if (target) {\n            this.observer = new IntersectionObserver(\n                (entries) => {\n                    entries.forEach((e) => {\n                        if (e.isIntersecting && !this.hasPlayerInitialized) {\n                            this.loadVideoPlayer();\n                            this.observer?.disconnect();\n                        }\n                    });\n                },\n                { rootMargin: '200px 0px' }\n            );\n            this.observer.observe(target);\n        }\n    }\n\n    ngOnDestroy(): void {\n        this.observer?.disconnect();\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n\n    private manageVideoOrImage(): void {\n        if (!isPlatformBrowser(this.platform)) {\n            return;\n        }\n\n        /* CASO MÓVIL: muestra imagen y oculta wrapper ---------------- */\n        if (!this.screenSizer.minMediumTablet()) {\n            const wrapper = document.querySelector('#wrapper_bgndVideo');\n            if (this.img?.src && wrapper) {\n                this.renderer.setStyle(wrapper, 'display', 'none');\n                this.renderer.setStyle(\n                    document.querySelector('.youtube-bg'),\n                    'padding-top',\n                    '110px'\n                );\n            }\n        }\n        /* CASO DESKTOP/TABLET: no hace nada aquí ---------------------- */\n    }\n\n    private async loadVideoPlayer(): Promise<void> {\n        if (!isPlatformBrowser(this.platform)) return;\n\n        if (this.hasPlayerInitialized) return;\n\n        if (!(window as any).jQuery?.fn?.YTPlayer) {\n            await Utils.loadScript$(\n                'assets/babylon/js/jquery.mb.YTPlayer.min.js'\n            );\n        }\n\n        const videoEl = $('#bgndVideo');\n        if (videoEl.length) {\n            this.hasPlayerInitialized = true;\n            videoEl.YTPlayer(this.getVideoDataProperty());\n\n            this.renderer.setStyle(\n                document.querySelector('.babylon__topslidervideo img'),\n                'display',\n                'none'\n            );\n        }\n    }\n\n    getVideoDataProperty(): any {\n        return {\n            videoURL: this.videoData?.src,\n            containment: '.youtube-bg',\n            autoPlay: true,\n            mute: true,\n            startAt: 1,\n            opacity: 1,\n            showControls: false,\n            loop: true,\n            stopMovieOnBlur: false,\n        };\n    }\n}\n\nexport interface BabylonLabelInfo {\n    title: string;\n    pretitle: string;\n}\n","<section class=\"babylon__topslidervideo margin-main-botom\">\n    <div\n        class=\"cs_hero cs_style_4 cs_primary_bg cs_bg_filed text-center position-relative youtube-bg\"\n    >\n        @if (videoData?.src) {\n            <div id=\"bgndVideo\" class=\"player\"></div>\n        }\n\n        @if (img && img.src) {\n            <img [src]=\"img.src\" [alt]=\"img.alt\" loading=\"lazy\" />\n        }\n        <div\n            class=\"cs_hero_text_wrap cs_center wow fadeIn\"\n            data-wow-duration=\"0.8s\"\n            data-wow-delay=\"0.2s\"\n        >\n            <div class=\"container position-relative cs_zindex_3\">\n                <div class=\"cs_hero_text\">\n                    @if (labelInfos?.pretitle) {\n                        <h1 class=\"cs_hero_subtitle pretitle_carrusel\">\n                            {{ labelInfos?.pretitle }}\n                        </h1>\n                    }\n                    @if (labelInfos?.title) {\n                        <h1 class=\"title_carrusel\">{{ labelInfos?.title }}</h1>\n                    }\n                    @if (button?.url) {\n                        <div class=\"btns__box align--center\">\n                            <a\n                                [attr.aria-label]=\"button?.label\"\n                                [href]=\"button?.url\"\n                                class=\"btn btn_primary btn--light\"\n                            >\n                                <b>{{ button?.label }}</b>\n                                <span class=\"babylon-arrow-right-big\"></span>\n                            </a>\n                        </div>\n                    }\n                </div>\n            </div>\n        </div>\n    </div>\n</section>\n"]}
@@ -10,7 +10,7 @@ import * as i2 from '@angular/forms';
10
10
  import { Validators, FormBuilder, FormsModule, ReactiveFormsModule, FormControl, FormGroup } from '@angular/forms';
11
11
  import * as i1$3 from '@angular/material/dialog';
12
12
  import { MAT_DIALOG_DATA, MatDialog, MatDialogRef } from '@angular/material/dialog';
13
- import { map as map$1, catchError, take as take$1, takeUntil as takeUntil$1 } from 'rxjs/operators';
13
+ import { map as map$1, catchError } from 'rxjs/operators';
14
14
  import * as i1$4 from '@angular/common/http';
15
15
  import * as i4 from '@angular/material/checkbox';
16
16
  import { MatCheckboxModule } from '@angular/material/checkbox';
@@ -8415,24 +8415,20 @@ class BabylonTopSliderVideoComponent {
8415
8415
  }
8416
8416
  /* CASO DESKTOP/TABLET: no hace nada aquí ---------------------- */
8417
8417
  }
8418
- loadVideoPlayer() {
8419
- Utils.loadScript$('assets/babylon/js/jquery.min.js')
8420
- .pipe(switchMap(() => Utils.loadScript$('assets/babylon/js/jquery.mb.YTPlayer.min.js')), tap(() => {
8421
- if (this.hasPlayerInitialized) {
8422
- return;
8423
- }
8424
- const videoEl = $('#bgndVideo');
8425
- if (videoEl.length &&
8426
- window.jQuery?.fn?.YTPlayer) {
8427
- this.hasPlayerInitialized = true;
8428
- videoEl.YTPlayer(this.getVideoDataProperty());
8429
- const img = document.querySelector('.babylon__topslidervideo img');
8430
- if (img) {
8431
- img.style.display = 'none';
8432
- }
8433
- }
8434
- }), take$1(1), takeUntil$1(this.destroy$))
8435
- .subscribe();
8418
+ async loadVideoPlayer() {
8419
+ if (!isPlatformBrowser(this.platform))
8420
+ return;
8421
+ if (this.hasPlayerInitialized)
8422
+ return;
8423
+ if (!window.jQuery?.fn?.YTPlayer) {
8424
+ await Utils.loadScript$('assets/babylon/js/jquery.mb.YTPlayer.min.js');
8425
+ }
8426
+ const videoEl = $('#bgndVideo');
8427
+ if (videoEl.length) {
8428
+ this.hasPlayerInitialized = true;
8429
+ videoEl.YTPlayer(this.getVideoDataProperty());
8430
+ this.renderer.setStyle(document.querySelector('.babylon__topslidervideo img'), 'display', 'none');
8431
+ }
8436
8432
  }
8437
8433
  getVideoDataProperty() {
8438
8434
  return {