ng-easycommerce-v18 0.3.20-beta.2 → 0.3.21-beta.1

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 (26) hide show
  1. package/README.md +2 -16
  2. package/esm2022/lib/classes/filters/attributes-filter.mjs +4 -74
  3. package/esm2022/lib/classes/filters/category-filter.mjs +26 -105
  4. package/esm2022/lib/classes/filters/filter-factory.mjs +3 -7
  5. package/esm2022/lib/classes/filters/price_range-filter.mjs +3 -3
  6. package/esm2022/lib/constants/core.constants.service.mjs +1 -12
  7. package/esm2022/lib/ec-components/collection-ec/collection-ec.component.mjs +17 -41
  8. package/esm2022/lib/ec-components/filters-ec/filters-ec.component.mjs +9 -42
  9. package/esm2022/lib/ec-components/header-ec/header-ec.component.mjs +5 -13
  10. package/esm2022/lib/ec-components/price-range-filter/price-range-filter.component.mjs +2 -13
  11. package/esm2022/lib/ec-components/widgets-ec/redsys-catch-ec/redsys-catch-ec.component.mjs +17 -7
  12. package/esm2022/lib/ec-services/filters.service.mjs +18 -124
  13. package/esm2022/lib/ec-services/pagination.service.mjs +22 -70
  14. package/esm2022/lib/ec-services/products.service.mjs +3 -5
  15. package/fesm2022/ng-easycommerce-v18.mjs +113 -497
  16. package/fesm2022/ng-easycommerce-v18.mjs.map +1 -1
  17. package/lib/classes/filters/attributes-filter.d.ts +0 -24
  18. package/lib/classes/filters/category-filter.d.ts +3 -30
  19. package/lib/constants/core.constants.service.d.ts +0 -7
  20. package/lib/ec-components/collection-ec/collection-ec.component.d.ts +4 -5
  21. package/lib/ec-components/filters-ec/filters-ec.component.d.ts +0 -13
  22. package/lib/ec-components/price-range-filter/price-range-filter.component.d.ts +0 -2
  23. package/lib/ec-services/filters.service.d.ts +1 -18
  24. package/lib/ec-services/pagination.service.d.ts +5 -21
  25. package/lib/ec-services/products.service.d.ts +1 -1
  26. package/package.json +1 -1
@@ -30,11 +30,6 @@ export class CoreConstantsService {
30
30
  * Guarda la variable window del web browser.
31
31
  */
32
32
  window;
33
- /**
34
- * Tipo de ruta actual (ej: 'categories', 'attributes', etc).
35
- * Lo usamos para que PaginationService sepa qué filtro esperar.
36
- */
37
- currentRouteType = null;
38
33
  constructor() {
39
34
  if (isPlatformBrowser(this.platformId)) {
40
35
  this.window = window;
@@ -312,12 +307,6 @@ export class CoreConstantsService {
312
307
  return this.apiConstants.CHANNEL;
313
308
  }
314
309
  form_sender = false;
315
- setCurrentRouteType(type) {
316
- this.currentRouteType = type;
317
- }
318
- getCurrentRouteType() {
319
- return this.currentRouteType;
320
- }
321
310
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CoreConstantsService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
322
311
  static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CoreConstantsService, providedIn: 'root' });
323
312
  }
@@ -327,4 +316,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
327
316
  providedIn: 'root'
328
317
  }]
329
318
  }], ctorParameters: () => [] });
330
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core.constants.service.js","sourceRoot":"","sources":["../../../../../projects/ng-easycommerce-v18/src/lib/constants/core.constants.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAChE,OAAO,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AAC9D,OAAO,EAAE,iBAAiB,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAE9D,OAAO,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAC;;AACjD;;;;GAIG;AAIH,MAAM,OAAO,oBAAoB;IAEzB,WAAW,GAAW,EAAE,CAAC;IAChC;;OAEG;IACK,YAAY,GAAG,MAAM,CAAC,mBAAmB,CAAC,CAAA;IAClD;;OAEG;IACK,UAAU,GAAQ,MAAM,CAAC,WAAW,CAAC,CAAA;IAC7C;;OAEG;IACK,QAAQ,GAAa,MAAM,CAAC,QAAQ,CAAC,CAAA;IAC7C;;OAEG;IACK,WAAW,GAAgB,MAAM,CAAC,iBAAiB,CAAC,CAAA;IAC5D;;OAEG;IACK,MAAM,CAAS;IAEvB;;;OAGG;IACI,gBAAgB,GAAkB,IAAI,CAAC;IAE9C;QACC,IAAI,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;YACxC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAA;QACrB,CAAC;IACF,CAAC;IACD;;OAEG;IACI,kBAAkB,GAAW,aAAa,CAAC;IAClD;;OAEG;IACI,cAAc,GAAW,WAAW,CAAC;IAC5C;;OAEG;IACa,UAAU,GAAW,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC;IAC/D;;;;OAIG;IACI,QAAQ,GAAG,CAAC,SAAkB,EAAE,EAAE,CAAC,IAAI,CAAC,UAAU,GAAG,CAAC,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC;IAChK;;;;OAIG;IACI,aAAa,GAAG,CAAC,SAAkB,EAAE,EAAE,CAAC,IAAI,CAAC,UAAU,GAAG,CAAC,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC;IAC3K;;;;OAIG;IACI,GAAG,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,CAAC,qBAAqB;IAEtF;;OAEG;IACH,IAAW,YAAY;QACtB,uCAAuC;QACvC,IAAI,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;YACxC,mEAAmE;YACnE,MAAM,SAAS,GAAI,IAAI,CAAC,MAAc,EAAE,KAAK,CAAC;YAC9C,IAAI,SAAS,EAAE,WAAW,EAAE,CAAC;gBAC5B,mCAAmC;gBACnC,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC;oBAC/C,OAAO,CAAC,IAAI,CAAC,4CAA4C,EAAE,SAAS,CAAC,WAAW,CAAC,CAAC;gBACnF,CAAC;gBACD,OAAO,SAAS,CAAC,WAAW,CAAC;YAC9B,CAAC;YAED,sEAAsE;YACtE,IAAI,IAAI,CAAC,MAAM,EAAE,QAAQ,EAAE,CAAC;gBAC3B,MAAM,GAAG,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,QAAQ,KAAK,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;gBAC7E,2DAA2D;gBAC3D,IAAI,GAAG,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,GAAG,CAAC,QAAQ,CAAC,WAAW,CAAC,EAAE,CAAC;oBAC5D,OAAO,CAAC,IAAI,CAAC,6FAA6F,CAAC,CAAC;gBAC7G,CAAC;gBACD,OAAO,GAAG,CAAC;YACZ,CAAC;QACF,CAAC;QAED,oEAAoE;QACpE,IAAI,IAAI,CAAC,QAAQ,EAAE,QAAQ,EAAE,CAAC;YAC7B,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,QAAQ,KAAK,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QAC7E,CAAC;QAED,qCAAqC;QACrC,IAAI,IAAI,CAAC,WAAW,CAAC,WAAW,EAAE,CAAC;YAClC,OAAO,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC;QACrC,CAAC;QAED,0EAA0E;QAC1E,MAAM,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC;QACzC,IAAI,MAAM,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,SAAS,CAAC,IAAI,MAAM,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC,EAAE,CAAC;YAC/E,IAAI,CAAC;gBACJ,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,MAAM,CAAC,CAAC;gBAC5B,OAAO,GAAG,GAAG,CAAC,QAAQ,KAAK,GAAG,CAAC,IAAI,EAAE,CAAC;YACvC,CAAC;YAAC,OAAO,CAAC,EAAE,CAAC;gBACZ,OAAO,CAAC,IAAI,CAAC,qDAAqD,EAAE,MAAM,CAAC,CAAC;YAC7E,CAAC;QACF,CAAC;QAED,sCAAsC;QACtC,OAAO,CAAC,IAAI,CAAC,kFAAkF,CAAC,CAAC;QACjG,OAAO,EAAE,CAAC;IACX,CAAC;IAED;;;;OAIG;IACI,cAAc,GAAG,CAAC,IAAa,EAAU,EAAE;QACjD,MAAM,OAAO,GAAG,IAAI,CAAC,YAAY,CAAC;QAClC,IAAI,CAAC,IAAI,EAAE,CAAC;YACX,OAAO,OAAO,CAAC;QAChB,CAAC;QAED,+DAA+D;QAC/D,MAAM,SAAS,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,IAAI,EAAE,CAAC;QAC3D,MAAM,YAAY,GAAG,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;QAE5E,OAAO,GAAG,YAAY,GAAG,SAAS,EAAE,CAAC;IACtC,CAAC,CAAA;IAED;;;;OAIG;IACI,mBAAmB,GAAG,CAAC,SAAkB,EAAU,EAAE;QAC3D,qDAAqD;QACrD,IAAI,SAAS,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,SAAS,CAAC,IAAI,SAAS,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC,EAAE,CAAC;YACxF,OAAO,SAAS,CAAC;QAClB,CAAC;QAED,sDAAsD;QACtD,MAAM,QAAQ,GAAG,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC;QAE/C,oDAAoD;QACpD,IAAI,QAAQ,CAAC,UAAU,CAAC,SAAS,CAAC,IAAI,QAAQ,CAAC,UAAU,CAAC,UAAU,CAAC,EAAE,CAAC;YACvE,OAAO,QAAQ,CAAC;QACjB,CAAC;QAED,4EAA4E;QAC5E,MAAM,UAAU,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC;QAC7C,IAAI,UAAU,CAAC,UAAU,CAAC,SAAS,CAAC,IAAI,UAAU,CAAC,UAAU,CAAC,UAAU,CAAC,EAAE,CAAC;YAC3E,yBAAyB;YACzB,OAAO,QAAQ,CAAC;QACjB,CAAC;QAED,6DAA6D;QAC7D,MAAM,WAAW,GAAG,IAAI,CAAC,YAAY,CAAC;QACtC,IAAI,CAAC,WAAW,EAAE,CAAC;YAClB,OAAO,QAAQ,CAAC,CAAC,wDAAwD;QAC1E,CAAC;QAED,yBAAyB;QACzB,MAAM,WAAW,GAAG,UAAU,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC;QACtF,MAAM,gBAAgB,GAAG,WAAW,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC;QAC5F,MAAM,aAAa,GAAG,QAAQ,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC;QAElF,OAAO,GAAG,gBAAgB,IAAI,WAAW,GAAG,aAAa,EAAE,CAAC;IAC7D,CAAC,CAAA;IAED;;;OAGG;IACI,cAAc,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,GAAG,CAAC,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,eAAe,CAAC;IAEjI,aAAa,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,GAAG,CAAC,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,cAAc,CAAC;IAExH;;;OAGG;IACI,YAAY,GAAG,GAAY,EAAE,CAAC,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,EAAE,UAAU,GAAG,GAAG,IAAI,KAAK,CAAC;IAC3F;;OAEG;IACI,QAAQ,GAAmB;QACjC,IAAI,EAAE,KAAK;QACX,MAAM,EAAE,GAAG;QACX,QAAQ,EAAE,MAAM;QAChB,cAAc,EAAE,KAAK;KACrB,CAAC;IAEF;;OAEG;IACI,kBAAkB,GAAqB;QAC7C;YACC,IAAI,EAAE,KAAK;YACX,MAAM,EAAE,GAAG;YACX,QAAQ,EAAE,OAAO;YACjB,cAAc,EAAE,KAAK;SAErB;QACD;YACC,IAAI,EAAE,KAAK;YACX,MAAM,EAAE,GAAG;YACX,QAAQ,EAAE,MAAM;YAChB,cAAc,EAAE,KAAK;SACrB;QACD;YACC,IAAI,EAAE,KAAK;YACX,MAAM,EAAE,GAAG;YACX,QAAQ,EAAE,MAAM;YAChB,cAAc,EAAE,KAAK;SACrB;QACD;YACC,IAAI,EAAE,KAAK;YACX,MAAM,EAAE,GAAG;YACX,QAAQ,EAAE,MAAM;YAChB,cAAc,EAAE,KAAK;SACrB;QACD;YACC,IAAI,EAAE,KAAK;YACX,MAAM,EAAE,KAAK;YACb,QAAQ,EAAE,MAAM;YAChB,cAAc,EAAE,KAAK;SACrB;QACD;YACC,IAAI,EAAE,KAAK;YACX,MAAM,EAAE,IAAI;YACZ,QAAQ,EAAE,MAAM;YAChB,cAAc,EAAE,KAAK;SACrB;QACD;YACC,IAAI,EAAE,KAAK;YACX,MAAM,EAAE,KAAK;YACb,QAAQ,EAAE,OAAO;YACjB,cAAc,EAAE,IAAI;SACpB;KACD,CAAA;IACD;;;OAGG;IACI,qBAAqB,CAAC,kBAAoC;QAChE,IAAI,CAAC,kBAAkB,GAAG,kBAAkB,CAAC;IAC9C,CAAC;IAED;;;;;;OAMG;IACI,WAAW,CAAC,gBAA8B,EAAE,UAA2B;QAC7E,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC,EAAkB,EAAE,EAAE,CAAC,EAAE,CAAC,IAAI,IAAI,gBAAgB,CAAC,WAAW,EAAE,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAA;QAChI,UAAU,IAAI,CAAC,IAAI,CAAC,QAAQ,GAAG,EAAE,GAAG,IAAI,CAAC,QAAQ,EAAE,GAAG,UAAU,EAAE,CAAC,CAAA;QACnE,OAAO,IAAI,CAAC,QAAQ,CAAC;IACtB,CAAC;IAAA,CAAC;IAGK,mBAAmB,CAAC,aAAkB;QAC5C,IAAI,aAAa,CAAC,OAAO,IAAI,aAAa,CAAC,IAAI;YAC9C,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,aAAa,CAAC,OAAO,IAAI,aAAa,CAAC,IAAI,CAAC,CAAA;QAE1E,IAAI,aAAa,CAAC,MAAM,IAAI,aAAa,CAAC,OAAO,CAAC,IAAI;YACrD,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,aAAa,CAAC,MAAM,IAAI,aAAa,CAAC,OAAO,CAAC,IAAI,CAAC,CAAA;QAEhF,IAAI,aAAa,CAAC,QAAQ,IAAI,aAAa,CAAC,YAAY;YACvD,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,QAAQ,IAAI,aAAa,CAAC,YAAY,CAAC,CAAA;QAEvE,OAAO,aAAa,CAAC;IACtB,CAAC;IAED;;;MAGE;IACM,WAAW,GAAa,CAAC,OAAO,EAAE,YAAY,EAAE,QAAQ,CAAC,CAAA;IAEjE;;;;;;OAMG;IACH,cAAc,GAAG,CAAC,cAAwB,CAAC,KAAK,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;IAErF,cAAc,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC;IAExC,kBAAkB;IACV,yBAAyB,GAAY,KAAK,CAAC;IACnD,2BAA2B,CAAC,KAAc,IAAI,IAAI,CAAC,yBAAyB,GAAG,KAAK,CAAC,CAAC,CAAC;IACvF,2BAA2B,KAAK,OAAO,IAAI,CAAC,yBAAyB,CAAA,CAAC,CAAC;IAEvE;;;;;;;;;;;;;;MAcE;IACM,+BAA+B,GAAoC;QAC1E,IAAI,EAAE,OAAO;QACb,IAAI,EAAE,OAAO;QACb,kBAAkB,EAAE,KAAK;QACzB,YAAY,EAAE,IAAI;KAClB,CAAA;IAED,kCAAkC,GAAG,CAAC,KAAsC,EAAE,EAAE;QAC/E,IAAI,CAAC,+BAA+B,GAAG;YACtC,GAAG,IAAI,CAAC,+BAA+B;YACvC,GAAG,KAAK;SACR,CAAA;IACF,CAAC,CAAA;IAED,kCAAkC,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,+BAA+B,CAAA;IAExE,UAAU;QAChB,OAAO,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC;IAClC,CAAC;IAEM,WAAW,GAAY,KAAK,CAAC;IAEpC,mBAAmB,CAAC,IAAmB;QACtC,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;IAC9B,CAAC;IAED,mBAAmB;QAClB,OAAO,IAAI,CAAC,gBAAgB,CAAC;IAC9B,CAAC;wGA5VW,oBAAoB;4GAApB,oBAAoB,cAFpB,MAAM;;4FAEN,oBAAoB;kBAHhC,UAAU;mBAAC;oBACX,UAAU,EAAE,MAAM;iBAClB","sourcesContent":["import { inject, Injectable, PLATFORM_ID } from '@angular/core';\nimport { ApiConstantsService } from './api.constants.service';\nimport { isPlatformBrowser, DOCUMENT } from '@angular/common';\nimport { CurrencyConfig, currencyType, ParamsProductsWithUniqueVariant, Environment } from '../interfaces';\nimport { ENVIRONMENT_TOKEN } from '../providers';\n/**\n * Servicio que provee las constantes necesarias que se utilizan por toda la aplicación.\n * @export\n * @class CoreConstantsService\n */\n@Injectable({\n\tprovidedIn: 'root'\n})\nexport class CoreConstantsService {\n\n\tpublic searchValue: string = '';\n\t/**\n\t * Servicio que contiene las constantes usadas para la API\n\t */\n\tprivate apiConstants = inject(ApiConstantsService)\n\t/**\n\t * Provee el ID de la plataforma en donde se esta ejecutando el codigo, esto sirve para poder diferenciar si es de un servidor o un navegador web.\n\t */\n\tprivate platformId: any = inject(PLATFORM_ID)\n\t/**\n\t * Document token para acceso SSR-compatible al documento\n\t */\n\tprivate document: Document = inject(DOCUMENT)\n\t/**\n\t * Contiene los datos provisto por el frontend en el archivo environment.ts\n\t */\n\tprivate environment: Environment = inject(ENVIRONMENT_TOKEN)\n\t/**\n\t * Guarda la variable window del web browser.\n\t */\n\tprivate window?:Window;\n\n\t/**\n\t * Tipo de ruta actual (ej: 'categories', 'attributes', etc).\n\t * Lo usamos para que PaginationService sepa qué filtro esperar.\n\t */\n\tpublic currentRouteType: string | null = null;\n\n\tconstructor() {\n\t\tif (isPlatformBrowser(this.platformId)) {\n\t\t\tthis.window = window\n\t\t}\n\t}\n\t/**\n\t * Path usado en las colecciones de productos.\n\t */\n\tpublic PRODUCT_LIST_ROUTE: string = 'collection/';\n\t/**\n\t * Path usado para acceder a las secciones.\n\t */\n\tpublic SECTIONS_ROUTE: string = 'sections/';\n\t/**\n\t * Path que aloja la carpeta de los assets.\n\t */\n\tpublic readonly ASSETS_URL: string = this.apiConstants.API_URL;\n\t/**\n\t * Retorna la url donde se guarda las imagenes.\n\t * @param postMedia \n\t * @returns \n\t */\n\tpublic mediaUrl = (postMedia?: string) => this.ASSETS_URL + (this.ASSETS_URL == this.apiConstants.API_URL ? 'media/' : '') + (postMedia ? postMedia : \"image/\");\n\t/**\n\t * Retorna la url donde se guarda las imagenes.\n\t * @param postMedia \n\t * @returns \n\t */\n\tpublic mediaImageUrl = (postMedia?: string) => this.ASSETS_URL + (this.ASSETS_URL == this.apiConstants.API_URL ? 'media/image/' : '') + (postMedia ? postMedia : \"image/\");\n\t/**\n\t * Retorna la url del sitio.\n\t * @param postMedia \n\t * @returns \n\t */\n\tpublic url = () => this.apiConstants.API_URL.replace(/\\/$/, ''); // remove last slash\t\n\n\t/**\n\t * URL del sitio frontend - Compatible con Angular SSR\n\t */\n\tpublic get FRONTEND_URL(): string {\n\t\t// Verificar si estamos en el navegador\n\t\tif (isPlatformBrowser(this.platformId)) {\n\t\t\t// Primero intenta leer de window.__env (configurado por Docker/CI)\n\t\t\tconst windowEnv = (this.window as any)?.__env;\n\t\t\tif (windowEnv?.frontendUrl) {\n\t\t\t\t// Log para debugging en desarrollo\n\t\t\t\tif (!windowEnv.frontendUrl.startsWith('http')) {\n\t\t\t\t\tconsole.warn('[FRONTEND_URL] Invalid frontendUrl format:', windowEnv.frontendUrl);\n\t\t\t\t}\n\t\t\t\treturn windowEnv.frontendUrl;\n\t\t\t}\n\t\t\t\n\t\t\t// Si no hay configuración específica, construir desde window.location\n\t\t\tif (this.window?.location) {\n\t\t\t\tconst url = `${this.window.location.protocol}//${this.window.location.host}`;\n\t\t\t\t// Verificar que no sea localhost o 127.0.0.1 en producción\n\t\t\t\tif (url.includes('127.0.0.1') || url.includes('localhost')) {\n\t\t\t\t\tconsole.warn('[FRONTEND_URL] Using localhost URL in production, consider setting window.__env.frontendUrl');\n\t\t\t\t}\n\t\t\t\treturn url;\n\t\t\t}\n\t\t}\n\t\t\n\t\t// Para SSR, intentar construir desde el document si está disponible\n\t\tif (this.document?.location) {\n\t\t\treturn `${this.document.location.protocol}//${this.document.location.host}`;\n\t\t}\n\t\t\n\t\t// Intentar obtener desde environment\n\t\tif (this.environment.frontendUrl) {\n\t\t\treturn this.environment.frontendUrl;\n\t\t}\n\t\t\n\t\t// Último fallback - usar la URL del API si está configurada y es absoluta\n\t\tconst apiUrl = this.apiConstants.API_URL;\n\t\tif (apiUrl && (apiUrl.startsWith('http://') || apiUrl.startsWith('https://'))) {\n\t\t\ttry {\n\t\t\t\tconst url = new URL(apiUrl);\n\t\t\t\treturn `${url.protocol}//${url.host}`;\n\t\t\t} catch (e) {\n\t\t\t\tconsole.warn('[FRONTEND_URL] Could not parse API URL as fallback:', apiUrl);\n\t\t\t}\n\t\t}\n\t\t\n\t\t// Fallback final - retornar URL vacía\n\t\tconsole.warn('[FRONTEND_URL] No valid frontend URL found, this may cause issues with meta tags');\n\t\treturn '';\n\t}\n\n\t/**\n\t * Retorna la URL completa del frontend con una ruta opcional\n\t * @param path - Ruta opcional para agregar a la URL base\n\t * @returns {string} URL completa del frontend\n\t */\n\tpublic getFrontendUrl = (path?: string): string => {\n\t\tconst baseUrl = this.FRONTEND_URL;\n\t\tif (!path) {\n\t\t\treturn baseUrl;\n\t\t}\n\t\t\n\t\t// Asegurar que la ruta comience con '/' y no tenga doble slash\n\t\tconst cleanPath = path.startsWith('/') ? path : `/${path}`;\n\t\tconst cleanBaseUrl = baseUrl.endsWith('/') ? baseUrl.slice(0, -1) : baseUrl;\n\t\t\n\t\treturn `${cleanBaseUrl}${cleanPath}`;\n\t}\n\n\t/**\n\t * Retorna la URL absoluta de una imagen para meta tags (compatible con SSR)\n\t * @param postMedia - Ruta de la imagen\n\t * @returns {string} URL absoluta de la imagen\n\t */\n\tpublic getAbsoluteImageUrl = (postMedia?: string): string => {\n\t\t// Si la URL ya es absoluta, devolverla tal como está\n\t\tif (postMedia && (postMedia.startsWith('http://') || postMedia.startsWith('https://'))) {\n\t\t\treturn postMedia;\n\t\t}\n\n\t\t// Construir la URL de la imagen usando la URL del API\n\t\tconst imageUrl = this.mediaImageUrl(postMedia);\n\t\t\n\t\t// Si la URL de la imagen ya es absoluta, devolverla\n\t\tif (imageUrl.startsWith('http://') || imageUrl.startsWith('https://')) {\n\t\t\treturn imageUrl;\n\t\t}\n\t\t\n\t\t// Si es una URL relativa, convertirla a absoluta usando la URL base del API\n\t\tconst apiBaseUrl = this.apiConstants.API_URL;\n\t\tif (apiBaseUrl.startsWith('http://') || apiBaseUrl.startsWith('https://')) {\n\t\t\t// API_URL ya es absoluta\n\t\t\treturn imageUrl;\n\t\t}\n\t\t\n\t\t// Si API_URL es relativa, usar la URL del frontend como base\n\t\tconst frontendUrl = this.FRONTEND_URL;\n\t\tif (!frontendUrl) {\n\t\t\treturn imageUrl; // Fallback si no podemos determinar la URL del frontend\n\t\t}\n\t\t\n\t\t// Construir URL absoluta\n\t\tconst cleanApiUrl = apiBaseUrl.startsWith('/') ? apiBaseUrl.substring(1) : apiBaseUrl;\n\t\tconst cleanFrontendUrl = frontendUrl.endsWith('/') ? frontendUrl.slice(0, -1) : frontendUrl;\n\t\tconst cleanImageUrl = imageUrl.startsWith('/') ? imageUrl.substring(1) : imageUrl;\n\t\t\n\t\treturn `${cleanFrontendUrl}/${cleanApiUrl}${cleanImageUrl}`;\n\t}\n\n\t/**\n\t * Retorna la url de las imagenes de los banners\n\t * @returns \n\t */\n\tpublic mediaBannerUrl = () => this.ASSETS_URL + (this.ASSETS_URL == this.apiConstants.API_URL ? 'media/' : '') + \"banner-image/\";\n\t\n\tmediaStoreUrl = () => this.ASSETS_URL + (this.ASSETS_URL == this.apiConstants.API_URL ? 'media/' : '') + \"store-image/\";\n\t\n\t/**\n\t * Retorna `true` si la vista es mobile, `false` caso contrario.\n\t * @returns {boolean}\n\t */\n\tpublic mobileScreen = (): boolean => this.window && this.window?.innerWidth < 750 || false;\n\t/**\n\t * Contiene los valores para la moneda actual\n\t */\n\tpublic currency: CurrencyConfig = {\n\t\tcode: 'ARG',\n\t\tsymbol: '$',\n\t\tposition: 'Left',\n\t\twithoutDecimal: false\n\t};\n\n\t/**\n\t * Arreglo de valores usados para el pipe currencyPrice\n\t */\n\tpublic currencyTypeConfig: CurrencyConfig[] = [\n\t\t{\n\t\t\tcode: 'EUR',\n\t\t\tsymbol: '€',\n\t\t\tposition: 'Right',\n\t\t\twithoutDecimal: false\n\n\t\t},\n\t\t{\n\t\t\tcode: 'ARG',\n\t\t\tsymbol: '$',\n\t\t\tposition: 'Left',\n\t\t\twithoutDecimal: false\n\t\t},\n\t\t{\n\t\t\tcode: 'ARS',\n\t\t\tsymbol: '$',\n\t\t\tposition: 'Left',\n\t\t\twithoutDecimal: false\n\t\t},\n\t\t{\n\t\t\tcode: 'USD',\n\t\t\tsymbol: '$',\n\t\t\tposition: 'Left',\n\t\t\twithoutDecimal: false\n\t\t},\n\t\t{\n\t\t\tcode: 'PYG',\n\t\t\tsymbol: 'Gs.',\n\t\t\tposition: 'Left',\n\t\t\twithoutDecimal: false\n\t\t},\n\t\t{\n\t\t\tcode: 'PEN',\n\t\t\tsymbol: 'S/',\n\t\t\tposition: 'Left',\n\t\t\twithoutDecimal: false\n\t\t},\n\t\t{\n\t\t\tcode: 'SEK',\n\t\t\tsymbol: 'SEK',\n\t\t\tposition: 'Right',\n\t\t\twithoutDecimal: true\n\t\t},\n\t]\n\t/**\n\t * Cambia la configuración de la moneda.\n\t * @param currencyTypeConfig Arreglo con las distintas monedas.\n\t */\n\tpublic setCurrencyTypeConfig(currencyTypeConfig: CurrencyConfig[]) {\n\t\tthis.currencyTypeConfig = currencyTypeConfig;\n\t}\n\n\t/**\n\t * @param currencyTypeFind Definir el code del tipo de moneda que se quiera utilizar.\n\t * Si el tipo es CUSTOM se toman los valores del segundo parametro donde se puede definir la simbología y posesión que se quiera.\n\t * @param customType Formato del parámetro ejemplo { code: 'ARG', symbol: '$', position: 'L' , withoutDecimals: false } ,\n\t * todas las key son opcionales y por defecto se toman los valores del ejemplo.\n\t * @returns se retorna la configuración que se seteo a la propiedad currency del servicio.\n\t */\n\tpublic setCurrency(currencyTypeFind: currencyType, customType?: CurrencyConfig): CurrencyConfig {\n\t\tthis.currency = this.currencyTypeConfig.find((ct: CurrencyConfig) => ct.code == currencyTypeFind.toUpperCase()) || this.currency\n\t\tcustomType && (this.currency = { ...this.currency, ...customType })\n\t\treturn this.currency;\n\t};\n\n\n\tpublic modifyChannelConfig(channelConfig: any) {\n\t\tif (channelConfig.channel || channelConfig.code)\n\t\t\tthis.apiConstants.setChannel(channelConfig.channel || channelConfig.code)\n\n\t\tif (channelConfig.locale || channelConfig.locales.code)\n\t\t\tthis.apiConstants.setLocale(channelConfig.locale || channelConfig.locales.code)\n\n\t\tif (channelConfig.currency || channelConfig.baseCurrency)\n\t\t\tthis.setCurrency(channelConfig.currency || channelConfig.baseCurrency)\n\n\t\treturn channelConfig;\n\t}\n\n\t/**\n\t* @description se utiliza para configurar que filtros del tipo `SortFilter` se quiere mostrar en la vista.\n\t* Se usan los codigo de los filtros para indicar cuales se deben mostrar.\n\t*/\n\tprivate sortFilters: string[] = ['price', 'order-alph', 'recent']\n\n\t/**\n\t *\n\t * @param filtersCode arreglo de strings con los codigos de los filtros.\n\t * Si se le pasa el parametro **all** este mostrara todos.\n\t * @example price | order-alph | recent | update | all\n\t * @returns\n\t */\n\tsetSortFilters = (filtersCode: string[] = ['all']) => this.sortFilters = filtersCode;\n\n\tgetSortFilters = () => this.sortFilters;\n\n\t// ABOUT PRODUCTS \n\tprivate productsWithUniqueVariant: boolean = false;\n\tsetProductWithUniqueVariant(value: boolean) { this.productsWithUniqueVariant = value; }\n\tgetProductWithUniqueVariant() { return this.productsWithUniqueVariant }\n\n\t/**\n\t* @description esta variable se utiliza para configurar los parametros cuando se desea mostrar\n\t* variantes el listado de productos.\n\t* @param {string}type tipo de options\n\t* @param {string}code codigo de options\n\t* @param {boolean}defaultFirstOption `true` toma el primer option del producto en general\n\t* @param {boolean}checkIfStock `true` se realiza un chequeo de si la variante tiene stock para mostrarla\n\t* @example  ```javascript\n\t* {\n\t   type: 'color',\n\t   code: 'color',\n\t   defaultFirstOption: false ,\n\t   checkIfStock:true\n\t   } ```\n\t*/\n\tprivate paramsProductsWithUniqueVariant: ParamsProductsWithUniqueVariant = {\n\t\ttype: 'color',\n\t\tcode: 'color',\n\t\tdefaultFirstOption: false,\n\t\tcheckIfStock: true\n\t}\n\n\tsetParamsProductsWithUniqueVariant = (value: ParamsProductsWithUniqueVariant) => {\n\t\tthis.paramsProductsWithUniqueVariant = {\n\t\t\t...this.paramsProductsWithUniqueVariant,\n\t\t\t...value\n\t\t}\n\t}\n\n\tgetParamsProductsWithUniqueVariant = () => this.paramsProductsWithUniqueVariant\n\t\n\tpublic getChannel(){\n\t\treturn this.apiConstants.CHANNEL;\n\t}\n\n\tpublic form_sender: boolean = false;\n\n\tsetCurrentRouteType(type: string | null) {\n\t\tthis.currentRouteType = type;\n\t}\n\n\tgetCurrentRouteType(): string | null {\n\t\treturn this.currentRouteType;\n\t}\n}\n"]}
319
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core.constants.service.js","sourceRoot":"","sources":["../../../../../projects/ng-easycommerce-v18/src/lib/constants/core.constants.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { inject, Injectable, PLATFORM_ID } from '@angular/core';\nimport { ApiConstantsService } from './api.constants.service';\nimport { isPlatformBrowser, DOCUMENT } from '@angular/common';\nimport { CurrencyConfig, currencyType, ParamsProductsWithUniqueVariant, Environment } from '../interfaces';\nimport { ENVIRONMENT_TOKEN } from '../providers';\n/**\n * Servicio que provee las constantes necesarias que se utilizan por toda la aplicación.\n * @export\n * @class CoreConstantsService\n */\n@Injectable({\n\tprovidedIn: 'root'\n})\nexport class CoreConstantsService {\n\n\tpublic searchValue: string = '';\n\t/**\n\t * Servicio que contiene las constantes usadas para la API\n\t */\n\tprivate apiConstants = inject(ApiConstantsService)\n\t/**\n\t * Provee el ID de la plataforma en donde se esta ejecutando el codigo, esto sirve para poder diferenciar si es de un servidor o un navegador web.\n\t */\n\tprivate platformId: any = inject(PLATFORM_ID)\n\t/**\n\t * Document token para acceso SSR-compatible al documento\n\t */\n\tprivate document: Document = inject(DOCUMENT)\n\t/**\n\t * Contiene los datos provisto por el frontend en el archivo environment.ts\n\t */\n\tprivate environment: Environment = inject(ENVIRONMENT_TOKEN)\n\t/**\n\t * Guarda la variable window del web browser.\n\t */\n\tprivate window?:Window;\n\n\tconstructor() {\n\t\tif (isPlatformBrowser(this.platformId)) {\n\t\t\tthis.window = window\n\t\t}\n\t}\n\t/**\n\t * Path usado en las colecciones de productos.\n\t */\n\tpublic PRODUCT_LIST_ROUTE: string = 'collection/';\n\t/**\n\t * Path usado para acceder a las secciones.\n\t */\n\tpublic SECTIONS_ROUTE: string = 'sections/';\n\t/**\n\t * Path que aloja la carpeta de los assets.\n\t */\n\tpublic readonly ASSETS_URL: string = this.apiConstants.API_URL;\n\t/**\n\t * Retorna la url donde se guarda las imagenes.\n\t * @param postMedia \n\t * @returns \n\t */\n\tpublic mediaUrl = (postMedia?: string) => this.ASSETS_URL + (this.ASSETS_URL == this.apiConstants.API_URL ? 'media/' : '') + (postMedia ? postMedia : \"image/\");\n\t/**\n\t * Retorna la url donde se guarda las imagenes.\n\t * @param postMedia \n\t * @returns \n\t */\n\tpublic mediaImageUrl = (postMedia?: string) => this.ASSETS_URL + (this.ASSETS_URL == this.apiConstants.API_URL ? 'media/image/' : '') + (postMedia ? postMedia : \"image/\");\n\t/**\n\t * Retorna la url del sitio.\n\t * @param postMedia \n\t * @returns \n\t */\n\tpublic url = () => this.apiConstants.API_URL.replace(/\\/$/, ''); // remove last slash\t\n\n\t/**\n\t * URL del sitio frontend - Compatible con Angular SSR\n\t */\n\tpublic get FRONTEND_URL(): string {\n\t\t// Verificar si estamos en el navegador\n\t\tif (isPlatformBrowser(this.platformId)) {\n\t\t\t// Primero intenta leer de window.__env (configurado por Docker/CI)\n\t\t\tconst windowEnv = (this.window as any)?.__env;\n\t\t\tif (windowEnv?.frontendUrl) {\n\t\t\t\t// Log para debugging en desarrollo\n\t\t\t\tif (!windowEnv.frontendUrl.startsWith('http')) {\n\t\t\t\t\tconsole.warn('[FRONTEND_URL] Invalid frontendUrl format:', windowEnv.frontendUrl);\n\t\t\t\t}\n\t\t\t\treturn windowEnv.frontendUrl;\n\t\t\t}\n\t\t\t\n\t\t\t// Si no hay configuración específica, construir desde window.location\n\t\t\tif (this.window?.location) {\n\t\t\t\tconst url = `${this.window.location.protocol}//${this.window.location.host}`;\n\t\t\t\t// Verificar que no sea localhost o 127.0.0.1 en producción\n\t\t\t\tif (url.includes('127.0.0.1') || url.includes('localhost')) {\n\t\t\t\t\tconsole.warn('[FRONTEND_URL] Using localhost URL in production, consider setting window.__env.frontendUrl');\n\t\t\t\t}\n\t\t\t\treturn url;\n\t\t\t}\n\t\t}\n\t\t\n\t\t// Para SSR, intentar construir desde el document si está disponible\n\t\tif (this.document?.location) {\n\t\t\treturn `${this.document.location.protocol}//${this.document.location.host}`;\n\t\t}\n\t\t\n\t\t// Intentar obtener desde environment\n\t\tif (this.environment.frontendUrl) {\n\t\t\treturn this.environment.frontendUrl;\n\t\t}\n\t\t\n\t\t// Último fallback - usar la URL del API si está configurada y es absoluta\n\t\tconst apiUrl = this.apiConstants.API_URL;\n\t\tif (apiUrl && (apiUrl.startsWith('http://') || apiUrl.startsWith('https://'))) {\n\t\t\ttry {\n\t\t\t\tconst url = new URL(apiUrl);\n\t\t\t\treturn `${url.protocol}//${url.host}`;\n\t\t\t} catch (e) {\n\t\t\t\tconsole.warn('[FRONTEND_URL] Could not parse API URL as fallback:', apiUrl);\n\t\t\t}\n\t\t}\n\t\t\n\t\t// Fallback final - retornar URL vacía\n\t\tconsole.warn('[FRONTEND_URL] No valid frontend URL found, this may cause issues with meta tags');\n\t\treturn '';\n\t}\n\n\t/**\n\t * Retorna la URL completa del frontend con una ruta opcional\n\t * @param path - Ruta opcional para agregar a la URL base\n\t * @returns {string} URL completa del frontend\n\t */\n\tpublic getFrontendUrl = (path?: string): string => {\n\t\tconst baseUrl = this.FRONTEND_URL;\n\t\tif (!path) {\n\t\t\treturn baseUrl;\n\t\t}\n\t\t\n\t\t// Asegurar que la ruta comience con '/' y no tenga doble slash\n\t\tconst cleanPath = path.startsWith('/') ? path : `/${path}`;\n\t\tconst cleanBaseUrl = baseUrl.endsWith('/') ? baseUrl.slice(0, -1) : baseUrl;\n\t\t\n\t\treturn `${cleanBaseUrl}${cleanPath}`;\n\t}\n\n\t/**\n\t * Retorna la URL absoluta de una imagen para meta tags (compatible con SSR)\n\t * @param postMedia - Ruta de la imagen\n\t * @returns {string} URL absoluta de la imagen\n\t */\n\tpublic getAbsoluteImageUrl = (postMedia?: string): string => {\n\t\t// Si la URL ya es absoluta, devolverla tal como está\n\t\tif (postMedia && (postMedia.startsWith('http://') || postMedia.startsWith('https://'))) {\n\t\t\treturn postMedia;\n\t\t}\n\n\t\t// Construir la URL de la imagen usando la URL del API\n\t\tconst imageUrl = this.mediaImageUrl(postMedia);\n\t\t\n\t\t// Si la URL de la imagen ya es absoluta, devolverla\n\t\tif (imageUrl.startsWith('http://') || imageUrl.startsWith('https://')) {\n\t\t\treturn imageUrl;\n\t\t}\n\t\t\n\t\t// Si es una URL relativa, convertirla a absoluta usando la URL base del API\n\t\tconst apiBaseUrl = this.apiConstants.API_URL;\n\t\tif (apiBaseUrl.startsWith('http://') || apiBaseUrl.startsWith('https://')) {\n\t\t\t// API_URL ya es absoluta\n\t\t\treturn imageUrl;\n\t\t}\n\t\t\n\t\t// Si API_URL es relativa, usar la URL del frontend como base\n\t\tconst frontendUrl = this.FRONTEND_URL;\n\t\tif (!frontendUrl) {\n\t\t\treturn imageUrl; // Fallback si no podemos determinar la URL del frontend\n\t\t}\n\t\t\n\t\t// Construir URL absoluta\n\t\tconst cleanApiUrl = apiBaseUrl.startsWith('/') ? apiBaseUrl.substring(1) : apiBaseUrl;\n\t\tconst cleanFrontendUrl = frontendUrl.endsWith('/') ? frontendUrl.slice(0, -1) : frontendUrl;\n\t\tconst cleanImageUrl = imageUrl.startsWith('/') ? imageUrl.substring(1) : imageUrl;\n\t\t\n\t\treturn `${cleanFrontendUrl}/${cleanApiUrl}${cleanImageUrl}`;\n\t}\n\n\t/**\n\t * Retorna la url de las imagenes de los banners\n\t * @returns \n\t */\n\tpublic mediaBannerUrl = () => this.ASSETS_URL + (this.ASSETS_URL == this.apiConstants.API_URL ? 'media/' : '') + \"banner-image/\";\n\t\n\tmediaStoreUrl = () => this.ASSETS_URL + (this.ASSETS_URL == this.apiConstants.API_URL ? 'media/' : '') + \"store-image/\";\n\t\n\t/**\n\t * Retorna `true` si la vista es mobile, `false` caso contrario.\n\t * @returns {boolean}\n\t */\n\tpublic mobileScreen = (): boolean => this.window && this.window?.innerWidth < 750 || false;\n\t/**\n\t * Contiene los valores para la moneda actual\n\t */\n\tpublic currency: CurrencyConfig = {\n\t\tcode: 'ARG',\n\t\tsymbol: '$',\n\t\tposition: 'Left',\n\t\twithoutDecimal: false\n\t};\n\n\t/**\n\t * Arreglo de valores usados para el pipe currencyPrice\n\t */\n\tpublic currencyTypeConfig: CurrencyConfig[] = [\n\t\t{\n\t\t\tcode: 'EUR',\n\t\t\tsymbol: '€',\n\t\t\tposition: 'Right',\n\t\t\twithoutDecimal: false\n\n\t\t},\n\t\t{\n\t\t\tcode: 'ARG',\n\t\t\tsymbol: '$',\n\t\t\tposition: 'Left',\n\t\t\twithoutDecimal: false\n\t\t},\n\t\t{\n\t\t\tcode: 'ARS',\n\t\t\tsymbol: '$',\n\t\t\tposition: 'Left',\n\t\t\twithoutDecimal: false\n\t\t},\n\t\t{\n\t\t\tcode: 'USD',\n\t\t\tsymbol: '$',\n\t\t\tposition: 'Left',\n\t\t\twithoutDecimal: false\n\t\t},\n\t\t{\n\t\t\tcode: 'PYG',\n\t\t\tsymbol: 'Gs.',\n\t\t\tposition: 'Left',\n\t\t\twithoutDecimal: false\n\t\t},\n\t\t{\n\t\t\tcode: 'PEN',\n\t\t\tsymbol: 'S/',\n\t\t\tposition: 'Left',\n\t\t\twithoutDecimal: false\n\t\t},\n\t\t{\n\t\t\tcode: 'SEK',\n\t\t\tsymbol: 'SEK',\n\t\t\tposition: 'Right',\n\t\t\twithoutDecimal: true\n\t\t},\n\t]\n\t/**\n\t * Cambia la configuración de la moneda.\n\t * @param currencyTypeConfig Arreglo con las distintas monedas.\n\t */\n\tpublic setCurrencyTypeConfig(currencyTypeConfig: CurrencyConfig[]) {\n\t\tthis.currencyTypeConfig = currencyTypeConfig;\n\t}\n\n\t/**\n\t * @param currencyTypeFind Definir el code del tipo de moneda que se quiera utilizar.\n\t * Si el tipo es CUSTOM se toman los valores del segundo parametro donde se puede definir la simbología y posesión que se quiera.\n\t * @param customType Formato del parámetro ejemplo { code: 'ARG', symbol: '$', position: 'L' , withoutDecimals: false } ,\n\t * todas las key son opcionales y por defecto se toman los valores del ejemplo.\n\t * @returns se retorna la configuración que se seteo a la propiedad currency del servicio.\n\t */\n\tpublic setCurrency(currencyTypeFind: currencyType, customType?: CurrencyConfig): CurrencyConfig {\n\t\tthis.currency = this.currencyTypeConfig.find((ct: CurrencyConfig) => ct.code == currencyTypeFind.toUpperCase()) || this.currency\n\t\tcustomType && (this.currency = { ...this.currency, ...customType })\n\t\treturn this.currency;\n\t};\n\n\n\tpublic modifyChannelConfig(channelConfig: any) {\n\t\tif (channelConfig.channel || channelConfig.code)\n\t\t\tthis.apiConstants.setChannel(channelConfig.channel || channelConfig.code)\n\n\t\tif (channelConfig.locale || channelConfig.locales.code)\n\t\t\tthis.apiConstants.setLocale(channelConfig.locale || channelConfig.locales.code)\n\n\t\tif (channelConfig.currency || channelConfig.baseCurrency)\n\t\t\tthis.setCurrency(channelConfig.currency || channelConfig.baseCurrency)\n\n\t\treturn channelConfig;\n\t}\n\n\t/**\n\t* @description se utiliza para configurar que filtros del tipo `SortFilter` se quiere mostrar en la vista.\n\t* Se usan los codigo de los filtros para indicar cuales se deben mostrar.\n\t*/\n\tprivate sortFilters: string[] = ['price', 'order-alph', 'recent']\n\n\t/**\n\t *\n\t * @param filtersCode arreglo de strings con los codigos de los filtros.\n\t * Si se le pasa el parametro **all** este mostrara todos.\n\t * @example price | order-alph | recent | update | all\n\t * @returns\n\t */\n\tsetSortFilters = (filtersCode: string[] = ['all']) => this.sortFilters = filtersCode;\n\n\tgetSortFilters = () => this.sortFilters;\n\n\t// ABOUT PRODUCTS \n\tprivate productsWithUniqueVariant: boolean = false;\n\tsetProductWithUniqueVariant(value: boolean) { this.productsWithUniqueVariant = value; }\n\tgetProductWithUniqueVariant() { return this.productsWithUniqueVariant }\n\n\t/**\n\t* @description esta variable se utiliza para configurar los parametros cuando se desea mostrar\n\t* variantes el listado de productos.\n\t* @param {string}type tipo de options\n\t* @param {string}code codigo de options\n\t* @param {boolean}defaultFirstOption `true` toma el primer option del producto en general\n\t* @param {boolean}checkIfStock `true` se realiza un chequeo de si la variante tiene stock para mostrarla\n\t* @example  ```javascript\n\t* {\n\t   type: 'color',\n\t   code: 'color',\n\t   defaultFirstOption: false ,\n\t   checkIfStock:true\n\t   } ```\n\t*/\n\tprivate paramsProductsWithUniqueVariant: ParamsProductsWithUniqueVariant = {\n\t\ttype: 'color',\n\t\tcode: 'color',\n\t\tdefaultFirstOption: false,\n\t\tcheckIfStock: true\n\t}\n\n\tsetParamsProductsWithUniqueVariant = (value: ParamsProductsWithUniqueVariant) => {\n\t\tthis.paramsProductsWithUniqueVariant = {\n\t\t\t...this.paramsProductsWithUniqueVariant,\n\t\t\t...value\n\t\t}\n\t}\n\n\tgetParamsProductsWithUniqueVariant = () => this.paramsProductsWithUniqueVariant\n\t\n\tpublic getChannel(){\n\t\treturn this.apiConstants.CHANNEL;\n\t}\n\n\tpublic form_sender: boolean = false;\n}\n"]}
@@ -2,7 +2,7 @@ import { Component, inject, Input, PLATFORM_ID, signal } from '@angular/core';
2
2
  import { AuthService, FiltersService, OptionsService, ProductsService } from '../../ec-services';
3
3
  import { ActivatedRoute } from '@angular/router';
4
4
  import { CoreConstantsService } from '../../constants';
5
- import { combineLatest, distinctUntilChanged, map, Subject, takeUntil } from 'rxjs';
5
+ import { combineLatest } from 'rxjs';
6
6
  import { InfiniteScrollDirective } from "ngx-infinite-scroll";
7
7
  import { isPlatformBrowser } from '@angular/common';
8
8
  import * as i0 from "@angular/core";
@@ -10,7 +10,6 @@ export class CollectionEcComponent {
10
10
  _productsService = inject(ProductsService);
11
11
  _activeRoute = inject(ActivatedRoute);
12
12
  _optionsService = inject(OptionsService);
13
- _filtersService = inject(FiltersService);
14
13
  params$ = this._activeRoute.params;
15
14
  //public ready = this._optionsService.ready
16
15
  queryParams$ = this._activeRoute.queryParams;
@@ -22,63 +21,40 @@ export class CollectionEcComponent {
22
21
  defaultFilters = [];
23
22
  loading = false;
24
23
  countProducts = signal(0);
25
- loaded = signal(false);
24
+ loaded = false;
26
25
  optionsFilters = ['all'];
27
26
  filters_sort = [];
27
+ _filtersService = inject(FiltersService);
28
28
  filters$ = this._filtersService.filters$;
29
29
  ready$ = this._filtersService.ready$;
30
30
  window;
31
31
  isList = false;
32
- destroy$ = new Subject();
33
32
  setAsList = (value) => this.isList = value;
34
33
  ngOnInit() {
35
- if (isPlatformBrowser(this.platformId)) {
36
- this.window?.scroll(0, 0);
37
- }
38
- combineLatest([this.params$, this.queryParams$])
39
- .pipe(map(([params, query]) => ({ params, query })), distinctUntilChanged((a, b) => JSON.stringify(a) === JSON.stringify(b)), takeUntil(this.destroy$))
40
- .subscribe(({ params, query }) => {
41
- // Guardamos el tipo de ruta actual en las constantes (ej: 'categories', 'sections', etc.)
42
- const routeType = params['type'] || null;
43
- this.constanst.setCurrentRouteType(routeType);
44
- const paginationSettings = {
45
- latest: true,
46
- limit: 10,
47
- type: params['type'] || null,
48
- value: params['value'] || null
49
- };
50
- // Punto clave:
51
- // A partir de la URL (params + query) reconstruimos los filtros
52
- // (categorías, atributos, rango de precios, etc.)
53
- // Esto permite:
54
- // - Soportar F5 / recarga sin perder filtros
55
- // - Navegar con URL compartibles (deep linking)
56
- this._filtersService.hydrateFromRoute(paginationSettings, params, query);
57
- });
34
+ this.getProducts();
35
+ this.window?.scroll(0, 0);
58
36
  }
59
37
  //protected readonly questions = signal<Question[]>([]);
60
38
  total = 0;
61
39
  platformId = inject(PLATFORM_ID);
62
40
  constructor() {
63
- // Guardamos window sólo en Browser para evitar errores en SSR
64
41
  if (isPlatformBrowser(this.platformId)) {
65
42
  this.window = window;
66
43
  }
67
- // Nos suscribimos al stream de productos.
68
- // Cuando ProductsService emite, marcamos `loaded` en true, pero solo en Browser.
69
- // En SSR no lo marcamos para evitar cambios de estado innecesarios.
70
- this.products$
71
- .pipe(takeUntil(this.destroy$))
72
- .subscribe(products => {
73
- if (isPlatformBrowser(this.platformId)) {
74
- this.loaded.set(true);
44
+ }
45
+ getProducts() {
46
+ combineLatest([this.params$, this.queryParams$]).subscribe({
47
+ next: ([params, queryParams]) => {
48
+ const paginationSettings = {
49
+ latest: true,
50
+ limit: 10,
51
+ type: params['type'] || null,
52
+ value: params['value'] || null
53
+ };
54
+ this._productsService.getProductsForFilter(paginationSettings, queryParams["search"]);
75
55
  }
76
56
  });
77
57
  }
78
- ngOnDestroy() {
79
- this.destroy$.next();
80
- this.destroy$.complete();
81
- }
82
58
  onScroll() {
83
59
  this.loading = true;
84
60
  this._productsService.updateProducts();
@@ -96,4 +72,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
96
72
  }], ctorParameters: () => [], propDecorators: { optionsFilters: [{
97
73
  type: Input
98
74
  }] } });
99
- //# 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, OnDestroy, OnInit, PLATFORM_ID, signal } from '@angular/core';\nimport { DefaultFilter, FilterType, PaginationSettings, Product } from '../../interfaces';\nimport { AuthService, FiltersService, OptionsService, ProductsService } from '../../ec-services';\nimport { ActivatedRoute } from '@angular/router';\nimport { CoreConstantsService } from '../../constants';\nimport { combineLatest, distinctUntilChanged, forkJoin, map, Observable, Subject, take, takeUntil } from 'rxjs';\nimport { Filter } from '../../classes';\nimport { InfiniteScrollDirective } from \"ngx-infinite-scroll\";\nimport { isPlatformBrowser } from '@angular/common';\n@Component({\n\tselector: 'lib-collection-ec',\n\tstandalone: true,\n\timports: [InfiniteScrollDirective],\n\ttemplateUrl: './collection-ec.component.html',\n\tstyleUrl: './collection-ec.component.scss'\n})\nexport class CollectionEcComponent implements OnInit, OnDestroy {\n\n\tprotected _productsService: ProductsService = inject(ProductsService)\n\tprotected _activeRoute: ActivatedRoute = inject(ActivatedRoute)\n\tprotected _optionsService: OptionsService = inject(OptionsService)\n\tprivate _filtersService: FiltersService = inject(FiltersService);\n\n\tpublic params$ = this._activeRoute.params\n\t//public ready = this._optionsService.ready\n\tpublic queryParams$ = this._activeRoute.queryParams\n\tpublic products$ = this._productsService.products$\n\t//public products$ = []\n\n\tpublic authService: AuthService = inject(AuthService)\n\tpublic constanst: CoreConstantsService = inject(CoreConstantsService)\n\n\tpublic products: Product[] = [];\n\tpublic defaultFilters: DefaultFilter[] = [];\n\tpublic loading: Boolean = false;\n\tpublic countProducts = signal<number>(0)\n\tprivate loaded = signal(false);\n\n\t@Input() optionsFilters: FilterType[] = ['all'];\n\n\tfilters_sort: Filter[] = [];\n\n\tpublic filters$: Observable<Filter[]> = this._filtersService.filters$;\n\tpublic ready$: Observable<boolean> = this._filtersService.ready$;\n\n\tprivate window?: Window;\n\n\tpublic isList: boolean = false\n\tprivate destroy$ = new Subject<void>();\n\tsetAsList = (value: boolean) => this.isList = value\n\n\tngOnInit(): void {\n\t\tif (isPlatformBrowser(this.platformId)) {\n\t\t\tthis.window?.scroll(0, 0);\n\t\t}\n\n\t\tcombineLatest([this.params$, this.queryParams$])\n\t\t\t.pipe(\n\t\t\t\tmap(([params, query]) => ({ params, query })),\n\t\t\t\tdistinctUntilChanged((a, b) => JSON.stringify(a) === JSON.stringify(b)),\n\t\t\t\ttakeUntil(this.destroy$)\n\t\t\t)\n\t\t\t.subscribe(({ params, query }) => {\n\t\t\t\t// Guardamos el tipo de ruta actual en las constantes (ej: 'categories', 'sections', etc.)\n\t\t\t\tconst routeType = params['type'] || null;\n\t\t\t\tthis.constanst.setCurrentRouteType(routeType);\n\n\t\t\t\tconst paginationSettings: PaginationSettings = {\n\t\t\t\t\tlatest: true,\n\t\t\t\t\tlimit: 10,\n\t\t\t\t\ttype: params['type'] || null,\n\t\t\t\t\tvalue: params['value'] || null\n\t\t\t\t};\n\n\t\t\t\t//  Punto clave:\n\t\t\t\t//    A partir de la URL (params + query) reconstruimos los filtros\n\t\t\t\t//    (categorías, atributos, rango de precios, etc.)\n\t\t\t\t//    Esto permite:\n\t\t\t\t//    - Soportar F5 / recarga sin perder filtros\n\t\t\t\t//    - Navegar con URL compartibles (deep linking)\n\t\t\t\tthis._filtersService.hydrateFromRoute(paginationSettings, params, query);\n\t\t\t});\n\t}\n\n\t//protected readonly questions = signal<Question[]>([]);\n\tprivate total = 0;\n\tprivate platformId: any = inject(PLATFORM_ID)\n\n\tconstructor() {\n\t\t// Guardamos window sólo en Browser para evitar errores en SSR\n\t\tif (isPlatformBrowser(this.platformId)) {\n\t\t\tthis.window = window\n\n\t\t}\n\t\t//  Nos suscribimos al stream de productos.\n\t\t//    Cuando ProductsService emite, marcamos `loaded` en true, pero solo en Browser.\n\t\t//    En SSR no lo marcamos para evitar cambios de estado innecesarios.\n\t\tthis.products$\n\t\t\t.pipe(takeUntil(this.destroy$))\n\t\t\t.subscribe(products => {\n\t\t\t\tif (isPlatformBrowser(this.platformId)) {\n\t\t\t\t\tthis.loaded.set(true);\n\t\t\t\t}\n\t\t\t});\n\t}\n\n\tngOnDestroy(): void {\n\t\tthis.destroy$.next();\n\t\tthis.destroy$.complete();\n\t}\n\n\tonScroll() {\n\t\tthis.loading = true;\n\t\tthis._productsService.updateProducts()\n\t}\n\n\t// Método para saber si un producto tiene stock usando el servicio\n\tpublic productHasStock(product: Product): boolean {\n\t\treturn this._productsService.hasStock(product);\n\t}\n}\n","<section class=\"container-xl mb-5\">\n    <div class=\"row m-0 p-0\">\n        <div class=\"d-none d-lg-block col-3\">\n            <!--Filtros-->\n        </div>\n\n        <div class=\"col-12 col-lg-9 mt-2 p-0\">\n            <div class=\"container\">\n                <!-- @for(['a', 'b', 'c', 'd'] as product){\n\n                } -->\n            </div>\n        </div>\n\n    </div>\n</section>\n"]}
75
+ //# 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":"AAAA,OAAO,EAAmB,SAAS,EAAgB,MAAM,EAAE,KAAK,EAAU,WAAW,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAErH,OAAO,EAAE,WAAW,EAAE,cAAc,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACjG,OAAO,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AACjD,OAAO,EAAE,oBAAoB,EAAE,MAAM,iBAAiB,CAAC;AACvD,OAAO,EAAE,aAAa,EAAmC,MAAM,MAAM,CAAC;AAEtE,OAAO,EAAE,uBAAuB,EAAE,MAAM,qBAAqB,CAAC;AAC9D,OAAO,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;;AAQpD,MAAM,OAAO,qBAAqB;IAEvB,gBAAgB,GAAoB,MAAM,CAAC,eAAe,CAAC,CAAA;IAC3D,YAAY,GAAmB,MAAM,CAAC,cAAc,CAAC,CAAA;IACrD,eAAe,GAAmB,MAAM,CAAC,cAAc,CAAC,CAAA;IAE3D,OAAO,GAAG,IAAI,CAAC,YAAY,CAAC,MAAM,CAAA;IACzC,2CAA2C;IACpC,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC,WAAW,CAAA;IAC5C,SAAS,GAAG,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAA;IAClD,uBAAuB;IAEhB,WAAW,GAAgB,MAAM,CAAC,WAAW,CAAC,CAAA;IAC9C,SAAS,GAAyB,MAAM,CAAC,oBAAoB,CAAC,CAAA;IAE9D,QAAQ,GAAc,EAAE,CAAC;IACzB,cAAc,GAAoB,EAAE,CAAC;IACrC,OAAO,GAAY,KAAK,CAAC;IACzB,aAAa,GAAG,MAAM,CAAS,CAAC,CAAC,CAAA;IAChC,MAAM,GAAG,KAAK,CAAC;IAEd,cAAc,GAAiB,CAAC,KAAK,CAAC,CAAC;IAEhD,YAAY,GAAa,EAAE,CAAC;IAEpB,eAAe,GAAmB,MAAM,CAAC,cAAc,CAAC,CAAA;IACzD,QAAQ,GAAyB,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC;IAC/D,MAAM,GAAwB,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC;IAEzD,MAAM,CAAU;IAEjB,MAAM,GAAY,KAAK,CAAA;IAC9B,SAAS,GAAG,CAAC,KAAc,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,GAAG,KAAK,CAAA;IAEnD,QAAQ;QACP,IAAI,CAAC,WAAW,EAAE,CAAC;QACnB,IAAI,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,CAAA;IAC1B,CAAC;IAED,wDAAwD;IAChD,KAAK,GAAG,CAAC,CAAC;IACV,UAAU,GAAQ,MAAM,CAAC,WAAW,CAAC,CAAA;IAE7C;QACC,IAAI,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;YACxC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAA;QAErB,CAAC;IACF,CAAC;IAED,WAAW;QACV,aAAa,CAAC,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,SAAS,CAAC;YAC1D,IAAI,EAAE,CAAC,CAAC,MAAM,EAAE,WAAW,CAAC,EAAE,EAAE;gBAC/B,MAAM,kBAAkB,GAAuB;oBAC9C,MAAM,EAAE,IAAI;oBACZ,KAAK,EAAE,EAAE;oBACT,IAAI,EAAE,MAAM,CAAC,MAAM,CAAC,IAAI,IAAI;oBAC5B,KAAK,EAAE,MAAM,CAAC,OAAO,CAAC,IAAI,IAAI;iBAC9B,CAAA;gBACD,IAAI,CAAC,gBAAgB,CAAC,oBAAoB,CAAC,kBAAkB,EAAE,WAAW,CAAC,QAAQ,CAAC,CAAC,CAAC;YACvF,CAAC;SACD,CAAC,CAAA;IACH,CAAC;IAED,QAAQ;QACP,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACpB,IAAI,CAAC,gBAAgB,CAAC,cAAc,EAAE,CAAA;IACvC,CAAC;IAED,kEAAkE;IAC3D,eAAe,CAAC,OAAgB;QACtC,OAAO,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;IAChD,CAAC;wGAxEW,qBAAqB;4FAArB,qBAAqB,2HChBlC,sZAgBA;;4FDAa,qBAAqB;kBAPjC,SAAS;+BACC,mBAAmB,cACjB,IAAI,WACP,CAAC,uBAAuB,CAAC;wDAyBzB,cAAc;sBAAtB,KAAK","sourcesContent":["import { afterNextRender, Component, HostListener, inject, Input, OnInit, PLATFORM_ID, signal } from '@angular/core';\nimport { DefaultFilter, FilterType, PaginationSettings, Product } from '../../interfaces';\nimport { AuthService, FiltersService, OptionsService, ProductsService } from '../../ec-services';\nimport { ActivatedRoute } from '@angular/router';\nimport { CoreConstantsService } from '../../constants';\nimport { combineLatest, forkJoin, map, Observable, take } from 'rxjs';\nimport { Filter } from '../../classes';\nimport { InfiniteScrollDirective } from \"ngx-infinite-scroll\";\nimport { isPlatformBrowser } from '@angular/common';\n@Component({\n\tselector: 'lib-collection-ec',\n\tstandalone: true,\n\timports: [InfiniteScrollDirective],\n\ttemplateUrl: './collection-ec.component.html',\n\tstyleUrl: './collection-ec.component.scss'\n})\nexport class CollectionEcComponent implements OnInit {\n\n\tprotected _productsService: ProductsService = inject(ProductsService)\n\tprotected _activeRoute: ActivatedRoute = inject(ActivatedRoute)\n\tprotected _optionsService: OptionsService = inject(OptionsService)\n\n\tpublic params$ = this._activeRoute.params\n\t//public ready = this._optionsService.ready\n\tpublic queryParams$ = this._activeRoute.queryParams\n\tpublic products$ = this._productsService.products$\n\t//public products$ = []\n\n\tpublic authService: AuthService = inject(AuthService)\n\tpublic constanst: CoreConstantsService = inject(CoreConstantsService)\n\n\tpublic products: Product[] = [];\n\tpublic defaultFilters: DefaultFilter[] = [];\n\tpublic loading: Boolean = false;\n\tpublic countProducts = signal<number>(0)\n\tprivate loaded = false;\n\n\t@Input() optionsFilters: FilterType[] = ['all'];\n\n\tfilters_sort: Filter[] = [];\n\n\tprivate _filtersService: FiltersService = inject(FiltersService)\n\tpublic filters$: Observable<Filter[]> = this._filtersService.filters$;\n\tpublic ready$: Observable<boolean> = this._filtersService.ready$;\n\n\tprivate window?: Window;\n\n\tpublic isList: boolean = false\n\tsetAsList = (value: boolean) => this.isList = value\n\n\tngOnInit(): void {\n\t\tthis.getProducts();\n\t\tthis.window?.scroll(0, 0)\n\t}\n\n\t//protected readonly questions = signal<Question[]>([]);\n\tprivate total = 0;\n\tprivate platformId: any = inject(PLATFORM_ID)\n\n\tconstructor() {\n\t\tif (isPlatformBrowser(this.platformId)) {\n\t\t\tthis.window = window\n\n\t\t}\n\t}\n\n\tgetProducts(): void {\n\t\tcombineLatest([this.params$, this.queryParams$]).subscribe({\n\t\t\tnext: ([params, queryParams]) => {\n\t\t\t\tconst paginationSettings: PaginationSettings = {\n\t\t\t\t\tlatest: true,\n\t\t\t\t\tlimit: 10,\n\t\t\t\t\ttype: params['type'] || null,\n\t\t\t\t\tvalue: params['value'] || null\n\t\t\t\t}\n\t\t\t\tthis._productsService.getProductsForFilter(paginationSettings, queryParams[\"search\"]);\n\t\t\t}\n\t\t})\n\t}\n\n\tonScroll() {\n\t\tthis.loading = true;\n\t\tthis._productsService.updateProducts()\n\t}\n\n\t// Método para saber si un producto tiene stock usando el servicio\n\tpublic productHasStock(product: Product): boolean {\n\t\treturn this._productsService.hasStock(product);\n\t}\n}\n","<section class=\"container-xl mb-5\">\n    <div class=\"row m-0 p-0\">\n        <div class=\"d-none d-lg-block col-3\">\n            <!--Filtros-->\n        </div>\n\n        <div class=\"col-12 col-lg-9 mt-2 p-0\">\n            <div class=\"container\">\n                <!-- @for(['a', 'b', 'c', 'd'] as product){\n\n                } -->\n            </div>\n        </div>\n\n    </div>\n</section>\n"]}
@@ -3,7 +3,7 @@ import { FiltersService, AuthService } 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
- import { ActivatedRoute, Router } from '@angular/router';
6
+ import { Router } from '@angular/router';
7
7
  import { PriceRangeFilter } from '../../classes/filters/price_range-filter';
8
8
  import { ChannelService } from '../../ec-services/channel.service';
9
9
  import * as i0 from "@angular/core";
@@ -19,7 +19,6 @@ export class FiltersEcComponent {
19
19
  injector = inject(Injector);
20
20
  isAuthenticated$ = this._authService.isAuthenticated();
21
21
  hidePrices = false;
22
- route = inject(ActivatedRoute);
23
22
  setSelect;
24
23
  ngOnInit() {
25
24
  }
@@ -49,56 +48,26 @@ export class FiltersEcComponent {
49
48
  .pop()
50
49
  selectedOption && this._filtersService.setFilterSelected(this.filters[0], selectedOption) */
51
50
  }
52
- /**
53
- * Maneja el click sobre un elemento de filtro (categoría, atributo, etc.).
54
- *
55
- * - Para categorías: navega a la URL de la categoría.
56
- * - Para atributos: actualiza la query string de la URL con `attributeCodes`.
57
- * - Para otros filtros: delega en FiltersService para marcar seleccionado.
58
- *
59
- * La idea es que **la URL siempre represente los filtros aplicados**,
60
- * de modo que:
61
- * - al hacer F5 no se pierdan los filtros,
62
- * - los links sean compartibles (deep linking).
63
- */
64
51
  setSelected(filter, selected) {
65
52
  if (!filter || !selected) {
53
+ console.error('Filter or selected element is undefined:', { filter, selected });
66
54
  return;
67
55
  }
68
- // Si el elemento está marcado como no visible, no hacemos nada
69
- if (selected.isVisible === false)
70
- return;
71
56
  if (typeof filter.setSelected !== 'function') {
57
+ console.error('filter.setSelected is not a function. Filter might not be an instance of the expected class:', filter);
72
58
  return;
73
59
  }
74
60
  try {
61
+ // this._filtersService.setFilterSelected(filter, selected);
75
62
  if (filter.type() === 'categories') {
76
- // Para categorías usamos navegación por path (ej: /collection/categories/camas-elasticas)
77
63
  if (selected.path) {
78
64
  this.router.navigate([selected.path]);
79
65
  }
80
- return;
81
66
  }
82
- if (filter.type() === 'attributes') {
83
- // El backend espera que le mandemos el "code" del atributo en el query param
84
- const code = selected.code || selected.value || null;
85
- // Actualizamos la URL manteniendo la ruta, pero agregando `attributeCodes`
86
- // Ejemplo de resultado:
87
- // /collection/categories/camas-elasticas?attributeCodes=ABC123&...
88
- //
89
- // También reseteamos la página a null para que vuelva a la primera página
90
- // cuando se aplica un nuevo filtro.
91
- this.router.navigate([], {
92
- relativeTo: this.route,
93
- queryParams: {
94
- attributeCodes: code,
95
- page: null
96
- },
97
- queryParamsHandling: 'merge'
98
- });
99
- return;
67
+ else if (filter.type() === 'attributes') {
68
+ // Manejar la navegación para atributos
69
+ this._filtersService.setFilterSelected(filter, selected);
100
70
  }
101
- this._filtersService.setFilterSelected(filter, selected);
102
71
  }
103
72
  catch (error) {
104
73
  console.error("Error while setting selected filter:", error);
@@ -132,9 +101,7 @@ export class FiltersEcComponent {
132
101
  return true;
133
102
  };
134
103
  scrollUp = () => {
135
- if (typeof window !== 'undefined') {
136
- window.scroll(0, 0);
137
- }
104
+ window.scroll(0, 0);
138
105
  return true;
139
106
  };
140
107
  hasAppliedFilters() {
@@ -171,4 +138,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
171
138
  }], ctorParameters: () => [], propDecorators: { setSelect: [{
172
139
  type: Input
173
140
  }] } });
174
- //# 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, Injector } from '@angular/core';\nimport { FiltersService , AuthService} from '../../ec-services';\nimport { Filter } from '../../classes';\nimport { FilterElement, FilterType, PaginationSettings } from '../../interfaces';\nimport { ProductsService } from '../../ec-services/products.service';\nimport { CoreConstantsService } from '../../constants';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { PriceRangeFilter } from '../../classes/filters/price_range-filter';\nimport { ChannelService } from '../../ec-services/channel.service';\n\n\n@Component({\n    selector: 'lib-filters-ec',\n    standalone: true,\n    imports: [],\n    templateUrl: './filters-ec.component.html',\n    styleUrl: './filters-ec.component.scss'\n})\nexport class FiltersEcComponent {\n\n    private _authService: AuthService = inject(AuthService);\n    private _filtersService: FiltersService = inject(FiltersService);\n    private _productsService: ProductsService = inject(ProductsService);\n    private _constants: CoreConstantsService = inject(CoreConstantsService);\n    private router: Router = inject(Router);\n    public filters: Filter[] = [];\n    public filter$ = this._filtersService.filters$;\n    public showPricesOnlyToLoggedUsers: boolean = false;\n    public injector: Injector = inject(Injector);\n\tpublic isAuthenticated$ = this._authService.isAuthenticated();\n    public hidePrices: boolean = false;\n    private route: ActivatedRoute = inject(ActivatedRoute);\n\n    @Input() setSelect: any;\n\n    ngOnInit() {\n\n    }\n\n    constructor() {\n        this._filtersService.filters$.subscribe((filters: Filter[]) => {\n            this.filters = filters;\n        });\n        this.injector.get(ChannelService).channel$.subscribe(channel => {\n            this.showPricesOnlyToLoggedUsers = !!channel.showPricesOnlyToLoggedUsers;\n            this.hidePrices = !!channel.hidePrices;\n        });\n    }\n    /** 1) Para cuando me piden 'price_range', devuelvo PriceRangeFilter */\n    public getSpecificFilter(type: 'price_range'): PriceRangeFilter | null;\n\n    /** 2) Para cualquier otro FilterType, devuelvo Filter */\n    public getSpecificFilter(type: FilterType): Filter | null;\n    public getSpecificFilter(type: FilterType): Filter | null {\n        const filter = this.filters.find(f => f.type() === type);\n        if (type === 'price_range' && filter && !(filter instanceof Filter)) {\n            console.error(`Expected a Filter instance but got`, filter);\n        }\n        return filter || null;\n    }\n\n    /*Obtiene el filtro elegido en el select, lo pasa al setSelect\n    para que se marque seleccionado*/\n    onSelect(event: any, filter: FilterElement[] | null) {\n        // console.log(filter)\n        /*  const selectedOption = filter\n             .flatMap(category => category.children)\n             .filter(option => option?.code === event.target.value)\n             .pop()\n         selectedOption && this._filtersService.setFilterSelected(this.filters[0], selectedOption) */\n    }\n\n    /**\n     * Maneja el click sobre un elemento de filtro (categoría, atributo, etc.).\n     *\n     * - Para categorías: navega a la URL de la categoría.\n     * - Para atributos: actualiza la query string de la URL con `attributeCodes`.\n     * - Para otros filtros: delega en FiltersService para marcar seleccionado.\n     *\n     * La idea es que **la URL siempre represente los filtros aplicados**,\n     * de modo que:\n     *   - al hacer F5 no se pierdan los filtros,\n     *   - los links sean compartibles (deep linking).\n     */\n    setSelected(filter: Filter | null, selected: FilterElement | null) {\n        if (!filter || !selected) {\n            return;\n        }\n\n        // Si el elemento está marcado como no visible, no hacemos nada\n        if ((selected as any).isVisible === false) return;\n\n        if (typeof (filter as any).setSelected !== 'function') {\n            return;\n        }\n\n        try {\n            if (filter.type() === 'categories') {\n                // Para categorías usamos navegación por path (ej: /collection/categories/camas-elasticas)\n                if (selected.path) {\n                    this.router.navigate([selected.path]);\n                }\n                return;\n            }\n            if (filter.type() === 'attributes') {\n                // El backend espera que le mandemos el \"code\" del atributo en el query param\n                const code = (selected as any).code || (selected as any).value || null;\n\n                // Actualizamos la URL manteniendo la ruta, pero agregando `attributeCodes`\n                // Ejemplo de resultado:\n                //   /collection/categories/camas-elasticas?attributeCodes=ABC123&...\n                //\n                // También reseteamos la página a null para que vuelva a la primera página\n                // cuando se aplica un nuevo filtro.\n                this.router.navigate([], {\n                    relativeTo: this.route,\n                    queryParams: {\n                        attributeCodes: code,\n                        page: null\n                    },\n                    queryParamsHandling: 'merge'\n                });\n\n                return;\n            }\n            this._filtersService.setFilterSelected(filter, selected);\n\n        } catch (error) {\n            console.error(\"Error while setting selected filter:\", error);\n        }\n    }\n\n    uniqueSelection(filter: { data: any[]; }, filterChild: any) {\n        // Buscar si hay un filtro de tipo PriceRangeFilter en la lista de filtros\n        const priceRangeFilter = this.filters.find(f => f instanceof PriceRangeFilter);\n\n        if (priceRangeFilter) {\n            priceRangeFilter.reset();\n        }\n        filter.data.forEach(filterElement => {\n            if (filterElement.selected) {\n                filterElement.selected = false;\n            }\n            filterElement.children.forEach((filterChildren: FilterElement) => {\n                if (filterChildren != filterChild && filterChildren.selected) {\n                    filterChildren.selected = false;\n                }\n            });\n        });\n    }\n\n    //  close = () => {\n    //       this.document.getElementById(\"filtros\").classList.remove('in');\n    //       return true;\n    //  };\n\n\n    close = () => {\n        // this.consts.mobile()\n        //      ? this.document.getElementById(\"accordionExample\").classList.remove('show')\n        //      : this.document.getElementById(accordion_id).classList.remove('show');\n        return true;\n    };\n\n\n    scrollUp = () => {\n        if (typeof window !== 'undefined') {\n            window.scroll(0, 0);\n        }\n        return true\n    }\n\n\n\n\n\n    hasAppliedFilters(): boolean {\n        return this.filters?.some((filter: any) => {\n            if (filter.type?.() === 'price_range') {\n                const minSet = filter.currentMinPrice !== null && filter.currentMinPrice !== 0;\n                const maxSet = filter.currentMaxPrice !== null && filter.currentMaxPrice !== filter.maxPrice;\n                if (minSet || maxSet) {\n                    return true;\n                }\n            }\n\n            return filter.data?.some((filterElement: any) => {\n                if (Array.isArray(filterElement.children)) {\n                    return filterElement.children.some((child: any) => child.selected);\n                }\n                return filterElement.selected;\n            });\n        }) ?? false;\n    }\n/**\n   * Verifica si una categoría tiene la propiedad isVisible y está marcada como visible\n   * @param category - La categoría a verificar\n   * @returns true si la categoría es visible, false en caso contrario\n   */\n    hasVisibleProperty(category: FilterElement): boolean {\n        return (category as any).isVisible === true;\n    }\n}\n","<p>filters-ec works!</p>\n"]}
141
+ //# 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, Injector } from '@angular/core';\nimport { FiltersService , AuthService} from '../../ec-services';\nimport { Filter } from '../../classes';\nimport { FilterElement, FilterType, PaginationSettings } from '../../interfaces';\nimport { ProductsService } from '../../ec-services/products.service';\nimport { CoreConstantsService } from '../../constants';\nimport { Router } from '@angular/router';\nimport { PriceRangeFilter } from '../../classes/filters/price_range-filter';\nimport { ChannelService } from '../../ec-services/channel.service';\n\n\n@Component({\n    selector: 'lib-filters-ec',\n    standalone: true,\n    imports: [],\n    templateUrl: './filters-ec.component.html',\n    styleUrl: './filters-ec.component.scss'\n})\nexport class FiltersEcComponent {\n\n    private _authService: AuthService = inject(AuthService);\n    private _filtersService: FiltersService = inject(FiltersService);\n    private _productsService: ProductsService = inject(ProductsService);\n    private _constants: CoreConstantsService = inject(CoreConstantsService);\n    private router: Router = inject(Router);\n    public filters: Filter[] = [];\n    public filter$ = this._filtersService.filters$;\n    public showPricesOnlyToLoggedUsers: boolean = false;\n    public injector: Injector = inject(Injector);\n\tpublic isAuthenticated$ = this._authService.isAuthenticated();\n    public hidePrices: boolean = false;\n    \n    @Input() setSelect: any;\n\n    ngOnInit() {\n\n    }\n\n    constructor() {\n        this._filtersService.filters$.subscribe((filters: Filter[]) => {\n            this.filters = filters;\n        });\n        this.injector.get(ChannelService).channel$.subscribe(channel => {\n            this.showPricesOnlyToLoggedUsers = !!channel.showPricesOnlyToLoggedUsers;\n            this.hidePrices = !!channel.hidePrices;\n        });\n    }\n    /** 1) Para cuando me piden 'price_range', devuelvo PriceRangeFilter */\n    public getSpecificFilter(type: 'price_range'): PriceRangeFilter | null;\n\n    /** 2) Para cualquier otro FilterType, devuelvo Filter */\n    public getSpecificFilter(type: FilterType): Filter | null;\n    public getSpecificFilter(type: FilterType): Filter | null {\n        const filter = this.filters.find(f => f.type() === type);\n        if (type === 'price_range' && filter && !(filter instanceof Filter)) {\n            console.error(`Expected a Filter instance but got`, filter);\n        }\n        return filter || null;\n    }\n\n    /*Obtiene el filtro elegido en el select, lo pasa al setSelect\n    para que se marque seleccionado*/\n    onSelect(event: any, filter: FilterElement[] | null) {\n        // console.log(filter)\n        /*  const selectedOption = filter\n             .flatMap(category => category.children)\n             .filter(option => option?.code === event.target.value)\n             .pop()\n         selectedOption && this._filtersService.setFilterSelected(this.filters[0], selectedOption) */\n    }\n\n    setSelected(filter: Filter | null, selected: FilterElement | null) {\n        if (!filter || !selected) {\n            console.error('Filter or selected element is undefined:', { filter, selected });\n            return;\n        }\n\n        if (typeof (filter as any).setSelected !== 'function') {\n            console.error('filter.setSelected is not a function. Filter might not be an instance of the expected class:', filter);\n            return;\n        }\n\n        try {\n            // this._filtersService.setFilterSelected(filter, selected);\n            if (filter.type() === 'categories') {\n                if (selected.path) {\n                    this.router.navigate([selected.path]);\n                }\n            } else if (filter.type() === 'attributes') {\n                // Manejar la navegación para atributos\n                this._filtersService.setFilterSelected(filter, selected);\n            }\n\n\n        } catch (error) {\n            console.error(\"Error while setting selected filter:\", error);\n        }\n    }\n\n    uniqueSelection(filter: { data: any[]; }, filterChild: any) {\n        // Buscar si hay un filtro de tipo PriceRangeFilter en la lista de filtros\n        const priceRangeFilter = this.filters.find(f => f instanceof PriceRangeFilter);\n\n        if (priceRangeFilter) {\n            priceRangeFilter.reset();\n        }\n        filter.data.forEach(filterElement => {\n            if (filterElement.selected) {\n                filterElement.selected = false;\n            }\n            filterElement.children.forEach((filterChildren: FilterElement) => {\n                if (filterChildren != filterChild && filterChildren.selected) {\n                    filterChildren.selected = false;\n                }\n            });\n        });\n    }\n\n    //  close = () => {\n    //       this.document.getElementById(\"filtros\").classList.remove('in');\n    //       return true;\n    //  };\n\n\n    close = () => {\n        // this.consts.mobile()\n        //      ? this.document.getElementById(\"accordionExample\").classList.remove('show')\n        //      : this.document.getElementById(accordion_id).classList.remove('show');\n        return true;\n    };\n\n\n    scrollUp = () => {\n        window.scroll(0, 0);\n        return true\n    }\n\n\n\n\n\n    hasAppliedFilters(): boolean {\n        return this.filters?.some((filter: any) => {\n            if (filter.type?.() === 'price_range') {\n                const minSet = filter.currentMinPrice !== null && filter.currentMinPrice !== 0;\n                const maxSet = filter.currentMaxPrice !== null && filter.currentMaxPrice !== filter.maxPrice;\n                if (minSet || maxSet) {\n                    return true;\n                }\n            }\n\n            return filter.data?.some((filterElement: any) => {\n                if (Array.isArray(filterElement.children)) {\n                    return filterElement.children.some((child: any) => child.selected);\n                }\n                return filterElement.selected;\n            });\n        }) ?? false;\n    }\n/**\n   * Verifica si una categoría tiene la propiedad isVisible y está marcada como visible\n   * @param category - La categoría a verificar\n   * @returns true si la categoría es visible, false en caso contrario\n   */\n    hasVisibleProperty(category: FilterElement): boolean {\n        return (category as any).isVisible === true;\n    }\n}\n","<p>filters-ec works!</p>\n"]}
@@ -31,8 +31,10 @@ export class HeaderEcComponent extends MenuEcComponent {
31
31
  constructor() {
32
32
  super();
33
33
  this._channelService.channel$.subscribe(cfg => {
34
+ // console.log('Channel configuration:', cfg);
34
35
  this.showPricesOnlyToLoggedUsers = !!cfg.showPricesOnlyToLoggedUsers;
35
36
  this.hidePrices = !!cfg.hidePrices;
37
+ // console.log('hidePrices:', this.hidePrices);
36
38
  });
37
39
  }
38
40
  coreConstantsService = inject(CoreConstantsService);
@@ -40,7 +42,6 @@ export class HeaderEcComponent extends MenuEcComponent {
40
42
  cdr = inject(ChangeDetectorRef); // Inyectamos ChangeDetectorRef para forzar la actualización
41
43
  ngOnInit() {
42
44
  this.channel = this.coreConstantsService.getChannel();
43
- this.searchValue = this.coreConstantsService.searchValue || '';
44
45
  this.onWindowScroll();
45
46
  this.detectRouteChange(); // Llamamos a la función que detecta el cambio de ruta
46
47
  // Usar el Observable del AuthService
@@ -128,19 +129,10 @@ export class HeaderEcComponent extends MenuEcComponent {
128
129
  }
129
130
  this.searchValue = '';
130
131
  this.coreConstantsService.searchValue = '';
131
- // En lugar de relanzar la búsqueda con string vacío,
132
- // actualizamos la URL para quitar el query param `search` y resetear la paginación.
133
- this.router.navigate(['/collection'], {
134
- queryParams: {
135
- search: null,
136
- page: null
137
- },
138
- queryParamsHandling: 'merge'
139
- });
132
+ this.getCollectionSearch();
140
133
  }
141
134
  setupMobileMenu() {
142
- if (!isPlatformBrowser(this.platformId) || typeof document === 'undefined')
143
- return;
135
+ // console.log('setupMobileMenu called');
144
136
  const menuMobile = document.querySelector('.menuMobile');
145
137
  if (!(menuMobile instanceof HTMLElement))
146
138
  return;
@@ -241,4 +233,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
241
233
  type: HostListener,
242
234
  args: ['window:scroll', []]
243
235
  }] } });
244
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"header-ec.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/header-ec/header-ec.component.ts","../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/header-ec/header-ec.component.html"],"names":[],"mappings":"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","sourcesContent":["import { afterNextRender, Component, inject, PLATFORM_ID, Injector, OnInit, HostListener, ChangeDetectorRef, signal } from '@angular/core';\nimport { TitleCasePipe, AsyncPipe, JsonPipe, CommonModule } from '@angular/common';\nimport { MenuEcComponent } from '../abstractions-components';\nimport { CartService, TestService, ToastService } from '../../ec-services';\nimport { Observable } from 'rxjs';\nimport { AuthService } from '../../ec-services';\nimport { Router, NavigationEnd, RouterLink, RouterLinkActive } from '@angular/router';\nimport { Category } from '../../interfaces';\nimport { CoreConstantsService } from '../../constants';\nimport { ChannelService } from '../../ec-services';\nimport { isPlatformBrowser } from '@angular/common';\n\n/**\n * Componente que se encarga de manejar la funcionalidad del Header.\n */\n@Component({\n  selector: 'lib-header-ec',\n  standalone: true,\n  imports: [CommonModule, TitleCasePipe, AsyncPipe, JsonPipe, RouterLink, RouterLinkActive],\n  templateUrl: './header-ec.component.html',\n  styleUrl: './header-ec.component.scss'\n})\nexport class HeaderEcComponent extends MenuEcComponent {\n  public channel: string | undefined;\n  public searchValue: string = '';\n  transparent: boolean = false;\n  isHome: boolean = false; // Nueva variable para verificar si estamos en /home\n  isScrolled: boolean = false;\n  showPricesOnlyToLoggedUsers: boolean = false;\n  hidePrices: boolean = false;\n  public __authService: AuthService = inject(AuthService)\n  public _channelService: ChannelService = inject(ChannelService);\n  public changeDetector = inject(ChangeDetectorRef);\n  public appRouter = inject(Router);\n  public platformId = inject(PLATFORM_ID);\n\n  mobileDropdownOpen = signal(false);\n  isMenuOpen = signal(false);\n\n\n  // Observable del estado de autenticación\n  public logged$!: Observable<boolean>;\n  public isAuthenticated$ = this.__authService.isAuthenticated();\n  constructor() {\n    super();\n    this._channelService.channel$.subscribe(cfg => {\n      this.showPricesOnlyToLoggedUsers = !!cfg.showPricesOnlyToLoggedUsers;\n      this.hidePrices = !!cfg.hidePrices;\n    });\n  }\n\n  private coreConstantsService = inject(CoreConstantsService);\n  private router = inject(Router);\n  private cdr = inject(ChangeDetectorRef); // Inyectamos ChangeDetectorRef para forzar la actualización\n\n  ngOnInit(): void {\n    this.channel = this.coreConstantsService.getChannel();\n    this.searchValue = this.coreConstantsService.searchValue || '';\n    this.onWindowScroll();\n    this.detectRouteChange(); // Llamamos a la función que detecta el cambio de ruta\n    // Usar el Observable del AuthService\n    this.logged$ = this.__authService.loggedIn$;\n\n    // Suscribirse al Observable y forzar detección de cambios cuando sea necesario\n    this.logged$.subscribe(isLoggedIn => {\n      this.changeDetector.detectChanges();\n    });\n    if (isPlatformBrowser(this.platformId)) {\n      this.appRouter.events.subscribe(evt => {\n        if (evt instanceof NavigationEnd) {\n          // Forzar detección de cambios después de navegación\n          setTimeout(() => {\n            this.changeDetector.detectChanges();\n          }, 100);\n        }\n      });\n    }\n  }\n  ngAfterViewInit(): void {\n    this.setupMobileMenu(); // Inicializamos el menú móvil\n    this.setupSearchInputs(); // Inicializamos los inputs de búsqueda   \n    this.isHomeFunction();\n  }\n  /**\n   * Detecta cuando cambia la ruta y actualiza la clase del header\n   */\n  private detectRouteChange() {\n    this.router.events.subscribe(event => {\n      if (event instanceof NavigationEnd) {\n        this.isHome = this.router.url === '/home';\n        this.cdr.detectChanges(); // Forzamos la detección de cambios para actualizar la vista\n      }\n    });\n  }\n\n  @HostListener('window:scroll', [])\n  onWindowScroll() {\n    const scrollTop = window.scrollY;\n    this.isScrolled = scrollTop > 80;\n  }\n\n  isHomeFunction(): void {\n    const headerElement = document.querySelector('header');\n    if (headerElement) {\n      if (this.router.url !== '/home') {\n        headerElement.classList.add('show-menu');\n      } else {\n        headerElement.classList.remove('show-menu');\n      }\n    }\n  }\n\n  changeUrlTransparent = (urlTransparent: string) => {\n    return urlTransparent;\n  };\n\n\n  getCollectionSearch = () => {\n    this.coreConstantsService.searchValue = this.searchValue;\n    this.router.navigateByUrl('/collection?search=' + this.searchValue);\n  };\n\n  setSearchValue = (event: Event, afterSearch?: Function, ...args: any[]) => {\n    const target = event.target as HTMLInputElement;\n    if (target) {\n      this.searchValue = target.value;\n    }\n\n    // if (event.key === 'Enter') {\n    // this.getCollectionSearch();\n    if (afterSearch) {\n      afterSearch(...args);\n      // }\n    }\n  };\n\n  borrarInput(inputId?: string) {\n    if (inputId) {\n      const input = document.getElementById(inputId) as HTMLInputElement;\n      if (input) {\n        input.value = '';\n      }\n    } else {\n      const inputs = ['searchInput1'];\n      inputs.forEach((id) => {\n        const input = document.getElementById(id) as HTMLInputElement;\n        if (input) {\n          input.value = '';\n        }\n      });\n    }\n\n    this.searchValue = '';\n    this.coreConstantsService.searchValue = '';\n    \n    // En lugar de relanzar la búsqueda con string vacío,\n    // actualizamos la URL para quitar el query param `search` y resetear la paginación.\n    this.router.navigate(['/collection'], {\n      queryParams: {\n        search: null,\n        page: null\n      },\n      queryParamsHandling: 'merge'\n    });\n  }\n  setupMobileMenu() {\n    if (!isPlatformBrowser(this.platformId) || typeof document === 'undefined') return;\n    const menuMobile = document.querySelector('.menuMobile');\n    if (!(menuMobile instanceof HTMLElement)) return;\n    const openBtn = document.querySelector('.abreMenuMobile .abre');\n    const closeBtn = document.querySelector('.abreMenuMobile .close');\n    const iconMenu = document.getElementById('icMenu');\n    const searchMobile = document.querySelector('.searchMobile');\n\n    const closeMenu = () => {\n      menuMobile.style.display = 'none';\n      closeBtn?.setAttribute('style', 'display:none');\n      iconMenu?.setAttribute('style', 'display:block');\n    };\n\n    menuMobile.style.display = 'none';\n\n    openBtn?.addEventListener('click', () => {\n      menuMobile.style.display = 'block';\n      closeBtn?.setAttribute('style', 'display:block');\n      if (searchMobile instanceof HTMLElement) {\n        searchMobile.style.display = 'none';\n      }\n      iconMenu?.setAttribute('style', 'display:none');\n    });\n\n    closeBtn?.addEventListener('click', closeMenu);\n\n    // Cierra el menú si se hace clic en un enlace específico dentro del menú\n    const linkSelectors = ['.categoryMobile', '.subcategoryMobile', '.usuariomobile'];\n    linkSelectors.forEach(selector => {\n      const links = menuMobile.querySelectorAll<HTMLAnchorElement>(`a${selector}`);\n      links.forEach(link => {\n        link.addEventListener('click', () => {\n          closeMenu();\n        });\n      });\n    });\n  }\n  setupSearchInputs() {\n    const inputs = ['searchInput1', 'searchInput2'];\n\n    inputs.forEach(id => {\n      const input = document.getElementById(id);\n      if (!(input instanceof HTMLInputElement)) return;\n      const clearBtn = document.querySelector(`.clear-btn${id.slice(-1)}`);\n\n      if (!input || !(clearBtn instanceof HTMLElement)) return;\n\n      input.addEventListener('focus', () => {\n        if (input.value === 'Buscar producto...') {\n          input.value = '';\n        }\n      });\n\n      input.addEventListener('blur', () => {\n        if (input.value.trim() === '') {\n          input.value = 'Buscar producto...';\n        }\n      });\n\n      input.addEventListener('input', () => {\n        clearBtn.style.display = input.value.trim() !== '' ? 'block' : 'none';\n      });\n\n      clearBtn.addEventListener('click', (e) => {\n        e.preventDefault();\n        input.value = '';\n        clearBtn.style.display = 'none';\n        input.focus();\n      });\n    });\n\n  }\n\n  togglePanel(id: string) {\n    // Solo ejecutar en el navegador para evitar problemas con SSR\n    if (isPlatformBrowser(this.platformId)) {\n      this.openPanels.update(panels => ({\n        ...panels,\n        [id]: !panels[id]\n      }));\n    }\n  }\n\n  openPanels = signal<Record<string, boolean>>({\n    collapseUno: false,\n    collapseDos: true // Productos abierto por defecto\n  });\n\n\n\n\n  collapseAllMenus() {\n    // Solo ejecutar en el navegador para evitar problemas con SSR\n    if (isPlatformBrowser(this.platformId)) {\n      this.openPanels.update(panels => {\n        const newPanels = { ...panels };\n        Object.keys(newPanels).forEach(key => {\n          if (key !== 'collapseDos') {\n            newPanels[key] = false;\n          }\n        });\n        return newPanels;\n      });\n    }\n  }\n}\n","<p>header-ec works!</p>\n"]}
236
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"header-ec.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/header-ec/header-ec.component.ts","../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/header-ec/header-ec.component.html"],"names":[],"mappings":"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","sourcesContent":["import { afterNextRender, Component, inject,PLATFORM_ID, Injector, OnInit, HostListener, ChangeDetectorRef, signal } from '@angular/core';\nimport { TitleCasePipe, AsyncPipe, JsonPipe, CommonModule } from '@angular/common';\nimport { MenuEcComponent } from '../abstractions-components';\nimport { CartService, TestService, ToastService } from '../../ec-services';\nimport { Observable } from 'rxjs';\nimport { AuthService } from '../../ec-services';\nimport { Router, NavigationEnd, RouterLink, RouterLinkActive } from '@angular/router';\nimport { Category } from '../../interfaces';\nimport { CoreConstantsService } from '../../constants';\nimport { ChannelService } from '../../ec-services';\nimport { isPlatformBrowser } from '@angular/common';\n\n/**\n * Componente que se encarga de manejar la funcionalidad del Header.\n */\n@Component({\n  selector: 'lib-header-ec',\n  standalone: true,\n  imports: [CommonModule, TitleCasePipe, AsyncPipe, JsonPipe, RouterLink, RouterLinkActive],\n  templateUrl: './header-ec.component.html',\n  styleUrl: './header-ec.component.scss'\n})\nexport class HeaderEcComponent extends MenuEcComponent {\n  public channel: string | undefined;\n  public searchValue: string = '';\n  transparent: boolean = false;\n  isHome: boolean = false; // Nueva variable para verificar si estamos en /home\n  isScrolled: boolean = false;\n  showPricesOnlyToLoggedUsers: boolean = false;\n  hidePrices: boolean = false;\n  public __authService: AuthService = inject(AuthService)\n  public _channelService: ChannelService = inject(ChannelService);\n  public changeDetector = inject(ChangeDetectorRef);\n  public appRouter = inject(Router);\n  public platformId = inject(PLATFORM_ID);\n\n    mobileDropdownOpen = signal(false);\n     isMenuOpen = signal(false);\n\n\n  // Observable del estado de autenticación\n  public logged$!: Observable<boolean>;\n  public isAuthenticated$ = this.__authService.isAuthenticated();\n  constructor() {\n    super();\n    this._channelService.channel$.subscribe(cfg => {\n      // console.log('Channel configuration:', cfg);\n      this.showPricesOnlyToLoggedUsers = !!cfg.showPricesOnlyToLoggedUsers;\n      this.hidePrices = !!cfg.hidePrices;\n      // console.log('hidePrices:', this.hidePrices);\n    });\n  }\n\n  private coreConstantsService = inject(CoreConstantsService);\n  private router = inject(Router);\n  private cdr = inject(ChangeDetectorRef); // Inyectamos ChangeDetectorRef para forzar la actualización\n\n  ngOnInit(): void {\n    this.channel = this.coreConstantsService.getChannel();\n    this.onWindowScroll();\n    this.detectRouteChange(); // Llamamos a la función que detecta el cambio de ruta\n    // Usar el Observable del AuthService\n    this.logged$ = this.__authService.loggedIn$;\n\n    // Suscribirse al Observable y forzar detección de cambios cuando sea necesario\n    this.logged$.subscribe(isLoggedIn => {\n      this.changeDetector.detectChanges();\n    });\n     if (isPlatformBrowser(this.platformId)) {\n      this.appRouter.events.subscribe(evt => {\n        if (evt instanceof NavigationEnd) {\n          // Forzar detección de cambios después de navegación\n          setTimeout(() => {\n            this.changeDetector.detectChanges();\n          }, 100);\n        }\n      });\n    }\n  }\n  ngAfterViewInit(): void {\n    this.setupMobileMenu(); // Inicializamos el menú móvil\n    this.setupSearchInputs(); // Inicializamos los inputs de búsqueda   \n    this.isHomeFunction();\n  }\n  /**\n   * Detecta cuando cambia la ruta y actualiza la clase del header\n   */\n  private detectRouteChange() {\n    this.router.events.subscribe(event => {\n      if (event instanceof NavigationEnd) {\n        this.isHome = this.router.url === '/home';\n        this.cdr.detectChanges(); // Forzamos la detección de cambios para actualizar la vista\n      }\n    });\n  }\n\n  @HostListener('window:scroll', [])\n  onWindowScroll() {\n    const scrollTop = window.scrollY;\n    this.isScrolled = scrollTop > 80;\n  }\n\n  isHomeFunction(): void {\n    const headerElement = document.querySelector('header');\n    if (headerElement) {\n      if (this.router.url !== '/home') {\n        headerElement.classList.add('show-menu');\n      } else {\n        headerElement.classList.remove('show-menu');\n      }\n    }\n  }\n\n  changeUrlTransparent = (urlTransparent: string) => {\n    return urlTransparent;\n  };\n\n\n  getCollectionSearch = () => {\n    this.coreConstantsService.searchValue = this.searchValue;\n    this.router.navigateByUrl('/collection?search=' + this.searchValue);\n  };\n\n  setSearchValue = (event: Event, afterSearch?: Function, ...args: any[]) => {\n    const target = event.target as HTMLInputElement;\n    if (target) {\n      this.searchValue = target.value;\n    }\n\n    // if (event.key === 'Enter') {\n    // this.getCollectionSearch();\n    if (afterSearch) {\n      afterSearch(...args);\n      // }\n    }\n  };\n\n  borrarInput(inputId?: string) {\n    if (inputId) {\n      const input = document.getElementById(inputId) as HTMLInputElement;\n      if (input) {\n        input.value = '';\n      }\n    } else {\n      const inputs = ['searchInput1'];\n      inputs.forEach((id) => {\n        const input = document.getElementById(id) as HTMLInputElement;\n        if (input) {\n          input.value = '';\n        }\n      });\n    }\n\n    this.searchValue = '';\n    this.coreConstantsService.searchValue = '';\n    this.getCollectionSearch();\n  }\n  setupMobileMenu() {\n    // console.log('setupMobileMenu called');\n    const menuMobile = document.querySelector('.menuMobile');\n    if (!(menuMobile instanceof HTMLElement)) return;\n    const openBtn = document.querySelector('.abreMenuMobile .abre');\n    const closeBtn = document.querySelector('.abreMenuMobile .close');\n    const iconMenu = document.getElementById('icMenu');\n    const searchMobile = document.querySelector('.searchMobile');\n\n    const closeMenu = () => {\n      menuMobile.style.display = 'none';\n      closeBtn?.setAttribute('style', 'display:none');\n      iconMenu?.setAttribute('style', 'display:block');\n    };\n\n    menuMobile.style.display = 'none';\n\n    openBtn?.addEventListener('click', () => {\n      menuMobile.style.display = 'block';\n      closeBtn?.setAttribute('style', 'display:block');\n      if (searchMobile instanceof HTMLElement) {\n        searchMobile.style.display = 'none';\n      }\n      iconMenu?.setAttribute('style', 'display:none');\n    });\n\n    closeBtn?.addEventListener('click', closeMenu);\n\n    // Cierra el menú si se hace clic en un enlace específico dentro del menú\n    const linkSelectors = ['.categoryMobile', '.subcategoryMobile', '.usuariomobile'];\n    linkSelectors.forEach(selector => {\n      const links = menuMobile.querySelectorAll<HTMLAnchorElement>(`a${selector}`);\n      links.forEach(link => {\n        link.addEventListener('click', () => {\n          closeMenu();\n        });\n      });\n    });\n  }\n  setupSearchInputs() {\n    const inputs = ['searchInput1', 'searchInput2'];\n\n    inputs.forEach(id => {\n      const input = document.getElementById(id);\n      if (!(input instanceof HTMLInputElement)) return;\n      const clearBtn = document.querySelector(`.clear-btn${id.slice(-1)}`);\n\n      if (!input || !(clearBtn instanceof HTMLElement)) return;\n\n      input.addEventListener('focus', () => {\n        if (input.value === 'Buscar producto...') {\n          input.value = '';\n        }\n      });\n\n      input.addEventListener('blur', () => {\n        if (input.value.trim() === '') {\n          input.value = 'Buscar producto...';\n        }\n      });\n\n      input.addEventListener('input', () => {\n        clearBtn.style.display = input.value.trim() !== '' ? 'block' : 'none';\n      });\n\n      clearBtn.addEventListener('click', (e) => {\n        e.preventDefault();\n        input.value = '';\n        clearBtn.style.display = 'none';\n        input.focus();\n      });\n    });\n\n  }\n\n   togglePanel(id: string) {\n    // Solo ejecutar en el navegador para evitar problemas con SSR\n    if (isPlatformBrowser(this.platformId)) {\n      this.openPanels.update(panels => ({\n        ...panels,\n        [id]: !panels[id]\n      }));\n    }\n  }\n\n    openPanels = signal<Record<string, boolean>>({\n    collapseUno: false,\n    collapseDos: true // Productos abierto por defecto\n  });\n\n\n\n\n       collapseAllMenus() {\n    // Solo ejecutar en el navegador para evitar problemas con SSR\n    if (isPlatformBrowser(this.platformId)) {\n      this.openPanels.update(panels => {\n        const newPanels = { ...panels };\n        Object.keys(newPanels).forEach(key => {\n          if (key !== 'collapseDos') {\n            newPanels[key] = false;\n          }\n        });\n        return newPanels;\n      });\n    }\n  }\n}\n","<p>header-ec works!</p>\n"]}