ng-easycommerce-v18 0.2.1 → 0.2.2

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.
Files changed (43) hide show
  1. package/assets/ec-i18n/ct.json +2 -1
  2. package/assets/ec-i18n/en.json +2 -1
  3. package/assets/ec-i18n/es.json +1 -0
  4. package/assets/ec-i18n/fr.json +2 -1
  5. package/assets/ec-i18n/gl.json +2 -1
  6. package/assets/ec-i18n/pr.json +2 -1
  7. package/esm2022/lib/classes/filters/filter-factory.mjs +4 -1
  8. package/esm2022/lib/classes/filters/price_range-filter.mjs +59 -0
  9. package/esm2022/lib/ec-components/auth-ec/login-form-ec/login-form-ec.component.mjs +3 -3
  10. package/esm2022/lib/ec-components/blocks-ec/block-products-ec/block-products-ec.component.mjs +3 -2
  11. package/esm2022/lib/ec-components/cart-ec/cart-ec.component.mjs +9 -1
  12. package/esm2022/lib/ec-components/checkout-ec/dataform-ec/dataform-ec.component.mjs +24 -3
  13. package/esm2022/lib/ec-components/collection-ec/collection-ec.component.mjs +1 -5
  14. package/esm2022/lib/ec-components/coupon-ec/coupon-ec.component.mjs +3 -3
  15. package/esm2022/lib/ec-components/filters-ec/filters-ec.component.mjs +38 -91
  16. package/esm2022/lib/ec-components/index.mjs +2 -1
  17. package/esm2022/lib/ec-components/price-range-filter/price-range-filter.component.mjs +143 -0
  18. package/esm2022/lib/ec-components/product-detail-ec/product-detail-ec.component.mjs +39 -3
  19. package/esm2022/lib/ec-components/product-ec/product-ec.component.mjs +16 -2
  20. package/esm2022/lib/ec-components/widgets-ec/price-ec/price-ec.component.mjs +73 -10
  21. package/esm2022/lib/ec-services/filters.service.mjs +45 -12
  22. package/esm2022/lib/ec-services/pagination.service.mjs +8 -7
  23. package/esm2022/lib/ec-services/product-detail.service.mjs +50 -35
  24. package/esm2022/lib/ec-services/products.service.mjs +18 -4
  25. package/esm2022/lib/interfaces/filter.mjs +1 -1
  26. package/esm2022/lib/interfaces/pagination.mjs +1 -1
  27. package/fesm2022/ng-easycommerce-v18.mjs +504 -166
  28. package/fesm2022/ng-easycommerce-v18.mjs.map +1 -1
  29. package/lib/classes/filters/price_range-filter.d.ts +26 -0
  30. package/lib/ec-components/cart-ec/cart-ec.component.d.ts +1 -0
  31. package/lib/ec-components/checkout-ec/dataform-ec/dataform-ec.component.d.ts +1 -0
  32. package/lib/ec-components/filters-ec/filters-ec.component.d.ts +7 -22
  33. package/lib/ec-components/index.d.ts +1 -0
  34. package/lib/ec-components/price-range-filter/price-range-filter.component.d.ts +37 -0
  35. package/lib/ec-components/product-detail-ec/product-detail-ec.component.d.ts +4 -0
  36. package/lib/ec-components/product-ec/product-ec.component.d.ts +1 -0
  37. package/lib/ec-components/widgets-ec/price-ec/price-ec.component.d.ts +30 -10
  38. package/lib/ec-services/filters.service.d.ts +6 -1
  39. package/lib/ec-services/product-detail.service.d.ts +4 -4
  40. package/lib/ec-services/products.service.d.ts +1 -0
  41. package/lib/interfaces/filter.d.ts +1 -1
  42. package/lib/interfaces/pagination.d.ts +2 -0
  43. package/package.json +1 -1
@@ -49,10 +49,6 @@ export class CollectionEcComponent {
49
49
  type: params['type'] || null,
50
50
  value: params['value'] || null
51
51
  };
52
- //console.log(ready,"actualizar")
53
- console.log(paginationSettings);
54
- /* console.log(paginationSettings) */
55
- // console.log('params',queryParams["search"])
56
52
  this._productsService.getProductsForFilter(paginationSettings, queryParams["search"]);
57
53
  }
58
54
  });
@@ -70,4 +66,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
70
66
  }], ctorParameters: () => [], propDecorators: { optionsFilters: [{
71
67
  type: Input
72
68
  }] } });
73
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"collection-ec.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/collection-ec/collection-ec.component.ts","../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/collection-ec/collection-ec.component.html"],"names":[],"mappings":"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","sourcesContent":["import { afterNextRender, Component, HostListener, inject, Input, OnInit, PLATFORM_ID, signal } from '@angular/core';\r\nimport { DefaultFilter, FilterType, PaginationSettings, Product } from '../../interfaces';\r\nimport { AuthService, FiltersService, OptionsService, ProductsService } from '../../ec-services';\r\nimport { ActivatedRoute } from '@angular/router';\r\nimport { CoreConstantsService } from '../../constants';\r\nimport { combineLatest, forkJoin, map, Observable, take } from 'rxjs';\r\nimport { Filter } from '../../classes';\r\nimport { InfiniteScrollDirective } from \"ngx-infinite-scroll\";\r\nimport { isPlatformBrowser } from '@angular/common';\r\n@Component({\r\n\tselector: 'lib-collection-ec',\r\n\tstandalone: true,\r\n\timports: [InfiniteScrollDirective],\r\n\ttemplateUrl: './collection-ec.component.html',\r\n\tstyleUrl: './collection-ec.component.scss'\r\n})\r\nexport class CollectionEcComponent implements OnInit {\r\n\r\n\tprotected _productsService: ProductsService = inject(ProductsService)\r\n\tprotected _activeRoute: ActivatedRoute = inject(ActivatedRoute)\r\n\tprotected _optionsService: OptionsService = inject(OptionsService)\r\n\r\n\tpublic params$ = this._activeRoute.params\r\n\t//public ready = this._optionsService.ready\r\n\tpublic queryParams$ = this._activeRoute.queryParams\r\n\tpublic products$ = this._productsService.products$\r\n\t//public products$ = []\r\n\r\n\tpublic authService: AuthService = inject(AuthService)\r\n\tpublic constanst: CoreConstantsService = inject(CoreConstantsService)\r\n\r\n\tpublic products: Product[] = [];\r\n\tpublic defaultFilters: DefaultFilter[] = [];\r\n\tpublic loading:Boolean = false;\r\n\tpublic countProducts = signal<number>(0)\r\n\tprivate loaded = false;\r\n\r\n\t@Input() optionsFilters: FilterType[] = ['all'];\r\n\r\n\tfilters_sort:Filter[] = [];\r\n\r\n\tprivate _filtersService: FiltersService = inject(FiltersService)\r\n    public filters$: Observable<Filter[]> = this._filtersService.filters$;\r\n\tpublic ready$: Observable<boolean> = this._filtersService.ready$;\r\n\r\n\tprivate window?:Window;\r\n\r\n\tngOnInit(): void {\r\n\t   \tthis.getProducts();\r\n\t\tthis.window?.scroll(0, 0)\r\n\t}\r\n\r\n\t//protected readonly questions = signal<Question[]>([]);\r\n\tprivate total = 0;\r\n\tprivate platformId: any = inject(PLATFORM_ID)\r\n\r\n\tconstructor() {\r\n\t\tif (isPlatformBrowser(this.platformId)) {\r\n\t\t\tthis.window = window\r\n\t\t\t\r\n\t\t}\r\n\t}\r\n\r\n\tgetProducts(): void {\r\n\t\tcombineLatest([this.params$, this.queryParams$]).subscribe({\r\n\t\t\tnext: ([params, queryParams]) => {\r\n\t\t\t\tconst paginationSettings:PaginationSettings = {\r\n\t\t\t\t\tlatest:true,\r\n\t\t\t\t\tlimit:10,\r\n\t\t\t\t\ttype: params['type'] || null,\r\n\t\t\t\t\tvalue: params['value'] || null\r\n\t\t\t\t}\r\n\t\t\t\t//console.log(ready,\"actualizar\")\r\n\t\t\t\tconsole.log(paginationSettings)\r\n\t\t\t\t/* console.log(paginationSettings) */\r\n\t\t\t\t// console.log('params',queryParams[\"search\"])\r\n\t\t\t\tthis._productsService.getProductsForFilter(paginationSettings, queryParams[\"search\"]);\r\n\t\t\t}\r\n\t\t})\r\n\t}\r\n\r\n\tonScroll() {\r\n\t\tthis.loading = true;\r\n        this._productsService.updateProducts()\r\n\t  }\r\n\r\n}\r\n","<section class=\"container-xl mb-5\">\r\n    <div class=\"row m-0 p-0\">\r\n        <div class=\"d-none d-lg-block col-3\">\r\n            <!--Filtros-->\r\n        </div>\r\n\r\n        <div class=\"col-12 col-lg-9 mt-2 p-0\">\r\n            <div class=\"container\">\r\n                <!-- @for(['a', 'b', 'c', 'd'] as product){\r\n\r\n                } -->\r\n            </div>\r\n        </div>\r\n\r\n    </div>\r\n</section>\r\n"]}
69
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sbGVjdGlvbi1lYy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1lYXN5Y29tbWVyY2UtdjE4L3NyYy9saWIvZWMtY29tcG9uZW50cy9jb2xsZWN0aW9uLWVjL2NvbGxlY3Rpb24tZWMuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctZWFzeWNvbW1lcmNlLXYxOC9zcmMvbGliL2VjLWNvbXBvbmVudHMvY29sbGVjdGlvbi1lYy9jb2xsZWN0aW9uLWVjLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBbUIsU0FBUyxFQUFnQixNQUFNLEVBQUUsS0FBSyxFQUFVLFdBQVcsRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFckgsT0FBTyxFQUFFLFdBQVcsRUFBRSxjQUFjLEVBQUUsY0FBYyxFQUFFLGVBQWUsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ2pHLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUNqRCxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUN2RCxPQUFPLEVBQUUsYUFBYSxFQUFtQyxNQUFNLE1BQU0sQ0FBQztBQUV0RSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUM5RCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQzs7QUFRcEQsTUFBTSxPQUFPLHFCQUFxQjtJQUV2QixnQkFBZ0IsR0FBb0IsTUFBTSxDQUFDLGVBQWUsQ0FBQyxDQUFBO0lBQzNELFlBQVksR0FBbUIsTUFBTSxDQUFDLGNBQWMsQ0FBQyxDQUFBO0lBQ3JELGVBQWUsR0FBbUIsTUFBTSxDQUFDLGNBQWMsQ0FBQyxDQUFBO0lBRTNELE9BQU8sR0FBRyxJQUFJLENBQUMsWUFBWSxDQUFDLE1BQU0sQ0FBQTtJQUN6QywyQ0FBMkM7SUFDcEMsWUFBWSxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsV0FBVyxDQUFBO0lBQzVDLFNBQVMsR0FBRyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsU0FBUyxDQUFBO0lBQ2xELHVCQUF1QjtJQUVoQixXQUFXLEdBQWdCLE1BQU0sQ0FBQyxXQUFXLENBQUMsQ0FBQTtJQUM5QyxTQUFTLEdBQXlCLE1BQU0sQ0FBQyxvQkFBb0IsQ0FBQyxDQUFBO0lBRTlELFFBQVEsR0FBYyxFQUFFLENBQUM7SUFDekIsY0FBYyxHQUFvQixFQUFFLENBQUM7SUFDckMsT0FBTyxHQUFXLEtBQUssQ0FBQztJQUN4QixhQUFhLEdBQUcsTUFBTSxDQUFTLENBQUMsQ0FBQyxDQUFBO0lBQ2hDLE1BQU0sR0FBRyxLQUFLLENBQUM7SUFFZCxjQUFjLEdBQWlCLENBQUMsS0FBSyxDQUFDLENBQUM7SUFFaEQsWUFBWSxHQUFZLEVBQUUsQ0FBQztJQUVuQixlQUFlLEdBQW1CLE1BQU0sQ0FBQyxjQUFjLENBQUMsQ0FBQTtJQUN0RCxRQUFRLEdBQXlCLElBQUksQ0FBQyxlQUFlLENBQUMsUUFBUSxDQUFDO0lBQ2xFLE1BQU0sR0FBd0IsSUFBSSxDQUFDLGVBQWUsQ0FBQyxNQUFNLENBQUM7SUFFekQsTUFBTSxDQUFTO0lBRXZCLFFBQVE7UUFDSixJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7UUFDdEIsSUFBSSxDQUFDLE1BQU0sRUFBRSxNQUFNLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFBO0lBQzFCLENBQUM7SUFFRCx3REFBd0Q7SUFDaEQsS0FBSyxHQUFHLENBQUMsQ0FBQztJQUNWLFVBQVUsR0FBUSxNQUFNLENBQUMsV0FBVyxDQUFDLENBQUE7SUFFN0M7UUFDQyxJQUFJLGlCQUFpQixDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsRUFBRSxDQUFDO1lBQ3hDLElBQUksQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFBO1FBRXJCLENBQUM7SUFDRixDQUFDO0lBRUQsV0FBVztRQUNWLGFBQWEsQ0FBQyxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDO1lBQzFELElBQUksRUFBRSxDQUFDLENBQUMsTUFBTSxFQUFFLFdBQVcsQ0FBQyxFQUFFLEVBQUU7Z0JBQy9CLE1BQU0sa0JBQWtCLEdBQXNCO29CQUM3QyxNQUFNLEVBQUMsSUFBSTtvQkFDWCxLQUFLLEVBQUMsRUFBRTtvQkFDUixJQUFJLEVBQUUsTUFBTSxDQUFDLE1BQU0sQ0FBQyxJQUFJLElBQUk7b0JBQzVCLEtBQUssRUFBRSxNQUFNLENBQUMsT0FBTyxDQUFDLElBQUksSUFBSTtpQkFDOUIsQ0FBQTtnQkFDRCxJQUFJLENBQUMsZ0JBQWdCLENBQUMsb0JBQW9CLENBQUMsa0JBQWtCLEVBQUUsV0FBVyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUM7WUFDdkYsQ0FBQztTQUNELENBQUMsQ0FBQTtJQUNILENBQUM7SUFFRCxRQUFRO1FBQ1AsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUM7UUFDZCxJQUFJLENBQUMsZ0JBQWdCLENBQUMsY0FBYyxFQUFFLENBQUE7SUFDM0MsQ0FBQzt3R0FoRVMscUJBQXFCOzRGQUFyQixxQkFBcUIsMkhDaEJsQyxzYkFnQkE7OzRGREFhLHFCQUFxQjtrQkFQakMsU0FBUzsrQkFDQyxtQkFBbUIsY0FDakIsSUFBSSxXQUNQLENBQUMsdUJBQXVCLENBQUM7d0RBeUJ6QixjQUFjO3NCQUF0QixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgYWZ0ZXJOZXh0UmVuZGVyLCBDb21wb25lbnQsIEhvc3RMaXN0ZW5lciwgaW5qZWN0LCBJbnB1dCwgT25Jbml0LCBQTEFURk9STV9JRCwgc2lnbmFsIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IERlZmF1bHRGaWx0ZXIsIEZpbHRlclR5cGUsIFBhZ2luYXRpb25TZXR0aW5ncywgUHJvZHVjdCB9IGZyb20gJy4uLy4uL2ludGVyZmFjZXMnO1xyXG5pbXBvcnQgeyBBdXRoU2VydmljZSwgRmlsdGVyc1NlcnZpY2UsIE9wdGlvbnNTZXJ2aWNlLCBQcm9kdWN0c1NlcnZpY2UgfSBmcm9tICcuLi8uLi9lYy1zZXJ2aWNlcyc7XHJcbmltcG9ydCB7IEFjdGl2YXRlZFJvdXRlIH0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcclxuaW1wb3J0IHsgQ29yZUNvbnN0YW50c1NlcnZpY2UgfSBmcm9tICcuLi8uLi9jb25zdGFudHMnO1xyXG5pbXBvcnQgeyBjb21iaW5lTGF0ZXN0LCBmb3JrSm9pbiwgbWFwLCBPYnNlcnZhYmxlLCB0YWtlIH0gZnJvbSAncnhqcyc7XHJcbmltcG9ydCB7IEZpbHRlciB9IGZyb20gJy4uLy4uL2NsYXNzZXMnO1xyXG5pbXBvcnQgeyBJbmZpbml0ZVNjcm9sbERpcmVjdGl2ZSB9IGZyb20gXCJuZ3gtaW5maW5pdGUtc2Nyb2xsXCI7XHJcbmltcG9ydCB7IGlzUGxhdGZvcm1Ccm93c2VyIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuQENvbXBvbmVudCh7XHJcblx0c2VsZWN0b3I6ICdsaWItY29sbGVjdGlvbi1lYycsXHJcblx0c3RhbmRhbG9uZTogdHJ1ZSxcclxuXHRpbXBvcnRzOiBbSW5maW5pdGVTY3JvbGxEaXJlY3RpdmVdLFxyXG5cdHRlbXBsYXRlVXJsOiAnLi9jb2xsZWN0aW9uLWVjLmNvbXBvbmVudC5odG1sJyxcclxuXHRzdHlsZVVybDogJy4vY29sbGVjdGlvbi1lYy5jb21wb25lbnQuc2NzcydcclxufSlcclxuZXhwb3J0IGNsYXNzIENvbGxlY3Rpb25FY0NvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcblxyXG5cdHByb3RlY3RlZCBfcHJvZHVjdHNTZXJ2aWNlOiBQcm9kdWN0c1NlcnZpY2UgPSBpbmplY3QoUHJvZHVjdHNTZXJ2aWNlKVxyXG5cdHByb3RlY3RlZCBfYWN0aXZlUm91dGU6IEFjdGl2YXRlZFJvdXRlID0gaW5qZWN0KEFjdGl2YXRlZFJvdXRlKVxyXG5cdHByb3RlY3RlZCBfb3B0aW9uc1NlcnZpY2U6IE9wdGlvbnNTZXJ2aWNlID0gaW5qZWN0KE9wdGlvbnNTZXJ2aWNlKVxyXG5cclxuXHRwdWJsaWMgcGFyYW1zJCA9IHRoaXMuX2FjdGl2ZVJvdXRlLnBhcmFtc1xyXG5cdC8vcHVibGljIHJlYWR5ID0gdGhpcy5fb3B0aW9uc1NlcnZpY2UucmVhZHlcclxuXHRwdWJsaWMgcXVlcnlQYXJhbXMkID0gdGhpcy5fYWN0aXZlUm91dGUucXVlcnlQYXJhbXNcclxuXHRwdWJsaWMgcHJvZHVjdHMkID0gdGhpcy5fcHJvZHVjdHNTZXJ2aWNlLnByb2R1Y3RzJFxyXG5cdC8vcHVibGljIHByb2R1Y3RzJCA9IFtdXHJcblxyXG5cdHB1YmxpYyBhdXRoU2VydmljZTogQXV0aFNlcnZpY2UgPSBpbmplY3QoQXV0aFNlcnZpY2UpXHJcblx0cHVibGljIGNvbnN0YW5zdDogQ29yZUNvbnN0YW50c1NlcnZpY2UgPSBpbmplY3QoQ29yZUNvbnN0YW50c1NlcnZpY2UpXHJcblxyXG5cdHB1YmxpYyBwcm9kdWN0czogUHJvZHVjdFtdID0gW107XHJcblx0cHVibGljIGRlZmF1bHRGaWx0ZXJzOiBEZWZhdWx0RmlsdGVyW10gPSBbXTtcclxuXHRwdWJsaWMgbG9hZGluZzpCb29sZWFuID0gZmFsc2U7XHJcblx0cHVibGljIGNvdW50UHJvZHVjdHMgPSBzaWduYWw8bnVtYmVyPigwKVxyXG5cdHByaXZhdGUgbG9hZGVkID0gZmFsc2U7XHJcblxyXG5cdEBJbnB1dCgpIG9wdGlvbnNGaWx0ZXJzOiBGaWx0ZXJUeXBlW10gPSBbJ2FsbCddO1xyXG5cclxuXHRmaWx0ZXJzX3NvcnQ6RmlsdGVyW10gPSBbXTtcclxuXHJcblx0cHJpdmF0ZSBfZmlsdGVyc1NlcnZpY2U6IEZpbHRlcnNTZXJ2aWNlID0gaW5qZWN0KEZpbHRlcnNTZXJ2aWNlKVxyXG4gICAgcHVibGljIGZpbHRlcnMkOiBPYnNlcnZhYmxlPEZpbHRlcltdPiA9IHRoaXMuX2ZpbHRlcnNTZXJ2aWNlLmZpbHRlcnMkO1xyXG5cdHB1YmxpYyByZWFkeSQ6IE9ic2VydmFibGU8Ym9vbGVhbj4gPSB0aGlzLl9maWx0ZXJzU2VydmljZS5yZWFkeSQ7XHJcblxyXG5cdHByaXZhdGUgd2luZG93PzpXaW5kb3c7XHJcblxyXG5cdG5nT25Jbml0KCk6IHZvaWQge1xyXG5cdCAgIFx0dGhpcy5nZXRQcm9kdWN0cygpO1xyXG5cdFx0dGhpcy53aW5kb3c/LnNjcm9sbCgwLCAwKVxyXG5cdH1cclxuXHJcblx0Ly9wcm90ZWN0ZWQgcmVhZG9ubHkgcXVlc3Rpb25zID0gc2lnbmFsPFF1ZXN0aW9uW10+KFtdKTtcclxuXHRwcml2YXRlIHRvdGFsID0gMDtcclxuXHRwcml2YXRlIHBsYXRmb3JtSWQ6IGFueSA9IGluamVjdChQTEFURk9STV9JRClcclxuXHJcblx0Y29uc3RydWN0b3IoKSB7XHJcblx0XHRpZiAoaXNQbGF0Zm9ybUJyb3dzZXIodGhpcy5wbGF0Zm9ybUlkKSkge1xyXG5cdFx0XHR0aGlzLndpbmRvdyA9IHdpbmRvd1xyXG5cdFx0XHRcclxuXHRcdH1cclxuXHR9XHJcblxyXG5cdGdldFByb2R1Y3RzKCk6IHZvaWQge1x0XHRcclxuXHRcdGNvbWJpbmVMYXRlc3QoW3RoaXMucGFyYW1zJCwgdGhpcy5xdWVyeVBhcmFtcyRdKS5zdWJzY3JpYmUoe1xyXG5cdFx0XHRuZXh0OiAoW3BhcmFtcywgcXVlcnlQYXJhbXNdKSA9PiB7XHRcdFx0XHRcclxuXHRcdFx0XHRjb25zdCBwYWdpbmF0aW9uU2V0dGluZ3M6UGFnaW5hdGlvblNldHRpbmdzID0ge1xyXG5cdFx0XHRcdFx0bGF0ZXN0OnRydWUsXHJcblx0XHRcdFx0XHRsaW1pdDoxMCxcclxuXHRcdFx0XHRcdHR5cGU6IHBhcmFtc1sndHlwZSddIHx8IG51bGwsXHJcblx0XHRcdFx0XHR2YWx1ZTogcGFyYW1zWyd2YWx1ZSddIHx8IG51bGxcclxuXHRcdFx0XHR9XHJcblx0XHRcdFx0dGhpcy5fcHJvZHVjdHNTZXJ2aWNlLmdldFByb2R1Y3RzRm9yRmlsdGVyKHBhZ2luYXRpb25TZXR0aW5ncywgcXVlcnlQYXJhbXNbXCJzZWFyY2hcIl0pO1xyXG5cdFx0XHR9XHJcblx0XHR9KVxyXG5cdH1cclxuXHJcblx0b25TY3JvbGwoKSB7XHJcblx0XHR0aGlzLmxvYWRpbmcgPSB0cnVlO1xyXG4gICAgICAgIHRoaXMuX3Byb2R1Y3RzU2VydmljZS51cGRhdGVQcm9kdWN0cygpXHJcblx0ICB9XHJcblxyXG59XHJcbiIsIjxzZWN0aW9uIGNsYXNzPVwiY29udGFpbmVyLXhsIG1iLTVcIj5cclxuICAgIDxkaXYgY2xhc3M9XCJyb3cgbS0wIHAtMFwiPlxyXG4gICAgICAgIDxkaXYgY2xhc3M9XCJkLW5vbmUgZC1sZy1ibG9jayBjb2wtM1wiPlxyXG4gICAgICAgICAgICA8IS0tRmlsdHJvcy0tPlxyXG4gICAgICAgIDwvZGl2PlxyXG5cclxuICAgICAgICA8ZGl2IGNsYXNzPVwiY29sLTEyIGNvbC1sZy05IG10LTIgcC0wXCI+XHJcbiAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJjb250YWluZXJcIj5cclxuICAgICAgICAgICAgICAgIDwhLS0gQGZvcihbJ2EnLCAnYicsICdjJywgJ2QnXSBhcyBwcm9kdWN0KXtcclxuXHJcbiAgICAgICAgICAgICAgICB9IC0tPlxyXG4gICAgICAgICAgICA8L2Rpdj5cclxuICAgICAgICA8L2Rpdj5cclxuXHJcbiAgICA8L2Rpdj5cclxuPC9zZWN0aW9uPlxyXG4iXX0=
@@ -26,10 +26,10 @@ export class CouponEcComponent {
26
26
  }
27
27
  setLoading = () => this.loading = true;
28
28
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CouponEcComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
29
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: CouponEcComponent, isStandalone: true, selector: "app-coupon-ec", ngImport: i0, template: "<div class=\"border border-bottom card p-2\">\r\n <p class=\"w-100 mb-1\">C\u00F3digo de descuento</p>\r\n \r\n @if(coupon$ | async; as coupon){\r\n <div class=\"d-flex justify-content-between align-items-center px-1\">\r\n <p class=\"m-0\">{{coupon.code | uppercase}}</p>\r\n <button class=\"btn\" (click)=\"removeCoupon()\"><i class=\"bi bi-trash\"></i></button>\r\n </div>\r\n }@else {\r\n <form class=\"campo d-flex align-items-center\">\r\n <input type='text' class=\"elcampo\" [(ngModel)]=\"couponValue\" name=\"coupon_value\" />\r\n <input type='button' value='VALIDAR' class=\"btn btn-primary btnSend py-1\"\r\n (click)=\" addCoupon()\" />\r\n </form> \r\n }\r\n</div>", styles: [""], dependencies: [{ kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i1.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "pipe", type: UpperCasePipe, name: "uppercase" }] });
29
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: CouponEcComponent, isStandalone: true, selector: "app-coupon-ec", ngImport: i0, template: "<div class=\"border border-bottom card p-2\">\r\n <p class=\"w-100 mb-1\">C\u00F3digo de descuento</p>\r\n \r\n @if(coupon$ | async; as coupon){\r\n <div class=\"d-flex justify-content-between align-items-center px-1\">\r\n <p class=\"m-0\">{{coupon.code}}</p>\r\n <button class=\"btn\" (click)=\"removeCoupon()\"><i class=\"bi bi-trash\"></i></button>\r\n </div>\r\n }@else {\r\n <form class=\"campo d-flex align-items-center\">\r\n <input type='text' class=\"elcampo\" [(ngModel)]=\"couponValue\" name=\"coupon_value\" />\r\n <input type='button' value='VALIDAR' class=\"btn btn-primary btnSend py-1\"\r\n (click)=\" addCoupon()\" />\r\n </form> \r\n }\r\n</div>", styles: [""], dependencies: [{ kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i1.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }] });
30
30
  }
31
31
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CouponEcComponent, decorators: [{
32
32
  type: Component,
33
- args: [{ selector: 'app-coupon-ec', standalone: true, imports: [AsyncPipe, FormsModule, UpperCasePipe], template: "<div class=\"border border-bottom card p-2\">\r\n <p class=\"w-100 mb-1\">C\u00F3digo de descuento</p>\r\n \r\n @if(coupon$ | async; as coupon){\r\n <div class=\"d-flex justify-content-between align-items-center px-1\">\r\n <p class=\"m-0\">{{coupon.code | uppercase}}</p>\r\n <button class=\"btn\" (click)=\"removeCoupon()\"><i class=\"bi bi-trash\"></i></button>\r\n </div>\r\n }@else {\r\n <form class=\"campo d-flex align-items-center\">\r\n <input type='text' class=\"elcampo\" [(ngModel)]=\"couponValue\" name=\"coupon_value\" />\r\n <input type='button' value='VALIDAR' class=\"btn btn-primary btnSend py-1\"\r\n (click)=\" addCoupon()\" />\r\n </form> \r\n }\r\n</div>" }]
33
+ args: [{ selector: 'app-coupon-ec', standalone: true, imports: [AsyncPipe, FormsModule, UpperCasePipe], template: "<div class=\"border border-bottom card p-2\">\r\n <p class=\"w-100 mb-1\">C\u00F3digo de descuento</p>\r\n \r\n @if(coupon$ | async; as coupon){\r\n <div class=\"d-flex justify-content-between align-items-center px-1\">\r\n <p class=\"m-0\">{{coupon.code}}</p>\r\n <button class=\"btn\" (click)=\"removeCoupon()\"><i class=\"bi bi-trash\"></i></button>\r\n </div>\r\n }@else {\r\n <form class=\"campo d-flex align-items-center\">\r\n <input type='text' class=\"elcampo\" [(ngModel)]=\"couponValue\" name=\"coupon_value\" />\r\n <input type='button' value='VALIDAR' class=\"btn btn-primary btnSend py-1\"\r\n (click)=\" addCoupon()\" />\r\n </form> \r\n }\r\n</div>" }]
34
34
  }] });
35
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY291cG9uLWVjLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLWVhc3ljb21tZXJjZS12MTgvc3JjL2xpYi9lYy1jb21wb25lbnRzL2NvdXBvbi1lYy9jb3Vwb24tZWMuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctZWFzeWNvbW1lcmNlLXYxOC9zcmMvbGliL2VjLWNvbXBvbmVudHMvY291cG9uLWVjL2NvdXBvbi1lYy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNsRCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFFaEQsT0FBTyxFQUFFLFNBQVMsRUFBRSxhQUFhLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7OztBQVM3QyxNQUFNLE9BQU8saUJBQWlCO0lBQ3JCLFlBQVksR0FBZ0IsTUFBTSxDQUFDLFdBQVcsQ0FBQyxDQUFDO0lBQ2pELE9BQU8sR0FBb0IsSUFBSSxDQUFDLFlBQVksQ0FBQyxPQUFPLENBQUE7SUFDcEQsV0FBVyxHQUFXLEVBQUUsQ0FBQztJQUN6QixNQUFNLEdBQUcsS0FBSyxDQUFDO0lBQ2YsT0FBTyxHQUFHLEtBQUssQ0FBQztJQUV2QixTQUFTO1FBQ1IsSUFBSSxDQUFDLFdBQVcsRUFBRSxJQUFJLElBQUksQ0FBQyxZQUFZLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQTtJQUNwRSxDQUFDO0lBRUQsV0FBVztRQUNWLElBQUksSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO1lBQ3RCLE9BQU8sdUJBQXVCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUN2RCxDQUFDO2FBQU0sQ0FBQztZQUNQLE9BQU8sS0FBSyxDQUFDO1FBQ2QsQ0FBQztJQUNGLENBQUM7SUFFRCxZQUFZO1FBQ1gsSUFBSSxDQUFDLFlBQVksQ0FBQyxZQUFZLEVBQUUsQ0FBQTtJQUNqQyxDQUFDO0lBRUQsVUFBVSxHQUFHLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDO3dHQXZCM0IsaUJBQWlCOzRGQUFqQixpQkFBaUIseUVDYjlCLG92QkFlTSxxREROSyxTQUFTLDZDQUFFLFdBQVcsbWlDQUFFLGFBQWE7OzRGQUluQyxpQkFBaUI7a0JBUDdCLFNBQVM7K0JBQ0MsZUFBZSxjQUNiLElBQUksV0FDUCxDQUFDLFNBQVMsRUFBRSxXQUFXLEVBQUUsYUFBYSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ2FydFNlcnZpY2UgfSBmcm9tICcuLi8uLi9lYy1zZXJ2aWNlcyc7XHJcbmltcG9ydCB7IE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHsgQXN5bmNQaXBlLCBVcHBlckNhc2VQaXBlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuXHRzZWxlY3RvcjogJ2FwcC1jb3Vwb24tZWMnLFxyXG5cdHN0YW5kYWxvbmU6IHRydWUsXHJcblx0aW1wb3J0czogW0FzeW5jUGlwZSwgRm9ybXNNb2R1bGUsIFVwcGVyQ2FzZVBpcGVdLFxyXG5cdHRlbXBsYXRlVXJsOiAnLi9jb3Vwb24tZWMuY29tcG9uZW50Lmh0bWwnLFxyXG5cdHN0eWxlVXJsOiAnLi9jb3Vwb24tZWMuY29tcG9uZW50LnNjc3MnXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDb3Vwb25FY0NvbXBvbmVudCB7XHJcblx0cHJpdmF0ZSBfY2FydFNlcnZpY2U6IENhcnRTZXJ2aWNlID0gaW5qZWN0KENhcnRTZXJ2aWNlKTtcclxuXHRwdWJsaWMgY291cG9uJDogT2JzZXJ2YWJsZTxhbnk+ID0gdGhpcy5fY2FydFNlcnZpY2UuY291cG9uJFxyXG5cdHB1YmxpYyBjb3Vwb25WYWx1ZTogc3RyaW5nID0gXCJcIjtcclxuXHRwdWJsaWMgYXBsaWVkID0gZmFsc2U7XHJcblx0cHVibGljIGxvYWRpbmcgPSBmYWxzZTtcclxuXHJcblx0YWRkQ291cG9uKCkge1xyXG5cdFx0dGhpcy52YWxpZENvdXBvbigpICYmIHRoaXMuX2NhcnRTZXJ2aWNlLmFkZENvdXBvbih0aGlzLmNvdXBvblZhbHVlKVxyXG5cdH1cclxuXHJcblx0dmFsaWRDb3Vwb24oKTogYm9vbGVhbiB7XHJcblx0XHRpZiAodGhpcy5jb3Vwb25WYWx1ZSkge1xyXG5cdFx0XHRyZXR1cm4gL14oW0EtWmEtelxcLTAtOV0qKVxcdyskLy50ZXN0KHRoaXMuY291cG9uVmFsdWUpO1xyXG5cdFx0fSBlbHNlIHtcclxuXHRcdFx0cmV0dXJuIGZhbHNlO1xyXG5cdFx0fVxyXG5cdH1cclxuXHJcblx0cmVtb3ZlQ291cG9uKCkge1xyXG5cdFx0dGhpcy5fY2FydFNlcnZpY2UucmVtb3ZlQ291cG9uKClcclxuXHR9XHJcblx0XHJcblx0c2V0TG9hZGluZyA9ICgpID0+IHRoaXMubG9hZGluZyA9IHRydWU7XHJcbn1cclxuIiwiPGRpdiBjbGFzcz1cImJvcmRlciBib3JkZXItYm90dG9tIGNhcmQgcC0yXCI+XHJcbiAgICA8cCBjbGFzcz1cInctMTAwIG1iLTFcIj5Dw7NkaWdvIGRlIGRlc2N1ZW50bzwvcD5cclxuICAgIFxyXG4gICAgQGlmKGNvdXBvbiQgfCBhc3luYzsgYXMgY291cG9uKXtcclxuICAgICAgICA8ZGl2IGNsYXNzPVwiZC1mbGV4IGp1c3RpZnktY29udGVudC1iZXR3ZWVuIGFsaWduLWl0ZW1zLWNlbnRlciBweC0xXCI+XHJcbiAgICAgICAgPHAgY2xhc3M9XCJtLTBcIj57e2NvdXBvbi5jb2RlIHwgdXBwZXJjYXNlfX08L3A+XHJcbiAgICAgICAgPGJ1dHRvbiBjbGFzcz1cImJ0blwiIChjbGljayk9XCJyZW1vdmVDb3Vwb24oKVwiPjxpIGNsYXNzPVwiYmkgYmktdHJhc2hcIj48L2k+PC9idXR0b24+XHJcbiAgICAgICAgPC9kaXY+XHJcbiAgICB9QGVsc2Uge1xyXG4gICAgICAgPGZvcm0gY2xhc3M9XCJjYW1wbyBkLWZsZXggYWxpZ24taXRlbXMtY2VudGVyXCI+XHJcbiAgICAgICAgPGlucHV0IHR5cGU9J3RleHQnIGNsYXNzPVwiZWxjYW1wb1wiIFsobmdNb2RlbCldPVwiY291cG9uVmFsdWVcIiBuYW1lPVwiY291cG9uX3ZhbHVlXCIgLz5cclxuICAgICAgICA8aW5wdXQgdHlwZT0nYnV0dG9uJyAgdmFsdWU9J1ZBTElEQVInIGNsYXNzPVwiYnRuIGJ0bi1wcmltYXJ5IGJ0blNlbmQgcHktMVwiXHJcbiAgICAgICAgICAgIChjbGljayk9XCIgYWRkQ291cG9uKClcIiAvPlxyXG4gICAgPC9mb3JtPiBcclxuICAgIH1cclxuPC9kaXY+Il19
35
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY291cG9uLWVjLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLWVhc3ljb21tZXJjZS12MTgvc3JjL2xpYi9lYy1jb21wb25lbnRzL2NvdXBvbi1lYy9jb3Vwb24tZWMuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctZWFzeWNvbW1lcmNlLXYxOC9zcmMvbGliL2VjLWNvbXBvbmVudHMvY291cG9uLWVjL2NvdXBvbi1lYy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNsRCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFFaEQsT0FBTyxFQUFFLFNBQVMsRUFBRSxhQUFhLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7OztBQVM3QyxNQUFNLE9BQU8saUJBQWlCO0lBQ3JCLFlBQVksR0FBZ0IsTUFBTSxDQUFDLFdBQVcsQ0FBQyxDQUFDO0lBQ2pELE9BQU8sR0FBb0IsSUFBSSxDQUFDLFlBQVksQ0FBQyxPQUFPLENBQUE7SUFDcEQsV0FBVyxHQUFXLEVBQUUsQ0FBQztJQUN6QixNQUFNLEdBQUcsS0FBSyxDQUFDO0lBQ2YsT0FBTyxHQUFHLEtBQUssQ0FBQztJQUV2QixTQUFTO1FBQ1IsSUFBSSxDQUFDLFdBQVcsRUFBRSxJQUFJLElBQUksQ0FBQyxZQUFZLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQTtJQUNwRSxDQUFDO0lBRUQsV0FBVztRQUNWLElBQUksSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO1lBQ3RCLE9BQU8sdUJBQXVCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUN2RCxDQUFDO2FBQU0sQ0FBQztZQUNQLE9BQU8sS0FBSyxDQUFDO1FBQ2QsQ0FBQztJQUNGLENBQUM7SUFFRCxZQUFZO1FBQ1gsSUFBSSxDQUFDLFlBQVksQ0FBQyxZQUFZLEVBQUUsQ0FBQTtJQUNqQyxDQUFDO0lBRUQsVUFBVSxHQUFHLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDO3dHQXZCM0IsaUJBQWlCOzRGQUFqQixpQkFBaUIseUVDYjlCLHd1QkFlTSxxREROSyxTQUFTLDZDQUFFLFdBQVc7OzRGQUlwQixpQkFBaUI7a0JBUDdCLFNBQVM7K0JBQ0MsZUFBZSxjQUNiLElBQUksV0FDUCxDQUFDLFNBQVMsRUFBRSxXQUFXLEVBQUUsYUFBYSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ2FydFNlcnZpY2UgfSBmcm9tICcuLi8uLi9lYy1zZXJ2aWNlcyc7XHJcbmltcG9ydCB7IE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHsgQXN5bmNQaXBlLCBVcHBlckNhc2VQaXBlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuXHRzZWxlY3RvcjogJ2FwcC1jb3Vwb24tZWMnLFxyXG5cdHN0YW5kYWxvbmU6IHRydWUsXHJcblx0aW1wb3J0czogW0FzeW5jUGlwZSwgRm9ybXNNb2R1bGUsIFVwcGVyQ2FzZVBpcGVdLFxyXG5cdHRlbXBsYXRlVXJsOiAnLi9jb3Vwb24tZWMuY29tcG9uZW50Lmh0bWwnLFxyXG5cdHN0eWxlVXJsOiAnLi9jb3Vwb24tZWMuY29tcG9uZW50LnNjc3MnXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDb3Vwb25FY0NvbXBvbmVudCB7XHJcblx0cHJpdmF0ZSBfY2FydFNlcnZpY2U6IENhcnRTZXJ2aWNlID0gaW5qZWN0KENhcnRTZXJ2aWNlKTtcclxuXHRwdWJsaWMgY291cG9uJDogT2JzZXJ2YWJsZTxhbnk+ID0gdGhpcy5fY2FydFNlcnZpY2UuY291cG9uJFxyXG5cdHB1YmxpYyBjb3Vwb25WYWx1ZTogc3RyaW5nID0gXCJcIjtcclxuXHRwdWJsaWMgYXBsaWVkID0gZmFsc2U7XHJcblx0cHVibGljIGxvYWRpbmcgPSBmYWxzZTtcclxuXHJcblx0YWRkQ291cG9uKCkge1xyXG5cdFx0dGhpcy52YWxpZENvdXBvbigpICYmIHRoaXMuX2NhcnRTZXJ2aWNlLmFkZENvdXBvbih0aGlzLmNvdXBvblZhbHVlKVxyXG5cdH1cclxuXHJcblx0dmFsaWRDb3Vwb24oKTogYm9vbGVhbiB7XHJcblx0XHRpZiAodGhpcy5jb3Vwb25WYWx1ZSkge1xyXG5cdFx0XHRyZXR1cm4gL14oW0EtWmEtelxcLTAtOV0qKVxcdyskLy50ZXN0KHRoaXMuY291cG9uVmFsdWUpO1xyXG5cdFx0fSBlbHNlIHtcclxuXHRcdFx0cmV0dXJuIGZhbHNlO1xyXG5cdFx0fVxyXG5cdH1cclxuXHJcblx0cmVtb3ZlQ291cG9uKCkge1xyXG5cdFx0dGhpcy5fY2FydFNlcnZpY2UucmVtb3ZlQ291cG9uKClcclxuXHR9XHJcblx0XHJcblx0c2V0TG9hZGluZyA9ICgpID0+IHRoaXMubG9hZGluZyA9IHRydWU7XHJcbn1cclxuIiwiPGRpdiBjbGFzcz1cImJvcmRlciBib3JkZXItYm90dG9tIGNhcmQgcC0yXCI+XHJcbiAgICA8cCBjbGFzcz1cInctMTAwIG1iLTFcIj5Dw7NkaWdvIGRlIGRlc2N1ZW50bzwvcD5cclxuICAgIFxyXG4gICAgQGlmKGNvdXBvbiQgfCBhc3luYzsgYXMgY291cG9uKXtcclxuICAgICAgICA8ZGl2IGNsYXNzPVwiZC1mbGV4IGp1c3RpZnktY29udGVudC1iZXR3ZWVuIGFsaWduLWl0ZW1zLWNlbnRlciBweC0xXCI+XHJcbiAgICAgICAgPHAgY2xhc3M9XCJtLTBcIj57e2NvdXBvbi5jb2RlfX08L3A+XHJcbiAgICAgICAgPGJ1dHRvbiBjbGFzcz1cImJ0blwiIChjbGljayk9XCJyZW1vdmVDb3Vwb24oKVwiPjxpIGNsYXNzPVwiYmkgYmktdHJhc2hcIj48L2k+PC9idXR0b24+XHJcbiAgICAgICAgPC9kaXY+XHJcbiAgICB9QGVsc2Uge1xyXG4gICAgICAgPGZvcm0gY2xhc3M9XCJjYW1wbyBkLWZsZXggYWxpZ24taXRlbXMtY2VudGVyXCI+XHJcbiAgICAgICAgPGlucHV0IHR5cGU9J3RleHQnIGNsYXNzPVwiZWxjYW1wb1wiIFsobmdNb2RlbCldPVwiY291cG9uVmFsdWVcIiBuYW1lPVwiY291cG9uX3ZhbHVlXCIgLz5cclxuICAgICAgICA8aW5wdXQgdHlwZT0nYnV0dG9uJyAgdmFsdWU9J1ZBTElEQVInIGNsYXNzPVwiYnRuIGJ0bi1wcmltYXJ5IGJ0blNlbmQgcHktMVwiXHJcbiAgICAgICAgICAgIChjbGljayk9XCIgYWRkQ291cG9uKClcIiAvPlxyXG4gICAgPC9mb3JtPiBcclxuICAgIH1cclxuPC9kaXY+Il19
@@ -1,9 +1,10 @@
1
- import { Component, inject, Input, ViewChild } from '@angular/core';
1
+ import { Component, inject, Input } from '@angular/core';
2
2
  import { FiltersService } from '../../ec-services';
3
3
  import { Filter } from '../../classes';
4
4
  import { ProductsService } from '../../ec-services/products.service';
5
5
  import { CoreConstantsService } from '../../constants';
6
6
  import { Router } from '@angular/router';
7
+ import { PriceRangeFilter } from '../../classes/filters/price_range-filter';
7
8
  import * as i0 from "@angular/core";
8
9
  export class FiltersEcComponent {
9
10
  _filtersService = inject(FiltersService);
@@ -13,9 +14,8 @@ export class FiltersEcComponent {
13
14
  filters = [];
14
15
  filter$ = this._filtersService.filters$;
15
16
  setSelect;
16
- rangeMinRef;
17
- rangeMaxRef;
18
- priceGapPercentage = 0.1;
17
+ ngOnInit() {
18
+ }
19
19
  constructor() {
20
20
  this._filtersService.filters$.subscribe((filters) => {
21
21
  this.filters = filters;
@@ -23,7 +23,7 @@ export class FiltersEcComponent {
23
23
  }
24
24
  getSpecificFilter(type) {
25
25
  const filter = this.filters.find(f => f.type() === type);
26
- if (!(filter instanceof Filter)) {
26
+ if (type === 'price_range' && filter && !(filter instanceof Filter)) {
27
27
  console.error(`Expected a Filter instance but got`, filter);
28
28
  }
29
29
  return filter || null;
@@ -47,8 +47,6 @@ export class FiltersEcComponent {
47
47
  console.error('filter.setSelected is not a function. Filter might not be an instance of the expected class:', filter);
48
48
  return;
49
49
  }
50
- console.log("Setting selected filter:", filter);
51
- console.log("Setting selected element:", selected);
52
50
  try {
53
51
  // this._filtersService.setFilterSelected(filter, selected);
54
52
  if (selected.path) {
@@ -59,33 +57,12 @@ export class FiltersEcComponent {
59
57
  console.error("Error while setting selected filter:", error);
60
58
  }
61
59
  }
62
- /**
63
- * Redondea al múltiplo de 'step' respetando el redondeo entero:
64
- * - Mínimo: redondea hacia abajo.
65
- * - Máximo: redondea hacia arriba.
66
- */
67
- onRangeChange(event, type, filter) {
68
- const input = event.target;
69
- let value = parseInt(input.value, 10);
70
- value = this.roundToNearest(value, 5, type, filter);
71
- this.updateFilterPrices(type, value, filter, this.priceGapPercentage);
72
- }
73
- roundToNearest(value, step, type, filter) {
74
- let rounded = Math.round(value / step) * step;
75
- if (type === 'max' && rounded < filter.maxPrice) {
76
- rounded = Math.ceil(value / step) * step;
77
- }
78
- if (type === 'min' && rounded > filter.minPrice) {
79
- rounded = Math.floor(value / step) * step;
80
- }
81
- return rounded;
82
- }
83
60
  uniqueSelection(filter, filterChild) {
84
61
  // Buscar si hay un filtro de tipo PriceRangeFilter en la lista de filtros
85
- // const priceRangeFilter = this.filters.find(f => f instanceof PriceRangeFilter);
86
- // if (priceRangeFilter) {
87
- // priceRangeFilter.reset();
88
- // }
62
+ const priceRangeFilter = this.filters.find(f => f instanceof PriceRangeFilter);
63
+ if (priceRangeFilter) {
64
+ priceRangeFilter.reset();
65
+ }
89
66
  filter.data.forEach(filterElement => {
90
67
  if (filterElement.selected) {
91
68
  filterElement.selected = false;
@@ -97,74 +74,44 @@ export class FiltersEcComponent {
97
74
  });
98
75
  });
99
76
  }
100
- /**
101
- * Actualiza los valores del filtro permitiendo que un input empuje al otro.
102
- */
103
- updateFilterPrices(type, value, filter, priceGap) {
104
- const globalMin = filter.minPrice ?? 0;
105
- const globalMax = filter.maxPrice;
106
- let currentMin = filter.currentMinPrice ?? globalMin;
107
- let currentMax = filter.currentMaxPrice ?? globalMax;
108
- if (type === 'min') {
109
- let newMin = Math.min(Math.max(value, globalMin), globalMax);
110
- if (newMin + priceGap > currentMax) {
111
- let newMaxCandidate = newMin + priceGap;
112
- if (newMaxCandidate <= globalMax) {
113
- currentMax = newMaxCandidate;
114
- }
115
- else {
116
- newMin = globalMax - priceGap;
117
- }
118
- }
119
- filter.currentMinPrice = newMin;
120
- filter.currentMaxPrice = currentMax;
121
- }
122
- else if (type === 'max') {
123
- let newMax = Math.max(Math.min(value, globalMax), globalMin);
124
- if (newMax - priceGap < currentMin) {
125
- let newMinCandidate = newMax - priceGap;
126
- if (newMinCandidate >= globalMin) {
127
- currentMin = newMinCandidate;
128
- }
129
- else {
130
- newMax = globalMin + priceGap;
131
- }
132
- }
133
- filter.currentMaxPrice = newMax;
134
- filter.currentMinPrice = currentMin;
135
- }
136
- }
137
- // Método para actualizar los valores de precio seleccionados
138
- // updatePriceRange(min: number, max: number, priceFilter: PriceRangeFilter) {
139
- // priceFilter.setSelected(min, max);
140
- // this.setSelect(priceFilter);
141
- // }
142
- // Métodos para actualizar la barra del filtro por precio
143
- calculateLeftPercentage(currentMinPrice, minPrice, maxPrice) {
144
- const minVal = Math.max(minPrice, Math.min(currentMinPrice ?? minPrice, maxPrice));
145
- return Math.max(0, Math.min(((minVal - minPrice) / (maxPrice - minPrice)) * 100, 100));
146
- }
147
- calculateRightPercentage(currentMaxPrice, minPrice, maxPrice) {
148
- const maxVal = Math.max(minPrice, Math.min(currentMaxPrice ?? maxPrice, maxPrice));
149
- return Math.max(0, Math.min(100 - ((maxVal - minPrice) / (maxPrice - minPrice)) * 100, 100));
150
- }
77
+ // close = () => {
78
+ // this.document.getElementById("filtros").classList.remove('in');
79
+ // return true;
80
+ // };
81
+ close = () => {
82
+ // this.consts.mobile()
83
+ // ? this.document.getElementById("accordionExample").classList.remove('show')
84
+ // : this.document.getElementById(accordion_id).classList.remove('show');
85
+ return true;
86
+ };
151
87
  scrollUp = () => {
152
88
  window.scroll(0, 0);
153
89
  return true;
154
90
  };
91
+ hasAppliedFilters() {
92
+ return this.filters?.some((filter) => {
93
+ if (filter.type?.() === 'price_range') {
94
+ const minSet = filter.currentMinPrice !== null && filter.currentMinPrice !== 0;
95
+ const maxSet = filter.currentMaxPrice !== null && filter.currentMaxPrice !== filter.maxPrice;
96
+ if (minSet || maxSet) {
97
+ return true;
98
+ }
99
+ }
100
+ return filter.data?.some((filterElement) => {
101
+ if (Array.isArray(filterElement.children)) {
102
+ return filterElement.children.some((child) => child.selected);
103
+ }
104
+ return filterElement.selected;
105
+ });
106
+ }) ?? false;
107
+ }
155
108
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FiltersEcComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
156
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FiltersEcComponent, isStandalone: true, selector: "lib-filters-ec", inputs: { setSelect: "setSelect" }, viewQueries: [{ propertyName: "rangeMinRef", first: true, predicate: ["rangeMin"], descendants: true }, { propertyName: "rangeMaxRef", first: true, predicate: ["rangeMax"], descendants: true }], ngImport: i0, template: "<p>filters-ec works!</p>\r\n", styles: [""] });
109
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FiltersEcComponent, isStandalone: true, selector: "lib-filters-ec", inputs: { setSelect: "setSelect" }, ngImport: i0, template: "<p>filters-ec works!</p>\r\n", styles: [""] });
157
110
  }
158
111
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FiltersEcComponent, decorators: [{
159
112
  type: Component,
160
113
  args: [{ selector: 'lib-filters-ec', standalone: true, imports: [], template: "<p>filters-ec works!</p>\r\n" }]
161
114
  }], ctorParameters: () => [], propDecorators: { setSelect: [{
162
115
  type: Input
163
- }], rangeMinRef: [{
164
- type: ViewChild,
165
- args: ['rangeMin']
166
- }], rangeMaxRef: [{
167
- type: ViewChild,
168
- args: ['rangeMax']
169
116
  }] } });
170
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filters-ec.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/filters-ec/filters-ec.component.ts","../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/filters-ec/filters-ec.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, inject, Input, ElementRef, ViewChild } from '@angular/core';\r\nimport { FiltersService } from '../../ec-services';\r\nimport { Filter } from '../../classes';\r\nimport { FilterElement, FilterType, PaginationSettings } from '../../interfaces';\r\nimport { ProductsService } from '../../ec-services/products.service';\r\nimport { CoreConstantsService } from '../../constants';\r\nimport { Router } from '@angular/router';\r\n\r\n@Component({\r\n\tselector: 'lib-filters-ec',\r\n\tstandalone: true,\r\n\timports: [],\r\n\ttemplateUrl: './filters-ec.component.html',\r\n\tstyleUrl: './filters-ec.component.scss'\r\n})\r\nexport class FiltersEcComponent {\r\n\tprivate _filtersService: FiltersService = inject(FiltersService);\r\n\tprivate _productsService: ProductsService = inject(ProductsService);\r\n\tprivate _constants: CoreConstantsService = inject(CoreConstantsService);\r\n\tprivate router: Router = inject(Router);\r\n\tpublic filters: Filter[] = [];\r\n\tpublic filter$ = this._filtersService.filters$;\r\n\t@Input() setSelect: any;\r\n\r\n\t@ViewChild('rangeMin') rangeMinRef!: ElementRef;\r\n\t@ViewChild('rangeMax') rangeMaxRef!: ElementRef;\r\n\r\n\tpriceGapPercentage = 0.1;\r\n\r\n\r\n\tconstructor() {\r\n\t\tthis._filtersService.filters$.subscribe((filters: Filter[]) => {\r\n\t\t\tthis.filters = filters;\r\n\t\t});\r\n\t}\r\n\r\n\tgetSpecificFilter(type: FilterType): Filter | null {\r\n\t\tconst filter = this.filters.find(f => f.type() === type);\r\n\t\tif (!(filter instanceof Filter)) {\r\n\t\t\tconsole.error(`Expected a Filter instance but got`, filter);\r\n\t\t}\r\n\t\treturn filter || null;\r\n\t}\r\n\r\n\t/*Obtiene el filtro elegido en el select, lo pasa al setSelect\r\n\tpara que se marque seleccionado*/\r\n\tonSelect(event: any, filter: FilterElement[] | null) {\r\n\t\tconsole.log(filter)\r\n\t\t/*  const selectedOption = filter\r\n\t\t\t .flatMap(category => category.children)\r\n\t\t\t .filter(option => option?.code === event.target.value)\r\n\t\t\t .pop()\r\n\t\t selectedOption && this._filtersService.setFilterSelected(this.filters[0], selectedOption) */\r\n\t}\r\n\r\n\tsetSelected(filter: Filter | null, selected: FilterElement | null) {\r\n\t\tif (!filter || !selected) {\r\n\t\t\tconsole.error('Filter or selected element is undefined:', { filter, selected });\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tif (typeof (filter as any).setSelected !== 'function') {\r\n\t\t\tconsole.error('filter.setSelected is not a function. Filter might not be an instance of the expected class:', filter);\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tconsole.log(\"Setting selected filter:\", filter);\r\n\t\tconsole.log(\"Setting selected element:\", selected);\r\n\r\n\t\ttry {\r\n\t\t\t// this._filtersService.setFilterSelected(filter, selected);\r\n\t\t\tif (selected.path) {\r\n\t\t\t\tthis.router.navigate([selected.path]);\r\n\t\t\t}\r\n\r\n\r\n\t\t} catch (error) {\r\n\t\t\tconsole.error(\"Error while setting selected filter:\", error);\r\n\t\t}\r\n\t}\r\n\r\n\t/**\r\n\t* Redondea al múltiplo de 'step' respetando el redondeo entero:\r\n\t* - Mínimo: redondea hacia abajo.\r\n\t* - Máximo: redondea hacia arriba.\r\n\t*/\r\n\tonRangeChange(event: Event, type: 'min' | 'max', filter: { minPrice: number; maxPrice: number; currentMinPrice?: number; currentMaxPrice?: number }) {\r\n\t\tconst input = event.target as HTMLInputElement;\r\n\t\tlet value = parseInt(input.value, 10);\r\n\t\tvalue = this.roundToNearest(value, 5, type, filter);\r\n\r\n\t\tthis.updateFilterPrices(type, value, filter, this.priceGapPercentage);\r\n\t}\r\n\r\n\troundToNearest(value: number, step: number, type: 'min' | 'max', filter: any): number {\r\n\t\tlet rounded = Math.round(value / step) * step;\r\n\t\tif (type === 'max' && rounded < filter.maxPrice) {\r\n\t\t\trounded = Math.ceil(value / step) * step;\r\n\t\t}\r\n\t\tif (type === 'min' && rounded > filter.minPrice) {\r\n\t\t\trounded = Math.floor(value / step) * step;\r\n\t\t}\r\n\t\treturn rounded;\r\n\t}\r\n\tuniqueSelection(filter: { data: any[]; }, filterChild: any) {\r\n\t\t// Buscar si hay un filtro de tipo PriceRangeFilter en la lista de filtros\r\n\t\t// const priceRangeFilter = this.filters.find(f => f instanceof PriceRangeFilter);\r\n\r\n\t\t// if (priceRangeFilter) {\r\n\t\t// \tpriceRangeFilter.reset();\r\n\t\t// }\r\n\t\tfilter.data.forEach(filterElement => {\r\n\t\t\tif (filterElement.selected) {\r\n\t\t\t\tfilterElement.selected = false;\r\n\t\t\t}\r\n\t\t\tfilterElement.children.forEach((filterChildren: FilterElement) => {\r\n\t\t\t\tif (filterChildren != filterChild && filterChildren.selected) {\r\n\t\t\t\t\tfilterChildren.selected = false;\r\n\t\t\t\t}\r\n\t\t\t});\r\n\t\t});\r\n\t}\r\n\r\n\t/**\r\n   * Actualiza los valores del filtro permitiendo que un input empuje al otro.\r\n  */\r\n\tupdateFilterPrices(type: 'min' | 'max', value: number, filter: any, priceGap: number) {\r\n\t\tconst globalMin = filter.minPrice ?? 0;\r\n\t\tconst globalMax = filter.maxPrice;\r\n\r\n\t\tlet currentMin = filter.currentMinPrice ?? globalMin;\r\n\t\tlet currentMax = filter.currentMaxPrice ?? globalMax;\r\n\r\n\t\tif (type === 'min') {\r\n\t\t\tlet newMin = Math.min(Math.max(value, globalMin), globalMax);\r\n\t\t\tif (newMin + priceGap > currentMax) {\r\n\t\t\t\tlet newMaxCandidate = newMin + priceGap;\r\n\t\t\t\tif (newMaxCandidate <= globalMax) {\r\n\t\t\t\t\tcurrentMax = newMaxCandidate;\r\n\t\t\t\t} else {\r\n\t\t\t\t\tnewMin = globalMax - priceGap;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\tfilter.currentMinPrice = newMin;\r\n\t\t\tfilter.currentMaxPrice = currentMax;\r\n\t\t} else if (type === 'max') {\r\n\t\t\tlet newMax = Math.max(Math.min(value, globalMax), globalMin);\r\n\t\t\tif (newMax - priceGap < currentMin) {\r\n\t\t\t\tlet newMinCandidate = newMax - priceGap;\r\n\t\t\t\tif (newMinCandidate >= globalMin) {\r\n\t\t\t\t\tcurrentMin = newMinCandidate;\r\n\t\t\t\t} else {\r\n\t\t\t\t\tnewMax = globalMin + priceGap;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\tfilter.currentMaxPrice = newMax;\r\n\t\t\tfilter.currentMinPrice = currentMin;\r\n\t\t}\r\n\t}\r\n\t// Método para actualizar los valores de precio seleccionados\r\n\t// updatePriceRange(min: number, max: number, priceFilter: PriceRangeFilter) {\r\n\t// \tpriceFilter.setSelected(min, max);\r\n\t// \tthis.setSelect(priceFilter);\r\n\t// }\r\n\r\n\t// Métodos para actualizar la barra del filtro por precio\r\n\tcalculateLeftPercentage(currentMinPrice: number, minPrice: number, maxPrice: number): number {\r\n\t\tconst minVal = Math.max(minPrice, Math.min(currentMinPrice ?? minPrice, maxPrice));\r\n\t\treturn Math.max(0, Math.min(((minVal - minPrice) / (maxPrice - minPrice)) * 100, 100));\r\n\t}\r\n\r\n\tcalculateRightPercentage(currentMaxPrice: number, minPrice: number, maxPrice: number): number {\r\n\t\tconst maxVal = Math.max(minPrice, Math.min(currentMaxPrice ?? maxPrice, maxPrice));\r\n\t\treturn Math.max(0, Math.min(100 - ((maxVal - minPrice) / (maxPrice - minPrice)) * 100, 100));\r\n\t}\r\n\r\n\tscrollUp = () => {\r\n\t\twindow.scroll(0, 0);\r\n\t\treturn true\r\n\t}\r\n\r\n}\r\n","<p>filters-ec works!</p>\r\n"]}
117
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filters-ec.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/filters-ec/filters-ec.component.ts","../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/filters-ec/filters-ec.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, inject, Input, ElementRef, ViewChild } from '@angular/core';\r\nimport { FiltersService } from '../../ec-services';\r\nimport { Filter } from '../../classes';\r\nimport { FilterElement, FilterType, PaginationSettings } from '../../interfaces';\r\nimport { ProductsService } from '../../ec-services/products.service';\r\nimport { CoreConstantsService } from '../../constants';\r\nimport { Router } from '@angular/router';\r\nimport { PriceRangeFilter } from '../../classes/filters/price_range-filter';\r\n\r\n\r\n@Component({\r\n    selector: 'lib-filters-ec',\r\n    standalone: true,\r\n    imports: [],\r\n    templateUrl: './filters-ec.component.html',\r\n    styleUrl: './filters-ec.component.scss'\r\n})\r\nexport class FiltersEcComponent {\r\n\r\n    private _filtersService: FiltersService = inject(FiltersService);\r\n    private _productsService: ProductsService = inject(ProductsService);\r\n    private _constants: CoreConstantsService = inject(CoreConstantsService);\r\n    private router: Router = inject(Router);\r\n    public filters: Filter[] = [];\r\n    public filter$ = this._filtersService.filters$;\r\n    @Input() setSelect: any;\r\n\r\n    ngOnInit() {\r\n\r\n    }\r\n\r\n    constructor() {\r\n        this._filtersService.filters$.subscribe((filters: Filter[]) => {            \r\n            this.filters = filters;\r\n        });\r\n    }\r\n    /** 1) Para cuando me piden 'price_range', devuelvo PriceRangeFilter */\r\n    public getSpecificFilter(type: 'price_range'): PriceRangeFilter | null;\r\n\r\n    /** 2) Para cualquier otro FilterType, devuelvo Filter */\r\n    public getSpecificFilter(type: FilterType): Filter | null;\r\n    public getSpecificFilter(type: FilterType): Filter | null {\r\n        const filter = this.filters.find(f => f.type() === type);\r\n        if (type === 'price_range' && filter && !(filter instanceof Filter)) {\r\n            console.error(`Expected a Filter instance but got`, filter);\r\n        }\r\n        return filter || null;\r\n    }\r\n\r\n    /*Obtiene el filtro elegido en el select, lo pasa al setSelect\r\n    para que se marque seleccionado*/\r\n    onSelect(event: any, filter: FilterElement[] | null) {\r\n        console.log(filter)\r\n        /*  const selectedOption = filter\r\n             .flatMap(category => category.children)\r\n             .filter(option => option?.code === event.target.value)\r\n             .pop()\r\n         selectedOption && this._filtersService.setFilterSelected(this.filters[0], selectedOption) */\r\n    }\r\n\r\n    setSelected(filter: Filter | null, selected: FilterElement | null) {        \r\n        if (!filter || !selected) {\r\n            console.error('Filter or selected element is undefined:', { filter, selected });\r\n            return;\r\n        }\r\n\r\n        if (typeof (filter as any).setSelected !== 'function') {\r\n            console.error('filter.setSelected is not a function. Filter might not be an instance of the expected class:', filter);\r\n            return;\r\n        }\r\n\r\n        try {\r\n            // this._filtersService.setFilterSelected(filter, selected);\r\n            if (selected.path) {                \r\n                this.router.navigate([selected.path]);\r\n            }\r\n\r\n\r\n        } catch (error) {\r\n            console.error(\"Error while setting selected filter:\", error);\r\n        }\r\n    }\r\n\r\n    uniqueSelection(filter: { data: any[]; }, filterChild: any) {\r\n        // Buscar si hay un filtro de tipo PriceRangeFilter en la lista de filtros\r\n        const priceRangeFilter = this.filters.find(f => f instanceof PriceRangeFilter);        \r\n\r\n        if (priceRangeFilter) {\r\n            priceRangeFilter.reset();\r\n        }\r\n        filter.data.forEach(filterElement => {\r\n            if (filterElement.selected) {\r\n                filterElement.selected = false;\r\n            }\r\n            filterElement.children.forEach((filterChildren: FilterElement) => {\r\n                if (filterChildren != filterChild && filterChildren.selected) {\r\n                    filterChildren.selected = false;\r\n                }\r\n            });\r\n        });\r\n    }\r\n\r\n    //  close = () => {\r\n    //       this.document.getElementById(\"filtros\").classList.remove('in');\r\n    //       return true;\r\n    //  };\r\n\r\n\r\n    close = () => {\r\n        // this.consts.mobile()\r\n        //      ? this.document.getElementById(\"accordionExample\").classList.remove('show')\r\n        //      : this.document.getElementById(accordion_id).classList.remove('show');\r\n        return true;\r\n    };\r\n\r\n\r\n    scrollUp = () => {\r\n        window.scroll(0, 0);\r\n        return true\r\n    }\r\n\r\n\r\n\r\n\r\n\r\n    hasAppliedFilters(): boolean {\r\n        return this.filters?.some((filter: any) => {\r\n            if (filter.type?.() === 'price_range') {\r\n                const minSet = filter.currentMinPrice !== null && filter.currentMinPrice !== 0;\r\n                const maxSet = filter.currentMaxPrice !== null && filter.currentMaxPrice !== filter.maxPrice;\r\n                if (minSet || maxSet) {\r\n                    return true;\r\n                }\r\n            }\r\n\r\n            return filter.data?.some((filterElement: any) => {\r\n                if (Array.isArray(filterElement.children)) {\r\n                    return filterElement.children.some((child: any) => child.selected);\r\n                }\r\n                return filterElement.selected;\r\n            });\r\n        }) ?? false;\r\n    }\r\n\r\n}\r\n","<p>filters-ec works!</p>\r\n"]}
@@ -31,4 +31,5 @@ export * from './reviews-ec/reviews-ec.component';
31
31
  export * from './reviews-form-ec/reviews-form-ec.component';
32
32
  export * from './section-container-ec/section-container-ec.component';
33
33
  export * from './stores-ec/stores-ec.component';
34
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1lYXN5Y29tbWVyY2UtdjE4L3NyYy9saWIvZWMtY29tcG9uZW50cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsbUNBQW1DLENBQUM7QUFDbEQsY0FBYyx5Q0FBeUMsQ0FBQztBQUN4RCxjQUFjLDZDQUE2QyxDQUFDO0FBQzVELGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsV0FBVyxDQUFDO0FBQzFCLGNBQWMsbUNBQW1DLENBQUM7QUFDbEQsY0FBYyxpREFBaUQsQ0FBQztBQUNoRSxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMseUNBQXlDLENBQUM7QUFDeEQsY0FBYyxXQUFXLENBQUM7QUFDMUIsY0FBYyxpQ0FBaUMsQ0FBQztBQUNoRCxjQUFjLG1DQUFtQyxDQUFDO0FBQ2xELGNBQWMscUNBQXFDLENBQUM7QUFDcEQsY0FBYywrQ0FBK0MsQ0FBQztBQUM5RCxjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLCtEQUErRCxDQUFDO0FBQzlFLGNBQWMsbURBQW1ELENBQUM7QUFDbEUsY0FBYywyREFBMkQsQ0FBQztBQUMxRSxjQUFjLGlFQUFpRSxDQUFDO0FBQ2hGLGNBQWMsK0RBQStELENBQUE7QUFDN0UsY0FBYyxtRUFBbUUsQ0FBQTtBQUNqRixjQUFjLG1DQUFtQyxDQUFDO0FBQ2xELGNBQWMscURBQXFELENBQUM7QUFDcEUsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMsbUNBQW1DLENBQUM7QUFDbEQsY0FBYyw2Q0FBNkMsQ0FBQztBQUM1RCxjQUFjLHVEQUF1RCxDQUFDO0FBQ3RFLGNBQWMsaUNBQWlDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2Zvb3Rlci1lYy9mb290ZXItZWMuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9oZWFkZXItZWMvaGVhZGVyLWVjLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vaG9tZS1lYy9ob21lLWVjLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vYmxvY2tzLWVjL2Jsb2Nrcy1lYy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL3Byb2R1Y3QtZWMvcHJvZHVjdC1lYy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2NvbGxlY3Rpb24tZWMvY29sbGVjdGlvbi1lYy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2ZpbHRlcnMtc29ydC1lYy9maWx0ZXJzLXNvcnQtZWMuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi93aWRnZXRzLWVjJztcclxuZXhwb3J0ICogZnJvbSAnLi9hdXRoLWVjJztcclxuZXhwb3J0ICogZnJvbSAnLi9maWx0ZXJzLWVjL2ZpbHRlcnMtZWMuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9wcm9kdWN0LWRldGFpbC1lYy9wcm9kdWN0LWRldGFpbC1lYy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL3ZhcmlhbnRzLWVjL3ZhcmlhbnRzLWVjLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vYnJlYWRjcnVtYi1lYy9icmVhZGNydW1iLWVjLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vY2FydC1lYyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vY291cG9uLWVjL2NvdXBvbi1lYy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2NvbnRhY3QtZWMvY29udGFjdC1lYy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2NoZWNrb3V0LWVjL2NoZWNrb3V0LWVjLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vY2hlY2tvdXQtZWMvc3VjY2Vzcy1lYy9zdWNjZXNzLWVjLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vYWNjb3VudC1lYyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vYmxvY2tzLWVjL2Jsb2NrLW5ld3NsZXR0ZXItZWMvYmxvY2stbmV3c2xldHRlci1lYy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2Jsb2Nrcy1lYy9ibG9jay1odG1sLWVjL2Jsb2NrLWh0bWwtZWMuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9ibG9ja3MtZWMvYmxvY2stcHJvZHVjdHMtZWMvYmxvY2stcHJvZHVjdHMtZWMuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9ibG9ja3MtZWMvYmxvY2stYmFubmVyLWZ1bGwtZWMvYmxvY2stYmFubmVyLWZ1bGwtZWMuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9ibG9ja3MtZWMvYmxvY2stYmFubmVyLWJveC1lYy9ibG9jay1iYW5uZXItYm94LWVjLmNvbXBvbmVudCdcclxuZXhwb3J0ICogZnJvbSAnLi9ibG9ja3MtZWMvYmxvY2stZm9ybS1jb250YWN0LWVjL2Jsb2NrLWZvcm0tY29udGFjdC1lYy5jb21wb25lbnQnXHJcbmV4cG9ydCAqIGZyb20gJy4vc2lkZWJhci1lYy9zaWRlYmFyLWVjLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vcmVsYXRlZC1wcm9kdWN0cy1lYy9yZWxhdGVkLXByb2R1Y3RzLWVjLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vZmFxcy1lYy9mYXFzLWVjLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vc2hhcmUtZWMvc2hhcmUtZWMuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9yZXZpZXdzLWVjL3Jldmlld3MtZWMuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9yZXZpZXdzLWZvcm0tZWMvcmV2aWV3cy1mb3JtLWVjLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vc2VjdGlvbi1jb250YWluZXItZWMvc2VjdGlvbi1jb250YWluZXItZWMuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9zdG9yZXMtZWMvc3RvcmVzLWVjLmNvbXBvbmVudCc7Il19
34
+ export * from './price-range-filter/price-range-filter.component';
35
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1lYXN5Y29tbWVyY2UtdjE4L3NyYy9saWIvZWMtY29tcG9uZW50cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsbUNBQW1DLENBQUM7QUFDbEQsY0FBYyx5Q0FBeUMsQ0FBQztBQUN4RCxjQUFjLDZDQUE2QyxDQUFDO0FBQzVELGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsV0FBVyxDQUFDO0FBQzFCLGNBQWMsbUNBQW1DLENBQUM7QUFDbEQsY0FBYyxpREFBaUQsQ0FBQztBQUNoRSxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMseUNBQXlDLENBQUM7QUFDeEQsY0FBYyxXQUFXLENBQUM7QUFDMUIsY0FBYyxpQ0FBaUMsQ0FBQztBQUNoRCxjQUFjLG1DQUFtQyxDQUFDO0FBQ2xELGNBQWMscUNBQXFDLENBQUM7QUFDcEQsY0FBYywrQ0FBK0MsQ0FBQztBQUM5RCxjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLCtEQUErRCxDQUFDO0FBQzlFLGNBQWMsbURBQW1ELENBQUM7QUFDbEUsY0FBYywyREFBMkQsQ0FBQztBQUMxRSxjQUFjLGlFQUFpRSxDQUFDO0FBQ2hGLGNBQWMsK0RBQStELENBQUE7QUFDN0UsY0FBYyxtRUFBbUUsQ0FBQTtBQUNqRixjQUFjLG1DQUFtQyxDQUFDO0FBQ2xELGNBQWMscURBQXFELENBQUM7QUFDcEUsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMsbUNBQW1DLENBQUM7QUFDbEQsY0FBYyw2Q0FBNkMsQ0FBQztBQUM1RCxjQUFjLHVEQUF1RCxDQUFDO0FBQ3RFLGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyxtREFBbUQsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vZm9vdGVyLWVjL2Zvb3Rlci1lYy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2hlYWRlci1lYy9oZWFkZXItZWMuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9ob21lLWVjL2hvbWUtZWMuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9ibG9ja3MtZWMvYmxvY2tzLWVjLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vcHJvZHVjdC1lYy9wcm9kdWN0LWVjLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vY29sbGVjdGlvbi1lYy9jb2xsZWN0aW9uLWVjLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vZmlsdGVycy1zb3J0LWVjL2ZpbHRlcnMtc29ydC1lYy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL3dpZGdldHMtZWMnO1xyXG5leHBvcnQgKiBmcm9tICcuL2F1dGgtZWMnO1xyXG5leHBvcnQgKiBmcm9tICcuL2ZpbHRlcnMtZWMvZmlsdGVycy1lYy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL3Byb2R1Y3QtZGV0YWlsLWVjL3Byb2R1Y3QtZGV0YWlsLWVjLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vdmFyaWFudHMtZWMvdmFyaWFudHMtZWMuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9icmVhZGNydW1iLWVjL2JyZWFkY3J1bWItZWMuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9jYXJ0LWVjJztcclxuZXhwb3J0ICogZnJvbSAnLi9jb3Vwb24tZWMvY291cG9uLWVjLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vY29udGFjdC1lYy9jb250YWN0LWVjLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vY2hlY2tvdXQtZWMvY2hlY2tvdXQtZWMuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9jaGVja291dC1lYy9zdWNjZXNzLWVjL3N1Y2Nlc3MtZWMuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9hY2NvdW50LWVjJztcclxuZXhwb3J0ICogZnJvbSAnLi9ibG9ja3MtZWMvYmxvY2stbmV3c2xldHRlci1lYy9ibG9jay1uZXdzbGV0dGVyLWVjLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vYmxvY2tzLWVjL2Jsb2NrLWh0bWwtZWMvYmxvY2staHRtbC1lYy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2Jsb2Nrcy1lYy9ibG9jay1wcm9kdWN0cy1lYy9ibG9jay1wcm9kdWN0cy1lYy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2Jsb2Nrcy1lYy9ibG9jay1iYW5uZXItZnVsbC1lYy9ibG9jay1iYW5uZXItZnVsbC1lYy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2Jsb2Nrcy1lYy9ibG9jay1iYW5uZXItYm94LWVjL2Jsb2NrLWJhbm5lci1ib3gtZWMuY29tcG9uZW50J1xyXG5leHBvcnQgKiBmcm9tICcuL2Jsb2Nrcy1lYy9ibG9jay1mb3JtLWNvbnRhY3QtZWMvYmxvY2stZm9ybS1jb250YWN0LWVjLmNvbXBvbmVudCdcclxuZXhwb3J0ICogZnJvbSAnLi9zaWRlYmFyLWVjL3NpZGViYXItZWMuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9yZWxhdGVkLXByb2R1Y3RzLWVjL3JlbGF0ZWQtcHJvZHVjdHMtZWMuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9mYXFzLWVjL2ZhcXMtZWMuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9zaGFyZS1lYy9zaGFyZS1lYy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL3Jldmlld3MtZWMvcmV2aWV3cy1lYy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL3Jldmlld3MtZm9ybS1lYy9yZXZpZXdzLWZvcm0tZWMuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9zZWN0aW9uLWNvbnRhaW5lci1lYy9zZWN0aW9uLWNvbnRhaW5lci1lYy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL3N0b3Jlcy1lYy9zdG9yZXMtZWMuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9wcmljZS1yYW5nZS1maWx0ZXIvcHJpY2UtcmFuZ2UtZmlsdGVyLmNvbXBvbmVudCc7Il19
@@ -0,0 +1,143 @@
1
+ import { ChangeDetectionStrategy, Component, EventEmitter, inject, Input, Output } from '@angular/core';
2
+ import { PriceRangeFilter } from '../../classes/filters/price_range-filter';
3
+ import { CommonModule } from '@angular/common';
4
+ import { EcCurrencySymbolPipe } from '../../ec-pipe';
5
+ import { FiltersService } from '../../ec-services';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "@angular/common";
8
+ export class PriceRangeFilterComponent {
9
+ _filtersService = inject(FiltersService);
10
+ priceGap = 1;
11
+ roundStep = 5;
12
+ filter;
13
+ rangeChanged = new EventEmitter();
14
+ getSliderStyle(filter) {
15
+ if (!(filter instanceof PriceRangeFilter))
16
+ return { left: '0%', right: '0%' };
17
+ const left = this.calculateLeftPercentage(filter);
18
+ const right = this.calculateRightPercentage(filter);
19
+ return { left: `${left}%`, right: `${right}%` };
20
+ }
21
+ // Métodos para actualizar la barra del filtro por precio
22
+ calculateLeftPercentage(filter) {
23
+ if (!(filter instanceof PriceRangeFilter))
24
+ return 0;
25
+ const min = filter.minPrice;
26
+ const max = filter.maxPrice;
27
+ const currentMin = filter.currentMinPrice ?? min;
28
+ const clampedMin = Math.max(min, Math.min(currentMin, max));
29
+ return Math.max(0, Math.min(((clampedMin - min) / (max - min)) * 100, 100));
30
+ }
31
+ calculateRightPercentage(filter) {
32
+ if (!(filter instanceof PriceRangeFilter))
33
+ return 0;
34
+ const min = filter.minPrice;
35
+ const max = filter.maxPrice;
36
+ const currentMax = filter.currentMaxPrice ?? max;
37
+ const clampedMax = Math.max(min, Math.min(currentMax, max));
38
+ return Math.max(0, Math.min(100 - ((clampedMax - min) / (max - min)) * 100, 100));
39
+ }
40
+ // Método para actualizar los valores de precio seleccionados
41
+ updatePriceRange(filter) {
42
+ if (!(filter instanceof PriceRangeFilter))
43
+ return;
44
+ const min = filter.currentMinPrice ?? filter.minPrice;
45
+ const max = filter.currentMaxPrice ?? filter.maxPrice;
46
+ this._filtersService.updatePriceRangeFilter(min, max);
47
+ }
48
+ getMinValue(filter) {
49
+ return (filter instanceof PriceRangeFilter && filter.currentMinPrice != null)
50
+ ? filter.currentMinPrice
51
+ : filter.minPrice;
52
+ }
53
+ getMaxValue(filter) {
54
+ return (filter instanceof PriceRangeFilter && filter.currentMaxPrice != null)
55
+ ? filter.currentMaxPrice
56
+ : filter.maxPrice;
57
+ }
58
+ /**
59
+ * Redondea al múltiplo de 'step' respetando el redondeo entero:
60
+ * - Mínimo: redondea hacia abajo.
61
+ * - Máximo: redondea hacia arriba.
62
+ */
63
+ onRangeChange(event, type, filter) {
64
+ const input = event.target;
65
+ let value = parseFloat(input.value);
66
+ value = this.roundToNearest(value, this.roundStep, type, filter);
67
+ this.updateFilterPrices(type, value, filter, this.priceGap);
68
+ }
69
+ roundToNearest(value, step, type, filter) {
70
+ let rounded = Math.round(value / step) * step;
71
+ if (type === 'max' && rounded < filter.maxPrice) {
72
+ rounded = Math.ceil(value / step) * step;
73
+ }
74
+ if (type === 'min' && rounded > filter.minPrice) {
75
+ rounded = Math.floor(value / step) * step;
76
+ }
77
+ return rounded;
78
+ }
79
+ /**
80
+ * Actualiza los valores del filtro permitiendo que un input empuje al otro.
81
+ */
82
+ updateFilterPrices(type, value, filter, priceGap) {
83
+ const globalMin = filter.minPrice ?? 0;
84
+ const globalMax = filter.maxPrice;
85
+ let currentMin = filter.currentMinPrice ?? globalMin;
86
+ let currentMax = filter.currentMaxPrice ?? globalMax;
87
+ if (type === 'min') {
88
+ let newMin = Math.min(Math.max(value, globalMin), globalMax);
89
+ if (newMin + priceGap > currentMax) {
90
+ let newMaxCandidate = newMin + priceGap;
91
+ if (newMaxCandidate <= globalMax) {
92
+ currentMax = newMaxCandidate;
93
+ }
94
+ else {
95
+ newMin = globalMax - priceGap;
96
+ }
97
+ }
98
+ filter.currentMinPrice = newMin;
99
+ filter.currentMaxPrice = currentMax;
100
+ }
101
+ else if (type === 'max') {
102
+ let newMax = Math.max(Math.min(value, globalMax), globalMin);
103
+ if (newMax - priceGap < currentMin) {
104
+ let newMinCandidate = newMax - priceGap;
105
+ if (newMinCandidate >= globalMin) {
106
+ currentMin = newMinCandidate;
107
+ }
108
+ else {
109
+ newMax = globalMin + priceGap;
110
+ }
111
+ }
112
+ filter.currentMaxPrice = newMax;
113
+ filter.currentMinPrice = currentMin;
114
+ }
115
+ }
116
+ scrollUp = () => {
117
+ window.scroll(0, 0);
118
+ return true;
119
+ };
120
+ getFormattedMinPrice(filter) {
121
+ const value = (filter instanceof PriceRangeFilter && filter.currentMinPrice != null)
122
+ ? filter.currentMinPrice
123
+ : filter.minPrice;
124
+ return value;
125
+ }
126
+ getFormattedMaxPrice(filter) {
127
+ const value = (filter instanceof PriceRangeFilter && filter.currentMaxPrice != null)
128
+ ? filter.currentMaxPrice
129
+ : filter.maxPrice;
130
+ return value;
131
+ }
132
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: PriceRangeFilterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
133
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: PriceRangeFilterComponent, isStandalone: true, selector: "lib-price-range-filter", inputs: { filter: "filter" }, outputs: { rangeChanged: "rangeChanged" }, ngImport: i0, template: "<div class=\"slider\">\r\n <div class=\"slider\">\r\n <div class=\"progress\" [ngStyle]=\"getSliderStyle(filter)\">\r\n </div>\r\n </div>\r\n</div>\r\n<div class=\"range-input d-flex gap-2\">\r\n <input #rangeMin type=\"range\" class=\"range-min\" [min]=\"filter.minPrice\" [max]=\"filter.maxPrice\"\r\n [value]=\"getMinValue(filter)\" (input)=\"onRangeChange($event, 'min', filter)\"\r\n (change)=\"updatePriceRange(filter); scrollUp()\">\r\n <input #rangeMax type=\"range\" class=\"range-max\" [min]=\"filter.minPrice\" [max]=\"filter.maxPrice\"\r\n [value]=\"getMaxValue(filter)\" (input)=\"onRangeChange($event, 'max', filter)\"\r\n (change)=\"updatePriceRange(filter); scrollUp()\">\r\n</div>\r\n<!-- precios M\u00EDnimo / M\u00E1ximo -->\r\n<div class=\"price-container mt-2\">\r\n <div class=\"price-label-wrapper\">\r\n <span class=\"price-label\">M\u00EDnimo:</span>\r\n <span class=\"price-value\">\r\n {{ (getFormattedMinPrice(filter) | ecCurrencySymbol) || '0' }}\r\n </span>\r\n </div>\r\n <div class=\"price-label-wrapper\">\r\n <span class=\"price-label\">M\u00E1ximo:</span>\r\n <span class=\"price-value price-value-right\">\r\n {{ getFormattedMaxPrice(filter) | ecCurrencySymbol }}\r\n </span>\r\n </div>\r\n</div>", styles: [":root{--slider-bg: #ddd;--slider-progress-bg: #0FA3AF;--thumb-bg: #0FA3AF;--thumb-border: #fff;--text-color: #131716;--label-color: #0FA3AF;--shadow-color: rgba(15, 163, 175, .4)}.slider{height:6px;border-radius:5px;background:var(--slider-bg);position:relative;overflow:hidden}.slider .progress{height:6px;position:absolute;left:0;right:0;border-radius:5px;background:var(--slider-progress-bg)}.range-input{position:relative;margin-bottom:14px}.range-input input[type=range]{position:absolute;top:-5px;width:100%;height:5px;background:none;pointer-events:none;-webkit-appearance:none}.range-input input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;pointer-events:auto;height:20px;width:20px;border-radius:50%;background:var(--thumb-bg);border:3px solid var(--thumb-border);cursor:pointer;box-shadow:0 4px 8px #0003}.range-input input[type=range]::-moz-range-thumb{-moz-appearance:none;pointer-events:auto;height:20px;width:20px;border-radius:50%;background:var(--thumb-bg);border:3px solid var(--thumb-border);cursor:pointer;box-shadow:0 4px 8px #0003}.range-input input[type=range]:focus::-webkit-slider-thumb,.range-input input[type=range]:focus::-moz-range-thumb{box-shadow:0 0 0 4px var(--shadow-color);outline:none}.price-container{display:flex;flex-wrap:wrap;gap:1rem}.price-label-wrapper{display:flex;flex-direction:column;flex:0 1 auto;min-width:0}.price-label{font-weight:600;color:var(--label-color);margin-bottom:.25rem}.price-value{white-space:nowrap;font-weight:700;color:var(--text-color);overflow:hidden;text-overflow:ellipsis;font-size:14px}.price-value-right{text-align:right}\n"], dependencies: [{ kind: "pipe", type: EcCurrencySymbolPipe, name: "ecCurrencySymbol" }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
134
+ }
135
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: PriceRangeFilterComponent, decorators: [{
136
+ type: Component,
137
+ args: [{ selector: 'lib-price-range-filter', standalone: true, imports: [EcCurrencySymbolPipe, CommonModule], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"slider\">\r\n <div class=\"slider\">\r\n <div class=\"progress\" [ngStyle]=\"getSliderStyle(filter)\">\r\n </div>\r\n </div>\r\n</div>\r\n<div class=\"range-input d-flex gap-2\">\r\n <input #rangeMin type=\"range\" class=\"range-min\" [min]=\"filter.minPrice\" [max]=\"filter.maxPrice\"\r\n [value]=\"getMinValue(filter)\" (input)=\"onRangeChange($event, 'min', filter)\"\r\n (change)=\"updatePriceRange(filter); scrollUp()\">\r\n <input #rangeMax type=\"range\" class=\"range-max\" [min]=\"filter.minPrice\" [max]=\"filter.maxPrice\"\r\n [value]=\"getMaxValue(filter)\" (input)=\"onRangeChange($event, 'max', filter)\"\r\n (change)=\"updatePriceRange(filter); scrollUp()\">\r\n</div>\r\n<!-- precios M\u00EDnimo / M\u00E1ximo -->\r\n<div class=\"price-container mt-2\">\r\n <div class=\"price-label-wrapper\">\r\n <span class=\"price-label\">M\u00EDnimo:</span>\r\n <span class=\"price-value\">\r\n {{ (getFormattedMinPrice(filter) | ecCurrencySymbol) || '0' }}\r\n </span>\r\n </div>\r\n <div class=\"price-label-wrapper\">\r\n <span class=\"price-label\">M\u00E1ximo:</span>\r\n <span class=\"price-value price-value-right\">\r\n {{ getFormattedMaxPrice(filter) | ecCurrencySymbol }}\r\n </span>\r\n </div>\r\n</div>", styles: [":root{--slider-bg: #ddd;--slider-progress-bg: #0FA3AF;--thumb-bg: #0FA3AF;--thumb-border: #fff;--text-color: #131716;--label-color: #0FA3AF;--shadow-color: rgba(15, 163, 175, .4)}.slider{height:6px;border-radius:5px;background:var(--slider-bg);position:relative;overflow:hidden}.slider .progress{height:6px;position:absolute;left:0;right:0;border-radius:5px;background:var(--slider-progress-bg)}.range-input{position:relative;margin-bottom:14px}.range-input input[type=range]{position:absolute;top:-5px;width:100%;height:5px;background:none;pointer-events:none;-webkit-appearance:none}.range-input input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;pointer-events:auto;height:20px;width:20px;border-radius:50%;background:var(--thumb-bg);border:3px solid var(--thumb-border);cursor:pointer;box-shadow:0 4px 8px #0003}.range-input input[type=range]::-moz-range-thumb{-moz-appearance:none;pointer-events:auto;height:20px;width:20px;border-radius:50%;background:var(--thumb-bg);border:3px solid var(--thumb-border);cursor:pointer;box-shadow:0 4px 8px #0003}.range-input input[type=range]:focus::-webkit-slider-thumb,.range-input input[type=range]:focus::-moz-range-thumb{box-shadow:0 0 0 4px var(--shadow-color);outline:none}.price-container{display:flex;flex-wrap:wrap;gap:1rem}.price-label-wrapper{display:flex;flex-direction:column;flex:0 1 auto;min-width:0}.price-label{font-weight:600;color:var(--label-color);margin-bottom:.25rem}.price-value{white-space:nowrap;font-weight:700;color:var(--text-color);overflow:hidden;text-overflow:ellipsis;font-size:14px}.price-value-right{text-align:right}\n"] }]
138
+ }], propDecorators: { filter: [{
139
+ type: Input
140
+ }], rangeChanged: [{
141
+ type: Output
142
+ }] } });
143
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"price-range-filter.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/price-range-filter/price-range-filter.component.ts","../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/price-range-filter/price-range-filter.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, inject, Input, Output } from '@angular/core';\r\nimport { PriceRangeFilter } from '../../classes/filters/price_range-filter';\r\nimport { CommonModule } from '@angular/common';\r\nimport { EcCurrencySymbolPipe } from '../../ec-pipe';\r\nimport { FiltersService } from '../../ec-services';\r\n\r\n@Component({\r\n  selector: 'lib-price-range-filter',\r\n  standalone: true,\r\n  imports: [EcCurrencySymbolPipe, CommonModule],\r\n  templateUrl: './price-range-filter.component.html',\r\n  styleUrl: './price-range-filter.component.scss',\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class PriceRangeFilterComponent {\r\n\r\n  private _filtersService: FiltersService = inject(FiltersService);\r\n\r\n  priceGap = 1;\r\n  roundStep = 5;\r\n\r\n  @Input() filter!: PriceRangeFilter;\r\n  @Output() rangeChanged = new EventEmitter<{ min: number; max: number }>();\r\n\r\n  getSliderStyle(filter: any): { [klass: string]: string } {\r\n    if (!(filter instanceof PriceRangeFilter)) return { left: '0%', right: '0%' };\r\n\r\n    const left = this.calculateLeftPercentage(filter);\r\n    const right = this.calculateRightPercentage(filter);\r\n    return { left: `${left}%`, right: `${right}%` };\r\n  }\r\n\r\n  // Métodos para actualizar la barra del filtro por precio\r\n  calculateLeftPercentage(filter: any): number {\r\n    if (!(filter instanceof PriceRangeFilter)) return 0;\r\n\r\n    const min = filter.minPrice;\r\n    const max = filter.maxPrice;\r\n    const currentMin = filter.currentMinPrice ?? min;\r\n\r\n    const clampedMin = Math.max(min, Math.min(currentMin, max));\r\n    return Math.max(0, Math.min(((clampedMin - min) / (max - min)) * 100, 100));\r\n  }\r\n\r\n  calculateRightPercentage(filter: any): number {\r\n    if (!(filter instanceof PriceRangeFilter)) return 0;\r\n\r\n    const min = filter.minPrice;\r\n    const max = filter.maxPrice;\r\n    const currentMax = filter.currentMaxPrice ?? max;\r\n\r\n    const clampedMax = Math.max(min, Math.min(currentMax, max));\r\n    return Math.max(0, Math.min(100 - ((clampedMax - min) / (max - min)) * 100, 100));\r\n  }\r\n\r\n  // Método para actualizar los valores de precio seleccionados\r\n  updatePriceRange(filter: any) {\r\n    if (!(filter instanceof PriceRangeFilter)) return;\r\n\r\n    const min = filter.currentMinPrice ?? filter.minPrice;\r\n    const max = filter.currentMaxPrice ?? filter.maxPrice;\r\n    this._filtersService.updatePriceRangeFilter(min, max);\r\n  }\r\n\r\n  getMinValue(filter: any): number {\r\n    return (filter instanceof PriceRangeFilter && filter.currentMinPrice != null)\r\n      ? filter.currentMinPrice\r\n      : filter.minPrice;\r\n  }\r\n\r\n  getMaxValue(filter: any): number {\r\n    return (filter instanceof PriceRangeFilter && filter.currentMaxPrice != null)\r\n      ? filter.currentMaxPrice\r\n      : filter.maxPrice;\r\n  }\r\n\r\n  /**\r\n  * Redondea al múltiplo de 'step' respetando el redondeo entero:\r\n  * - Mínimo: redondea hacia abajo.\r\n  * - Máximo: redondea hacia arriba.\r\n  */\r\n  onRangeChange(event: Event, type: 'min' | 'max', filter: any) {\r\n    const input = event.target as HTMLInputElement;\r\n    let value = parseFloat(input.value);\r\n    value = this.roundToNearest(value, this.roundStep, type, filter);\r\n    this.updateFilterPrices(type, value, filter, this.priceGap);\r\n  }\r\n\r\n  protected roundToNearest(value: number, step: number, type: 'min' | 'max', filter: any): number {\r\n    let rounded = Math.round(value / step) * step;\r\n    if (type === 'max' && rounded < filter.maxPrice) {\r\n      rounded = Math.ceil(value / step) * step;\r\n    }\r\n    if (type === 'min' && rounded > filter.minPrice) {\r\n      rounded = Math.floor(value / step) * step;\r\n    }\r\n    return rounded;\r\n  }\r\n\r\n  /**\r\n  * Actualiza los valores del filtro permitiendo que un input empuje al otro.\r\n  */\r\n  protected updateFilterPrices(type: 'min' | 'max', value: number, filter: any, priceGap: number) {\r\n    const globalMin = filter.minPrice ?? 0;\r\n    const globalMax = filter.maxPrice;\r\n\r\n    let currentMin = filter.currentMinPrice ?? globalMin;\r\n    let currentMax = filter.currentMaxPrice ?? globalMax;\r\n\r\n    if (type === 'min') {\r\n      let newMin = Math.min(Math.max(value, globalMin), globalMax);\r\n      if (newMin + priceGap > currentMax) {\r\n        let newMaxCandidate = newMin + priceGap;\r\n        if (newMaxCandidate <= globalMax) {\r\n          currentMax = newMaxCandidate;\r\n        } else {\r\n          newMin = globalMax - priceGap;\r\n        }\r\n      }\r\n      filter.currentMinPrice = newMin;\r\n      filter.currentMaxPrice = currentMax;\r\n    } else if (type === 'max') {\r\n      let newMax = Math.max(Math.min(value, globalMax), globalMin);\r\n      if (newMax - priceGap < currentMin) {\r\n        let newMinCandidate = newMax - priceGap;\r\n        if (newMinCandidate >= globalMin) {\r\n          currentMin = newMinCandidate;\r\n        } else {\r\n          newMax = globalMin + priceGap;\r\n        }\r\n      }\r\n      filter.currentMaxPrice = newMax;\r\n      filter.currentMinPrice = currentMin;\r\n    }\r\n  }\r\n\r\n  scrollUp = () => {\r\n    window.scroll(0, 0);\r\n    return true\r\n  }\r\n\r\n  getFormattedMinPrice(filter: any): string {\r\n    const value = (filter instanceof PriceRangeFilter && filter.currentMinPrice != null)\r\n      ? filter.currentMinPrice\r\n      : filter.minPrice;\r\n    return value;\r\n  }\r\n\r\n  getFormattedMaxPrice(filter: any): string {\r\n    const value = (filter instanceof PriceRangeFilter && filter.currentMaxPrice != null)\r\n      ? filter.currentMaxPrice\r\n      : filter.maxPrice;\r\n    return value;\r\n  }\r\n}\r\n","<div class=\"slider\">\r\n    <div class=\"slider\">\r\n        <div class=\"progress\" [ngStyle]=\"getSliderStyle(filter)\">\r\n        </div>\r\n    </div>\r\n</div>\r\n<div class=\"range-input d-flex gap-2\">\r\n    <input #rangeMin type=\"range\" class=\"range-min\" [min]=\"filter.minPrice\" [max]=\"filter.maxPrice\"\r\n        [value]=\"getMinValue(filter)\" (input)=\"onRangeChange($event, 'min', filter)\"\r\n        (change)=\"updatePriceRange(filter); scrollUp()\">\r\n    <input #rangeMax type=\"range\" class=\"range-max\" [min]=\"filter.minPrice\" [max]=\"filter.maxPrice\"\r\n        [value]=\"getMaxValue(filter)\" (input)=\"onRangeChange($event, 'max', filter)\"\r\n        (change)=\"updatePriceRange(filter); scrollUp()\">\r\n</div>\r\n<!-- precios Mínimo / Máximo -->\r\n<div class=\"price-container mt-2\">\r\n    <div class=\"price-label-wrapper\">\r\n        <span class=\"price-label\">Mínimo:</span>\r\n        <span class=\"price-value\">\r\n            {{ (getFormattedMinPrice(filter) | ecCurrencySymbol) || '0' }}\r\n        </span>\r\n    </div>\r\n    <div class=\"price-label-wrapper\">\r\n        <span class=\"price-label\">Máximo:</span>\r\n        <span class=\"price-value price-value-right\">\r\n            {{ getFormattedMaxPrice(filter) | ecCurrencySymbol }}\r\n        </span>\r\n    </div>\r\n</div>"]}