tent-lib 0.0.836 → 0.0.837

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.
@@ -56,6 +56,7 @@ export class TopModuleComponent {
56
56
  return this.sanitizer.bypassSecurityTrustStyle(`background-image: url(${image})`);
57
57
  }
58
58
  ngAfterViewInit() {
59
+ this.sliderOptions.loop = this.items.length > 1;
59
60
  const dots = document.getElementsByClassName('owl-dots')[0];
60
61
  this.renderer.appendChild(dots, this.nav.nativeElement);
61
62
  this.renderer.setStyle(this.nav.nativeElement, 'width', `${dots.clientWidth + 40}px`);
@@ -112,4 +113,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
112
113
  }], scrollLabel: [{
113
114
  type: Input
114
115
  }] } });
115
- //# 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 { 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\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    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        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    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    <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    <owl-carousel-o class=\"top-module--slider\" [options]=\"sliderOptions\">\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    <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"]}
116
+ //# 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 { 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\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    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        this.sliderOptions.loop = this.items.length > 1;\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    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    <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    <owl-carousel-o class=\"top-module--slider\" [options]=\"sliderOptions\">\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    <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"]}
@@ -1476,6 +1476,7 @@ class TopModuleComponent {
1476
1476
  return this.sanitizer.bypassSecurityTrustStyle(`background-image: url(${image})`);
1477
1477
  }
1478
1478
  ngAfterViewInit() {
1479
+ this.sliderOptions.loop = this.items.length > 1;
1479
1480
  const dots = document.getElementsByClassName('owl-dots')[0];
1480
1481
  this.renderer.appendChild(dots, this.nav.nativeElement);
1481
1482
  this.renderer.setStyle(this.nav.nativeElement, 'width', `${dots.clientWidth + 40}px`);