ctt-babylon 0.11.9 → 0.11.10
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/esm2022/lib/components/core/babylon-ba-sli-img-txt/babylon-ba-sli-img-txt.component.mjs +4 -3
- package/esm2022/lib/components/core/babylon-banner-gallery/babylon-banner-gallery.component.mjs +3 -3
- package/esm2022/lib/components/core/babylon-he-svg-list/babylon-he-svg-list.component.mjs +3 -3
- package/esm2022/lib/components/core/babylon-top-slider/babylon-top-slider.component.mjs +2 -1
- package/esm2022/lib/directives/widget/widget-dynamic.directive.mjs +74 -0
- package/esm2022/lib/services/mapper/mapper.service.mjs +21 -10
- package/fesm2022/ctt-babylon.mjs +98 -15
- package/fesm2022/ctt-babylon.mjs.map +1 -1
- package/lib/directives/widget/widget-dynamic.directive.d.ts +19 -0
- package/package.json +1 -1
|
@@ -51,6 +51,7 @@ export class BabylonTopSliderComponent {
|
|
|
51
51
|
return;
|
|
52
52
|
if (!this.screenSizer.minMediumTablet())
|
|
53
53
|
return;
|
|
54
|
+
this.actualItems = [...(this.items ?? [])];
|
|
54
55
|
const target = document.querySelector('.youtube-bg');
|
|
55
56
|
if (!target)
|
|
56
57
|
return;
|
|
@@ -200,4 +201,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
200
201
|
}], modalClick: [{
|
|
201
202
|
type: Output
|
|
202
203
|
}] } });
|
|
203
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"babylon-top-slider.component.js","sourceRoot":"","sources":["../../../../../../../projects/babylon/src/lib/components/core/babylon-top-slider/babylon-top-slider.component.ts","../../../../../../../projects/babylon/src/lib/components/core/babylon-top-slider/babylon-top-slider.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule, isPlatformBrowser } from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    effect,\n    EventEmitter,\n    inject,\n    Input,\n    OnInit,\n    Output,\n    PLATFORM_ID,\n} from '@angular/core';\n\nimport { Subject } from 'rxjs';\nimport { BabylonSwiperSliderDirective } from '../../../directives/babylon-sliders/babylon-swiper-slider.directive';\nimport { BabylonDataBackgroundDirective } from '../../../directives/data-background/data-background.directive';\nimport { BabylonLinkTypeDirective } from '../../../directives/link-type/link-type.directive';\nimport { BabylonTagsI, BabylonTextsColorsI } from '../../../interfaces';\nimport { BabylonButtonI } from '../../../interfaces/babylon-button.interface';\nimport { BabylonImageI } from '../../../interfaces/babylon-image.interface';\nimport { ScreenSizerService } from '../../../services/screen-sizer';\nimport { Utils } from '../../../utils';\nimport { BabylonDynamicHeadingComponent } from '../../shared';\nimport { BabylonVideoSourceI } from '../babylon-top-slider-video/babylon-video-source.interface';\nimport { BabylonTopSliderItem } from './babylon-top-slider-item.interface';\nimport { takeUntil } from 'rxjs/operators';\n\n@Component({\n    selector: 'lib-babylon-top-slider',\n    standalone: true,\n    imports: [\n        CommonModule,\n        BabylonDataBackgroundDirective,\n        BabylonSwiperSliderDirective,\n        BabylonLinkTypeDirective,\n        BabylonDynamicHeadingComponent,\n    ],\n    templateUrl: './babylon-top-slider.component.html',\n    styleUrl: './babylon-top-slider.component.scss',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class BabylonTopSliderComponent implements OnInit {\n    @Input() items?: BabylonTopSliderItem[];\n    @Input() buttons?: BabylonButtonI[];\n    @Input() logo?: BabylonImageI;\n    @Input() itemsMobile?: BabylonTopSliderItem[]; // Dont work, i hace to fix\n    @Input() logoTitle?: BabylonImageI;\n    @Input() tags?: BabylonTagsI;\n    @Input() textColors?: BabylonTextsColorsI;\n    @Input() videoData?: BabylonVideoSourceI;\n\n    @Output() btnClick = new EventEmitter<BabylonButtonI>();\n    @Output() modalClick = new EventEmitter<string>();\n\n    mobile: boolean = false;\n\n    private _hideVideo = false;\n    public get hideVideo(): boolean {\n        return this._hideVideo;\n    }\n    public set hideVideo(value: boolean) {\n        this._hideVideo = value;\n        this.changeDetectorRef.markForCheck();\n    }\n\n    public actualItems = [...(this.items ?? [])];\n\n    private hasPlayerInitialized = false;\n    private observer?: IntersectionObserver;\n\n    private readonly changeDetectorRef = inject(ChangeDetectorRef);\n    private readonly screenSizer = inject(ScreenSizerService);\n    private readonly platformId = inject(PLATFORM_ID);\n\n    private destroy$ = new Subject<void>();\n\n    constructor() {\n        effect(() => {\n            this.manageVideoOrImage();\n        });\n        effect(() => {\n            const isMaxMediumTablet = this.screenSizer.maxMediumTablet();\n            if (isPlatformBrowser(this.platformId)) {\n                if (isMaxMediumTablet && this.itemsMobile?.length) {\n                    this.hideVideo = true;\n                    this.actualItems = [...this.itemsMobile];\n                } else if (this.itemsMobile?.length && this.items?.length) {\n                    this.hideVideo = false;\n                    this.actualItems = [...this.items];\n                }\n            }\n            this.changeDetectorRef.markForCheck();\n        });\n    }\n\n    ngOnInit(): void {}\n\n    ngAfterViewInit() {\n        if (!isPlatformBrowser(this.platformId)) return;\n        if (!this.screenSizer.minMediumTablet()) return;\n\n        const target = document.querySelector('.youtube-bg');\n        if (!target) return;\n\n        this.observer = new IntersectionObserver(\n            async (entries) => {\n                for (const e of entries) {\n                    if (e.isIntersecting && !this.hasPlayerInitialized) {\n                        try {\n                            await this.loadVideoPlayer();\n                        } finally {\n                            this.observer?.disconnect();\n                        }\n                    }\n                }\n            },\n            { rootMargin: '200px 0px' }\n        );\n        this.observer.observe(target);\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.platformId)) return;\n        const isDesktop = this.screenSizer.minMediumTablet();\n\n        if (!isPlatformBrowser(this.platformId) || !isDesktop) {\n            this.hideVideo = true;\n            return;\n        }\n        if (this.videoData?.src) {\n            this.hideVideo = false;\n            this.hasPlayerInitialized = false;\n            setTimeout(() => {\n                this.loadVideoPlayer();\n            }, 0);\n        } else {\n            this.hideVideo = true;\n        }\n    }\n\n    private async loadVideoPlayer(): Promise<void> {\n        await Utils.loadScript$('assets/babylon/js/jquery.min.js').toPromise();\n        await this.waitFor(() => (window as any).jQuery || (window as any).$);\n        const w = window as any;\n        if (!w.$ && w.jQuery) w.$ = w.jQuery;\n\n        const src = await this.waitFor(() => this.videoData?.src);\n        const videoId = this.extractYouTubeId(src!);\n        if (!videoId) {\n            console.warn('YT src no válido:', src);\n            return;\n        }\n\n        await Utils.loadScript$(\n            'assets/babylon/js/jquery.mb.YTPlayer.min.js'\n        ).toPromise();\n        await this.waitFor(() => w.$?.fn?.YTPlayer);\n\n        if (this.hasPlayerInitialized) return;\n\n        const $ = w.$;\n        const videoEl = $('#bgndVideo');\n        if (!videoEl?.length) return;\n        this.hasPlayerInitialized = true;\n\n        videoEl.YTPlayer({\n            videoURL: videoId,\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            quality: 'hd1080',\n            ratio: '16/9',\n            optimizeDisplay: true,\n        });\n\n        videoEl.on('YTPReady', () => {\n            try {\n                const player = videoEl.YTPGetPlayer();\n                player?.setPlaybackQuality?.('hd1080');\n            } catch {}\n        });\n    }\n\n    private waitFor<T>(\n        cond: () => T | undefined | null,\n        interval = 50,\n        timeout = 5000\n    ): Promise<T> {\n        return new Promise((resolve, reject) => {\n            const t0 = Date.now();\n            const tick = () => {\n                const v = cond();\n                if (v) return resolve(v);\n                if (Date.now() - t0 > timeout)\n                    return reject(new Error('waitFor timeout'));\n                setTimeout(tick, interval);\n            };\n            tick();\n        });\n    }\n\n    private extractYouTubeId(input: string): string | null {\n        if (!input) return null;\n\n        const idOnly = /^[\\w-]{6,}$/i;\n        if (idOnly.test(input)) return input;\n        const m = input.match(\n            /(?:v=|\\/(?:embed|shorts|v)\\/|youtu\\.be\\/)([\\w-]{6,})/i\n        );\n        return m ? m[1] : null;\n    }\n\n    scrollToSection(event: Event, sectionId: string): void {\n        event.preventDefault();\n        if (isPlatformBrowser(this.platformId)) {\n            const section = document.getElementById(sectionId);\n            if (section) {\n                section.scrollIntoView({ behavior: 'smooth' });\n            }\n        }\n    }\n}\n","<section class=\"babylon__topslider margin-main-botom\" babylonSwiperSlider>\n    <div\n        [class]=\"\n            videoData?.src && !hideVideo\n                ? 'cs_hero cs_style_4 cs_primary_bg cs_bg_filed text-center position-relative youtube-bg'\n                : 'cs_parallax_slider loading overflow-hidden position-relative'\n        \"\n    >\n        @if (videoData?.src && !hideVideo) {\n            <div id=\"bgndVideo\" class=\"player\"></div>\n        } @else if (actualItems?.length) {\n            <div class=\"swiper-wrapper\">\n                @for (item of actualItems; track $index) {\n                    <div class=\"swiper-slide\">\n                        <div\n                            class=\"cs_hero cs_style_1 cs_center text-center position-relative\"\n                        >\n                            @if (item.img) {\n                                <figure\n                                    class=\"cs_swiper_parallax_bg cs_hero_bg cs_bg_filed h-100 w-100 position-absolute top-0 start-0 mb-0\"\n                                    [attr.data-src]=\"item.img.src\"\n                                    dataBackground=\"url('{{ item.img.src }}')\"\n                                ></figure>\n                            }\n                            <div\n                                class=\"container position-relative cs_zindex_3\"\n                            >\n                                <div class=\"cs_hero_text\">\n                                    @if (item.subtitle) {\n                                        <lib-babylon-dynamic-heading\n                                            [tag]=\"tags?.title || 'h2'\"\n                                            cssClass=\"pretitle_carrusel\"\n                                            [content]=\"item.subtitle\"\n                                            [color]=\"textColors?.title\"\n                                        ></lib-babylon-dynamic-heading>\n                                    }\n                                    @if (logoTitle && logoTitle.src) {\n                                        <div class=\"logo_title\">\n                                            <img\n                                                [src]=\"logoTitle.src\"\n                                                [alt]=\"logoTitle.alt\"\n                                                loading=\"lazy\"\n                                            />\n                                        </div>\n                                    } @else {\n                                        @if (item.title) {\n                                            <lib-babylon-dynamic-heading\n                                                [tag]=\"\n                                                    tags?.title || $index == 0\n                                                        ? 'h1'\n                                                        : 'h2'\n                                                \"\n                                                cssClass=\"title_carrusel\"\n                                                [content]=\"item.title\"\n                                                [color]=\"textColors?.title\"\n                                            ></lib-babylon-dynamic-heading>\n                                        }\n                                    }\n                                    @if (item?.buttons?.length) {\n                                        @for (\n                                            button of item?.buttons;\n                                            track $index\n                                        ) {\n                                            <div\n                                                class=\"btns__box align--center\"\n                                            >\n                                                <a\n                                                    [linkType]=\"\n                                                        button?.linkType\n                                                    \"\n                                                    [href]=\"button?.url ?? '#'\"\n                                                    [modalClick]=\"modalClick\"\n                                                    class=\"btn btn_primary btn--light\"\n                                                >\n                                                    <b>{{\n                                                        button?.label ?? ''\n                                                    }}</b>\n                                                    <span\n                                                        class=\"babylon-arrow-right-big\"\n                                                    ></span>\n                                                </a>\n                                            </div>\n                                        }\n                                    }\n                                </div>\n                            </div>\n                        </div>\n                    </div>\n                }\n            </div>\n        }\n    </div>\n    @if (actualItems && actualItems.length > 1 && !videoData?.src) {\n        <div class=\"cs_slider_navigation cs_white_color\">\n            <div class=\"cs_swiper_button_prev\">\n                <span class=\"babylon-arrow-left-big\"></span>\n            </div>\n            <div class=\"cs_swiper_button_next\">\n                <span class=\"babylon-arrow-right-big\"></span>\n            </div>\n        </div>\n    }\n    @if (logo) {\n        <img\n            [src]=\"logo.src\"\n            [alt]=\"logo.alt\"\n            class=\"top-slider-logo\"\n            loading=\"lazy\"\n        />\n    }\n    <div class=\"mouse_wp\">\n        <a\n            [attr.aria-label]=\"'Scroll to first section'\"\n            href=\"#first_section\"\n            aria-label=\"first_section\"\n            (click)=\"scrollToSection($event, 'first_section')\"\n            class=\"cs_down_btn_2\"\n        >\n            <div class=\"mouse\"></div>\n        </a>\n    </div>\n</section>\n<div id=\"first_section\"></div>\n"]}
|
|
204
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"babylon-top-slider.component.js","sourceRoot":"","sources":["../../../../../../../projects/babylon/src/lib/components/core/babylon-top-slider/babylon-top-slider.component.ts","../../../../../../../projects/babylon/src/lib/components/core/babylon-top-slider/babylon-top-slider.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;AAClE,OAAO,EACH,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,MAAM,EACN,YAAY,EACZ,MAAM,EACN,KAAK,EAEL,MAAM,EACN,WAAW,GACd,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,4BAA4B,EAAE,MAAM,qEAAqE,CAAC;AACnH,OAAO,EAAE,8BAA8B,EAAE,MAAM,+DAA+D,CAAC;AAC/G,OAAO,EAAE,wBAAwB,EAAE,MAAM,mDAAmD,CAAC;AAI7F,OAAO,EAAE,kBAAkB,EAAE,MAAM,gCAAgC,CAAC;AACpE,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AACvC,OAAO,EAAE,8BAA8B,EAAE,MAAM,cAAc,CAAC;;AAkB9D,MAAM,OAAO,yBAAyB;IAgBlC,IAAW,SAAS;QAChB,OAAO,IAAI,CAAC,UAAU,CAAC;IAC3B,CAAC;IACD,IAAW,SAAS,CAAC,KAAc;QAC/B,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,CAAC,iBAAiB,CAAC,YAAY,EAAE,CAAC;IAC1C,CAAC;IAaD;QAzBU,aAAQ,GAAG,IAAI,YAAY,EAAkB,CAAC;QAC9C,eAAU,GAAG,IAAI,YAAY,EAAU,CAAC;QAElD,WAAM,GAAY,KAAK,CAAC;QAEhB,eAAU,GAAG,KAAK,CAAC;QASpB,gBAAW,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC,CAAC;QAErC,yBAAoB,GAAG,KAAK,CAAC;QAGpB,sBAAiB,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;QAC9C,gBAAW,GAAG,MAAM,CAAC,kBAAkB,CAAC,CAAC;QACzC,eAAU,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC;QAE1C,aAAQ,GAAG,IAAI,OAAO,EAAQ,CAAC;QAGnC,MAAM,CAAC,GAAG,EAAE;YACR,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC9B,CAAC,CAAC,CAAC;QACH,MAAM,CAAC,GAAG,EAAE;YACR,MAAM,iBAAiB,GAAG,IAAI,CAAC,WAAW,CAAC,eAAe,EAAE,CAAC;YAC7D,IAAI,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE;gBACpC,IAAI,iBAAiB,IAAI,IAAI,CAAC,WAAW,EAAE,MAAM,EAAE;oBAC/C,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;oBACtB,IAAI,CAAC,WAAW,GAAG,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC;iBAC5C;qBAAM,IAAI,IAAI,CAAC,WAAW,EAAE,MAAM,IAAI,IAAI,CAAC,KAAK,EAAE,MAAM,EAAE;oBACvD,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;oBACvB,IAAI,CAAC,WAAW,GAAG,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC;iBACtC;aACJ;YACD,IAAI,CAAC,iBAAiB,CAAC,YAAY,EAAE,CAAC;QAC1C,CAAC,CAAC,CAAC;IACP,CAAC;IAED,QAAQ,KAAU,CAAC;IAEnB,eAAe;QACX,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC;YAAE,OAAO;QAChD,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,eAAe,EAAE;YAAE,OAAO;QAEhD,IAAI,CAAC,WAAW,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC,CAAC;QAE3C,MAAM,MAAM,GAAG,QAAQ,CAAC,aAAa,CAAC,aAAa,CAAC,CAAC;QACrD,IAAI,CAAC,MAAM;YAAE,OAAO;QAEpB,IAAI,CAAC,QAAQ,GAAG,IAAI,oBAAoB,CACpC,KAAK,EAAE,OAAO,EAAE,EAAE;YACd,KAAK,MAAM,CAAC,IAAI,OAAO,EAAE;gBACrB,IAAI,CAAC,CAAC,cAAc,IAAI,CAAC,IAAI,CAAC,oBAAoB,EAAE;oBAChD,IAAI;wBACA,MAAM,IAAI,CAAC,eAAe,EAAE,CAAC;qBAChC;4BAAS;wBACN,IAAI,CAAC,QAAQ,EAAE,UAAU,EAAE,CAAC;qBAC/B;iBACJ;aACJ;QACL,CAAC,EACD,EAAE,UAAU,EAAE,WAAW,EAAE,CAC9B,CAAC;QACF,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;IAClC,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,UAAU,CAAC;YAAE,OAAO;QAChD,MAAM,SAAS,GAAG,IAAI,CAAC,WAAW,CAAC,eAAe,EAAE,CAAC;QAErD,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,SAAS,EAAE;YACnD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;YACtB,OAAO;SACV;QACD,IAAI,IAAI,CAAC,SAAS,EAAE,GAAG,EAAE;YACrB,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;YACvB,IAAI,CAAC,oBAAoB,GAAG,KAAK,CAAC;YAClC,UAAU,CAAC,GAAG,EAAE;gBACZ,IAAI,CAAC,eAAe,EAAE,CAAC;YAC3B,CAAC,EAAE,CAAC,CAAC,CAAC;SACT;aAAM;YACH,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;SACzB;IACL,CAAC;IAEO,KAAK,CAAC,eAAe;QACzB,MAAM,KAAK,CAAC,WAAW,CAAC,iCAAiC,CAAC,CAAC,SAAS,EAAE,CAAC;QACvE,MAAM,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,CAAE,MAAc,CAAC,MAAM,IAAK,MAAc,CAAC,CAAC,CAAC,CAAC;QACtE,MAAM,CAAC,GAAG,MAAa,CAAC;QACxB,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,MAAM;YAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC;QAErC,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC;QAC1D,MAAM,OAAO,GAAG,IAAI,CAAC,gBAAgB,CAAC,GAAI,CAAC,CAAC;QAC5C,IAAI,CAAC,OAAO,EAAE;YACV,OAAO,CAAC,IAAI,CAAC,mBAAmB,EAAE,GAAG,CAAC,CAAC;YACvC,OAAO;SACV;QAED,MAAM,KAAK,CAAC,WAAW,CACnB,6CAA6C,CAChD,CAAC,SAAS,EAAE,CAAC;QACd,MAAM,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,QAAQ,CAAC,CAAC;QAE5C,IAAI,IAAI,CAAC,oBAAoB;YAAE,OAAO;QAEtC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACd,MAAM,OAAO,GAAG,CAAC,CAAC,YAAY,CAAC,CAAC;QAChC,IAAI,CAAC,OAAO,EAAE,MAAM;YAAE,OAAO;QAC7B,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC;QAEjC,OAAO,CAAC,QAAQ,CAAC;YACb,QAAQ,EAAE,OAAO;YACjB,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;YACtB,OAAO,EAAE,QAAQ;YACjB,KAAK,EAAE,MAAM;YACb,eAAe,EAAE,IAAI;SACxB,CAAC,CAAC;QAEH,OAAO,CAAC,EAAE,CAAC,UAAU,EAAE,GAAG,EAAE;YACxB,IAAI;gBACA,MAAM,MAAM,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC;gBACtC,MAAM,EAAE,kBAAkB,EAAE,CAAC,QAAQ,CAAC,CAAC;aAC1C;YAAC,MAAM,GAAE;QACd,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,OAAO,CACX,IAAgC,EAChC,QAAQ,GAAG,EAAE,EACb,OAAO,GAAG,IAAI;QAEd,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACnC,MAAM,EAAE,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;YACtB,MAAM,IAAI,GAAG,GAAG,EAAE;gBACd,MAAM,CAAC,GAAG,IAAI,EAAE,CAAC;gBACjB,IAAI,CAAC;oBAAE,OAAO,OAAO,CAAC,CAAC,CAAC,CAAC;gBACzB,IAAI,IAAI,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,OAAO;oBACzB,OAAO,MAAM,CAAC,IAAI,KAAK,CAAC,iBAAiB,CAAC,CAAC,CAAC;gBAChD,UAAU,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;YAC/B,CAAC,CAAC;YACF,IAAI,EAAE,CAAC;QACX,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,gBAAgB,CAAC,KAAa;QAClC,IAAI,CAAC,KAAK;YAAE,OAAO,IAAI,CAAC;QAExB,MAAM,MAAM,GAAG,cAAc,CAAC;QAC9B,IAAI,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC;YAAE,OAAO,KAAK,CAAC;QACrC,MAAM,CAAC,GAAG,KAAK,CAAC,KAAK,CACjB,uDAAuD,CAC1D,CAAC;QACF,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IAC3B,CAAC;IAED,eAAe,CAAC,KAAY,EAAE,SAAiB;QAC3C,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,IAAI,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE;YACpC,MAAM,OAAO,GAAG,QAAQ,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC;YACnD,IAAI,OAAO,EAAE;gBACT,OAAO,CAAC,cAAc,CAAC,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC,CAAC;aAClD;SACJ;IACL,CAAC;+GAhMQ,yBAAyB;mGAAzB,yBAAyB,iUCzCtC,mmMA2HA,yl4BD5FQ,YAAY,+BACZ,8BAA8B,yFAC9B,4BAA4B,kEAC5B,wBAAwB,6IACxB,8BAA8B;;4FAMzB,yBAAyB;kBAdrC,SAAS;+BACI,wBAAwB,cACtB,IAAI,WACP;wBACL,YAAY;wBACZ,8BAA8B;wBAC9B,4BAA4B;wBAC5B,wBAAwB;wBACxB,8BAA8B;qBACjC,mBAGgB,uBAAuB,CAAC,MAAM;wDAGtC,KAAK;sBAAb,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBAEI,QAAQ;sBAAjB,MAAM;gBACG,UAAU;sBAAnB,MAAM","sourcesContent":["import { CommonModule, isPlatformBrowser } from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    effect,\n    EventEmitter,\n    inject,\n    Input,\n    OnInit,\n    Output,\n    PLATFORM_ID,\n} from '@angular/core';\n\nimport { Subject } from 'rxjs';\nimport { BabylonSwiperSliderDirective } from '../../../directives/babylon-sliders/babylon-swiper-slider.directive';\nimport { BabylonDataBackgroundDirective } from '../../../directives/data-background/data-background.directive';\nimport { BabylonLinkTypeDirective } from '../../../directives/link-type/link-type.directive';\nimport { BabylonTagsI, BabylonTextsColorsI } from '../../../interfaces';\nimport { BabylonButtonI } from '../../../interfaces/babylon-button.interface';\nimport { BabylonImageI } from '../../../interfaces/babylon-image.interface';\nimport { ScreenSizerService } from '../../../services/screen-sizer';\nimport { Utils } from '../../../utils';\nimport { BabylonDynamicHeadingComponent } from '../../shared';\nimport { BabylonVideoSourceI } from '../babylon-top-slider-video/babylon-video-source.interface';\nimport { BabylonTopSliderItem } from './babylon-top-slider-item.interface';\n\n@Component({\n    selector: 'lib-babylon-top-slider',\n    standalone: true,\n    imports: [\n        CommonModule,\n        BabylonDataBackgroundDirective,\n        BabylonSwiperSliderDirective,\n        BabylonLinkTypeDirective,\n        BabylonDynamicHeadingComponent,\n    ],\n    templateUrl: './babylon-top-slider.component.html',\n    styleUrl: './babylon-top-slider.component.scss',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class BabylonTopSliderComponent implements OnInit {\n    @Input() items?: BabylonTopSliderItem[];\n    @Input() buttons?: BabylonButtonI[];\n    @Input() logo?: BabylonImageI;\n    @Input() itemsMobile?: BabylonTopSliderItem[]; // Dont work, i hace to fix\n    @Input() logoTitle?: BabylonImageI;\n    @Input() tags?: BabylonTagsI;\n    @Input() textColors?: BabylonTextsColorsI;\n    @Input() videoData?: BabylonVideoSourceI;\n\n    @Output() btnClick = new EventEmitter<BabylonButtonI>();\n    @Output() modalClick = new EventEmitter<string>();\n\n    mobile: boolean = false;\n\n    private _hideVideo = false;\n    public get hideVideo(): boolean {\n        return this._hideVideo;\n    }\n    public set hideVideo(value: boolean) {\n        this._hideVideo = value;\n        this.changeDetectorRef.markForCheck();\n    }\n\n    public actualItems = [...(this.items ?? [])];\n\n    private hasPlayerInitialized = false;\n    private observer?: IntersectionObserver;\n\n    private readonly changeDetectorRef = inject(ChangeDetectorRef);\n    private readonly screenSizer = inject(ScreenSizerService);\n    private readonly platformId = inject(PLATFORM_ID);\n\n    private destroy$ = new Subject<void>();\n\n    constructor() {\n        effect(() => {\n            this.manageVideoOrImage();\n        });\n        effect(() => {\n            const isMaxMediumTablet = this.screenSizer.maxMediumTablet();\n            if (isPlatformBrowser(this.platformId)) {\n                if (isMaxMediumTablet && this.itemsMobile?.length) {\n                    this.hideVideo = true;\n                    this.actualItems = [...this.itemsMobile];\n                } else if (this.itemsMobile?.length && this.items?.length) {\n                    this.hideVideo = false;\n                    this.actualItems = [...this.items];\n                }\n            }\n            this.changeDetectorRef.markForCheck();\n        });\n    }\n\n    ngOnInit(): void {}\n\n    ngAfterViewInit() {\n        if (!isPlatformBrowser(this.platformId)) return;\n        if (!this.screenSizer.minMediumTablet()) return;\n\n        this.actualItems = [...(this.items ?? [])];\n\n        const target = document.querySelector('.youtube-bg');\n        if (!target) return;\n\n        this.observer = new IntersectionObserver(\n            async (entries) => {\n                for (const e of entries) {\n                    if (e.isIntersecting && !this.hasPlayerInitialized) {\n                        try {\n                            await this.loadVideoPlayer();\n                        } finally {\n                            this.observer?.disconnect();\n                        }\n                    }\n                }\n            },\n            { rootMargin: '200px 0px' }\n        );\n        this.observer.observe(target);\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.platformId)) return;\n        const isDesktop = this.screenSizer.minMediumTablet();\n\n        if (!isPlatformBrowser(this.platformId) || !isDesktop) {\n            this.hideVideo = true;\n            return;\n        }\n        if (this.videoData?.src) {\n            this.hideVideo = false;\n            this.hasPlayerInitialized = false;\n            setTimeout(() => {\n                this.loadVideoPlayer();\n            }, 0);\n        } else {\n            this.hideVideo = true;\n        }\n    }\n\n    private async loadVideoPlayer(): Promise<void> {\n        await Utils.loadScript$('assets/babylon/js/jquery.min.js').toPromise();\n        await this.waitFor(() => (window as any).jQuery || (window as any).$);\n        const w = window as any;\n        if (!w.$ && w.jQuery) w.$ = w.jQuery;\n\n        const src = await this.waitFor(() => this.videoData?.src);\n        const videoId = this.extractYouTubeId(src!);\n        if (!videoId) {\n            console.warn('YT src no válido:', src);\n            return;\n        }\n\n        await Utils.loadScript$(\n            'assets/babylon/js/jquery.mb.YTPlayer.min.js'\n        ).toPromise();\n        await this.waitFor(() => w.$?.fn?.YTPlayer);\n\n        if (this.hasPlayerInitialized) return;\n\n        const $ = w.$;\n        const videoEl = $('#bgndVideo');\n        if (!videoEl?.length) return;\n        this.hasPlayerInitialized = true;\n\n        videoEl.YTPlayer({\n            videoURL: videoId,\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            quality: 'hd1080',\n            ratio: '16/9',\n            optimizeDisplay: true,\n        });\n\n        videoEl.on('YTPReady', () => {\n            try {\n                const player = videoEl.YTPGetPlayer();\n                player?.setPlaybackQuality?.('hd1080');\n            } catch {}\n        });\n    }\n\n    private waitFor<T>(\n        cond: () => T | undefined | null,\n        interval = 50,\n        timeout = 5000\n    ): Promise<T> {\n        return new Promise((resolve, reject) => {\n            const t0 = Date.now();\n            const tick = () => {\n                const v = cond();\n                if (v) return resolve(v);\n                if (Date.now() - t0 > timeout)\n                    return reject(new Error('waitFor timeout'));\n                setTimeout(tick, interval);\n            };\n            tick();\n        });\n    }\n\n    private extractYouTubeId(input: string): string | null {\n        if (!input) return null;\n\n        const idOnly = /^[\\w-]{6,}$/i;\n        if (idOnly.test(input)) return input;\n        const m = input.match(\n            /(?:v=|\\/(?:embed|shorts|v)\\/|youtu\\.be\\/)([\\w-]{6,})/i\n        );\n        return m ? m[1] : null;\n    }\n\n    scrollToSection(event: Event, sectionId: string): void {\n        event.preventDefault();\n        if (isPlatformBrowser(this.platformId)) {\n            const section = document.getElementById(sectionId);\n            if (section) {\n                section.scrollIntoView({ behavior: 'smooth' });\n            }\n        }\n    }\n}\n","<section class=\"babylon__topslider margin-main-botom\" babylonSwiperSlider>\n    <div\n        [class]=\"\n            videoData?.src && !hideVideo\n                ? 'cs_hero cs_style_4 cs_primary_bg cs_bg_filed text-center position-relative youtube-bg'\n                : 'cs_parallax_slider loading overflow-hidden position-relative'\n        \"\n    >\n        @if (videoData?.src && !hideVideo) {\n            <div id=\"bgndVideo\" class=\"player\"></div>\n        } @else if (actualItems?.length) {\n            <div class=\"swiper-wrapper\">\n                @for (item of actualItems; track $index) {\n                    <div class=\"swiper-slide\">\n                        <div\n                            class=\"cs_hero cs_style_1 cs_center text-center position-relative\"\n                        >\n                            @if (item.img) {\n                                <figure\n                                    class=\"cs_swiper_parallax_bg cs_hero_bg cs_bg_filed h-100 w-100 position-absolute top-0 start-0 mb-0\"\n                                    [attr.data-src]=\"item.img.src\"\n                                    dataBackground=\"url('{{ item.img.src }}')\"\n                                ></figure>\n                            }\n                            <div\n                                class=\"container position-relative cs_zindex_3\"\n                            >\n                                <div class=\"cs_hero_text\">\n                                    @if (item.subtitle) {\n                                        <lib-babylon-dynamic-heading\n                                            [tag]=\"tags?.title || 'h2'\"\n                                            cssClass=\"pretitle_carrusel\"\n                                            [content]=\"item.subtitle\"\n                                            [color]=\"textColors?.title\"\n                                        ></lib-babylon-dynamic-heading>\n                                    }\n                                    @if (logoTitle && logoTitle.src) {\n                                        <div class=\"logo_title\">\n                                            <img\n                                                [src]=\"logoTitle.src\"\n                                                [alt]=\"logoTitle.alt\"\n                                                loading=\"lazy\"\n                                            />\n                                        </div>\n                                    } @else {\n                                        @if (item.title) {\n                                            <lib-babylon-dynamic-heading\n                                                [tag]=\"\n                                                    tags?.title || $index == 0\n                                                        ? 'h1'\n                                                        : 'h2'\n                                                \"\n                                                cssClass=\"title_carrusel\"\n                                                [content]=\"item.title\"\n                                                [color]=\"textColors?.title\"\n                                            ></lib-babylon-dynamic-heading>\n                                        }\n                                    }\n                                    @if (item?.buttons?.length) {\n                                        @for (\n                                            button of item?.buttons;\n                                            track $index\n                                        ) {\n                                            <div\n                                                class=\"btns__box align--center\"\n                                            >\n                                                <a\n                                                    [linkType]=\"\n                                                        button?.linkType\n                                                    \"\n                                                    [href]=\"button?.url ?? '#'\"\n                                                    [modalClick]=\"modalClick\"\n                                                    class=\"btn btn_primary btn--light\"\n                                                >\n                                                    <b>{{\n                                                        button?.label ?? ''\n                                                    }}</b>\n                                                    <span\n                                                        class=\"babylon-arrow-right-big\"\n                                                    ></span>\n                                                </a>\n                                            </div>\n                                        }\n                                    }\n                                </div>\n                            </div>\n                        </div>\n                    </div>\n                }\n            </div>\n        }\n    </div>\n    @if (actualItems && actualItems.length > 1 && !videoData?.src) {\n        <div class=\"cs_slider_navigation cs_white_color\">\n            <div class=\"cs_swiper_button_prev\">\n                <span class=\"babylon-arrow-left-big\"></span>\n            </div>\n            <div class=\"cs_swiper_button_next\">\n                <span class=\"babylon-arrow-right-big\"></span>\n            </div>\n        </div>\n    }\n    @if (logo) {\n        <img\n            [src]=\"logo.src\"\n            [alt]=\"logo.alt\"\n            class=\"top-slider-logo\"\n            loading=\"lazy\"\n        />\n    }\n    <div class=\"mouse_wp\">\n        <a\n            [attr.aria-label]=\"'Scroll to first section'\"\n            href=\"#first_section\"\n            aria-label=\"first_section\"\n            (click)=\"scrollToSection($event, 'first_section')\"\n            class=\"cs_down_btn_2\"\n        >\n            <div class=\"mouse\"></div>\n        </a>\n    </div>\n</section>\n<div id=\"first_section\"></div>\n"]}
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
import { isPlatformBrowser } from '@angular/common';
|
|
2
|
+
import { Directive, Input, NgZone, PLATFORM_ID, inject, } from '@angular/core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class WidgetDynamicDirective {
|
|
5
|
+
constructor(host) {
|
|
6
|
+
this.host = host;
|
|
7
|
+
this.platformId = inject(PLATFORM_ID);
|
|
8
|
+
this.zone = inject(NgZone);
|
|
9
|
+
/** Reintentos */
|
|
10
|
+
this.moveMaxTries = 200; // 200 * 100ms = 20s
|
|
11
|
+
this.moveIntervalMs = 100;
|
|
12
|
+
}
|
|
13
|
+
ngAfterViewInit() {
|
|
14
|
+
if (!isPlatformBrowser(this.platformId))
|
|
15
|
+
return;
|
|
16
|
+
if (!this.moveSelector)
|
|
17
|
+
return;
|
|
18
|
+
this.zone.runOutsideAngular(() => {
|
|
19
|
+
const target = this.host.nativeElement;
|
|
20
|
+
const tryMove = () => {
|
|
21
|
+
const node = document.querySelector(this.moveSelector);
|
|
22
|
+
if (!node)
|
|
23
|
+
return false;
|
|
24
|
+
// si ya está dentro, ok
|
|
25
|
+
if (target.contains(node))
|
|
26
|
+
return true;
|
|
27
|
+
// evita movidas raras si el selector apunta al mismo host
|
|
28
|
+
if (node === target)
|
|
29
|
+
return true;
|
|
30
|
+
target.appendChild(node);
|
|
31
|
+
return true;
|
|
32
|
+
};
|
|
33
|
+
// reintentos
|
|
34
|
+
let tries = 0;
|
|
35
|
+
this.timer = window.setInterval(() => {
|
|
36
|
+
tries++;
|
|
37
|
+
const ok = tryMove();
|
|
38
|
+
if (ok || tries >= this.moveMaxTries) {
|
|
39
|
+
if (this.timer)
|
|
40
|
+
window.clearInterval(this.timer);
|
|
41
|
+
this.timer = undefined;
|
|
42
|
+
}
|
|
43
|
+
}, this.moveIntervalMs);
|
|
44
|
+
// observer para reinyecciones
|
|
45
|
+
this.observer = new MutationObserver(() => tryMove());
|
|
46
|
+
this.observer.observe(document.body, {
|
|
47
|
+
childList: true,
|
|
48
|
+
subtree: true,
|
|
49
|
+
});
|
|
50
|
+
});
|
|
51
|
+
}
|
|
52
|
+
ngOnDestroy() {
|
|
53
|
+
if (this.timer)
|
|
54
|
+
window.clearInterval(this.timer);
|
|
55
|
+
this.observer?.disconnect();
|
|
56
|
+
}
|
|
57
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: WidgetDynamicDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
58
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.12", type: WidgetDynamicDirective, isStandalone: true, selector: "[widgetDynamic]", inputs: { moveSelector: ["widgetDynamic", "moveSelector"], moveMaxTries: "moveMaxTries", moveIntervalMs: "moveIntervalMs" }, ngImport: i0 }); }
|
|
59
|
+
}
|
|
60
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: WidgetDynamicDirective, decorators: [{
|
|
61
|
+
type: Directive,
|
|
62
|
+
args: [{
|
|
63
|
+
selector: '[widgetDynamic]',
|
|
64
|
+
standalone: true,
|
|
65
|
+
}]
|
|
66
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }], propDecorators: { moveSelector: [{
|
|
67
|
+
type: Input,
|
|
68
|
+
args: ['widgetDynamic']
|
|
69
|
+
}], moveMaxTries: [{
|
|
70
|
+
type: Input
|
|
71
|
+
}], moveIntervalMs: [{
|
|
72
|
+
type: Input
|
|
73
|
+
}] } });
|
|
74
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2lkZ2V0LWR5bmFtaWMuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFieWxvbi9zcmMvbGliL2RpcmVjdGl2ZXMvd2lkZ2V0L3dpZGdldC1keW5hbWljLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUNwRCxPQUFPLEVBRUgsU0FBUyxFQUVULEtBQUssRUFDTCxNQUFNLEVBRU4sV0FBVyxFQUNYLE1BQU0sR0FDVCxNQUFNLGVBQWUsQ0FBQzs7QUFNdkIsTUFBTSxPQUFPLHNCQUFzQjtJQWMvQixZQUFvQixJQUE2QjtRQUE3QixTQUFJLEdBQUosSUFBSSxDQUF5QjtRQWJoQyxlQUFVLEdBQUcsTUFBTSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBQ2pDLFNBQUksR0FBRyxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUM7UUFLdkMsaUJBQWlCO1FBQ1IsaUJBQVksR0FBRyxHQUFHLENBQUMsQ0FBQyxvQkFBb0I7UUFDeEMsbUJBQWMsR0FBRyxHQUFHLENBQUM7SUFLc0IsQ0FBQztJQUVyRCxlQUFlO1FBQ1gsSUFBSSxDQUFDLGlCQUFpQixDQUFDLElBQUksQ0FBQyxVQUFVLENBQUM7WUFBRSxPQUFPO1FBQ2hELElBQUksQ0FBQyxJQUFJLENBQUMsWUFBWTtZQUFFLE9BQU87UUFFL0IsSUFBSSxDQUFDLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxHQUFHLEVBQUU7WUFDN0IsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUM7WUFFdkMsTUFBTSxPQUFPLEdBQUcsR0FBRyxFQUFFO2dCQUNqQixNQUFNLElBQUksR0FBRyxRQUFRLENBQUMsYUFBYSxDQUMvQixJQUFJLENBQUMsWUFBWSxDQUNFLENBQUM7Z0JBQ3hCLElBQUksQ0FBQyxJQUFJO29CQUFFLE9BQU8sS0FBSyxDQUFDO2dCQUV4Qix3QkFBd0I7Z0JBQ3hCLElBQUksTUFBTSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUM7b0JBQUUsT0FBTyxJQUFJLENBQUM7Z0JBRXZDLDBEQUEwRDtnQkFDMUQsSUFBSSxJQUFJLEtBQUssTUFBTTtvQkFBRSxPQUFPLElBQUksQ0FBQztnQkFFakMsTUFBTSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsQ0FBQztnQkFDekIsT0FBTyxJQUFJLENBQUM7WUFDaEIsQ0FBQyxDQUFDO1lBRUYsYUFBYTtZQUNiLElBQUksS0FBSyxHQUFHLENBQUMsQ0FBQztZQUNkLElBQUksQ0FBQyxLQUFLLEdBQUcsTUFBTSxDQUFDLFdBQVcsQ0FBQyxHQUFHLEVBQUU7Z0JBQ2pDLEtBQUssRUFBRSxDQUFDO2dCQUNSLE1BQU0sRUFBRSxHQUFHLE9BQU8sRUFBRSxDQUFDO2dCQUNyQixJQUFJLEVBQUUsSUFBSSxLQUFLLElBQUksSUFBSSxDQUFDLFlBQVksRUFBRTtvQkFDbEMsSUFBSSxJQUFJLENBQUMsS0FBSzt3QkFBRSxNQUFNLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztvQkFDakQsSUFBSSxDQUFDLEtBQUssR0FBRyxTQUFTLENBQUM7aUJBQzFCO1lBQ0wsQ0FBQyxFQUFFLElBQUksQ0FBQyxjQUFjLENBQUMsQ0FBQztZQUV4Qiw4QkFBOEI7WUFDOUIsSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLGdCQUFnQixDQUFDLEdBQUcsRUFBRSxDQUFDLE9BQU8sRUFBRSxDQUFDLENBQUM7WUFDdEQsSUFBSSxDQUFDLFFBQVEsQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLElBQUksRUFBRTtnQkFDakMsU0FBUyxFQUFFLElBQUk7Z0JBQ2YsT0FBTyxFQUFFLElBQUk7YUFDaEIsQ0FBQyxDQUFDO1FBQ1AsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0lBRUQsV0FBVztRQUNQLElBQUksSUFBSSxDQUFDLEtBQUs7WUFBRSxNQUFNLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUNqRCxJQUFJLENBQUMsUUFBUSxFQUFFLFVBQVUsRUFBRSxDQUFDO0lBQ2hDLENBQUM7K0dBOURRLHNCQUFzQjttR0FBdEIsc0JBQXNCOzs0RkFBdEIsc0JBQXNCO2tCQUpsQyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSxpQkFBaUI7b0JBQzNCLFVBQVUsRUFBRSxJQUFJO2lCQUNuQjsrRUFNMkIsWUFBWTtzQkFBbkMsS0FBSzt1QkFBQyxlQUFlO2dCQUdiLFlBQVk7c0JBQXBCLEtBQUs7Z0JBQ0csY0FBYztzQkFBdEIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGlzUGxhdGZvcm1Ccm93c2VyIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7XG4gICAgQWZ0ZXJWaWV3SW5pdCxcbiAgICBEaXJlY3RpdmUsXG4gICAgRWxlbWVudFJlZixcbiAgICBJbnB1dCxcbiAgICBOZ1pvbmUsXG4gICAgT25EZXN0cm95LFxuICAgIFBMQVRGT1JNX0lELFxuICAgIGluamVjdCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBEaXJlY3RpdmUoe1xuICAgIHNlbGVjdG9yOiAnW3dpZGdldER5bmFtaWNdJyxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxufSlcbmV4cG9ydCBjbGFzcyBXaWRnZXREeW5hbWljRGlyZWN0aXZlIGltcGxlbWVudHMgQWZ0ZXJWaWV3SW5pdCwgT25EZXN0cm95IHtcbiAgICBwcml2YXRlIHJlYWRvbmx5IHBsYXRmb3JtSWQgPSBpbmplY3QoUExBVEZPUk1fSUQpO1xuICAgIHByaXZhdGUgcmVhZG9ubHkgem9uZSA9IGluamVjdChOZ1pvbmUpO1xuXG4gICAgLyoqIFNlbGVjdG9yIGRlbCBub2RvIGEgbW92ZXIgKHNvdXJjZSkgKi9cbiAgICBASW5wdXQoJ3dpZGdldER5bmFtaWMnKSBtb3ZlU2VsZWN0b3IhOiBzdHJpbmc7XG5cbiAgICAvKiogUmVpbnRlbnRvcyAqL1xuICAgIEBJbnB1dCgpIG1vdmVNYXhUcmllcyA9IDIwMDsgLy8gMjAwICogMTAwbXMgPSAyMHNcbiAgICBASW5wdXQoKSBtb3ZlSW50ZXJ2YWxNcyA9IDEwMDtcblxuICAgIHByaXZhdGUgb2JzZXJ2ZXI/OiBNdXRhdGlvbk9ic2VydmVyO1xuICAgIHByaXZhdGUgdGltZXI/OiBudW1iZXI7XG5cbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIGhvc3Q6IEVsZW1lbnRSZWY8SFRNTEVsZW1lbnQ+KSB7fVxuXG4gICAgbmdBZnRlclZpZXdJbml0KCk6IHZvaWQge1xuICAgICAgICBpZiAoIWlzUGxhdGZvcm1Ccm93c2VyKHRoaXMucGxhdGZvcm1JZCkpIHJldHVybjtcbiAgICAgICAgaWYgKCF0aGlzLm1vdmVTZWxlY3RvcikgcmV0dXJuO1xuXG4gICAgICAgIHRoaXMuem9uZS5ydW5PdXRzaWRlQW5ndWxhcigoKSA9PiB7XG4gICAgICAgICAgICBjb25zdCB0YXJnZXQgPSB0aGlzLmhvc3QubmF0aXZlRWxlbWVudDtcblxuICAgICAgICAgICAgY29uc3QgdHJ5TW92ZSA9ICgpID0+IHtcbiAgICAgICAgICAgICAgICBjb25zdCBub2RlID0gZG9jdW1lbnQucXVlcnlTZWxlY3RvcihcbiAgICAgICAgICAgICAgICAgICAgdGhpcy5tb3ZlU2VsZWN0b3JcbiAgICAgICAgICAgICAgICApIGFzIEhUTUxFbGVtZW50IHwgbnVsbDtcbiAgICAgICAgICAgICAgICBpZiAoIW5vZGUpIHJldHVybiBmYWxzZTtcblxuICAgICAgICAgICAgICAgIC8vIHNpIHlhIGVzdMOhIGRlbnRybywgb2tcbiAgICAgICAgICAgICAgICBpZiAodGFyZ2V0LmNvbnRhaW5zKG5vZGUpKSByZXR1cm4gdHJ1ZTtcblxuICAgICAgICAgICAgICAgIC8vIGV2aXRhIG1vdmlkYXMgcmFyYXMgc2kgZWwgc2VsZWN0b3IgYXB1bnRhIGFsIG1pc21vIGhvc3RcbiAgICAgICAgICAgICAgICBpZiAobm9kZSA9PT0gdGFyZ2V0KSByZXR1cm4gdHJ1ZTtcblxuICAgICAgICAgICAgICAgIHRhcmdldC5hcHBlbmRDaGlsZChub2RlKTtcbiAgICAgICAgICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICAgICAgICAgIH07XG5cbiAgICAgICAgICAgIC8vIHJlaW50ZW50b3NcbiAgICAgICAgICAgIGxldCB0cmllcyA9IDA7XG4gICAgICAgICAgICB0aGlzLnRpbWVyID0gd2luZG93LnNldEludGVydmFsKCgpID0+IHtcbiAgICAgICAgICAgICAgICB0cmllcysrO1xuICAgICAgICAgICAgICAgIGNvbnN0IG9rID0gdHJ5TW92ZSgpO1xuICAgICAgICAgICAgICAgIGlmIChvayB8fCB0cmllcyA+PSB0aGlzLm1vdmVNYXhUcmllcykge1xuICAgICAgICAgICAgICAgICAgICBpZiAodGhpcy50aW1lcikgd2luZG93LmNsZWFySW50ZXJ2YWwodGhpcy50aW1lcik7XG4gICAgICAgICAgICAgICAgICAgIHRoaXMudGltZXIgPSB1bmRlZmluZWQ7XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfSwgdGhpcy5tb3ZlSW50ZXJ2YWxNcyk7XG5cbiAgICAgICAgICAgIC8vIG9ic2VydmVyIHBhcmEgcmVpbnllY2Npb25lc1xuICAgICAgICAgICAgdGhpcy5vYnNlcnZlciA9IG5ldyBNdXRhdGlvbk9ic2VydmVyKCgpID0+IHRyeU1vdmUoKSk7XG4gICAgICAgICAgICB0aGlzLm9ic2VydmVyLm9ic2VydmUoZG9jdW1lbnQuYm9keSwge1xuICAgICAgICAgICAgICAgIGNoaWxkTGlzdDogdHJ1ZSxcbiAgICAgICAgICAgICAgICBzdWJ0cmVlOiB0cnVlLFxuICAgICAgICAgICAgfSk7XG4gICAgICAgIH0pO1xuICAgIH1cblxuICAgIG5nT25EZXN0cm95KCk6IHZvaWQge1xuICAgICAgICBpZiAodGhpcy50aW1lcikgd2luZG93LmNsZWFySW50ZXJ2YWwodGhpcy50aW1lcik7XG4gICAgICAgIHRoaXMub2JzZXJ2ZXI/LmRpc2Nvbm5lY3QoKTtcbiAgICB9XG59XG4iXX0=
|