ng-easycommerce-v18 0.0.5 → 0.0.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -43,6 +43,12 @@ export class CoreConstantsService {
43
43
  * @returns
44
44
  */
45
45
  mediaUrl = (postMedia) => this.ASSETS_URL + (this.ASSETS_URL == this.apiConstants.API_URL ? 'media/' : '') + (postMedia ? postMedia : "image/");
46
+ /**
47
+ * Retorna la url donde se guarda las imagenes.
48
+ * @param postMedia
49
+ * @returns
50
+ */
51
+ mediaImageUrl = (postMedia) => this.ASSETS_URL + (this.ASSETS_URL == this.apiConstants.API_URL ? 'media/image/' : '') + (postMedia ? postMedia : "image/");
46
52
  /**
47
53
  * Retorna la url del sitio.
48
54
  * @param postMedia
@@ -202,4 +208,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
202
208
  providedIn: 'root'
203
209
  }]
204
210
  }], ctorParameters: () => [] });
205
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core.constants.service.js","sourceRoot":"","sources":["../../../../../projects/ng-easycommerce-v18/src/lib/constants/core.constants.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { inject, Injectable, PLATFORM_ID } from '@angular/core';\r\nimport { ApiConstantsService } from './api.constants.service';\r\nimport { isPlatformBrowser } from '@angular/common';\r\nimport { CurrencyConfig, currencyType, ParamsProductsWithUniqueVariant } from '../interfaces';\r\n/**\r\n * Servicio que provee las constantes necesarias que se utilizan por toda la aplicación.\r\n * @export\r\n * @class CoreConstantsService\r\n */\r\n@Injectable({\r\n\tprovidedIn: 'root'\r\n})\r\nexport class CoreConstantsService {\r\n\r\n\t/**\r\n\t * Servicio que contiene las constantes usadas para la API\r\n\t */\r\n\tprivate apiConstants = inject(ApiConstantsService)\r\n\t/**\r\n\t * Provee el ID de la plataforma en donde se esta ejecutando el codigo, esto sirve para poder diferenciar si es de un servidor o un navegador web.\r\n\t */\r\n\tprivate platformId: any = inject(PLATFORM_ID)\r\n\t/**\r\n\t * Guarda la variable window del web browser.\r\n\t */\r\n\tprivate window?:Window;\r\n\r\n\tconstructor() {\r\n\t\tif (isPlatformBrowser(this.platformId)) {\r\n\t\t\tthis.window = window\r\n\t\t}\r\n\t}\r\n\t/**\r\n\t * Path usado en las colecciones de productos.\r\n\t */\r\n\tpublic PRODUCT_LIST_ROUTE: string = 'collection/';\r\n\t/**\r\n\t * Path usado para acceder a las secciones.\r\n\t */\r\n\tpublic SECTIONS_ROUTE: string = 'sections/';\r\n\t/**\r\n\t * Path que aloja la carpeta de los assets.\r\n\t */\r\n\tpublic readonly ASSETS_URL: string = this.apiConstants.API_URL;\r\n\t/**\r\n\t * Retorna la url donde se guarda las imagenes.\r\n\t * @param postMedia \r\n\t * @returns \r\n\t */\r\n\tpublic mediaUrl = (postMedia?: string) => this.ASSETS_URL + (this.ASSETS_URL == this.apiConstants.API_URL ? 'media/' : '') + (postMedia ? postMedia : \"image/\");\r\n\t/**\r\n\t * Retorna la url del sitio.\r\n\t * @param postMedia \r\n\t * @returns \r\n\t */\r\n\tpublic url = () => this.apiConstants.API_URL.replace(/\\/$/, ''); // remove last slash\t\r\n\t/**\r\n\t * Retorna la url de las imagenes de los banners\r\n\t * @returns \r\n\t */\r\n\tpublic mediaBannerUrl = () => this.ASSETS_URL + (this.ASSETS_URL == this.apiConstants.API_URL ? 'media/' : '') + \"banner-image/\";\r\n\t/**\r\n\t * Retorna `true` si la vista es mobile, `false` caso contrario.\r\n\t * @returns {boolean}\r\n\t */\r\n\tpublic mobileScreen = (): boolean => this.window && this.window?.innerWidth < 750 || false;\r\n\t/**\r\n\t * Contiene los valores para la moneda actual\r\n\t */\r\n\tpublic currency: CurrencyConfig = {\r\n\t\tcode: 'ARG',\r\n\t\tsymbol: '$',\r\n\t\tposition: 'Left',\r\n\t\twithoutDecimal: false\r\n\t};\r\n\r\n\t/**\r\n\t * Arreglo de valores usados para el pipe currencyPrice\r\n\t */\r\n\tpublic currencyTypeConfig: CurrencyConfig[] = [\r\n\t\t{\r\n\t\t\tcode: 'EUR',\r\n\t\t\tsymbol: '€',\r\n\t\t\tposition: 'Right',\r\n\t\t\twithoutDecimal: false\r\n\r\n\t\t},\r\n\t\t{\r\n\t\t\tcode: 'ARG',\r\n\t\t\tsymbol: '$',\r\n\t\t\tposition: 'Left',\r\n\t\t\twithoutDecimal: false\r\n\t\t},\r\n\t\t{\r\n\t\t\tcode: 'ARS',\r\n\t\t\tsymbol: '$',\r\n\t\t\tposition: 'Left',\r\n\t\t\twithoutDecimal: false\r\n\t\t},\r\n\t\t{\r\n\t\t\tcode: 'USD',\r\n\t\t\tsymbol: '$',\r\n\t\t\tposition: 'Left',\r\n\t\t\twithoutDecimal: false\r\n\t\t},\r\n\t\t{\r\n\t\t\tcode: 'PYG',\r\n\t\t\tsymbol: 'Gs.',\r\n\t\t\tposition: 'Left',\r\n\t\t\twithoutDecimal: false\r\n\t\t},\r\n\t\t{\r\n\t\t\tcode: 'PEN',\r\n\t\t\tsymbol: 'S/',\r\n\t\t\tposition: 'Left',\r\n\t\t\twithoutDecimal: false\r\n\t\t},\r\n\t\t{\r\n\t\t\tcode: 'SEK',\r\n\t\t\tsymbol: 'SEK',\r\n\t\t\tposition: 'Right',\r\n\t\t\twithoutDecimal: true\r\n\t\t},\r\n\t]\r\n\t/**\r\n\t * Cambia la configuración de la moneda.\r\n\t * @param currencyTypeConfig Arreglo con las distintas monedas.\r\n\t */\r\n\tpublic setCurrencyTypeConfig(currencyTypeConfig: CurrencyConfig[]) {\r\n\t\tthis.currencyTypeConfig = currencyTypeConfig;\r\n\t}\r\n\r\n\t/**\r\n\t * @param currencyTypeFind Definir el code del tipo de moneda que se quiera utilizar.\r\n\t * Si el tipo es CUSTOM se toman los valores del segundo parametro donde se puede definir la simbología y posesión que se quiera.\r\n\t * @param customType Formato del parámetro ejemplo { code: 'ARG', symbol: '$', position: 'L' , withoutDecimals: false } ,\r\n\t * todas las key son opcionales y por defecto se toman los valores del ejemplo.\r\n\t * @returns se retorna la configuración que se seteo a la propiedad currency del servicio.\r\n\t */\r\n\tpublic setCurrency(currencyTypeFind: currencyType, customType?: CurrencyConfig): CurrencyConfig {\r\n\t\tthis.currency = this.currencyTypeConfig.find((ct: CurrencyConfig) => ct.code == currencyTypeFind.toUpperCase()) || this.currency\r\n\t\tcustomType && (this.currency = { ...this.currency, ...customType })\r\n\t\treturn this.currency;\r\n\t};\r\n\r\n\r\n\tpublic modifyChannelConfig(channelConfig: any) {\r\n\t\tif (channelConfig.channel || channelConfig.code)\r\n\t\t\tthis.apiConstants.setChannel(channelConfig.channel || channelConfig.code)\r\n\r\n\t\tif (channelConfig.locale || channelConfig.locales.code)\r\n\t\t\tthis.apiConstants.setLocale(channelConfig.locale || channelConfig.locales.code)\r\n\r\n\t\tif (channelConfig.currency || channelConfig.baseCurrency)\r\n\t\t\tthis.setCurrency(channelConfig.currency || channelConfig.baseCurrency)\r\n\r\n\t\treturn channelConfig;\r\n\t}\r\n\r\n\t/**\r\n\t* @description se utiliza para configurar que filtros del tipo `SortFilter` se quiere mostrar en la vista.\r\n\t* Se usan los codigo de los filtros para indicar cuales se deben mostrar.\r\n\t*/\r\n\tprivate sortFilters: string[] = ['price', 'order-alph', 'recent']\r\n\r\n\t/**\r\n\t *\r\n\t * @param filtersCode arreglo de strings con los codigos de los filtros.\r\n\t * Si se le pasa el parametro **all** este mostrara todos.\r\n\t * @example price | order-alph | recent | update | all\r\n\t * @returns\r\n\t */\r\n\tsetSortFilters = (filtersCode: string[] = ['all']) => this.sortFilters = filtersCode;\r\n\r\n\tgetSortFilters = () => this.sortFilters;\r\n\r\n\t// ABOUT PRODUCTS \r\n\tprivate productsWithUniqueVariant: boolean = false;\r\n\tsetProductWithUniqueVariant(value: boolean) { this.productsWithUniqueVariant = value; }\r\n\tgetProductWithUniqueVariant() { return this.productsWithUniqueVariant }\r\n\r\n\t/**\r\n\t* @description esta variable se utiliza para configurar los parametros cuando se desea mostrar\r\n\t* variantes el listado de productos.\r\n\t* @param {string}type tipo de options\r\n\t* @param {string}code codigo de options\r\n\t* @param {boolean}defaultFirstOption `true` toma el primer option del producto en general\r\n\t* @param {boolean}checkIfStock `true` se realiza un chequeo de si la variante tiene stock para mostrarla\r\n\t* @example  ```javascript\r\n\t* {\r\n\t   type: 'color',\r\n\t   code: 'color',\r\n\t   defaultFirstOption: false ,\r\n\t   checkIfStock:true\r\n\t   } ```\r\n\t*/\r\n\tprivate paramsProductsWithUniqueVariant: ParamsProductsWithUniqueVariant = {\r\n\t\ttype: 'color',\r\n\t\tcode: 'color',\r\n\t\tdefaultFirstOption: false,\r\n\t\tcheckIfStock: true\r\n\t}\r\n\r\n\tsetParamsProductsWithUniqueVariant = (value: ParamsProductsWithUniqueVariant) => {\r\n\t\tthis.paramsProductsWithUniqueVariant = {\r\n\t\t\t...this.paramsProductsWithUniqueVariant,\r\n\t\t\t...value\r\n\t\t}\r\n\t}\r\n\r\n\tgetParamsProductsWithUniqueVariant = () => this.paramsProductsWithUniqueVariant\r\n\t\r\n\tpublic getChannel(){\r\n\t\treturn this.apiConstants.CHANNEL;\r\n\t}\r\n}\r\n"]}
211
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core.constants.service.js","sourceRoot":"","sources":["../../../../../projects/ng-easycommerce-v18/src/lib/constants/core.constants.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { inject, Injectable, PLATFORM_ID } from '@angular/core';\r\nimport { ApiConstantsService } from './api.constants.service';\r\nimport { isPlatformBrowser } from '@angular/common';\r\nimport { CurrencyConfig, currencyType, ParamsProductsWithUniqueVariant } from '../interfaces';\r\n/**\r\n * Servicio que provee las constantes necesarias que se utilizan por toda la aplicación.\r\n * @export\r\n * @class CoreConstantsService\r\n */\r\n@Injectable({\r\n\tprovidedIn: 'root'\r\n})\r\nexport class CoreConstantsService {\r\n\r\n\t/**\r\n\t * Servicio que contiene las constantes usadas para la API\r\n\t */\r\n\tprivate apiConstants = inject(ApiConstantsService)\r\n\t/**\r\n\t * Provee el ID de la plataforma en donde se esta ejecutando el codigo, esto sirve para poder diferenciar si es de un servidor o un navegador web.\r\n\t */\r\n\tprivate platformId: any = inject(PLATFORM_ID)\r\n\t/**\r\n\t * Guarda la variable window del web browser.\r\n\t */\r\n\tprivate window?:Window;\r\n\r\n\tconstructor() {\r\n\t\tif (isPlatformBrowser(this.platformId)) {\r\n\t\t\tthis.window = window\r\n\t\t}\r\n\t}\r\n\t/**\r\n\t * Path usado en las colecciones de productos.\r\n\t */\r\n\tpublic PRODUCT_LIST_ROUTE: string = 'collection/';\r\n\t/**\r\n\t * Path usado para acceder a las secciones.\r\n\t */\r\n\tpublic SECTIONS_ROUTE: string = 'sections/';\r\n\t/**\r\n\t * Path que aloja la carpeta de los assets.\r\n\t */\r\n\tpublic readonly ASSETS_URL: string = this.apiConstants.API_URL;\r\n\t/**\r\n\t * Retorna la url donde se guarda las imagenes.\r\n\t * @param postMedia \r\n\t * @returns \r\n\t */\r\n\tpublic mediaUrl = (postMedia?: string) => this.ASSETS_URL + (this.ASSETS_URL == this.apiConstants.API_URL ? 'media/' : '') + (postMedia ? postMedia : \"image/\");\r\n\t/**\r\n\t * Retorna la url donde se guarda las imagenes.\r\n\t * @param postMedia \r\n\t * @returns \r\n\t */\r\n\tpublic mediaImageUrl = (postMedia?: string) => this.ASSETS_URL + (this.ASSETS_URL == this.apiConstants.API_URL ? 'media/image/' : '') + (postMedia ? postMedia : \"image/\");\r\n\t/**\r\n\t * Retorna la url del sitio.\r\n\t * @param postMedia \r\n\t * @returns \r\n\t */\r\n\tpublic url = () => this.apiConstants.API_URL.replace(/\\/$/, ''); // remove last slash\t\r\n\t/**\r\n\t * Retorna la url de las imagenes de los banners\r\n\t * @returns \r\n\t */\r\n\tpublic mediaBannerUrl = () => this.ASSETS_URL + (this.ASSETS_URL == this.apiConstants.API_URL ? 'media/' : '') + \"banner-image/\";\r\n\t/**\r\n\t * Retorna `true` si la vista es mobile, `false` caso contrario.\r\n\t * @returns {boolean}\r\n\t */\r\n\tpublic mobileScreen = (): boolean => this.window && this.window?.innerWidth < 750 || false;\r\n\t/**\r\n\t * Contiene los valores para la moneda actual\r\n\t */\r\n\tpublic currency: CurrencyConfig = {\r\n\t\tcode: 'ARG',\r\n\t\tsymbol: '$',\r\n\t\tposition: 'Left',\r\n\t\twithoutDecimal: false\r\n\t};\r\n\r\n\t/**\r\n\t * Arreglo de valores usados para el pipe currencyPrice\r\n\t */\r\n\tpublic currencyTypeConfig: CurrencyConfig[] = [\r\n\t\t{\r\n\t\t\tcode: 'EUR',\r\n\t\t\tsymbol: '€',\r\n\t\t\tposition: 'Right',\r\n\t\t\twithoutDecimal: false\r\n\r\n\t\t},\r\n\t\t{\r\n\t\t\tcode: 'ARG',\r\n\t\t\tsymbol: '$',\r\n\t\t\tposition: 'Left',\r\n\t\t\twithoutDecimal: false\r\n\t\t},\r\n\t\t{\r\n\t\t\tcode: 'ARS',\r\n\t\t\tsymbol: '$',\r\n\t\t\tposition: 'Left',\r\n\t\t\twithoutDecimal: false\r\n\t\t},\r\n\t\t{\r\n\t\t\tcode: 'USD',\r\n\t\t\tsymbol: '$',\r\n\t\t\tposition: 'Left',\r\n\t\t\twithoutDecimal: false\r\n\t\t},\r\n\t\t{\r\n\t\t\tcode: 'PYG',\r\n\t\t\tsymbol: 'Gs.',\r\n\t\t\tposition: 'Left',\r\n\t\t\twithoutDecimal: false\r\n\t\t},\r\n\t\t{\r\n\t\t\tcode: 'PEN',\r\n\t\t\tsymbol: 'S/',\r\n\t\t\tposition: 'Left',\r\n\t\t\twithoutDecimal: false\r\n\t\t},\r\n\t\t{\r\n\t\t\tcode: 'SEK',\r\n\t\t\tsymbol: 'SEK',\r\n\t\t\tposition: 'Right',\r\n\t\t\twithoutDecimal: true\r\n\t\t},\r\n\t]\r\n\t/**\r\n\t * Cambia la configuración de la moneda.\r\n\t * @param currencyTypeConfig Arreglo con las distintas monedas.\r\n\t */\r\n\tpublic setCurrencyTypeConfig(currencyTypeConfig: CurrencyConfig[]) {\r\n\t\tthis.currencyTypeConfig = currencyTypeConfig;\r\n\t}\r\n\r\n\t/**\r\n\t * @param currencyTypeFind Definir el code del tipo de moneda que se quiera utilizar.\r\n\t * Si el tipo es CUSTOM se toman los valores del segundo parametro donde se puede definir la simbología y posesión que se quiera.\r\n\t * @param customType Formato del parámetro ejemplo { code: 'ARG', symbol: '$', position: 'L' , withoutDecimals: false } ,\r\n\t * todas las key son opcionales y por defecto se toman los valores del ejemplo.\r\n\t * @returns se retorna la configuración que se seteo a la propiedad currency del servicio.\r\n\t */\r\n\tpublic setCurrency(currencyTypeFind: currencyType, customType?: CurrencyConfig): CurrencyConfig {\r\n\t\tthis.currency = this.currencyTypeConfig.find((ct: CurrencyConfig) => ct.code == currencyTypeFind.toUpperCase()) || this.currency\r\n\t\tcustomType && (this.currency = { ...this.currency, ...customType })\r\n\t\treturn this.currency;\r\n\t};\r\n\r\n\r\n\tpublic modifyChannelConfig(channelConfig: any) {\r\n\t\tif (channelConfig.channel || channelConfig.code)\r\n\t\t\tthis.apiConstants.setChannel(channelConfig.channel || channelConfig.code)\r\n\r\n\t\tif (channelConfig.locale || channelConfig.locales.code)\r\n\t\t\tthis.apiConstants.setLocale(channelConfig.locale || channelConfig.locales.code)\r\n\r\n\t\tif (channelConfig.currency || channelConfig.baseCurrency)\r\n\t\t\tthis.setCurrency(channelConfig.currency || channelConfig.baseCurrency)\r\n\r\n\t\treturn channelConfig;\r\n\t}\r\n\r\n\t/**\r\n\t* @description se utiliza para configurar que filtros del tipo `SortFilter` se quiere mostrar en la vista.\r\n\t* Se usan los codigo de los filtros para indicar cuales se deben mostrar.\r\n\t*/\r\n\tprivate sortFilters: string[] = ['price', 'order-alph', 'recent']\r\n\r\n\t/**\r\n\t *\r\n\t * @param filtersCode arreglo de strings con los codigos de los filtros.\r\n\t * Si se le pasa el parametro **all** este mostrara todos.\r\n\t * @example price | order-alph | recent | update | all\r\n\t * @returns\r\n\t */\r\n\tsetSortFilters = (filtersCode: string[] = ['all']) => this.sortFilters = filtersCode;\r\n\r\n\tgetSortFilters = () => this.sortFilters;\r\n\r\n\t// ABOUT PRODUCTS \r\n\tprivate productsWithUniqueVariant: boolean = false;\r\n\tsetProductWithUniqueVariant(value: boolean) { this.productsWithUniqueVariant = value; }\r\n\tgetProductWithUniqueVariant() { return this.productsWithUniqueVariant }\r\n\r\n\t/**\r\n\t* @description esta variable se utiliza para configurar los parametros cuando se desea mostrar\r\n\t* variantes el listado de productos.\r\n\t* @param {string}type tipo de options\r\n\t* @param {string}code codigo de options\r\n\t* @param {boolean}defaultFirstOption `true` toma el primer option del producto en general\r\n\t* @param {boolean}checkIfStock `true` se realiza un chequeo de si la variante tiene stock para mostrarla\r\n\t* @example  ```javascript\r\n\t* {\r\n\t   type: 'color',\r\n\t   code: 'color',\r\n\t   defaultFirstOption: false ,\r\n\t   checkIfStock:true\r\n\t   } ```\r\n\t*/\r\n\tprivate paramsProductsWithUniqueVariant: ParamsProductsWithUniqueVariant = {\r\n\t\ttype: 'color',\r\n\t\tcode: 'color',\r\n\t\tdefaultFirstOption: false,\r\n\t\tcheckIfStock: true\r\n\t}\r\n\r\n\tsetParamsProductsWithUniqueVariant = (value: ParamsProductsWithUniqueVariant) => {\r\n\t\tthis.paramsProductsWithUniqueVariant = {\r\n\t\t\t...this.paramsProductsWithUniqueVariant,\r\n\t\t\t...value\r\n\t\t}\r\n\t}\r\n\r\n\tgetParamsProductsWithUniqueVariant = () => this.paramsProductsWithUniqueVariant\r\n\t\r\n\tpublic getChannel(){\r\n\t\treturn this.apiConstants.CHANNEL;\r\n\t}\r\n}\r\n"]}
@@ -58,8 +58,9 @@ export class ProductDetailEcComponent {
58
58
  const currentUrl = this._consts.url() + this._location.path(true); // `true` incluye el query string
59
59
  this._meta.updateTag({ property: 'og:title', content: product.name || '' });
60
60
  this._meta.updateTag({ property: 'og:description', content: descripcionLimpia || '' });
61
- this._meta.updateTag({ property: 'og:image', content: this._consts.mediaUrl(Array.isArray(product.picturesdefault) ? product.picturesdefault[0] : product.picturesdefault) || '' });
61
+ this._meta.updateTag({ property: 'og:image', content: this._consts.mediaImageUrl(Array.isArray(product.picturesdefault) ? product.picturesdefault[0] : product.picturesdefault) || '' });
62
62
  this._meta.updateTag({ property: 'og:url', content: currentUrl });
63
+ this._meta.updateTag({ property: 'og:type', content: 'product' });
63
64
  }
64
65
  sanitizedHtml(html) {
65
66
  return this._domSanitizer.bypassSecurityTrustHtml(html);
@@ -113,4 +114,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
113
114
  type: Component,
114
115
  args: [{ selector: 'app-product-detail-ec', standalone: true, imports: [], template: "" }]
115
116
  }], ctorParameters: () => [] });
116
- //# 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.mediaUrl(Array.isArray(product.picturesdefault) ? product.picturesdefault[0] : product.picturesdefault) || '' });\r\n    this._meta.updateTag({ property: 'og:url', content: currentUrl });\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",""]}
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",""]}
@@ -218,6 +218,12 @@ class CoreConstantsService {
218
218
  * @returns
219
219
  */
220
220
  mediaUrl = (postMedia) => this.ASSETS_URL + (this.ASSETS_URL == this.apiConstants.API_URL ? 'media/' : '') + (postMedia ? postMedia : "image/");
221
+ /**
222
+ * Retorna la url donde se guarda las imagenes.
223
+ * @param postMedia
224
+ * @returns
225
+ */
226
+ mediaImageUrl = (postMedia) => this.ASSETS_URL + (this.ASSETS_URL == this.apiConstants.API_URL ? 'media/image/' : '') + (postMedia ? postMedia : "image/");
221
227
  /**
222
228
  * Retorna la url del sitio.
223
229
  * @param postMedia
@@ -7352,8 +7358,9 @@ class ProductDetailEcComponent {
7352
7358
  const currentUrl = this._consts.url() + this._location.path(true); // `true` incluye el query string
7353
7359
  this._meta.updateTag({ property: 'og:title', content: product.name || '' });
7354
7360
  this._meta.updateTag({ property: 'og:description', content: descripcionLimpia || '' });
7355
- this._meta.updateTag({ property: 'og:image', content: this._consts.mediaUrl(Array.isArray(product.picturesdefault) ? product.picturesdefault[0] : product.picturesdefault) || '' });
7361
+ this._meta.updateTag({ property: 'og:image', content: this._consts.mediaImageUrl(Array.isArray(product.picturesdefault) ? product.picturesdefault[0] : product.picturesdefault) || '' });
7356
7362
  this._meta.updateTag({ property: 'og:url', content: currentUrl });
7363
+ this._meta.updateTag({ property: 'og:type', content: 'product' });
7357
7364
  }
7358
7365
  sanitizedHtml(html) {
7359
7366
  return this._domSanitizer.bypassSecurityTrustHtml(html);