tent-lib 0.0.418 → 0.0.419
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/hotel-equipment/hotel-equipment.component.mjs +5 -2
- package/esm2022/lib/components/core/room-slider/room-slider.component.mjs +11 -1
- package/fesm2022/tent-lib.mjs +13 -1
- package/fesm2022/tent-lib.mjs.map +1 -1
- package/lib/components/core/hotel-equipment/hotel-equipment.component.d.ts +3 -2
- package/lib/components/core/room-slider/room-slider.component.d.ts +2 -0
- package/package.json +1 -1
|
@@ -7,9 +7,12 @@ import * as i1 from "@angular/common";
|
|
|
7
7
|
export class HotelEquipmentComponent {
|
|
8
8
|
constructor() {
|
|
9
9
|
this.collapsed1 = true;
|
|
10
|
-
this.itemsToShow =
|
|
10
|
+
this.itemsToShow = 6;
|
|
11
11
|
this.collapsed2 = true;
|
|
12
12
|
}
|
|
13
|
+
ngOnInit() {
|
|
14
|
+
this.itemsToShow = window.innerWidth >= 1680 ? 6 : 4;
|
|
15
|
+
}
|
|
13
16
|
ngAfterViewInit() {
|
|
14
17
|
fromEvent(window, 'resize')
|
|
15
18
|
.pipe(tap(() => {
|
|
@@ -40,4 +43,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.9", ngImpor
|
|
|
40
43
|
}], btnLess: [{
|
|
41
44
|
type: Input
|
|
42
45
|
}] } });
|
|
43
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
46
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hotel-equipment.component.js","sourceRoot":"","sources":["../../../../../../../projects/tent/src/lib/components/core/hotel-equipment/hotel-equipment.component.ts","../../../../../../../projects/tent/src/lib/components/core/hotel-equipment/hotel-equipment.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAiB,SAAS,EAAE,KAAK,EAAU,MAAM,eAAe,CAAC;AACxE,OAAO,EAAE,SAAS,EAAE,GAAG,EAAE,MAAM,MAAM,CAAC;AAEtC,OAAO,EAAE,eAAe,EAAE,MAAM,sCAAsC,CAAC;;;AAQvE,MAAM,OAAO,uBAAuB;IAPpC;QAcI,eAAU,GAAG,IAAI,CAAC;QAElB,gBAAW,GAAG,CAAC,CAAC;QAmBhB,eAAU,GAAG,IAAI,CAAC;KAIrB;IArBG,QAAQ;QACJ,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC,UAAU,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IACzD,CAAC;IAED,eAAe;QACX,SAAS,CAAC,MAAM,EAAE,QAAQ,CAAC;aACtB,IAAI,CACD,GAAG,CAAC,GAAG,EAAE;YACL,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC,UAAU,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACzD,CAAC,CAAC,CACL;aACA,SAAS,EAAE,CAAC;IACrB,CAAC;IAED,eAAe;QACX,IAAI,CAAC,UAAU,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC;IACvC,CAAC;IAED,eAAe;QACX,IAAI,CAAC,UAAU,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC;IACvC,CAAC;8GA/BQ,uBAAuB;kGAAvB,uBAAuB,8LCZpC,mxHA2FA,q4mBDnFc,YAAY,6HAAE,eAAe;;2FAI9B,uBAAuB;kBAPnC,SAAS;+BACI,sBAAsB,cACpB,IAAI,WACP,CAAC,YAAY,EAAE,eAAe,CAAC;8BAK/B,KAAK;sBAAb,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,OAAO;sBAAf,KAAK","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { AfterViewInit, Component, Input, OnInit } from '@angular/core';\r\nimport { fromEvent, tap } from 'rxjs';\r\nimport { ButtonI } from '../../../interfaces/atomic/button.interface';\r\nimport { ButtonComponent } from '../../atomic/button/button.component';\r\n@Component({\r\n    selector: 'tent-hotel-equipment',\r\n    standalone: true,\r\n    imports: [CommonModule, ButtonComponent],\r\n    templateUrl: './hotel-equipment.component.html',\r\n    styleUrl: './hotel-equipment.component.scss',\r\n})\r\nexport class HotelEquipmentComponent implements OnInit, AfterViewInit {\r\n    @Input() items?: HotelEquipmentItem[];\r\n    @Input() itemsBelow?: HotelEquipmentItem[];\r\n    @Input() title?: string;\r\n    @Input() btnMore?: ButtonI;\r\n    @Input() btnLess?: ButtonI;\r\n\r\n    collapsed1 = true;\r\n\r\n    itemsToShow = 6;\r\n\r\n    ngOnInit(): void {\r\n        this.itemsToShow = window.innerWidth >= 1680 ? 6 : 4;\r\n    }\r\n\r\n    ngAfterViewInit(): void {\r\n        fromEvent(window, 'resize')\r\n            .pipe(\r\n                tap(() => {\r\n                    this.itemsToShow = window.innerWidth >= 1680 ? 6 : 4;\r\n                })\r\n            )\r\n            .subscribe();\r\n    }\r\n\r\n    toggleCollapse1(): void {\r\n        this.collapsed1 = !this.collapsed1;\r\n    }\r\n    collapsed2 = true;\r\n    toggleCollapse2(): void {\r\n        this.collapsed2 = !this.collapsed2;\r\n    }\r\n}\r\n\r\nexport interface HotelEquipmentItem {\r\n    title: string;\r\n    icon: string;\r\n    alt: string;\r\n}\r\n","<section class=\"hotel-benefits module-spacer--bottom\">\r\n    <div class=\"hotel-benefits--content wrapper-big\">\r\n        <div class=\"hotel-benefits--box\">\r\n            <div\r\n                class=\"hotel-benefits--equipament\"\r\n                [ngClass]=\"collapsed1 ? 'close' : 'open'\"\r\n            >\r\n                @if (title) {\r\n                <div class=\"hotel-benefits--info\">\r\n                    <h2 class=\"hotel-benefits--title title--60 color--brown\">\r\n                        {{ title }}\r\n                    </h2>\r\n                </div>\r\n                } @if (items?.length) {\r\n                <div class=\"hotel-benefits--list\">\r\n                    @for (item of items; track $index) {\r\n                    <div class=\"hotel-benefits--item bg-beige\">\r\n                        <div class=\"hotel-benefits--item--inner\">\r\n                            @if (item.title) {\r\n                            <h3 class=\"title--24 color--brown-70\">\r\n                                {{ item.title }}\r\n                            </h3>\r\n                            } @if (item.icon) {\r\n                            <span\r\n                                [ngClass]=\"item.icon\"\r\n                                class=\"hotel-benefits--icon\"\r\n                            ></span>\r\n                            }\r\n                        </div>\r\n                    </div>\r\n                    }\r\n                </div>\r\n                } @if (btnMore && btnLess && (items?.length ?? 4) > itemsToShow)\r\n                {\r\n                <div class=\"hotel-benefits--btns\">\r\n                    <tent-button\r\n                        class=\"btn-more\"\r\n                        type=\"dark-link\"\r\n                        [label]=\"btnMore.label\"\r\n                        (click)=\"toggleCollapse1()\"\r\n                        [name]=\"btnMore.label\"\r\n                    ></tent-button>\r\n\r\n                    <tent-button\r\n                        class=\"btn-minus\"\r\n                        type=\"dark-link\"\r\n                        [label]=\"btnLess.label\"\r\n                        (click)=\"toggleCollapse1()\"\r\n                        [name]=\"btnLess.label\"\r\n                    ></tent-button>\r\n                </div>\r\n                }\r\n            </div>\r\n            @if (itemsBelow?.length) {\r\n            <div\r\n                class=\"hotel-benefits--services\"\r\n                [ngClass]=\"collapsed2 ? 'close' : 'open'\"\r\n            >\r\n                <ul class=\"hotel-benefits--services--list\">\r\n                    @for (item of itemsBelow; track $index) {\r\n                    <li>\r\n                        <span [ngClass]=\"item.icon\"></span>\r\n                        <p class=\"text\">{{ item.title }}</p>\r\n                    </li>\r\n                    }\r\n                </ul>\r\n                @if (btnMore && btnLess) {\r\n                <div class=\"hotel-benefits--btns\">\r\n                    <tent-button\r\n                        class=\"btn-more\"\r\n                        type=\"dark-link\"\r\n                        [label]=\"btnMore.label\"\r\n                        (click)=\"toggleCollapse2()\"\r\n                        [name]=\"btnMore.label\"\r\n                    ></tent-button>\r\n\r\n                    <tent-button\r\n                        class=\"btn-minus\"\r\n                        type=\"dark-link\"\r\n                        [label]=\"btnLess.label\"\r\n                        (click)=\"toggleCollapse2()\"\r\n                        [name]=\"btnLess.label\"\r\n                    ></tent-button>\r\n                </div>\r\n                }\r\n            </div>\r\n\r\n            }\r\n        </div>\r\n    </div>\r\n</section>\r\n"]}
|
|
@@ -4,6 +4,7 @@ import { ButtonComponent } from '../../atomic/button/button.component';
|
|
|
4
4
|
import { BadgeComponent } from '../../atomic/badge/badge.component';
|
|
5
5
|
import { CarouselModule } from 'ngx-owl-carousel-o';
|
|
6
6
|
import { RoomZoomModalComponent } from '../modals/room-zoom-modal/room-zoom-modal.component';
|
|
7
|
+
import { fromEvent, tap } from 'rxjs';
|
|
7
8
|
import * as i0 from "@angular/core";
|
|
8
9
|
import * as i1 from "@angular/material/dialog";
|
|
9
10
|
import * as i2 from "@angular/platform-browser";
|
|
@@ -41,10 +42,19 @@ export class RoomSliderComponent {
|
|
|
41
42
|
};
|
|
42
43
|
this.collapsed = [];
|
|
43
44
|
this.viewmore = [];
|
|
45
|
+
this.itemsToShow = 4;
|
|
44
46
|
}
|
|
45
47
|
ngOnInit() {
|
|
46
48
|
this.collapsed = new Array(this.items.length).fill(true);
|
|
47
49
|
this.viewmore = new Array(this.items.length).fill(true);
|
|
50
|
+
this.itemsToShow = window.innerWidth >= 540 ? 6 : 3;
|
|
51
|
+
}
|
|
52
|
+
ngAfterViewInit() {
|
|
53
|
+
fromEvent(window, 'resize')
|
|
54
|
+
.pipe(tap(() => {
|
|
55
|
+
this.itemsToShow = window.innerWidth >= 540 ? 6 : 3;
|
|
56
|
+
}))
|
|
57
|
+
.subscribe();
|
|
48
58
|
}
|
|
49
59
|
toggleCollapse(index) {
|
|
50
60
|
this.collapsed[index] = !this.collapsed[index];
|
|
@@ -87,4 +97,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.9", ngImpor
|
|
|
87
97
|
}], linkEquipmentLess: [{
|
|
88
98
|
type: Input
|
|
89
99
|
}] } });
|
|
90
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"room-slider.component.js","sourceRoot":"","sources":["../../../../../../../projects/tent/src/lib/components/core/room-slider/room-slider.component.ts","../../../../../../../projects/tent/src/lib/components/core/room-slider/room-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 { ButtonComponent } from '../../atomic/button/button.component';\r\nimport { BadgeComponent } from '../../atomic/badge/badge.component';\r\nimport { CarouselModule, OwlOptions } from 'ngx-owl-carousel-o';\r\nimport { MatDialog } from '@angular/material/dialog';\r\nimport { RoomZoomModalComponent } from '../modals/room-zoom-modal/room-zoom-modal.component';\r\nimport { ButtonI } from '../../../interfaces/atomic/button.interface';\r\nimport { DomSanitizer, SafeStyle } from '@angular/platform-browser';\r\n@Component({\r\n    selector: 'tent-room-slider',\r\n    standalone: true,\r\n    imports: [CommonModule, ButtonComponent, CarouselModule, BadgeComponent],\r\n    templateUrl: './room-slider.component.html',\r\n    styleUrl: './room-slider.component.scss',\r\n})\r\nexport class RoomSliderComponent implements OnInit {\r\n    @Input({ required: true }) items!: RoomsSliderRoom[];\r\n    @Input() linkDescriptionMore?: ButtonI;\r\n    @Input() linkDescriptionLess?: ButtonI;\r\n    @Input() linkEquipmentMore?: ButtonI;\r\n    @Input() linkEquipmentLess?: ButtonI;\r\n\r\n    sliderOptions: OwlOptions = {\r\n        loop: true,\r\n        autoplay: true,\r\n        autoplayTimeout: 5000,\r\n        autoplaySpeed: 5000,\r\n        navSpeed: 6000,\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        navText: [\r\n            '<div class=\"btn btn__circle btn__circle-- btn__dark\"><span class=\"btn__circle-icon icon-signal-left icon--size12 \"> </span></div>',\r\n            '<div class=\"btn btn__circle btn__circle-- btn__dark\"><span class=\"btn__circle-icon icon-signal-right icon--size12 \"> </span></div>',\r\n        ],\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\r\n    collapsed: boolean[] = [];\r\n    viewmore: boolean[] = [];\r\n\r\n    constructor(\r\n        private readonly dialog: MatDialog,\r\n        private readonly sanitizer: DomSanitizer\r\n    ) {}\r\n\r\n    ngOnInit(): void {\r\n        this.collapsed = new Array(this.items.length).fill(true);\r\n        this.viewmore = new Array(this.items.length).fill(true);\r\n    }\r\n\r\n    toggleCollapse(index: number): void {\r\n        this.collapsed[index] = !this.collapsed[index];\r\n    }\r\n\r\n    toggleViewmore(index: number): void {\r\n        this.viewmore[index] = !this.viewmore[index];\r\n    }\r\n\r\n    getImage(img: string): SafeStyle {\r\n        return this.sanitizer.bypassSecurityTrustStyle(\r\n            `background-image: url(${img})`\r\n        );\r\n    }\r\n\r\n    openRoomModal(): void {\r\n        const dialogRef = this.dialog.open(RoomZoomModalComponent, {\r\n            width: '100vw',\r\n            height: '100vh',\r\n            maxWidth: '100vw',\r\n            panelClass: 'full-screen',\r\n            hasBackdrop: true,\r\n        });\r\n\r\n        dialogRef.componentInstance.title = 'Habitación doble';\r\n        dialogRef.componentInstance.images = [\r\n            '/assets/tent/img/room-modal-img.png',\r\n            '/assets/tent/img/room-modal-img.png',\r\n        ];\r\n    }\r\n}\r\n\r\nexport interface RoomsSliderRoom {\r\n    title?: string;\r\n    info?: {\r\n        label: string;\r\n        icon: string;\r\n    }[];\r\n    description?: string;\r\n    additionalDescription?: string;\r\n    images?: string[];\r\n    equipment?: {\r\n        title?: string;\r\n        items?: string[];\r\n    };\r\n    button?: ButtonI;\r\n}\r\n","<section class=\"room-slider module-spacer--bottom\">\r\n    <div class=\"room-slider--content wrapper-big\">\r\n        @for (item of items; track $index; let odd = $odd) {\r\n        <div\r\n            class=\"room-slider--box\"\r\n            [ngClass]=\"{\r\n                'info-right': !odd,\r\n                'info-left': odd,\r\n                'module-spacer-small--bottom': $index !== items.length - 1\r\n            }\"\r\n        >\r\n            <owl-carousel-o\r\n                class=\"room-slider--slider slider-circle--center figure-sticky\"\r\n                [options]=\"sliderOptions\"\r\n            >\r\n                @for (img of item.images; track $index) {\r\n                <ng-template carouselSlide>\r\n                    <div class=\"room-slider--photo figure-content\">\r\n                        <figure\r\n                            class=\"figure-full\"\r\n                            [style]=\"getImage(img)\"\r\n                        ></figure>\r\n                        <div\r\n                            class=\"btn btn__circle btn__circle-- btn__white btn_search\"\r\n                            (click)=\"openRoomModal()\"\r\n                        >\r\n                            <span\r\n                                class=\"btn__circle-icon icon-search-plus icon--size22\"\r\n                            >\r\n                            </span>\r\n                        </div>\r\n                    </div>\r\n                </ng-template>\r\n                }\r\n            </owl-carousel-o>\r\n            <div class=\"room-slider--info\">\r\n                @if (item.title) {\r\n                <h2 class=\"room-slider--info--title title--80 color--brown\">\r\n                    {{ item.title }}\r\n                </h2>\r\n                } @if (item.info) {\r\n                <ul class=\"room-slider--info--icons\">\r\n                    @for (infoItem of item.info; track $index) {\r\n                    <li>\r\n                        <span\r\n                            class=\"info--icon\"\r\n                            [ngClass]=\"infoItem.icon\"\r\n                        ></span>\r\n                        <p class=\"text\">{{ infoItem.label }}</p>\r\n                    </li>\r\n                    }\r\n                </ul>\r\n                } @if (item.description && item.additionalDescription) {\r\n                <div\r\n                    class=\"room-slider--info--des\"\r\n                    [ngClass]=\"collapsed[$index] ? 'close' : 'open'\"\r\n                >\r\n                    <p class=\"text\">\r\n                        {{ item.description }}\r\n                    </p>\r\n                    <p class=\"text text-more\">\r\n                        {{ item.additionalDescription }}\r\n                    </p>\r\n                    @if (linkDescriptionMore && linkDescriptionLess) {\r\n                    <tent-button\r\n                        class=\"btn-more\"\r\n                        type=\"dark-link\"\r\n                        [label]=\"linkDescriptionMore.label\"\r\n                        (click)=\"toggleCollapse($index)\"\r\n                        [name]=\"linkDescriptionMore.label\"\r\n                    ></tent-button>\r\n                    <tent-button\r\n                        class=\"btn-minus\"\r\n                        type=\"dark-link\"\r\n                        [label]=\"linkDescriptionLess.label\"\r\n                        (click)=\"toggleCollapse($index)\"\r\n                        [name]=\"linkDescriptionLess.label\"\r\n                    ></tent-button>\r\n                    }\r\n                </div>\r\n                }\r\n                <div\r\n                    class=\"room-slider--info--equipament\"\r\n                    [ngClass]=\"viewmore[$index] ? 'close' : 'open'\"\r\n                >\r\n                    @if (item.equipment?.title) {\r\n                    <h2\r\n                        class=\"room-slider--info--subtit title--24 color--brown\"\r\n                    >\r\n                        {{ item.equipment?.title }}\r\n                    </h2>\r\n\r\n                    } @if (item.equipment?.items) {\r\n                    <ul>\r\n                        @for (equipmentItem of item.equipment?.items; track\r\n                        $index) {\r\n                        <li>\r\n                            <span class=\"icon-check\"></span>\r\n                            <p class=\"text\">{{ equipmentItem }}</p>\r\n                        </li>\r\n                        }\r\n                    </ul>\r\n                    }\r\n\r\n                    <div class=\"room-slider--info--btns\">\r\n                        @if (linkEquipmentMore && linkEquipmentLess &&\r\n                        item.equipment?.items?.length! > 4) {\r\n                        <tent-button\r\n                            class=\"btn-more\"\r\n                            type=\"dark-link\"\r\n                            [label]=\"linkEquipmentMore.label\"\r\n                            (click)=\"toggleViewmore($index)\"\r\n                            [name]=\"linkEquipmentMore.label\"\r\n                        ></tent-button>\r\n                        <tent-button\r\n                            class=\"btn-minus\"\r\n                            type=\"dark-link\"\r\n                            [label]=\"linkEquipmentLess.label\"\r\n                            (click)=\"toggleViewmore($index)\"\r\n                            [name]=\"linkEquipmentLess.label\"\r\n                        ></tent-button>\r\n                        } @if (item.button) {\r\n                        <tent-button\r\n                            class=\"btn-book\"\r\n                            type=\"dark-box-filled\"\r\n                            [label]=\"item.button.label\"\r\n                            [url]=\"item.button.url\"\r\n                            [linkType]=\"item.button.linkType!\"\r\n                        ></tent-button>\r\n                        }\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n        }\r\n    </div>\r\n</section>\r\n"]}
|
|
100
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"room-slider.component.js","sourceRoot":"","sources":["../../../../../../../projects/tent/src/lib/components/core/room-slider/room-slider.component.ts","../../../../../../../projects/tent/src/lib/components/core/room-slider/room-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 { ButtonComponent } from '../../atomic/button/button.component';\r\nimport { BadgeComponent } from '../../atomic/badge/badge.component';\r\nimport { CarouselModule, OwlOptions } from 'ngx-owl-carousel-o';\r\nimport { MatDialog } from '@angular/material/dialog';\r\nimport { RoomZoomModalComponent } from '../modals/room-zoom-modal/room-zoom-modal.component';\r\nimport { ButtonI } from '../../../interfaces/atomic/button.interface';\r\nimport { DomSanitizer, SafeStyle } from '@angular/platform-browser';\r\nimport { fromEvent, tap } from 'rxjs';\r\n@Component({\r\n    selector: 'tent-room-slider',\r\n    standalone: true,\r\n    imports: [CommonModule, ButtonComponent, CarouselModule, BadgeComponent],\r\n    templateUrl: './room-slider.component.html',\r\n    styleUrl: './room-slider.component.scss',\r\n})\r\nexport class RoomSliderComponent implements OnInit {\r\n    @Input({ required: true }) items!: RoomsSliderRoom[];\r\n    @Input() linkDescriptionMore?: ButtonI;\r\n    @Input() linkDescriptionLess?: ButtonI;\r\n    @Input() linkEquipmentMore?: ButtonI;\r\n    @Input() linkEquipmentLess?: ButtonI;\r\n\r\n    sliderOptions: OwlOptions = {\r\n        loop: true,\r\n        autoplay: true,\r\n        autoplayTimeout: 5000,\r\n        autoplaySpeed: 5000,\r\n        navSpeed: 6000,\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        navText: [\r\n            '<div class=\"btn btn__circle btn__circle-- btn__dark\"><span class=\"btn__circle-icon icon-signal-left icon--size12 \"> </span></div>',\r\n            '<div class=\"btn btn__circle btn__circle-- btn__dark\"><span class=\"btn__circle-icon icon-signal-right icon--size12 \"> </span></div>',\r\n        ],\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\r\n    collapsed: boolean[] = [];\r\n    viewmore: boolean[] = [];\r\n\r\n    itemsToShow = 4;\r\n    constructor(\r\n        private readonly dialog: MatDialog,\r\n        private readonly sanitizer: DomSanitizer\r\n    ) {}\r\n\r\n    ngOnInit(): void {\r\n        this.collapsed = new Array(this.items.length).fill(true);\r\n        this.viewmore = new Array(this.items.length).fill(true);\r\n        this.itemsToShow = window.innerWidth >= 540 ? 6 : 3;\r\n    }\r\n\r\n    ngAfterViewInit(): void {\r\n        fromEvent(window, 'resize')\r\n            .pipe(\r\n                tap(() => {\r\n                    this.itemsToShow = window.innerWidth >= 540 ? 6 : 3;\r\n                })\r\n            )\r\n            .subscribe();\r\n    }\r\n\r\n    toggleCollapse(index: number): void {\r\n        this.collapsed[index] = !this.collapsed[index];\r\n    }\r\n\r\n    toggleViewmore(index: number): void {\r\n        this.viewmore[index] = !this.viewmore[index];\r\n    }\r\n\r\n    getImage(img: string): SafeStyle {\r\n        return this.sanitizer.bypassSecurityTrustStyle(\r\n            `background-image: url(${img})`\r\n        );\r\n    }\r\n\r\n    openRoomModal(): void {\r\n        const dialogRef = this.dialog.open(RoomZoomModalComponent, {\r\n            width: '100vw',\r\n            height: '100vh',\r\n            maxWidth: '100vw',\r\n            panelClass: 'full-screen',\r\n            hasBackdrop: true,\r\n        });\r\n\r\n        dialogRef.componentInstance.title = 'Habitación doble';\r\n        dialogRef.componentInstance.images = [\r\n            '/assets/tent/img/room-modal-img.png',\r\n            '/assets/tent/img/room-modal-img.png',\r\n        ];\r\n    }\r\n}\r\n\r\nexport interface RoomsSliderRoom {\r\n    title?: string;\r\n    info?: {\r\n        label: string;\r\n        icon: string;\r\n    }[];\r\n    description?: string;\r\n    additionalDescription?: string;\r\n    images?: string[];\r\n    equipment?: {\r\n        title?: string;\r\n        items?: string[];\r\n    };\r\n    button?: ButtonI;\r\n}\r\n","<section class=\"room-slider module-spacer--bottom\">\r\n    <div class=\"room-slider--content wrapper-big\">\r\n        @for (item of items; track $index; let odd = $odd) {\r\n        <div\r\n            class=\"room-slider--box\"\r\n            [ngClass]=\"{\r\n                'info-right': !odd,\r\n                'info-left': odd,\r\n                'module-spacer-small--bottom': $index !== items.length - 1\r\n            }\"\r\n        >\r\n            <owl-carousel-o\r\n                class=\"room-slider--slider slider-circle--center figure-sticky\"\r\n                [options]=\"sliderOptions\"\r\n            >\r\n                @for (img of item.images; track $index) {\r\n                <ng-template carouselSlide>\r\n                    <div class=\"room-slider--photo figure-content\">\r\n                        <figure\r\n                            class=\"figure-full\"\r\n                            [style]=\"getImage(img)\"\r\n                        ></figure>\r\n                        <div\r\n                            class=\"btn btn__circle btn__circle-- btn__white btn_search\"\r\n                            (click)=\"openRoomModal()\"\r\n                        >\r\n                            <span\r\n                                class=\"btn__circle-icon icon-search-plus icon--size22\"\r\n                            >\r\n                            </span>\r\n                        </div>\r\n                    </div>\r\n                </ng-template>\r\n                }\r\n            </owl-carousel-o>\r\n            <div class=\"room-slider--info\">\r\n                @if (item.title) {\r\n                <h2 class=\"room-slider--info--title title--80 color--brown\">\r\n                    {{ item.title }}\r\n                </h2>\r\n                } @if (item.info) {\r\n                <ul class=\"room-slider--info--icons\">\r\n                    @for (infoItem of item.info; track $index) {\r\n                    <li>\r\n                        <span\r\n                            class=\"info--icon\"\r\n                            [ngClass]=\"infoItem.icon\"\r\n                        ></span>\r\n                        <p class=\"text\">{{ infoItem.label }}</p>\r\n                    </li>\r\n                    }\r\n                </ul>\r\n                } @if (item.description && item.additionalDescription) {\r\n                <div\r\n                    class=\"room-slider--info--des\"\r\n                    [ngClass]=\"collapsed[$index] ? 'close' : 'open'\"\r\n                >\r\n                    <p class=\"text\">\r\n                        {{ item.description }}\r\n                    </p>\r\n                    <p class=\"text text-more\">\r\n                        {{ item.additionalDescription }}\r\n                    </p>\r\n                    @if (linkDescriptionMore && linkDescriptionLess) {\r\n                    <tent-button\r\n                        class=\"btn-more\"\r\n                        type=\"dark-link\"\r\n                        [label]=\"linkDescriptionMore.label\"\r\n                        (click)=\"toggleCollapse($index)\"\r\n                        [name]=\"linkDescriptionMore.label\"\r\n                    ></tent-button>\r\n                    <tent-button\r\n                        class=\"btn-minus\"\r\n                        type=\"dark-link\"\r\n                        [label]=\"linkDescriptionLess.label\"\r\n                        (click)=\"toggleCollapse($index)\"\r\n                        [name]=\"linkDescriptionLess.label\"\r\n                    ></tent-button>\r\n                    }\r\n                </div>\r\n                }\r\n                <div\r\n                    class=\"room-slider--info--equipament\"\r\n                    [ngClass]=\"viewmore[$index] ? 'close' : 'open'\"\r\n                >\r\n                    @if (item.equipment?.title) {\r\n                    <h2\r\n                        class=\"room-slider--info--subtit title--24 color--brown\"\r\n                    >\r\n                        {{ item.equipment?.title }}\r\n                    </h2>\r\n\r\n                    } @if (item.equipment?.items) {\r\n                    <ul>\r\n                        @for (equipmentItem of item.equipment?.items; track\r\n                        $index) {\r\n                        <li>\r\n                            <span class=\"icon-check\"></span>\r\n                            <p class=\"text\">{{ equipmentItem }}</p>\r\n                        </li>\r\n                        }\r\n                    </ul>\r\n                    }\r\n\r\n                    <div class=\"room-slider--info--btns\">\r\n                        @if (linkEquipmentMore && linkEquipmentLess &&\r\n                        item.equipment?.items?.length! > 4) {\r\n                        <tent-button\r\n                            class=\"btn-more\"\r\n                            type=\"dark-link\"\r\n                            [label]=\"linkEquipmentMore.label\"\r\n                            (click)=\"toggleViewmore($index)\"\r\n                            [name]=\"linkEquipmentMore.label\"\r\n                        ></tent-button>\r\n                        <tent-button\r\n                            class=\"btn-minus\"\r\n                            type=\"dark-link\"\r\n                            [label]=\"linkEquipmentLess.label\"\r\n                            (click)=\"toggleViewmore($index)\"\r\n                            [name]=\"linkEquipmentLess.label\"\r\n                        ></tent-button>\r\n                        } @if (item.button) {\r\n                        <tent-button\r\n                            class=\"btn-book\"\r\n                            type=\"dark-box-filled\"\r\n                            [label]=\"item.button.label\"\r\n                            [url]=\"item.button.url\"\r\n                            [linkType]=\"item.button.linkType!\"\r\n                        ></tent-button>\r\n                        }\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n        }\r\n    </div>\r\n</section>\r\n"]}
|
package/fesm2022/tent-lib.mjs
CHANGED
|
@@ -1347,10 +1347,19 @@ class RoomSliderComponent {
|
|
|
1347
1347
|
};
|
|
1348
1348
|
this.collapsed = [];
|
|
1349
1349
|
this.viewmore = [];
|
|
1350
|
+
this.itemsToShow = 4;
|
|
1350
1351
|
}
|
|
1351
1352
|
ngOnInit() {
|
|
1352
1353
|
this.collapsed = new Array(this.items.length).fill(true);
|
|
1353
1354
|
this.viewmore = new Array(this.items.length).fill(true);
|
|
1355
|
+
this.itemsToShow = window.innerWidth >= 540 ? 6 : 3;
|
|
1356
|
+
}
|
|
1357
|
+
ngAfterViewInit() {
|
|
1358
|
+
fromEvent(window, 'resize')
|
|
1359
|
+
.pipe(tap(() => {
|
|
1360
|
+
this.itemsToShow = window.innerWidth >= 540 ? 6 : 3;
|
|
1361
|
+
}))
|
|
1362
|
+
.subscribe();
|
|
1354
1363
|
}
|
|
1355
1364
|
toggleCollapse(index) {
|
|
1356
1365
|
this.collapsed[index] = !this.collapsed[index];
|
|
@@ -2254,9 +2263,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.9", ngImpor
|
|
|
2254
2263
|
class HotelEquipmentComponent {
|
|
2255
2264
|
constructor() {
|
|
2256
2265
|
this.collapsed1 = true;
|
|
2257
|
-
this.itemsToShow =
|
|
2266
|
+
this.itemsToShow = 6;
|
|
2258
2267
|
this.collapsed2 = true;
|
|
2259
2268
|
}
|
|
2269
|
+
ngOnInit() {
|
|
2270
|
+
this.itemsToShow = window.innerWidth >= 1680 ? 6 : 4;
|
|
2271
|
+
}
|
|
2260
2272
|
ngAfterViewInit() {
|
|
2261
2273
|
fromEvent(window, 'resize')
|
|
2262
2274
|
.pipe(tap(() => {
|