tent-lib 0.0.541 → 0.0.542
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.
|
@@ -15,7 +15,6 @@ export class HotelsListComponent {
|
|
|
15
15
|
}
|
|
16
16
|
ngOnInit() {
|
|
17
17
|
this.collapsed = new Array(this.items?.length).fill(true);
|
|
18
|
-
this.groupItems();
|
|
19
18
|
}
|
|
20
19
|
ngOnChanges(changes) {
|
|
21
20
|
if (changes?.['items']?.currentValue) {
|
|
@@ -24,6 +23,7 @@ export class HotelsListComponent {
|
|
|
24
23
|
}
|
|
25
24
|
}
|
|
26
25
|
groupItems() {
|
|
26
|
+
this.groupedItems = [];
|
|
27
27
|
this.items?.forEach((item) => {
|
|
28
28
|
const existingParentDestiny = this.groupedItems?.find((gruopedItem) => gruopedItem.parentDestiny?.toLowerCase() ===
|
|
29
29
|
item.parentDestiny?.toLowerCase());
|
|
@@ -67,4 +67,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.9", ngImpor
|
|
|
67
67
|
}], hotelClick: [{
|
|
68
68
|
type: Output
|
|
69
69
|
}] } });
|
|
70
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hotels-list.component.js","sourceRoot":"","sources":["../../../../../../../projects/tent/src/lib/components/core/hotels-list/hotels-list.component.ts","../../../../../../../projects/tent/src/lib/components/core/hotels-list/hotels-list.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EACH,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,KAAK,EAGL,MAAM,GAET,MAAM,eAAe,CAAC;AAGvB,OAAO,EAAE,YAAY,EAAE,MAAM,8BAA8B,CAAC;AAC5D,OAAO,EAAE,eAAe,EAAE,MAAM,sCAAsC,CAAC;AACvE,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;;;;;AAS/C,MAAM,OAAO,mBAAmB;IAa5B,YAA6B,SAAuB;QAAvB,cAAS,GAAT,SAAS,CAAc;QAN1C,eAAU,GAAG,IAAI,YAAY,EAAkB,CAAC;QAI1D,iBAAY,GAAoB,EAAE,CAAC;IAEoB,CAAC;IAExD,QAAQ;QACJ,IAAI,CAAC,SAAS,GAAG,IAAI,KAAK,CAAC,IAAI,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC1D,IAAI,CAAC,UAAU,EAAE,CAAC;IACtB,CAAC;IAED,WAAW,CAAC,OAAsB;QAC9B,IAAI,OAAO,EAAE,CAAC,OAAO,CAAC,EAAE,YAAY,EAAE;YAClC,IAAI,CAAC,SAAS,GAAG,IAAI,KAAK,CAAC,IAAI,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAC1D,IAAI,CAAC,UAAU,EAAE,CAAC;SACrB;IACL,CAAC;IAED,UAAU;QACN,IAAI,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;YACzB,MAAM,qBAAqB,GAAG,IAAI,CAAC,YAAY,EAAE,IAAI,CACjD,CAAC,WAAW,EAAE,EAAE,CACZ,WAAW,CAAC,aAAa,EAAE,WAAW,EAAE;gBACxC,IAAI,CAAC,aAAa,EAAE,WAAW,EAAE,CACxC,CAAC;YACF,IAAI,qBAAqB,EAAE;gBACvB,qBAAqB,CAAC,KAAK,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;aAC3C;iBAAM;gBACH,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC;oBACnB,aAAa,EAAE,IAAI,CAAC,aAAa;oBACjC,KAAK,EAAE,CAAC,IAAI,CAAC;iBAChB,CAAC,CAAC;aACN;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAED,QAAQ,CAAC,KAAa;QAClB,OAAO,IAAI,CAAC,SAAS,CAAC,wBAAwB,CAC1C,yBAAyB,KAAK,GAAG,CACpC,CAAC;IACN,CAAC;IAED,cAAc,CAAC,KAAa;QACxB,IAAI,IAAI,CAAC,SAAS,EAAE,MAAM,EAAE;YACxB,MAAM,YAAY,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;YAC3C,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAC1B,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,YAAY,CAAC;SACzC;IACL,CAAC;8GAzDQ,mBAAmB;kGAAnB,mBAAmB,gRCxBhC,i0NAoJA,ghsBDjIc,YAAY,6HAAE,eAAe,8OAAE,YAAY,sDAAE,YAAY;;2FAK1D,mBAAmB;kBAR/B,SAAS;+BACI,kBAAkB,cAChB,IAAI,WACP,CAAC,YAAY,EAAE,eAAe,EAAE,YAAY,EAAE,YAAY,CAAC,mBAGnD,uBAAuB,CAAC,MAAM;iFAGtC,SAAS;sBAAjB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,KAAK;sBAAb,KAAK;gBAEI,UAAU;sBAAnB,MAAM","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport {\r\n    ChangeDetectionStrategy,\r\n    Component,\r\n    EventEmitter,\r\n    Input,\r\n    OnChanges,\r\n    OnInit,\r\n    Output,\r\n    SimpleChanges,\r\n} from '@angular/core';\r\nimport { DomSanitizer, SafeStyle } from '@angular/platform-browser';\r\nimport { ButtonI } from '../../../interfaces/atomic/button.interface';\r\nimport { CurrencyPipe } from '../../../pipes/currency.pipe';\r\nimport { ButtonComponent } from '../../atomic/button/button.component';\r\nimport { RouterModule } from '@angular/router';\r\n@Component({\r\n    selector: 'tent-hotels-list',\r\n    standalone: true,\r\n    imports: [CommonModule, ButtonComponent, CurrencyPipe, RouterModule],\r\n    templateUrl: './hotels-list.component.html',\r\n    styleUrl: './hotels-list.component.scss',\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class HotelsListComponent implements OnInit, OnChanges {\r\n    @Input() infoTitle?: string;\r\n    @Input() infoTitleDark?: string;\r\n    @Input() infoDescription?: string;\r\n    @Input() links?: ButtonI[];\r\n    @Input() items?: HotelsListItem[];\r\n\r\n    @Output() hotelClick = new EventEmitter<HotelsListItem>();\r\n\r\n    collapsed?: boolean[];\r\n\r\n    groupedItems: HotelsListRow[] = [];\r\n\r\n    constructor(private readonly sanitizer: DomSanitizer) {}\r\n\r\n    ngOnInit(): void {\r\n        this.collapsed = new Array(this.items?.length).fill(true);\r\n        this.groupItems();\r\n    }\r\n\r\n    ngOnChanges(changes: SimpleChanges): void {\r\n        if (changes?.['items']?.currentValue) {\r\n            this.collapsed = new Array(this.items?.length).fill(true);\r\n            this.groupItems();\r\n        }\r\n    }\r\n\r\n    groupItems(): void {\r\n        this.items?.forEach((item) => {\r\n            const existingParentDestiny = this.groupedItems?.find(\r\n                (gruopedItem) =>\r\n                    gruopedItem.parentDestiny?.toLowerCase() ===\r\n                    item.parentDestiny?.toLowerCase()\r\n            );\r\n            if (existingParentDestiny) {\r\n                existingParentDestiny.items?.push(item);\r\n            } else {\r\n                this.groupedItems.push({\r\n                    parentDestiny: item.parentDestiny,\r\n                    items: [item],\r\n                });\r\n            }\r\n        });\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    toggleCollapse(index: number): void {\r\n        if (this.collapsed?.length) {\r\n            const itemCollapse = this.collapsed[index];\r\n            this.collapsed.fill(true);\r\n            this.collapsed[index] = !itemCollapse;\r\n        }\r\n    }\r\n}\r\n\r\nexport interface HotelsListItem {\r\n    title?: string;\r\n    ndTitle?: string;\r\n    subtitle?: string;\r\n    description?: string;\r\n    additionalDescription?: string;\r\n    priceTitle?: string;\r\n    priceSubtitle?: string;\r\n    price?: string | number;\r\n    currency?: string;\r\n    image?: string;\r\n    services?: string[];\r\n    button?: ButtonI;\r\n    hotelUrl?: string;\r\n    destinyId?: string | number;\r\n    parentDestiny?: string;\r\n    id: number;\r\n}\r\n\r\nexport interface HotelsListRow {\r\n    parentDestiny?: string;\r\n    items?: HotelsListItem[];\r\n}\r\n","@if (items?.length) {\r\n<section class=\"hotels-list module-spacer--bottom\">\r\n    @for (row of groupedItems; track $index) {\r\n    <div class=\"hotels-list--row\">\r\n        <h2 class=\"title--60 color--brown\">\r\n            {{ row.parentDestiny }}\r\n        </h2>\r\n        <div class=\"hotels-list--content wrapper-big\">\r\n            <div class=\"hotels-list--inner\">\r\n                @for (item of row.items; track mainIndex; let mainIndex =\r\n                $index) {\r\n                <div class=\"hotels-list--item\">\r\n                    @if (item.image) {\r\n                    <a\r\n                        [href]=\"item.hotelUrl\"\r\n                        [routerLink]=\"[item.hotelUrl]\"\r\n                        (click)=\"$event.preventDefault(); hotelClick.emit(item)\"\r\n                        class=\"hotels-list--photo figure-content figure-zoom\"\r\n                    >\r\n                        <figure\r\n                            class=\"figure-full\"\r\n                            [style]=\"this.getImage(item.image)\"\r\n                        ></figure>\r\n                    </a>\r\n                    } @if (item.title || item.description) {\r\n                    <div\r\n                        class=\"hotels-list--info bg-white\"\r\n                        [ngClass]=\"collapsed?.[mainIndex] ? 'close' : 'open'\"\r\n                    >\r\n                        @if (item.title) {\r\n                        <a\r\n                            [href]=\"item.hotelUrl\"\r\n                            [routerLink]=\"[item.hotelUrl]\"\r\n                            (click)=\"\r\n                                $event.preventDefault(); hotelClick.emit(item)\r\n                            \"\r\n                        >\r\n                            <h2 class=\"hotels-list--tit title--38 color--camel\">\r\n                                {{ item.title }} <br />{{ item.ndTitle }}\r\n                            </h2>\r\n                        </a>\r\n                        } @if (item.subtitle) {\r\n                        <h3 class=\"subtitle--medium color--brown-dark\">\r\n                            {{ item.subtitle }}\r\n                        </h3>\r\n                        } @if (item.description) {\r\n                        <p class=\"text\">\r\n                            {{ item.description }}\r\n                        </p>\r\n                        } @if (item.additionalDescription) {\r\n                        <p class=\"text text-more\">\r\n                            {{ item.additionalDescription }}\r\n                        </p>\r\n                        } @if (links?.length) {\r\n                        <div class=\"hotels-list--btns\">\r\n                            @for (link of links; track $index; let first =\r\n                            $first) {\r\n                            <tent-button\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(mainIndex)\"\r\n                                [name]=\"link.label\"\r\n                            ></tent-button>\r\n                            }\r\n                        </div>\r\n                        }\r\n                    </div>\r\n                    } @if (item.services?.length || (item.priceTitle &&\r\n                    item.price && item.currency)) {\r\n                    <ul class=\"hotels-list--services bg-beige\">\r\n                        @if (item.services?.length) { @for (service of\r\n                        item.services; track $index) {\r\n                        <li class=\"hotels-list--services--item\">\r\n                            <p class=\"text\">{{ service }}</p>\r\n                        </li>\r\n                        } } @if (item.priceTitle && item.price && item.currency)\r\n                        {\r\n                        <div class=\"hotels-list--footer\">\r\n                            <div class=\"hotels-list--footer--text\">\r\n                                <p\r\n                                    class=\"hotels-list--footer--title color--brown\"\r\n                                >\r\n                                    {{ item.priceTitle }}\r\n                                </p>\r\n                                @if (item.priceSubtitle) {\r\n                                <p\r\n                                    class=\"hotels-list--footer--subtitle color--brown\"\r\n                                >\r\n                                    {{ item.priceSubtitle }}\r\n                                </p>\r\n                                }\r\n                            </div>\r\n                            <span\r\n                                class=\"hotels-list--footer--price color--brown\"\r\n                                >{{ item.price\r\n                                }}<span>{{\r\n                                    item.currency | currencySymbol\r\n                                }}</span></span\r\n                            >\r\n                        </div>\r\n                        }\r\n                    </ul>\r\n                    } @if (item.button) {\r\n                    <div class=\"hotels-list--book\">\r\n                        <tent-button\r\n                            type=\"dark-box-filled\"\r\n                            class=\"btn-small\"\r\n                            [label]=\"item.button.label\"\r\n                            [url]=\"item.button.url\"\r\n                            [linkType]=\"item.button.linkType\"\r\n                        ></tent-button>\r\n                    </div>\r\n                    }\r\n                </div>\r\n                }\r\n            </div>\r\n        </div>\r\n    </div>\r\n\r\n    }\r\n</section>\r\n} @if(infoTitle || infoDescription){\r\n<section class=\"module-info module-spacer--bottom\">\r\n    <div class=\"module-info--content wrapper-big\">\r\n        <div class=\"module-info--inner\">\r\n            <div class=\"module-info--box\">\r\n                @if (infoTitle) {\r\n                <h3 class=\"module-info--title title--80 color--camel\">\r\n                    {{ infoTitle }} @if (infoTitleDark) {\r\n                    <span class=\"color--brown\">\r\n                        {{ infoTitleDark }}\r\n                    </span>\r\n                    }\r\n                </h3>\r\n                } @if (infoDescription) {\r\n                <div class=\"module-info--des\">\r\n                    <p class=\"text\" [innerHTML]=\"infoDescription\"></p>\r\n                </div>\r\n                }\r\n            </div>\r\n        </div>\r\n    </div>\r\n</section>\r\n}\r\n"]}
|
|
70
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hotels-list.component.js","sourceRoot":"","sources":["../../../../../../../projects/tent/src/lib/components/core/hotels-list/hotels-list.component.ts","../../../../../../../projects/tent/src/lib/components/core/hotels-list/hotels-list.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EACH,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,KAAK,EAGL,MAAM,GAET,MAAM,eAAe,CAAC;AAGvB,OAAO,EAAE,YAAY,EAAE,MAAM,8BAA8B,CAAC;AAC5D,OAAO,EAAE,eAAe,EAAE,MAAM,sCAAsC,CAAC;AACvE,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;;;;;AAS/C,MAAM,OAAO,mBAAmB;IAa5B,YAA6B,SAAuB;QAAvB,cAAS,GAAT,SAAS,CAAc;QAN1C,eAAU,GAAG,IAAI,YAAY,EAAkB,CAAC;QAI1D,iBAAY,GAAoB,EAAE,CAAC;IAEoB,CAAC;IAExD,QAAQ;QACJ,IAAI,CAAC,SAAS,GAAG,IAAI,KAAK,CAAC,IAAI,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC9D,CAAC;IAED,WAAW,CAAC,OAAsB;QAC9B,IAAI,OAAO,EAAE,CAAC,OAAO,CAAC,EAAE,YAAY,EAAE;YAClC,IAAI,CAAC,SAAS,GAAG,IAAI,KAAK,CAAC,IAAI,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAC1D,IAAI,CAAC,UAAU,EAAE,CAAC;SACrB;IACL,CAAC;IAED,UAAU;QACN,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;QACvB,IAAI,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;YACzB,MAAM,qBAAqB,GAAG,IAAI,CAAC,YAAY,EAAE,IAAI,CACjD,CAAC,WAAW,EAAE,EAAE,CACZ,WAAW,CAAC,aAAa,EAAE,WAAW,EAAE;gBACxC,IAAI,CAAC,aAAa,EAAE,WAAW,EAAE,CACxC,CAAC;YACF,IAAI,qBAAqB,EAAE;gBACvB,qBAAqB,CAAC,KAAK,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;aAC3C;iBAAM;gBACH,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC;oBACnB,aAAa,EAAE,IAAI,CAAC,aAAa;oBACjC,KAAK,EAAE,CAAC,IAAI,CAAC;iBAChB,CAAC,CAAC;aACN;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAED,QAAQ,CAAC,KAAa;QAClB,OAAO,IAAI,CAAC,SAAS,CAAC,wBAAwB,CAC1C,yBAAyB,KAAK,GAAG,CACpC,CAAC;IACN,CAAC;IAED,cAAc,CAAC,KAAa;QACxB,IAAI,IAAI,CAAC,SAAS,EAAE,MAAM,EAAE;YACxB,MAAM,YAAY,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;YAC3C,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAC1B,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,YAAY,CAAC;SACzC;IACL,CAAC;8GAzDQ,mBAAmB;kGAAnB,mBAAmB,gRCxBhC,i0NAoJA,ghsBDjIc,YAAY,6HAAE,eAAe,8OAAE,YAAY,sDAAE,YAAY;;2FAK1D,mBAAmB;kBAR/B,SAAS;+BACI,kBAAkB,cAChB,IAAI,WACP,CAAC,YAAY,EAAE,eAAe,EAAE,YAAY,EAAE,YAAY,CAAC,mBAGnD,uBAAuB,CAAC,MAAM;iFAGtC,SAAS;sBAAjB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,KAAK;sBAAb,KAAK;gBAEI,UAAU;sBAAnB,MAAM","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport {\r\n    ChangeDetectionStrategy,\r\n    Component,\r\n    EventEmitter,\r\n    Input,\r\n    OnChanges,\r\n    OnInit,\r\n    Output,\r\n    SimpleChanges,\r\n} from '@angular/core';\r\nimport { DomSanitizer, SafeStyle } from '@angular/platform-browser';\r\nimport { ButtonI } from '../../../interfaces/atomic/button.interface';\r\nimport { CurrencyPipe } from '../../../pipes/currency.pipe';\r\nimport { ButtonComponent } from '../../atomic/button/button.component';\r\nimport { RouterModule } from '@angular/router';\r\n@Component({\r\n    selector: 'tent-hotels-list',\r\n    standalone: true,\r\n    imports: [CommonModule, ButtonComponent, CurrencyPipe, RouterModule],\r\n    templateUrl: './hotels-list.component.html',\r\n    styleUrl: './hotels-list.component.scss',\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class HotelsListComponent implements OnInit, OnChanges {\r\n    @Input() infoTitle?: string;\r\n    @Input() infoTitleDark?: string;\r\n    @Input() infoDescription?: string;\r\n    @Input() links?: ButtonI[];\r\n    @Input() items?: HotelsListItem[];\r\n\r\n    @Output() hotelClick = new EventEmitter<HotelsListItem>();\r\n\r\n    collapsed?: boolean[];\r\n\r\n    groupedItems: HotelsListRow[] = [];\r\n\r\n    constructor(private readonly sanitizer: DomSanitizer) {}\r\n\r\n    ngOnInit(): void {\r\n        this.collapsed = new Array(this.items?.length).fill(true);\r\n    }\r\n\r\n    ngOnChanges(changes: SimpleChanges): void {\r\n        if (changes?.['items']?.currentValue) {\r\n            this.collapsed = new Array(this.items?.length).fill(true);\r\n            this.groupItems();\r\n        }\r\n    }\r\n\r\n    groupItems(): void {\r\n        this.groupedItems = [];\r\n        this.items?.forEach((item) => {\r\n            const existingParentDestiny = this.groupedItems?.find(\r\n                (gruopedItem) =>\r\n                    gruopedItem.parentDestiny?.toLowerCase() ===\r\n                    item.parentDestiny?.toLowerCase()\r\n            );\r\n            if (existingParentDestiny) {\r\n                existingParentDestiny.items?.push(item);\r\n            } else {\r\n                this.groupedItems.push({\r\n                    parentDestiny: item.parentDestiny,\r\n                    items: [item],\r\n                });\r\n            }\r\n        });\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    toggleCollapse(index: number): void {\r\n        if (this.collapsed?.length) {\r\n            const itemCollapse = this.collapsed[index];\r\n            this.collapsed.fill(true);\r\n            this.collapsed[index] = !itemCollapse;\r\n        }\r\n    }\r\n}\r\n\r\nexport interface HotelsListItem {\r\n    title?: string;\r\n    ndTitle?: string;\r\n    subtitle?: string;\r\n    description?: string;\r\n    additionalDescription?: string;\r\n    priceTitle?: string;\r\n    priceSubtitle?: string;\r\n    price?: string | number;\r\n    currency?: string;\r\n    image?: string;\r\n    services?: string[];\r\n    button?: ButtonI;\r\n    hotelUrl?: string;\r\n    destinyId?: string | number;\r\n    parentDestiny?: string;\r\n    id: number;\r\n}\r\n\r\nexport interface HotelsListRow {\r\n    parentDestiny?: string;\r\n    items?: HotelsListItem[];\r\n}\r\n","@if (items?.length) {\r\n<section class=\"hotels-list module-spacer--bottom\">\r\n    @for (row of groupedItems; track $index) {\r\n    <div class=\"hotels-list--row\">\r\n        <h2 class=\"title--60 color--brown\">\r\n            {{ row.parentDestiny }}\r\n        </h2>\r\n        <div class=\"hotels-list--content wrapper-big\">\r\n            <div class=\"hotels-list--inner\">\r\n                @for (item of row.items; track mainIndex; let mainIndex =\r\n                $index) {\r\n                <div class=\"hotels-list--item\">\r\n                    @if (item.image) {\r\n                    <a\r\n                        [href]=\"item.hotelUrl\"\r\n                        [routerLink]=\"[item.hotelUrl]\"\r\n                        (click)=\"$event.preventDefault(); hotelClick.emit(item)\"\r\n                        class=\"hotels-list--photo figure-content figure-zoom\"\r\n                    >\r\n                        <figure\r\n                            class=\"figure-full\"\r\n                            [style]=\"this.getImage(item.image)\"\r\n                        ></figure>\r\n                    </a>\r\n                    } @if (item.title || item.description) {\r\n                    <div\r\n                        class=\"hotels-list--info bg-white\"\r\n                        [ngClass]=\"collapsed?.[mainIndex] ? 'close' : 'open'\"\r\n                    >\r\n                        @if (item.title) {\r\n                        <a\r\n                            [href]=\"item.hotelUrl\"\r\n                            [routerLink]=\"[item.hotelUrl]\"\r\n                            (click)=\"\r\n                                $event.preventDefault(); hotelClick.emit(item)\r\n                            \"\r\n                        >\r\n                            <h2 class=\"hotels-list--tit title--38 color--camel\">\r\n                                {{ item.title }} <br />{{ item.ndTitle }}\r\n                            </h2>\r\n                        </a>\r\n                        } @if (item.subtitle) {\r\n                        <h3 class=\"subtitle--medium color--brown-dark\">\r\n                            {{ item.subtitle }}\r\n                        </h3>\r\n                        } @if (item.description) {\r\n                        <p class=\"text\">\r\n                            {{ item.description }}\r\n                        </p>\r\n                        } @if (item.additionalDescription) {\r\n                        <p class=\"text text-more\">\r\n                            {{ item.additionalDescription }}\r\n                        </p>\r\n                        } @if (links?.length) {\r\n                        <div class=\"hotels-list--btns\">\r\n                            @for (link of links; track $index; let first =\r\n                            $first) {\r\n                            <tent-button\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(mainIndex)\"\r\n                                [name]=\"link.label\"\r\n                            ></tent-button>\r\n                            }\r\n                        </div>\r\n                        }\r\n                    </div>\r\n                    } @if (item.services?.length || (item.priceTitle &&\r\n                    item.price && item.currency)) {\r\n                    <ul class=\"hotels-list--services bg-beige\">\r\n                        @if (item.services?.length) { @for (service of\r\n                        item.services; track $index) {\r\n                        <li class=\"hotels-list--services--item\">\r\n                            <p class=\"text\">{{ service }}</p>\r\n                        </li>\r\n                        } } @if (item.priceTitle && item.price && item.currency)\r\n                        {\r\n                        <div class=\"hotels-list--footer\">\r\n                            <div class=\"hotels-list--footer--text\">\r\n                                <p\r\n                                    class=\"hotels-list--footer--title color--brown\"\r\n                                >\r\n                                    {{ item.priceTitle }}\r\n                                </p>\r\n                                @if (item.priceSubtitle) {\r\n                                <p\r\n                                    class=\"hotels-list--footer--subtitle color--brown\"\r\n                                >\r\n                                    {{ item.priceSubtitle }}\r\n                                </p>\r\n                                }\r\n                            </div>\r\n                            <span\r\n                                class=\"hotels-list--footer--price color--brown\"\r\n                                >{{ item.price\r\n                                }}<span>{{\r\n                                    item.currency | currencySymbol\r\n                                }}</span></span\r\n                            >\r\n                        </div>\r\n                        }\r\n                    </ul>\r\n                    } @if (item.button) {\r\n                    <div class=\"hotels-list--book\">\r\n                        <tent-button\r\n                            type=\"dark-box-filled\"\r\n                            class=\"btn-small\"\r\n                            [label]=\"item.button.label\"\r\n                            [url]=\"item.button.url\"\r\n                            [linkType]=\"item.button.linkType\"\r\n                        ></tent-button>\r\n                    </div>\r\n                    }\r\n                </div>\r\n                }\r\n            </div>\r\n        </div>\r\n    </div>\r\n\r\n    }\r\n</section>\r\n} @if(infoTitle || infoDescription){\r\n<section class=\"module-info module-spacer--bottom\">\r\n    <div class=\"module-info--content wrapper-big\">\r\n        <div class=\"module-info--inner\">\r\n            <div class=\"module-info--box\">\r\n                @if (infoTitle) {\r\n                <h3 class=\"module-info--title title--80 color--camel\">\r\n                    {{ infoTitle }} @if (infoTitleDark) {\r\n                    <span class=\"color--brown\">\r\n                        {{ infoTitleDark }}\r\n                    </span>\r\n                    }\r\n                </h3>\r\n                } @if (infoDescription) {\r\n                <div class=\"module-info--des\">\r\n                    <p class=\"text\" [innerHTML]=\"infoDescription\"></p>\r\n                </div>\r\n                }\r\n            </div>\r\n        </div>\r\n    </div>\r\n</section>\r\n}\r\n"]}
|
package/fesm2022/tent-lib.mjs
CHANGED
|
@@ -2351,7 +2351,6 @@ class HotelsListComponent {
|
|
|
2351
2351
|
}
|
|
2352
2352
|
ngOnInit() {
|
|
2353
2353
|
this.collapsed = new Array(this.items?.length).fill(true);
|
|
2354
|
-
this.groupItems();
|
|
2355
2354
|
}
|
|
2356
2355
|
ngOnChanges(changes) {
|
|
2357
2356
|
if (changes?.['items']?.currentValue) {
|
|
@@ -2360,6 +2359,7 @@ class HotelsListComponent {
|
|
|
2360
2359
|
}
|
|
2361
2360
|
}
|
|
2362
2361
|
groupItems() {
|
|
2362
|
+
this.groupedItems = [];
|
|
2363
2363
|
this.items?.forEach((item) => {
|
|
2364
2364
|
const existingParentDestiny = this.groupedItems?.find((gruopedItem) => gruopedItem.parentDestiny?.toLowerCase() ===
|
|
2365
2365
|
item.parentDestiny?.toLowerCase());
|