tent-lib 0.0.511 → 0.0.512
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.
|
@@ -25,6 +25,7 @@ export class HotelsListComponent {
|
|
|
25
25
|
}
|
|
26
26
|
toggleCollapse(index) {
|
|
27
27
|
if (this.collapsed?.length) {
|
|
28
|
+
this.collapsed.fill(false);
|
|
28
29
|
this.collapsed[index] = !this.collapsed[index];
|
|
29
30
|
}
|
|
30
31
|
}
|
|
@@ -47,4 +48,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.9", ngImpor
|
|
|
47
48
|
}], hotelClick: [{
|
|
48
49
|
type: Output
|
|
49
50
|
}] } });
|
|
50
|
-
//# 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;IAW5B,YAA6B,SAAuB;QAAvB,cAAS,GAAT,SAAS,CAAc;QAJ1C,eAAU,GAAG,IAAI,YAAY,EAAkB,CAAC;IAIH,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;SAC7D;IACL,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,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;SAClD;IACL,CAAC;8GAjCQ,mBAAmB;kGAAnB,mBAAmB,gRCxBhC,w7LAoIA,mxrBDjHc,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    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        }\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            this.collapsed[index] = !this.collapsed[index];\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    id: number;\r\n}\r\n","@if (items?.length) {\r\n<section class=\"hotels-list module-spacer--bottom\">\r\n    <div class=\"hotels-list--content wrapper-big\">\r\n        <div class=\"hotels-list--inner\">\r\n            @for (item of items; track mainIndex; let mainIndex = $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)=\"$event.preventDefault(); hotelClick.emit(item)\"\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 = $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 && item.price\r\n                && 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                    <div class=\"hotels-list--footer\">\r\n                        <div class=\"hotels-list--footer--text\">\r\n                            <p class=\"hotels-list--footer--title color--brown\">\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 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</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"]}
|
|
51
|
+
//# 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;IAW5B,YAA6B,SAAuB;QAAvB,cAAS,GAAT,SAAS,CAAc;QAJ1C,eAAU,GAAG,IAAI,YAAY,EAAkB,CAAC;IAIH,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;SAC7D;IACL,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,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAC3B,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;SAClD;IACL,CAAC;8GAlCQ,mBAAmB;kGAAnB,mBAAmB,gRCxBhC,w7LAoIA,mxrBDjHc,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    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        }\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            this.collapsed.fill(false);\r\n            this.collapsed[index] = !this.collapsed[index];\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    id: number;\r\n}\r\n","@if (items?.length) {\r\n<section class=\"hotels-list module-spacer--bottom\">\r\n    <div class=\"hotels-list--content wrapper-big\">\r\n        <div class=\"hotels-list--inner\">\r\n            @for (item of items; track mainIndex; let mainIndex = $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)=\"$event.preventDefault(); hotelClick.emit(item)\"\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 = $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 && item.price\r\n                && 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                    <div class=\"hotels-list--footer\">\r\n                        <div class=\"hotels-list--footer--text\">\r\n                            <p class=\"hotels-list--footer--title color--brown\">\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 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</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"]}
|