tent-lib 0.0.765 → 0.0.767
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/brunch/brunch.component.mjs +32 -20
- package/esm2022/lib/components/core/info-slider/info-slider.component.mjs +33 -21
- package/fesm2022/tent-lib.mjs +63 -39
- package/fesm2022/tent-lib.mjs.map +1 -1
- package/lib/components/core/brunch/brunch.component.d.ts +1 -0
- package/lib/components/core/info-slider/info-slider.component.d.ts +1 -0
- package/package.json +1 -1
|
@@ -19,42 +19,54 @@ export class BrunchComponent {
|
|
|
19
19
|
ngOnDestroy() {
|
|
20
20
|
if (this.player) {
|
|
21
21
|
this.player.destroy();
|
|
22
|
+
document.head.removeChild(this.tag);
|
|
22
23
|
}
|
|
23
24
|
}
|
|
24
25
|
initPlayer() {
|
|
25
|
-
|
|
26
|
+
const existingScript = Array.from(document.getElementsByTagName('script')).find((script) => script.src === 'https://www.youtube.com/iframe_api');
|
|
27
|
+
this.tag = document.createElement('script');
|
|
28
|
+
this.tag.src = 'https://www.youtube.com/iframe_api';
|
|
29
|
+
this.tag.async = true;
|
|
30
|
+
const firstScriptTag = document.getElementsByTagName('script')[0];
|
|
31
|
+
firstScriptTag.parentNode?.insertBefore(this.tag, firstScriptTag);
|
|
32
|
+
window['onYouTubeIframeAPIReady'] = () => {
|
|
26
33
|
this.createPlayer();
|
|
27
|
-
}
|
|
28
|
-
else {
|
|
29
|
-
const existingScript = Array.from(document.getElementsByTagName('script')).find((script) => script.src === 'https://www.youtube.com/iframe_api');
|
|
30
|
-
if (!existingScript) {
|
|
31
|
-
const tag = document.createElement('script');
|
|
32
|
-
tag.src = 'https://www.youtube.com/iframe_api';
|
|
33
|
-
tag.async = true;
|
|
34
|
-
const firstScriptTag = document.getElementsByTagName('script')[0];
|
|
35
|
-
firstScriptTag.parentNode?.insertBefore(tag, firstScriptTag);
|
|
36
|
-
}
|
|
37
|
-
window['onYouTubeIframeAPIReady'] = () => {
|
|
38
|
-
this.createPlayer();
|
|
39
|
-
};
|
|
40
|
-
}
|
|
34
|
+
};
|
|
41
35
|
}
|
|
42
36
|
createPlayer() {
|
|
43
37
|
this.player = new YT.Player('youtube-player-brunch', {
|
|
44
38
|
videoId: this.video?.src,
|
|
45
39
|
playerVars: {
|
|
40
|
+
enablejsapi: 1,
|
|
46
41
|
autoplay: 1,
|
|
47
42
|
controls: 0,
|
|
43
|
+
showinfo: 0,
|
|
48
44
|
modestbranding: 1,
|
|
49
45
|
loop: 1,
|
|
46
|
+
fs: 1,
|
|
47
|
+
cc_load_policy: 1,
|
|
48
|
+
iv_load_policy: 3,
|
|
49
|
+
autohide: 1,
|
|
50
|
+
rel: 0,
|
|
51
|
+
playsinline: 1,
|
|
50
52
|
playlist: this.video?.src,
|
|
51
53
|
},
|
|
52
54
|
events: {
|
|
53
55
|
onReady: this.onPlayerReady,
|
|
54
|
-
onStateChange: (
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
56
|
+
onStateChange: (e) => {
|
|
57
|
+
e.target.setPlaybackQuality('highres');
|
|
58
|
+
if (e.data == YT.PlayerState.PLAYING) {
|
|
59
|
+
document.getElementById('youtube-player-brunch').style.opacity = '1';
|
|
60
|
+
}
|
|
61
|
+
if (e.data == YT.PlayerState.PAUSED) {
|
|
62
|
+
setTimeout(function () {
|
|
63
|
+
e.target.playVideo();
|
|
64
|
+
document.getElementById('youtube-player-brunch').style.opacity = '1';
|
|
65
|
+
}, 2500);
|
|
66
|
+
}
|
|
67
|
+
if (e.data == YT.PlayerState.ENDED) {
|
|
68
|
+
e.target.seekTo(0);
|
|
69
|
+
e.target.playVideo();
|
|
58
70
|
}
|
|
59
71
|
},
|
|
60
72
|
},
|
|
@@ -87,4 +99,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
87
99
|
}], timmingItems: [{
|
|
88
100
|
type: Input
|
|
89
101
|
}] } });
|
|
90
|
-
//# 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, OnDestroy, OnInit } from '@angular/core';\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: [CommonModule, ButtonComponent, YouTubePlayerModule],\r\n    templateUrl: './brunch.component.html',\r\n    styleUrl: './brunch.component.scss',\r\n})\r\nexport class BrunchComponent implements OnInit, OnDestroy {\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    player!: YT.Player;\r\n\r\n    toggleShowMore(): void {\r\n        this.showMore = !this.showMore;\r\n    }\r\n\r\n    ngOnInit(): void {\r\n        if (this.video) {\r\n            this.initPlayer();\r\n        }\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        if (this.player) {\r\n            this.player.destroy();\r\n        }\r\n    }\r\n\r\n    initPlayer(): void {\r\n        if (window['YT'] && window['YT'].Player) {\r\n            this.createPlayer();\r\n        } else {\r\n            const existingScript = Array.from(\r\n                document.getElementsByTagName('script')\r\n            ).find(\r\n                (script) => script.src === 'https://www.youtube.com/iframe_api'\r\n            );\r\n\r\n            if (!existingScript) {\r\n                const tag = document.createElement('script');\r\n                tag.src = 'https://www.youtube.com/iframe_api';\r\n                tag.async = true;\r\n                const firstScriptTag =\r\n                    document.getElementsByTagName('script')[0];\r\n                firstScriptTag.parentNode?.insertBefore(tag, firstScriptTag);\r\n            }\r\n\r\n            (window as any)['onYouTubeIframeAPIReady'] = () => {\r\n                this.createPlayer();\r\n            };\r\n        }\r\n    }\r\n\r\n    createPlayer(): void {\r\n        this.player = new YT.Player('youtube-player-brunch', {\r\n            videoId: this.video?.src,\r\n            playerVars: {\r\n                autoplay: 1,\r\n                controls: 0,\r\n                modestbranding: 1,\r\n                loop: 1,\r\n                playlist: this.video?.src,\r\n            },\r\n            events: {\r\n                onReady: this.onPlayerReady,\r\n                onStateChange: (event: any) => {\r\n                    if (event.data === YT.PlayerState.ENDED) {\r\n                        event.target.seekTo(0);\r\n                        event.target.playVideo();\r\n                    }\r\n                },\r\n            },\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                <div id=\"youtube-player-brunch\"></div>\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"]}
|
|
102
|
+
//# 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, OnDestroy, OnInit } from '@angular/core';\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: [CommonModule, ButtonComponent, YouTubePlayerModule],\r\n    templateUrl: './brunch.component.html',\r\n    styleUrl: './brunch.component.scss',\r\n})\r\nexport class BrunchComponent implements OnInit, OnDestroy {\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    player!: YT.Player;\r\n\r\n    tag!: HTMLScriptElement;\r\n\r\n    toggleShowMore(): void {\r\n        this.showMore = !this.showMore;\r\n    }\r\n\r\n    ngOnInit(): void {\r\n        if (this.video) {\r\n            this.initPlayer();\r\n        }\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        if (this.player) {\r\n            this.player.destroy();\r\n            document.head.removeChild(this.tag);\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        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.createPlayer();\r\n        };\r\n    }\r\n\r\n    createPlayer(): void {\r\n        this.player = new YT.Player('youtube-player-brunch', {\r\n            videoId: this.video?.src,\r\n            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            events: {\r\n                onReady: this.onPlayerReady,\r\n                onStateChange: (e: any) => {\r\n                    e.target.setPlaybackQuality('highres');\r\n                    if (e.data == YT.PlayerState.PLAYING) {\r\n                        document.getElementById(\r\n                            'youtube-player-brunch'\r\n                        )!.style.opacity = '1';\r\n                    }\r\n                    if (e.data == YT.PlayerState.PAUSED) {\r\n                        setTimeout(function () {\r\n                            e.target.playVideo();\r\n                            document.getElementById(\r\n                                'youtube-player-brunch'\r\n                            )!.style.opacity = '1';\r\n                        }, 2500);\r\n                    }\r\n                    if (e.data == YT.PlayerState.ENDED) {\r\n                        e.target.seekTo(0);\r\n                        e.target.playVideo();\r\n                    }\r\n                },\r\n            },\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                <div id=\"youtube-player-brunch\"></div>\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"]}
|
|
@@ -58,42 +58,54 @@ export class InfoSliderComponent {
|
|
|
58
58
|
ngOnDestroy() {
|
|
59
59
|
if (this.player) {
|
|
60
60
|
this.player.destroy();
|
|
61
|
+
document.head.removeChild(this.tag);
|
|
61
62
|
}
|
|
62
63
|
}
|
|
63
64
|
initPlayer() {
|
|
64
|
-
|
|
65
|
+
const existingScript = Array.from(document.getElementsByTagName('script')).find((script) => script.src === 'https://www.youtube.com/iframe_api');
|
|
66
|
+
this.tag = document.createElement('script');
|
|
67
|
+
this.tag.src = 'https://www.youtube.com/iframe_api';
|
|
68
|
+
this.tag.async = true;
|
|
69
|
+
const firstScriptTag = document.getElementsByTagName('script')[0];
|
|
70
|
+
firstScriptTag.parentNode?.insertBefore(this.tag, firstScriptTag);
|
|
71
|
+
window['onYouTubeIframeAPIReady'] = () => {
|
|
65
72
|
this.createPlayer();
|
|
66
|
-
}
|
|
67
|
-
else {
|
|
68
|
-
const existingScript = Array.from(document.getElementsByTagName('script')).find((script) => script.src === 'https://www.youtube.com/iframe_api');
|
|
69
|
-
if (!existingScript) {
|
|
70
|
-
const tag = document.createElement('script');
|
|
71
|
-
tag.src = 'https://www.youtube.com/iframe_api';
|
|
72
|
-
tag.async = true;
|
|
73
|
-
const firstScriptTag = document.getElementsByTagName('script')[0];
|
|
74
|
-
firstScriptTag.parentNode?.insertBefore(tag, firstScriptTag);
|
|
75
|
-
}
|
|
76
|
-
window['onYouTubeIframeAPIReady'] = () => {
|
|
77
|
-
this.createPlayer();
|
|
78
|
-
};
|
|
79
|
-
}
|
|
73
|
+
};
|
|
80
74
|
}
|
|
81
75
|
createPlayer() {
|
|
82
|
-
this.player = new YT.Player('youtube-player-
|
|
76
|
+
this.player = new YT.Player('youtube-player-services', {
|
|
83
77
|
videoId: this.video?.src,
|
|
84
78
|
playerVars: {
|
|
79
|
+
enablejsapi: 1,
|
|
85
80
|
autoplay: 1,
|
|
86
81
|
controls: 0,
|
|
82
|
+
showinfo: 0,
|
|
87
83
|
modestbranding: 1,
|
|
88
84
|
loop: 1,
|
|
85
|
+
fs: 1,
|
|
86
|
+
cc_load_policy: 1,
|
|
87
|
+
iv_load_policy: 3,
|
|
88
|
+
autohide: 1,
|
|
89
|
+
rel: 0,
|
|
90
|
+
playsinline: 1,
|
|
89
91
|
playlist: this.video?.src,
|
|
90
92
|
},
|
|
91
93
|
events: {
|
|
92
94
|
onReady: this.onPlayerReady,
|
|
93
|
-
onStateChange: (
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
95
|
+
onStateChange: (e) => {
|
|
96
|
+
e.target.setPlaybackQuality('highres');
|
|
97
|
+
if (e.data == YT.PlayerState.PLAYING) {
|
|
98
|
+
document.getElementById('youtube-player-services').style.opacity = '1';
|
|
99
|
+
}
|
|
100
|
+
if (e.data == YT.PlayerState.PAUSED) {
|
|
101
|
+
setTimeout(function () {
|
|
102
|
+
e.target.playVideo();
|
|
103
|
+
document.getElementById('youtube-player-services').style.opacity = '1';
|
|
104
|
+
}, 2500);
|
|
105
|
+
}
|
|
106
|
+
if (e.data == YT.PlayerState.ENDED) {
|
|
107
|
+
e.target.seekTo(0);
|
|
108
|
+
e.target.playVideo();
|
|
97
109
|
}
|
|
98
110
|
},
|
|
99
111
|
},
|
|
@@ -136,4 +148,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
136
148
|
}], slim: [{
|
|
137
149
|
type: Input
|
|
138
150
|
}] } });
|
|
139
|
-
//# 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 {\r\n    ChangeDetectionStrategy,\r\n    Component,\r\n    Input,\r\n    OnInit,\r\n} from '@angular/core';\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    ],\r\n    templateUrl: './info-slider.component.html',\r\n    styleUrl: './info-slider.component.scss',\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\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    player!: YT.Player;\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        }\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    ngOnDestroy(): void {\r\n        if (this.player) {\r\n            this.player.destroy();\r\n        }\r\n    }\r\n\r\n    initPlayer(): void {\r\n        if (window['YT'] && window['YT'].Player) {\r\n            this.createPlayer();\r\n        } else {\r\n            const existingScript = Array.from(\r\n                document.getElementsByTagName('script')\r\n            ).find(\r\n                (script) => script.src === 'https://www.youtube.com/iframe_api'\r\n            );\r\n\r\n            if (!existingScript) {\r\n                const tag = document.createElement('script');\r\n                tag.src = 'https://www.youtube.com/iframe_api';\r\n                tag.async = true;\r\n                const firstScriptTag =\r\n                    document.getElementsByTagName('script')[0];\r\n                firstScriptTag.parentNode?.insertBefore(tag, firstScriptTag);\r\n            }\r\n\r\n            (window as any)['onYouTubeIframeAPIReady'] = () => {\r\n                this.createPlayer();\r\n            };\r\n        }\r\n    }\r\n\r\n    createPlayer(): void {\r\n        this.player = new YT.Player('youtube-player-brunch', {\r\n            videoId: this.video?.src,\r\n            playerVars: {\r\n                autoplay: 1,\r\n                controls: 0,\r\n                modestbranding: 1,\r\n                loop: 1,\r\n                playlist: this.video?.src,\r\n            },\r\n            events: {\r\n                onReady: this.onPlayerReady,\r\n                onStateChange: (event: any) => {\r\n                    if (event.data === YT.PlayerState.ENDED) {\r\n                        event.target.seekTo(0);\r\n                        event.target.playVideo();\r\n                    }\r\n                },\r\n            },\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    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                <div id=\"youtube-player-services\"></div>\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"]}
|
|
151
|
+
//# 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 {\r\n    ChangeDetectionStrategy,\r\n    Component,\r\n    Input,\r\n    OnInit,\r\n} from '@angular/core';\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    ],\r\n    templateUrl: './info-slider.component.html',\r\n    styleUrl: './info-slider.component.scss',\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\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    player!: YT.Player;\r\n\r\n    tag!: HTMLScriptElement;\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        }\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    ngOnDestroy(): void {\r\n        if (this.player) {\r\n            this.player.destroy();\r\n            document.head.removeChild(this.tag);\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        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.createPlayer();\r\n        };\r\n    }\r\n\r\n    createPlayer(): void {\r\n        this.player = new YT.Player('youtube-player-services', {\r\n            videoId: this.video?.src,\r\n            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            events: {\r\n                onReady: this.onPlayerReady,\r\n                onStateChange: (e: any) => {\r\n                    e.target.setPlaybackQuality('highres');\r\n                    if (e.data == YT.PlayerState.PLAYING) {\r\n                        document.getElementById(\r\n                            'youtube-player-services'\r\n                        )!.style.opacity = '1';\r\n                    }\r\n                    if (e.data == YT.PlayerState.PAUSED) {\r\n                        setTimeout(function () {\r\n                            e.target.playVideo();\r\n                            document.getElementById(\r\n                                'youtube-player-services'\r\n                            )!.style.opacity = '1';\r\n                        }, 2500);\r\n                    }\r\n                    if (e.data == YT.PlayerState.ENDED) {\r\n                        e.target.seekTo(0);\r\n                        e.target.playVideo();\r\n                    }\r\n                },\r\n            },\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    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                <div id=\"youtube-player-services\"></div>\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
|
@@ -2586,42 +2586,54 @@ class InfoSliderComponent {
|
|
|
2586
2586
|
ngOnDestroy() {
|
|
2587
2587
|
if (this.player) {
|
|
2588
2588
|
this.player.destroy();
|
|
2589
|
+
document.head.removeChild(this.tag);
|
|
2589
2590
|
}
|
|
2590
2591
|
}
|
|
2591
2592
|
initPlayer() {
|
|
2592
|
-
|
|
2593
|
+
const existingScript = Array.from(document.getElementsByTagName('script')).find((script) => script.src === 'https://www.youtube.com/iframe_api');
|
|
2594
|
+
this.tag = document.createElement('script');
|
|
2595
|
+
this.tag.src = 'https://www.youtube.com/iframe_api';
|
|
2596
|
+
this.tag.async = true;
|
|
2597
|
+
const firstScriptTag = document.getElementsByTagName('script')[0];
|
|
2598
|
+
firstScriptTag.parentNode?.insertBefore(this.tag, firstScriptTag);
|
|
2599
|
+
window['onYouTubeIframeAPIReady'] = () => {
|
|
2593
2600
|
this.createPlayer();
|
|
2594
|
-
}
|
|
2595
|
-
else {
|
|
2596
|
-
const existingScript = Array.from(document.getElementsByTagName('script')).find((script) => script.src === 'https://www.youtube.com/iframe_api');
|
|
2597
|
-
if (!existingScript) {
|
|
2598
|
-
const tag = document.createElement('script');
|
|
2599
|
-
tag.src = 'https://www.youtube.com/iframe_api';
|
|
2600
|
-
tag.async = true;
|
|
2601
|
-
const firstScriptTag = document.getElementsByTagName('script')[0];
|
|
2602
|
-
firstScriptTag.parentNode?.insertBefore(tag, firstScriptTag);
|
|
2603
|
-
}
|
|
2604
|
-
window['onYouTubeIframeAPIReady'] = () => {
|
|
2605
|
-
this.createPlayer();
|
|
2606
|
-
};
|
|
2607
|
-
}
|
|
2601
|
+
};
|
|
2608
2602
|
}
|
|
2609
2603
|
createPlayer() {
|
|
2610
|
-
this.player = new YT.Player('youtube-player-
|
|
2604
|
+
this.player = new YT.Player('youtube-player-services', {
|
|
2611
2605
|
videoId: this.video?.src,
|
|
2612
2606
|
playerVars: {
|
|
2607
|
+
enablejsapi: 1,
|
|
2613
2608
|
autoplay: 1,
|
|
2614
2609
|
controls: 0,
|
|
2610
|
+
showinfo: 0,
|
|
2615
2611
|
modestbranding: 1,
|
|
2616
2612
|
loop: 1,
|
|
2613
|
+
fs: 1,
|
|
2614
|
+
cc_load_policy: 1,
|
|
2615
|
+
iv_load_policy: 3,
|
|
2616
|
+
autohide: 1,
|
|
2617
|
+
rel: 0,
|
|
2618
|
+
playsinline: 1,
|
|
2617
2619
|
playlist: this.video?.src,
|
|
2618
2620
|
},
|
|
2619
2621
|
events: {
|
|
2620
2622
|
onReady: this.onPlayerReady,
|
|
2621
|
-
onStateChange: (
|
|
2622
|
-
|
|
2623
|
-
|
|
2624
|
-
|
|
2623
|
+
onStateChange: (e) => {
|
|
2624
|
+
e.target.setPlaybackQuality('highres');
|
|
2625
|
+
if (e.data == YT.PlayerState.PLAYING) {
|
|
2626
|
+
document.getElementById('youtube-player-services').style.opacity = '1';
|
|
2627
|
+
}
|
|
2628
|
+
if (e.data == YT.PlayerState.PAUSED) {
|
|
2629
|
+
setTimeout(function () {
|
|
2630
|
+
e.target.playVideo();
|
|
2631
|
+
document.getElementById('youtube-player-services').style.opacity = '1';
|
|
2632
|
+
}, 2500);
|
|
2633
|
+
}
|
|
2634
|
+
if (e.data == YT.PlayerState.ENDED) {
|
|
2635
|
+
e.target.seekTo(0);
|
|
2636
|
+
e.target.playVideo();
|
|
2625
2637
|
}
|
|
2626
2638
|
},
|
|
2627
2639
|
},
|
|
@@ -3748,42 +3760,54 @@ class BrunchComponent {
|
|
|
3748
3760
|
ngOnDestroy() {
|
|
3749
3761
|
if (this.player) {
|
|
3750
3762
|
this.player.destroy();
|
|
3763
|
+
document.head.removeChild(this.tag);
|
|
3751
3764
|
}
|
|
3752
3765
|
}
|
|
3753
3766
|
initPlayer() {
|
|
3754
|
-
|
|
3767
|
+
const existingScript = Array.from(document.getElementsByTagName('script')).find((script) => script.src === 'https://www.youtube.com/iframe_api');
|
|
3768
|
+
this.tag = document.createElement('script');
|
|
3769
|
+
this.tag.src = 'https://www.youtube.com/iframe_api';
|
|
3770
|
+
this.tag.async = true;
|
|
3771
|
+
const firstScriptTag = document.getElementsByTagName('script')[0];
|
|
3772
|
+
firstScriptTag.parentNode?.insertBefore(this.tag, firstScriptTag);
|
|
3773
|
+
window['onYouTubeIframeAPIReady'] = () => {
|
|
3755
3774
|
this.createPlayer();
|
|
3756
|
-
}
|
|
3757
|
-
else {
|
|
3758
|
-
const existingScript = Array.from(document.getElementsByTagName('script')).find((script) => script.src === 'https://www.youtube.com/iframe_api');
|
|
3759
|
-
if (!existingScript) {
|
|
3760
|
-
const tag = document.createElement('script');
|
|
3761
|
-
tag.src = 'https://www.youtube.com/iframe_api';
|
|
3762
|
-
tag.async = true;
|
|
3763
|
-
const firstScriptTag = document.getElementsByTagName('script')[0];
|
|
3764
|
-
firstScriptTag.parentNode?.insertBefore(tag, firstScriptTag);
|
|
3765
|
-
}
|
|
3766
|
-
window['onYouTubeIframeAPIReady'] = () => {
|
|
3767
|
-
this.createPlayer();
|
|
3768
|
-
};
|
|
3769
|
-
}
|
|
3775
|
+
};
|
|
3770
3776
|
}
|
|
3771
3777
|
createPlayer() {
|
|
3772
3778
|
this.player = new YT.Player('youtube-player-brunch', {
|
|
3773
3779
|
videoId: this.video?.src,
|
|
3774
3780
|
playerVars: {
|
|
3781
|
+
enablejsapi: 1,
|
|
3775
3782
|
autoplay: 1,
|
|
3776
3783
|
controls: 0,
|
|
3784
|
+
showinfo: 0,
|
|
3777
3785
|
modestbranding: 1,
|
|
3778
3786
|
loop: 1,
|
|
3787
|
+
fs: 1,
|
|
3788
|
+
cc_load_policy: 1,
|
|
3789
|
+
iv_load_policy: 3,
|
|
3790
|
+
autohide: 1,
|
|
3791
|
+
rel: 0,
|
|
3792
|
+
playsinline: 1,
|
|
3779
3793
|
playlist: this.video?.src,
|
|
3780
3794
|
},
|
|
3781
3795
|
events: {
|
|
3782
3796
|
onReady: this.onPlayerReady,
|
|
3783
|
-
onStateChange: (
|
|
3784
|
-
|
|
3785
|
-
|
|
3786
|
-
|
|
3797
|
+
onStateChange: (e) => {
|
|
3798
|
+
e.target.setPlaybackQuality('highres');
|
|
3799
|
+
if (e.data == YT.PlayerState.PLAYING) {
|
|
3800
|
+
document.getElementById('youtube-player-brunch').style.opacity = '1';
|
|
3801
|
+
}
|
|
3802
|
+
if (e.data == YT.PlayerState.PAUSED) {
|
|
3803
|
+
setTimeout(function () {
|
|
3804
|
+
e.target.playVideo();
|
|
3805
|
+
document.getElementById('youtube-player-brunch').style.opacity = '1';
|
|
3806
|
+
}, 2500);
|
|
3807
|
+
}
|
|
3808
|
+
if (e.data == YT.PlayerState.ENDED) {
|
|
3809
|
+
e.target.seekTo(0);
|
|
3810
|
+
e.target.playVideo();
|
|
3787
3811
|
}
|
|
3788
3812
|
},
|
|
3789
3813
|
},
|