ctt-puro 0.70.4 → 0.70.6

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.
@@ -58,9 +58,13 @@ export class PuroHeaderComponent {
58
58
  return this.isHotelsPage && !this.isRestaurant && !this.isGroupSite;
59
59
  }
60
60
  get showBook() {
61
- return (!!this.btnBook &&
62
- !this.isGroupSite &&
63
- !(this.HIDE_RESTAURANT_BUTTONS && this.isRestaurant));
61
+ if (!this.btnBook)
62
+ return false;
63
+ // Si es SITE_GROUP solo mostrar si es restaurante
64
+ if (this.isGroupSite) {
65
+ return this.isRestaurant;
66
+ }
67
+ return true;
64
68
  }
65
69
  get showCheckinOnline() {
66
70
  return this.isHotelStickyContext && !!this.btnCheckinOnline;
@@ -129,4 +133,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
129
133
  }], btnClickCheckinOnline: [{
130
134
  type: Output
131
135
  }] } });
132
- //# 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 } 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    ],\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    resolvedLogoImg?: string;\n    resolvedSvgHref?: string;\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        //logos\n        if (this.logoHotel) {\n            this.resolvedLogoImg = this.logoHotel;\n            this.resolvedSvgHref = undefined;\n        } else {\n            this.resolvedLogoImg = undefined;\n            this.resolvedSvgHref = this.resolveSiteSvg();\n        }\n\n        //backgrounds\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    private resolveSiteSvg(): string {\n        switch (this.siteId) {\n            case this.SITE_HOTELS:\n                return '#puro-logo';\n            case this.SITE_BEACH:\n                return '#purobeach-logo';\n            case this.SITE_GROUP:\n            default:\n                return '#purogroup-logo';\n        }\n    }\n}\n","<header class=\"header\" navSticky [isDynamic]=\"isDynamic\">\n    <div class=\"header__logo\">\n        <a [href]=\"linkHotel\" linkType=\"internal\">\n            @if (resolvedLogoImg) {\n                <img\n                    [src]=\"resolvedLogoImg\"\n                    alt=\"Logo\"\n                    width=\"301\"\n                    height=\"32\"\n                    class=\"header__logo--img\" loading=\"lazy\" />\n            } @else if (resolvedSvgHref) {\n                <svg\n                    aria-hidden=\"true\"\n                    width=\"301\"\n                    height=\"32\"\n                    focusable=\"false\"\n                    class=\"header__logo--img\"\n                >\n                    <use [attr.href]=\"resolvedSvgHref\"></use>\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    <!-- 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"]}
136
+ //# 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":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EACH,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,MAAM,EACN,KAAK,EAEL,MAAM,GACT,MAAM,eAAe,CAAC;AACvB,OAAO,EACH,wBAAwB,EACxB,qBAAqB,GACxB,MAAM,kBAAkB,CAAC;AAC1B,OAAO,EAAE,sBAAsB,EAAE,MAAM,4DAA4D,CAAC;;AAiBpG,MAAM,OAAO,mBAAmB;IAdhC;QAeY,mBAAc,GAAG,MAAM,CAAC,wBAAwB,CAAC,CAAC;QASjD,iBAAY,GAAY,KAAK,CAAC;QAC9B,iBAAY,GAAY,KAAK,CAAC;QAI9B,cAAS,GAAG,KAAK,CAAC;QAOjB,aAAQ,GAAG,IAAI,YAAY,EAAE,CAAC;QAC9B,oBAAe,GAAG,IAAI,YAAY,EAAE,CAAC;QACrC,0BAAqB,GAAG,IAAI,YAAY,EAAE,CAAC;QAE5C,eAAU,GAAG,CAAC,CAAC;QACf,gBAAW,GAAG,CAAC,CAAC;QAChB,eAAU,GAAG,CAAC,CAAC;QACf,4BAAuB,GAAG,IAAI,CAAC,CAAC,iBAAiB;QAE1D,aAAQ,GAAG,EAAE,CAAC;QACd,eAAU,GAAG,EAAE,CAAC;KA6EnB;IAzEG,YAAY;QACR,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACrB,QAAQ,IAAI,CAAC,MAAM,EAAE;YACjB,KAAK,IAAI,CAAC,UAAU;gBAChB,MAAM;YACV,KAAK,IAAI,CAAC,WAAW;gBACjB,IAAI,CAAC,cAAc,CAAC,WAAW,EAAE,CAAC;gBAClC,MAAM;YACV,KAAK,IAAI,CAAC,UAAU;gBAChB,MAAM;YAEV;gBACI,MAAM;SACb;IACL,CAAC;IAED,QAAQ;QACJ,OAAO;QACP,IAAI,IAAI,CAAC,SAAS,EAAE;YAChB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,SAAS,CAAC;YACtC,IAAI,CAAC,eAAe,GAAG,SAAS,CAAC;SACpC;aAAM;YACH,IAAI,CAAC,eAAe,GAAG,SAAS,CAAC;YACjC,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;SAChD;QAED,aAAa;QACb,IAAI,IAAI,CAAC,UAAU,EAAE,GAAG,EAAE;YACtB,IAAI,CAAC,UAAU,GAAG,QAAQ,IAAI,CAAC,UAAU,CAAC,GAAG,IAAI,CAAC;SACrD;QACD,IAAI,IAAI,CAAC,aAAa,EAAE,GAAG,EAAE;YACzB,IAAI,CAAC,QAAQ,GAAG,QAAQ,IAAI,CAAC,aAAa,CAAC,GAAG,IAAI,CAAC;SACtD;IACL,CAAC;IAED,IAAI,WAAW;QACX,OAAO,IAAI,CAAC,MAAM,KAAK,IAAI,CAAC,UAAU,CAAC;IAC3C,CAAC;IAED,IAAI,oBAAoB;QACpB,OAAO,IAAI,CAAC,YAAY,IAAI,CAAC,IAAI,CAAC,YAAY,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC;IACxE,CAAC;IAED,IAAI,QAAQ;QACR,IAAI,CAAC,IAAI,CAAC,OAAO;YAAE,OAAO,KAAK,CAAC;QAEhC,kDAAkD;QAClD,IAAI,IAAI,CAAC,WAAW,EAAE;YAClB,OAAO,IAAI,CAAC,YAAY,CAAC;SAC5B;QAED,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,IAAI,iBAAiB;QACjB,OAAO,IAAI,CAAC,oBAAoB,IAAI,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC;IAChE,CAAC;IAED,IAAI,WAAW;QACX,OAAO,IAAI,CAAC,oBAAoB,IAAI,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC;IAC1D,CAAC;IAEO,cAAc;QAClB,QAAQ,IAAI,CAAC,MAAM,EAAE;YACjB,KAAK,IAAI,CAAC,WAAW;gBACjB,OAAO,YAAY,CAAC;YACxB,KAAK,IAAI,CAAC,UAAU;gBAChB,OAAO,iBAAiB,CAAC;YAC7B,KAAK,IAAI,CAAC,UAAU,CAAC;YACrB;gBACI,OAAO,iBAAiB,CAAC;SAChC;IACL,CAAC;+GA5GQ,mBAAmB;mGAAnB,mBAAmB,ymBAFjB,CAAC,wBAAwB,CAAC,0BC7BzC,yvOAqMA,oNDhLQ,YAAY,+BACZ,qBAAqB,4IACrB,wBAAwB,0DACxB,sBAAsB;;4FAOjB,mBAAmB;kBAd/B,SAAS;+BACI,iBAAiB,cACf,IAAI,WACP;wBACL,YAAY;wBACZ,qBAAqB;wBACrB,wBAAwB;wBACxB,sBAAsB;qBACzB,mBAGgB,uBAAuB,CAAC,MAAM,aACpC,CAAC,wBAAwB,CAAC;8BAI5B,SAAS;sBAAjB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,MAAM;sBAAd,KAAK;gBAIG,YAAY;sBAApB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBAEI,QAAQ;sBAAjB,MAAM;gBACG,eAAe;sBAAxB,MAAM;gBACG,qBAAqB;sBAA9B,MAAM","sourcesContent":["import { CommonModule } 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    ],\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    resolvedLogoImg?: string;\n    resolvedSvgHref?: string;\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        //logos\n        if (this.logoHotel) {\n            this.resolvedLogoImg = this.logoHotel;\n            this.resolvedSvgHref = undefined;\n        } else {\n            this.resolvedLogoImg = undefined;\n            this.resolvedSvgHref = this.resolveSiteSvg();\n        }\n\n        //backgrounds\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        if (!this.btnBook) return false;\n\n        // Si es SITE_GROUP solo mostrar si es restaurante\n        if (this.isGroupSite) {\n            return this.isRestaurant;\n        }\n\n        return true;\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    private resolveSiteSvg(): string {\n        switch (this.siteId) {\n            case this.SITE_HOTELS:\n                return '#puro-logo';\n            case this.SITE_BEACH:\n                return '#purobeach-logo';\n            case this.SITE_GROUP:\n            default:\n                return '#purogroup-logo';\n        }\n    }\n}\n","<header class=\"header\" navSticky [isDynamic]=\"isDynamic\">\n    <div class=\"header__logo\">\n        <a [href]=\"linkHotel\" linkType=\"internal\">\n            @if (resolvedLogoImg) {\n                <img\n                    [src]=\"resolvedLogoImg\"\n                    alt=\"Logo\"\n                    width=\"301\"\n                    height=\"32\"\n                    class=\"header__logo--img\" loading=\"lazy\" />\n            } @else if (resolvedSvgHref) {\n                <svg\n                    aria-hidden=\"true\"\n                    width=\"301\"\n                    height=\"32\"\n                    focusable=\"false\"\n                    class=\"header__logo--img\"\n                >\n                    <use [attr.href]=\"resolvedSvgHref\"></use>\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    <!-- 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"]}
@@ -10,6 +10,7 @@ export class PuroHeaderMobileComponent {
10
10
  this.platformId = inject(PLATFORM_ID);
11
11
  this.router = inject(Router);
12
12
  this.isDynamic = false;
13
+ this.isRestaurant = false;
13
14
  this.btnClick = new EventEmitter();
14
15
  this.SITE_GROUP = 1;
15
16
  this.SITE_HOTELS = 2;
@@ -88,15 +89,15 @@ export class PuroHeaderMobileComponent {
88
89
  break;
89
90
  }
90
91
  }
92
+ get isGroupSite() {
93
+ return this.siteId === this.SITE_GROUP;
94
+ }
91
95
  get showHeaderBookButton() {
92
96
  if (!this.btnBook)
93
97
  return false;
94
- // Site 1 nunca botón (coherente con desktop)
95
- if (this.siteId === this.SITE_GROUP)
96
- return false;
97
- // ⚠️ PROVISIONAL: ocultar botones en restaurantes
98
- if (this.HIDE_RESTAURANT_BUTTONS && this.isRestaurant) {
99
- return false;
98
+ // Si es SITE_GROUP solo mostrar si es restaurante
99
+ if (this.isGroupSite) {
100
+ return this.isRestaurant;
100
101
  }
101
102
  return true;
102
103
  }
@@ -138,4 +139,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
138
139
  }], btnClick: [{
139
140
  type: Output
140
141
  }] } });
141
- //# 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 { CommonModule, isPlatformBrowser } from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    EventEmitter,\n    inject,\n    Input,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    Output,\n    PLATFORM_ID,\n    signal,\n} from '@angular/core';\nimport { Router } from '@angular/router';\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    ],\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    resolvedImg?: string;\n    resolvedSvgHref?: string;\n    resolvedLink = '/';\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            this.updateStickyState();\n\n            this.observer = new MutationObserver(() => {\n                this.updateStickyState();\n            });\n\n            this.observer.observe(document.body, {\n                attributes: true,\n                attributeFilter: ['class'],\n            });\n\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\n            window.addEventListener('scroll', this.scrollListener, {\n                passive: true,\n            });\n        }\n    }\n\n    ngOnDestroy(): void {\n        if (!isPlatformBrowser(this.platformId)) return;\n\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        if (!isPlatformBrowser(this.platformId)) return;\n\n        const current = this.checkStickyClasses();\n        if (this.hasStickyClasses() !== current) {\n            this.hasStickyClasses.set(current);\n        }\n    }\n\n    private checkStickyClasses(): boolean {\n        if (!isPlatformBrowser(this.platformId)) return false;\n\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}\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=\"Logo\"\n        >\n            @if (logoHotelWhite && logoHotel) {\n                <img\n                    [src]=\"hasStickyClasses() ? logoHotel : logoHotelWhite\"\n                    alt=\"Logo\"\n                    width=\"177\"\n                    height=\"68\"\n                    class=\"banner__logo--img\" loading=\"lazy\" />\n            }\n        </a>\n    </div>\n\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\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"]}
142
+ //# 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 { CommonModule, isPlatformBrowser } from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    EventEmitter,\n    inject,\n    Input,\n    OnDestroy,\n    OnInit,\n    Output,\n    PLATFORM_ID,\n    signal,\n} from '@angular/core';\nimport { Router } from '@angular/router';\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    ],\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 = false;\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    resolvedImg?: string;\n    resolvedSvgHref?: string;\n    resolvedLink = '/';\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            this.updateStickyState();\n\n            this.observer = new MutationObserver(() => {\n                this.updateStickyState();\n            });\n\n            this.observer.observe(document.body, {\n                attributes: true,\n                attributeFilter: ['class'],\n            });\n\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\n            window.addEventListener('scroll', this.scrollListener, {\n                passive: true,\n            });\n        }\n    }\n\n    ngOnDestroy(): void {\n        if (!isPlatformBrowser(this.platformId)) return;\n\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        if (!isPlatformBrowser(this.platformId)) return;\n\n        const current = this.checkStickyClasses();\n        if (this.hasStickyClasses() !== current) {\n            this.hasStickyClasses.set(current);\n        }\n    }\n\n    private checkStickyClasses(): boolean {\n        if (!isPlatformBrowser(this.platformId)) return false;\n\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 isGroupSite(): boolean {\n        return this.siteId === this.SITE_GROUP;\n    }\n\n    get showHeaderBookButton(): boolean {\n        if (!this.btnBook) return false;\n\n        // Si es SITE_GROUP solo mostrar si es restaurante\n        if (this.isGroupSite) {\n            return this.isRestaurant;\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=\"Logo\"\n        >\n            @if (logoHotelWhite && logoHotel) {\n                <img\n                    [src]=\"hasStickyClasses() ? logoHotel : logoHotelWhite\"\n                    alt=\"Logo\"\n                    width=\"177\"\n                    height=\"68\"\n                    class=\"banner__logo--img\" loading=\"lazy\" />\n            }\n        </a>\n    </div>\n\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\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"]}