ng-easycommerce-v18 0.0.6 → 0.0.8

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.
@@ -12,7 +12,7 @@ export class FiltersEcComponent {
12
12
  priceGapPercentage = 0.1;
13
13
  constructor() {
14
14
  this.filter$.subscribe(res => {
15
- this.filters = this._filtersService.getSpecificFilters(['attributes', 'categories', 'price_range', 'dynamics']);
15
+ console.log("filters", res);
16
16
  });
17
17
  }
18
18
  getSpecificFilter(type) {
@@ -141,4 +141,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
141
141
  type: ViewChild,
142
142
  args: ['rangeMax']
143
143
  }] } });
144
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filters-ec.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/filters-ec/filters-ec.component.ts","../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/filters-ec/filters-ec.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, inject, Input, ElementRef , ViewChild } from '@angular/core';\r\nimport { FiltersService } from '../../ec-services';\r\nimport { Filter } from '../../classes';\r\nimport { FilterElement, FilterType } from '../../interfaces';\r\nimport { PriceRangeFilter } from '../../classes/filters/PriceRangeFilter';\r\n\r\n@Component({\r\n\tselector: 'lib-filters-ec',\r\n\tstandalone: true,\r\n\timports: [],\r\n\ttemplateUrl: './filters-ec.component.html',\r\n\tstyleUrl: './filters-ec.component.scss'\r\n})\r\nexport class FiltersEcComponent {\r\n\tprivate _filtersService: FiltersService = inject(FiltersService);\r\n\tpublic filters: Filter[] = [];\r\n\tpublic filter$ = this._filtersService.filters$;\r\n\t@Input() setSelect: any;\r\n\r\n\t@ViewChild('rangeMin') rangeMinRef!: ElementRef;\r\n\t@ViewChild('rangeMax') rangeMaxRef!: ElementRef;\r\n\r\n\tpriceGapPercentage = 0.1;\r\n\r\n\r\n\tconstructor() {\r\n\t\tthis.filter$.subscribe(res => {\r\n\t\t\tthis.filters = this._filtersService.getSpecificFilters(['attributes', 'categories', 'price_range', 'dynamics'])\r\n\t\t})\r\n\t}\r\n\r\n\tgetSpecificFilter(type: FilterType): Filter | null {\r\n\t\tconst filter = this.filters.find(filter => filter.type() === type)\r\n\t\treturn filter || null;\r\n\t}\r\n\r\n\t/*Obtiene el filtro elegido en el select, lo pasa al setSelect\r\n\tpara que se marque seleccionado*/\r\n\tonSelect(event: any, filter: FilterElement[] | null) {\r\n\t\tconsole.log(filter)\r\n\t\t/*  const selectedOption = filter\r\n\t\t\t .flatMap(category => category.children)\r\n\t\t\t .filter(option => option?.code === event.target.value)\r\n\t\t\t .pop()\r\n\t\t selectedOption && this._filtersService.setFilterSelected(this.filters[0], selectedOption) */\r\n\t}\r\n\r\n\tsetSelected(filter: Filter | null, selected: FilterElement) {\r\n\t\tconsole.log(\"set\", filter);\r\n\t\tfilter && this._filtersService.setFilterSelected(filter, selected)\r\n\t}\r\n\r\n\t/**\r\n\t* Redondea al múltiplo de 'step' respetando el redondeo entero:\r\n\t* - Mínimo: redondea hacia abajo.\r\n\t* - Máximo: redondea hacia arriba.\r\n\t*/\r\n\tonRangeChange(event: Event, type: 'min' | 'max', filter: { minPrice: number; maxPrice: number; currentMinPrice?: number; currentMaxPrice?: number }) {\r\n\t\tconst input = event.target as HTMLInputElement;\r\n\t\tlet value = parseInt(input.value, 10);\r\n\t\tvalue = this.roundToNearest(value, 5, type, filter);\r\n\r\n\t\tthis.updateFilterPrices(type, value, filter, this.priceGapPercentage);\r\n\t}\r\n\r\n\troundToNearest(value: number, step: number, type: 'min' | 'max', filter: any): number {\r\n\t\tlet rounded = Math.round(value / step) * step;\r\n\t\tif (type === 'max' && rounded < filter.maxPrice) {\r\n\t\t\trounded = Math.ceil(value / step) * step;\r\n\t\t}\r\n\t\tif (type === 'min' && rounded > filter.minPrice) {\r\n\t\t\trounded = Math.floor(value / step) * step;\r\n\t\t}\r\n\t\treturn rounded;\r\n\t}\r\n\tuniqueSelection(filter: { data: any[]; }, filterChild: any) {\r\n\t\t// Buscar si hay un filtro de tipo PriceRangeFilter en la lista de filtros\r\n\t\tconst priceRangeFilter = this.filters.find(f => f instanceof PriceRangeFilter);\r\n\r\n\t\tif (priceRangeFilter) {\r\n\t\t\tpriceRangeFilter.reset();\r\n\t\t}\r\n\t\tfilter.data.forEach(filterElement => {\r\n\t\t\tif (filterElement.selected) {\r\n\t\t\t\tfilterElement.selected = false;\r\n\t\t\t}\r\n\t\t\tfilterElement.children.forEach((filterChildren: FilterElement) => {\r\n\t\t\t\tif (filterChildren != filterChild && filterChildren.selected) {\r\n\t\t\t\t\tfilterChildren.selected = false;\r\n\t\t\t\t}\r\n\t\t\t});\r\n\t\t});\r\n\t}\r\n\r\n\t/**\r\n   * Actualiza los valores del filtro permitiendo que un input empuje al otro.\r\n  */\r\n\tupdateFilterPrices(type: 'min' | 'max', value: number, filter: any, priceGap: number) {\r\n\t\tconst globalMin = filter.minPrice ?? 0;\r\n\t\tconst globalMax = filter.maxPrice;\r\n\r\n\t\tlet currentMin = filter.currentMinPrice ?? globalMin;\r\n\t\tlet currentMax = filter.currentMaxPrice ?? globalMax;\r\n\r\n\t\tif (type === 'min') {\r\n\t\t\tlet newMin = Math.min(Math.max(value, globalMin), globalMax);\r\n\t\t\tif (newMin + priceGap > currentMax) {\r\n\t\t\t\tlet newMaxCandidate = newMin + priceGap;\r\n\t\t\t\tif (newMaxCandidate <= globalMax) {\r\n\t\t\t\t\tcurrentMax = newMaxCandidate;\r\n\t\t\t\t} else {\r\n\t\t\t\t\tnewMin = globalMax - priceGap;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\tfilter.currentMinPrice = newMin;\r\n\t\t\tfilter.currentMaxPrice = currentMax;\r\n\t\t} else if (type === 'max') {\r\n\t\t\tlet newMax = Math.max(Math.min(value, globalMax), globalMin);\r\n\t\t\tif (newMax - priceGap < currentMin) {\r\n\t\t\t\tlet newMinCandidate = newMax - priceGap;\r\n\t\t\t\tif (newMinCandidate >= globalMin) {\r\n\t\t\t\t\tcurrentMin = newMinCandidate;\r\n\t\t\t\t} else {\r\n\t\t\t\t\tnewMax = globalMin + priceGap;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\tfilter.currentMaxPrice = newMax;\r\n\t\t\tfilter.currentMinPrice = currentMin;\r\n\t\t}\r\n\t}\r\n\t// Método para actualizar los valores de precio seleccionados\r\n\tupdatePriceRange(min: number, max: number, priceFilter: PriceRangeFilter) {\r\n\t\tpriceFilter.setSelected(min, max);\r\n\t\tthis.setSelect(priceFilter);\r\n\t}\r\n\r\n\t// Métodos para actualizar la barra del filtro por precio\r\n\tcalculateLeftPercentage(currentMinPrice: number, minPrice: number, maxPrice: number): number {\r\n\t\tconst minVal = Math.max(minPrice, Math.min(currentMinPrice ?? minPrice, maxPrice));\r\n\t\treturn Math.max(0, Math.min(((minVal - minPrice) / (maxPrice - minPrice)) * 100, 100));\r\n\t}\r\n\r\n\tcalculateRightPercentage(currentMaxPrice: number, minPrice: number, maxPrice: number): number {\r\n\t\tconst maxVal = Math.max(minPrice, Math.min(currentMaxPrice ?? maxPrice, maxPrice));\r\n\t\treturn Math.max(0, Math.min(100 - ((maxVal - minPrice) / (maxPrice - minPrice)) * 100, 100));\r\n\t}\r\n\r\n\tscrollUp = () => {\r\n\t\twindow.scroll(0, 0);\r\n\t\treturn true\r\n\t}\r\n\t\r\n}\r\n","<p>filters-ec works!</p>\r\n"]}
144
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filters-ec.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/filters-ec/filters-ec.component.ts","../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/filters-ec/filters-ec.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, inject, Input, ElementRef , ViewChild } from '@angular/core';\r\nimport { FiltersService } from '../../ec-services';\r\nimport { Filter } from '../../classes';\r\nimport { FilterElement, FilterType } from '../../interfaces';\r\nimport { PriceRangeFilter } from '../../classes/filters/PriceRangeFilter';\r\n\r\n@Component({\r\n\tselector: 'lib-filters-ec',\r\n\tstandalone: true,\r\n\timports: [],\r\n\ttemplateUrl: './filters-ec.component.html',\r\n\tstyleUrl: './filters-ec.component.scss'\r\n})\r\nexport class FiltersEcComponent {\r\n\tprivate _filtersService: FiltersService = inject(FiltersService);\r\n\tpublic filters: Filter[] = [];\r\n\tpublic filter$ = this._filtersService.filters$;\r\n\t@Input() setSelect: any;\r\n\r\n\t@ViewChild('rangeMin') rangeMinRef!: ElementRef;\r\n\t@ViewChild('rangeMax') rangeMaxRef!: ElementRef;\r\n\r\n\tpriceGapPercentage = 0.1;\r\n\r\n\r\n\tconstructor() {\r\n\t\tthis.filter$.subscribe(res => {\r\n\t\t\tconsole.log(\"filters\", res);\r\n\t\t})\r\n\t}\r\n\r\n\tgetSpecificFilter(type: FilterType): Filter | null {\r\n\t\tconst filter = this.filters.find(filter => filter.type() === type)\r\n\t\treturn filter || null;\r\n\t}\r\n\r\n\t/*Obtiene el filtro elegido en el select, lo pasa al setSelect\r\n\tpara que se marque seleccionado*/\r\n\tonSelect(event: any, filter: FilterElement[] | null) {\r\n\t\tconsole.log(filter)\r\n\t\t/*  const selectedOption = filter\r\n\t\t\t .flatMap(category => category.children)\r\n\t\t\t .filter(option => option?.code === event.target.value)\r\n\t\t\t .pop()\r\n\t\t selectedOption && this._filtersService.setFilterSelected(this.filters[0], selectedOption) */\r\n\t}\r\n\r\n\tsetSelected(filter: Filter | null, selected: FilterElement) {\r\n\t\tconsole.log(\"set\", filter);\r\n\t\tfilter && this._filtersService.setFilterSelected(filter, selected)\r\n\t}\r\n\r\n\t/**\r\n\t* Redondea al múltiplo de 'step' respetando el redondeo entero:\r\n\t* - Mínimo: redondea hacia abajo.\r\n\t* - Máximo: redondea hacia arriba.\r\n\t*/\r\n\tonRangeChange(event: Event, type: 'min' | 'max', filter: { minPrice: number; maxPrice: number; currentMinPrice?: number; currentMaxPrice?: number }) {\r\n\t\tconst input = event.target as HTMLInputElement;\r\n\t\tlet value = parseInt(input.value, 10);\r\n\t\tvalue = this.roundToNearest(value, 5, type, filter);\r\n\r\n\t\tthis.updateFilterPrices(type, value, filter, this.priceGapPercentage);\r\n\t}\r\n\r\n\troundToNearest(value: number, step: number, type: 'min' | 'max', filter: any): number {\r\n\t\tlet rounded = Math.round(value / step) * step;\r\n\t\tif (type === 'max' && rounded < filter.maxPrice) {\r\n\t\t\trounded = Math.ceil(value / step) * step;\r\n\t\t}\r\n\t\tif (type === 'min' && rounded > filter.minPrice) {\r\n\t\t\trounded = Math.floor(value / step) * step;\r\n\t\t}\r\n\t\treturn rounded;\r\n\t}\r\n\tuniqueSelection(filter: { data: any[]; }, filterChild: any) {\r\n\t\t// Buscar si hay un filtro de tipo PriceRangeFilter en la lista de filtros\r\n\t\tconst priceRangeFilter = this.filters.find(f => f instanceof PriceRangeFilter);\r\n\r\n\t\tif (priceRangeFilter) {\r\n\t\t\tpriceRangeFilter.reset();\r\n\t\t}\r\n\t\tfilter.data.forEach(filterElement => {\r\n\t\t\tif (filterElement.selected) {\r\n\t\t\t\tfilterElement.selected = false;\r\n\t\t\t}\r\n\t\t\tfilterElement.children.forEach((filterChildren: FilterElement) => {\r\n\t\t\t\tif (filterChildren != filterChild && filterChildren.selected) {\r\n\t\t\t\t\tfilterChildren.selected = false;\r\n\t\t\t\t}\r\n\t\t\t});\r\n\t\t});\r\n\t}\r\n\r\n\t/**\r\n   * Actualiza los valores del filtro permitiendo que un input empuje al otro.\r\n  */\r\n\tupdateFilterPrices(type: 'min' | 'max', value: number, filter: any, priceGap: number) {\r\n\t\tconst globalMin = filter.minPrice ?? 0;\r\n\t\tconst globalMax = filter.maxPrice;\r\n\r\n\t\tlet currentMin = filter.currentMinPrice ?? globalMin;\r\n\t\tlet currentMax = filter.currentMaxPrice ?? globalMax;\r\n\r\n\t\tif (type === 'min') {\r\n\t\t\tlet newMin = Math.min(Math.max(value, globalMin), globalMax);\r\n\t\t\tif (newMin + priceGap > currentMax) {\r\n\t\t\t\tlet newMaxCandidate = newMin + priceGap;\r\n\t\t\t\tif (newMaxCandidate <= globalMax) {\r\n\t\t\t\t\tcurrentMax = newMaxCandidate;\r\n\t\t\t\t} else {\r\n\t\t\t\t\tnewMin = globalMax - priceGap;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\tfilter.currentMinPrice = newMin;\r\n\t\t\tfilter.currentMaxPrice = currentMax;\r\n\t\t} else if (type === 'max') {\r\n\t\t\tlet newMax = Math.max(Math.min(value, globalMax), globalMin);\r\n\t\t\tif (newMax - priceGap < currentMin) {\r\n\t\t\t\tlet newMinCandidate = newMax - priceGap;\r\n\t\t\t\tif (newMinCandidate >= globalMin) {\r\n\t\t\t\t\tcurrentMin = newMinCandidate;\r\n\t\t\t\t} else {\r\n\t\t\t\t\tnewMax = globalMin + priceGap;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\tfilter.currentMaxPrice = newMax;\r\n\t\t\tfilter.currentMinPrice = currentMin;\r\n\t\t}\r\n\t}\r\n\t// Método para actualizar los valores de precio seleccionados\r\n\tupdatePriceRange(min: number, max: number, priceFilter: PriceRangeFilter) {\r\n\t\tpriceFilter.setSelected(min, max);\r\n\t\tthis.setSelect(priceFilter);\r\n\t}\r\n\r\n\t// Métodos para actualizar la barra del filtro por precio\r\n\tcalculateLeftPercentage(currentMinPrice: number, minPrice: number, maxPrice: number): number {\r\n\t\tconst minVal = Math.max(minPrice, Math.min(currentMinPrice ?? minPrice, maxPrice));\r\n\t\treturn Math.max(0, Math.min(((minVal - minPrice) / (maxPrice - minPrice)) * 100, 100));\r\n\t}\r\n\r\n\tcalculateRightPercentage(currentMaxPrice: number, minPrice: number, maxPrice: number): number {\r\n\t\tconst maxVal = Math.max(minPrice, Math.min(currentMaxPrice ?? maxPrice, maxPrice));\r\n\t\treturn Math.max(0, Math.min(100 - ((maxVal - minPrice) / (maxPrice - minPrice)) * 100, 100));\r\n\t}\r\n\r\n\tscrollUp = () => {\r\n\t\twindow.scroll(0, 0);\r\n\t\treturn true\r\n\t}\r\n\t\r\n}\r\n","<p>filters-ec works!</p>\r\n"]}
@@ -62,8 +62,14 @@ export class ProductDetailEcComponent {
62
62
  this._meta.updateTag({ property: 'og:url', content: currentUrl });
63
63
  this._meta.updateTag({ property: 'og:type', content: 'product' });
64
64
  }
65
+ decodeHtml(html) {
66
+ const txt = document.createElement('textarea');
67
+ txt.innerHTML = html;
68
+ return txt.value;
69
+ }
65
70
  sanitizedHtml(html) {
66
- return this._domSanitizer.bypassSecurityTrustHtml(html);
71
+ const decodedHtml = this.decodeHtml(html);
72
+ return this._domSanitizer.bypassSecurityTrustHtml(decodedHtml);
67
73
  }
68
74
  addToCart() {
69
75
  this.quantity() > 0 && this._productDetailService.addToCart(this.quantity());
@@ -114,4 +120,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
114
120
  type: Component,
115
121
  args: [{ selector: 'app-product-detail-ec', standalone: true, imports: [], template: "" }]
116
122
  }], ctorParameters: () => [] });
117
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"product-detail-ec.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/product-detail-ec/product-detail-ec.component.ts","../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/product-detail-ec/product-detail-ec.component.html"],"names":[],"mappings":"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","sourcesContent":["import { computed , Injector} from '@angular/core';\r\nimport { ParametersService, ChannelService } from '../../ec-services';\r\nimport {  Parameter } from '../../interfaces';\r\nimport { Component, inject, WritableSignal, signal, PLATFORM_ID, Inject } from '@angular/core';\r\nimport { Location } from '@angular/common';\r\nimport { Meta, Title } from '@angular/platform-browser';\r\nimport { ActivatedRoute } from '@angular/router';\r\nimport { ProductDetailService, ProductsService, ToastService } from '../../ec-services';\r\nimport { DomSanitizer } from '@angular/platform-browser';\r\nimport { CoreConstantsService } from '../../constants';\r\nimport { Observable } from 'rxjs';\r\nimport { Product } from '../../interfaces';\r\nimport * as he from 'he';\r\n\r\n\r\n\r\n@Component({\r\n  selector: 'app-product-detail-ec',\r\n  standalone: true,\r\n  imports: [],\r\n  templateUrl: './product-detail-ec.component.html',\r\n  styleUrls: ['./product-detail-ec.component.scss']\r\n})\r\nexport class ProductDetailEcComponent {\r\n\tprivate _productDetailService: ProductDetailService = inject(ProductDetailService);\r\n\tprivate _productService: ProductsService = inject(ProductsService);\r\n\tprivate _activedRoute: ActivatedRoute = inject(ActivatedRoute);\r\n\tprivate _domSanitizer: DomSanitizer = inject(DomSanitizer);\r\n\tprivate _consts: CoreConstantsService = inject(CoreConstantsService);\r\n\tprivate _toastService: ToastService = inject(ToastService);\r\n\tprivate parametersService = inject(ParametersService);\r\n\tpublic injector: Injector = inject(Injector);\r\n\tprivate _meta: Meta = inject(Meta);\r\n\tprivate _title: Title = inject(Title);\r\n\tprivate _location: Location = inject(Location);\r\n\tpublic product$: Observable<Product | null> = this._productDetailService.product$;\r\n\tpublic options$: Observable<any> = this._productDetailService.options$;\r\n\tpublic data$: Observable<any> = this._productDetailService.associatedData$;\r\n\r\n\tpublic mediaUrl = this._consts.mediaUrl();\r\n\tpublic code: string = '';\r\n\tpublic showFormContact = false;\r\n\tpublic showReviews: boolean = false;\r\n  public reset: boolean = false;\r\n\t public success: boolean = false;\r\n\r\n\tpublic quantity: WritableSignal<number> = signal(1);\r\n\tpublic parameters$: Observable<Parameter[] | null> = this.parametersService.getParameters();\r\n\tpublic hasParams = this.parametersService.hasParams\r\n\r\n\tconstructor() {\r\n\t\tthis._activedRoute.params.subscribe(queryParams => {\r\n\t\t\tthis.code = queryParams[\"id\"];\r\n\t\t\tthis._productDetailService.loadProduct(this.code);\r\n\t\t  });\r\n\t\tthis._activedRoute.params.subscribe(queryParams => {\r\n\t\t\tthis.code = queryParams[\"id\"];\r\n\t\t\tthis._productDetailService.loadProduct(this.code);\r\n\t\t})\r\n\t\t this.injector.get(ChannelService).channel$.subscribe(channel => {\r\n           this.showReviews = channel.showReviews;\r\n     });\r\n\t}\r\n\r\n  ngOnInit() {\r\n    this.product$.subscribe(product => {\r\n      if (product) {\r\n        this.updateMetaTags(product);\r\n      }\r\n    });\r\n  }\r\n\r\n  updateMetaTags(product: Product) {\r\n\tconst descripcionLimpia = he.decode(product.description || '').replace(/<[^>]*>/g, ' ').replace(/\\s+/g, ' ').trim();\r\n    const currentUrl =this._consts.url() +  this._location.path(true);  // `true` incluye el query string\r\n\r\n\r\n\r\n    this._meta.updateTag({ property: 'og:title', content: product.name || '' });\r\n    this._meta.updateTag({ property: 'og:description', content: descripcionLimpia || '' });\r\n    this._meta.updateTag({ property: 'og:image', content: this._consts.mediaImageUrl(Array.isArray(product.picturesdefault) ? product.picturesdefault[0] : product.picturesdefault) || '' });\r\n    this._meta.updateTag({ property: 'og:url', content: currentUrl });\r\n    this._meta.updateTag({ property: 'og:type', content: 'product' });\r\n  }\r\n\r\n  sanitizedHtml(html: string) {\r\n    return this._domSanitizer.bypassSecurityTrustHtml(html);\r\n  }\r\n\r\n  addToCart() {\r\n    this.quantity() > 0 && this._productDetailService.addToCart(this.quantity());\r\n  }\r\n\r\n  plus(stock?: number, multipleQuantity?: number) {\r\n    if (multipleQuantity && multipleQuantity > 0) {\r\n      stock ? (this.quantity() < stock\r\n        ? this.quantity.update(value => value + multipleQuantity)\r\n        : this._toastService.show('out-of-stock-actually'))\r\n        : this.quantity.update(value => value + multipleQuantity)\r\n    } else {\r\n      stock ? (this.quantity() < stock\r\n        ? this.quantity.update(value => value + 1)\r\n        : this._toastService.show('out-of-stock-actually'))\r\n        : this.quantity.update(value => value + 1)\r\n    }\r\n  }\r\n\r\n  less(multipleQuantity?: any) {\r\n    if (multipleQuantity && multipleQuantity > 0) {\r\n      this.quantity() > multipleQuantity ? this.quantity.update(value => value - multipleQuantity) : null;\r\n    } else {\r\n      this.quantity() > 1 ? this.quantity.update(value => value - 1) : null;\r\n    }\r\n  }\r\n\r\n  checkStock(stock: number) {\r\n    if (this.quantity() >= stock)\r\n      this.quantity.set(stock);\r\n  }\r\n\r\n  public goToSection(section: string): void {\r\n    this.showFormContact = true;\r\n    setTimeout(() => {\r\n      const element = document.getElementById(section);\r\n      if (element) {\r\n        element.scrollIntoView({ behavior: 'smooth' });\r\n      }\r\n    }, 500);\r\n  }\r\n\r\n  resetForm = () => {\r\n    this.reset = !this.reset\r\n    this.success = true\r\n}\r\n}\r\n",""]}
123
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"product-detail-ec.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/product-detail-ec/product-detail-ec.component.ts","../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/product-detail-ec/product-detail-ec.component.html"],"names":[],"mappings":"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","sourcesContent":["import { computed , Injector} from '@angular/core';\r\nimport { ParametersService, ChannelService } from '../../ec-services';\r\nimport {  Parameter } from '../../interfaces';\r\nimport { Component, inject, WritableSignal, signal, PLATFORM_ID, Inject } from '@angular/core';\r\nimport { Location } from '@angular/common';\r\nimport { Meta, Title } from '@angular/platform-browser';\r\nimport { ActivatedRoute } from '@angular/router';\r\nimport { ProductDetailService, ProductsService, ToastService } from '../../ec-services';\r\nimport { DomSanitizer , SafeHtml  } from '@angular/platform-browser';\r\nimport { CoreConstantsService } from '../../constants';\r\nimport { Observable } from 'rxjs';\r\nimport { Product } from '../../interfaces';\r\nimport * as he from 'he';\r\n\r\n\r\n\r\n@Component({\r\n  selector: 'app-product-detail-ec',\r\n  standalone: true,\r\n  imports: [],\r\n  templateUrl: './product-detail-ec.component.html',\r\n  styleUrls: ['./product-detail-ec.component.scss']\r\n})\r\nexport class ProductDetailEcComponent {\r\n\tprivate _productDetailService: ProductDetailService = inject(ProductDetailService);\r\n\tprivate _productService: ProductsService = inject(ProductsService);\r\n\tprivate _activedRoute: ActivatedRoute = inject(ActivatedRoute);\r\n\tprivate _domSanitizer: DomSanitizer = inject(DomSanitizer);\r\n\tprivate _consts: CoreConstantsService = inject(CoreConstantsService);\r\n\tprivate _toastService: ToastService = inject(ToastService);\r\n\tprivate parametersService = inject(ParametersService);\r\n\tpublic injector: Injector = inject(Injector);\r\n\tprivate _meta: Meta = inject(Meta);\r\n\tprivate _title: Title = inject(Title);\r\n\tprivate _location: Location = inject(Location);\r\n\tpublic product$: Observable<Product | null> = this._productDetailService.product$;\r\n\tpublic options$: Observable<any> = this._productDetailService.options$;\r\n\tpublic data$: Observable<any> = this._productDetailService.associatedData$;\r\n\r\n\tpublic mediaUrl = this._consts.mediaUrl();\r\n\tpublic code: string = '';\r\n\tpublic showFormContact = false;\r\n\tpublic showReviews: boolean = false;\r\n  public reset: boolean = false;\r\n\t public success: boolean = false;\r\n\r\n\tpublic quantity: WritableSignal<number> = signal(1);\r\n\tpublic parameters$: Observable<Parameter[] | null> = this.parametersService.getParameters();\r\n\tpublic hasParams = this.parametersService.hasParams\r\n\r\n\tconstructor() {\r\n\t\tthis._activedRoute.params.subscribe(queryParams => {\r\n\t\t\tthis.code = queryParams[\"id\"];\r\n\t\t\tthis._productDetailService.loadProduct(this.code);\r\n\t\t  });\r\n\t\tthis._activedRoute.params.subscribe(queryParams => {\r\n\t\t\tthis.code = queryParams[\"id\"];\r\n\t\t\tthis._productDetailService.loadProduct(this.code);\r\n\t\t})\r\n\t\t this.injector.get(ChannelService).channel$.subscribe(channel => {\r\n           this.showReviews = channel.showReviews;\r\n     });\r\n\t}\r\n\r\n  ngOnInit() {\r\n    this.product$.subscribe(product => {\r\n      if (product) {\r\n        this.updateMetaTags(product);\r\n      }\r\n    });\r\n  }\r\n\r\n  updateMetaTags(product: Product) {\r\n\tconst descripcionLimpia = he.decode(product.description || '').replace(/<[^>]*>/g, ' ').replace(/\\s+/g, ' ').trim();\r\n    const currentUrl =this._consts.url() +  this._location.path(true);  // `true` incluye el query string\r\n\r\n\r\n\r\n    this._meta.updateTag({ property: 'og:title', content: product.name || '' });\r\n    this._meta.updateTag({ property: 'og:description', content: descripcionLimpia || '' });\r\n    this._meta.updateTag({ property: 'og:image', content: this._consts.mediaImageUrl(Array.isArray(product.picturesdefault) ? product.picturesdefault[0] : product.picturesdefault) || '' });\r\n    this._meta.updateTag({ property: 'og:url', content: currentUrl });\r\n    this._meta.updateTag({ property: 'og:type', content: 'product' });\r\n  }\r\n  decodeHtml(html: string): string {\r\n    const txt = document.createElement('textarea');\r\n    txt.innerHTML = html;\r\n    return txt.value;\r\n    \r\n  }\r\n  sanitizedHtml(html: string): SafeHtml  {\r\n    const decodedHtml = this.decodeHtml(html);\r\n    return this._domSanitizer.bypassSecurityTrustHtml(decodedHtml);\r\n  }\r\n\r\n  addToCart() {\r\n    this.quantity() > 0 && this._productDetailService.addToCart(this.quantity());\r\n  }\r\n\r\n  plus(stock?: number, multipleQuantity?: number) {\r\n    if (multipleQuantity && multipleQuantity > 0) {\r\n      stock ? (this.quantity() < stock\r\n        ? this.quantity.update(value => value + multipleQuantity)\r\n        : this._toastService.show('out-of-stock-actually'))\r\n        : this.quantity.update(value => value + multipleQuantity)\r\n    } else {\r\n      stock ? (this.quantity() < stock\r\n        ? this.quantity.update(value => value + 1)\r\n        : this._toastService.show('out-of-stock-actually'))\r\n        : this.quantity.update(value => value + 1)\r\n    }\r\n  }\r\n\r\n  less(multipleQuantity?: any) {\r\n    if (multipleQuantity && multipleQuantity > 0) {\r\n      this.quantity() > multipleQuantity ? this.quantity.update(value => value - multipleQuantity) : null;\r\n    } else {\r\n      this.quantity() > 1 ? this.quantity.update(value => value - 1) : null;\r\n    }\r\n  }\r\n\r\n  checkStock(stock: number) {\r\n    if (this.quantity() >= stock)\r\n      this.quantity.set(stock);\r\n  }\r\n\r\n  public goToSection(section: string): void {\r\n    this.showFormContact = true;\r\n    setTimeout(() => {\r\n      const element = document.getElementById(section);\r\n      if (element) {\r\n        element.scrollIntoView({ behavior: 'smooth' });\r\n      }\r\n    }, 500);\r\n  }\r\n\r\n  resetForm = () => {\r\n    this.reset = !this.reset\r\n    this.success = true\r\n}\r\n}\r\n",""]}
@@ -48,11 +48,11 @@ export class ProductEcComponent {
48
48
  return this.product.saleprice && this.product.saleprice !== this.product.price;
49
49
  }
50
50
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: ProductEcComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
51
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.0", type: ProductEcComponent, isStandalone: true, selector: "app-product-ec", inputs: { product: "product", isProductBox: "isProductBox", isCollection: "isCollection" }, outputs: { loaded: "loaded" }, ngImport: i0, template: "<a [routerLink]=\"['/product', product.id]\" class=\"text-decoration-none\">\r\n <!-- Marca especial y descuento -->\r\n <!-- <div *ngIf=\"product.saleprice || (product.special_mark && product.special_mark !== null && product.special_mark !== undefined && product.special_mark.length >0)\"\r\n class=\"marcas\">\r\n <div *ecProductStock=\"product\" [ecProductMini]=\"product.special_mark\"></div>\r\n <ng-container *ngIf=\"shouldShowPrice\">\r\n <div *ecProductStock=\"product\" [ngClass]=\"{'tag-dsc float-right': product.saleprice}\"\r\n [ecProductOff]=\"product\">\r\n </div>\r\n </ng-container>\r\n </div> -->\r\n\r\n <!-- Imagen del producto -->\r\n <div class=\"foto\">\r\n @if(product.picturesdefault){\r\n @if (product.picturesdefault && product.picturesdefault.length > 1 ) {\r\n <img [src]=\"mediaUrl + product.picturesdefault[0]\" alt=\"Imagen principal\" class=\"w-100 pic01\" />\r\n <img [src]=\"mediaUrl + product.picturesdefault[1]\" alt=\"Imagen secundaria\" class=\"w-100 pic02\" />\r\n } @else {\r\n <img [src]=\"mediaUrl + product.picturesdefault[0]\" alt=\"Imagen principal\" class=\"w-100 pic01\" />\r\n }\r\n }\r\n </div>\r\n <!-- Precio -->\r\n \r\n\r\n <!-- Nombre del producto -->\r\n <h6 class=\"title\">{{ product.name | titlecase }}</h6>\r\n\r\n <div class=\"sku\" [innerHTML]=\"product.shortdetails\"></div>\r\n \r\n @if (shouldShowPrice) {\r\n <app-price-ec [price]=\"product.price\" [saleprice]=\"product.saleprice\" class=\"\" />\r\n }@else {\r\n <p class=\"noPrice\"></p>\r\n }\r\n\r\n <div class=\"fixBottom\">\r\n\r\n <!-- Bot\u00F3n de acciones -->\r\n <!-- <ng-container *ecProductStock=\"product; else noStock\"> -->\r\n <!-- Cuando no tiene marca especial o es de tipo 'standard' -->\r\n @if (!product.special_mark || product.special_mark.length === 0 || product.special_mark[0]?.type ===\r\n 'standard') {\r\n <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n <ng-container *ngIf=\"isCollection; else normalText\">\r\n <span> {{(\"buy\" | translate) | uppercase}} </span>\r\n </ng-container>\r\n <ng-template #normalText>\r\n {{(\"buy\" | translate) | uppercase}}\r\n </ng-template>\r\n </button>\r\n }\r\n <!-- Cuando tiene marca especial y el tipo no es 'standard' -->\r\n @if(product.special_mark?.[0]?.type !== 'standard'){\r\n @for (item of product.special_mark; track $index) {\r\n <!-- Caso 1: Agotado o Disponible muy pronto -->\r\n @if (item.type === 'out_of_stock' || item.type === 'coming_soon') {\r\n <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n @if(isCollection){\r\n <span>{{ item.name | uppercase }} </span>\r\n }@else {\r\n {{ item.name | uppercase }}\r\n }\r\n </button>}\r\n <!-- Caso 2: Contacto por WhatsApp -->\r\n @if (item.type === 'whatsapp_contact') {\r\n <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\"\r\n (click)=\"openWhatsApp(item.whatsappContact)\">\r\n @if(isCollection){\r\n <span>{{ item.name | uppercase }}</span>\r\n }@else {\r\n {{ item.name | uppercase }}\r\n }\r\n\r\n </button>\r\n }\r\n <!-- Caso 3: Solicitar m\u00E1s informaci\u00F3n -->\r\n @if (item.type === 'more_info') {\r\n <button *ngIf=\"\" class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n @if(isCollection){\r\n <span>{{ item.name | uppercase }}</span>\r\n }@else {\r\n {{ item.name | uppercase }}\r\n }\r\n </button>\r\n }\r\n\r\n }\r\n }\r\n\r\n <!-- </ng-container>\r\n <ng-template #noStock>\r\n <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n <ng-container *ngIf=\"isCollection; else normalText\">\r\n <span>{{(\"out-of-stock-short\" | translate) | uppercase}}</span>\r\n </ng-container>\r\n <ng-template #normalText>\r\n {{(\"out-of-stock-short\" | translate) | uppercase}}\r\n </ng-template>\r\n </button>\r\n </ng-template> -->\r\n </div>\r\n</a>", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i1.UpperCasePipe, name: "uppercase" }, { kind: "pipe", type: i1.TitleCasePipe, name: "titlecase" }, { kind: "component", type: PriceEcComponent, selector: "app-price-ec", inputs: ["price", "saleprice"] }, { kind: "directive", type: RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }] });
51
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.0", type: ProductEcComponent, isStandalone: true, selector: "app-product-ec", inputs: { product: "product", isProductBox: "isProductBox", isCollection: "isCollection" }, outputs: { loaded: "loaded" }, ngImport: i0, template: "<a [routerLink]=\"['/product', product.id]\" class=\"text-decoration-none producto\">\r\n <!-- Marca especial y descuento -->\r\n <!-- <div *ngIf=\"product.saleprice || (product.special_mark && product.special_mark !== null && product.special_mark !== undefined && product.special_mark.length >0)\"\r\n class=\"marcas\">\r\n <div *ecProductStock=\"product\" [ecProductMini]=\"product.special_mark\"></div>\r\n <ng-container *ngIf=\"shouldShowPrice\">\r\n <div *ecProductStock=\"product\" [ngClass]=\"{'tag-dsc float-right': product.saleprice}\"\r\n [ecProductOff]=\"product\">\r\n </div>\r\n </ng-container>\r\n </div> -->\r\n\r\n <!-- Imagen del producto -->\r\n <div class=\"foto\">\r\n @if(product.picturesdefault){\r\n @if (product.picturesdefault && product.picturesdefault.length > 1 ) {\r\n <img [src]=\"mediaUrl + product.picturesdefault[0]\" alt=\"Imagen principal\" class=\"w-100 pic01\" />\r\n <img [src]=\"mediaUrl + product.picturesdefault[1]\" alt=\"Imagen secundaria\" class=\"w-100 pic02\" />\r\n } @else {\r\n <img [src]=\"mediaUrl + product.picturesdefault[0]\" alt=\"Imagen principal\" class=\"w-100 pic01\" />\r\n }\r\n }\r\n </div>\r\n <!-- Precio -->\r\n \r\n\r\n <!-- Nombre del producto -->\r\n <h6 class=\"title\">{{ product.name | titlecase }}</h6>\r\n\r\n <div class=\"sku\" [innerHTML]=\"product.shortdetails\"></div>\r\n \r\n @if (shouldShowPrice) {\r\n <app-price-ec [price]=\"product.price\" [saleprice]=\"product.saleprice\" class=\"\" />\r\n }@else {\r\n <p class=\"noPrice\"></p>\r\n }\r\n\r\n <div class=\"fixBottom\">\r\n\r\n <!-- Bot\u00F3n de acciones -->\r\n <!-- <ng-container *ecProductStock=\"product; else noStock\"> -->\r\n <!-- Cuando no tiene marca especial o es de tipo 'standard' -->\r\n @if (!product.special_mark || product.special_mark.length === 0 || product.special_mark[0]?.type ===\r\n 'standard') {\r\n <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n <ng-container *ngIf=\"isCollection; else normalText\">\r\n <span> {{(\"buy\" | translate) | uppercase}} </span>\r\n </ng-container>\r\n <ng-template #normalText>\r\n {{(\"buy\" | translate) | uppercase}}\r\n </ng-template>\r\n </button>\r\n }\r\n <!-- Cuando tiene marca especial y el tipo no es 'standard' -->\r\n @if(product.special_mark?.[0]?.type !== 'standard'){\r\n @for (item of product.special_mark; track $index) {\r\n <!-- Caso 1: Agotado o Disponible muy pronto -->\r\n @if (item.type === 'out_of_stock' || item.type === 'coming_soon') {\r\n <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n @if(isCollection){\r\n <span>{{ item.name | uppercase }} </span>\r\n }@else {\r\n {{ item.name | uppercase }}\r\n }\r\n </button>}\r\n <!-- Caso 2: Contacto por WhatsApp -->\r\n @if (item.type === 'whatsapp_contact') {\r\n <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\"\r\n (click)=\"openWhatsApp(item.whatsappContact)\">\r\n @if(isCollection){\r\n <span>{{ item.name | uppercase }}</span>\r\n }@else {\r\n {{ item.name | uppercase }}\r\n }\r\n\r\n </button>\r\n }\r\n <!-- Caso 3: Solicitar m\u00E1s informaci\u00F3n -->\r\n @if (item.type === 'more_info') {\r\n <button *ngIf=\"\" class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n @if(isCollection){\r\n <span>{{ item.name | uppercase }}</span>\r\n }@else {\r\n {{ item.name | uppercase }}\r\n }\r\n </button>\r\n }\r\n\r\n }\r\n }\r\n\r\n <!-- </ng-container>\r\n <ng-template #noStock>\r\n <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n <ng-container *ngIf=\"isCollection; else normalText\">\r\n <span>{{(\"out-of-stock-short\" | translate) | uppercase}}</span>\r\n </ng-container>\r\n <ng-template #normalText>\r\n {{(\"out-of-stock-short\" | translate) | uppercase}}\r\n </ng-template>\r\n </button>\r\n </ng-template> -->\r\n </div>\r\n</a>", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i1.UpperCasePipe, name: "uppercase" }, { kind: "pipe", type: i1.TitleCasePipe, name: "titlecase" }, { kind: "component", type: PriceEcComponent, selector: "app-price-ec", inputs: ["price", "saleprice"] }, { kind: "directive", type: RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }] });
52
52
  }
53
53
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: ProductEcComponent, decorators: [{
54
54
  type: Component,
55
- args: [{ selector: 'app-product-ec', standalone: true, imports: [CommonModule, PriceEcComponent, RouterLink, TranslateModule], template: "<a [routerLink]=\"['/product', product.id]\" class=\"text-decoration-none\">\r\n <!-- Marca especial y descuento -->\r\n <!-- <div *ngIf=\"product.saleprice || (product.special_mark && product.special_mark !== null && product.special_mark !== undefined && product.special_mark.length >0)\"\r\n class=\"marcas\">\r\n <div *ecProductStock=\"product\" [ecProductMini]=\"product.special_mark\"></div>\r\n <ng-container *ngIf=\"shouldShowPrice\">\r\n <div *ecProductStock=\"product\" [ngClass]=\"{'tag-dsc float-right': product.saleprice}\"\r\n [ecProductOff]=\"product\">\r\n </div>\r\n </ng-container>\r\n </div> -->\r\n\r\n <!-- Imagen del producto -->\r\n <div class=\"foto\">\r\n @if(product.picturesdefault){\r\n @if (product.picturesdefault && product.picturesdefault.length > 1 ) {\r\n <img [src]=\"mediaUrl + product.picturesdefault[0]\" alt=\"Imagen principal\" class=\"w-100 pic01\" />\r\n <img [src]=\"mediaUrl + product.picturesdefault[1]\" alt=\"Imagen secundaria\" class=\"w-100 pic02\" />\r\n } @else {\r\n <img [src]=\"mediaUrl + product.picturesdefault[0]\" alt=\"Imagen principal\" class=\"w-100 pic01\" />\r\n }\r\n }\r\n </div>\r\n <!-- Precio -->\r\n \r\n\r\n <!-- Nombre del producto -->\r\n <h6 class=\"title\">{{ product.name | titlecase }}</h6>\r\n\r\n <div class=\"sku\" [innerHTML]=\"product.shortdetails\"></div>\r\n \r\n @if (shouldShowPrice) {\r\n <app-price-ec [price]=\"product.price\" [saleprice]=\"product.saleprice\" class=\"\" />\r\n }@else {\r\n <p class=\"noPrice\"></p>\r\n }\r\n\r\n <div class=\"fixBottom\">\r\n\r\n <!-- Bot\u00F3n de acciones -->\r\n <!-- <ng-container *ecProductStock=\"product; else noStock\"> -->\r\n <!-- Cuando no tiene marca especial o es de tipo 'standard' -->\r\n @if (!product.special_mark || product.special_mark.length === 0 || product.special_mark[0]?.type ===\r\n 'standard') {\r\n <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n <ng-container *ngIf=\"isCollection; else normalText\">\r\n <span> {{(\"buy\" | translate) | uppercase}} </span>\r\n </ng-container>\r\n <ng-template #normalText>\r\n {{(\"buy\" | translate) | uppercase}}\r\n </ng-template>\r\n </button>\r\n }\r\n <!-- Cuando tiene marca especial y el tipo no es 'standard' -->\r\n @if(product.special_mark?.[0]?.type !== 'standard'){\r\n @for (item of product.special_mark; track $index) {\r\n <!-- Caso 1: Agotado o Disponible muy pronto -->\r\n @if (item.type === 'out_of_stock' || item.type === 'coming_soon') {\r\n <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n @if(isCollection){\r\n <span>{{ item.name | uppercase }} </span>\r\n }@else {\r\n {{ item.name | uppercase }}\r\n }\r\n </button>}\r\n <!-- Caso 2: Contacto por WhatsApp -->\r\n @if (item.type === 'whatsapp_contact') {\r\n <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\"\r\n (click)=\"openWhatsApp(item.whatsappContact)\">\r\n @if(isCollection){\r\n <span>{{ item.name | uppercase }}</span>\r\n }@else {\r\n {{ item.name | uppercase }}\r\n }\r\n\r\n </button>\r\n }\r\n <!-- Caso 3: Solicitar m\u00E1s informaci\u00F3n -->\r\n @if (item.type === 'more_info') {\r\n <button *ngIf=\"\" class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n @if(isCollection){\r\n <span>{{ item.name | uppercase }}</span>\r\n }@else {\r\n {{ item.name | uppercase }}\r\n }\r\n </button>\r\n }\r\n\r\n }\r\n }\r\n\r\n <!-- </ng-container>\r\n <ng-template #noStock>\r\n <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n <ng-container *ngIf=\"isCollection; else normalText\">\r\n <span>{{(\"out-of-stock-short\" | translate) | uppercase}}</span>\r\n </ng-container>\r\n <ng-template #normalText>\r\n {{(\"out-of-stock-short\" | translate) | uppercase}}\r\n </ng-template>\r\n </button>\r\n </ng-template> -->\r\n </div>\r\n</a>" }]
55
+ args: [{ selector: 'app-product-ec', standalone: true, imports: [CommonModule, PriceEcComponent, RouterLink, TranslateModule], template: "<a [routerLink]=\"['/product', product.id]\" class=\"text-decoration-none producto\">\r\n <!-- Marca especial y descuento -->\r\n <!-- <div *ngIf=\"product.saleprice || (product.special_mark && product.special_mark !== null && product.special_mark !== undefined && product.special_mark.length >0)\"\r\n class=\"marcas\">\r\n <div *ecProductStock=\"product\" [ecProductMini]=\"product.special_mark\"></div>\r\n <ng-container *ngIf=\"shouldShowPrice\">\r\n <div *ecProductStock=\"product\" [ngClass]=\"{'tag-dsc float-right': product.saleprice}\"\r\n [ecProductOff]=\"product\">\r\n </div>\r\n </ng-container>\r\n </div> -->\r\n\r\n <!-- Imagen del producto -->\r\n <div class=\"foto\">\r\n @if(product.picturesdefault){\r\n @if (product.picturesdefault && product.picturesdefault.length > 1 ) {\r\n <img [src]=\"mediaUrl + product.picturesdefault[0]\" alt=\"Imagen principal\" class=\"w-100 pic01\" />\r\n <img [src]=\"mediaUrl + product.picturesdefault[1]\" alt=\"Imagen secundaria\" class=\"w-100 pic02\" />\r\n } @else {\r\n <img [src]=\"mediaUrl + product.picturesdefault[0]\" alt=\"Imagen principal\" class=\"w-100 pic01\" />\r\n }\r\n }\r\n </div>\r\n <!-- Precio -->\r\n \r\n\r\n <!-- Nombre del producto -->\r\n <h6 class=\"title\">{{ product.name | titlecase }}</h6>\r\n\r\n <div class=\"sku\" [innerHTML]=\"product.shortdetails\"></div>\r\n \r\n @if (shouldShowPrice) {\r\n <app-price-ec [price]=\"product.price\" [saleprice]=\"product.saleprice\" class=\"\" />\r\n }@else {\r\n <p class=\"noPrice\"></p>\r\n }\r\n\r\n <div class=\"fixBottom\">\r\n\r\n <!-- Bot\u00F3n de acciones -->\r\n <!-- <ng-container *ecProductStock=\"product; else noStock\"> -->\r\n <!-- Cuando no tiene marca especial o es de tipo 'standard' -->\r\n @if (!product.special_mark || product.special_mark.length === 0 || product.special_mark[0]?.type ===\r\n 'standard') {\r\n <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n <ng-container *ngIf=\"isCollection; else normalText\">\r\n <span> {{(\"buy\" | translate) | uppercase}} </span>\r\n </ng-container>\r\n <ng-template #normalText>\r\n {{(\"buy\" | translate) | uppercase}}\r\n </ng-template>\r\n </button>\r\n }\r\n <!-- Cuando tiene marca especial y el tipo no es 'standard' -->\r\n @if(product.special_mark?.[0]?.type !== 'standard'){\r\n @for (item of product.special_mark; track $index) {\r\n <!-- Caso 1: Agotado o Disponible muy pronto -->\r\n @if (item.type === 'out_of_stock' || item.type === 'coming_soon') {\r\n <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n @if(isCollection){\r\n <span>{{ item.name | uppercase }} </span>\r\n }@else {\r\n {{ item.name | uppercase }}\r\n }\r\n </button>}\r\n <!-- Caso 2: Contacto por WhatsApp -->\r\n @if (item.type === 'whatsapp_contact') {\r\n <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\"\r\n (click)=\"openWhatsApp(item.whatsappContact)\">\r\n @if(isCollection){\r\n <span>{{ item.name | uppercase }}</span>\r\n }@else {\r\n {{ item.name | uppercase }}\r\n }\r\n\r\n </button>\r\n }\r\n <!-- Caso 3: Solicitar m\u00E1s informaci\u00F3n -->\r\n @if (item.type === 'more_info') {\r\n <button *ngIf=\"\" class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n @if(isCollection){\r\n <span>{{ item.name | uppercase }}</span>\r\n }@else {\r\n {{ item.name | uppercase }}\r\n }\r\n </button>\r\n }\r\n\r\n }\r\n }\r\n\r\n <!-- </ng-container>\r\n <ng-template #noStock>\r\n <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n <ng-container *ngIf=\"isCollection; else normalText\">\r\n <span>{{(\"out-of-stock-short\" | translate) | uppercase}}</span>\r\n </ng-container>\r\n <ng-template #normalText>\r\n {{(\"out-of-stock-short\" | translate) | uppercase}}\r\n </ng-template>\r\n </button>\r\n </ng-template> -->\r\n </div>\r\n</a>" }]
56
56
  }], propDecorators: { product: [{
57
57
  type: Input,
58
58
  args: [{
@@ -65,4 +65,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
65
65
  }], isCollection: [{
66
66
  type: Input
67
67
  }] } });
68
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"product-ec.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/product-ec/product-ec.component.ts","../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/product-ec/product-ec.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;AAEvF,OAAO,EAAE,oBAAoB,EAAE,MAAM,iBAAiB,CAAC;AACvD,OAAO,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AACrD,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AACrD,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,gBAAgB,EAAE,MAAM,2CAA2C,CAAC;AAC7E,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;;;;AACtD;;;GAGG;AAQH,MAAM,OAAO,kBAAkB;IAC9B;;OAEG;IAIH,OAAO,CAAW;IAClB;;OAEG;IACM,YAAY,GAAW,IAAI,CAAC;IACrC;;OAEG;IACO,MAAM,GAAG,IAAI,YAAY,EAAU,CAAC;IAErC,YAAY,GAAY,KAAK,CAAC;IAEvC,QAAQ;QACN,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;IACpC,CAAC;IACO,MAAM,GAAwB,MAAM,CAAC,oBAAoB,CAAC,CAAA;IAC1D,gBAAgB,GAAqB,MAAM,CAAC,gBAAgB,CAAC,CAAA;IAC7D,MAAM,GAAU,MAAM,CAAC,MAAM,CAAC,CAAA;IACtC;;OAEG;IACI,QAAQ,GAAU,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAA;IAC/C,YAAY,CAAC,GAAW;QACjB,IAAI,GAAG,EAAE,CAAC;YACN,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;QAC/B,CAAC;IACL,CAAC;IAED,IAAI,eAAe;QACf,OAAO,CAAC,IAAI,CAAC,OAAO,EAAE,YAAY,IAAI,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,MAAM,KAAK,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC,EAAE,SAAS,CAAC;IAC5H,CAAC;IAED,IAAI,WAAW;QACX,OAAO,IAAI,CAAC,OAAO,CAAC,SAAS,IAAI,IAAI,CAAC,OAAO,CAAC,SAAS,KAAK,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC;IACnF,CAAC;uGAzCQ,kBAAkB;2FAAlB,kBAAkB,qMCnB/B,kkJAuGI,yDDxFO,YAAY,2VAAE,gBAAgB,yFAAE,UAAU,mOAAG,eAAe;;2FAI1D,kBAAkB;kBAP9B,SAAS;+BACC,gBAAgB,cACd,IAAI,WACP,CAAC,YAAY,EAAE,gBAAgB,EAAE,UAAU,EAAG,eAAe,CAAC;8BAWvE,OAAO;sBAHN,KAAK;uBAAC;wBACN,QAAQ,EAAE,IAAI;qBACd;gBAKQ,YAAY;sBAApB,KAAK;gBAII,MAAM;sBAAf,MAAM;gBAEE,YAAY;sBAApB,KAAK","sourcesContent":["import { Component, EventEmitter, inject, Input, OnInit, Output } from '@angular/core';\r\nimport { Product } from '../../interfaces';\r\nimport { CoreConstantsService } from '../../constants';\r\nimport { AnalyticsService } from '../../ec-services';\r\nimport { Router, RouterLink } from '@angular/router';\r\nimport { CommonModule } from '@angular/common';\r\nimport { PriceEcComponent } from \"../widgets-ec/price-ec/price-ec.component\";\r\nimport { TranslateModule } from '@ngx-translate/core';\r\n/**\r\n * Componente que se encarga de manejar un producto.\r\n * @class ProductEcComponent\r\n */\r\n@Component({\r\n\tselector: 'app-product-ec',\r\n\tstandalone: true,\r\n\timports: [CommonModule, PriceEcComponent, RouterLink , TranslateModule],\r\n\ttemplateUrl: './product-ec.component.html',\r\n\tstyleUrl: './product-ec.component.scss'\r\n})\r\nexport class ProductEcComponent implements OnInit {\r\n\t/**\r\n\t * Datos del producto.\r\n\t */\r\n\t@Input({\r\n\t\trequired: true\r\n\t})\r\n\tproduct!: Product;\r\n\t/**\r\n\t * Se usa para saber si el producto es de tipo Box o no y definir la vista adecuada.\r\n\t */\r\n\t@Input() isProductBox:boolean = true;\r\n\t/**\r\n\t * Constantes del core\r\n\t */\r\n\t@Output() loaded = new EventEmitter<number>();\r\n\r\n\t@Input() isCollection: boolean = false;\r\n\r\n\tngOnInit() {\r\n\t  this.loaded.emit(this.product.id);\r\n\t}\r\n\tprivate consts:CoreConstantsService = inject(CoreConstantsService)\r\n\tprivate analyticsService: AnalyticsService = inject(AnalyticsService)\r\n\tprivate router:Router = inject(Router)\r\n\t/**\r\n\t * URL para las imagenes del producto.\r\n\t */\r\n\tpublic mediaUrl:string = this.consts.mediaUrl()\r\n\topenWhatsApp(url: string): void {\r\n        if (url) {\r\n            window.open(url, '_blank');\r\n        }\r\n    }\r\n\r\n    get shouldShowPrice(): boolean {\r\n        return !this.product?.special_mark || this.product.special_mark.length === 0 || this.product.special_mark[0]?.showPrice;\r\n    }\r\n\r\n    get hasDiscount(): boolean {\r\n        return this.product.saleprice && this.product.saleprice !== this.product.price;\r\n    }\r\n}\r\n","<a [routerLink]=\"['/product', product.id]\" class=\"text-decoration-none\">\r\n    <!-- Marca especial y descuento -->\r\n    <!-- <div *ngIf=\"product.saleprice || (product.special_mark && product.special_mark !== null && product.special_mark !== undefined && product.special_mark.length >0)\"\r\n        class=\"marcas\">\r\n        <div *ecProductStock=\"product\" [ecProductMini]=\"product.special_mark\"></div>\r\n        <ng-container *ngIf=\"shouldShowPrice\">\r\n            <div *ecProductStock=\"product\" [ngClass]=\"{'tag-dsc float-right': product.saleprice}\"\r\n                [ecProductOff]=\"product\">\r\n            </div>\r\n        </ng-container>\r\n    </div> -->\r\n\r\n    <!-- Imagen del producto -->\r\n    <div class=\"foto\">\r\n        @if(product.picturesdefault){\r\n        @if (product.picturesdefault && product.picturesdefault.length > 1 ) {\r\n        <img [src]=\"mediaUrl + product.picturesdefault[0]\" alt=\"Imagen principal\" class=\"w-100 pic01\" />\r\n        <img [src]=\"mediaUrl + product.picturesdefault[1]\" alt=\"Imagen secundaria\" class=\"w-100 pic02\" />\r\n        } @else {\r\n        <img [src]=\"mediaUrl + product.picturesdefault[0]\" alt=\"Imagen principal\" class=\"w-100 pic01\" />\r\n        }\r\n        }\r\n    </div>\r\n    <!-- Precio -->\r\n    \r\n\r\n    <!-- Nombre del producto -->\r\n    <h6 class=\"title\">{{ product.name | titlecase }}</h6>\r\n\r\n    <div class=\"sku\" [innerHTML]=\"product.shortdetails\"></div>\r\n    \r\n    @if (shouldShowPrice) {\r\n    <app-price-ec [price]=\"product.price\" [saleprice]=\"product.saleprice\" class=\"\" />\r\n    }@else {\r\n    <p class=\"noPrice\"></p>\r\n    }\r\n\r\n    <div class=\"fixBottom\">\r\n\r\n        <!-- Botón de acciones -->\r\n         <!-- <ng-container *ecProductStock=\"product; else noStock\"> -->\r\n        <!-- Cuando no tiene marca especial o es de tipo 'standard' -->\r\n        @if (!product.special_mark || product.special_mark.length === 0 || product.special_mark[0]?.type ===\r\n        'standard') {\r\n        <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n            <ng-container *ngIf=\"isCollection; else normalText\">\r\n                <span> {{(\"buy\" | translate) | uppercase}} </span>\r\n            </ng-container>\r\n            <ng-template #normalText>\r\n                {{(\"buy\" | translate) | uppercase}}\r\n            </ng-template>\r\n        </button>\r\n        }\r\n        <!-- Cuando tiene marca especial y el tipo no es 'standard' -->\r\n        @if(product.special_mark?.[0]?.type !== 'standard'){\r\n        @for (item of product.special_mark; track $index) {\r\n        <!-- Caso 1: Agotado o Disponible muy pronto -->\r\n        @if (item.type === 'out_of_stock' || item.type === 'coming_soon') {\r\n        <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n            @if(isCollection){\r\n            <span>{{ item.name | uppercase }} </span>\r\n            }@else {\r\n            {{ item.name | uppercase }}\r\n            }\r\n        </button>}\r\n        <!-- Caso 2: Contacto por WhatsApp -->\r\n        @if (item.type === 'whatsapp_contact') {\r\n        <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\"\r\n            (click)=\"openWhatsApp(item.whatsappContact)\">\r\n            @if(isCollection){\r\n            <span>{{ item.name | uppercase }}</span>\r\n            }@else {\r\n            {{ item.name | uppercase }}\r\n            }\r\n\r\n        </button>\r\n        }\r\n        <!-- Caso 3: Solicitar más información -->\r\n        @if (item.type === 'more_info') {\r\n        <button *ngIf=\"\" class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n            @if(isCollection){\r\n            <span>{{ item.name | uppercase }}</span>\r\n            }@else {\r\n            {{ item.name | uppercase }}\r\n            }\r\n        </button>\r\n        }\r\n\r\n        }\r\n        }\r\n\r\n        <!-- </ng-container>\r\n        <ng-template #noStock>\r\n            <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n                <ng-container *ngIf=\"isCollection; else normalText\">\r\n                    <span>{{(\"out-of-stock-short\" | translate) | uppercase}}</span>\r\n                </ng-container>\r\n                <ng-template #normalText>\r\n                    {{(\"out-of-stock-short\" | translate) | uppercase}}\r\n                </ng-template>\r\n            </button>\r\n        </ng-template> -->\r\n    </div>\r\n</a>"]}
68
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"product-ec.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/product-ec/product-ec.component.ts","../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/product-ec/product-ec.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;AAEvF,OAAO,EAAE,oBAAoB,EAAE,MAAM,iBAAiB,CAAC;AACvD,OAAO,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AACrD,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AACrD,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,gBAAgB,EAAE,MAAM,2CAA2C,CAAC;AAC7E,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;;;;AACtD;;;GAGG;AAQH,MAAM,OAAO,kBAAkB;IAC9B;;OAEG;IAIH,OAAO,CAAW;IAClB;;OAEG;IACM,YAAY,GAAW,IAAI,CAAC;IACrC;;OAEG;IACO,MAAM,GAAG,IAAI,YAAY,EAAU,CAAC;IAErC,YAAY,GAAY,KAAK,CAAC;IAEvC,QAAQ;QACN,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;IACpC,CAAC;IACO,MAAM,GAAwB,MAAM,CAAC,oBAAoB,CAAC,CAAA;IAC1D,gBAAgB,GAAqB,MAAM,CAAC,gBAAgB,CAAC,CAAA;IAC7D,MAAM,GAAU,MAAM,CAAC,MAAM,CAAC,CAAA;IACtC;;OAEG;IACI,QAAQ,GAAU,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAA;IAC/C,YAAY,CAAC,GAAW;QACjB,IAAI,GAAG,EAAE,CAAC;YACN,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;QAC/B,CAAC;IACL,CAAC;IAED,IAAI,eAAe;QACf,OAAO,CAAC,IAAI,CAAC,OAAO,EAAE,YAAY,IAAI,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,MAAM,KAAK,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC,EAAE,SAAS,CAAC;IAC5H,CAAC;IAED,IAAI,WAAW;QACX,OAAO,IAAI,CAAC,OAAO,CAAC,SAAS,IAAI,IAAI,CAAC,OAAO,CAAC,SAAS,KAAK,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC;IACnF,CAAC;uGAzCQ,kBAAkB;2FAAlB,kBAAkB,qMCnB/B,2kJAuGI,yDDxFO,YAAY,2VAAE,gBAAgB,yFAAE,UAAU,mOAAG,eAAe;;2FAI1D,kBAAkB;kBAP9B,SAAS;+BACC,gBAAgB,cACd,IAAI,WACP,CAAC,YAAY,EAAE,gBAAgB,EAAE,UAAU,EAAG,eAAe,CAAC;8BAWvE,OAAO;sBAHN,KAAK;uBAAC;wBACN,QAAQ,EAAE,IAAI;qBACd;gBAKQ,YAAY;sBAApB,KAAK;gBAII,MAAM;sBAAf,MAAM;gBAEE,YAAY;sBAApB,KAAK","sourcesContent":["import { Component, EventEmitter, inject, Input, OnInit, Output } from '@angular/core';\r\nimport { Product } from '../../interfaces';\r\nimport { CoreConstantsService } from '../../constants';\r\nimport { AnalyticsService } from '../../ec-services';\r\nimport { Router, RouterLink } from '@angular/router';\r\nimport { CommonModule } from '@angular/common';\r\nimport { PriceEcComponent } from \"../widgets-ec/price-ec/price-ec.component\";\r\nimport { TranslateModule } from '@ngx-translate/core';\r\n/**\r\n * Componente que se encarga de manejar un producto.\r\n * @class ProductEcComponent\r\n */\r\n@Component({\r\n\tselector: 'app-product-ec',\r\n\tstandalone: true,\r\n\timports: [CommonModule, PriceEcComponent, RouterLink , TranslateModule],\r\n\ttemplateUrl: './product-ec.component.html',\r\n\tstyleUrl: './product-ec.component.scss'\r\n})\r\nexport class ProductEcComponent implements OnInit {\r\n\t/**\r\n\t * Datos del producto.\r\n\t */\r\n\t@Input({\r\n\t\trequired: true\r\n\t})\r\n\tproduct!: Product;\r\n\t/**\r\n\t * Se usa para saber si el producto es de tipo Box o no y definir la vista adecuada.\r\n\t */\r\n\t@Input() isProductBox:boolean = true;\r\n\t/**\r\n\t * Constantes del core\r\n\t */\r\n\t@Output() loaded = new EventEmitter<number>();\r\n\r\n\t@Input() isCollection: boolean = false;\r\n\r\n\tngOnInit() {\r\n\t  this.loaded.emit(this.product.id);\r\n\t}\r\n\tprivate consts:CoreConstantsService = inject(CoreConstantsService)\r\n\tprivate analyticsService: AnalyticsService = inject(AnalyticsService)\r\n\tprivate router:Router = inject(Router)\r\n\t/**\r\n\t * URL para las imagenes del producto.\r\n\t */\r\n\tpublic mediaUrl:string = this.consts.mediaUrl()\r\n\topenWhatsApp(url: string): void {\r\n        if (url) {\r\n            window.open(url, '_blank');\r\n        }\r\n    }\r\n\r\n    get shouldShowPrice(): boolean {\r\n        return !this.product?.special_mark || this.product.special_mark.length === 0 || this.product.special_mark[0]?.showPrice;\r\n    }\r\n\r\n    get hasDiscount(): boolean {\r\n        return this.product.saleprice && this.product.saleprice !== this.product.price;\r\n    }\r\n}\r\n","<a [routerLink]=\"['/product', product.id]\" class=\"text-decoration-none producto\">\r\n    <!-- Marca especial y descuento -->\r\n    <!-- <div *ngIf=\"product.saleprice || (product.special_mark && product.special_mark !== null && product.special_mark !== undefined && product.special_mark.length >0)\"\r\n        class=\"marcas\">\r\n        <div *ecProductStock=\"product\" [ecProductMini]=\"product.special_mark\"></div>\r\n        <ng-container *ngIf=\"shouldShowPrice\">\r\n            <div *ecProductStock=\"product\" [ngClass]=\"{'tag-dsc float-right': product.saleprice}\"\r\n                [ecProductOff]=\"product\">\r\n            </div>\r\n        </ng-container>\r\n    </div> -->\r\n\r\n    <!-- Imagen del producto -->\r\n    <div class=\"foto\">\r\n        @if(product.picturesdefault){\r\n        @if (product.picturesdefault && product.picturesdefault.length > 1 ) {\r\n        <img [src]=\"mediaUrl + product.picturesdefault[0]\" alt=\"Imagen principal\" class=\"w-100 pic01\" />\r\n        <img [src]=\"mediaUrl + product.picturesdefault[1]\" alt=\"Imagen secundaria\" class=\"w-100 pic02\" />\r\n        } @else {\r\n        <img [src]=\"mediaUrl + product.picturesdefault[0]\" alt=\"Imagen principal\" class=\"w-100 pic01\" />\r\n        }\r\n        }\r\n    </div>\r\n    <!-- Precio -->\r\n    \r\n\r\n    <!-- Nombre del producto -->\r\n    <h6 class=\"title\">{{ product.name | titlecase }}</h6>\r\n\r\n    <div class=\"sku\" [innerHTML]=\"product.shortdetails\"></div>\r\n    \r\n    @if (shouldShowPrice) {\r\n    <app-price-ec [price]=\"product.price\" [saleprice]=\"product.saleprice\" class=\"\" />\r\n    }@else {\r\n    <p class=\"noPrice\"></p>\r\n    }\r\n\r\n    <div class=\"fixBottom\">\r\n\r\n        <!-- Botón de acciones -->\r\n         <!-- <ng-container *ecProductStock=\"product; else noStock\"> -->\r\n        <!-- Cuando no tiene marca especial o es de tipo 'standard' -->\r\n        @if (!product.special_mark || product.special_mark.length === 0 || product.special_mark[0]?.type ===\r\n        'standard') {\r\n        <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n            <ng-container *ngIf=\"isCollection; else normalText\">\r\n                <span> {{(\"buy\" | translate) | uppercase}} </span>\r\n            </ng-container>\r\n            <ng-template #normalText>\r\n                {{(\"buy\" | translate) | uppercase}}\r\n            </ng-template>\r\n        </button>\r\n        }\r\n        <!-- Cuando tiene marca especial y el tipo no es 'standard' -->\r\n        @if(product.special_mark?.[0]?.type !== 'standard'){\r\n        @for (item of product.special_mark; track $index) {\r\n        <!-- Caso 1: Agotado o Disponible muy pronto -->\r\n        @if (item.type === 'out_of_stock' || item.type === 'coming_soon') {\r\n        <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n            @if(isCollection){\r\n            <span>{{ item.name | uppercase }} </span>\r\n            }@else {\r\n            {{ item.name | uppercase }}\r\n            }\r\n        </button>}\r\n        <!-- Caso 2: Contacto por WhatsApp -->\r\n        @if (item.type === 'whatsapp_contact') {\r\n        <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\"\r\n            (click)=\"openWhatsApp(item.whatsappContact)\">\r\n            @if(isCollection){\r\n            <span>{{ item.name | uppercase }}</span>\r\n            }@else {\r\n            {{ item.name | uppercase }}\r\n            }\r\n\r\n        </button>\r\n        }\r\n        <!-- Caso 3: Solicitar más información -->\r\n        @if (item.type === 'more_info') {\r\n        <button *ngIf=\"\" class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n            @if(isCollection){\r\n            <span>{{ item.name | uppercase }}</span>\r\n            }@else {\r\n            {{ item.name | uppercase }}\r\n            }\r\n        </button>\r\n        }\r\n\r\n        }\r\n        }\r\n\r\n        <!-- </ng-container>\r\n        <ng-template #noStock>\r\n            <button class=\"btn\" [ngClass]=\"isCollection ? 'px-2 w-100 d-sm-block' : 'py-2 px-4'\">\r\n                <ng-container *ngIf=\"isCollection; else normalText\">\r\n                    <span>{{(\"out-of-stock-short\" | translate) | uppercase}}</span>\r\n                </ng-container>\r\n                <ng-template #normalText>\r\n                    {{(\"out-of-stock-short\" | translate) | uppercase}}\r\n                </ng-template>\r\n            </button>\r\n        </ng-template> -->\r\n    </div>\r\n</a>"]}
@@ -51,10 +51,10 @@ export class SidebarEcComponent {
51
51
  throw new Error('Method not implemented.');
52
52
  }
53
53
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: SidebarEcComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
54
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.0", type: SidebarEcComponent, isStandalone: true, selector: "app-sidebar-ec", ngImport: i0, template: "<div class=\"nav my-4 mx-0 position-relative text-center shadow-sm border-bottom d-flex justify-content-center\">\r\n <h2 class=\"row text-center\">Mi carrito</h2>\r\n <div class=\" me-3 closeCart position-absolute end-0\" data-bs-dismiss=\"offcanvas\" aria-label=\"Close\">\r\n <i class=\"fa fa-times-circle fs-5\" aria-hidden=\"true\"></i>\r\n </div>\r\n</div>\r\n\r\n\r\n@if(cartItems$ | async; as items){\r\n @if(items.length > 0){\r\n <!-- PRODUCTO -->\r\n <div class=\"d-flex flex-column mb-4 items\">\r\n @for(item of items; track $index; let i = $index){\r\n <div class=\"productoCarrito mt-1 mb-2 w-100\">\r\n <app-cart-item-ec [inSidebar]=\"true\" [item]=\"item\"></app-cart-item-ec>\r\n </div>\r\n }\r\n </div>\r\n <div class=\"d-flex mx-4 justify-content-between border-top \">\r\n <p>Subtotal</p>\r\n <p class=\"fw-700\">{{ (subTotalAmount$ | async) | ecCurrencySymbol}}</p>\r\n </div>\r\n <div class=\"mx-4 bordeBot\">\r\n <app-coupon-ec></app-coupon-ec>\r\n </div>\r\n <div class=\"d-flex mx-4 justify-content-between bordeBot2\">\r\n <p>Descuentos:</p>\r\n <p>{{ (totalPromotionAmount$ | async) |ecCurrencySymbol }}</p>\r\n </div>\r\n\r\n <div class=\"d-flex mx-4 justify-content-between bordeBot2\">\r\n <!-- @if(this._cartService.cart.source.value.couponCode){\r\n <a class=\"quitar-cupon text-dark\" role=\"button\"\r\n (click)=\"removeCoupon()\">(Quitar cup\u00F3n)</a>\r\n } -->\r\n </div>\r\n <div class=\"d-flex mx-4 justify-content-between mb-3 mt-2\">\r\n <p class=\"fw-bold h5\">TOTAL</p>\r\n <p class=\"fw-bold h5\">{{(totalAmount$ | async) | ecCurrencySymbol}}</p>\r\n </div>\r\n <div class=\"d-flex flex-column mx-4 justify-content-between mb-3\" data-bs-dismiss=\"offcanvas\" aria-label=\"Close\">\r\n <a [routerLink]=\"['/cart']\" class=\"btn btn-primary btn-block w-100 btnComprar mb-2 mt-3 \">CONFIRMAR PEDIDO</a>\r\n <a [routerLink]=\"['/collection']\" class=\"btn btn-secondary btn-block w-100 btnSeguir\">SEGUIR COMPRANDO</a>\r\n </div>\r\n\r\n\r\n } @else {\r\n <div class=\"container-lg px-lg-0 px-md-4 my-5\">\r\n <div class=\"row\">\r\n <div class=\"col-12\">\r\n <h5 class=\"text-center mb-sm-4 text-uppercase\"> \u00B7 Su carrito se\r\n encuentra vac\u00EDo \u00B7 </h5>\r\n </div>\r\n </div>\r\n </div>\r\n }\r\n}", styles: [".items{max-height:35vh;overflow-y:scroll;overflow-x:hidden}\n"], dependencies: [{ kind: "directive", type: RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "component", type: CouponEcComponent, selector: "app-coupon-ec" }, { kind: "component", type: CartItemEcComponent, selector: "app-cart-item-ec", inputs: ["item", "inSidebar"] }, { kind: "pipe", type: EcCurrencySymbolPipe, name: "ecCurrencySymbol" }] });
54
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.0", type: SidebarEcComponent, isStandalone: true, selector: "app-sidebar-ec", ngImport: i0, template: "<div class=\"nav my-4 mx-0 position-relative text-center shadow-sm border-bottom d-flex justify-content-center\">\r\n <h2 class=\"row text-center\">Mi carrito</h2>\r\n <div class=\" me-3 closeCart position-absolute end-0\" data-bs-dismiss=\"offcanvas\" aria-label=\"Close\">\r\n <i class=\"fa fa-times-circle fs-5\" aria-hidden=\"true\"></i>\r\n </div>\r\n</div>\r\n\r\n\r\n@if(cartItems$ | async; as items){\r\n @if(items.length > 0){\r\n <!-- PRODUCTO -->\r\n <div class=\"d-flex flex-column mb-4 items\">\r\n @for(item of items; track $index; let i = $index){\r\n <div class=\"productoCarrito mt-1 mb-2 w-100\">\r\n <app-cart-item-ec [inSidebar]=\"true\" [item]=\"item\"></app-cart-item-ec>\r\n </div>\r\n }\r\n </div>\r\n <div class=\"d-flex mx-4 justify-content-between border-top \">\r\n <p>Subtotal</p>\r\n <p class=\"fw-700\">{{ (subTotalAmount$ | async) | ecCurrencySymbol}}</p>\r\n </div>\r\n <div class=\"mx-4 bordeBot\">\r\n <app-coupon-ec></app-coupon-ec>\r\n </div>\r\n <div class=\"d-flex mx-4 justify-content-between bordeBot2\">\r\n <p>Descuentos:</p>\r\n <p>{{ (totalPromotionAmount$ | async) |ecCurrencySymbol }}</p>\r\n </div>\r\n\r\n <div class=\"d-flex mx-4 justify-content-between bordeBot2\">\r\n <!-- @if(this._cartService.cart.source.value.couponCode){\r\n <a class=\"quitar-cupon text-dark\" role=\"button\"\r\n (click)=\"removeCoupon()\">(Quitar cup\u00F3n)</a>\r\n } -->\r\n </div>\r\n <div class=\"d-flex mx-4 justify-content-between mb-3 mt-2\">\r\n <p class=\"fw-bold h5\">TOTAL</p>\r\n <p class=\"fw-bold h5\">{{(totalAmount$ | async) | ecCurrencySymbol}}</p>\r\n </div>\r\n <div class=\"d-flex flex-column mx-4 justify-content-between mb-3\" data-bs-dismiss=\"offcanvas\" aria-label=\"Close\">\r\n <a [routerLink]=\"['/cart']\" class=\"btn btnPedido mb-2\">FINALIZAR PEDIDO</a>\r\n <a [routerLink]=\"['/collection']\" class=\"btn btnSeguir mb-3\">SEGUIR COMPRANDO</a>\r\n </div>\r\n\r\n\r\n } @else {\r\n <div class=\"container-lg px-lg-0 px-md-4 my-5\">\r\n <div class=\"row\">\r\n <div class=\"col-12\">\r\n <h5 class=\"text-center mb-sm-4 text-uppercase\"> \u00B7 Su carrito se\r\n encuentra vac\u00EDo \u00B7 </h5>\r\n </div>\r\n </div>\r\n </div>\r\n }\r\n}", styles: [""], dependencies: [{ kind: "directive", type: RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "component", type: CouponEcComponent, selector: "app-coupon-ec" }, { kind: "component", type: CartItemEcComponent, selector: "app-cart-item-ec", inputs: ["item", "inSidebar"] }, { kind: "pipe", type: EcCurrencySymbolPipe, name: "ecCurrencySymbol" }] });
55
55
  }
56
56
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: SidebarEcComponent, decorators: [{
57
57
  type: Component,
58
- args: [{ selector: 'app-sidebar-ec', standalone: true, imports: [RouterLink, AsyncPipe, CouponEcComponent, CartItemEcComponent, EcCurrencySymbolPipe], template: "<div class=\"nav my-4 mx-0 position-relative text-center shadow-sm border-bottom d-flex justify-content-center\">\r\n <h2 class=\"row text-center\">Mi carrito</h2>\r\n <div class=\" me-3 closeCart position-absolute end-0\" data-bs-dismiss=\"offcanvas\" aria-label=\"Close\">\r\n <i class=\"fa fa-times-circle fs-5\" aria-hidden=\"true\"></i>\r\n </div>\r\n</div>\r\n\r\n\r\n@if(cartItems$ | async; as items){\r\n @if(items.length > 0){\r\n <!-- PRODUCTO -->\r\n <div class=\"d-flex flex-column mb-4 items\">\r\n @for(item of items; track $index; let i = $index){\r\n <div class=\"productoCarrito mt-1 mb-2 w-100\">\r\n <app-cart-item-ec [inSidebar]=\"true\" [item]=\"item\"></app-cart-item-ec>\r\n </div>\r\n }\r\n </div>\r\n <div class=\"d-flex mx-4 justify-content-between border-top \">\r\n <p>Subtotal</p>\r\n <p class=\"fw-700\">{{ (subTotalAmount$ | async) | ecCurrencySymbol}}</p>\r\n </div>\r\n <div class=\"mx-4 bordeBot\">\r\n <app-coupon-ec></app-coupon-ec>\r\n </div>\r\n <div class=\"d-flex mx-4 justify-content-between bordeBot2\">\r\n <p>Descuentos:</p>\r\n <p>{{ (totalPromotionAmount$ | async) |ecCurrencySymbol }}</p>\r\n </div>\r\n\r\n <div class=\"d-flex mx-4 justify-content-between bordeBot2\">\r\n <!-- @if(this._cartService.cart.source.value.couponCode){\r\n <a class=\"quitar-cupon text-dark\" role=\"button\"\r\n (click)=\"removeCoupon()\">(Quitar cup\u00F3n)</a>\r\n } -->\r\n </div>\r\n <div class=\"d-flex mx-4 justify-content-between mb-3 mt-2\">\r\n <p class=\"fw-bold h5\">TOTAL</p>\r\n <p class=\"fw-bold h5\">{{(totalAmount$ | async) | ecCurrencySymbol}}</p>\r\n </div>\r\n <div class=\"d-flex flex-column mx-4 justify-content-between mb-3\" data-bs-dismiss=\"offcanvas\" aria-label=\"Close\">\r\n <a [routerLink]=\"['/cart']\" class=\"btn btn-primary btn-block w-100 btnComprar mb-2 mt-3 \">CONFIRMAR PEDIDO</a>\r\n <a [routerLink]=\"['/collection']\" class=\"btn btn-secondary btn-block w-100 btnSeguir\">SEGUIR COMPRANDO</a>\r\n </div>\r\n\r\n\r\n } @else {\r\n <div class=\"container-lg px-lg-0 px-md-4 my-5\">\r\n <div class=\"row\">\r\n <div class=\"col-12\">\r\n <h5 class=\"text-center mb-sm-4 text-uppercase\"> \u00B7 Su carrito se\r\n encuentra vac\u00EDo \u00B7 </h5>\r\n </div>\r\n </div>\r\n </div>\r\n }\r\n}", styles: [".items{max-height:35vh;overflow-y:scroll;overflow-x:hidden}\n"] }]
58
+ args: [{ selector: 'app-sidebar-ec', standalone: true, imports: [RouterLink, AsyncPipe, CouponEcComponent, CartItemEcComponent, EcCurrencySymbolPipe], template: "<div class=\"nav my-4 mx-0 position-relative text-center shadow-sm border-bottom d-flex justify-content-center\">\r\n <h2 class=\"row text-center\">Mi carrito</h2>\r\n <div class=\" me-3 closeCart position-absolute end-0\" data-bs-dismiss=\"offcanvas\" aria-label=\"Close\">\r\n <i class=\"fa fa-times-circle fs-5\" aria-hidden=\"true\"></i>\r\n </div>\r\n</div>\r\n\r\n\r\n@if(cartItems$ | async; as items){\r\n @if(items.length > 0){\r\n <!-- PRODUCTO -->\r\n <div class=\"d-flex flex-column mb-4 items\">\r\n @for(item of items; track $index; let i = $index){\r\n <div class=\"productoCarrito mt-1 mb-2 w-100\">\r\n <app-cart-item-ec [inSidebar]=\"true\" [item]=\"item\"></app-cart-item-ec>\r\n </div>\r\n }\r\n </div>\r\n <div class=\"d-flex mx-4 justify-content-between border-top \">\r\n <p>Subtotal</p>\r\n <p class=\"fw-700\">{{ (subTotalAmount$ | async) | ecCurrencySymbol}}</p>\r\n </div>\r\n <div class=\"mx-4 bordeBot\">\r\n <app-coupon-ec></app-coupon-ec>\r\n </div>\r\n <div class=\"d-flex mx-4 justify-content-between bordeBot2\">\r\n <p>Descuentos:</p>\r\n <p>{{ (totalPromotionAmount$ | async) |ecCurrencySymbol }}</p>\r\n </div>\r\n\r\n <div class=\"d-flex mx-4 justify-content-between bordeBot2\">\r\n <!-- @if(this._cartService.cart.source.value.couponCode){\r\n <a class=\"quitar-cupon text-dark\" role=\"button\"\r\n (click)=\"removeCoupon()\">(Quitar cup\u00F3n)</a>\r\n } -->\r\n </div>\r\n <div class=\"d-flex mx-4 justify-content-between mb-3 mt-2\">\r\n <p class=\"fw-bold h5\">TOTAL</p>\r\n <p class=\"fw-bold h5\">{{(totalAmount$ | async) | ecCurrencySymbol}}</p>\r\n </div>\r\n <div class=\"d-flex flex-column mx-4 justify-content-between mb-3\" data-bs-dismiss=\"offcanvas\" aria-label=\"Close\">\r\n <a [routerLink]=\"['/cart']\" class=\"btn btnPedido mb-2\">FINALIZAR PEDIDO</a>\r\n <a [routerLink]=\"['/collection']\" class=\"btn btnSeguir mb-3\">SEGUIR COMPRANDO</a>\r\n </div>\r\n\r\n\r\n } @else {\r\n <div class=\"container-lg px-lg-0 px-md-4 my-5\">\r\n <div class=\"row\">\r\n <div class=\"col-12\">\r\n <h5 class=\"text-center mb-sm-4 text-uppercase\"> \u00B7 Su carrito se\r\n encuentra vac\u00EDo \u00B7 </h5>\r\n </div>\r\n </div>\r\n </div>\r\n }\r\n}" }]
59
59
  }] });
60
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sidebar-ec.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/sidebar-ec/sidebar-ec.component.ts","../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/sidebar-ec/sidebar-ec.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, inject } from '@angular/core';\r\nimport { User } from '../../classes';\r\nimport { AuthService, CartService, ChannelService, ToastService } from '../../ec-services';\r\nimport { CoreConstantsService } from '../../constants';\r\nimport { Router, RouterLink } from '@angular/router';\r\nimport { AsyncPipe, TitleCasePipe } from '@angular/common';\r\nimport { EcCurrencySymbolPipe } from '../../ec-pipe';\r\nimport { CouponEcComponent } from '../coupon-ec/coupon-ec.component';\r\nimport { CartItemEcComponent } from '../cart-ec';\r\n\r\n@Component({\r\n    selector: 'app-sidebar-ec',\r\n    standalone: true,\r\n    imports: [RouterLink, AsyncPipe, CouponEcComponent, CartItemEcComponent, EcCurrencySymbolPipe],\r\n    templateUrl: './sidebar-ec.component.html',\r\n    styleUrl: './sidebar-ec.component.scss'\r\n})\r\nexport class SidebarEcComponent {\r\n\r\n    private _cartService: CartService = inject(CartService)\r\n    private _consts: CoreConstantsService = inject(CoreConstantsService)\r\n    private _authService: AuthService = inject(AuthService)\r\n    private _router: Router = inject(Router)\r\n    private _toastrService: ToastService = inject(ToastService)\r\n    private _channelService: ChannelService = inject(ChannelService)\r\n\r\n    public user: User | null = null\r\n    public mediaUrl: string = this._consts.mediaUrl();\r\n    public promotions = [];\r\n    public variantsToShow: string[] = ['TALLE', 'COLOR'];\r\n    public hideDiscounts: boolean = false;\r\n    public hideTaxes: boolean = false;\r\n\r\n    public cartItems$ = this._cartService.cartItems$;\r\n    public subTotalAmount$ = this._cartService.getSubTotalAmount();\r\n\tpublic totalPromotionAmount$ = this._cartService.getTotalPromotionAmount();\r\n\tpublic taxesAmount$ = this._cartService.getTaxesAmount();\r\n\tpublic totalAmount$ = this._cartService.getTotalAmount();\r\n\r\n    ngOnInit() {\r\n        this._cartService.promotions$.subscribe(promotions => this.promotions = promotions);\r\n        this._authService.getUserProfile().subscribe(u => {\r\n            this.user = u\r\n        })\r\n        this._channelService.channel$.subscribe(channel => {\r\n            this.hideDiscounts = channel?.hideDiscounts ?? false;\r\n            this.hideTaxes = channel?.hideTaxes ?? false;\r\n        });\r\n\r\n    }\r\n    actualizarCantidad(_t13: any, arg1?: any, arg2?: any, arg3?: any, arg4?: any) {\r\n        throw new Error('Method not implemented.');\r\n    }\r\n\r\n    getVariants(_t8: any): any {\r\n        throw new Error('Method not implemented.');\r\n    }\r\n    getTotalAmount(): import(\"rxjs\").Observable<any> | Promise<any> | import(\"rxjs\").Subscribable<any> {\r\n        throw new Error('Method not implemented.');\r\n    }\r\n    removeCoupon() {\r\n        throw new Error('Method not implemented.');\r\n    }\r\n\r\n    deleteCartItem(_t8: any, arg1: boolean) {\r\n        throw new Error('Method not implemented.');\r\n    }\r\n}\r\n","<div class=\"nav my-4 mx-0 position-relative text-center shadow-sm border-bottom d-flex justify-content-center\">\r\n    <h2 class=\"row text-center\">Mi carrito</h2>\r\n    <div class=\" me-3 closeCart position-absolute end-0\" data-bs-dismiss=\"offcanvas\" aria-label=\"Close\">\r\n        <i class=\"fa fa-times-circle fs-5\" aria-hidden=\"true\"></i>\r\n    </div>\r\n</div>\r\n\r\n\r\n@if(cartItems$ | async; as items){\r\n    @if(items.length > 0){\r\n    <!-- PRODUCTO -->\r\n    <div class=\"d-flex flex-column mb-4 items\">\r\n        @for(item of items; track $index; let i = $index){\r\n        <div class=\"productoCarrito mt-1 mb-2 w-100\">\r\n            <app-cart-item-ec [inSidebar]=\"true\" [item]=\"item\"></app-cart-item-ec>\r\n        </div>\r\n        }\r\n    </div>\r\n    <div class=\"d-flex mx-4 justify-content-between border-top \">\r\n        <p>Subtotal</p>\r\n        <p class=\"fw-700\">{{ (subTotalAmount$ | async) | ecCurrencySymbol}}</p>\r\n    </div>\r\n    <div class=\"mx-4 bordeBot\">\r\n        <app-coupon-ec></app-coupon-ec>\r\n    </div>\r\n    <div class=\"d-flex mx-4 justify-content-between bordeBot2\">\r\n        <p>Descuentos:</p>\r\n        <p>{{ (totalPromotionAmount$ | async) |ecCurrencySymbol }}</p>\r\n    </div>\r\n\r\n    <div class=\"d-flex mx-4 justify-content-between bordeBot2\">\r\n        <!--  @if(this._cartService.cart.source.value.couponCode){\r\n                <a class=\"quitar-cupon text-dark\" role=\"button\"\r\n                (click)=\"removeCoupon()\">(Quitar cupón)</a>\r\n            } -->\r\n    </div>\r\n    <div class=\"d-flex mx-4 justify-content-between mb-3 mt-2\">\r\n        <p class=\"fw-bold h5\">TOTAL</p>\r\n     <p class=\"fw-bold h5\">{{(totalAmount$ | async) | ecCurrencySymbol}}</p>\r\n    </div>\r\n    <div class=\"d-flex flex-column mx-4 justify-content-between mb-3\" data-bs-dismiss=\"offcanvas\" aria-label=\"Close\">\r\n        <a [routerLink]=\"['/cart']\" class=\"btn btn-primary btn-block w-100 btnComprar mb-2 mt-3 \">CONFIRMAR PEDIDO</a>\r\n        <a [routerLink]=\"['/collection']\" class=\"btn btn-secondary btn-block w-100 btnSeguir\">SEGUIR COMPRANDO</a>\r\n    </div>\r\n\r\n\r\n    } @else {\r\n    <div class=\"container-lg px-lg-0 px-md-4 my-5\">\r\n        <div class=\"row\">\r\n            <div class=\"col-12\">\r\n                <h5 class=\"text-center mb-sm-4 text-uppercase\"> · Su carrito se\r\n                    encuentra vacío · </h5>\r\n            </div>\r\n        </div>\r\n    </div>\r\n    }\r\n}"]}
60
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sidebar-ec.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/sidebar-ec/sidebar-ec.component.ts","../../../../../../projects/ng-easycommerce-v18/src/lib/ec-components/sidebar-ec/sidebar-ec.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, inject } from '@angular/core';\r\nimport { User } from '../../classes';\r\nimport { AuthService, CartService, ChannelService, ToastService } from '../../ec-services';\r\nimport { CoreConstantsService } from '../../constants';\r\nimport { Router, RouterLink } from '@angular/router';\r\nimport { AsyncPipe, TitleCasePipe } from '@angular/common';\r\nimport { EcCurrencySymbolPipe } from '../../ec-pipe';\r\nimport { CouponEcComponent } from '../coupon-ec/coupon-ec.component';\r\nimport { CartItemEcComponent } from '../cart-ec';\r\n\r\n@Component({\r\n    selector: 'app-sidebar-ec',\r\n    standalone: true,\r\n    imports: [RouterLink, AsyncPipe, CouponEcComponent, CartItemEcComponent, EcCurrencySymbolPipe],\r\n    templateUrl: './sidebar-ec.component.html',\r\n    styleUrl: './sidebar-ec.component.scss'\r\n})\r\nexport class SidebarEcComponent {\r\n\r\n    private _cartService: CartService = inject(CartService)\r\n    private _consts: CoreConstantsService = inject(CoreConstantsService)\r\n    private _authService: AuthService = inject(AuthService)\r\n    private _router: Router = inject(Router)\r\n    private _toastrService: ToastService = inject(ToastService)\r\n    private _channelService: ChannelService = inject(ChannelService)\r\n\r\n    public user: User | null = null\r\n    public mediaUrl: string = this._consts.mediaUrl();\r\n    public promotions = [];\r\n    public variantsToShow: string[] = ['TALLE', 'COLOR'];\r\n    public hideDiscounts: boolean = false;\r\n    public hideTaxes: boolean = false;\r\n\r\n    public cartItems$ = this._cartService.cartItems$;\r\n    public subTotalAmount$ = this._cartService.getSubTotalAmount();\r\n\tpublic totalPromotionAmount$ = this._cartService.getTotalPromotionAmount();\r\n\tpublic taxesAmount$ = this._cartService.getTaxesAmount();\r\n\tpublic totalAmount$ = this._cartService.getTotalAmount();\r\n\r\n    ngOnInit() {\r\n        this._cartService.promotions$.subscribe(promotions => this.promotions = promotions);\r\n        this._authService.getUserProfile().subscribe(u => {\r\n            this.user = u\r\n        })\r\n        this._channelService.channel$.subscribe(channel => {\r\n            this.hideDiscounts = channel?.hideDiscounts ?? false;\r\n            this.hideTaxes = channel?.hideTaxes ?? false;\r\n        });\r\n\r\n    }\r\n    actualizarCantidad(_t13: any, arg1?: any, arg2?: any, arg3?: any, arg4?: any) {\r\n        throw new Error('Method not implemented.');\r\n    }\r\n\r\n    getVariants(_t8: any): any {\r\n        throw new Error('Method not implemented.');\r\n    }\r\n    getTotalAmount(): import(\"rxjs\").Observable<any> | Promise<any> | import(\"rxjs\").Subscribable<any> {\r\n        throw new Error('Method not implemented.');\r\n    }\r\n    removeCoupon() {\r\n        throw new Error('Method not implemented.');\r\n    }\r\n\r\n    deleteCartItem(_t8: any, arg1: boolean) {\r\n        throw new Error('Method not implemented.');\r\n    }\r\n}\r\n","<div class=\"nav my-4 mx-0 position-relative text-center shadow-sm border-bottom d-flex justify-content-center\">\r\n    <h2 class=\"row text-center\">Mi carrito</h2>\r\n    <div class=\" me-3 closeCart position-absolute end-0\" data-bs-dismiss=\"offcanvas\" aria-label=\"Close\">\r\n        <i class=\"fa fa-times-circle fs-5\" aria-hidden=\"true\"></i>\r\n    </div>\r\n</div>\r\n\r\n\r\n@if(cartItems$ | async; as items){\r\n    @if(items.length > 0){\r\n    <!-- PRODUCTO -->\r\n    <div class=\"d-flex flex-column mb-4 items\">\r\n        @for(item of items; track $index; let i = $index){\r\n        <div class=\"productoCarrito mt-1 mb-2 w-100\">\r\n            <app-cart-item-ec [inSidebar]=\"true\" [item]=\"item\"></app-cart-item-ec>\r\n        </div>\r\n        }\r\n    </div>\r\n    <div class=\"d-flex mx-4 justify-content-between border-top \">\r\n        <p>Subtotal</p>\r\n        <p class=\"fw-700\">{{ (subTotalAmount$ | async) | ecCurrencySymbol}}</p>\r\n    </div>\r\n    <div class=\"mx-4 bordeBot\">\r\n        <app-coupon-ec></app-coupon-ec>\r\n    </div>\r\n    <div class=\"d-flex mx-4 justify-content-between bordeBot2\">\r\n        <p>Descuentos:</p>\r\n        <p>{{ (totalPromotionAmount$ | async) |ecCurrencySymbol }}</p>\r\n    </div>\r\n\r\n    <div class=\"d-flex mx-4 justify-content-between bordeBot2\">\r\n        <!--  @if(this._cartService.cart.source.value.couponCode){\r\n                <a class=\"quitar-cupon text-dark\" role=\"button\"\r\n                (click)=\"removeCoupon()\">(Quitar cupón)</a>\r\n            } -->\r\n    </div>\r\n    <div class=\"d-flex mx-4 justify-content-between mb-3 mt-2\">\r\n        <p class=\"fw-bold h5\">TOTAL</p>\r\n     <p class=\"fw-bold h5\">{{(totalAmount$ | async) | ecCurrencySymbol}}</p>\r\n    </div>\r\n    <div class=\"d-flex flex-column mx-4 justify-content-between mb-3\" data-bs-dismiss=\"offcanvas\" aria-label=\"Close\">\r\n        <a [routerLink]=\"['/cart']\" class=\"btn btnPedido mb-2\">FINALIZAR PEDIDO</a>\r\n        <a [routerLink]=\"['/collection']\" class=\"btn btnSeguir mb-3\">SEGUIR COMPRANDO</a>\r\n    </div>\r\n\r\n\r\n    } @else {\r\n    <div class=\"container-lg px-lg-0 px-md-4 my-5\">\r\n        <div class=\"row\">\r\n            <div class=\"col-12\">\r\n                <h5 class=\"text-center mb-sm-4 text-uppercase\"> · Su carrito se\r\n                    encuentra vacío · </h5>\r\n            </div>\r\n        </div>\r\n    </div>\r\n    }\r\n}"]}
@@ -9,10 +9,10 @@ export class VariantsEcComponent {
9
9
  this._productDetailsService.setOption(optionCode, optionValue);
10
10
  }
11
11
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: VariantsEcComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
12
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.0", type: VariantsEcComponent, isStandalone: true, selector: "app-variants-ec", ngImport: i0, template: "@if(options$ | async; as options){\r\n@if(options && options.length){\r\n@for(option of options; track $index){\r\n@switch (option.type) {\r\n@case ('color') {\r\n<h5>Colores disponibles</h5>\r\n<div class=\"row w-100 mx-auto pb-3 mb-3\">\r\n @for(value of option.values; track $index; let x = $index){\r\n <a role=\"button\" [title]=\"value.description\" (click)=\"setOption(option.code, value.name)\"\r\n [class]=\"'item m-1 circle ' + (value.selected ? 'shadow' : '')\" [id]=\"x + value.name\"\r\n [style.background]=\"'#' + value.name\" [style.box-shadow]=\"(value.selected ? '0px 0px 0px 2px #000' : 'none')\">\r\n </a>\r\n }\r\n</div>\r\n}\r\n@case ('size') {\r\n<h5>Talles displonibles</h5>\r\n<div class=\"row w-100 mx-auto pb-3\">\r\n @for(value of option.values; track $index; let x = $index){\r\n <a role=\"buttom\" (click)=\"setOption(option.code, value.name)\" [id]=\"x + value.name\"\r\n [class]=\"'btn item m-1 ' + (value.selected ? 'selected-size' : 'unselected-size')\">\r\n {{ value.name }}\r\n </a>\r\n }\r\n\r\n</div>\r\n}\r\n@default {\r\n\r\n}\r\n}\r\n}\r\n}\r\n}\r\n", styles: [".circle{width:32px;height:32px;border-radius:50%}.shadow{border:1px solid #000}\n"], dependencies: [{ kind: "pipe", type: AsyncPipe, name: "async" }] });
12
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.0", type: VariantsEcComponent, isStandalone: true, selector: "app-variants-ec", ngImport: i0, template: "@if(options$ | async; as options){\r\n@if(options && options.length ){\r\n@for(option of options; track $index){\r\n@switch (option.type) {\r\n@case ('color') {\r\n@if(option.values && option.values.length > 1) {\r\n<h5>Colores disponibles</h5>\r\n<div class=\"row w-100 mx-auto pb-3 mb-3\">\r\n @for(value of option.values; track $index; let x = $index){\r\n <a role=\"button\" [title]=\"value.description\" (click)=\"setOption(option.code, value.name)\"\r\n [class]=\"'item m-1 circle ' + (value.selected ? 'shadow' : '')\" [id]=\"x + value.name\"\r\n [style.background]=\"'#' + value.name\" [style.box-shadow]=\"(value.selected ? '0px 0px 0px 2px #000' : 'none')\">\r\n </a>\r\n }\r\n</div>\r\n}\r\n}\r\n@case ('size') {\r\n@if(option.values && option.values.length > 1) {\r\n<h5>Talles displonibles</h5>\r\n<div class=\"row w-100 mx-auto pb-3\">\r\n @for(value of option.values; track $index; let x = $index){\r\n <a role=\"buttom\" (click)=\"setOption(option.code, value.name)\" [id]=\"x + value.name\"\r\n [class]=\"'btn item m-1 ' + (value.selected ? 'selected-size' : 'unselected-size')\">\r\n {{ value.name }}\r\n </a>\r\n }\r\n\r\n</div>\r\n}\r\n}\r\n@default {\r\n\r\n}\r\n}\r\n}\r\n}\r\n}", styles: [".circle{width:32px;height:32px;border-radius:50%}.shadow{border:1px solid #000}\n"], dependencies: [{ kind: "pipe", type: AsyncPipe, name: "async" }] });
13
13
  }
14
14
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: VariantsEcComponent, decorators: [{
15
15
  type: Component,
16
- args: [{ selector: 'app-variants-ec', standalone: true, imports: [AsyncPipe], template: "@if(options$ | async; as options){\r\n@if(options && options.length){\r\n@for(option of options; track $index){\r\n@switch (option.type) {\r\n@case ('color') {\r\n<h5>Colores disponibles</h5>\r\n<div class=\"row w-100 mx-auto pb-3 mb-3\">\r\n @for(value of option.values; track $index; let x = $index){\r\n <a role=\"button\" [title]=\"value.description\" (click)=\"setOption(option.code, value.name)\"\r\n [class]=\"'item m-1 circle ' + (value.selected ? 'shadow' : '')\" [id]=\"x + value.name\"\r\n [style.background]=\"'#' + value.name\" [style.box-shadow]=\"(value.selected ? '0px 0px 0px 2px #000' : 'none')\">\r\n </a>\r\n }\r\n</div>\r\n}\r\n@case ('size') {\r\n<h5>Talles displonibles</h5>\r\n<div class=\"row w-100 mx-auto pb-3\">\r\n @for(value of option.values; track $index; let x = $index){\r\n <a role=\"buttom\" (click)=\"setOption(option.code, value.name)\" [id]=\"x + value.name\"\r\n [class]=\"'btn item m-1 ' + (value.selected ? 'selected-size' : 'unselected-size')\">\r\n {{ value.name }}\r\n </a>\r\n }\r\n\r\n</div>\r\n}\r\n@default {\r\n\r\n}\r\n}\r\n}\r\n}\r\n}\r\n", styles: [".circle{width:32px;height:32px;border-radius:50%}.shadow{border:1px solid #000}\n"] }]
16
+ args: [{ selector: 'app-variants-ec', standalone: true, imports: [AsyncPipe], template: "@if(options$ | async; as options){\r\n@if(options && options.length ){\r\n@for(option of options; track $index){\r\n@switch (option.type) {\r\n@case ('color') {\r\n@if(option.values && option.values.length > 1) {\r\n<h5>Colores disponibles</h5>\r\n<div class=\"row w-100 mx-auto pb-3 mb-3\">\r\n @for(value of option.values; track $index; let x = $index){\r\n <a role=\"button\" [title]=\"value.description\" (click)=\"setOption(option.code, value.name)\"\r\n [class]=\"'item m-1 circle ' + (value.selected ? 'shadow' : '')\" [id]=\"x + value.name\"\r\n [style.background]=\"'#' + value.name\" [style.box-shadow]=\"(value.selected ? '0px 0px 0px 2px #000' : 'none')\">\r\n </a>\r\n }\r\n</div>\r\n}\r\n}\r\n@case ('size') {\r\n@if(option.values && option.values.length > 1) {\r\n<h5>Talles displonibles</h5>\r\n<div class=\"row w-100 mx-auto pb-3\">\r\n @for(value of option.values; track $index; let x = $index){\r\n <a role=\"buttom\" (click)=\"setOption(option.code, value.name)\" [id]=\"x + value.name\"\r\n [class]=\"'btn item m-1 ' + (value.selected ? 'selected-size' : 'unselected-size')\">\r\n {{ value.name }}\r\n </a>\r\n }\r\n\r\n</div>\r\n}\r\n}\r\n@default {\r\n\r\n}\r\n}\r\n}\r\n}\r\n}", styles: [".circle{width:32px;height:32px;border-radius:50%}.shadow{border:1px solid #000}\n"] }]
17
17
  }] });
18
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFyaWFudHMtZWMuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctZWFzeWNvbW1lcmNlLXYxOC9zcmMvbGliL2VjLWNvbXBvbmVudHMvdmFyaWFudHMtZWMvdmFyaWFudHMtZWMuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctZWFzeWNvbW1lcmNlLXYxOC9zcmMvbGliL2VjLWNvbXBvbmVudHMvdmFyaWFudHMtZWMvdmFyaWFudHMtZWMuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQVMsTUFBTSxlQUFlLENBQUM7QUFDekQsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDekQsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGlCQUFpQixDQUFDOztBQVM1QyxNQUFNLE9BQU8sbUJBQW1CO0lBQ3ZCLHNCQUFzQixHQUF5QixNQUFNLENBQUMsb0JBQW9CLENBQUMsQ0FBQztJQUM3RSxRQUFRLEdBQUcsSUFBSSxDQUFDLHNCQUFzQixDQUFDLFFBQVEsQ0FBQztJQUV2RCxTQUFTLENBQUMsVUFBYyxFQUFFLFdBQWU7UUFDdEMsSUFBSSxDQUFDLHNCQUFzQixDQUFDLFNBQVMsQ0FBQyxVQUFVLEVBQUUsV0FBVyxDQUFDLENBQUM7SUFDakUsQ0FBQzt1R0FOVSxtQkFBbUI7MkZBQW5CLG1CQUFtQiwyRUNYaEMsdW5DQWtDQSxzSUQzQlksU0FBUzs7MkZBSVIsbUJBQW1CO2tCQVAvQixTQUFTOytCQUNFLGlCQUFpQixjQUNmLElBQUksV0FDUCxDQUFDLFNBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgaW5qZWN0LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBQcm9kdWN0RGV0YWlsU2VydmljZSB9IGZyb20gJy4uLy4uL2VjLXNlcnZpY2VzJztcclxuaW1wb3J0IHsgQXN5bmNQaXBlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnYXBwLXZhcmlhbnRzLWVjJyxcclxuICBzdGFuZGFsb25lOiB0cnVlLFxyXG4gIGltcG9ydHM6IFtBc3luY1BpcGVdLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi92YXJpYW50cy1lYy5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmw6ICcuL3ZhcmlhbnRzLWVjLmNvbXBvbmVudC5zY3NzJ1xyXG59KVxyXG5leHBvcnQgY2xhc3MgVmFyaWFudHNFY0NvbXBvbmVudCB7XHJcblx0cHJpdmF0ZSBfcHJvZHVjdERldGFpbHNTZXJ2aWNlOiBQcm9kdWN0RGV0YWlsU2VydmljZSA9IGluamVjdChQcm9kdWN0RGV0YWlsU2VydmljZSk7XHJcblx0cHVibGljIG9wdGlvbnMkID0gdGhpcy5fcHJvZHVjdERldGFpbHNTZXJ2aWNlLm9wdGlvbnMkO1xyXG5cdFxyXG5cdHNldE9wdGlvbihvcHRpb25Db2RlOmFueSwgb3B0aW9uVmFsdWU6YW55KSB7XHJcbiAgICB0aGlzLl9wcm9kdWN0RGV0YWlsc1NlcnZpY2Uuc2V0T3B0aW9uKG9wdGlvbkNvZGUsIG9wdGlvblZhbHVlKTtcclxuICB9XHJcblx0XHJcbn1cclxuIiwiQGlmKG9wdGlvbnMkIHwgYXN5bmM7IGFzIG9wdGlvbnMpe1xyXG5AaWYob3B0aW9ucyAmJiBvcHRpb25zLmxlbmd0aCl7XHJcbkBmb3Iob3B0aW9uIG9mIG9wdGlvbnM7IHRyYWNrICRpbmRleCl7XHJcbkBzd2l0Y2ggKG9wdGlvbi50eXBlKSB7XHJcbkBjYXNlICgnY29sb3InKSB7XHJcbjxoNT5Db2xvcmVzIGRpc3BvbmlibGVzPC9oNT5cclxuPGRpdiBjbGFzcz1cInJvdyB3LTEwMCBteC1hdXRvIHBiLTMgbWItM1wiPlxyXG4gICAgQGZvcih2YWx1ZSBvZiBvcHRpb24udmFsdWVzOyB0cmFjayAkaW5kZXg7IGxldCB4ID0gJGluZGV4KXtcclxuICAgIDxhIHJvbGU9XCJidXR0b25cIiBbdGl0bGVdPVwidmFsdWUuZGVzY3JpcHRpb25cIiAoY2xpY2spPVwic2V0T3B0aW9uKG9wdGlvbi5jb2RlLCB2YWx1ZS5uYW1lKVwiXHJcbiAgICAgICAgW2NsYXNzXT1cIidpdGVtIG0tMSBjaXJjbGUgJyArICh2YWx1ZS5zZWxlY3RlZCA/ICdzaGFkb3cnIDogJycpXCIgW2lkXT1cInggKyB2YWx1ZS5uYW1lXCJcclxuICAgICAgICBbc3R5bGUuYmFja2dyb3VuZF09XCInIycgKyB2YWx1ZS5uYW1lXCIgW3N0eWxlLmJveC1zaGFkb3ddPVwiKHZhbHVlLnNlbGVjdGVkID8gJzBweCAwcHggMHB4IDJweCAjMDAwJyA6ICdub25lJylcIj5cclxuICAgIDwvYT5cclxuICAgIH1cclxuPC9kaXY+XHJcbn1cclxuQGNhc2UgKCdzaXplJykge1xyXG48aDU+VGFsbGVzIGRpc3Bsb25pYmxlczwvaDU+XHJcbjxkaXYgY2xhc3M9XCJyb3cgdy0xMDAgbXgtYXV0byBwYi0zXCI+XHJcbiAgICBAZm9yKHZhbHVlIG9mIG9wdGlvbi52YWx1ZXM7IHRyYWNrICRpbmRleDsgbGV0IHggPSAkaW5kZXgpe1xyXG4gICAgPGEgcm9sZT1cImJ1dHRvbVwiIChjbGljayk9XCJzZXRPcHRpb24ob3B0aW9uLmNvZGUsIHZhbHVlLm5hbWUpXCIgW2lkXT1cInggKyB2YWx1ZS5uYW1lXCJcclxuICAgICAgICBbY2xhc3NdPVwiJ2J0biBpdGVtIG0tMSAnICsgKHZhbHVlLnNlbGVjdGVkID8gJ3NlbGVjdGVkLXNpemUnIDogJ3Vuc2VsZWN0ZWQtc2l6ZScpXCI+XHJcbiAgICAgICAge3sgdmFsdWUubmFtZSB9fVxyXG4gICAgPC9hPlxyXG4gICAgfVxyXG5cclxuPC9kaXY+XHJcbn1cclxuQGRlZmF1bHQge1xyXG5cclxufVxyXG59XHJcbn1cclxufVxyXG59XHJcbiJdfQ==
18
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFyaWFudHMtZWMuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctZWFzeWNvbW1lcmNlLXYxOC9zcmMvbGliL2VjLWNvbXBvbmVudHMvdmFyaWFudHMtZWMvdmFyaWFudHMtZWMuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctZWFzeWNvbW1lcmNlLXYxOC9zcmMvbGliL2VjLWNvbXBvbmVudHMvdmFyaWFudHMtZWMvdmFyaWFudHMtZWMuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQVMsTUFBTSxlQUFlLENBQUM7QUFDekQsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDekQsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGlCQUFpQixDQUFDOztBQVM1QyxNQUFNLE9BQU8sbUJBQW1CO0lBQ3ZCLHNCQUFzQixHQUF5QixNQUFNLENBQUMsb0JBQW9CLENBQUMsQ0FBQztJQUM3RSxRQUFRLEdBQUcsSUFBSSxDQUFDLHNCQUFzQixDQUFDLFFBQVEsQ0FBQztJQUV2RCxTQUFTLENBQUMsVUFBYyxFQUFFLFdBQWU7UUFDdEMsSUFBSSxDQUFDLHNCQUFzQixDQUFDLFNBQVMsQ0FBQyxVQUFVLEVBQUUsV0FBVyxDQUFDLENBQUM7SUFDakUsQ0FBQzt1R0FOVSxtQkFBbUI7MkZBQW5CLG1CQUFtQiwyRUNYaEMsc3VDQXFDQyxzSUQ5QlcsU0FBUzs7MkZBSVIsbUJBQW1CO2tCQVAvQixTQUFTOytCQUNFLGlCQUFpQixjQUNmLElBQUksV0FDUCxDQUFDLFNBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgaW5qZWN0LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBQcm9kdWN0RGV0YWlsU2VydmljZSB9IGZyb20gJy4uLy4uL2VjLXNlcnZpY2VzJztcclxuaW1wb3J0IHsgQXN5bmNQaXBlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnYXBwLXZhcmlhbnRzLWVjJyxcclxuICBzdGFuZGFsb25lOiB0cnVlLFxyXG4gIGltcG9ydHM6IFtBc3luY1BpcGVdLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi92YXJpYW50cy1lYy5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmw6ICcuL3ZhcmlhbnRzLWVjLmNvbXBvbmVudC5zY3NzJ1xyXG59KVxyXG5leHBvcnQgY2xhc3MgVmFyaWFudHNFY0NvbXBvbmVudCB7XHJcblx0cHJpdmF0ZSBfcHJvZHVjdERldGFpbHNTZXJ2aWNlOiBQcm9kdWN0RGV0YWlsU2VydmljZSA9IGluamVjdChQcm9kdWN0RGV0YWlsU2VydmljZSk7XHJcblx0cHVibGljIG9wdGlvbnMkID0gdGhpcy5fcHJvZHVjdERldGFpbHNTZXJ2aWNlLm9wdGlvbnMkO1xyXG5cdFxyXG5cdHNldE9wdGlvbihvcHRpb25Db2RlOmFueSwgb3B0aW9uVmFsdWU6YW55KSB7XHJcbiAgICB0aGlzLl9wcm9kdWN0RGV0YWlsc1NlcnZpY2Uuc2V0T3B0aW9uKG9wdGlvbkNvZGUsIG9wdGlvblZhbHVlKTtcclxuICB9XHJcblx0XHJcbn1cclxuIiwiQGlmKG9wdGlvbnMkIHwgYXN5bmM7IGFzIG9wdGlvbnMpe1xyXG5AaWYob3B0aW9ucyAmJiBvcHRpb25zLmxlbmd0aCApe1xyXG5AZm9yKG9wdGlvbiBvZiBvcHRpb25zOyB0cmFjayAkaW5kZXgpe1xyXG5Ac3dpdGNoIChvcHRpb24udHlwZSkge1xyXG5AY2FzZSAoJ2NvbG9yJykge1xyXG5AaWYob3B0aW9uLnZhbHVlcyAmJiBvcHRpb24udmFsdWVzLmxlbmd0aCA+IDEpIHtcclxuPGg1PkNvbG9yZXMgZGlzcG9uaWJsZXM8L2g1PlxyXG48ZGl2IGNsYXNzPVwicm93IHctMTAwIG14LWF1dG8gcGItMyBtYi0zXCI+XHJcbiAgICBAZm9yKHZhbHVlIG9mIG9wdGlvbi52YWx1ZXM7IHRyYWNrICRpbmRleDsgbGV0IHggPSAkaW5kZXgpe1xyXG4gICAgPGEgcm9sZT1cImJ1dHRvblwiIFt0aXRsZV09XCJ2YWx1ZS5kZXNjcmlwdGlvblwiIChjbGljayk9XCJzZXRPcHRpb24ob3B0aW9uLmNvZGUsIHZhbHVlLm5hbWUpXCJcclxuICAgICAgICBbY2xhc3NdPVwiJ2l0ZW0gbS0xIGNpcmNsZSAnICsgKHZhbHVlLnNlbGVjdGVkID8gJ3NoYWRvdycgOiAnJylcIiBbaWRdPVwieCArIHZhbHVlLm5hbWVcIlxyXG4gICAgICAgIFtzdHlsZS5iYWNrZ3JvdW5kXT1cIicjJyArIHZhbHVlLm5hbWVcIiBbc3R5bGUuYm94LXNoYWRvd109XCIodmFsdWUuc2VsZWN0ZWQgPyAnMHB4IDBweCAwcHggMnB4ICMwMDAnIDogJ25vbmUnKVwiPlxyXG4gICAgPC9hPlxyXG4gICAgfVxyXG48L2Rpdj5cclxufVxyXG59XHJcbkBjYXNlICgnc2l6ZScpIHtcclxuQGlmKG9wdGlvbi52YWx1ZXMgJiYgb3B0aW9uLnZhbHVlcy5sZW5ndGggPiAxKSB7XHJcbjxoNT5UYWxsZXMgZGlzcGxvbmlibGVzPC9oNT5cclxuPGRpdiBjbGFzcz1cInJvdyB3LTEwMCBteC1hdXRvIHBiLTNcIj5cclxuICAgIEBmb3IodmFsdWUgb2Ygb3B0aW9uLnZhbHVlczsgdHJhY2sgJGluZGV4OyBsZXQgeCA9ICRpbmRleCl7XHJcbiAgICA8YSByb2xlPVwiYnV0dG9tXCIgKGNsaWNrKT1cInNldE9wdGlvbihvcHRpb24uY29kZSwgdmFsdWUubmFtZSlcIiBbaWRdPVwieCArIHZhbHVlLm5hbWVcIlxyXG4gICAgICAgIFtjbGFzc109XCInYnRuIGl0ZW0gbS0xICcgKyAodmFsdWUuc2VsZWN0ZWQgPyAnc2VsZWN0ZWQtc2l6ZScgOiAndW5zZWxlY3RlZC1zaXplJylcIj5cclxuICAgICAgICB7eyB2YWx1ZS5uYW1lIH19XHJcbiAgICA8L2E+XHJcbiAgICB9XHJcblxyXG48L2Rpdj5cclxufVxyXG59XHJcbkBkZWZhdWx0IHtcclxuXHJcbn1cclxufVxyXG59XHJcbn1cclxufSJdfQ==