ctt-puro 0.64.13 → 0.64.15

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,6 +15,7 @@ export class PuroHeaderComponent {
15
15
  this.SITE_GROUP = 1;
16
16
  this.SITE_HOTELS = 2;
17
17
  this.SITE_BEACH = 3;
18
+ this.HIDE_RESTAURANT_BUTTONS = true; // ⚠️ PROVISIONAL
18
19
  this.cssBgUrl = '';
19
20
  this.cssLogoUrl = '';
20
21
  }
@@ -47,7 +48,9 @@ export class PuroHeaderComponent {
47
48
  return this.isHotelsPage && !this.isRestaurant && !this.isGroupSite;
48
49
  }
49
50
  get showBook() {
50
- return !!this.btnBook && !this.isGroupSite;
51
+ return (!!this.btnBook &&
52
+ !this.isGroupSite &&
53
+ !(this.HIDE_RESTAURANT_BUTTONS && this.isRestaurant));
51
54
  }
52
55
  get showCheckinOnline() {
53
56
  return this.isHotelStickyContext && !!this.btnCheckinOnline;
@@ -106,4 +109,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
106
109
  }], btnClickCheckinOnline: [{
107
110
  type: Output
108
111
  }] } });
109
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"puro-header.component.js","sourceRoot":"","sources":["../../../../../../projects/puro/src/lib/components/puro-header/puro-header.component.ts","../../../../../../projects/puro/src/lib/components/puro-header/puro-header.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule, NgOptimizedImage } from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    EventEmitter,\n    inject,\n    Input,\n    OnInit,\n    Output,\n} from '@angular/core';\nimport {\n    PuroActiveModalDirective,\n    PuroLinkTypeDirective,\n} from '../../directives';\nimport { PuroNavStickyDirective } from '../../directives/puro-nav-sticky/puro-nav-sticky.directive';\nimport { PuroButtonI, PuroImageI } from '../../interfaces';\n\n@Component({\n    selector: 'lib-puro-header',\n    standalone: true,\n    imports: [\n        CommonModule,\n        PuroLinkTypeDirective,\n        PuroActiveModalDirective,\n        PuroNavStickyDirective,\n        NgOptimizedImage,\n    ],\n    templateUrl: './puro-header.component.html',\n    styleUrl: './puro-header.component.scss',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [PuroActiveModalDirective],\n})\nexport class PuroHeaderComponent implements OnInit {\n    private activeModalDtv = inject(PuroActiveModalDirective);\n    @Input() titleMenu?: string;\n    @Input() titleLang?: string;\n    @Input() navLinks?: PuroButtonI[];\n    @Input() bottomLinks?: PuroButtonI[];\n    @Input() siteId?:\n        | typeof this.SITE_GROUP\n        | typeof this.SITE_BEACH\n        | typeof this.SITE_HOTELS;\n    @Input() isHotelsPage: boolean = false;\n    @Input() isRestaurant: boolean = false;\n    @Input() btnBook?: string;\n    @Input() btnCheckinOnline?: string;\n    @Input() btnCheckin?: string;\n    @Input() isDynamic = false;\n    @Input() logoHotel?: string;\n    @Input() linkHotel?: string;\n    @Input() hotelBrand?: PuroImageI;\n    @Input() backgroundImg?: PuroImageI;\n    @Input() currentHotelId?: number;\n\n    @Output() btnClick = new EventEmitter();\n    @Output() btnClickCheckin = new EventEmitter();\n    @Output() btnClickCheckinOnline = new EventEmitter();\n\n    readonly SITE_GROUP = 1;\n    readonly SITE_HOTELS = 2;\n    readonly SITE_BEACH = 3;\n\n    cssBgUrl = '';\n    cssLogoUrl = '';\n\n    clickBtnBook(): void {\n        this.btnClick.emit();\n        switch (this.siteId) {\n            case this.SITE_GROUP:\n                break;\n            case this.SITE_HOTELS:\n                this.activeModalDtv.handleClick();\n                break;\n            case this.SITE_BEACH:\n                break;\n\n            default:\n                break;\n        }\n    }\n\n    ngOnInit(): void {\n        if (this.hotelBrand?.src) {\n            this.cssLogoUrl = `url(\"${this.hotelBrand.src}\")`;\n        }\n        if (this.backgroundImg?.src) {\n            this.cssBgUrl = `url(\"${this.backgroundImg.src}\")`;\n        }\n    }\n\n    get isGroupSite(): boolean {\n        return this.siteId === this.SITE_GROUP;\n    }\n\n    get isHotelStickyContext(): boolean {\n        return this.isHotelsPage && !this.isRestaurant && !this.isGroupSite;\n    }\n\n    get showBook(): boolean {\n        return !!this.btnBook && !this.isGroupSite;\n    }\n\n    get showCheckinOnline(): boolean {\n        return this.isHotelStickyContext && !!this.btnCheckinOnline;\n    }\n\n    get showCheckin(): boolean {\n        return this.isHotelStickyContext && !!this.btnCheckin;\n    }\n}\n","<header class=\"header\" navSticky [isDynamic]=\"isDynamic\">\n    <div class=\"header__logo\">\n        @if (logoHotel) {\n            <a [href]=\"linkHotel\" linkType=\"internal\">\n                <img\n                    [ngSrc]=\"logoHotel\"\n                    alt=\"Logo\"\n                    width=\"301\"\n                    height=\"32\"\n                    class=\"header__logo--img\"\n                    priority\n                />\n            </a>\n        } @else {\n            <a [href]=\"navLinks?.[0]?.url\" [linkType]=\"navLinks?.[0]?.linkType\">\n                <svg\n                    aria-hidden=\"true\"\n                    focusable=\"false\"\n                    width=\"301\"\n                    height=\"32\"\n                    class=\"header__logo--img\"\n                >\n                    @if (siteId === SITE_HOTELS) {\n                        <use href=\"#puro-logo\"></use>\n                    }\n                    @if (siteId === SITE_BEACH) {\n                        <use href=\"#purobeach-logo\"></use>\n                    }\n                    @if (siteId === SITE_GROUP) {\n                        <use href=\"#purogroup-logo\"></use>\n                    }\n                </svg>\n            </a>\n        }\n    </div>\n    <div class=\"header__leftNav\">\n        <div\n            class=\"header__menu js-active-modal\"\n            activeModal\n            data-modal_name=\"navigation\"\n            role=\"button\"\n            [attr.aria-label]=\"titleMenu ?? 'Menu'\"\n        >\n            <i class=\"icon-83\"></i>\n            @if (titleMenu) {\n                <span>{{ titleMenu }}</span>\n            }\n        </div>\n        <div\n            class=\"header__language js-active-modal\"\n            activeModal\n            data-modal_name=\"language\"\n            role=\"button\"\n            [attr.aria-label]=\"titleLang ?? 'Language Menu'\"\n        >\n            @if (titleLang) {\n                {{ titleLang }}\n            }\n        </div>\n    </div>\n    <!-- hide buttons when Puro Oasis Urbano -->\n\n    @if (currentHotelId === 5) {\n        @if (showBook) {\n            <a\n                (click)=\"btnClick.emit()\"\n                class=\"header__reserver\"\n                role=\"button\"\n                [attr.aria-label]=\"btnBook\"\n            >\n                <div class=\"btn btn__primary btn--lg\">\n                    <span>{{ btnBook }}</span>\n                </div>\n            </a>\n        }\n    } @else {\n        @if (isHotelStickyContext) {\n            <!-- SOLO hoteles reales (sticky) -->\n            <div class=\"header__reserver\">\n                @if (showCheckinOnline) {\n                    <a\n                        (click)=\"btnClickCheckinOnline.emit()\"\n                        class=\"btn btn__primary btn--lg checkIn\"\n                        role=\"button\"\n                        [attr.aria-label]=\"btnCheckinOnline\"\n                    >\n                        <span>{{ btnCheckinOnline }}</span>\n                    </a>\n                }\n\n                @if (showCheckin) {\n                    <a\n                        (click)=\"btnClickCheckin.emit()\"\n                        class=\"header__checkIn\"\n                        role=\"button\"\n                        [attr.aria-label]=\"btnCheckin\"\n                    >\n                        {{ btnCheckin }}\n                    </a>\n                }\n\n                @if (showBook) {\n                    <a\n                        (click)=\"btnClick.emit()\"\n                        class=\"btn btn__primary btn--lg reservar\"\n                        role=\"button\"\n                        [attr.aria-label]=\"btnBook\"\n                    >\n                        <span>{{ btnBook }}</span>\n                    </a>\n                }\n            </div>\n        } @else {\n            <!-- Restaurante y páginas NO hotel -->\n            @if (showBook) {\n                <a\n                    (click)=\"btnClick.emit()\"\n                    class=\"header__reserver\"\n                    role=\"button\"\n                    [attr.aria-label]=\"btnBook\"\n                >\n                    <div class=\"btn btn__primary btn--lg\">\n                        <span>{{ btnBook }}</span>\n                    </div>\n                </a>\n            }\n        }\n    }\n</header>\n\n<div class=\"modal modal--solidCream modal--navigation\">\n    <div class=\"modal__inner\">\n        <div\n            class=\"modal__body\"\n            [style.--bg-url]=\"cssBgUrl\"\n            [style.--logo-url]=\"cssLogoUrl\"\n        >\n            <div\n                class=\"modal__close js-close\"\n                activeModal\n                data-modal_name=\"navigation\"\n                role=\"button\"\n                aria-label=\"Close Button\"\n            >\n                <svg\n                    aria-hidden=\"true\"\n                    focusable=\"false\"\n                    class=\"modal__close--icon\"\n                >\n                    <use href=\"#modal-close\"></use>\n                </svg>\n            </div>\n            <div class=\"modal__nav\">\n                <ul class=\"modal__nav--items\">\n                    @if (navLinks) {\n                        @for (link of navLinks; track $index) {\n                            <li class=\"modal__nav--link\">\n                                <a\n                                    class=\"js-close\"\n                                    activeModal\n                                    data-modal_name=\"navigation\"\n                                    [href]=\"link.url\"\n                                    [linkType]=\"link.linkType\"\n                                    [attr.aria-label]=\"link.label\"\n                                >\n                                    {{ link.label }}\n                                </a>\n                            </li>\n                        }\n                    }\n                </ul>\n                <ul class=\"modal__nav--itemsSmall\">\n                    @if (bottomLinks) {\n                        @for (link of bottomLinks; track $index) {\n                            @if (link.url === 'lang') {\n                                <li\n                                    class=\"modal__nav--link js-active-modal\"\n                                    activeModal\n                                    data-modal_name=\"language\"\n                                    role=\"button\"\n                                    [attr.aria-label]=\"\n                                        link.label ?? 'Language Menu'\n                                    \"\n                                >\n                                    <a>\n                                        {{ link.label }}\n                                    </a>\n                                </li>\n                            } @else {\n                                <li class=\"modal__nav--link\">\n                                    <a\n                                        class=\"js-close\"\n                                        activeModal\n                                        data-modal_name=\"navigation\"\n                                        [href]=\"link.url\"\n                                        [linkType]=\"link.linkType\"\n                                        [attr.aria-label]=\"link.label\"\n                                    >\n                                        {{ link.label }}\n                                    </a>\n                                </li>\n                            }\n                        }\n                    }\n                </ul>\n            </div>\n        </div>\n    </div>\n</div>\n"]}
112
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"puro-header.component.js","sourceRoot":"","sources":["../../../../../../projects/puro/src/lib/components/puro-header/puro-header.component.ts","../../../../../../projects/puro/src/lib/components/puro-header/puro-header.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule, NgOptimizedImage } from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    EventEmitter,\n    inject,\n    Input,\n    OnInit,\n    Output,\n} from '@angular/core';\nimport {\n    PuroActiveModalDirective,\n    PuroLinkTypeDirective,\n} from '../../directives';\nimport { PuroNavStickyDirective } from '../../directives/puro-nav-sticky/puro-nav-sticky.directive';\nimport { PuroButtonI, PuroImageI } from '../../interfaces';\n\n@Component({\n    selector: 'lib-puro-header',\n    standalone: true,\n    imports: [\n        CommonModule,\n        PuroLinkTypeDirective,\n        PuroActiveModalDirective,\n        PuroNavStickyDirective,\n        NgOptimizedImage,\n    ],\n    templateUrl: './puro-header.component.html',\n    styleUrl: './puro-header.component.scss',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [PuroActiveModalDirective],\n})\nexport class PuroHeaderComponent implements OnInit {\n    private activeModalDtv = inject(PuroActiveModalDirective);\n    @Input() titleMenu?: string;\n    @Input() titleLang?: string;\n    @Input() navLinks?: PuroButtonI[];\n    @Input() bottomLinks?: PuroButtonI[];\n    @Input() siteId?:\n        | typeof this.SITE_GROUP\n        | typeof this.SITE_BEACH\n        | typeof this.SITE_HOTELS;\n    @Input() isHotelsPage: boolean = false;\n    @Input() isRestaurant: boolean = false;\n    @Input() btnBook?: string;\n    @Input() btnCheckinOnline?: string;\n    @Input() btnCheckin?: string;\n    @Input() isDynamic = false;\n    @Input() logoHotel?: string;\n    @Input() linkHotel?: string;\n    @Input() hotelBrand?: PuroImageI;\n    @Input() backgroundImg?: PuroImageI;\n    @Input() currentHotelId?: number;\n\n    @Output() btnClick = new EventEmitter();\n    @Output() btnClickCheckin = new EventEmitter();\n    @Output() btnClickCheckinOnline = new EventEmitter();\n\n    readonly SITE_GROUP = 1;\n    readonly SITE_HOTELS = 2;\n    readonly SITE_BEACH = 3;\n    readonly HIDE_RESTAURANT_BUTTONS = true; // ⚠️ PROVISIONAL\n\n    cssBgUrl = '';\n    cssLogoUrl = '';\n\n    clickBtnBook(): void {\n        this.btnClick.emit();\n        switch (this.siteId) {\n            case this.SITE_GROUP:\n                break;\n            case this.SITE_HOTELS:\n                this.activeModalDtv.handleClick();\n                break;\n            case this.SITE_BEACH:\n                break;\n\n            default:\n                break;\n        }\n    }\n\n    ngOnInit(): void {\n        if (this.hotelBrand?.src) {\n            this.cssLogoUrl = `url(\"${this.hotelBrand.src}\")`;\n        }\n        if (this.backgroundImg?.src) {\n            this.cssBgUrl = `url(\"${this.backgroundImg.src}\")`;\n        }\n    }\n\n    get isGroupSite(): boolean {\n        return this.siteId === this.SITE_GROUP;\n    }\n\n    get isHotelStickyContext(): boolean {\n        return this.isHotelsPage && !this.isRestaurant && !this.isGroupSite;\n    }\n\n    get showBook(): boolean {\n        return (\n            !!this.btnBook &&\n            !this.isGroupSite &&\n            !(this.HIDE_RESTAURANT_BUTTONS && this.isRestaurant)\n        );\n    }\n\n    get showCheckinOnline(): boolean {\n        return this.isHotelStickyContext && !!this.btnCheckinOnline;\n    }\n\n    get showCheckin(): boolean {\n        return this.isHotelStickyContext && !!this.btnCheckin;\n    }\n}\n","<header class=\"header\" navSticky [isDynamic]=\"isDynamic\">\n    <div class=\"header__logo\">\n        @if (logoHotel) {\n            <a [href]=\"linkHotel\" linkType=\"internal\">\n                <img\n                    [ngSrc]=\"logoHotel\"\n                    alt=\"Logo\"\n                    width=\"301\"\n                    height=\"32\"\n                    class=\"header__logo--img\"\n                    priority\n                />\n            </a>\n        } @else {\n            <a [href]=\"navLinks?.[0]?.url\" [linkType]=\"navLinks?.[0]?.linkType\">\n                <svg\n                    aria-hidden=\"true\"\n                    focusable=\"false\"\n                    width=\"301\"\n                    height=\"32\"\n                    class=\"header__logo--img\"\n                >\n                    @if (siteId === SITE_HOTELS) {\n                        <use href=\"#puro-logo\"></use>\n                    }\n                    @if (siteId === SITE_BEACH) {\n                        <use href=\"#purobeach-logo\"></use>\n                    }\n                    @if (siteId === SITE_GROUP) {\n                        <use href=\"#purogroup-logo\"></use>\n                    }\n                </svg>\n            </a>\n        }\n    </div>\n    <div class=\"header__leftNav\">\n        <div\n            class=\"header__menu js-active-modal\"\n            activeModal\n            data-modal_name=\"navigation\"\n            role=\"button\"\n            [attr.aria-label]=\"titleMenu ?? 'Menu'\"\n        >\n            <i class=\"icon-83\"></i>\n            @if (titleMenu) {\n                <span>{{ titleMenu }}</span>\n            }\n        </div>\n        <div\n            class=\"header__language js-active-modal\"\n            activeModal\n            data-modal_name=\"language\"\n            role=\"button\"\n            [attr.aria-label]=\"titleLang ?? 'Language Menu'\"\n        >\n            @if (titleLang) {\n                {{ titleLang }}\n            }\n        </div>\n    </div>\n    <!-- hide buttons when Puro Oasis Urbano -->\n\n    @if (currentHotelId === 5) {\n        @if (showBook) {\n            <a\n                (click)=\"btnClick.emit()\"\n                class=\"header__reserver\"\n                role=\"button\"\n                [attr.aria-label]=\"btnBook\"\n            >\n                <div class=\"btn btn__primary btn--lg\">\n                    <span>{{ btnBook }}</span>\n                </div>\n            </a>\n        }\n    } @else {\n        @if (isHotelStickyContext) {\n            <!-- SOLO hoteles reales (sticky) -->\n            <div class=\"header__reserver\">\n                @if (showCheckinOnline) {\n                    <a\n                        (click)=\"btnClickCheckinOnline.emit()\"\n                        class=\"btn btn__primary btn--lg checkIn\"\n                        role=\"button\"\n                        [attr.aria-label]=\"btnCheckinOnline\"\n                    >\n                        <span>{{ btnCheckinOnline }}</span>\n                    </a>\n                }\n\n                @if (showCheckin) {\n                    <a\n                        (click)=\"btnClickCheckin.emit()\"\n                        class=\"header__checkIn\"\n                        role=\"button\"\n                        [attr.aria-label]=\"btnCheckin\"\n                    >\n                        {{ btnCheckin }}\n                    </a>\n                }\n\n                @if (showBook) {\n                    <a\n                        (click)=\"btnClick.emit()\"\n                        class=\"btn btn__primary btn--lg reservar\"\n                        role=\"button\"\n                        [attr.aria-label]=\"btnBook\"\n                    >\n                        <span>{{ btnBook }}</span>\n                    </a>\n                }\n            </div>\n        } @else {\n            <!-- Restaurante y páginas NO hotel -->\n            @if (showBook) {\n                <a\n                    (click)=\"btnClick.emit()\"\n                    class=\"header__reserver\"\n                    role=\"button\"\n                    [attr.aria-label]=\"btnBook\"\n                >\n                    <div class=\"btn btn__primary btn--lg\">\n                        <span>{{ btnBook }}</span>\n                    </div>\n                </a>\n            }\n        }\n    }\n</header>\n\n<div class=\"modal modal--solidCream modal--navigation\">\n    <div class=\"modal__inner\">\n        <div\n            class=\"modal__body\"\n            [style.--bg-url]=\"cssBgUrl\"\n            [style.--logo-url]=\"cssLogoUrl\"\n        >\n            <div\n                class=\"modal__close js-close\"\n                activeModal\n                data-modal_name=\"navigation\"\n                role=\"button\"\n                aria-label=\"Close Button\"\n            >\n                <svg\n                    aria-hidden=\"true\"\n                    focusable=\"false\"\n                    class=\"modal__close--icon\"\n                >\n                    <use href=\"#modal-close\"></use>\n                </svg>\n            </div>\n            <div class=\"modal__nav\">\n                <ul class=\"modal__nav--items\">\n                    @if (navLinks) {\n                        @for (link of navLinks; track $index) {\n                            <li class=\"modal__nav--link\">\n                                <a\n                                    class=\"js-close\"\n                                    activeModal\n                                    data-modal_name=\"navigation\"\n                                    [href]=\"link.url\"\n                                    [linkType]=\"link.linkType\"\n                                    [attr.aria-label]=\"link.label\"\n                                >\n                                    {{ link.label }}\n                                </a>\n                            </li>\n                        }\n                    }\n                </ul>\n                <ul class=\"modal__nav--itemsSmall\">\n                    @if (bottomLinks) {\n                        @for (link of bottomLinks; track $index) {\n                            @if (link.url === 'lang') {\n                                <li\n                                    class=\"modal__nav--link js-active-modal\"\n                                    activeModal\n                                    data-modal_name=\"language\"\n                                    role=\"button\"\n                                    [attr.aria-label]=\"\n                                        link.label ?? 'Language Menu'\n                                    \"\n                                >\n                                    <a>\n                                        {{ link.label }}\n                                    </a>\n                                </li>\n                            } @else {\n                                <li class=\"modal__nav--link\">\n                                    <a\n                                        class=\"js-close\"\n                                        activeModal\n                                        data-modal_name=\"navigation\"\n                                        [href]=\"link.url\"\n                                        [linkType]=\"link.linkType\"\n                                        [attr.aria-label]=\"link.label\"\n                                    >\n                                        {{ link.label }}\n                                    </a>\n                                </li>\n                            }\n                        }\n                    }\n                </ul>\n            </div>\n        </div>\n    </div>\n</div>\n"]}
@@ -14,6 +14,7 @@ export class PuroHeaderMobileComponent {
14
14
  this.SITE_GROUP = 1;
15
15
  this.SITE_HOTELS = 2;
16
16
  this.SITE_BEACH = 3;
17
+ this.HIDE_RESTAURANT_BUTTONS = true; // ⚠️ PROVISIONAL
17
18
  this.cssBgUrl = '';
18
19
  this.cssLogoUrl = '';
19
20
  // 👁️ Signal reactivo que indica si el body tiene las clases sticky
@@ -84,9 +85,12 @@ export class PuroHeaderMobileComponent {
84
85
  get showHeaderBookButton() {
85
86
  if (!this.btnBook)
86
87
  return false;
87
- // Site 1 → solo restaurantes
88
- if (this.siteId === 1) {
89
- return this.isRestaurant === true;
88
+ // Site 1 → nunca botón (coherente con desktop)
89
+ if (this.siteId === this.SITE_GROUP)
90
+ return false;
91
+ // ⚠️ PROVISIONAL: ocultar botones en restaurantes
92
+ if (this.HIDE_RESTAURANT_BUTTONS && this.isRestaurant) {
93
+ return false;
90
94
  }
91
95
  return true;
92
96
  }
@@ -129,4 +133,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
129
133
  }], btnClick: [{
130
134
  type: Output
131
135
  }] } });
132
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"puro-header-mobile.component.js","sourceRoot":"","sources":["../../../../../../projects/puro/src/lib/components/puro-header-mobile/puro-header-mobile.component.ts","../../../../../../projects/puro/src/lib/components/puro-header-mobile/puro-header-mobile.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    CommonModule,\n    isPlatformBrowser,\n    NgOptimizedImage,\n} from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    EventEmitter,\n    Input,\n    Output,\n    PLATFORM_ID,\n    inject,\n    OnInit,\n    OnDestroy,\n    signal,\n} from '@angular/core';\nimport { NavigationEnd, Router } from '@angular/router';\nimport { filter } from 'rxjs';\nimport {\n    PuroActiveModalDirective,\n    PuroLinkTypeDirective,\n} from '../../directives';\nimport { PuroNavStickyDirective } from '../../directives/puro-nav-sticky/puro-nav-sticky.directive';\nimport { PuroButtonI, PuroImageI } from '../../interfaces';\n\n@Component({\n    selector: 'lib-puro-header-mobile',\n    standalone: true,\n    imports: [\n        CommonModule,\n        PuroLinkTypeDirective,\n        PuroActiveModalDirective,\n        PuroNavStickyDirective,\n        NgOptimizedImage,\n    ],\n    templateUrl: './puro-header-mobile.component.html',\n    styleUrl: './puro-header-mobile.component.scss',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [PuroActiveModalDirective],\n})\nexport class PuroHeaderMobileComponent implements OnInit, OnDestroy {\n    private activeModalDtv = inject(PuroActiveModalDirective);\n    private platformId = inject(PLATFORM_ID);\n    private router = inject(Router);\n\n    @Input() titleMenu?: string;\n    @Input() titleLang?: string;\n    @Input() btnBook?: string;\n    @Input() navLinks?: PuroButtonI[];\n    @Input() bottomLinks?: PuroButtonI[];\n    @Input() isDynamic = false;\n    @Input() hotelBrand?: PuroImageI;\n    @Input() backgroundImg?: PuroImageI;\n    @Input() logoHotel?: string;\n    @Input() logoHotelWhite?: string;\n    @Input() isRestaurant?: boolean;\n    @Input() siteId?:\n        | typeof this.SITE_GROUP\n        | typeof this.SITE_BEACH\n        | typeof this.SITE_HOTELS;\n\n    @Output() btnClick = new EventEmitter();\n\n    readonly SITE_GROUP = 1;\n    readonly SITE_HOTELS = 2;\n    readonly SITE_BEACH = 3;\n\n    cssBgUrl = '';\n    cssLogoUrl = '';\n\n    // 👁️ Signal reactivo que indica si el body tiene las clases sticky\n    hasStickyClasses = signal(false);\n\n    private observer?: MutationObserver;\n    private scrollListener?: () => void;\n    private rafId?: number;\n    private routerSub?: any;\n\n    ngOnInit(): void {\n        if (this.hotelBrand?.src) {\n            this.cssLogoUrl = `url(\"${this.hotelBrand.src}\")`;\n        }\n        if (this.backgroundImg?.src) {\n            this.cssBgUrl = `url(\"${this.backgroundImg.src}\")`;\n        }\n\n        if (isPlatformBrowser(this.platformId)) {\n            // Inicializar estado sticky\n            this.updateStickyState();\n\n            // 👁️ Observer para cambios de clase en el body\n            this.observer = new MutationObserver(() =>\n                this.updateStickyState()\n            );\n            this.observer.observe(document.body, {\n                attributes: true,\n                attributeFilter: ['class'],\n            });\n\n            // 🎯 Listener de scroll\n            this.scrollListener = () => {\n                cancelAnimationFrame(this.rafId!);\n                this.rafId = requestAnimationFrame(() => {\n                    const current = this.checkStickyClasses();\n                    if (this.hasStickyClasses() !== current) {\n                        this.hasStickyClasses.set(current);\n                    }\n                });\n            };\n            window.addEventListener('scroll', this.scrollListener, {\n                passive: true,\n            });\n        }\n    }\n\n    ngOnDestroy(): void {\n        this.observer?.disconnect();\n        if (this.scrollListener)\n            window.removeEventListener('scroll', this.scrollListener);\n        if (this.rafId) cancelAnimationFrame(this.rafId);\n    }\n\n    private updateStickyState(): void {\n        const current = this.checkStickyClasses();\n        if (this.hasStickyClasses() !== current) {\n            this.hasStickyClasses.set(current);\n        }\n    }\n\n    private checkStickyClasses(): boolean {\n        const body = document.body.classList;\n        return body.contains('nav-sticky') && body.contains('mobile-sticky');\n    }\n\n    clickBtnBook(): void {\n        this.btnClick.emit();\n        switch (this.siteId) {\n            case this.SITE_GROUP:\n                break;\n            case this.SITE_HOTELS:\n                this.activeModalDtv.handleClick();\n                break;\n            case this.SITE_BEACH:\n                break;\n            default:\n                break;\n        }\n    }\n\n    get showHeaderBookButton(): boolean {\n        if (!this.btnBook) return false;\n\n        // Site 1 → solo restaurantes\n        if (this.siteId === 1) {\n            return this.isRestaurant === true;\n        }\n\n        return true;\n    }\n}\n","<header \n    class=\"header\" \n    navSticky \n    [isDynamic]=\"isDynamic\" \n    [class.header--no-reserver]=\"!showHeaderBookButton\"\n>\n    <div class=\"banner__logo\">\n        <a\n            [href]=\"navLinks?.[0]?.url\"\n            [linkType]=\"navLinks?.[0]?.linkType\"\n            aria-label=\"Saulo logo\"\n        >\n        @if (logoHotel && logoHotelWhite) {\n            <img\n                    [ngSrc]=\"hasStickyClasses() ? logoHotel : logoHotelWhite\"\n                    alt=\"Logo\"\n                    width=\"177\"\n                    height=\"68\"\n                    class=\"banner__logo--img restaurant\"\n                    priority\n                />\n        } @else {\n            <svg\n                aria-hidden=\"true\"\n                width=\"177\"\n                height=\"68\"\n                focusable=\"false\"\n                class=\"banner__logo--img\"\n            >\n                @if (siteId === SITE_HOTELS) {\n                    <use href=\"#puro-logo\" class=\"purohotels\"></use>\n                }\n                @if (siteId === SITE_BEACH) {\n                    <use href=\"#purobeach-logo\" class=\"purobeach\"></use>\n                }\n                @if (siteId === SITE_GROUP) {\n                    <use href=\"#purogroup-logo\" class=\"purogroup\"></use>\n                }\n            </svg>\n        }\n        </a>\n    </div>\n    <div class=\"header__leftNav\">\n        <div\n            class=\"header__menu js-active-modal\"\n            activeModal\n            data-modal_name=\"navigation\"\n            role=\"button\"\n            [attr.aria-label]=\"titleMenu ?? 'Menu'\"\n        >\n            <i class=\"icon-83\"></i>\n            @if (titleMenu) {\n                <span>{{ titleMenu }}</span>\n            }\n        </div>\n        <div\n            class=\"header__language js-active-modal\"\n            activeModal\n            data-modal_name=\"language\"\n            role=\"button\"\n            [attr.aria-label]=\"titleLang ?? 'Language Menu'\"\n        >\n            @if (titleLang) {\n                {{ titleLang }}\n            }\n        </div>\n    </div>\n    @if (showHeaderBookButton) {\n        <a\n            (click)=\"btnClick.emit()\"\n            class=\"header__reserver\"\n            role=\"button\"\n            [attr.aria-label]=\"btnBook\"\n        >\n            <div class=\"btn btn__primary btn--lg\">\n                <span>{{ btnBook }}</span>\n            </div>\n        </a>\n    }\n</header>\n\n<div class=\"modal modal--solidCream modal--navigation\">\n    <div class=\"modal__inner\">\n        <div class=\"modal__body\" [style.--bg-url]=\"cssBgUrl\" [style.--logo-url]=\"cssLogoUrl\">\n            <div\n                class=\"modal__close js-close\"\n                activeModal\n                data-modal_name=\"navigation\"\n                role=\"button\"\n                aria-label=\"Close Button\"\n            >\n                <svg\n                    aria-hidden=\"true\"\n                    focusable=\"false\"\n                    class=\"modal__close--icon\"\n                >\n                    <use href=\"#modal-close\"></use>\n                </svg>\n            </div>\n            <div class=\"modal__nav\">\n                <ul class=\"modal__nav--items\">\n                    @if (navLinks) {\n                        @for (link of navLinks; track $index) {\n                            <li class=\"modal__nav--link\">\n                                <a\n                                    class=\"js-close\"\n                                    activeModal\n                                    data-modal_name=\"navigation\"\n                                    [href]=\"link.url\"\n                                    [linkType]=\"link.linkType\"\n                                    [attr.aria-label]=\"link.label\"\n                                >\n                                    {{ link.label }}\n                                </a>\n                            </li>\n                        }\n                    }\n                </ul>\n                <ul class=\"modal__nav--itemsSmall\">\n                    @if (bottomLinks) {\n                        @for (link of bottomLinks; track $index) {\n                            @if (link.url === 'lang') {\n                                <li\n                                    class=\"modal__nav--link js-active-modal\"\n                                    activeModal\n                                    data-modal_name=\"language\"\n                                    role=\"button\"\n                                    [attr.aria-label]=\"\n                                        link.label ?? 'Language Menu'\n                                    \"\n                                >\n                                    <a>\n                                        {{ link.label }}\n                                    </a>\n                                </li>\n                            } @else {\n                                <li class=\"modal__nav--link\">\n                                    <a\n                                        class=\"js-close\"\n                                        activeModal\n                                        data-modal_name=\"navigation\"\n                                        [href]=\"link.url\"\n                                        [linkType]=\"link.linkType\"\n                                        [attr.aria-label]=\"link.label\"\n                                    >\n                                        {{ link.label }}\n                                    </a>\n                                </li>\n                            }\n                        }\n                    }\n                </ul>\n            </div>\n        </div>\n    </div>\n</div>\n"]}
136
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"puro-header-mobile.component.js","sourceRoot":"","sources":["../../../../../../projects/puro/src/lib/components/puro-header-mobile/puro-header-mobile.component.ts","../../../../../../projects/puro/src/lib/components/puro-header-mobile/puro-header-mobile.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    CommonModule,\n    isPlatformBrowser,\n    NgOptimizedImage,\n} from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    EventEmitter,\n    Input,\n    Output,\n    PLATFORM_ID,\n    inject,\n    OnInit,\n    OnDestroy,\n    signal,\n} from '@angular/core';\nimport { NavigationEnd, Router } from '@angular/router';\nimport { filter } from 'rxjs';\nimport {\n    PuroActiveModalDirective,\n    PuroLinkTypeDirective,\n} from '../../directives';\nimport { PuroNavStickyDirective } from '../../directives/puro-nav-sticky/puro-nav-sticky.directive';\nimport { PuroButtonI, PuroImageI } from '../../interfaces';\n\n@Component({\n    selector: 'lib-puro-header-mobile',\n    standalone: true,\n    imports: [\n        CommonModule,\n        PuroLinkTypeDirective,\n        PuroActiveModalDirective,\n        PuroNavStickyDirective,\n        NgOptimizedImage,\n    ],\n    templateUrl: './puro-header-mobile.component.html',\n    styleUrl: './puro-header-mobile.component.scss',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [PuroActiveModalDirective],\n})\nexport class PuroHeaderMobileComponent implements OnInit, OnDestroy {\n    private activeModalDtv = inject(PuroActiveModalDirective);\n    private platformId = inject(PLATFORM_ID);\n    private router = inject(Router);\n\n    @Input() titleMenu?: string;\n    @Input() titleLang?: string;\n    @Input() btnBook?: string;\n    @Input() navLinks?: PuroButtonI[];\n    @Input() bottomLinks?: PuroButtonI[];\n    @Input() isDynamic = false;\n    @Input() hotelBrand?: PuroImageI;\n    @Input() backgroundImg?: PuroImageI;\n    @Input() logoHotel?: string;\n    @Input() logoHotelWhite?: string;\n    @Input() isRestaurant?: boolean;\n    @Input() siteId?:\n        | typeof this.SITE_GROUP\n        | typeof this.SITE_BEACH\n        | typeof this.SITE_HOTELS;\n\n    @Output() btnClick = new EventEmitter();\n\n    readonly SITE_GROUP = 1;\n    readonly SITE_HOTELS = 2;\n    readonly SITE_BEACH = 3;\n    readonly HIDE_RESTAURANT_BUTTONS = true; // ⚠️ PROVISIONAL\n\n    cssBgUrl = '';\n    cssLogoUrl = '';\n\n    // 👁️ Signal reactivo que indica si el body tiene las clases sticky\n    hasStickyClasses = signal(false);\n\n    private observer?: MutationObserver;\n    private scrollListener?: () => void;\n    private rafId?: number;\n    private routerSub?: any;\n\n    ngOnInit(): void {\n        if (this.hotelBrand?.src) {\n            this.cssLogoUrl = `url(\"${this.hotelBrand.src}\")`;\n        }\n        if (this.backgroundImg?.src) {\n            this.cssBgUrl = `url(\"${this.backgroundImg.src}\")`;\n        }\n\n        if (isPlatformBrowser(this.platformId)) {\n            // Inicializar estado sticky\n            this.updateStickyState();\n\n            // 👁️ Observer para cambios de clase en el body\n            this.observer = new MutationObserver(() =>\n                this.updateStickyState()\n            );\n            this.observer.observe(document.body, {\n                attributes: true,\n                attributeFilter: ['class'],\n            });\n\n            // 🎯 Listener de scroll\n            this.scrollListener = () => {\n                cancelAnimationFrame(this.rafId!);\n                this.rafId = requestAnimationFrame(() => {\n                    const current = this.checkStickyClasses();\n                    if (this.hasStickyClasses() !== current) {\n                        this.hasStickyClasses.set(current);\n                    }\n                });\n            };\n            window.addEventListener('scroll', this.scrollListener, {\n                passive: true,\n            });\n        }\n    }\n\n    ngOnDestroy(): void {\n        this.observer?.disconnect();\n        if (this.scrollListener)\n            window.removeEventListener('scroll', this.scrollListener);\n        if (this.rafId) cancelAnimationFrame(this.rafId);\n    }\n\n    private updateStickyState(): void {\n        const current = this.checkStickyClasses();\n        if (this.hasStickyClasses() !== current) {\n            this.hasStickyClasses.set(current);\n        }\n    }\n\n    private checkStickyClasses(): boolean {\n        const body = document.body.classList;\n        return body.contains('nav-sticky') && body.contains('mobile-sticky');\n    }\n\n    clickBtnBook(): void {\n        this.btnClick.emit();\n        switch (this.siteId) {\n            case this.SITE_GROUP:\n                break;\n            case this.SITE_HOTELS:\n                this.activeModalDtv.handleClick();\n                break;\n            case this.SITE_BEACH:\n                break;\n            default:\n                break;\n        }\n    }\n\n    get showHeaderBookButton(): boolean {\n        if (!this.btnBook) return false;\n\n        // Site 1 → nunca botón (coherente con desktop)\n        if (this.siteId === this.SITE_GROUP) return false;\n\n        // ⚠️ PROVISIONAL: ocultar botones en restaurantes\n        if (this.HIDE_RESTAURANT_BUTTONS && this.isRestaurant) {\n            return false;\n        }\n\n        return true;\n    }\n}\n","<header \n    class=\"header\" \n    navSticky \n    [isDynamic]=\"isDynamic\" \n    [class.header--no-reserver]=\"!showHeaderBookButton\"\n>\n    <div class=\"banner__logo\">\n        <a\n            [href]=\"navLinks?.[0]?.url\"\n            [linkType]=\"navLinks?.[0]?.linkType\"\n            aria-label=\"Saulo logo\"\n        >\n        @if (logoHotel && logoHotelWhite) {\n            <img\n                    [ngSrc]=\"hasStickyClasses() ? logoHotel : logoHotelWhite\"\n                    alt=\"Logo\"\n                    width=\"177\"\n                    height=\"68\"\n                    class=\"banner__logo--img restaurant\"\n                    priority\n                />\n        } @else {\n            <svg\n                aria-hidden=\"true\"\n                width=\"177\"\n                height=\"68\"\n                focusable=\"false\"\n                class=\"banner__logo--img\"\n            >\n                @if (siteId === SITE_HOTELS) {\n                    <use href=\"#puro-logo\" class=\"purohotels\"></use>\n                }\n                @if (siteId === SITE_BEACH) {\n                    <use href=\"#purobeach-logo\" class=\"purobeach\"></use>\n                }\n                @if (siteId === SITE_GROUP) {\n                    <use href=\"#purogroup-logo\" class=\"purogroup\"></use>\n                }\n            </svg>\n        }\n        </a>\n    </div>\n    <div class=\"header__leftNav\">\n        <div\n            class=\"header__menu js-active-modal\"\n            activeModal\n            data-modal_name=\"navigation\"\n            role=\"button\"\n            [attr.aria-label]=\"titleMenu ?? 'Menu'\"\n        >\n            <i class=\"icon-83\"></i>\n            @if (titleMenu) {\n                <span>{{ titleMenu }}</span>\n            }\n        </div>\n        <div\n            class=\"header__language js-active-modal\"\n            activeModal\n            data-modal_name=\"language\"\n            role=\"button\"\n            [attr.aria-label]=\"titleLang ?? 'Language Menu'\"\n        >\n            @if (titleLang) {\n                {{ titleLang }}\n            }\n        </div>\n    </div>\n    @if (showHeaderBookButton) {\n        <a\n            (click)=\"btnClick.emit()\"\n            class=\"header__reserver\"\n            role=\"button\"\n            [attr.aria-label]=\"btnBook\"\n        >\n            <div class=\"btn btn__primary btn--lg\">\n                <span>{{ btnBook }}</span>\n            </div>\n        </a>\n    }\n</header>\n\n<div class=\"modal modal--solidCream modal--navigation\">\n    <div class=\"modal__inner\">\n        <div class=\"modal__body\" [style.--bg-url]=\"cssBgUrl\" [style.--logo-url]=\"cssLogoUrl\">\n            <div\n                class=\"modal__close js-close\"\n                activeModal\n                data-modal_name=\"navigation\"\n                role=\"button\"\n                aria-label=\"Close Button\"\n            >\n                <svg\n                    aria-hidden=\"true\"\n                    focusable=\"false\"\n                    class=\"modal__close--icon\"\n                >\n                    <use href=\"#modal-close\"></use>\n                </svg>\n            </div>\n            <div class=\"modal__nav\">\n                <ul class=\"modal__nav--items\">\n                    @if (navLinks) {\n                        @for (link of navLinks; track $index) {\n                            <li class=\"modal__nav--link\">\n                                <a\n                                    class=\"js-close\"\n                                    activeModal\n                                    data-modal_name=\"navigation\"\n                                    [href]=\"link.url\"\n                                    [linkType]=\"link.linkType\"\n                                    [attr.aria-label]=\"link.label\"\n                                >\n                                    {{ link.label }}\n                                </a>\n                            </li>\n                        }\n                    }\n                </ul>\n                <ul class=\"modal__nav--itemsSmall\">\n                    @if (bottomLinks) {\n                        @for (link of bottomLinks; track $index) {\n                            @if (link.url === 'lang') {\n                                <li\n                                    class=\"modal__nav--link js-active-modal\"\n                                    activeModal\n                                    data-modal_name=\"language\"\n                                    role=\"button\"\n                                    [attr.aria-label]=\"\n                                        link.label ?? 'Language Menu'\n                                    \"\n                                >\n                                    <a>\n                                        {{ link.label }}\n                                    </a>\n                                </li>\n                            } @else {\n                                <li class=\"modal__nav--link\">\n                                    <a\n                                        class=\"js-close\"\n                                        activeModal\n                                        data-modal_name=\"navigation\"\n                                        [href]=\"link.url\"\n                                        [linkType]=\"link.linkType\"\n                                        [attr.aria-label]=\"link.label\"\n                                    >\n                                        {{ link.label }}\n                                    </a>\n                                </li>\n                            }\n                        }\n                    }\n                </ul>\n            </div>\n        </div>\n    </div>\n</div>\n"]}
@@ -5,7 +5,7 @@ import * as i0 from "@angular/core";
5
5
  import * as i1 from "@angular/common";
6
6
  export class PuroInfoSliderComponent {
7
7
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PuroInfoSliderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
8
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: PuroInfoSliderComponent, isStandalone: true, selector: "lib-puro-info-slider", inputs: { items: "items", reverse: "reverse" }, ngImport: i0, template: "<section\n class=\"textPhotoCarousel js-active-slider\"\n [puroSlider]=\"items\"\n [ngClass]=\"{\n 'textPhotoCarousel--right': !reverse,\n }\"\n data-slides_infinite=\"true\"\n data-slider_name=\"js-slider\"\n data-slider_showbtns=\"true\"\n data-slider_showdots=\"false\"\n data-slider_adaptiveheight=\"true\"\n data-slider_fade=\"true\"\n data-slider_autoplay=\"true\"\n data-slides_pc=\"1\"\n resizeZoom\n>\n <div class=\"relative\">\n <div class=\"js-slider js-slider_fix-arrows\">\n @for (item of items; track $index) {\n <div class=\"textPhotoCarousel__item\">\n <div class=\"textPhotoCarousel__image--outer\">\n <div\n class=\"textPhotoCarousel__image js-slider_fix-arrows-zone\"\n >\n @if (item.img) {\n <img\n [ngSrc]=\"item.img.src\"\n [alt]=\"item.img.alt\"\n width=\"960\"\n height=\"807\"\n class=\"textPhotoCarousel__img\"\n decoding=\"async\"\n />\n }\n </div>\n </div>\n <div\n class=\"textPhotoCarousel__content textPhotoCarousel__content--alignCenter\"\n >\n <div>\n @if (item.pretitle) {\n <span\n class=\"textPhotoCarousel__title photos\"\n [innerHTML]=\"item.pretitle\"\n ></span>\n }\n @if (item.title) {\n <h2\n class=\"textPhotoCarousel__heading photo\" \n [innerHTML]=\"item.title\"\n ></h2>\n }\n @if (item.subtitle) {\n <p\n class=\"textPhotoCarousel__subHeading photo\"\n [innerHTML]=\"item.subtitle\"\n ></p>\n }\n @if (item.description) {\n <div>\n <p\n class=\"textPhotoCarousel__paragraph\"\n [innerHTML]=\"item.description\"\n ></p>\n </div>\n }\n <div class=\"btn__group\">\n @if (item.buttons?.length) {\n @for (\n button of item.buttons;\n track $index\n ) {\n <a\n [href]=\"button.url\"\n [linkType]=\"button.linkType\"\n class=\"btn\"\n [ngClass]=\"{\n 'btn__primary--outline': $even,\n btn__primary: $odd,\n }\"\n [attr.aria-label]=\"button.label\"\n >\n <span>{{ button.label }}</span>\n </a>\n }\n }\n </div>\n </div>\n </div>\n </div>\n }\n </div>\n <div class=\"js-slider-arrows\"></div>\n </div>\n</section>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: PuroLinkTypeDirective, selector: "[linkType]", inputs: ["linkType", "href", "modalClick"], outputs: ["bookClick", "anchorClicked"] }, { kind: "directive", type: PuroSliderDirective, selector: "[puroSlider]", inputs: ["puroSlider"] }, { kind: "directive", type: NgOptimizedImage, selector: "img[ngSrc]", inputs: ["ngSrc", "ngSrcset", "sizes", "width", "height", "loading", "priority", "loaderParams", "disableOptimizedSrcset", "fill", "placeholder", "placeholderConfig", "src", "srcset"] }, { kind: "directive", type: AutoImageZoomWrapperDirective, selector: "img[ngSrc], img[src]" }, { kind: "directive", type: PuroResizeZoomDirective, selector: "[resizeZoom]" }] }); }
8
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: PuroInfoSliderComponent, isStandalone: true, selector: "lib-puro-info-slider", inputs: { items: "items", reverse: "reverse" }, ngImport: i0, template: "<section\n class=\"textPhotoCarousel js-active-slider\"\n [puroSlider]=\"items\"\n [ngClass]=\"{\n 'textPhotoCarousel--right': !reverse,\n }\"\n data-slides_infinite=\"true\"\n data-slider_name=\"js-slider\"\n data-slider_showbtns=\"true\"\n data-slider_showdots=\"false\"\n data-slider_adaptiveheight=\"true\"\n data-slider_fade=\"true\"\n data-slider_autoplay=\"true\"\n data-slides_pc=\"1\"\n resizeZoom\n>\n <div class=\"relative\">\n <div class=\"js-slider js-slider_fix-arrows\">\n @for (item of items; track $index) {\n <div class=\"textPhotoCarousel__item\">\n <div class=\"textPhotoCarousel__image--outer\">\n <div\n class=\"textPhotoCarousel__image js-slider_fix-arrows-zone\"\n >\n @if (item.img) {\n <img\n [ngSrc]=\"item.img.src\"\n [alt]=\"item.img.alt\"\n width=\"960\"\n height=\"807\"\n class=\"textPhotoCarousel__img\"\n decoding=\"async\"\n />\n }\n </div>\n </div>\n <div\n class=\"textPhotoCarousel__content textPhotoCarousel__content--alignCenter\"\n >\n <div>\n @if (item.pretitle) {\n <span\n class=\"textPhotoCarousel__title \"\n [innerHTML]=\"item.pretitle\"\n ></span>\n }\n @if (item.title) {\n <h2\n class=\"textPhotoCarousel__heading \" \n [innerHTML]=\"item.title\"\n ></h2>\n }\n @if (item.subtitle) {\n <p\n class=\"textPhotoCarousel__subHeading \"\n [innerHTML]=\"item.subtitle\"\n ></p>\n }\n @if (item.description) {\n <div>\n <p\n class=\"textPhotoCarousel__paragraph\"\n [innerHTML]=\"item.description\"\n ></p>\n </div>\n }\n <div class=\"btn__group\">\n @if (item.buttons?.length) {\n @for (\n button of item.buttons;\n track $index\n ) {\n <a\n [href]=\"button.url\"\n [linkType]=\"button.linkType\"\n class=\"btn\"\n [ngClass]=\"{\n 'btn__primary--outline': $even,\n btn__primary: $odd,\n }\"\n [attr.aria-label]=\"button.label\"\n >\n <span>{{ button.label }}</span>\n </a>\n }\n }\n </div>\n </div>\n </div>\n </div>\n }\n </div>\n <div class=\"js-slider-arrows\"></div>\n </div>\n</section>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: PuroLinkTypeDirective, selector: "[linkType]", inputs: ["linkType", "href", "modalClick"], outputs: ["bookClick", "anchorClicked"] }, { kind: "directive", type: PuroSliderDirective, selector: "[puroSlider]", inputs: ["puroSlider"] }, { kind: "directive", type: NgOptimizedImage, selector: "img[ngSrc]", inputs: ["ngSrc", "ngSrcset", "sizes", "width", "height", "loading", "priority", "loaderParams", "disableOptimizedSrcset", "fill", "placeholder", "placeholderConfig", "src", "srcset"] }, { kind: "directive", type: AutoImageZoomWrapperDirective, selector: "img[ngSrc], img[src]" }, { kind: "directive", type: PuroResizeZoomDirective, selector: "[resizeZoom]" }] }); }
9
9
  }
10
10
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PuroInfoSliderComponent, decorators: [{
11
11
  type: Component,
@@ -17,10 +17,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
17
17
  AutoImageZoomWrapperDirective,
18
18
  PuroResizeZoomDirective,
19
19
  PuroResizeZoomDirective,
20
- ], template: "<section\n class=\"textPhotoCarousel js-active-slider\"\n [puroSlider]=\"items\"\n [ngClass]=\"{\n 'textPhotoCarousel--right': !reverse,\n }\"\n data-slides_infinite=\"true\"\n data-slider_name=\"js-slider\"\n data-slider_showbtns=\"true\"\n data-slider_showdots=\"false\"\n data-slider_adaptiveheight=\"true\"\n data-slider_fade=\"true\"\n data-slider_autoplay=\"true\"\n data-slides_pc=\"1\"\n resizeZoom\n>\n <div class=\"relative\">\n <div class=\"js-slider js-slider_fix-arrows\">\n @for (item of items; track $index) {\n <div class=\"textPhotoCarousel__item\">\n <div class=\"textPhotoCarousel__image--outer\">\n <div\n class=\"textPhotoCarousel__image js-slider_fix-arrows-zone\"\n >\n @if (item.img) {\n <img\n [ngSrc]=\"item.img.src\"\n [alt]=\"item.img.alt\"\n width=\"960\"\n height=\"807\"\n class=\"textPhotoCarousel__img\"\n decoding=\"async\"\n />\n }\n </div>\n </div>\n <div\n class=\"textPhotoCarousel__content textPhotoCarousel__content--alignCenter\"\n >\n <div>\n @if (item.pretitle) {\n <span\n class=\"textPhotoCarousel__title photos\"\n [innerHTML]=\"item.pretitle\"\n ></span>\n }\n @if (item.title) {\n <h2\n class=\"textPhotoCarousel__heading photo\" \n [innerHTML]=\"item.title\"\n ></h2>\n }\n @if (item.subtitle) {\n <p\n class=\"textPhotoCarousel__subHeading photo\"\n [innerHTML]=\"item.subtitle\"\n ></p>\n }\n @if (item.description) {\n <div>\n <p\n class=\"textPhotoCarousel__paragraph\"\n [innerHTML]=\"item.description\"\n ></p>\n </div>\n }\n <div class=\"btn__group\">\n @if (item.buttons?.length) {\n @for (\n button of item.buttons;\n track $index\n ) {\n <a\n [href]=\"button.url\"\n [linkType]=\"button.linkType\"\n class=\"btn\"\n [ngClass]=\"{\n 'btn__primary--outline': $even,\n btn__primary: $odd,\n }\"\n [attr.aria-label]=\"button.label\"\n >\n <span>{{ button.label }}</span>\n </a>\n }\n }\n </div>\n </div>\n </div>\n </div>\n }\n </div>\n <div class=\"js-slider-arrows\"></div>\n </div>\n</section>\n" }]
20
+ ], template: "<section\n class=\"textPhotoCarousel js-active-slider\"\n [puroSlider]=\"items\"\n [ngClass]=\"{\n 'textPhotoCarousel--right': !reverse,\n }\"\n data-slides_infinite=\"true\"\n data-slider_name=\"js-slider\"\n data-slider_showbtns=\"true\"\n data-slider_showdots=\"false\"\n data-slider_adaptiveheight=\"true\"\n data-slider_fade=\"true\"\n data-slider_autoplay=\"true\"\n data-slides_pc=\"1\"\n resizeZoom\n>\n <div class=\"relative\">\n <div class=\"js-slider js-slider_fix-arrows\">\n @for (item of items; track $index) {\n <div class=\"textPhotoCarousel__item\">\n <div class=\"textPhotoCarousel__image--outer\">\n <div\n class=\"textPhotoCarousel__image js-slider_fix-arrows-zone\"\n >\n @if (item.img) {\n <img\n [ngSrc]=\"item.img.src\"\n [alt]=\"item.img.alt\"\n width=\"960\"\n height=\"807\"\n class=\"textPhotoCarousel__img\"\n decoding=\"async\"\n />\n }\n </div>\n </div>\n <div\n class=\"textPhotoCarousel__content textPhotoCarousel__content--alignCenter\"\n >\n <div>\n @if (item.pretitle) {\n <span\n class=\"textPhotoCarousel__title \"\n [innerHTML]=\"item.pretitle\"\n ></span>\n }\n @if (item.title) {\n <h2\n class=\"textPhotoCarousel__heading \" \n [innerHTML]=\"item.title\"\n ></h2>\n }\n @if (item.subtitle) {\n <p\n class=\"textPhotoCarousel__subHeading \"\n [innerHTML]=\"item.subtitle\"\n ></p>\n }\n @if (item.description) {\n <div>\n <p\n class=\"textPhotoCarousel__paragraph\"\n [innerHTML]=\"item.description\"\n ></p>\n </div>\n }\n <div class=\"btn__group\">\n @if (item.buttons?.length) {\n @for (\n button of item.buttons;\n track $index\n ) {\n <a\n [href]=\"button.url\"\n [linkType]=\"button.linkType\"\n class=\"btn\"\n [ngClass]=\"{\n 'btn__primary--outline': $even,\n btn__primary: $odd,\n }\"\n [attr.aria-label]=\"button.label\"\n >\n <span>{{ button.label }}</span>\n </a>\n }\n }\n </div>\n </div>\n </div>\n </div>\n }\n </div>\n <div class=\"js-slider-arrows\"></div>\n </div>\n</section>\n" }]
21
21
  }], propDecorators: { items: [{
22
22
  type: Input
23
23
  }], reverse: [{
24
24
  type: Input
25
25
  }] } });
26
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"puro-info-slider.component.js","sourceRoot":"","sources":["../../../../../../projects/puro/src/lib/components/puro-info-slider/puro-info-slider.component.ts","../../../../../../projects/puro/src/lib/components/puro-info-slider/puro-info-slider.component.html"],"names":[],"mappings":"AAAA,OAAO,EACH,YAAY,EACZ,gBAAgB,GACnB,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AACjD,OAAO,EACH,6BAA6B,EAC7B,qBAAqB,EACrB,uBAAuB,EACvB,mBAAmB,GACtB,MAAM,kBAAkB,CAAC;;;AAkB1B,MAAM,OAAO,uBAAuB;+GAAvB,uBAAuB;mGAAvB,uBAAuB,gIC5BpC,4sIA+FA,yDD9EQ,YAAY,6HACZ,qBAAqB,4IACrB,mBAAmB,iFACnB,gBAAgB,gPAChB,6BAA6B,iEAC7B,uBAAuB;;4FAMlB,uBAAuB;kBAfnC,SAAS;+BACI,sBAAsB,cACpB,IAAI,WACP;wBACL,YAAY;wBACZ,qBAAqB;wBACrB,mBAAmB;wBACnB,gBAAgB;wBAChB,6BAA6B;wBAC7B,uBAAuB;wBACvB,uBAAuB;qBAC1B;8BAKQ,KAAK;sBAAb,KAAK;gBACG,OAAO;sBAAf,KAAK","sourcesContent":["import {\n    CommonModule,\n    NgOptimizedImage,\n} from '@angular/common';\nimport { Component, Input } from '@angular/core';\nimport {\n    AutoImageZoomWrapperDirective,\n    PuroLinkTypeDirective,\n    PuroResizeZoomDirective,\n    PuroSliderDirective,\n} from '../../directives';\nimport { PuroButtonI, PuroImageI } from '../../interfaces';\n\n@Component({\n    selector: 'lib-puro-info-slider',\n    standalone: true,\n    imports: [\n        CommonModule,\n        PuroLinkTypeDirective,\n        PuroSliderDirective,\n        NgOptimizedImage,\n        AutoImageZoomWrapperDirective,\n        PuroResizeZoomDirective,\n        PuroResizeZoomDirective,\n    ],\n    templateUrl: './puro-info-slider.component.html',\n    styleUrl: './puro-info-slider.component.scss',\n})\nexport class PuroInfoSliderComponent {\n    @Input() items?: PuroInfoSliderItem[];\n    @Input() reverse?: boolean;\n}\n\nexport interface PuroInfoSliderItem {\n    pretitle?: string;\n    title?: string;\n    subtitle?: string;\n    description?: string;\n    img?: PuroImageI;\n    buttons?: PuroButtonI[];\n}\n","<section\n    class=\"textPhotoCarousel js-active-slider\"\n    [puroSlider]=\"items\"\n    [ngClass]=\"{\n        'textPhotoCarousel--right': !reverse,\n    }\"\n    data-slides_infinite=\"true\"\n    data-slider_name=\"js-slider\"\n    data-slider_showbtns=\"true\"\n    data-slider_showdots=\"false\"\n    data-slider_adaptiveheight=\"true\"\n    data-slider_fade=\"true\"\n    data-slider_autoplay=\"true\"\n    data-slides_pc=\"1\"\n    resizeZoom\n>\n    <div class=\"relative\">\n        <div class=\"js-slider js-slider_fix-arrows\">\n            @for (item of items; track $index) {\n                <div class=\"textPhotoCarousel__item\">\n                    <div class=\"textPhotoCarousel__image--outer\">\n                        <div\n                            class=\"textPhotoCarousel__image js-slider_fix-arrows-zone\"\n                        >\n                            @if (item.img) {\n                                <img\n                                    [ngSrc]=\"item.img.src\"\n                                    [alt]=\"item.img.alt\"\n                                    width=\"960\"\n                                    height=\"807\"\n                                    class=\"textPhotoCarousel__img\"\n                                    decoding=\"async\"\n                                />\n                            }\n                        </div>\n                    </div>\n                    <div\n                        class=\"textPhotoCarousel__content textPhotoCarousel__content--alignCenter\"\n                    >\n                        <div>\n                            @if (item.pretitle) {\n                                <span\n                                    class=\"textPhotoCarousel__title photos\"\n                                    [innerHTML]=\"item.pretitle\"\n                                ></span>\n                            }\n                            @if (item.title) {\n                                <h2\n                                    class=\"textPhotoCarousel__heading photo\"  \n                                    [innerHTML]=\"item.title\"\n                                ></h2>\n                            }\n                            @if (item.subtitle) {\n                                <p\n                                    class=\"textPhotoCarousel__subHeading photo\"\n                                    [innerHTML]=\"item.subtitle\"\n                                ></p>\n                            }\n                            @if (item.description) {\n                                <div>\n                                    <p\n                                        class=\"textPhotoCarousel__paragraph\"\n                                        [innerHTML]=\"item.description\"\n                                    ></p>\n                                </div>\n                            }\n                            <div class=\"btn__group\">\n                                @if (item.buttons?.length) {\n                                    @for (\n                                        button of item.buttons;\n                                        track $index\n                                    ) {\n                                        <a\n                                            [href]=\"button.url\"\n                                            [linkType]=\"button.linkType\"\n                                            class=\"btn\"\n                                            [ngClass]=\"{\n                                                'btn__primary--outline': $even,\n                                                btn__primary: $odd,\n                                            }\"\n                                            [attr.aria-label]=\"button.label\"\n                                        >\n                                            <span>{{ button.label }}</span>\n                                        </a>\n                                    }\n                                }\n                            </div>\n                        </div>\n                    </div>\n                </div>\n            }\n        </div>\n        <div class=\"js-slider-arrows\"></div>\n    </div>\n</section>\n"]}
26
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"puro-info-slider.component.js","sourceRoot":"","sources":["../../../../../../projects/puro/src/lib/components/puro-info-slider/puro-info-slider.component.ts","../../../../../../projects/puro/src/lib/components/puro-info-slider/puro-info-slider.component.html"],"names":[],"mappings":"AAAA,OAAO,EACH,YAAY,EACZ,gBAAgB,GACnB,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AACjD,OAAO,EACH,6BAA6B,EAC7B,qBAAqB,EACrB,uBAAuB,EACvB,mBAAmB,GACtB,MAAM,kBAAkB,CAAC;;;AAkB1B,MAAM,OAAO,uBAAuB;+GAAvB,uBAAuB;mGAAvB,uBAAuB,gIC5BpC,4rIA+FA,yDD9EQ,YAAY,6HACZ,qBAAqB,4IACrB,mBAAmB,iFACnB,gBAAgB,gPAChB,6BAA6B,iEAC7B,uBAAuB;;4FAMlB,uBAAuB;kBAfnC,SAAS;+BACI,sBAAsB,cACpB,IAAI,WACP;wBACL,YAAY;wBACZ,qBAAqB;wBACrB,mBAAmB;wBACnB,gBAAgB;wBAChB,6BAA6B;wBAC7B,uBAAuB;wBACvB,uBAAuB;qBAC1B;8BAKQ,KAAK;sBAAb,KAAK;gBACG,OAAO;sBAAf,KAAK","sourcesContent":["import {\n    CommonModule,\n    NgOptimizedImage,\n} from '@angular/common';\nimport { Component, Input } from '@angular/core';\nimport {\n    AutoImageZoomWrapperDirective,\n    PuroLinkTypeDirective,\n    PuroResizeZoomDirective,\n    PuroSliderDirective,\n} from '../../directives';\nimport { PuroButtonI, PuroImageI } from '../../interfaces';\n\n@Component({\n    selector: 'lib-puro-info-slider',\n    standalone: true,\n    imports: [\n        CommonModule,\n        PuroLinkTypeDirective,\n        PuroSliderDirective,\n        NgOptimizedImage,\n        AutoImageZoomWrapperDirective,\n        PuroResizeZoomDirective,\n        PuroResizeZoomDirective,\n    ],\n    templateUrl: './puro-info-slider.component.html',\n    styleUrl: './puro-info-slider.component.scss',\n})\nexport class PuroInfoSliderComponent {\n    @Input() items?: PuroInfoSliderItem[];\n    @Input() reverse?: boolean;\n}\n\nexport interface PuroInfoSliderItem {\n    pretitle?: string;\n    title?: string;\n    subtitle?: string;\n    description?: string;\n    img?: PuroImageI;\n    buttons?: PuroButtonI[];\n}\n","<section\n    class=\"textPhotoCarousel js-active-slider\"\n    [puroSlider]=\"items\"\n    [ngClass]=\"{\n        'textPhotoCarousel--right': !reverse,\n    }\"\n    data-slides_infinite=\"true\"\n    data-slider_name=\"js-slider\"\n    data-slider_showbtns=\"true\"\n    data-slider_showdots=\"false\"\n    data-slider_adaptiveheight=\"true\"\n    data-slider_fade=\"true\"\n    data-slider_autoplay=\"true\"\n    data-slides_pc=\"1\"\n    resizeZoom\n>\n    <div class=\"relative\">\n        <div class=\"js-slider js-slider_fix-arrows\">\n            @for (item of items; track $index) {\n                <div class=\"textPhotoCarousel__item\">\n                    <div class=\"textPhotoCarousel__image--outer\">\n                        <div\n                            class=\"textPhotoCarousel__image js-slider_fix-arrows-zone\"\n                        >\n                            @if (item.img) {\n                                <img\n                                    [ngSrc]=\"item.img.src\"\n                                    [alt]=\"item.img.alt\"\n                                    width=\"960\"\n                                    height=\"807\"\n                                    class=\"textPhotoCarousel__img\"\n                                    decoding=\"async\"\n                                />\n                            }\n                        </div>\n                    </div>\n                    <div\n                        class=\"textPhotoCarousel__content textPhotoCarousel__content--alignCenter\"\n                    >\n                        <div>\n                            @if (item.pretitle) {\n                                <span\n                                    class=\"textPhotoCarousel__title \"\n                                    [innerHTML]=\"item.pretitle\"\n                                ></span>\n                            }\n                            @if (item.title) {\n                                <h2\n                                    class=\"textPhotoCarousel__heading \"  \n                                    [innerHTML]=\"item.title\"\n                                ></h2>\n                            }\n                            @if (item.subtitle) {\n                                <p\n                                    class=\"textPhotoCarousel__subHeading \"\n                                    [innerHTML]=\"item.subtitle\"\n                                ></p>\n                            }\n                            @if (item.description) {\n                                <div>\n                                    <p\n                                        class=\"textPhotoCarousel__paragraph\"\n                                        [innerHTML]=\"item.description\"\n                                    ></p>\n                                </div>\n                            }\n                            <div class=\"btn__group\">\n                                @if (item.buttons?.length) {\n                                    @for (\n                                        button of item.buttons;\n                                        track $index\n                                    ) {\n                                        <a\n                                            [href]=\"button.url\"\n                                            [linkType]=\"button.linkType\"\n                                            class=\"btn\"\n                                            [ngClass]=\"{\n                                                'btn__primary--outline': $even,\n                                                btn__primary: $odd,\n                                            }\"\n                                            [attr.aria-label]=\"button.label\"\n                                        >\n                                            <span>{{ button.label }}</span>\n                                        </a>\n                                    }\n                                }\n                            </div>\n                        </div>\n                    </div>\n                </div>\n            }\n        </div>\n        <div class=\"js-slider-arrows\"></div>\n    </div>\n</section>\n"]}
@@ -4,7 +4,7 @@ import { AutoImageZoomWrapperDirective, PuroLinkTypeDirective, PuroSliderDirecti
4
4
  import * as i0 from "@angular/core";
5
5
  export class PuroPhotoSliderComponent {
6
6
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PuroPhotoSliderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
7
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: PuroPhotoSliderComponent, isStandalone: true, selector: "lib-puro-photo-slider", inputs: { title: "title", subtitle: "subtitle", pretitle: "pretitle", description: "description", button: "button", img: "img", reverse: "reverse" }, ngImport: i0, template: "<section\n class=\"textPhotoCarousel js-active-slider\"\n [puroSlider]=\"img\"\n data-slides_infinite=\"true\"\n data-slider_name=\"js-slider\"\n data-slider_showbtns=\"true\"\n data-slider_showdots=\"false\"\n data-slider_fade=\"true\"\n data-slider_autoplay=\"true\"\n data-slides_pc=\"1\"\n>\n <div class=\"relative\">\n <div class=\"js-slider js-slider_fix-arrows\">\n @for (image of img; track $index) {\n <div class=\"textPhotoCarousel__item\">\n <!-- IMAGEN A LA IZQUIERDA -->\n <div class=\"textPhotoCarousel__image--outer\">\n <div\n class=\"textPhotoCarousel__image js-slider_fix-arrows-zone\"\n >\n <img\n [ngSrc]=\"image.src\"\n [alt]=\"image.alt\"\n class=\"textPhotoCarousel__img\"\n width=\"960\"\n height=\"807\"\n />\n </div>\n </div>\n\n <!-- TEXTO A LA DERECHA -->\n <div\n class=\"textPhotoCarousel__content textPhotoCarousel__content--alignCenter\"\n >\n <div>\n @if (pretitle) {\n <span\n class=\"textPhotoCarousel__title photos\"\n [innerHTML]=\"pretitle\"\n ></span>\n }\n\n @if (title) {\n <h2\n class=\"textPhotoCarousel__heading photo\"\n [innerHTML]=\"title\"\n ></h2>\n }\n\n @if (subtitle) {\n <p\n class=\"textPhotoCarousel__subHeading photo\"\n [innerHTML]=\"subtitle\"\n ></p>\n }\n\n @if (description) {\n <p\n class=\"textPhotoCarousel__paragraph\"\n [innerHTML]=\"description\"\n ></p>\n }\n @if (button) {\n <div class=\"btn__group\">\n <a\n [href]=\"button.url\"\n [linkType]=\"button.linkType\"\n class=\"btn btn__primary--outline\"\n [attr.aria-label]=\"button.label\"\n >{{ button.label }}</a\n >\n </div>\n }\n </div>\n </div>\n </div>\n }\n </div>\n\n <div class=\"js-slider-arrows photoslider\"></div>\n </div>\n</section>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: PuroLinkTypeDirective, selector: "[linkType]", inputs: ["linkType", "href", "modalClick"], outputs: ["bookClick", "anchorClicked"] }, { kind: "directive", type: PuroSliderDirective, selector: "[puroSlider]", inputs: ["puroSlider"] }, { kind: "directive", type: NgOptimizedImage, selector: "img[ngSrc]", inputs: ["ngSrc", "ngSrcset", "sizes", "width", "height", "loading", "priority", "loaderParams", "disableOptimizedSrcset", "fill", "placeholder", "placeholderConfig", "src", "srcset"] }, { kind: "directive", type: AutoImageZoomWrapperDirective, selector: "img[ngSrc], img[src]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
7
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: PuroPhotoSliderComponent, isStandalone: true, selector: "lib-puro-photo-slider", inputs: { title: "title", subtitle: "subtitle", pretitle: "pretitle", description: "description", button: "button", img: "img", reverse: "reverse" }, ngImport: i0, template: "<section\n class=\"textPhotoCarousel js-active-slider\"\n [puroSlider]=\"img\"\n data-slides_infinite=\"true\"\n data-slider_name=\"js-slider\"\n data-slider_showbtns=\"true\"\n data-slider_showdots=\"false\"\n data-slider_fade=\"true\"\n data-slider_autoplay=\"true\"\n data-slides_pc=\"1\"\n>\n <div class=\"relative\">\n <div class=\"js-slider js-slider_fix-arrows\">\n @for (image of img; track $index) {\n <div class=\"textPhotoCarousel__item\">\n <!-- IMAGEN A LA IZQUIERDA -->\n <div class=\"textPhotoCarousel__image--outer\">\n <div\n class=\"textPhotoCarousel__image js-slider_fix-arrows-zone\"\n >\n <img\n [ngSrc]=\"image.src\"\n [alt]=\"image.alt\"\n class=\"textPhotoCarousel__img\"\n width=\"960\"\n height=\"807\"\n />\n </div>\n </div>\n\n <!-- TEXTO A LA DERECHA -->\n <div\n class=\"textPhotoCarousel__content textPhotoCarousel__content--alignCenter\"\n >\n <div>\n @if (pretitle) {\n <span\n class=\"textPhotoCarousel__title\"\n [innerHTML]=\"pretitle\"\n ></span>\n }\n\n @if (title) {\n <h2\n class=\"textPhotoCarousel__heading\"\n [innerHTML]=\"title\"\n ></h2>\n }\n\n @if (subtitle) {\n <p\n class=\"textPhotoCarousel__subHeading\"\n [innerHTML]=\"subtitle\"\n ></p>\n }\n\n @if (description) {\n <p\n class=\"textPhotoCarousel__paragraph\"\n [innerHTML]=\"description\"\n ></p>\n }\n @if (button) {\n <div class=\"btn__group\">\n <a\n [href]=\"button.url\"\n [linkType]=\"button.linkType\"\n class=\"btn btn__primary--outline\"\n [attr.aria-label]=\"button.label\"\n >{{ button.label }}</a\n >\n </div>\n }\n </div>\n </div>\n </div>\n }\n </div>\n\n <div class=\"js-slider-arrows photoslider\"></div>\n </div>\n</section>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: PuroLinkTypeDirective, selector: "[linkType]", inputs: ["linkType", "href", "modalClick"], outputs: ["bookClick", "anchorClicked"] }, { kind: "directive", type: PuroSliderDirective, selector: "[puroSlider]", inputs: ["puroSlider"] }, { kind: "directive", type: NgOptimizedImage, selector: "img[ngSrc]", inputs: ["ngSrc", "ngSrcset", "sizes", "width", "height", "loading", "priority", "loaderParams", "disableOptimizedSrcset", "fill", "placeholder", "placeholderConfig", "src", "srcset"] }, { kind: "directive", type: AutoImageZoomWrapperDirective, selector: "img[ngSrc], img[src]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
8
8
  }
9
9
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PuroPhotoSliderComponent, decorators: [{
10
10
  type: Component,
@@ -14,7 +14,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
14
14
  PuroSliderDirective,
15
15
  NgOptimizedImage,
16
16
  AutoImageZoomWrapperDirective,
17
- ], changeDetection: ChangeDetectionStrategy.OnPush, template: "<section\n class=\"textPhotoCarousel js-active-slider\"\n [puroSlider]=\"img\"\n data-slides_infinite=\"true\"\n data-slider_name=\"js-slider\"\n data-slider_showbtns=\"true\"\n data-slider_showdots=\"false\"\n data-slider_fade=\"true\"\n data-slider_autoplay=\"true\"\n data-slides_pc=\"1\"\n>\n <div class=\"relative\">\n <div class=\"js-slider js-slider_fix-arrows\">\n @for (image of img; track $index) {\n <div class=\"textPhotoCarousel__item\">\n <!-- IMAGEN A LA IZQUIERDA -->\n <div class=\"textPhotoCarousel__image--outer\">\n <div\n class=\"textPhotoCarousel__image js-slider_fix-arrows-zone\"\n >\n <img\n [ngSrc]=\"image.src\"\n [alt]=\"image.alt\"\n class=\"textPhotoCarousel__img\"\n width=\"960\"\n height=\"807\"\n />\n </div>\n </div>\n\n <!-- TEXTO A LA DERECHA -->\n <div\n class=\"textPhotoCarousel__content textPhotoCarousel__content--alignCenter\"\n >\n <div>\n @if (pretitle) {\n <span\n class=\"textPhotoCarousel__title photos\"\n [innerHTML]=\"pretitle\"\n ></span>\n }\n\n @if (title) {\n <h2\n class=\"textPhotoCarousel__heading photo\"\n [innerHTML]=\"title\"\n ></h2>\n }\n\n @if (subtitle) {\n <p\n class=\"textPhotoCarousel__subHeading photo\"\n [innerHTML]=\"subtitle\"\n ></p>\n }\n\n @if (description) {\n <p\n class=\"textPhotoCarousel__paragraph\"\n [innerHTML]=\"description\"\n ></p>\n }\n @if (button) {\n <div class=\"btn__group\">\n <a\n [href]=\"button.url\"\n [linkType]=\"button.linkType\"\n class=\"btn btn__primary--outline\"\n [attr.aria-label]=\"button.label\"\n >{{ button.label }}</a\n >\n </div>\n }\n </div>\n </div>\n </div>\n }\n </div>\n\n <div class=\"js-slider-arrows photoslider\"></div>\n </div>\n</section>\n" }]
17
+ ], changeDetection: ChangeDetectionStrategy.OnPush, template: "<section\n class=\"textPhotoCarousel js-active-slider\"\n [puroSlider]=\"img\"\n data-slides_infinite=\"true\"\n data-slider_name=\"js-slider\"\n data-slider_showbtns=\"true\"\n data-slider_showdots=\"false\"\n data-slider_fade=\"true\"\n data-slider_autoplay=\"true\"\n data-slides_pc=\"1\"\n>\n <div class=\"relative\">\n <div class=\"js-slider js-slider_fix-arrows\">\n @for (image of img; track $index) {\n <div class=\"textPhotoCarousel__item\">\n <!-- IMAGEN A LA IZQUIERDA -->\n <div class=\"textPhotoCarousel__image--outer\">\n <div\n class=\"textPhotoCarousel__image js-slider_fix-arrows-zone\"\n >\n <img\n [ngSrc]=\"image.src\"\n [alt]=\"image.alt\"\n class=\"textPhotoCarousel__img\"\n width=\"960\"\n height=\"807\"\n />\n </div>\n </div>\n\n <!-- TEXTO A LA DERECHA -->\n <div\n class=\"textPhotoCarousel__content textPhotoCarousel__content--alignCenter\"\n >\n <div>\n @if (pretitle) {\n <span\n class=\"textPhotoCarousel__title\"\n [innerHTML]=\"pretitle\"\n ></span>\n }\n\n @if (title) {\n <h2\n class=\"textPhotoCarousel__heading\"\n [innerHTML]=\"title\"\n ></h2>\n }\n\n @if (subtitle) {\n <p\n class=\"textPhotoCarousel__subHeading\"\n [innerHTML]=\"subtitle\"\n ></p>\n }\n\n @if (description) {\n <p\n class=\"textPhotoCarousel__paragraph\"\n [innerHTML]=\"description\"\n ></p>\n }\n @if (button) {\n <div class=\"btn__group\">\n <a\n [href]=\"button.url\"\n [linkType]=\"button.linkType\"\n class=\"btn btn__primary--outline\"\n [attr.aria-label]=\"button.label\"\n >{{ button.label }}</a\n >\n </div>\n }\n </div>\n </div>\n </div>\n }\n </div>\n\n <div class=\"js-slider-arrows photoslider\"></div>\n </div>\n</section>\n" }]
18
18
  }], propDecorators: { title: [{
19
19
  type: Input
20
20
  }], subtitle: [{
@@ -30,4 +30,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
30
30
  }], reverse: [{
31
31
  type: Input
32
32
  }] } });
33
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVyby1waG90by1zbGlkZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcHVyby9zcmMvbGliL2NvbXBvbmVudHMvcHVyby1waG90by1zbGlkZXIvcHVyby1waG90by1zbGlkZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcHVyby9zcmMvbGliL2NvbXBvbmVudHMvcHVyby1waG90by1zbGlkZXIvcHVyby1waG90by1zbGlkZXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNILFlBQVksRUFDWixnQkFBZ0IsR0FDbkIsTUFBTSxpQkFBaUIsQ0FBQztBQUN6QixPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMxRSxPQUFPLEVBQUUsNkJBQTZCLEVBQUUscUJBQXFCLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQzs7QUFpQjdHLE1BQU0sT0FBTyx3QkFBd0I7K0dBQXhCLHdCQUF3QjttR0FBeEIsd0JBQXdCLHVPQ3RCckMsZzFHQWtGQSx5RER0RVEsWUFBWSwrQkFDWixxQkFBcUIsNElBQ3JCLG1CQUFtQixpRkFDbkIsZ0JBQWdCLGdQQUNoQiw2QkFBNkI7OzRGQU14Qix3QkFBd0I7a0JBZHBDLFNBQVM7K0JBQ0ksdUJBQXVCLGNBQ3JCLElBQUksV0FDUDt3QkFDTCxZQUFZO3dCQUNaLHFCQUFxQjt3QkFDckIsbUJBQW1CO3dCQUNuQixnQkFBZ0I7d0JBQ2hCLDZCQUE2QjtxQkFDaEMsbUJBR2dCLHVCQUF1QixDQUFDLE1BQU07OEJBR3RDLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUNHLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSztnQkFDRyxNQUFNO3NCQUFkLEtBQUs7Z0JBQ0csR0FBRztzQkFBWCxLQUFLO2dCQUNHLE9BQU87c0JBQWYsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIE5nT3B0aW1pemVkSW1hZ2UsXG59IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQXV0b0ltYWdlWm9vbVdyYXBwZXJEaXJlY3RpdmUsIFB1cm9MaW5rVHlwZURpcmVjdGl2ZSwgUHVyb1NsaWRlckRpcmVjdGl2ZSB9IGZyb20gJy4uLy4uL2RpcmVjdGl2ZXMnO1xuaW1wb3J0IHsgUHVyb0J1dHRvbkksIFB1cm9JbWFnZUkgfSBmcm9tICcuLi8uLi9pbnRlcmZhY2VzJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdsaWItcHVyby1waG90by1zbGlkZXInLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaW1wb3J0czogW1xuICAgICAgICBDb21tb25Nb2R1bGUsXG4gICAgICAgIFB1cm9MaW5rVHlwZURpcmVjdGl2ZSxcbiAgICAgICAgUHVyb1NsaWRlckRpcmVjdGl2ZSxcbiAgICAgICAgTmdPcHRpbWl6ZWRJbWFnZSxcbiAgICAgICAgQXV0b0ltYWdlWm9vbVdyYXBwZXJEaXJlY3RpdmUsXG4gICAgXSxcbiAgICB0ZW1wbGF0ZVVybDogJy4vcHVyby1waG90by1zbGlkZXIuY29tcG9uZW50Lmh0bWwnLFxuICAgIHN0eWxlVXJsOiAnLi9wdXJvLXBob3RvLXNsaWRlci5jb21wb25lbnQuc2NzcycsXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG59KVxuZXhwb3J0IGNsYXNzIFB1cm9QaG90b1NsaWRlckNvbXBvbmVudCB7XG4gICAgQElucHV0KCkgdGl0bGU/OiBzdHJpbmc7XG4gICAgQElucHV0KCkgc3VidGl0bGU/OiBzdHJpbmc7XG4gICAgQElucHV0KCkgcHJldGl0bGU/OiBzdHJpbmc7XG4gICAgQElucHV0KCkgZGVzY3JpcHRpb24/OiBzdHJpbmc7XG4gICAgQElucHV0KCkgYnV0dG9uPzogUHVyb0J1dHRvbkk7XG4gICAgQElucHV0KCkgaW1nPzogUHVyb0ltYWdlSVtdO1xuICAgIEBJbnB1dCgpIHJldmVyc2U/OiBib29sZWFuO1xufVxuIiwiPHNlY3Rpb25cbiAgICBjbGFzcz1cInRleHRQaG90b0Nhcm91c2VsIGpzLWFjdGl2ZS1zbGlkZXJcIlxuICAgIFtwdXJvU2xpZGVyXT1cImltZ1wiXG4gICAgZGF0YS1zbGlkZXNfaW5maW5pdGU9XCJ0cnVlXCJcbiAgICBkYXRhLXNsaWRlcl9uYW1lPVwianMtc2xpZGVyXCJcbiAgICBkYXRhLXNsaWRlcl9zaG93YnRucz1cInRydWVcIlxuICAgIGRhdGEtc2xpZGVyX3Nob3dkb3RzPVwiZmFsc2VcIlxuICAgIGRhdGEtc2xpZGVyX2ZhZGU9XCJ0cnVlXCJcbiAgICBkYXRhLXNsaWRlcl9hdXRvcGxheT1cInRydWVcIlxuICAgIGRhdGEtc2xpZGVzX3BjPVwiMVwiXG4+XG4gICAgPGRpdiBjbGFzcz1cInJlbGF0aXZlXCI+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJqcy1zbGlkZXIganMtc2xpZGVyX2ZpeC1hcnJvd3NcIj5cbiAgICAgICAgICAgIEBmb3IgKGltYWdlIG9mIGltZzsgdHJhY2sgJGluZGV4KSB7XG4gICAgICAgICAgICAgICAgPGRpdiBjbGFzcz1cInRleHRQaG90b0Nhcm91c2VsX19pdGVtXCI+XG4gICAgICAgICAgICAgICAgICAgIDwhLS0gSU1BR0VOIEEgTEEgSVpRVUlFUkRBIC0tPlxuICAgICAgICAgICAgICAgICAgICA8ZGl2IGNsYXNzPVwidGV4dFBob3RvQ2Fyb3VzZWxfX2ltYWdlLS1vdXRlclwiPlxuICAgICAgICAgICAgICAgICAgICAgICAgPGRpdlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIGNsYXNzPVwidGV4dFBob3RvQ2Fyb3VzZWxfX2ltYWdlIGpzLXNsaWRlcl9maXgtYXJyb3dzLXpvbmVcIlxuICAgICAgICAgICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIDxpbWdcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgW25nU3JjXT1cImltYWdlLnNyY1wiXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFthbHRdPVwiaW1hZ2UuYWx0XCJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY2xhc3M9XCJ0ZXh0UGhvdG9DYXJvdXNlbF9faW1nXCJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgd2lkdGg9XCI5NjBcIlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBoZWlnaHQ9XCI4MDdcIlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgICAgICAgICAgPC9kaXY+XG5cbiAgICAgICAgICAgICAgICAgICAgPCEtLSBURVhUTyBBIExBIERFUkVDSEEgLS0+XG4gICAgICAgICAgICAgICAgICAgIDxkaXZcbiAgICAgICAgICAgICAgICAgICAgICAgIGNsYXNzPVwidGV4dFBob3RvQ2Fyb3VzZWxfX2NvbnRlbnQgdGV4dFBob3RvQ2Fyb3VzZWxfX2NvbnRlbnQtLWFsaWduQ2VudGVyXCJcbiAgICAgICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAgICAgICAgPGRpdj5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBAaWYgKHByZXRpdGxlKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIDxzcGFuXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBjbGFzcz1cInRleHRQaG90b0Nhcm91c2VsX190aXRsZSBwaG90b3NcIlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgW2lubmVySFRNTF09XCJwcmV0aXRsZVwiXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgID48L3NwYW4+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgQGlmICh0aXRsZSkge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICA8aDJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGNsYXNzPVwidGV4dFBob3RvQ2Fyb3VzZWxfX2hlYWRpbmcgcGhvdG9cIlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgW2lubmVySFRNTF09XCJ0aXRsZVwiXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgID48L2gyPlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIEBpZiAoc3VidGl0bGUpIHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgPHBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGNsYXNzPVwidGV4dFBob3RvQ2Fyb3VzZWxfX3N1YkhlYWRpbmcgcGhvdG9cIlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgW2lubmVySFRNTF09XCJzdWJ0aXRsZVwiXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgID48L3A+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgQGlmIChkZXNjcmlwdGlvbikge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICA8cFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY2xhc3M9XCJ0ZXh0UGhvdG9DYXJvdXNlbF9fcGFyYWdyYXBoXCJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFtpbm5lckhUTUxdPVwiZGVzY3JpcHRpb25cIlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICA+PC9wPlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBAaWYgKGJ1dHRvbikge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICA8ZGl2IGNsYXNzPVwiYnRuX19ncm91cFwiPlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgPGFcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBbaHJlZl09XCJidXR0b24udXJsXCJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBbbGlua1R5cGVdPVwiYnV0dG9uLmxpbmtUeXBlXCJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBjbGFzcz1cImJ0biBidG5fX3ByaW1hcnktLW91dGxpbmVcIlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFthdHRyLmFyaWEtbGFiZWxdPVwiYnV0dG9uLmxhYmVsXCJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICA+e3sgYnV0dG9uLmxhYmVsIH19PC9hXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgIH1cbiAgICAgICAgPC9kaXY+XG5cbiAgICAgICAgPGRpdiBjbGFzcz1cImpzLXNsaWRlci1hcnJvd3MgcGhvdG9zbGlkZXJcIj48L2Rpdj5cbiAgICA8L2Rpdj5cbjwvc2VjdGlvbj5cbiJdfQ==
33
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVyby1waG90by1zbGlkZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcHVyby9zcmMvbGliL2NvbXBvbmVudHMvcHVyby1waG90by1zbGlkZXIvcHVyby1waG90by1zbGlkZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcHVyby9zcmMvbGliL2NvbXBvbmVudHMvcHVyby1waG90by1zbGlkZXIvcHVyby1waG90by1zbGlkZXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNILFlBQVksRUFDWixnQkFBZ0IsR0FDbkIsTUFBTSxpQkFBaUIsQ0FBQztBQUN6QixPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMxRSxPQUFPLEVBQUUsNkJBQTZCLEVBQUUscUJBQXFCLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQzs7QUFpQjdHLE1BQU0sT0FBTyx3QkFBd0I7K0dBQXhCLHdCQUF3QjttR0FBeEIsd0JBQXdCLHVPQ3RCckMsNnpHQWtGQSx5RER0RVEsWUFBWSwrQkFDWixxQkFBcUIsNElBQ3JCLG1CQUFtQixpRkFDbkIsZ0JBQWdCLGdQQUNoQiw2QkFBNkI7OzRGQU14Qix3QkFBd0I7a0JBZHBDLFNBQVM7K0JBQ0ksdUJBQXVCLGNBQ3JCLElBQUksV0FDUDt3QkFDTCxZQUFZO3dCQUNaLHFCQUFxQjt3QkFDckIsbUJBQW1CO3dCQUNuQixnQkFBZ0I7d0JBQ2hCLDZCQUE2QjtxQkFDaEMsbUJBR2dCLHVCQUF1QixDQUFDLE1BQU07OEJBR3RDLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUNHLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSztnQkFDRyxNQUFNO3NCQUFkLEtBQUs7Z0JBQ0csR0FBRztzQkFBWCxLQUFLO2dCQUNHLE9BQU87c0JBQWYsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIE5nT3B0aW1pemVkSW1hZ2UsXG59IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQXV0b0ltYWdlWm9vbVdyYXBwZXJEaXJlY3RpdmUsIFB1cm9MaW5rVHlwZURpcmVjdGl2ZSwgUHVyb1NsaWRlckRpcmVjdGl2ZSB9IGZyb20gJy4uLy4uL2RpcmVjdGl2ZXMnO1xuaW1wb3J0IHsgUHVyb0J1dHRvbkksIFB1cm9JbWFnZUkgfSBmcm9tICcuLi8uLi9pbnRlcmZhY2VzJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdsaWItcHVyby1waG90by1zbGlkZXInLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaW1wb3J0czogW1xuICAgICAgICBDb21tb25Nb2R1bGUsXG4gICAgICAgIFB1cm9MaW5rVHlwZURpcmVjdGl2ZSxcbiAgICAgICAgUHVyb1NsaWRlckRpcmVjdGl2ZSxcbiAgICAgICAgTmdPcHRpbWl6ZWRJbWFnZSxcbiAgICAgICAgQXV0b0ltYWdlWm9vbVdyYXBwZXJEaXJlY3RpdmUsXG4gICAgXSxcbiAgICB0ZW1wbGF0ZVVybDogJy4vcHVyby1waG90by1zbGlkZXIuY29tcG9uZW50Lmh0bWwnLFxuICAgIHN0eWxlVXJsOiAnLi9wdXJvLXBob3RvLXNsaWRlci5jb21wb25lbnQuc2NzcycsXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG59KVxuZXhwb3J0IGNsYXNzIFB1cm9QaG90b1NsaWRlckNvbXBvbmVudCB7XG4gICAgQElucHV0KCkgdGl0bGU/OiBzdHJpbmc7XG4gICAgQElucHV0KCkgc3VidGl0bGU/OiBzdHJpbmc7XG4gICAgQElucHV0KCkgcHJldGl0bGU/OiBzdHJpbmc7XG4gICAgQElucHV0KCkgZGVzY3JpcHRpb24/OiBzdHJpbmc7XG4gICAgQElucHV0KCkgYnV0dG9uPzogUHVyb0J1dHRvbkk7XG4gICAgQElucHV0KCkgaW1nPzogUHVyb0ltYWdlSVtdO1xuICAgIEBJbnB1dCgpIHJldmVyc2U/OiBib29sZWFuO1xufVxuIiwiPHNlY3Rpb25cbiAgICBjbGFzcz1cInRleHRQaG90b0Nhcm91c2VsIGpzLWFjdGl2ZS1zbGlkZXJcIlxuICAgIFtwdXJvU2xpZGVyXT1cImltZ1wiXG4gICAgZGF0YS1zbGlkZXNfaW5maW5pdGU9XCJ0cnVlXCJcbiAgICBkYXRhLXNsaWRlcl9uYW1lPVwianMtc2xpZGVyXCJcbiAgICBkYXRhLXNsaWRlcl9zaG93YnRucz1cInRydWVcIlxuICAgIGRhdGEtc2xpZGVyX3Nob3dkb3RzPVwiZmFsc2VcIlxuICAgIGRhdGEtc2xpZGVyX2ZhZGU9XCJ0cnVlXCJcbiAgICBkYXRhLXNsaWRlcl9hdXRvcGxheT1cInRydWVcIlxuICAgIGRhdGEtc2xpZGVzX3BjPVwiMVwiXG4+XG4gICAgPGRpdiBjbGFzcz1cInJlbGF0aXZlXCI+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJqcy1zbGlkZXIganMtc2xpZGVyX2ZpeC1hcnJvd3NcIj5cbiAgICAgICAgICAgIEBmb3IgKGltYWdlIG9mIGltZzsgdHJhY2sgJGluZGV4KSB7XG4gICAgICAgICAgICAgICAgPGRpdiBjbGFzcz1cInRleHRQaG90b0Nhcm91c2VsX19pdGVtXCI+XG4gICAgICAgICAgICAgICAgICAgIDwhLS0gSU1BR0VOIEEgTEEgSVpRVUlFUkRBIC0tPlxuICAgICAgICAgICAgICAgICAgICA8ZGl2IGNsYXNzPVwidGV4dFBob3RvQ2Fyb3VzZWxfX2ltYWdlLS1vdXRlclwiPlxuICAgICAgICAgICAgICAgICAgICAgICAgPGRpdlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIGNsYXNzPVwidGV4dFBob3RvQ2Fyb3VzZWxfX2ltYWdlIGpzLXNsaWRlcl9maXgtYXJyb3dzLXpvbmVcIlxuICAgICAgICAgICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIDxpbWdcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgW25nU3JjXT1cImltYWdlLnNyY1wiXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFthbHRdPVwiaW1hZ2UuYWx0XCJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY2xhc3M9XCJ0ZXh0UGhvdG9DYXJvdXNlbF9faW1nXCJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgd2lkdGg9XCI5NjBcIlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBoZWlnaHQ9XCI4MDdcIlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgICAgICAgICAgPC9kaXY+XG5cbiAgICAgICAgICAgICAgICAgICAgPCEtLSBURVhUTyBBIExBIERFUkVDSEEgLS0+XG4gICAgICAgICAgICAgICAgICAgIDxkaXZcbiAgICAgICAgICAgICAgICAgICAgICAgIGNsYXNzPVwidGV4dFBob3RvQ2Fyb3VzZWxfX2NvbnRlbnQgdGV4dFBob3RvQ2Fyb3VzZWxfX2NvbnRlbnQtLWFsaWduQ2VudGVyXCJcbiAgICAgICAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgICAgICAgICAgPGRpdj5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBAaWYgKHByZXRpdGxlKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIDxzcGFuXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBjbGFzcz1cInRleHRQaG90b0Nhcm91c2VsX190aXRsZVwiXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBbaW5uZXJIVE1MXT1cInByZXRpdGxlXCJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgPjwvc3Bhbj5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBAaWYgKHRpdGxlKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIDxoMlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY2xhc3M9XCJ0ZXh0UGhvdG9DYXJvdXNlbF9faGVhZGluZ1wiXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBbaW5uZXJIVE1MXT1cInRpdGxlXCJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgPjwvaDI+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgQGlmIChzdWJ0aXRsZSkge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICA8cFxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY2xhc3M9XCJ0ZXh0UGhvdG9DYXJvdXNlbF9fc3ViSGVhZGluZ1wiXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBbaW5uZXJIVE1MXT1cInN1YnRpdGxlXCJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgPjwvcD5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBAaWYgKGRlc2NyaXB0aW9uKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIDxwXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBjbGFzcz1cInRleHRQaG90b0Nhcm91c2VsX19wYXJhZ3JhcGhcIlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgW2lubmVySFRNTF09XCJkZXNjcmlwdGlvblwiXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgID48L3A+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIEBpZiAoYnV0dG9uKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJidG5fX2dyb3VwXCI+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICA8YVxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFtocmVmXT1cImJ1dHRvbi51cmxcIlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFtsaW5rVHlwZV09XCJidXR0b24ubGlua1R5cGVcIlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGNsYXNzPVwiYnRuIGJ0bl9fcHJpbWFyeS0tb3V0bGluZVwiXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgW2F0dHIuYXJpYS1sYWJlbF09XCJidXR0b24ubGFiZWxcIlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgID57eyBidXR0b24ubGFiZWwgfX08L2FcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgfVxuICAgICAgICA8L2Rpdj5cblxuICAgICAgICA8ZGl2IGNsYXNzPVwianMtc2xpZGVyLWFycm93cyBwaG90b3NsaWRlclwiPjwvZGl2PlxuICAgIDwvZGl2PlxuPC9zZWN0aW9uPlxuIl19