tent-lib 0.0.788 → 0.0.789
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.
|
@@ -83,6 +83,7 @@ export class BrunchComponent {
|
|
|
83
83
|
}
|
|
84
84
|
onPlayerReady(event) {
|
|
85
85
|
event.target.mute();
|
|
86
|
+
event.target.seekTo(0.1, true);
|
|
86
87
|
event.target.playVideo();
|
|
87
88
|
}
|
|
88
89
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: BrunchComponent, deps: [{ token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
@@ -113,4 +114,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
113
114
|
}], timmingItems: [{
|
|
114
115
|
type: Input
|
|
115
116
|
}] } });
|
|
116
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"brunch.component.js","sourceRoot":"","sources":["../../../../../../../projects/tent/src/lib/components/core/brunch/brunch.component.ts","../../../../../../../projects/tent/src/lib/components/core/brunch/brunch.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { Component, Input, OnInit, Renderer2 } from '@angular/core';\r\nimport { MatProgressSpinnerModule } from '@angular/material/progress-spinner';\r\nimport { YouTubePlayerModule } from '@angular/youtube-player';\r\nimport { ButtonI } from '../../../interfaces/atomic/button.interface';\r\nimport { ImageI } from '../../../interfaces/atomic/image.interface';\r\nimport { ButtonComponent } from '../../atomic/button/button.component';\r\n@Component({\r\n    selector: 'tent-brunch',\r\n    standalone: true,\r\n    imports: [\r\n        CommonModule,\r\n        ButtonComponent,\r\n        YouTubePlayerModule,\r\n        MatProgressSpinnerModule,\r\n    ],\r\n    templateUrl: './brunch.component.html',\r\n    styleUrl: './brunch.component.scss',\r\n})\r\nexport class BrunchComponent implements OnInit {\r\n    @Input() title?: string;\r\n    @Input() description?: string;\r\n    @Input() additionalDescription?: string;\r\n    @Input() links?: ButtonI[];\r\n    @Input() image?: ImageI;\r\n    @Input() video?: ImageI;\r\n    @Input() timmingTitle?: string;\r\n    @Input() timmingItems?: TimingItem[];\r\n    showMore = false;\r\n\r\n    tag!: HTMLScriptElement;\r\n    playerVars!: YT.PlayerVars;\r\n    apiloaded = false;\r\n    loading = true;\r\n\r\n    constructor(private readonly renderer: Renderer2) {}\r\n\r\n    toggleShowMore(): void {\r\n        this.showMore = !this.showMore;\r\n    }\r\n\r\n    ngOnInit(): void {\r\n        this.playerVars = {\r\n            enablejsapi: 1,\r\n            autoplay: 1,\r\n            controls: 0,\r\n            showinfo: 0,\r\n            modestbranding: 1,\r\n            loop: 1,\r\n            fs: 1,\r\n            cc_load_policy: 1,\r\n            iv_load_policy: 3,\r\n            autohide: 1,\r\n            rel: 0,\r\n            playsinline: 1,\r\n            playlist: this.video?.src,\r\n        };\r\n        if (this.video) {\r\n            this.initPlayer();\r\n        }\r\n    }\r\n\r\n    onStateChange(e: any) {\r\n        e.target.setPlaybackQuality('highres');\r\n        if (e.data == YT.PlayerState.PLAYING) {\r\n            e.target.mute();\r\n            setTimeout(() => {\r\n                e.target.playVideo();\r\n                document\r\n                    .getElementsByTagName('youtube-player')[0]\r\n                    .children[0].children[0].setAttribute(\r\n                        'style',\r\n                        'opacity: 1'\r\n                    );\r\n                this.loading = false;\r\n            }, 1000);\r\n        }\r\n        if (e.data == YT.PlayerState.PAUSED) {\r\n            e.target.mute();\r\n            setTimeout(() => {\r\n                e.target.playVideo();\r\n                document\r\n                    .getElementsByTagName('youtube-player')[0]\r\n                    .children[0].children[0].setAttribute(\r\n                        'style',\r\n                        'opacity: 1'\r\n                    );\r\n                this.loading = false;\r\n            }, 1000);\r\n        }\r\n        if (e.data == YT.PlayerState.ENDED) {\r\n            e.target.mute();\r\n            e.target.seekTo(0);\r\n            e.target.playVideo();\r\n        }\r\n    }\r\n\r\n    initPlayer(): void {\r\n        const existingScript = Array.from(\r\n            document.getElementsByTagName('script')\r\n        ).find((script) => script.src === 'https://www.youtube.com/iframe_api');\r\n\r\n        if (!existingScript) {\r\n            this.tag = document.createElement('script');\r\n            this.tag.src = 'https://www.youtube.com/iframe_api';\r\n            this.tag.async = true;\r\n            const firstScriptTag = document.getElementsByTagName('script')[0];\r\n            firstScriptTag.parentNode?.insertBefore(this.tag, firstScriptTag);\r\n\r\n            (window as any)['onYouTubeIframeAPIReady'] = () => {\r\n                this.apiloaded = true;\r\n            };\r\n        } else {\r\n            this.apiloaded = true;\r\n        }\r\n    }\r\n\r\n    onPlayerReady(event: any) {\r\n        event.target.mute();\r\n        event.target.playVideo();\r\n    }\r\n}\r\n\r\nexport interface TimingItem {\r\n    label: string;\r\n    icon?: string;\r\n}\r\n","<div class=\"wrapper-big module-spacer--bottom\">\r\n    <div class=\"brunch\">\r\n        @if (video || image) {\r\n        <div class=\"brunch--video-wrapper figure-sticky\">\r\n            @if (video) {\r\n            <div class=\"brunch--video\">\r\n                @if (loading) {\r\n                <mat-spinner></mat-spinner>\r\n                } @if (apiloaded) {\r\n                <youtube-player\r\n                    #ytPlayer\r\n                    [videoId]=\"video.src\"\r\n                    suggestedQuality=\"highres\"\r\n                    [showBeforeIframeApiLoads]=\"true\"\r\n                    [playerVars]=\"playerVars\"\r\n                    (stateChange)=\"onStateChange($event)\"\r\n                    (ready)=\"onPlayerReady($event)\"\r\n                    [disablePlaceholder]=\"true\"\r\n                >\r\n                </youtube-player\r\n                >}\r\n            </div>\r\n            } @else if (image) {\r\n            <img\r\n                class=\"brunch--video\"\r\n                [src]=\"image.src\"\r\n                [alt]=\"image.alt\"\r\n                width=\"600\"\r\n                height=\"600\"\r\n                loading=\"lazy\"\r\n            />\r\n            }\r\n        </div>\r\n        }\r\n        <div class=\"brunch--content-wrapper\">\r\n            @if (title) {\r\n            <h2 class=\"brunch--title title--60 color--brown\">{{ title }}</h2>\r\n            } @if (description) {\r\n            <p class=\"brunch--description text\">\r\n                {{ description }}\r\n            </p>\r\n            } @if (showMore && additionalDescription) {\r\n            <p class=\"brunch--description text\">\r\n                {{ additionalDescription }}\r\n            </p>\r\n\r\n            } @if (additionalDescription && links?.length) { @if (!showMore) {\r\n            <tent-button\r\n                class=\"brunch--show-more\"\r\n                type=\"dark-link\"\r\n                [label]=\"links?.[0]?.label\"\r\n                (btnClick)=\"toggleShowMore()\"\r\n                [name]=\"links?.[0]?.label\"\r\n            >\r\n            </tent-button>\r\n            } @else {\r\n            <tent-button\r\n                type=\"dark-link\"\r\n                [label]=\"links?.[1]?.label\"\r\n                (btnClick)=\"toggleShowMore()\"\r\n                [name]=\"links?.[1]?.label\"\r\n            >\r\n            </tent-button>\r\n            } } @if (timmingItems?.length) {\r\n            <div class=\"brunch--timing-info\">\r\n                @if (timmingTitle) {\r\n                <p class=\"brunch--timing-title\">horarios</p>\r\n                }\r\n                <ul class=\"brunch--timing-list\">\r\n                    @for (item of timmingItems; track $index) { @if (item.label)\r\n                    {\r\n                    <li class=\"brunch--timing-item\">\r\n                        @if (item.icon) {\r\n                        <span\r\n                            class=\"brunch--timing-item--icon\"\r\n                            [ngClass]=\"item.icon\"\r\n                        ></span>\r\n                        }\r\n                        <span class=\"brunch--timing-item--text\">\r\n                            {{ item.label }}\r\n                        </span>\r\n                    </li>\r\n                    } }\r\n                </ul>\r\n            </div>\r\n            }\r\n        </div>\r\n    </div>\r\n</div>\r\n"]}
|
|
117
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"brunch.component.js","sourceRoot":"","sources":["../../../../../../../projects/tent/src/lib/components/core/brunch/brunch.component.ts","../../../../../../../projects/tent/src/lib/components/core/brunch/brunch.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { Component, Input, OnInit, Renderer2 } from '@angular/core';\r\nimport { MatProgressSpinnerModule } from '@angular/material/progress-spinner';\r\nimport { YouTubePlayerModule } from '@angular/youtube-player';\r\nimport { ButtonI } from '../../../interfaces/atomic/button.interface';\r\nimport { ImageI } from '../../../interfaces/atomic/image.interface';\r\nimport { ButtonComponent } from '../../atomic/button/button.component';\r\n@Component({\r\n    selector: 'tent-brunch',\r\n    standalone: true,\r\n    imports: [\r\n        CommonModule,\r\n        ButtonComponent,\r\n        YouTubePlayerModule,\r\n        MatProgressSpinnerModule,\r\n    ],\r\n    templateUrl: './brunch.component.html',\r\n    styleUrl: './brunch.component.scss',\r\n})\r\nexport class BrunchComponent implements OnInit {\r\n    @Input() title?: string;\r\n    @Input() description?: string;\r\n    @Input() additionalDescription?: string;\r\n    @Input() links?: ButtonI[];\r\n    @Input() image?: ImageI;\r\n    @Input() video?: ImageI;\r\n    @Input() timmingTitle?: string;\r\n    @Input() timmingItems?: TimingItem[];\r\n    showMore = false;\r\n\r\n    tag!: HTMLScriptElement;\r\n    playerVars!: YT.PlayerVars;\r\n    apiloaded = false;\r\n    loading = true;\r\n\r\n    constructor(private readonly renderer: Renderer2) {}\r\n\r\n    toggleShowMore(): void {\r\n        this.showMore = !this.showMore;\r\n    }\r\n\r\n    ngOnInit(): void {\r\n        this.playerVars = {\r\n            enablejsapi: 1,\r\n            autoplay: 1,\r\n            controls: 0,\r\n            showinfo: 0,\r\n            modestbranding: 1,\r\n            loop: 1,\r\n            fs: 1,\r\n            cc_load_policy: 1,\r\n            iv_load_policy: 3,\r\n            autohide: 1,\r\n            rel: 0,\r\n            playsinline: 1,\r\n            playlist: this.video?.src,\r\n        };\r\n        if (this.video) {\r\n            this.initPlayer();\r\n        }\r\n    }\r\n\r\n    onStateChange(e: any) {\r\n        e.target.setPlaybackQuality('highres');\r\n        if (e.data == YT.PlayerState.PLAYING) {\r\n            e.target.mute();\r\n            setTimeout(() => {\r\n                e.target.playVideo();\r\n                document\r\n                    .getElementsByTagName('youtube-player')[0]\r\n                    .children[0].children[0].setAttribute(\r\n                        'style',\r\n                        'opacity: 1'\r\n                    );\r\n                this.loading = false;\r\n            }, 1000);\r\n        }\r\n        if (e.data == YT.PlayerState.PAUSED) {\r\n            e.target.mute();\r\n            setTimeout(() => {\r\n                e.target.playVideo();\r\n                document\r\n                    .getElementsByTagName('youtube-player')[0]\r\n                    .children[0].children[0].setAttribute(\r\n                        'style',\r\n                        'opacity: 1'\r\n                    );\r\n                this.loading = false;\r\n            }, 1000);\r\n        }\r\n        if (e.data == YT.PlayerState.ENDED) {\r\n            e.target.mute();\r\n            e.target.seekTo(0);\r\n            e.target.playVideo();\r\n        }\r\n    }\r\n\r\n    initPlayer(): void {\r\n        const existingScript = Array.from(\r\n            document.getElementsByTagName('script')\r\n        ).find((script) => script.src === 'https://www.youtube.com/iframe_api');\r\n\r\n        if (!existingScript) {\r\n            this.tag = document.createElement('script');\r\n            this.tag.src = 'https://www.youtube.com/iframe_api';\r\n            this.tag.async = true;\r\n            const firstScriptTag = document.getElementsByTagName('script')[0];\r\n            firstScriptTag.parentNode?.insertBefore(this.tag, firstScriptTag);\r\n\r\n            (window as any)['onYouTubeIframeAPIReady'] = () => {\r\n                this.apiloaded = true;\r\n            };\r\n        } else {\r\n            this.apiloaded = true;\r\n        }\r\n    }\r\n\r\n    onPlayerReady(event: any) {\r\n        event.target.mute();\r\n        event.target.seekTo(0.1, true);\r\n        event.target.playVideo();\r\n    }\r\n}\r\n\r\nexport interface TimingItem {\r\n    label: string;\r\n    icon?: string;\r\n}\r\n","<div class=\"wrapper-big module-spacer--bottom\">\r\n    <div class=\"brunch\">\r\n        @if (video || image) {\r\n        <div class=\"brunch--video-wrapper figure-sticky\">\r\n            @if (video) {\r\n            <div class=\"brunch--video\">\r\n                @if (loading) {\r\n                <mat-spinner></mat-spinner>\r\n                } @if (apiloaded) {\r\n                <youtube-player\r\n                    #ytPlayer\r\n                    [videoId]=\"video.src\"\r\n                    suggestedQuality=\"highres\"\r\n                    [showBeforeIframeApiLoads]=\"true\"\r\n                    [playerVars]=\"playerVars\"\r\n                    (stateChange)=\"onStateChange($event)\"\r\n                    (ready)=\"onPlayerReady($event)\"\r\n                    [disablePlaceholder]=\"true\"\r\n                >\r\n                </youtube-player\r\n                >}\r\n            </div>\r\n            } @else if (image) {\r\n            <img\r\n                class=\"brunch--video\"\r\n                [src]=\"image.src\"\r\n                [alt]=\"image.alt\"\r\n                width=\"600\"\r\n                height=\"600\"\r\n                loading=\"lazy\"\r\n            />\r\n            }\r\n        </div>\r\n        }\r\n        <div class=\"brunch--content-wrapper\">\r\n            @if (title) {\r\n            <h2 class=\"brunch--title title--60 color--brown\">{{ title }}</h2>\r\n            } @if (description) {\r\n            <p class=\"brunch--description text\">\r\n                {{ description }}\r\n            </p>\r\n            } @if (showMore && additionalDescription) {\r\n            <p class=\"brunch--description text\">\r\n                {{ additionalDescription }}\r\n            </p>\r\n\r\n            } @if (additionalDescription && links?.length) { @if (!showMore) {\r\n            <tent-button\r\n                class=\"brunch--show-more\"\r\n                type=\"dark-link\"\r\n                [label]=\"links?.[0]?.label\"\r\n                (btnClick)=\"toggleShowMore()\"\r\n                [name]=\"links?.[0]?.label\"\r\n            >\r\n            </tent-button>\r\n            } @else {\r\n            <tent-button\r\n                type=\"dark-link\"\r\n                [label]=\"links?.[1]?.label\"\r\n                (btnClick)=\"toggleShowMore()\"\r\n                [name]=\"links?.[1]?.label\"\r\n            >\r\n            </tent-button>\r\n            } } @if (timmingItems?.length) {\r\n            <div class=\"brunch--timing-info\">\r\n                @if (timmingTitle) {\r\n                <p class=\"brunch--timing-title\">horarios</p>\r\n                }\r\n                <ul class=\"brunch--timing-list\">\r\n                    @for (item of timmingItems; track $index) { @if (item.label)\r\n                    {\r\n                    <li class=\"brunch--timing-item\">\r\n                        @if (item.icon) {\r\n                        <span\r\n                            class=\"brunch--timing-item--icon\"\r\n                            [ngClass]=\"item.icon\"\r\n                        ></span>\r\n                        }\r\n                        <span class=\"brunch--timing-item--text\">\r\n                            {{ item.label }}\r\n                        </span>\r\n                    </li>\r\n                    } }\r\n                </ul>\r\n            </div>\r\n            }\r\n        </div>\r\n    </div>\r\n</div>\r\n"]}
|
|
@@ -122,8 +122,9 @@ export class InfoSliderComponent {
|
|
|
122
122
|
}
|
|
123
123
|
}
|
|
124
124
|
onPlayerReady(event) {
|
|
125
|
-
event.target.playVideo();
|
|
126
125
|
event.target.mute();
|
|
126
|
+
event.target.seekTo(0.1, true);
|
|
127
|
+
event.target.playVideo();
|
|
127
128
|
}
|
|
128
129
|
getImage(image) {
|
|
129
130
|
return this.sanitizer.bypassSecurityTrustStyle(`background-image: url(${image})`);
|
|
@@ -159,4 +160,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
159
160
|
}], slim: [{
|
|
160
161
|
type: Input
|
|
161
162
|
}] } });
|
|
162
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"info-slider.component.js","sourceRoot":"","sources":["../../../../../../../projects/tent/src/lib/components/core/info-slider/info-slider.component.ts","../../../../../../../projects/tent/src/lib/components/core/info-slider/info-slider.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { Component, Input, OnInit } from '@angular/core';\r\nimport { MatProgressSpinnerModule } from '@angular/material/progress-spinner';\r\nimport { DomSanitizer, SafeStyle } from '@angular/platform-browser';\r\nimport { YouTubePlayerModule } from '@angular/youtube-player';\r\nimport { CarouselModule, OwlOptions } from 'ngx-owl-carousel-o';\r\nimport { ButtonI } from '../../../interfaces/atomic/button.interface';\r\nimport { ImageI } from '../../../interfaces/atomic/image.interface';\r\nimport { ButtonComponent } from '../../atomic/button/button.component';\r\n@Component({\r\n    selector: 'tent-info-slider',\r\n    standalone: true,\r\n    imports: [\r\n        CommonModule,\r\n        ButtonComponent,\r\n        CarouselModule,\r\n        YouTubePlayerModule,\r\n        MatProgressSpinnerModule,\r\n    ],\r\n    templateUrl: './info-slider.component.html',\r\n    styleUrl: './info-slider.component.scss',\r\n})\r\nexport class InfoSliderComponent implements OnInit {\r\n    @Input() theme?: string = '';\r\n    @Input() infoalign?: string = 'info-right';\r\n    @Input() images?: string[];\r\n    @Input() title?: string;\r\n    @Input() description?: string;\r\n    @Input() video?: ImageI;\r\n    @Input() additionalDescription?: string;\r\n    @Input() links?: ButtonI[];\r\n    @Input() slim?: boolean;\r\n    sliderOptions: OwlOptions = {\r\n        loop: true,\r\n        autoplay: true,\r\n        autoplayTimeout: 5000,\r\n        autoplaySpeed: 1500,\r\n        navSpeed: 1500,\r\n        responsiveRefreshRate: 100,\r\n        margin: 0,\r\n        mouseDrag: true,\r\n        touchDrag: true,\r\n        pullDrag: true,\r\n        dots: false,\r\n        responsive: {\r\n            0: {\r\n                items: 1,\r\n            },\r\n            1680: {\r\n                items: 1,\r\n            },\r\n        },\r\n        nav: true,\r\n    };\r\n    collapsed = true;\r\n\r\n    tag!: HTMLScriptElement;\r\n    playerVars!: YT.PlayerVars;\r\n    apiloaded = false;\r\n    loading = true;\r\n\r\n    constructor(private readonly sanitizer: DomSanitizer) {}\r\n\r\n    toggleCollapse(): void {\r\n        this.collapsed = !this.collapsed;\r\n    }\r\n\r\n    ngOnInit(): void {\r\n        if (this.video) {\r\n            this.initPlayer();\r\n            this.playerVars = {\r\n                enablejsapi: 1,\r\n                autoplay: 1,\r\n                controls: 0,\r\n                showinfo: 0,\r\n                modestbranding: 1,\r\n                loop: 1,\r\n                fs: 1,\r\n                cc_load_policy: 1,\r\n                iv_load_policy: 3,\r\n                autohide: 1,\r\n                rel: 0,\r\n                playsinline: 1,\r\n                playlist: this.video?.src,\r\n            };\r\n        }\r\n        this.sliderOptions = {\r\n            ...this.sliderOptions,\r\n            navText: [\r\n                `<div class=\"btn btn__circle btn__circle-- ${\r\n                    this.theme === 'theme-laundry'\r\n                        ? 'btn__laundry'\r\n                        : 'btn__dark'\r\n                }\"><span class=\"btn__circle-icon icon-signal-left icon--size12 \"> </span></div>`,\r\n                `<div class=\"btn btn__circle btn__circle-- ${\r\n                    this.theme === 'theme-laundry'\r\n                        ? 'btn__laundry'\r\n                        : 'btn__dark'\r\n                }\"><span class=\"btn__circle-icon icon-signal-right icon--size12 \"> </span></div>`,\r\n            ],\r\n        };\r\n    }\r\n\r\n    onStateChange(e: any) {\r\n        e.target.setPlaybackQuality('highres');\r\n        if (e.data == YT.PlayerState.PLAYING) {\r\n            e.target.mute();\r\n            setTimeout(() => {\r\n                e.target.mute();\r\n                e.target.playVideo();\r\n                document\r\n                    .getElementsByTagName('youtube-player')[0]\r\n                    .children[0].children[0].setAttribute(\r\n                        'style',\r\n                        'opacity: 1'\r\n                    );\r\n                this.loading = false;\r\n            }, 1000);\r\n        }\r\n        if (e.data == YT.PlayerState.PAUSED) {\r\n            e.target.mute();\r\n            setTimeout(() => {\r\n                e.target.mute();\r\n                e.target.playVideo();\r\n                document\r\n                    .getElementsByTagName('youtube-player')[0]\r\n                    .children[0].children[0].setAttribute(\r\n                        'style',\r\n                        'opacity: 1'\r\n                    );\r\n                this.loading = false;\r\n            }, 1000);\r\n        }\r\n        if (e.data == YT.PlayerState.ENDED) {\r\n            e.target.mute();\r\n            e.target.seekTo(0);\r\n            e.target.playVideo();\r\n        }\r\n    }\r\n\r\n    initPlayer(): void {\r\n        const existingScript = Array.from(\r\n            document.getElementsByTagName('script')\r\n        ).find((script) => script.src === 'https://www.youtube.com/iframe_api');\r\n\r\n        if (!existingScript) {\r\n            this.tag = document.createElement('script');\r\n            this.tag.src = 'https://www.youtube.com/iframe_api';\r\n            this.tag.async = true;\r\n            const firstScriptTag = document.getElementsByTagName('script')[0];\r\n            firstScriptTag.parentNode?.insertBefore(this.tag, firstScriptTag);\r\n\r\n            (window as any)['onYouTubeIframeAPIReady'] = () => {\r\n                this.apiloaded = true;\r\n            };\r\n        } else {\r\n            this.apiloaded = true;\r\n        }\r\n    }\r\n\r\n    onPlayerReady(event: any) {\r\n        event.target.playVideo();\r\n        event.target.mute();\r\n    }\r\n\r\n    getImage(image: string): SafeStyle {\r\n        return this.sanitizer.bypassSecurityTrustStyle(\r\n            `background-image: url(${image})`\r\n        );\r\n    }\r\n}\r\n","<section class=\"info-slider module-spacer--bottom\" [ngClass]=\"[theme]\">\r\n    <div\r\n        class=\"info-slider--content wrapper-big\"\r\n        [ngClass]=\"{ 'info-slider--content--slim': slim }\"\r\n    >\r\n        <div class=\"info-slider--box\" [ngClass]=\"[infoalign]\">\r\n            @if (video) {\r\n            <div class=\"info-slider--video info-slider--slider\">\r\n                @if (loading) {\r\n                <mat-spinner></mat-spinner>\r\n                } @if (apiloaded) {\r\n                <youtube-player\r\n                    #ytPlayer\r\n                    []\r\n                    [videoId]=\"video.src\"\r\n                    suggestedQuality=\"highres\"\r\n                    [showBeforeIframeApiLoads]=\"true\"\r\n                    [playerVars]=\"playerVars\"\r\n                    (stateChange)=\"onStateChange($event)\"\r\n                    (ready)=\"onPlayerReady($event)\"\r\n                    [disablePlaceholder]=\"true\"\r\n                >\r\n                </youtube-player\r\n                >}\r\n            </div>\r\n            } @else if (images?.length) {\r\n            <owl-carousel-o\r\n                class=\"info-slider--slider slider-circle--center figure-sticky\"\r\n                [ngClass]=\"{ 'info-slider--slider--slim': slim }\"\r\n                [options]=\"sliderOptions\"\r\n            >\r\n                @for (img of images; track $index) {\r\n                <ng-template carouselSlide>\r\n                    <div\r\n                        class=\"info-slider--photo figure-content\"\r\n                        [ngClass]=\"{ 'info-slider--photo--slim': slim }\"\r\n                    >\r\n                        <figure\r\n                            class=\"figure-full\"\r\n                            [style]=\"getImage(img)\"\r\n                        ></figure>\r\n                    </div>\r\n                </ng-template>\r\n                }\r\n            </owl-carousel-o>\r\n            }\r\n            <div\r\n                class=\"info-slider--info\"\r\n                [ngClass]=\"collapsed ? 'close' : 'open'\"\r\n            >\r\n                @if (title || description) {\r\n                <div class=\"info-slider--info--inner\">\r\n                    @if (title) {\r\n                    <h2\r\n                        class=\"location-beach--info--title title--60 color--brown\"\r\n                    >\r\n                        {{ title }}\r\n                    </h2>\r\n\r\n                    } @if (description) {\r\n                    <div class=\"info-slider--info--des\">\r\n                        <p class=\"text\">\r\n                            {{ description }}\r\n                        </p>\r\n                        @if (additionalDescription) {\r\n                        <p class=\"text text-more\">\r\n                            {{ additionalDescription }}\r\n                        </p>\r\n                        } @if (links?.length) {\r\n                        <div class=\"info-slider--btns\">\r\n                            @for (link of links; track $index; let first =\r\n                            $first) {\r\n                            <tent-button\r\n                                class=\"btn-more\"\r\n                                [ngClass]=\"{\r\n                                    'btn-more': first,\r\n                                    'btn-minus': !first\r\n                                }\"\r\n                                type=\"dark-link\"\r\n                                [label]=\"link.label\"\r\n                                (click)=\"toggleCollapse()\"\r\n                                [name]=\"link.label\"\r\n                            ></tent-button>\r\n                            }\r\n                        </div>\r\n                        }\r\n                    </div>\r\n                    }\r\n                </div>\r\n                }\r\n            </div>\r\n        </div>\r\n    </div>\r\n</section>\r\n"]}
|
|
163
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"info-slider.component.js","sourceRoot":"","sources":["../../../../../../../projects/tent/src/lib/components/core/info-slider/info-slider.component.ts","../../../../../../../projects/tent/src/lib/components/core/info-slider/info-slider.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { Component, Input, OnInit } from '@angular/core';\r\nimport { MatProgressSpinnerModule } from '@angular/material/progress-spinner';\r\nimport { DomSanitizer, SafeStyle } from '@angular/platform-browser';\r\nimport { YouTubePlayerModule } from '@angular/youtube-player';\r\nimport { CarouselModule, OwlOptions } from 'ngx-owl-carousel-o';\r\nimport { ButtonI } from '../../../interfaces/atomic/button.interface';\r\nimport { ImageI } from '../../../interfaces/atomic/image.interface';\r\nimport { ButtonComponent } from '../../atomic/button/button.component';\r\n@Component({\r\n    selector: 'tent-info-slider',\r\n    standalone: true,\r\n    imports: [\r\n        CommonModule,\r\n        ButtonComponent,\r\n        CarouselModule,\r\n        YouTubePlayerModule,\r\n        MatProgressSpinnerModule,\r\n    ],\r\n    templateUrl: './info-slider.component.html',\r\n    styleUrl: './info-slider.component.scss',\r\n})\r\nexport class InfoSliderComponent implements OnInit {\r\n    @Input() theme?: string = '';\r\n    @Input() infoalign?: string = 'info-right';\r\n    @Input() images?: string[];\r\n    @Input() title?: string;\r\n    @Input() description?: string;\r\n    @Input() video?: ImageI;\r\n    @Input() additionalDescription?: string;\r\n    @Input() links?: ButtonI[];\r\n    @Input() slim?: boolean;\r\n    sliderOptions: OwlOptions = {\r\n        loop: true,\r\n        autoplay: true,\r\n        autoplayTimeout: 5000,\r\n        autoplaySpeed: 1500,\r\n        navSpeed: 1500,\r\n        responsiveRefreshRate: 100,\r\n        margin: 0,\r\n        mouseDrag: true,\r\n        touchDrag: true,\r\n        pullDrag: true,\r\n        dots: false,\r\n        responsive: {\r\n            0: {\r\n                items: 1,\r\n            },\r\n            1680: {\r\n                items: 1,\r\n            },\r\n        },\r\n        nav: true,\r\n    };\r\n    collapsed = true;\r\n\r\n    tag!: HTMLScriptElement;\r\n    playerVars!: YT.PlayerVars;\r\n    apiloaded = false;\r\n    loading = true;\r\n\r\n    constructor(private readonly sanitizer: DomSanitizer) {}\r\n\r\n    toggleCollapse(): void {\r\n        this.collapsed = !this.collapsed;\r\n    }\r\n\r\n    ngOnInit(): void {\r\n        if (this.video) {\r\n            this.initPlayer();\r\n            this.playerVars = {\r\n                enablejsapi: 1,\r\n                autoplay: 1,\r\n                controls: 0,\r\n                showinfo: 0,\r\n                modestbranding: 1,\r\n                loop: 1,\r\n                fs: 1,\r\n                cc_load_policy: 1,\r\n                iv_load_policy: 3,\r\n                autohide: 1,\r\n                rel: 0,\r\n                playsinline: 1,\r\n                playlist: this.video?.src,\r\n            };\r\n        }\r\n        this.sliderOptions = {\r\n            ...this.sliderOptions,\r\n            navText: [\r\n                `<div class=\"btn btn__circle btn__circle-- ${\r\n                    this.theme === 'theme-laundry'\r\n                        ? 'btn__laundry'\r\n                        : 'btn__dark'\r\n                }\"><span class=\"btn__circle-icon icon-signal-left icon--size12 \"> </span></div>`,\r\n                `<div class=\"btn btn__circle btn__circle-- ${\r\n                    this.theme === 'theme-laundry'\r\n                        ? 'btn__laundry'\r\n                        : 'btn__dark'\r\n                }\"><span class=\"btn__circle-icon icon-signal-right icon--size12 \"> </span></div>`,\r\n            ],\r\n        };\r\n    }\r\n\r\n    onStateChange(e: any) {\r\n        e.target.setPlaybackQuality('highres');\r\n        if (e.data == YT.PlayerState.PLAYING) {\r\n            e.target.mute();\r\n            setTimeout(() => {\r\n                e.target.mute();\r\n                e.target.playVideo();\r\n                document\r\n                    .getElementsByTagName('youtube-player')[0]\r\n                    .children[0].children[0].setAttribute(\r\n                        'style',\r\n                        'opacity: 1'\r\n                    );\r\n                this.loading = false;\r\n            }, 1000);\r\n        }\r\n        if (e.data == YT.PlayerState.PAUSED) {\r\n            e.target.mute();\r\n            setTimeout(() => {\r\n                e.target.mute();\r\n                e.target.playVideo();\r\n                document\r\n                    .getElementsByTagName('youtube-player')[0]\r\n                    .children[0].children[0].setAttribute(\r\n                        'style',\r\n                        'opacity: 1'\r\n                    );\r\n                this.loading = false;\r\n            }, 1000);\r\n        }\r\n        if (e.data == YT.PlayerState.ENDED) {\r\n            e.target.mute();\r\n            e.target.seekTo(0);\r\n            e.target.playVideo();\r\n        }\r\n    }\r\n\r\n    initPlayer(): void {\r\n        const existingScript = Array.from(\r\n            document.getElementsByTagName('script')\r\n        ).find((script) => script.src === 'https://www.youtube.com/iframe_api');\r\n\r\n        if (!existingScript) {\r\n            this.tag = document.createElement('script');\r\n            this.tag.src = 'https://www.youtube.com/iframe_api';\r\n            this.tag.async = true;\r\n            const firstScriptTag = document.getElementsByTagName('script')[0];\r\n            firstScriptTag.parentNode?.insertBefore(this.tag, firstScriptTag);\r\n\r\n            (window as any)['onYouTubeIframeAPIReady'] = () => {\r\n                this.apiloaded = true;\r\n            };\r\n        } else {\r\n            this.apiloaded = true;\r\n        }\r\n    }\r\n\r\n    onPlayerReady(event: any) {\r\n        event.target.mute();\r\n        event.target.seekTo(0.1, true);\r\n        event.target.playVideo();\r\n    }\r\n\r\n    getImage(image: string): SafeStyle {\r\n        return this.sanitizer.bypassSecurityTrustStyle(\r\n            `background-image: url(${image})`\r\n        );\r\n    }\r\n}\r\n","<section class=\"info-slider module-spacer--bottom\" [ngClass]=\"[theme]\">\r\n    <div\r\n        class=\"info-slider--content wrapper-big\"\r\n        [ngClass]=\"{ 'info-slider--content--slim': slim }\"\r\n    >\r\n        <div class=\"info-slider--box\" [ngClass]=\"[infoalign]\">\r\n            @if (video) {\r\n            <div class=\"info-slider--video info-slider--slider\">\r\n                @if (loading) {\r\n                <mat-spinner></mat-spinner>\r\n                } @if (apiloaded) {\r\n                <youtube-player\r\n                    #ytPlayer\r\n                    []\r\n                    [videoId]=\"video.src\"\r\n                    suggestedQuality=\"highres\"\r\n                    [showBeforeIframeApiLoads]=\"true\"\r\n                    [playerVars]=\"playerVars\"\r\n                    (stateChange)=\"onStateChange($event)\"\r\n                    (ready)=\"onPlayerReady($event)\"\r\n                    [disablePlaceholder]=\"true\"\r\n                >\r\n                </youtube-player\r\n                >}\r\n            </div>\r\n            } @else if (images?.length) {\r\n            <owl-carousel-o\r\n                class=\"info-slider--slider slider-circle--center figure-sticky\"\r\n                [ngClass]=\"{ 'info-slider--slider--slim': slim }\"\r\n                [options]=\"sliderOptions\"\r\n            >\r\n                @for (img of images; track $index) {\r\n                <ng-template carouselSlide>\r\n                    <div\r\n                        class=\"info-slider--photo figure-content\"\r\n                        [ngClass]=\"{ 'info-slider--photo--slim': slim }\"\r\n                    >\r\n                        <figure\r\n                            class=\"figure-full\"\r\n                            [style]=\"getImage(img)\"\r\n                        ></figure>\r\n                    </div>\r\n                </ng-template>\r\n                }\r\n            </owl-carousel-o>\r\n            }\r\n            <div\r\n                class=\"info-slider--info\"\r\n                [ngClass]=\"collapsed ? 'close' : 'open'\"\r\n            >\r\n                @if (title || description) {\r\n                <div class=\"info-slider--info--inner\">\r\n                    @if (title) {\r\n                    <h2\r\n                        class=\"location-beach--info--title title--60 color--brown\"\r\n                    >\r\n                        {{ title }}\r\n                    </h2>\r\n\r\n                    } @if (description) {\r\n                    <div class=\"info-slider--info--des\">\r\n                        <p class=\"text\">\r\n                            {{ description }}\r\n                        </p>\r\n                        @if (additionalDescription) {\r\n                        <p class=\"text text-more\">\r\n                            {{ additionalDescription }}\r\n                        </p>\r\n                        } @if (links?.length) {\r\n                        <div class=\"info-slider--btns\">\r\n                            @for (link of links; track $index; let first =\r\n                            $first) {\r\n                            <tent-button\r\n                                class=\"btn-more\"\r\n                                [ngClass]=\"{\r\n                                    'btn-more': first,\r\n                                    'btn-minus': !first\r\n                                }\"\r\n                                type=\"dark-link\"\r\n                                [label]=\"link.label\"\r\n                                (click)=\"toggleCollapse()\"\r\n                                [name]=\"link.label\"\r\n                            ></tent-button>\r\n                            }\r\n                        </div>\r\n                        }\r\n                    </div>\r\n                    }\r\n                </div>\r\n                }\r\n            </div>\r\n        </div>\r\n    </div>\r\n</section>\r\n"]}
|
package/fesm2022/tent-lib.mjs
CHANGED
|
@@ -2650,8 +2650,9 @@ class InfoSliderComponent {
|
|
|
2650
2650
|
}
|
|
2651
2651
|
}
|
|
2652
2652
|
onPlayerReady(event) {
|
|
2653
|
-
event.target.playVideo();
|
|
2654
2653
|
event.target.mute();
|
|
2654
|
+
event.target.seekTo(0.1, true);
|
|
2655
|
+
event.target.playVideo();
|
|
2655
2656
|
}
|
|
2656
2657
|
getImage(image) {
|
|
2657
2658
|
return this.sanitizer.bypassSecurityTrustStyle(`background-image: url(${image})`);
|
|
@@ -3832,6 +3833,7 @@ class BrunchComponent {
|
|
|
3832
3833
|
}
|
|
3833
3834
|
onPlayerReady(event) {
|
|
3834
3835
|
event.target.mute();
|
|
3836
|
+
event.target.seekTo(0.1, true);
|
|
3835
3837
|
event.target.playVideo();
|
|
3836
3838
|
}
|
|
3837
3839
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: BrunchComponent, deps: [{ token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component }); }
|