tent-lib 0.0.854 → 0.0.855

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.
@@ -11,7 +11,7 @@ import * as i2 from "@angular/common";
11
11
  import * as i3 from "ngx-owl-carousel-o";
12
12
  export class TopModuleComponent {
13
13
  get videoUrl() {
14
- return `{videoURL:\'${this.video}\', containment:'.youtube-bg',autoPlay:true, mute:true, startAt:1, opacity:1, showControls:false, loop:true}`;
14
+ return `{videoURL:\'${this.video}\', containment:'.youtube-bg',autoPlay:true, mute:true, startAt:1, opacity:1, showControls:false, loop:true, stopMovieOnBlur: false}`;
15
15
  }
16
16
  constructor(renderer, sanitizer) {
17
17
  this.renderer = renderer;
@@ -122,4 +122,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
122
122
  }], gift: [{
123
123
  type: Input
124
124
  }] } });
125
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"top-module.component.js","sourceRoot":"","sources":["../../../../../../../projects/tent/src/lib/components/core/top-module/top-module.component.ts","../../../../../../../projects/tent/src/lib/components/core/top-module/top-module.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport {\r\n    AfterViewInit,\r\n    ChangeDetectionStrategy,\r\n    Component,\r\n    ElementRef,\r\n    Input,\r\n    OnInit,\r\n    Renderer2,\r\n    ViewChild,\r\n} from '@angular/core';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { DomSanitizer, SafeStyle } from '@angular/platform-browser';\r\nimport {\r\n    CarouselComponent,\r\n    CarouselModule,\r\n    OwlOptions,\r\n} from 'ngx-owl-carousel-o';\r\nimport { LazyBackgroundDirective } from '../../../directives/lazy-background.directive';\r\nimport { BadgeI } from '../../../interfaces/atomic/badge.interface';\r\nimport { ButtonI } from '../../../interfaces/atomic/button.interface';\r\nimport { ImageI } from '../../../interfaces/atomic/image.interface';\r\nimport { BadgeComponent } from '../../atomic/badge/badge.component';\r\nimport { ButtonComponent } from '../../atomic/button/button.component';\r\n\r\n@Component({\r\n    selector: 'tent-top-module',\r\n    standalone: true,\r\n    imports: [\r\n        CommonModule,\r\n        ButtonComponent,\r\n        BadgeComponent,\r\n        CarouselModule,\r\n        MatIconModule,\r\n        LazyBackgroundDirective,\r\n    ],\r\n    templateUrl: './top-module.component.html',\r\n    styleUrl: './top-module.component.scss',\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class TopModuleComponent implements AfterViewInit, OnInit {\r\n    @ViewChild(CarouselComponent) carousel!: CarouselComponent;\r\n    @ViewChild('nav', { read: ElementRef }) nav!: ElementRef;\r\n    @ViewChild('module', { read: ElementRef }) module!: ElementRef;\r\n    @Input() btnScroll!: ButtonI;\r\n    @Input({ required: true }) items!: TopModuleItem[];\r\n    @Input() desktop?: boolean;\r\n    @Input() scrollLabel?: string;\r\n    @Input() video?: string;\r\n    @Input() gift?: ImageI;\r\n\r\n    showScrollLabel = false;\r\n\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        mouseDrag: true,\r\n        touchDrag: true,\r\n        pullDrag: true,\r\n        dots: true,\r\n        nav: false,\r\n        navText: ['', ''],\r\n        responsive: {\r\n            0: {\r\n                items: 1,\r\n            },\r\n            540: {\r\n                items: 1,\r\n            },\r\n            768: {\r\n                items: 1,\r\n            },\r\n            1024: {\r\n                items: 1,\r\n            },\r\n            1280: {\r\n                items: 1,\r\n            },\r\n            1366: {\r\n                items: 1,\r\n            },\r\n            1680: {\r\n                items: 1,\r\n            },\r\n        },\r\n    };\r\n\r\n    get videoUrl(): string {\r\n        return `{videoURL:\\'${this.video}\\', containment:'.youtube-bg',autoPlay:true, mute:true, startAt:1, opacity:1, showControls:false, loop:true}`;\r\n    }\r\n\r\n    constructor(\r\n        private readonly renderer: Renderer2,\r\n        private readonly sanitizer: DomSanitizer\r\n    ) {}\r\n\r\n    ngOnInit(): void {}\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    ngAfterViewInit(): void {\r\n        if (!this.video && !this.gift) {\r\n            const dots = document.getElementsByClassName('owl-dots')[0];\r\n            this.renderer.appendChild(dots, this.nav.nativeElement);\r\n            this.renderer.setStyle(\r\n                this.nav.nativeElement,\r\n                'width',\r\n                `${dots.clientWidth + 40}px`\r\n            );\r\n        }\r\n    }\r\n\r\n    prevClick(): void {\r\n        this.carousel.prev();\r\n    }\r\n\r\n    nextClick(): void {\r\n        this.carousel.next();\r\n    }\r\n\r\n    scrollClicked(): void {\r\n        window.scrollTo({\r\n            top:\r\n                (this.module.nativeElement as HTMLElement).clientHeight +\r\n                Number(\r\n                    window\r\n                        .getComputedStyle(this.module.nativeElement)\r\n                        .getPropertyValue('padding-bottom')\r\n                        .split('px')[0]\r\n                ) -\r\n                document.getElementsByTagName('tent-header')[0].clientHeight,\r\n            behavior: 'smooth',\r\n        });\r\n    }\r\n\r\n    toggleScrollLabel(): void {\r\n        this.showScrollLabel = !this.showScrollLabel;\r\n    }\r\n}\r\n\r\nexport interface TopModuleItem {\r\n    mainBadge?: BadgeI;\r\n    title?: string;\r\n    badgePromo?: BadgeI;\r\n    badgeDiscount?: BadgeI;\r\n    btn?: ButtonI;\r\n    img?: string;\r\n}\r\n","<section class=\"top-module module-spacer--bottom\" #module>\r\n    @if( (!video && !gift) || (!gift && !desktop)) {\r\n    <div class=\"top-module--nav flex-row flex-row--between\" #nav>\r\n        <span\r\n            class=\"icon-pointer-down color--white\"\r\n            (click)=\"prevClick()\"\r\n        ></span>\r\n        <span\r\n            class=\"icon-pointer-down color--white\"\r\n            (click)=\"nextClick()\"\r\n        ></span>\r\n    </div>\r\n\r\n    } @if (video && desktop) {\r\n    <div class=\"youtube-bg\">\r\n        <div\r\n            id=\"bgndVideo\"\r\n            class=\"player\"\r\n            [attr.data-property]=\"videoUrl\"\r\n        ></div>\r\n    </div>\r\n    } @else if(gift) {\r\n    <img class=\"top-module--gift\" [src]=\"gift.src\" [alt]=\"gift.alt\" />\r\n    } @else if(items){\r\n    <owl-carousel-o\r\n        class=\"top-module--slider\"\r\n        [options]=\"sliderOptions\"\r\n        [ngClass]=\"{ 'no-loop': items.length < 2 }\"\r\n    >\r\n        @for (item of items; track $index) {\r\n        <ng-template carouselSlide>\r\n            <div class=\"top-module--content\">\r\n                @if (item.mainBadge) {\r\n                <div class=\"top-module--badge\">\r\n                    <tent-badge\r\n                        [rounded]=\"true\"\r\n                        [label]=\"item.mainBadge.label\"\r\n                    ></tent-badge>\r\n                </div>\r\n                } @if (item.title) {\r\n                <h3 class=\"title--80 color--white\">{{ item.title }}</h3>\r\n                } @if (item.badgePromo || item.badgeDiscount) {\r\n                <div class=\"top-module--offers flex-row\">\r\n                    @if (item.badgePromo) {\r\n                    <tent-badge\r\n                        class=\"top-module--promo\"\r\n                        [rounded]=\"true\"\r\n                        [label]=\"item.badgePromo.label\"\r\n                    ></tent-badge>\r\n                    } @if (item.badgeDiscount) {\r\n                    <tent-badge\r\n                        class=\"top-module--discount\"\r\n                        [rounded]=\"true\"\r\n                        [label]=\"item.badgeDiscount.label\"\r\n                    ></tent-badge>\r\n                    }\r\n                </div>\r\n                } @if (item.btn) {\r\n                <div class=\"top-module--btn-info\">\r\n                    <tent-button\r\n                        type=\"light-box\"\r\n                        [label]=\"item.btn.label\"\r\n                        [url]=\"item.btn.url\"\r\n                        [linkType]=\"item.btn.linkType!\"\r\n                    ></tent-button>\r\n                </div>\r\n                }\r\n            </div>\r\n            @if (item.img) {\r\n            <figure\r\n                class=\"top-module--image\"\r\n                [lazyBackground]=\"item.img\"\r\n            ></figure>\r\n            }\r\n        </ng-template>\r\n        }\r\n    </owl-carousel-o>\r\n\r\n    }\r\n\r\n    <div\r\n        class=\"top-module--btn-scroll\"\r\n        (mouseenter)=\"toggleScrollLabel()\"\r\n        (mouseleave)=\"toggleScrollLabel()\"\r\n    >\r\n        @if (showScrollLabel && scrollLabel) {\r\n        <p class=\"top-module--btn-scroll--label\">\r\n            {{ scrollLabel }}\r\n        </p>\r\n\r\n        }\r\n        <tent-button\r\n            type=\"light-circle\"\r\n            [icon]=\"btnScroll.icon\"\r\n            (click)=\"scrollClicked()\"\r\n            name=\"tent-hotels\"\r\n        ></tent-button>\r\n    </div>\r\n</section>\r\n"]}
125
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"top-module.component.js","sourceRoot":"","sources":["../../../../../../../projects/tent/src/lib/components/core/top-module/top-module.component.ts","../../../../../../../projects/tent/src/lib/components/core/top-module/top-module.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport {\r\n    AfterViewInit,\r\n    ChangeDetectionStrategy,\r\n    Component,\r\n    ElementRef,\r\n    Input,\r\n    OnInit,\r\n    Renderer2,\r\n    ViewChild,\r\n} from '@angular/core';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { DomSanitizer, SafeStyle } from '@angular/platform-browser';\r\nimport {\r\n    CarouselComponent,\r\n    CarouselModule,\r\n    OwlOptions,\r\n} from 'ngx-owl-carousel-o';\r\nimport { LazyBackgroundDirective } from '../../../directives/lazy-background.directive';\r\nimport { BadgeI } from '../../../interfaces/atomic/badge.interface';\r\nimport { ButtonI } from '../../../interfaces/atomic/button.interface';\r\nimport { ImageI } from '../../../interfaces/atomic/image.interface';\r\nimport { BadgeComponent } from '../../atomic/badge/badge.component';\r\nimport { ButtonComponent } from '../../atomic/button/button.component';\r\n\r\n@Component({\r\n    selector: 'tent-top-module',\r\n    standalone: true,\r\n    imports: [\r\n        CommonModule,\r\n        ButtonComponent,\r\n        BadgeComponent,\r\n        CarouselModule,\r\n        MatIconModule,\r\n        LazyBackgroundDirective,\r\n    ],\r\n    templateUrl: './top-module.component.html',\r\n    styleUrl: './top-module.component.scss',\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class TopModuleComponent implements AfterViewInit, OnInit {\r\n    @ViewChild(CarouselComponent) carousel!: CarouselComponent;\r\n    @ViewChild('nav', { read: ElementRef }) nav!: ElementRef;\r\n    @ViewChild('module', { read: ElementRef }) module!: ElementRef;\r\n    @Input() btnScroll!: ButtonI;\r\n    @Input({ required: true }) items!: TopModuleItem[];\r\n    @Input() desktop?: boolean;\r\n    @Input() scrollLabel?: string;\r\n    @Input() video?: string;\r\n    @Input() gift?: ImageI;\r\n\r\n    showScrollLabel = false;\r\n\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        mouseDrag: true,\r\n        touchDrag: true,\r\n        pullDrag: true,\r\n        dots: true,\r\n        nav: false,\r\n        navText: ['', ''],\r\n        responsive: {\r\n            0: {\r\n                items: 1,\r\n            },\r\n            540: {\r\n                items: 1,\r\n            },\r\n            768: {\r\n                items: 1,\r\n            },\r\n            1024: {\r\n                items: 1,\r\n            },\r\n            1280: {\r\n                items: 1,\r\n            },\r\n            1366: {\r\n                items: 1,\r\n            },\r\n            1680: {\r\n                items: 1,\r\n            },\r\n        },\r\n    };\r\n\r\n    get videoUrl(): string {\r\n        return `{videoURL:\\'${this.video}\\', containment:'.youtube-bg',autoPlay:true, mute:true, startAt:1, opacity:1, showControls:false, loop:true, stopMovieOnBlur: false}`;\r\n    }\r\n\r\n    constructor(\r\n        private readonly renderer: Renderer2,\r\n        private readonly sanitizer: DomSanitizer\r\n    ) {}\r\n\r\n    ngOnInit(): void {}\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    ngAfterViewInit(): void {\r\n        if (!this.video && !this.gift) {\r\n            const dots = document.getElementsByClassName('owl-dots')[0];\r\n            this.renderer.appendChild(dots, this.nav.nativeElement);\r\n            this.renderer.setStyle(\r\n                this.nav.nativeElement,\r\n                'width',\r\n                `${dots.clientWidth + 40}px`\r\n            );\r\n        }\r\n    }\r\n\r\n    prevClick(): void {\r\n        this.carousel.prev();\r\n    }\r\n\r\n    nextClick(): void {\r\n        this.carousel.next();\r\n    }\r\n\r\n    scrollClicked(): void {\r\n        window.scrollTo({\r\n            top:\r\n                (this.module.nativeElement as HTMLElement).clientHeight +\r\n                Number(\r\n                    window\r\n                        .getComputedStyle(this.module.nativeElement)\r\n                        .getPropertyValue('padding-bottom')\r\n                        .split('px')[0]\r\n                ) -\r\n                document.getElementsByTagName('tent-header')[0].clientHeight,\r\n            behavior: 'smooth',\r\n        });\r\n    }\r\n\r\n    toggleScrollLabel(): void {\r\n        this.showScrollLabel = !this.showScrollLabel;\r\n    }\r\n}\r\n\r\nexport interface TopModuleItem {\r\n    mainBadge?: BadgeI;\r\n    title?: string;\r\n    badgePromo?: BadgeI;\r\n    badgeDiscount?: BadgeI;\r\n    btn?: ButtonI;\r\n    img?: string;\r\n}\r\n","<section class=\"top-module module-spacer--bottom\" #module>\r\n    @if( (!video && !gift) || (!gift && !desktop)) {\r\n    <div class=\"top-module--nav flex-row flex-row--between\" #nav>\r\n        <span\r\n            class=\"icon-pointer-down color--white\"\r\n            (click)=\"prevClick()\"\r\n        ></span>\r\n        <span\r\n            class=\"icon-pointer-down color--white\"\r\n            (click)=\"nextClick()\"\r\n        ></span>\r\n    </div>\r\n\r\n    } @if (video && desktop) {\r\n    <div class=\"youtube-bg\">\r\n        <div\r\n            id=\"bgndVideo\"\r\n            class=\"player\"\r\n            [attr.data-property]=\"videoUrl\"\r\n        ></div>\r\n    </div>\r\n    } @else if(gift) {\r\n    <img class=\"top-module--gift\" [src]=\"gift.src\" [alt]=\"gift.alt\" />\r\n    } @else if(items){\r\n    <owl-carousel-o\r\n        class=\"top-module--slider\"\r\n        [options]=\"sliderOptions\"\r\n        [ngClass]=\"{ 'no-loop': items.length < 2 }\"\r\n    >\r\n        @for (item of items; track $index) {\r\n        <ng-template carouselSlide>\r\n            <div class=\"top-module--content\">\r\n                @if (item.mainBadge) {\r\n                <div class=\"top-module--badge\">\r\n                    <tent-badge\r\n                        [rounded]=\"true\"\r\n                        [label]=\"item.mainBadge.label\"\r\n                    ></tent-badge>\r\n                </div>\r\n                } @if (item.title) {\r\n                <h3 class=\"title--80 color--white\">{{ item.title }}</h3>\r\n                } @if (item.badgePromo || item.badgeDiscount) {\r\n                <div class=\"top-module--offers flex-row\">\r\n                    @if (item.badgePromo) {\r\n                    <tent-badge\r\n                        class=\"top-module--promo\"\r\n                        [rounded]=\"true\"\r\n                        [label]=\"item.badgePromo.label\"\r\n                    ></tent-badge>\r\n                    } @if (item.badgeDiscount) {\r\n                    <tent-badge\r\n                        class=\"top-module--discount\"\r\n                        [rounded]=\"true\"\r\n                        [label]=\"item.badgeDiscount.label\"\r\n                    ></tent-badge>\r\n                    }\r\n                </div>\r\n                } @if (item.btn) {\r\n                <div class=\"top-module--btn-info\">\r\n                    <tent-button\r\n                        type=\"light-box\"\r\n                        [label]=\"item.btn.label\"\r\n                        [url]=\"item.btn.url\"\r\n                        [linkType]=\"item.btn.linkType!\"\r\n                    ></tent-button>\r\n                </div>\r\n                }\r\n            </div>\r\n            @if (item.img) {\r\n            <figure\r\n                class=\"top-module--image\"\r\n                [lazyBackground]=\"item.img\"\r\n            ></figure>\r\n            }\r\n        </ng-template>\r\n        }\r\n    </owl-carousel-o>\r\n\r\n    }\r\n\r\n    <div\r\n        class=\"top-module--btn-scroll\"\r\n        (mouseenter)=\"toggleScrollLabel()\"\r\n        (mouseleave)=\"toggleScrollLabel()\"\r\n    >\r\n        @if (showScrollLabel && scrollLabel) {\r\n        <p class=\"top-module--btn-scroll--label\">\r\n            {{ scrollLabel }}\r\n        </p>\r\n\r\n        }\r\n        <tent-button\r\n            type=\"light-circle\"\r\n            [icon]=\"btnScroll.icon\"\r\n            (click)=\"scrollClicked()\"\r\n            name=\"tent-hotels\"\r\n        ></tent-button>\r\n    </div>\r\n</section>\r\n"]}
@@ -1430,7 +1430,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
1430
1430
 
1431
1431
  class TopModuleComponent {
1432
1432
  get videoUrl() {
1433
- return `{videoURL:\'${this.video}\', containment:'.youtube-bg',autoPlay:true, mute:true, startAt:1, opacity:1, showControls:false, loop:true}`;
1433
+ return `{videoURL:\'${this.video}\', containment:'.youtube-bg',autoPlay:true, mute:true, startAt:1, opacity:1, showControls:false, loop:true, stopMovieOnBlur: false}`;
1434
1434
  }
1435
1435
  constructor(renderer, sanitizer) {
1436
1436
  this.renderer = renderer;