ctt-babylon 0.13.24 → 0.13.25

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.
@@ -59,9 +59,8 @@ export class LisC2TxtImgComponent {
59
59
  /** ✅ util: sacar label humano para habitaciones */
60
60
  getRoomLabelFromImage(item) {
61
61
  // 1) si viene img.name (como en tu screenshot del back), lo usamos
62
- const n1 = item.img?.name;
63
- if (typeof n1 === 'string' && n1.trim())
64
- return n1.trim();
62
+ /* const n1 = (item.img as any)?.name;
63
+ if (typeof n1 === 'string' && n1.trim()) return n1.trim(); */
65
64
  // 2) si viene title, lo usamos
66
65
  if (item.title?.trim())
67
66
  return item.title.trim();
@@ -78,7 +77,6 @@ export class LisC2TxtImgComponent {
78
77
  return 'Habitación';
79
78
  }
80
79
  }
81
- /** ✅ opciones del modal habitaciones (dinámicas) */
82
80
  get roomOptions() {
83
81
  const rid = this.roomsFilterId;
84
82
  if (rid == null)
@@ -230,4 +228,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
230
228
  type: ViewChild,
231
229
  args: ['roomsModal']
232
230
  }] } });
233
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lis-c2-txt-img.component.js","sourceRoot":"","sources":["../../../../../../../../projects/babylon/src/lib/components/external/core/lis-c2-txt-img/lis-c2-txt-img.component.ts","../../../../../../../../projects/babylon/src/lib/components/external/core/lis-c2-txt-img/lis-c2-txt-img.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n    AfterViewInit,\n    Component,\n    ElementRef,\n    Input,\n    OnChanges,\n    OnDestroy,\n    SimpleChanges,\n    ViewChild,\n    ViewEncapsulation,\n} from '@angular/core';\nimport { Fancybox } from '@fancyapps/ui';\nimport { BabylonImageI, BabylonTextInfoI } from '../../../../interfaces';\nimport { BabylonStyleGlobalItem } from '../../../../interfaces/babylon-style.interface';\nimport defaultContent from './content.json';\n\nexport interface GalleryFilterItem {\n    id: number;\n    text: string; // ✅ viene así del back\n    all?: boolean;\n    room?: boolean;\n    rooms?: boolean;\n}\n\nexport interface GalleryImageItem {\n    filter: number; // ✅ id del filtro\n    img: BabylonImageI & { name?: string }; // a veces img trae name\n    title?: string; // opcional (veo que en gastronomía/spa viene)\n}\n\nexport interface BabylonGloablsGalleryFilter {\n    leftSide?: boolean;\n    rightSide?: boolean;\n    filters: GalleryFilterItem[];\n    images: GalleryImageItem[];\n}\n\nexport interface LisC2TxtImgContent {\n    lensIcon: string;\n}\n\nconst DEFAULT_CONTENT: LisC2TxtImgContent =\n    defaultContent as LisC2TxtImgContent;\n\n@Component({\n    selector: 'lis-c2-txt-img',\n    standalone: true,\n    encapsulation: ViewEncapsulation.None,\n    imports: [CommonModule],\n    templateUrl: './lis-c2-txt-img.component.html',\n    styleUrl: './lis-c2-txt-img.component.scss',\n})\nexport class LisC2TxtImgComponent\n    implements AfterViewInit, OnChanges, OnDestroy\n{\n    @Input() content: LisC2TxtImgContent = DEFAULT_CONTENT;\n\n    @Input() filters?: BabylonGloablsGalleryFilter;\n    @Input() texts?: BabylonTextInfoI;\n    @Input() styles?: BabylonStyleGlobalItem;\n\n    @ViewChild('categoriesModal') categoriesModal?: ElementRef<HTMLElement>;\n    @ViewChild('roomsModal') roomsModal?: ElementRef<HTMLElement>;\n\n    /** null => Todas */\n    selectedFilterId: number | null = null;\n\n    /** Dentro de habitaciones: '__all__' o una clave concreta */\n    selectedRoomKey: string | null = null;\n\n    private galleryBound = false;\n\n    constructor(private host: ElementRef<HTMLElement>) {}\n\n    ngAfterViewInit(): void {\n        this.bindGallery();\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes['filters'] && !changes['filters'].firstChange) {\n            // si llega data nueva, reseteo selección a “Todas” si existe\n            this.setDefaultSelection();\n            queueMicrotask(() => this.bindGallery());\n        }\n    }\n\n    ngOnDestroy(): void {\n        this.unbindGallery();\n        this.closeModals();\n    }\n\n    /** ✅ filtro “Habitaciones” */\n    get roomsFilterId(): number | null {\n        const f = this.filters?.filters?.find((x) => !!x.rooms);\n        return typeof f?.id === 'number' ? f.id : null;\n    }\n\n    /** ✅ existe filtro habitaciones */\n    get hasRoomsFilter(): boolean {\n        return this.roomsFilterId != null;\n    }\n\n    /** ✅ para marcar “Todas” (si existe) */\n    private get allFilterId(): number | null {\n        const f = this.filters?.filters?.find((x) => !!x.all);\n        return typeof f?.id === 'number' ? f.id : null;\n    }\n\n    private setDefaultSelection(): void {\n        // Por defecto: si existe \"Todas\" lo dejamos en null (mostrar todo),\n        // si no, ponemos el primer filtro.\n        const allId = this.allFilterId;\n        if (allId != null) {\n            this.selectedFilterId = null; // null significa “mostrar todo”\n            this.selectedRoomKey = null;\n            return;\n        }\n\n        const first = this.filters?.filters?.[0]?.id ?? null;\n        this.selectedFilterId = first;\n        this.selectedRoomKey = null;\n    }\n\n    /** ✅ util: sacar label humano para habitaciones */\n    private getRoomLabelFromImage(item: GalleryImageItem): string {\n        // 1) si viene img.name (como en tu screenshot del back), lo usamos\n        const n1 = (item.img as any)?.name;\n        if (typeof n1 === 'string' && n1.trim()) return n1.trim();\n\n        // 2) si viene title, lo usamos\n        if (item.title?.trim()) return item.title.trim();\n\n        // 3) fallback: filename de la url\n        const src = item.img?.src ?? '';\n        try {\n            const last = src.split('/').pop() ?? '';\n            const noQuery = last.split('?')[0];\n            const noExt = noQuery.replace(/\\.[a-z0-9]+$/i, '');\n            return (\n                decodeURIComponent(noExt).replace(/[_-]+/g, ' ').trim() ||\n                'Habitación'\n            );\n        } catch {\n            return 'Habitación';\n        }\n    }\n\n    /** ✅ opciones del modal habitaciones (dinámicas) */\n    get roomOptions(): { id: string; label: string }[] {\n        const rid = this.roomsFilterId;\n        if (rid == null) return [];\n\n        const imgs = (this.filters?.images ?? []).filter(\n            (i) => Number(i.filter) === Number(rid)\n        );\n\n        const labels = imgs\n            .map((i) => this.getRoomLabelFromImage(i))\n            .filter(Boolean);\n        const unique = Array.from(new Set(labels));\n\n        return [\n            { id: '__all__', label: 'Todas' },\n            ...unique.map((t) => ({ id: t, label: t })),\n        ];\n    }\n\n    /** ✅ lista filtrada real */\n    get filteredImages(): GalleryImageItem[] {\n        const imgs = this.filters?.images ?? [];\n        const rid = this.roomsFilterId;\n\n        // null => Todas\n        if (this.selectedFilterId == null) return imgs;\n\n        // Habitaciones\n        if (rid != null && Number(this.selectedFilterId) === Number(rid)) {\n            const inRooms = imgs.filter(\n                (i) => Number(i.filter) === Number(rid)\n            );\n\n            if (!this.selectedRoomKey || this.selectedRoomKey === '__all__') {\n                return inRooms;\n            }\n\n            return inRooms.filter(\n                (i) => this.getRoomLabelFromImage(i) === this.selectedRoomKey\n            );\n        }\n\n        // Resto\n        return imgs.filter(\n            (i) => Number(i.filter) === Number(this.selectedFilterId)\n        );\n    }\n\n    /** ✅ click filtro (desktop) */\n    filterBy(filter: GalleryFilterItem): void {\n        // Todas\n        if (filter.all) {\n            this.selectedFilterId = null;\n            this.selectedRoomKey = null;\n            this.closeModals();\n            return;\n        }\n\n        // Habitaciones -> modal\n        if (filter.rooms) {\n            this.selectedFilterId = filter.id;\n            this.selectedRoomKey = '__all__';\n            this.openRoomsModal();\n            return;\n        }\n\n        // normal\n        this.selectedFilterId = filter.id;\n        this.selectedRoomKey = null;\n        this.closeModals();\n    }\n\n    /** ✅ click filtro (modal categorías) */\n    filterFromModal(filter: GalleryFilterItem): void {\n        this.closeModals();\n        this.filterBy(filter);\n    }\n\n    /** ✅ seleccionar habitación (modal rooms) */\n    selectRoom(roomKey: string): void {\n        const rid = this.roomsFilterId;\n        if (rid == null) return;\n\n        this.selectedFilterId = rid;\n        this.selectedRoomKey = roomKey;\n        this.closeModals();\n    }\n\n    openCategoriesModal(): void {\n        this.openInlineModal(this.categoriesModal?.nativeElement);\n    }\n\n    openRoomsModal(): void {\n        this.openInlineModal(this.roomsModal?.nativeElement);\n    }\n\n    closeModals(): void {\n        Fancybox.close();\n    }\n\n    isFilterActive(filter: GalleryFilterItem): boolean {\n        if (filter.all) return this.selectedFilterId == null;\n        return this.selectedFilterId === filter.id;\n    }\n\n    getFancyboxGroup(): string {\n        // agrupar por selección actual (así no mezcla galleries raras)\n        if (this.selectedFilterId == null) return 'gallery-all';\n\n        const rid = this.roomsFilterId;\n        if (rid != null && Number(this.selectedFilterId) === Number(rid)) {\n            if (this.selectedRoomKey && this.selectedRoomKey !== '__all__') {\n                return `rooms-${this.selectedRoomKey}`;\n            }\n            return 'rooms-all';\n        }\n\n        return `gallery-${this.selectedFilterId}`;\n    }\n\n    trackByIndex(index: number): number {\n        return index;\n    }\n\n    /** Fancybox */\n    private bindGallery(): void {\n        this.unbindGallery();\n\n        const hostElement = this.host.nativeElement;\n        if (!hostElement.querySelector('[data-fancybox]')) return;\n\n        Fancybox.bind(hostElement, '[data-fancybox]', {\n            dragToClose: false,\n        });\n\n        this.galleryBound = true;\n    }\n\n    private unbindGallery(): void {\n        if (!this.galleryBound) return;\n\n        Fancybox.unbind(this.host.nativeElement);\n        this.galleryBound = false;\n    }\n\n    private openInlineModal(content?: HTMLElement): void {\n        if (!content) return;\n\n        const selector = content.id ? `#${content.id}` : null;\n        if (!selector) return;\n\n        content.removeAttribute('hidden');\n\n        Fancybox.close();\n        Fancybox.show([{ src: selector, type: 'inline' }], {\n            dragToClose: false,\n            hideScrollbar: true,\n            on: {\n                destroy: () => content.setAttribute('hidden', ''),\n            },\n        });\n    }\n}\n","@if (filters?.filters?.length) {\n    <section class=\"mdl-mdh002galeria\">\n        <div class=\"mdl-container\">\n            <div class=\"m-filters\">\n                <!-- DESKTOP -->\n                <div class=\"m-desktop-filters\">\n                    <div\n                        class=\"m-filter\"\n                        *ngFor=\"let f of filters?.filters\"\n                        (click)=\"filterBy(f)\"\n                        [class.active]=\"isFilterActive(f)\"\n                    >\n                        {{ f.text }}\n                    </div>\n                </div>\n\n                <!-- MOBILE -->\n                <div class=\"m-mobile-filters\">\n                    <div class=\"m-select\" (click)=\"openCategoriesModal()\">\n                        @if (texts?.categories) {\n                            <div>{{ texts?.categories }}</div>\n                        }\n                        <svg\n                            width=\"17\"\n                            height=\"11\"\n                            viewBox=\"0 0 17 11\"\n                            fill=\"none\"\n                            xmlns=\"http://www.w3.org/2000/svg\"\n                        >\n                            <g opacity=\"0.5\">\n                                <path\n                                    d=\"M16.0193 0H0V0.804475H16.0193V0Z\"\n                                    fill=\"#515050\"\n                                />\n                                <path\n                                    d=\"M16.0193 4.67969H0V5.4846H16.0193V4.67969Z\"\n                                    fill=\"#515050\"\n                                />\n                                <path\n                                    d=\"M16.0193 9.36328H0V10.1678H16.0193V9.36328Z\"\n                                    fill=\"#515050\"\n                                />\n                            </g>\n                        </svg>\n                    </div>\n\n                    @if (hasRoomsFilter) {\n                        <div class=\"m-select\" (click)=\"openRoomsModal()\">\n                            @if (texts?.rooms) {\n                                <div>{{ texts?.rooms }}</div>\n                            }\n                            <svg\n                                width=\"17\"\n                                height=\"11\"\n                                viewBox=\"0 0 17 11\"\n                                fill=\"none\"\n                                xmlns=\"http://www.w3.org/2000/svg\"\n                            >\n                                <g opacity=\"0.5\">\n                                    <path\n                                        d=\"M16.0193 0H0V0.804475H16.0193V0Z\"\n                                        fill=\"#515050\"\n                                    />\n                                    <path\n                                        d=\"M16.0193 4.67969H0V5.4846H16.0193V4.67969Z\"\n                                        fill=\"#515050\"\n                                    />\n                                    <path\n                                        d=\"M16.0193 9.36328H0V10.1678H16.0193V9.36328Z\"\n                                        fill=\"#515050\"\n                                    />\n                                </g>\n                            </svg>\n                        </div>\n                    }\n                </div>\n            </div>\n\n            <!-- GRID -->\n            @if (filteredImages?.length) {\n                <div class=\"m-gal-grid\">\n                    <div\n                        class=\"m-gal-item\"\n                        *ngFor=\"\n                            let item of filteredImages;\n                            trackBy: trackByIndex\n                        \"\n                    >\n                        <a\n                            class=\"m-media\"\n                            [href]=\"item.img?.src\"\n                            [attr.data-fancybox]=\"getFancyboxGroup()\"\n                            [attr.data-caption]=\"item.title ?? ''\"\n                        >\n                            <img\n                                [src]=\"item.img?.src\"\n                                [alt]=\"item.img?.alt || ''\"\n                            />\n                        </a>\n\n                        <div class=\"m-item-footer\">\n                            <span>{{ item.title || '' }}</span>\n                            <div class=\"m-icon\">\n                                <!-- <img [src]=\"content.lensIcon\" alt=\"name\" /> -->\n                                <svg\n                                    width=\"50\"\n                                    height=\"50\"\n                                    viewBox=\"0 0 40 40\"\n                                    fill=\"none\"\n                                    xmlns=\"http://www.w3.org/2000/svg\"\n                                >\n                                    <rect\n                                        width=\"50\"\n                                        height=\"50\"\n                                        [attr.fill]=\"\n                                            styles?.primary ?? '#FF4338'\n                                        \"\n                                    />\n                                    <path\n                                        d=\"M29.1792 27.9773L23.7219 22.5176L23.5868 22.4243C23.5567 22.4015 23.5367 22.3677 23.5314 22.3303C23.526 22.2929 23.5356 22.2549 23.5582 22.2246C24.6088 20.8364 25.0937 19.1014 24.9151 17.3697C24.7365 15.638 23.9077 14.0385 22.5959 12.894C21.2841 11.7495 19.587 11.1452 17.847 11.203C16.1071 11.2609 14.4539 11.9766 13.221 13.2057C11.9881 14.4349 11.2674 16.0859 11.2042 17.8257C11.1411 19.5654 11.7402 21.2644 12.8807 22.5796C14.0213 23.8949 15.6182 24.7286 17.3494 24.9125C19.0806 25.0963 20.817 24.6167 22.2084 23.5703C22.2423 23.5471 22.2827 23.5353 22.3238 23.5367C22.3438 23.5396 22.363 23.5467 22.3801 23.5575C22.3972 23.5684 22.4118 23.5828 22.4228 23.5997L27.9685 29.1888C28.1287 29.3465 28.3446 29.4347 28.5694 29.4344H28.6872L28.6987 29.4246C28.8808 29.3972 29.049 29.311 29.1775 29.179C29.3355 29.019 29.4243 28.8033 29.4246 28.5785C29.4249 28.3537 29.3367 28.1377 29.1792 27.9773ZM18.1074 12.988C19.1214 12.988 20.1125 13.2887 20.9556 13.852C21.7987 14.4153 22.4558 15.216 22.8438 16.1527C23.2318 17.0895 23.3333 18.1203 23.1355 19.1147C22.9377 20.1092 22.4494 21.0227 21.7325 21.7397C21.0155 22.4566 20.102 22.9449 19.1076 23.1427C18.1131 23.3405 17.0823 23.239 16.1456 22.851C15.2088 22.4629 14.4081 21.8059 13.8448 20.9628C13.2815 20.1197 12.9808 19.1285 12.9808 18.1146C12.9847 16.7561 13.5261 15.4544 14.4867 14.4938C15.4472 13.5333 16.749 12.9919 18.1074 12.988Z\"\n                                        fill=\"white\"\n                                    />\n                                </svg>\n                            </div>\n                        </div>\n                    </div>\n                </div>\n            } @else {\n                @if (texts?.notFound) {\n                    <div class=\"m-empty\" [innerHTML]=\"texts?.notFound\"></div>\n                }\n            }\n\n            @if (texts?.title) {\n                <div class=\"m-footer\" [innerHTML]=\"texts?.title\"></div>\n            }\n        </div>\n\n        <!-- MODAL categorías (mobile) -->\n        <div\n            #categoriesModal\n            class=\"m-modal-content\"\n            id=\"categories-filter-modal\"\n            role=\"dialog\"\n            aria-modal=\"true\"\n            hidden\n        >\n            <button\n                type=\"button\"\n                class=\"m-close\"\n                (click)=\"closeModals()\"\n                aria-label=\"Cerrar\"\n                [style.--cl-color]=\"styles?.primary\"\n            >\n                ×\n            </button>\n\n            <div class=\"m-container\">\n                <div class=\"m-right\">\n                    <div class=\"m-content\">\n                        @if (texts?.categories) {\n                            <span>{{ texts?.categories }}</span>\n                        }\n                        <button\n                            type=\"button\"\n                            *ngFor=\"let f of filters?.filters\"\n                            (click)=\"filterFromModal(f)\"\n                            [class.active]=\"isFilterActive(f)\"\n                        >\n                            {{ f.text }}\n                        </button>\n                    </div>\n                </div>\n            </div>\n        </div>\n\n        <!-- MODAL habitaciones -->\n        <div\n            #roomsModal\n            class=\"m-modal-content\"\n            id=\"rooms-filter-modal\"\n            role=\"dialog\"\n            aria-modal=\"true\"\n            hidden\n        >\n            <button\n                type=\"button\"\n                class=\"m-close\"\n                (click)=\"closeModals()\"\n                aria-label=\"Cerrar\"\n                [style.--cl-color]=\"styles?.primary\"\n                m-icon\n            >\n                ×\n            </button>\n\n            <div class=\"m-container\">\n                <div class=\"m-left\">\n                    <div class=\"m-content\">\n                        @if (texts?.rooms) {\n                            <span>{{ texts?.rooms }}</span>\n                        }\n                    </div>\n                </div>\n\n                <div class=\"m-right\">\n                    <div class=\"m-content\">\n                        @if (roomOptions?.length) {\n                            <button\n                                type=\"button\"\n                                *ngFor=\"let room of roomOptions\"\n                                (click)=\"selectRoom(room.id)\"\n                                [class.active]=\"selectedRoomKey === room.id\"\n                            >\n                                {{ room.label }}\n                            </button>\n                        }\n                    </div>\n                </div>\n            </div>\n        </div>\n    </section>\n}\n"]}
231
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lis-c2-txt-img.component.js","sourceRoot":"","sources":["../../../../../../../../projects/babylon/src/lib/components/external/core/lis-c2-txt-img/lis-c2-txt-img.component.ts","../../../../../../../../projects/babylon/src/lib/components/external/core/lis-c2-txt-img/lis-c2-txt-img.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n    AfterViewInit,\n    Component,\n    ElementRef,\n    Input,\n    OnChanges,\n    OnDestroy,\n    SimpleChanges,\n    ViewChild,\n    ViewEncapsulation,\n} from '@angular/core';\nimport { Fancybox } from '@fancyapps/ui';\nimport { BabylonImageI, BabylonTextInfoI } from '../../../../interfaces';\nimport { BabylonStyleGlobalItem } from '../../../../interfaces/babylon-style.interface';\nimport defaultContent from './content.json';\n\nexport interface GalleryFilterItem {\n    id: number;\n    text: string;\n    all?: boolean;\n    room?: boolean;\n    rooms?: boolean;\n}\n\nexport interface GalleryImageItem {\n    filter: number;\n    img: BabylonImageI & { name?: string };\n    title?: string;\n}\n\nexport interface BabylonGloablsGalleryFilter {\n    leftSide?: boolean;\n    rightSide?: boolean;\n    filters: GalleryFilterItem[];\n    images: GalleryImageItem[];\n}\n\nexport interface LisC2TxtImgContent {\n    lensIcon: string;\n}\n\nconst DEFAULT_CONTENT: LisC2TxtImgContent =\n    defaultContent as LisC2TxtImgContent;\n\n@Component({\n    selector: 'lis-c2-txt-img',\n    standalone: true,\n    encapsulation: ViewEncapsulation.None,\n    imports: [CommonModule],\n    templateUrl: './lis-c2-txt-img.component.html',\n    styleUrl: './lis-c2-txt-img.component.scss',\n})\nexport class LisC2TxtImgComponent\n    implements AfterViewInit, OnChanges, OnDestroy\n{\n    @Input() content: LisC2TxtImgContent = DEFAULT_CONTENT;\n\n    @Input() filters?: BabylonGloablsGalleryFilter;\n    @Input() texts?: BabylonTextInfoI;\n    @Input() styles?: BabylonStyleGlobalItem;\n\n    @ViewChild('categoriesModal') categoriesModal?: ElementRef<HTMLElement>;\n    @ViewChild('roomsModal') roomsModal?: ElementRef<HTMLElement>;\n\n    /** null => Todas */\n    selectedFilterId: number | null = null;\n\n    /** Dentro de habitaciones: '__all__' o una clave concreta */\n    selectedRoomKey: string | null = null;\n\n    private galleryBound = false;\n\n    constructor(private host: ElementRef<HTMLElement>) {}\n\n    ngAfterViewInit(): void {\n        this.bindGallery();\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes['filters'] && !changes['filters'].firstChange) {\n            // si llega data nueva, reseteo selección a “Todas” si existe\n            this.setDefaultSelection();\n            queueMicrotask(() => this.bindGallery());\n        }\n    }\n\n    ngOnDestroy(): void {\n        this.unbindGallery();\n        this.closeModals();\n    }\n\n    /** ✅ filtro “Habitaciones” */\n    get roomsFilterId(): number | null {\n        const f = this.filters?.filters?.find((x) => !!x.rooms);\n        return typeof f?.id === 'number' ? f.id : null;\n    }\n\n    /** ✅ existe filtro habitaciones */\n    get hasRoomsFilter(): boolean {\n        return this.roomsFilterId != null;\n    }\n\n    /** ✅ para marcar “Todas” (si existe) */\n    private get allFilterId(): number | null {\n        const f = this.filters?.filters?.find((x) => !!x.all);\n        return typeof f?.id === 'number' ? f.id : null;\n    }\n\n    private setDefaultSelection(): void {\n        // Por defecto: si existe \"Todas\" lo dejamos en null (mostrar todo),\n        // si no, ponemos el primer filtro.\n        const allId = this.allFilterId;\n        if (allId != null) {\n            this.selectedFilterId = null; // null significa “mostrar todo”\n            this.selectedRoomKey = null;\n            return;\n        }\n\n        const first = this.filters?.filters?.[0]?.id ?? null;\n        this.selectedFilterId = first;\n        this.selectedRoomKey = null;\n    }\n\n    /** ✅ util: sacar label humano para habitaciones */\n    private getRoomLabelFromImage(item: GalleryImageItem): string {\n        // 1) si viene img.name (como en tu screenshot del back), lo usamos\n        /*     const n1 = (item.img as any)?.name;\n        if (typeof n1 === 'string' && n1.trim()) return n1.trim(); */\n\n        // 2) si viene title, lo usamos\n        if (item.title?.trim()) return item.title.trim();\n\n        // 3) fallback: filename de la url\n        const src = item.img?.src ?? '';\n        try {\n            const last = src.split('/').pop() ?? '';\n            const noQuery = last.split('?')[0];\n            const noExt = noQuery.replace(/\\.[a-z0-9]+$/i, '');\n            return (\n                decodeURIComponent(noExt).replace(/[_-]+/g, ' ').trim() ||\n                'Habitación'\n            );\n        } catch {\n            return 'Habitación';\n        }\n    }\n\n    get roomOptions(): { id: string; label: string }[] {\n        const rid = this.roomsFilterId;\n        if (rid == null) return [];\n\n        const imgs = (this.filters?.images ?? []).filter(\n            (i) => Number(i.filter) === Number(rid)\n        );\n\n        const labels = imgs\n            .map((i) => this.getRoomLabelFromImage(i))\n            .filter(Boolean);\n        const unique = Array.from(new Set(labels));\n\n        return [\n            { id: '__all__', label: 'Todas' },\n            ...unique.map((t) => ({ id: t, label: t })),\n        ];\n    }\n\n    /** ✅ lista filtrada real */\n    get filteredImages(): GalleryImageItem[] {\n        const imgs = this.filters?.images ?? [];\n        const rid = this.roomsFilterId;\n\n        // null => Todas\n        if (this.selectedFilterId == null) return imgs;\n\n        // Habitaciones\n        if (rid != null && Number(this.selectedFilterId) === Number(rid)) {\n            const inRooms = imgs.filter(\n                (i) => Number(i.filter) === Number(rid)\n            );\n\n            if (!this.selectedRoomKey || this.selectedRoomKey === '__all__') {\n                return inRooms;\n            }\n\n            return inRooms.filter(\n                (i) => this.getRoomLabelFromImage(i) === this.selectedRoomKey\n            );\n        }\n\n        // Resto\n        return imgs.filter(\n            (i) => Number(i.filter) === Number(this.selectedFilterId)\n        );\n    }\n\n    /** ✅ click filtro (desktop) */\n    filterBy(filter: GalleryFilterItem): void {\n        // Todas\n        if (filter.all) {\n            this.selectedFilterId = null;\n            this.selectedRoomKey = null;\n            this.closeModals();\n            return;\n        }\n\n        // Habitaciones -> modal\n        if (filter.rooms) {\n            this.selectedFilterId = filter.id;\n            this.selectedRoomKey = '__all__';\n            this.openRoomsModal();\n            return;\n        }\n\n        // normal\n        this.selectedFilterId = filter.id;\n        this.selectedRoomKey = null;\n        this.closeModals();\n    }\n\n    /** ✅ click filtro (modal categorías) */\n    filterFromModal(filter: GalleryFilterItem): void {\n        this.closeModals();\n        this.filterBy(filter);\n    }\n\n    /** ✅ seleccionar habitación (modal rooms) */\n    selectRoom(roomKey: string): void {\n        const rid = this.roomsFilterId;\n        if (rid == null) return;\n\n        this.selectedFilterId = rid;\n        this.selectedRoomKey = roomKey;\n        this.closeModals();\n    }\n\n    openCategoriesModal(): void {\n        this.openInlineModal(this.categoriesModal?.nativeElement);\n    }\n\n    openRoomsModal(): void {\n        this.openInlineModal(this.roomsModal?.nativeElement);\n    }\n\n    closeModals(): void {\n        Fancybox.close();\n    }\n\n    isFilterActive(filter: GalleryFilterItem): boolean {\n        if (filter.all) return this.selectedFilterId == null;\n        return this.selectedFilterId === filter.id;\n    }\n\n    getFancyboxGroup(): string {\n        // agrupar por selección actual (así no mezcla galleries raras)\n        if (this.selectedFilterId == null) return 'gallery-all';\n\n        const rid = this.roomsFilterId;\n        if (rid != null && Number(this.selectedFilterId) === Number(rid)) {\n            if (this.selectedRoomKey && this.selectedRoomKey !== '__all__') {\n                return `rooms-${this.selectedRoomKey}`;\n            }\n            return 'rooms-all';\n        }\n\n        return `gallery-${this.selectedFilterId}`;\n    }\n\n    trackByIndex(index: number): number {\n        return index;\n    }\n\n    /** Fancybox */\n    private bindGallery(): void {\n        this.unbindGallery();\n\n        const hostElement = this.host.nativeElement;\n        if (!hostElement.querySelector('[data-fancybox]')) return;\n\n        Fancybox.bind(hostElement, '[data-fancybox]', {\n            dragToClose: false,\n        });\n\n        this.galleryBound = true;\n    }\n\n    private unbindGallery(): void {\n        if (!this.galleryBound) return;\n\n        Fancybox.unbind(this.host.nativeElement);\n        this.galleryBound = false;\n    }\n\n    private openInlineModal(content?: HTMLElement): void {\n        if (!content) return;\n\n        const selector = content.id ? `#${content.id}` : null;\n        if (!selector) return;\n\n        content.removeAttribute('hidden');\n\n        Fancybox.close();\n        Fancybox.show([{ src: selector, type: 'inline' }], {\n            dragToClose: false,\n            hideScrollbar: true,\n            on: {\n                destroy: () => content.setAttribute('hidden', ''),\n            },\n        });\n    }\n}\n","@if (filters?.filters?.length) {\n    <section class=\"mdl-mdh002galeria\">\n        <div class=\"mdl-container\">\n            <div class=\"m-filters\">\n                <!-- DESKTOP -->\n                <div class=\"m-desktop-filters\">\n                    <div\n                        class=\"m-filter\"\n                        *ngFor=\"let f of filters?.filters\"\n                        (click)=\"filterBy(f)\"\n                        [class.active]=\"isFilterActive(f)\"\n                    >\n                        {{ f.text }}\n                    </div>\n                </div>\n\n                <!-- MOBILE -->\n                <div class=\"m-mobile-filters\">\n                    <div class=\"m-select\" (click)=\"openCategoriesModal()\">\n                        @if (texts?.categories) {\n                            <div>{{ texts?.categories }}</div>\n                        }\n                        <svg\n                            width=\"17\"\n                            height=\"11\"\n                            viewBox=\"0 0 17 11\"\n                            fill=\"none\"\n                            xmlns=\"http://www.w3.org/2000/svg\"\n                        >\n                            <g opacity=\"0.5\">\n                                <path\n                                    d=\"M16.0193 0H0V0.804475H16.0193V0Z\"\n                                    fill=\"#515050\"\n                                />\n                                <path\n                                    d=\"M16.0193 4.67969H0V5.4846H16.0193V4.67969Z\"\n                                    fill=\"#515050\"\n                                />\n                                <path\n                                    d=\"M16.0193 9.36328H0V10.1678H16.0193V9.36328Z\"\n                                    fill=\"#515050\"\n                                />\n                            </g>\n                        </svg>\n                    </div>\n\n                    @if (hasRoomsFilter) {\n                        <div class=\"m-select\" (click)=\"openRoomsModal()\">\n                            @if (texts?.rooms) {\n                                <div>{{ texts?.rooms }}</div>\n                            }\n                            <svg\n                                width=\"17\"\n                                height=\"11\"\n                                viewBox=\"0 0 17 11\"\n                                fill=\"none\"\n                                xmlns=\"http://www.w3.org/2000/svg\"\n                            >\n                                <g opacity=\"0.5\">\n                                    <path\n                                        d=\"M16.0193 0H0V0.804475H16.0193V0Z\"\n                                        fill=\"#515050\"\n                                    />\n                                    <path\n                                        d=\"M16.0193 4.67969H0V5.4846H16.0193V4.67969Z\"\n                                        fill=\"#515050\"\n                                    />\n                                    <path\n                                        d=\"M16.0193 9.36328H0V10.1678H16.0193V9.36328Z\"\n                                        fill=\"#515050\"\n                                    />\n                                </g>\n                            </svg>\n                        </div>\n                    }\n                </div>\n            </div>\n\n            <!-- GRID -->\n            @if (filteredImages?.length) {\n                <div class=\"m-gal-grid\">\n                    <div\n                        class=\"m-gal-item\"\n                        *ngFor=\"\n                            let item of filteredImages;\n                            trackBy: trackByIndex\n                        \"\n                    >\n                        <a\n                            class=\"m-media\"\n                            [href]=\"item.img?.src\"\n                            [attr.data-fancybox]=\"getFancyboxGroup()\"\n                            [attr.data-caption]=\"item.title ?? ''\"\n                        >\n                            <img\n                                [src]=\"item.img?.src\"\n                                [alt]=\"item.img?.alt || ''\"\n                            />\n                        </a>\n\n                        <div class=\"m-item-footer\">\n                            <span>{{ item.title || '' }}</span>\n                            <div class=\"m-icon\">\n                                <!-- <img [src]=\"content.lensIcon\" alt=\"name\" /> -->\n                                <svg\n                                    width=\"50\"\n                                    height=\"50\"\n                                    viewBox=\"0 0 40 40\"\n                                    fill=\"none\"\n                                    xmlns=\"http://www.w3.org/2000/svg\"\n                                >\n                                    <rect\n                                        width=\"50\"\n                                        height=\"50\"\n                                        [attr.fill]=\"\n                                            styles?.primary ?? '#FF4338'\n                                        \"\n                                    />\n                                    <path\n                                        d=\"M29.1792 27.9773L23.7219 22.5176L23.5868 22.4243C23.5567 22.4015 23.5367 22.3677 23.5314 22.3303C23.526 22.2929 23.5356 22.2549 23.5582 22.2246C24.6088 20.8364 25.0937 19.1014 24.9151 17.3697C24.7365 15.638 23.9077 14.0385 22.5959 12.894C21.2841 11.7495 19.587 11.1452 17.847 11.203C16.1071 11.2609 14.4539 11.9766 13.221 13.2057C11.9881 14.4349 11.2674 16.0859 11.2042 17.8257C11.1411 19.5654 11.7402 21.2644 12.8807 22.5796C14.0213 23.8949 15.6182 24.7286 17.3494 24.9125C19.0806 25.0963 20.817 24.6167 22.2084 23.5703C22.2423 23.5471 22.2827 23.5353 22.3238 23.5367C22.3438 23.5396 22.363 23.5467 22.3801 23.5575C22.3972 23.5684 22.4118 23.5828 22.4228 23.5997L27.9685 29.1888C28.1287 29.3465 28.3446 29.4347 28.5694 29.4344H28.6872L28.6987 29.4246C28.8808 29.3972 29.049 29.311 29.1775 29.179C29.3355 29.019 29.4243 28.8033 29.4246 28.5785C29.4249 28.3537 29.3367 28.1377 29.1792 27.9773ZM18.1074 12.988C19.1214 12.988 20.1125 13.2887 20.9556 13.852C21.7987 14.4153 22.4558 15.216 22.8438 16.1527C23.2318 17.0895 23.3333 18.1203 23.1355 19.1147C22.9377 20.1092 22.4494 21.0227 21.7325 21.7397C21.0155 22.4566 20.102 22.9449 19.1076 23.1427C18.1131 23.3405 17.0823 23.239 16.1456 22.851C15.2088 22.4629 14.4081 21.8059 13.8448 20.9628C13.2815 20.1197 12.9808 19.1285 12.9808 18.1146C12.9847 16.7561 13.5261 15.4544 14.4867 14.4938C15.4472 13.5333 16.749 12.9919 18.1074 12.988Z\"\n                                        fill=\"white\"\n                                    />\n                                </svg>\n                            </div>\n                        </div>\n                    </div>\n                </div>\n            } @else {\n                @if (texts?.notFound) {\n                    <div class=\"m-empty\" [innerHTML]=\"texts?.notFound\"></div>\n                }\n            }\n\n            @if (texts?.title) {\n                <div class=\"m-footer\" [innerHTML]=\"texts?.title\"></div>\n            }\n        </div>\n\n        <!-- MODAL categorías (mobile) -->\n        <div\n            #categoriesModal\n            class=\"m-modal-content\"\n            id=\"categories-filter-modal\"\n            role=\"dialog\"\n            aria-modal=\"true\"\n            hidden\n        >\n            <button\n                type=\"button\"\n                class=\"m-close\"\n                (click)=\"closeModals()\"\n                aria-label=\"Cerrar\"\n                [style.--cl-color]=\"styles?.primary\"\n            >\n                ×\n            </button>\n\n            <div class=\"m-container\">\n                <div class=\"m-right\">\n                    <div class=\"m-content\">\n                        @if (texts?.categories) {\n                            <span>{{ texts?.categories }}</span>\n                        }\n                        <button\n                            type=\"button\"\n                            *ngFor=\"let f of filters?.filters\"\n                            (click)=\"filterFromModal(f)\"\n                            [class.active]=\"isFilterActive(f)\"\n                        >\n                            {{ f.text }}\n                        </button>\n                    </div>\n                </div>\n            </div>\n        </div>\n\n        <!-- MODAL habitaciones -->\n        <div\n            #roomsModal\n            class=\"m-modal-content\"\n            id=\"rooms-filter-modal\"\n            role=\"dialog\"\n            aria-modal=\"true\"\n            hidden\n        >\n            <button\n                type=\"button\"\n                class=\"m-close\"\n                (click)=\"closeModals()\"\n                aria-label=\"Cerrar\"\n                [style.--cl-color]=\"styles?.primary\"\n                m-icon\n            >\n                ×\n            </button>\n\n            <div class=\"m-container\">\n                <div class=\"m-left\">\n                    <div class=\"m-content\">\n                        @if (texts?.rooms) {\n                            <span>{{ texts?.rooms }}</span>\n                        }\n                    </div>\n                </div>\n\n                <div class=\"m-right\">\n                    <div class=\"m-content\">\n                        @if (roomOptions?.length) {\n                            <button\n                                type=\"button\"\n                                *ngFor=\"let room of roomOptions\"\n                                (click)=\"selectRoom(room.id)\"\n                                [class.active]=\"selectedRoomKey === room.id\"\n                            >\n                                {{ room.label }}\n                            </button>\n                        }\n                    </div>\n                </div>\n            </div>\n        </div>\n    </section>\n}\n"]}