ctt-puro 0.46.6 → 0.46.7

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.
@@ -18,7 +18,14 @@ export class PuroGalleryComponent {
18
18
  });
19
19
  }
20
20
  ngOnInit() {
21
- this.filterSelected.set(this.filters?.find((f) => f.all));
21
+ // Si existe, seleccionar "Todos"
22
+ const allFilter = this.filters?.find((f) => f.all);
23
+ if (allFilter) {
24
+ this.filterSelected.set(allFilter);
25
+ }
26
+ else {
27
+ this.filterSelected.set(this.filters?.[0]);
28
+ }
22
29
  }
23
30
  // filtros normales (no rooms)
24
31
  filterItems(filter) {
@@ -72,4 +79,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
72
79
  }], textColors: [{
73
80
  type: Input
74
81
  }] } });
75
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"puro-gallery.component.js","sourceRoot":"","sources":["../../../../../../projects/puro/src/lib/components/puro-gallery/puro-gallery.component.ts","../../../../../../projects/puro/src/lib/components/puro-gallery/puro-gallery.component.html"],"names":[],"mappings":"AAAA,OAAO,EACH,YAAY,EACZ,gBAAgB,GACnB,MAAM,iBAAiB,CAAC;AACzB,OAAO,EACH,uBAAuB,EACvB,SAAS,EACT,KAAK,EACL,QAAQ,EACR,MAAM,GACT,MAAM,eAAe,CAAC;AACvB,OAAO,EACH,6BAA6B,EAC7B,wBAAwB,EACxB,0BAA0B,EAC1B,qBAAqB,GACxB,MAAM,kBAAkB,CAAC;AAQ1B,OAAO,EAAE,2BAA2B,EAAE,MAAM,mCAAmC,CAAC;;;AAkBhF,MAAM,OAAO,oBAAoB;IA0B7B,YAA6B,UAA6B;QAA7B,eAAU,GAAV,UAAU,CAAmB;QAhB1D,mBAAc,GAAG,MAAM,CAAgC,SAAS,CAAC,CAAC;QAElE,wBAAwB;QACxB,sBAAiB,GAAG,QAAQ,CAAC,GAAG,EAAE,CAC9B,CAAC,IAAI,CAAC,OAAO,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAC9C,CAAC;QACF,iBAAY,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,OAAO,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;QAE1E,mBAAc,GAAG,QAAQ,CAAC,GAAG,EAAE;YAC3B,IAAI,IAAI,CAAC,cAAc,EAAE,EAAE,GAAG,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE;gBACpD,OAAO,IAAI,CAAC,KAAK,CAAC;YACtB,OAAO,IAAI,CAAC,KAAK,EAAE,MAAM,CACrB,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,IAAI,CAAC,cAAc,EAAE,EAAE,EAAE,CAChD,CAAC;QACN,CAAC,CAAC,CAAC;IAE0D,CAAC;IAE9D,QAAQ;QACJ,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;IAC9D,CAAC;IAED,8BAA8B;IAC9B,WAAW,CAAC,MAA0B;QAClC,IAAI,CAAC,MAAM;YAAE,OAAO;QAEpB,iCAAiC;QACjC,IAAI,MAAM,CAAC,KAAK,EAAE;YACd,IAAI,CAAC,iBAAiB,EAAE,CAAC;YACzB,OAAO;SACV;QAED,yCAAyC;QACzC,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;IACpC,CAAC;IAED,oDAAoD;IACpD,iBAAiB;QACb,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;QACvD,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC;YACtB,KAAK,EAAE,IAAI,CAAC,SAAS;YACrB,OAAO,EAAE,IAAI;YACb,QAAQ,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC,CAAC;SAC9C,CAAC,CAAC;IACP,CAAC;+GAtDQ,oBAAoB;mGAApB,oBAAoB,oPC1CjC,yrMA6JA,yDD/HQ,YAAY,+BACZ,2BAA2B,iIAC3B,qBAAqB,4IACrB,wBAAwB,0DACxB,0BAA0B,kHAC1B,gBAAgB,gPAChB,6BAA6B;;4FAMxB,oBAAoB;kBAhBhC,SAAS;+BACI,kBAAkB,cAChB,IAAI,WACP;wBACL,YAAY;wBACZ,2BAA2B;wBAC3B,qBAAqB;wBACrB,wBAAwB;wBACxB,0BAA0B;wBAC1B,gBAAgB;wBAChB,6BAA6B;qBAChC,mBAGgB,uBAAuB,CAAC,MAAM;sFAGtC,QAAQ;sBAAhB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,UAAU;sBAAlB,KAAK","sourcesContent":["import {\n    CommonModule,\n    NgOptimizedImage,\n} from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    Input,\n    computed,\n    signal,\n} from '@angular/core';\nimport {\n    AutoImageZoomWrapperDirective,\n    PuroActiveModalDirective,\n    PuroFilterGalleryDirective,\n    PuroLinkTypeDirective,\n} from '../../directives';\nimport {\n    PuroButtonI,\n    PuroImageI,\n    PuroTagsI,\n    PuroTextsColorsI,\n} from '../../interfaces';\nimport { ModalStateService } from '../../services';\nimport { PuroDynamicHeadingComponent } from '../../shared/puro-dynamic-heading';\n\n@Component({\n    selector: 'lib-puro-gallery',\n    standalone: true,\n    imports: [\n        CommonModule,\n        PuroDynamicHeadingComponent,\n        PuroLinkTypeDirective,\n        PuroActiveModalDirective,\n        PuroFilterGalleryDirective,\n        NgOptimizedImage,\n        AutoImageZoomWrapperDirective,\n    ],\n    templateUrl: './puro-gallery.component.html',\n    styleUrl: './puro-gallery.component.scss',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class PuroGalleryComponent {\n    @Input() pretitle?: string;\n    @Input() title?: string;\n    @Input() roomTitle?: string;\n    @Input() filters?: PuroGalleryFilter[];\n    @Input() items?: PuroGalleryItem[];\n    @Input() button?: PuroButtonI;\n    @Input() tags?: PuroTagsI;\n    @Input() textColors?: PuroTextsColorsI;\n\n    filterSelected = signal<PuroGalleryFilter | undefined>(undefined);\n\n    // Listas filtros mobile\n    categoriesFilters = computed(() =>\n        (this.filters ?? []).filter((f) => !f.room)\n    );\n    roomsFilters = computed(() => (this.filters ?? []).filter((f) => f.room));\n\n    itemsDisplayed = computed(() => {\n        if (this.filterSelected()?.all || !this.filterSelected())\n            return this.items;\n        return this.items?.filter(\n            (i) => i.filter === this.filterSelected()?.id\n        );\n    });\n\n    constructor(private readonly modalState: ModalStateService) {}\n\n    ngOnInit(): void {\n        this.filterSelected.set(this.filters?.find((f) => f.all));\n    }\n\n    // filtros normales (no rooms)\n    filterItems(filter?: PuroGalleryFilter): void {\n        if (!filter) return;\n\n        // Agregador \"Rooms\": abrir modal\n        if (filter.rooms) {\n            this.prepareRoomsModal();\n            return;\n        }\n\n        // Categoría normal o habitación concreta\n        this.filterSelected.set(filter);\n    }\n\n    // preparar datos para el modal antes/justo al click\n    prepareRoomsModal(): void {\n        const list = this.filters?.filter((f) => f.room) ?? [];\n        this.modalState.openRooms({\n            title: this.roomTitle,\n            filters: list,\n            onSelect: (f) => this.filterSelected.set(f),\n        });\n    }\n}\n\nexport interface PuroGalleryItem {\n    img?: PuroImageI;\n    title?: string;\n    filter?: number;\n}\nexport interface PuroGalleryFilter {\n    id: number;\n    text?: string;\n    rooms?: boolean; // “Rooms” tab\n    room?: boolean; // cada habitación dentro del modal\n    all?: boolean;\n}\n","<section class=\"gallery gallery--withTabs generalMargin\">\n    @if (pretitle) {\n        <lib-puro-dynamic-heading\n            [tag]=\"tags?.pretitle || 'span'\"\n            cssClass=\"gallery__title\"\n            [color]=\"textColors?.pretitle\"\n            [content]=\"pretitle\"\n        ></lib-puro-dynamic-heading>\n    }\n    @if (title) {\n        <lib-puro-dynamic-heading\n            [tag]=\"tags?.title || 'h2'\"\n            cssClass=\"gallery__heading\"\n            [color]=\"textColors?.title\"\n            [content]=\"title\"\n        ></lib-puro-dynamic-heading>\n    }\n\n    @if (categoriesFilters()) {\n        <ul class=\"gallery__tabs\">\n            @for (option of categoriesFilters(); track $index) {\n                <!-- Filtros normales -->\n                @if (!option.rooms) {\n                    <li\n                        role=\"button\"\n                        class=\"js-filter-gallery\"\n                        [filterGallery]=\"option\"\n                        (filterSelect)=\"filterItems($event)\"\n                        [class.active]=\"\n                            !filterSelected()?.room &&\n                            (option.all\n                                ? !!filterSelected()?.all\n                                : filterSelected()?.id === option.id)\n                        \"\n                        [attr.aria-selected]=\"\n                            !filterSelected()?.room &&\n                            (option.all\n                                ? !!filterSelected()?.all\n                                : filterSelected()?.id === option.id)\n                        \"\n                        [attr.data-filter_category]=\"option.id\"\n                        [attr.aria-label]=\"option.text\"\n                    >\n                        {{ option.text }}\n                    </li>\n                }\n\n                <!-- Rooms: MISMO patrón que languages -->\n                @if (option.rooms) {\n                    <li\n                        class=\"js-active-modal\"\n                        activeModal\n                        data-modal_name=\"filter\"\n                        role=\"button\"\n                        (click)=\"prepareRoomsModal()\"\n                        [attr.aria-label]=\"option.text || 'Rooms'\"\n                    >\n                        {{ option.text }}\n                    </li>\n                }\n            }\n        </ul>\n        <!-- Categorías (sin rooms ni room:true) -->\n        <div class=\"form__group withIcon\">\n            <select\n                class=\"form__control\"\n                [filterGallery]=\"categoriesFilters()\"\n                (filterSelect)=\"filterItems($event)\"\n            >\n                <option value=\"\" selected disabled>Categorías</option>\n                @for (option of categoriesFilters(); track $index) {\n                    @if (!option.rooms && !option.room) {\n                        <option [value]=\"option.id\">{{ option.text }}</option>\n                    }\n                }\n            </select>\n            <span class=\"icon-right\">\n                <svg aria-hidden=\"true\" focusable=\"false\" width=\"15\" height=\"8\">\n                    <use href=\"#select-arrow\"></use>\n                </svg>\n            </span>\n        </div>\n\n        <!-- Habitaciones (room:true) -->\n        <div class=\"form__group withIcon\">\n            <select\n                class=\"form__control\"\n                [filterGallery]=\"roomsFilters()\"\n                (filterSelect)=\"filterItems($event)\"\n            >\n                <option value=\"\" selected disabled>Habitaciones</option>\n                @for (option of roomsFilters(); track $index) {\n                    <option [value]=\"option.id\">{{ option.text }}</option>\n                }\n            </select>\n            <span class=\"icon-right\">\n                <svg aria-hidden=\"true\" focusable=\"false\" width=\"15\" height=\"8\">\n                    <use href=\"#select-arrow\"></use>\n                </svg>\n            </span>\n        </div>\n    }\n\n    <div class=\"gallery__list galleryGrid__for-7\">\n        @if (itemsDisplayed()) {\n            @for (item of itemsDisplayed(); track $index) {\n                <div\n                    class=\"gallery__item show\"\n                    [attr.data-category]=\"item.filter\"\n                    [attr.data-title]=\"item.title\"\n                >\n                    <div\n                        role=\"button\"\n                        class=\"gallery__box js-active-modal\"\n                        activeModal\n                        data-modal_name=\"gallery\"\n                        [attr.aria-label]=\"item.title ?? 'Gallery Item'\"\n                        [attr.data-img]=\"item.img?.src\"\n                        [attr.data-title]=\"item.title\"\n                    >\n                        <div class=\"gallery__graphic\">\n                            @if (item.img) {\n                                <img\n                                    [ngSrc]=\"item.img.src\"\n                                    width=\"789\"\n                                    height=\"747\"\n                                    class=\"gallery__graphic--img\"\n                                    [alt]=\"item.title\"\n                                    fetchpriority=\"high\"\n                                    priority\n                                />\n                                <div class=\"gallery__zoom\">\n                                    <span>{{ item.title }}</span>\n                                    <i class=\"icon-84\"></i>\n                                </div>\n                            }\n                        </div>\n                    </div>\n                </div>\n            }\n        }\n    </div>\n\n    @if (button) {\n        <div class=\"btn__group\">\n            <a\n                [href]=\"button.url\"\n                class=\"btn btn__primary--outline\"\n                puroLinkType\n                [linkType]=\"button.linkType\"\n                [attr.aria-label]=\"button.label\"\n            >\n                <span>{{ button.label }}</span>\n            </a>\n        </div>\n    }\n</section>\n"]}
82
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"puro-gallery.component.js","sourceRoot":"","sources":["../../../../../../projects/puro/src/lib/components/puro-gallery/puro-gallery.component.ts","../../../../../../projects/puro/src/lib/components/puro-gallery/puro-gallery.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    CommonModule,\n    NgOptimizedImage,\n} from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    Input,\n    computed,\n    signal,\n} from '@angular/core';\nimport {\n    AutoImageZoomWrapperDirective,\n    PuroActiveModalDirective,\n    PuroFilterGalleryDirective,\n    PuroLinkTypeDirective,\n} from '../../directives';\nimport {\n    PuroButtonI,\n    PuroImageI,\n    PuroTagsI,\n    PuroTextsColorsI,\n} from '../../interfaces';\nimport { ModalStateService } from '../../services';\nimport { PuroDynamicHeadingComponent } from '../../shared/puro-dynamic-heading';\n\n@Component({\n    selector: 'lib-puro-gallery',\n    standalone: true,\n    imports: [\n        CommonModule,\n        PuroDynamicHeadingComponent,\n        PuroLinkTypeDirective,\n        PuroActiveModalDirective,\n        PuroFilterGalleryDirective,\n        NgOptimizedImage,\n        AutoImageZoomWrapperDirective,\n    ],\n    templateUrl: './puro-gallery.component.html',\n    styleUrl: './puro-gallery.component.scss',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class PuroGalleryComponent {\n    @Input() pretitle?: string;\n    @Input() title?: string;\n    @Input() roomTitle?: string;\n    @Input() filters?: PuroGalleryFilter[];\n    @Input() items?: PuroGalleryItem[];\n    @Input() button?: PuroButtonI;\n    @Input() tags?: PuroTagsI;\n    @Input() textColors?: PuroTextsColorsI;\n\n    filterSelected = signal<PuroGalleryFilter | undefined>(undefined);\n\n    // Listas filtros mobile\n    categoriesFilters = computed(() =>\n        (this.filters ?? []).filter((f) => !f.room)\n    );\n    roomsFilters = computed(() => (this.filters ?? []).filter((f) => f.room));\n\n    itemsDisplayed = computed(() => {\n        if (this.filterSelected()?.all || !this.filterSelected())\n            return this.items;\n        return this.items?.filter(\n            (i) => i.filter === this.filterSelected()?.id\n        );\n    });\n\n    constructor(private readonly modalState: ModalStateService) {}\n\n    ngOnInit(): void {\n        // Si existe, seleccionar \"Todos\"\n        const allFilter = this.filters?.find((f) => f.all);\n\n        if (allFilter) {\n            this.filterSelected.set(allFilter);\n        } else {\n            this.filterSelected.set(this.filters?.[0]);\n        }\n    }\n\n    // filtros normales (no rooms)\n    filterItems(filter?: PuroGalleryFilter): void {\n        if (!filter) return;\n\n        // Agregador \"Rooms\": abrir modal\n        if (filter.rooms) {\n            this.prepareRoomsModal();\n            return;\n        }\n\n        // Categoría normal o habitación concreta\n        this.filterSelected.set(filter);\n    }\n\n    // preparar datos para el modal antes/justo al click\n    prepareRoomsModal(): void {\n        const list = this.filters?.filter((f) => f.room) ?? [];\n        this.modalState.openRooms({\n            title: this.roomTitle,\n            filters: list,\n            onSelect: (f) => this.filterSelected.set(f),\n        });\n    }\n}\n\nexport interface PuroGalleryItem {\n    img?: PuroImageI;\n    title?: string;\n    filter?: number;\n}\nexport interface PuroGalleryFilter {\n    id: number;\n    text?: string;\n    rooms?: boolean; // “Rooms” tab\n    room?: boolean; // cada habitación dentro del modal\n    all?: boolean;\n}\n","<section class=\"gallery gallery--withTabs generalMargin\">\n    @if (pretitle) {\n        <lib-puro-dynamic-heading\n            [tag]=\"tags?.pretitle || 'span'\"\n            cssClass=\"gallery__title\"\n            [color]=\"textColors?.pretitle\"\n            [content]=\"pretitle\"\n        ></lib-puro-dynamic-heading>\n    }\n    @if (title) {\n        <lib-puro-dynamic-heading\n            [tag]=\"tags?.title || 'h2'\"\n            cssClass=\"gallery__heading\"\n            [color]=\"textColors?.title\"\n            [content]=\"title\"\n        ></lib-puro-dynamic-heading>\n    }\n\n    @if (categoriesFilters()) {\n        <ul class=\"gallery__tabs\">\n            @for (option of categoriesFilters(); track $index) {\n                <!-- Filtros normales -->\n                @if (!option.rooms) {\n                    <li\n                        role=\"button\"\n                        class=\"js-filter-gallery\"\n                        [filterGallery]=\"option\"\n                        (filterSelect)=\"filterItems($event)\"\n                        [class.active]=\"\n                            !filterSelected()?.room &&\n                            (option.all\n                                ? !!filterSelected()?.all\n                                : filterSelected()?.id === option.id)\n                        \"\n                        [attr.aria-selected]=\"\n                            !filterSelected()?.room &&\n                            (option.all\n                                ? !!filterSelected()?.all\n                                : filterSelected()?.id === option.id)\n                        \"\n                        [attr.data-filter_category]=\"option.id\"\n                        [attr.aria-label]=\"option.text\"\n                    >\n                        {{ option.text }}\n                    </li>\n                }\n\n                <!-- Rooms: MISMO patrón que languages -->\n                @if (option.rooms) {\n                    <li\n                        class=\"js-active-modal\"\n                        activeModal\n                        data-modal_name=\"filter\"\n                        role=\"button\"\n                        (click)=\"prepareRoomsModal()\"\n                        [attr.aria-label]=\"option.text || 'Rooms'\"\n                    >\n                        {{ option.text }}\n                    </li>\n                }\n            }\n        </ul>\n        <!-- Categorías (sin rooms ni room:true) -->\n        <div class=\"form__group withIcon\">\n            <select\n                class=\"form__control\"\n                [filterGallery]=\"categoriesFilters()\"\n                (filterSelect)=\"filterItems($event)\"\n            >\n                <option value=\"\" selected disabled>Categorías</option>\n                @for (option of categoriesFilters(); track $index) {\n                    @if (!option.rooms && !option.room) {\n                        <option [value]=\"option.id\">{{ option.text }}</option>\n                    }\n                }\n            </select>\n            <span class=\"icon-right\">\n                <svg aria-hidden=\"true\" focusable=\"false\" width=\"15\" height=\"8\">\n                    <use href=\"#select-arrow\"></use>\n                </svg>\n            </span>\n        </div>\n\n        <!-- Habitaciones (room:true) -->\n        <div class=\"form__group withIcon\">\n            <select\n                class=\"form__control\"\n                [filterGallery]=\"roomsFilters()\"\n                (filterSelect)=\"filterItems($event)\"\n            >\n                <option value=\"\" selected disabled>Habitaciones</option>\n                @for (option of roomsFilters(); track $index) {\n                    <option [value]=\"option.id\">{{ option.text }}</option>\n                }\n            </select>\n            <span class=\"icon-right\">\n                <svg aria-hidden=\"true\" focusable=\"false\" width=\"15\" height=\"8\">\n                    <use href=\"#select-arrow\"></use>\n                </svg>\n            </span>\n        </div>\n    }\n\n    <div class=\"gallery__list galleryGrid__for-7\">\n        @if (itemsDisplayed()) {\n            @for (item of itemsDisplayed(); track $index) {\n                <div\n                    class=\"gallery__item show\"\n                    [attr.data-category]=\"item.filter\"\n                    [attr.data-title]=\"item.title\"\n                >\n                    <div\n                        role=\"button\"\n                        class=\"gallery__box js-active-modal\"\n                        activeModal\n                        data-modal_name=\"gallery\"\n                        [attr.aria-label]=\"item.title ?? 'Gallery Item'\"\n                        [attr.data-img]=\"item.img?.src\"\n                        [attr.data-title]=\"item.title\"\n                    >\n                        <div class=\"gallery__graphic\">\n                            @if (item.img) {\n                                <img\n                                    [ngSrc]=\"item.img.src\"\n                                    width=\"789\"\n                                    height=\"747\"\n                                    class=\"gallery__graphic--img\"\n                                    [alt]=\"item.title\"\n                                    fetchpriority=\"high\"\n                                    priority\n                                />\n                                <div class=\"gallery__zoom\">\n                                    <span>{{ item.title }}</span>\n                                    <i class=\"icon-84\"></i>\n                                </div>\n                            }\n                        </div>\n                    </div>\n                </div>\n            }\n        }\n    </div>\n\n    @if (button) {\n        <div class=\"btn__group\">\n            <a\n                [href]=\"button.url\"\n                class=\"btn btn__primary--outline\"\n                puroLinkType\n                [linkType]=\"button.linkType\"\n                [attr.aria-label]=\"button.label\"\n            >\n                <span>{{ button.label }}</span>\n            </a>\n        </div>\n    }\n</section>\n"]}