ng-easycommerce-v18 0.3.18-beta.1 → 0.3.19-beta.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +2 -3
- package/assets/ec-i18n/en.json +1 -0
- package/assets/ec-i18n/es.json +1 -0
- package/esm2022/lib/constants/api.constants.service.mjs +15 -19
- package/esm2022/lib/ec-components/blocks-ec/block-products-ec/block-products-ec.component.mjs +2 -4
- package/esm2022/lib/ec-components/cart-ec/cart-item-ec/cart-item-ec.component.mjs +37 -9
- package/esm2022/lib/ec-components/header-ec/header-ec.component.mjs +21 -31
- package/esm2022/lib/ec-components/product-ec/product-ec.component.mjs +54 -6
- package/esm2022/lib/ec-services/analytics/google-analytics.service.mjs +2 -2
- package/esm2022/lib/ec-services/cart.service.mjs +22 -4
- package/esm2022/lib/ec-services/checkout.service.mjs +2 -4
- package/esm2022/lib/ec-services/index.mjs +1 -3
- package/esm2022/lib/ec-services/product-detail.service.mjs +11 -1
- package/esm2022/lib/interfaces/environment.mjs +1 -1
- package/esm2022/lib/interfaces/index.mjs +1 -2
- package/esm2022/lib/interfaces/product.mjs +1 -1
- package/esm2022/lib/providers/index.mjs +1 -2
- package/fesm2022/ng-easycommerce-v18.mjs +215 -451
- package/fesm2022/ng-easycommerce-v18.mjs.map +1 -1
- package/lib/constants/api.constants.service.d.ts +0 -1
- package/lib/ec-components/cart-ec/cart-item-ec/cart-item-ec.component.d.ts +1 -1
- package/lib/ec-components/product-ec/product-ec.component.d.ts +4 -0
- package/lib/ec-services/cart.service.d.ts +1 -1
- package/lib/ec-services/index.d.ts +0 -2
- package/lib/interfaces/environment.d.ts +0 -1
- package/lib/interfaces/index.d.ts +0 -1
- package/lib/interfaces/product.d.ts +6 -0
- package/lib/providers/index.d.ts +0 -1
- package/package.json +1 -1
- package/esm2022/lib/ec-services/base-api.service.mjs +0 -148
- package/esm2022/lib/ec-services/runtime-config.service.mjs +0 -149
- package/esm2022/lib/interfaces/runtime-config.mjs +0 -2
- package/esm2022/lib/providers/provideRuntimeConfig.mjs +0 -39
- package/lib/ec-services/base-api.service.d.ts +0 -64
- package/lib/ec-services/runtime-config.service.d.ts +0 -56
- package/lib/interfaces/runtime-config.d.ts +0 -22
- package/lib/providers/provideRuntimeConfig.d.ts +0 -12
|
@@ -16,8 +16,8 @@ export declare class CartItemEcComponent implements OnInit {
|
|
|
16
16
|
isQuantityUpdating: boolean;
|
|
17
17
|
ngOnInit(): void;
|
|
18
18
|
updateQuantity(stock: number): void;
|
|
19
|
-
less(stock: number, value?: number): void;
|
|
20
19
|
plus(stock: number, value?: number): void;
|
|
20
|
+
less(stock: number, value?: number): void;
|
|
21
21
|
deleteCartItem(): void;
|
|
22
22
|
getVariants(product: any): any;
|
|
23
23
|
createDiscountMessage(saleprice: number, price: number): string;
|
|
@@ -50,6 +50,10 @@ export declare class ProductEcComponent implements OnInit {
|
|
|
50
50
|
plus(stock?: number, multipleQuantity?: number): void;
|
|
51
51
|
less(multipleQuantity?: number): void;
|
|
52
52
|
addToCart(): void;
|
|
53
|
+
/**
|
|
54
|
+
* Valida las restricciones de cantidad del producto
|
|
55
|
+
*/
|
|
56
|
+
private validateQuantity;
|
|
53
57
|
checkStock(stock: number): void;
|
|
54
58
|
onQuantityChange(event: Event): void;
|
|
55
59
|
static ɵfac: i0.ɵɵFactoryDeclaration<ProductEcComponent, never>;
|
|
@@ -115,7 +115,7 @@ export declare class CartService {
|
|
|
115
115
|
* @param item el item a actualizar.
|
|
116
116
|
* @param quantity la cantidad nueva.
|
|
117
117
|
*/
|
|
118
|
-
updateItemQuantity(item: CartItem, quantity: number):
|
|
118
|
+
updateItemQuantity(item: CartItem, quantity: number): boolean;
|
|
119
119
|
/**
|
|
120
120
|
* Maneja el error en caso de que no se pueda agregar al carrito el producto.
|
|
121
121
|
* @param err
|
|
@@ -5,6 +5,9 @@ export interface OptionValue {
|
|
|
5
5
|
name: string;
|
|
6
6
|
description?: string;
|
|
7
7
|
selected?: boolean;
|
|
8
|
+
maximumItemsQuantity?: number;
|
|
9
|
+
minimumItemsQuantity?: number;
|
|
10
|
+
multipleQuantity?: number;
|
|
8
11
|
}
|
|
9
12
|
export interface Options {
|
|
10
13
|
code: string;
|
|
@@ -34,6 +37,9 @@ export interface Product {
|
|
|
34
37
|
productWithUniqueVariant?: Product[];
|
|
35
38
|
stock?: number;
|
|
36
39
|
variant_id?: number;
|
|
40
|
+
maximumItemsQuantity?: number;
|
|
41
|
+
minimumItemsQuantity?: number;
|
|
42
|
+
multipleQuantity?: number;
|
|
37
43
|
}
|
|
38
44
|
export interface ProductToCartItem {
|
|
39
45
|
productCode?: string;
|
package/lib/providers/index.d.ts
CHANGED
package/package.json
CHANGED
|
@@ -1,148 +0,0 @@
|
|
|
1
|
-
import { Injectable } from '@angular/core';
|
|
2
|
-
import { HttpHeaders } from '@angular/common/http';
|
|
3
|
-
import { switchMap } from 'rxjs';
|
|
4
|
-
import * as i0 from "@angular/core";
|
|
5
|
-
import * as i1 from "@angular/common/http";
|
|
6
|
-
import * as i2 from "./runtime-config.service";
|
|
7
|
-
/**
|
|
8
|
-
* Servicio base para realizar peticiones HTTP usando configuración dinámica
|
|
9
|
-
* Todos los servicios de la aplicación deben extender este servicio o usar sus métodos
|
|
10
|
-
*/
|
|
11
|
-
export class BaseApiService {
|
|
12
|
-
http;
|
|
13
|
-
runtimeConfigService;
|
|
14
|
-
constructor(http, runtimeConfigService) {
|
|
15
|
-
this.http = http;
|
|
16
|
-
this.runtimeConfigService = runtimeConfigService;
|
|
17
|
-
}
|
|
18
|
-
/**
|
|
19
|
-
* Construye una URL completa usando la API_URL del runtime
|
|
20
|
-
*/
|
|
21
|
-
buildApiUrl(endpoint) {
|
|
22
|
-
return this.runtimeConfigService.buildApiUrl(endpoint);
|
|
23
|
-
}
|
|
24
|
-
/**
|
|
25
|
-
* Obtiene headers comunes que incluyen información del runtime
|
|
26
|
-
*/
|
|
27
|
-
getCommonHeaders() {
|
|
28
|
-
const config = this.runtimeConfigService.getConfig();
|
|
29
|
-
let headers = new HttpHeaders({
|
|
30
|
-
'Content-Type': 'application/json'
|
|
31
|
-
});
|
|
32
|
-
if (config) {
|
|
33
|
-
headers = headers
|
|
34
|
-
.set('X-Channel', config.channel)
|
|
35
|
-
.set('X-Locale', config.locale)
|
|
36
|
-
.set('X-Environment', config.appEnv);
|
|
37
|
-
}
|
|
38
|
-
return headers;
|
|
39
|
-
}
|
|
40
|
-
/**
|
|
41
|
-
* Método GET genérico
|
|
42
|
-
*/
|
|
43
|
-
get(endpoint, options = {}) {
|
|
44
|
-
const url = this.buildApiUrl(endpoint);
|
|
45
|
-
const headers = this.mergeHeaders(options.headers);
|
|
46
|
-
return this.http.get(url, {
|
|
47
|
-
...options,
|
|
48
|
-
headers
|
|
49
|
-
});
|
|
50
|
-
}
|
|
51
|
-
/**
|
|
52
|
-
* Método POST genérico
|
|
53
|
-
*/
|
|
54
|
-
post(endpoint, data, options = {}) {
|
|
55
|
-
const url = this.buildApiUrl(endpoint);
|
|
56
|
-
const headers = this.mergeHeaders(options.headers);
|
|
57
|
-
return this.http.post(url, data, {
|
|
58
|
-
...options,
|
|
59
|
-
headers
|
|
60
|
-
});
|
|
61
|
-
}
|
|
62
|
-
/**
|
|
63
|
-
* Método PUT genérico
|
|
64
|
-
*/
|
|
65
|
-
put(endpoint, data, options = {}) {
|
|
66
|
-
const url = this.buildApiUrl(endpoint);
|
|
67
|
-
const headers = this.mergeHeaders(options.headers);
|
|
68
|
-
return this.http.put(url, data, {
|
|
69
|
-
...options,
|
|
70
|
-
headers
|
|
71
|
-
});
|
|
72
|
-
}
|
|
73
|
-
/**
|
|
74
|
-
* Método PATCH genérico
|
|
75
|
-
*/
|
|
76
|
-
patch(endpoint, data, options = {}) {
|
|
77
|
-
const url = this.buildApiUrl(endpoint);
|
|
78
|
-
const headers = this.mergeHeaders(options.headers);
|
|
79
|
-
return this.http.patch(url, data, {
|
|
80
|
-
...options,
|
|
81
|
-
headers
|
|
82
|
-
});
|
|
83
|
-
}
|
|
84
|
-
/**
|
|
85
|
-
* Método DELETE genérico
|
|
86
|
-
*/
|
|
87
|
-
delete(endpoint, options = {}) {
|
|
88
|
-
const url = this.buildApiUrl(endpoint);
|
|
89
|
-
const headers = this.mergeHeaders(options.headers);
|
|
90
|
-
return this.http.delete(url, {
|
|
91
|
-
...options,
|
|
92
|
-
headers
|
|
93
|
-
});
|
|
94
|
-
}
|
|
95
|
-
/**
|
|
96
|
-
* Método para peticiones que necesitan esperar a que la config esté cargada
|
|
97
|
-
*/
|
|
98
|
-
getWithConfig(endpoint, options = {}) {
|
|
99
|
-
return this.runtimeConfigService.config$.pipe(switchMap(config => {
|
|
100
|
-
if (!config) {
|
|
101
|
-
throw new Error('Runtime config not loaded');
|
|
102
|
-
}
|
|
103
|
-
return this.get(endpoint, options);
|
|
104
|
-
}));
|
|
105
|
-
}
|
|
106
|
-
/**
|
|
107
|
-
* Método para POST que necesitan esperar a que la config esté cargada
|
|
108
|
-
*/
|
|
109
|
-
postWithConfig(endpoint, data, options = {}) {
|
|
110
|
-
return this.runtimeConfigService.config$.pipe(switchMap(config => {
|
|
111
|
-
if (!config) {
|
|
112
|
-
throw new Error('Runtime config not loaded');
|
|
113
|
-
}
|
|
114
|
-
return this.post(endpoint, data, options);
|
|
115
|
-
}));
|
|
116
|
-
}
|
|
117
|
-
/**
|
|
118
|
-
* Combina headers personalizados con los headers comunes
|
|
119
|
-
*/
|
|
120
|
-
mergeHeaders(customHeaders) {
|
|
121
|
-
let headers = this.getCommonHeaders();
|
|
122
|
-
if (customHeaders) {
|
|
123
|
-
if (customHeaders instanceof HttpHeaders) {
|
|
124
|
-
customHeaders.keys().forEach(key => {
|
|
125
|
-
const values = customHeaders.getAll(key);
|
|
126
|
-
if (values) {
|
|
127
|
-
headers = headers.set(key, values);
|
|
128
|
-
}
|
|
129
|
-
});
|
|
130
|
-
}
|
|
131
|
-
else {
|
|
132
|
-
Object.keys(customHeaders).forEach(key => {
|
|
133
|
-
headers = headers.set(key, customHeaders[key]);
|
|
134
|
-
});
|
|
135
|
-
}
|
|
136
|
-
}
|
|
137
|
-
return headers;
|
|
138
|
-
}
|
|
139
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: BaseApiService, deps: [{ token: i1.HttpClient }, { token: i2.RuntimeConfigService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
140
|
-
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: BaseApiService, providedIn: 'root' });
|
|
141
|
-
}
|
|
142
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: BaseApiService, decorators: [{
|
|
143
|
-
type: Injectable,
|
|
144
|
-
args: [{
|
|
145
|
-
providedIn: 'root'
|
|
146
|
-
}]
|
|
147
|
-
}], ctorParameters: () => [{ type: i1.HttpClient }, { type: i2.RuntimeConfigService }] });
|
|
148
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-api.service.js","sourceRoot":"","sources":["../../../../../projects/ng-easycommerce-v18/src/lib/ec-services/base-api.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\nimport { HttpClient, HttpHeaders, HttpParams } from '@angular/common/http';\r\nimport { Observable, switchMap } from 'rxjs';\r\nimport { RuntimeConfigService } from './runtime-config.service';\r\n\r\nexport interface ApiRequestOptions {\r\n  headers?: HttpHeaders | { [header: string]: string | string[] };\r\n  params?: HttpParams | { [param: string]: string | string[] };\r\n  withCredentials?: boolean;\r\n}\r\n\r\n/**\r\n * Servicio base para realizar peticiones HTTP usando configuración dinámica\r\n * Todos los servicios de la aplicación deben extender este servicio o usar sus métodos\r\n */\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class BaseApiService {\r\n  \r\n  constructor(\r\n    protected http: HttpClient,\r\n    protected runtimeConfigService: RuntimeConfigService\r\n  ) {}\r\n\r\n  /**\r\n   * Construye una URL completa usando la API_URL del runtime\r\n   */\r\n  protected buildApiUrl(endpoint: string): string {\r\n    return this.runtimeConfigService.buildApiUrl(endpoint);\r\n  }\r\n\r\n  /**\r\n   * Obtiene headers comunes que incluyen información del runtime\r\n   */\r\n  protected getCommonHeaders(): HttpHeaders {\r\n    const config = this.runtimeConfigService.getConfig();\r\n    let headers = new HttpHeaders({\r\n      'Content-Type': 'application/json'\r\n    });\r\n\r\n    if (config) {\r\n      headers = headers\r\n        .set('X-Channel', config.channel)\r\n        .set('X-Locale', config.locale)\r\n        .set('X-Environment', config.appEnv);\r\n    }\r\n\r\n    return headers;\r\n  }\r\n\r\n  /**\r\n   * Método GET genérico\r\n   */\r\n  get<T>(endpoint: string, options: ApiRequestOptions = {}): Observable<T> {\r\n    const url = this.buildApiUrl(endpoint);\r\n    const headers = this.mergeHeaders(options.headers);\r\n    \r\n    return this.http.get<T>(url, {\r\n      ...options,\r\n      headers\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Método POST genérico\r\n   */\r\n  post<T>(endpoint: string, data: any, options: ApiRequestOptions = {}): Observable<T> {\r\n    const url = this.buildApiUrl(endpoint);\r\n    const headers = this.mergeHeaders(options.headers);\r\n\r\n    return this.http.post<T>(url, data, {\r\n      ...options,\r\n      headers\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Método PUT genérico\r\n   */\r\n  put<T>(endpoint: string, data: any, options: ApiRequestOptions = {}): Observable<T> {\r\n    const url = this.buildApiUrl(endpoint);\r\n    const headers = this.mergeHeaders(options.headers);\r\n\r\n    return this.http.put<T>(url, data, {\r\n      ...options,\r\n      headers\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Método PATCH genérico\r\n   */\r\n  patch<T>(endpoint: string, data: any, options: ApiRequestOptions = {}): Observable<T> {\r\n    const url = this.buildApiUrl(endpoint);\r\n    const headers = this.mergeHeaders(options.headers);\r\n\r\n    return this.http.patch<T>(url, data, {\r\n      ...options,\r\n      headers\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Método DELETE genérico\r\n   */\r\n  delete<T>(endpoint: string, options: ApiRequestOptions = {}): Observable<T> {\r\n    const url = this.buildApiUrl(endpoint);\r\n    const headers = this.mergeHeaders(options.headers);\r\n\r\n    return this.http.delete<T>(url, {\r\n      ...options,\r\n      headers\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Método para peticiones que necesitan esperar a que la config esté cargada\r\n   */\r\n  getWithConfig<T>(endpoint: string, options: ApiRequestOptions = {}): Observable<T> {\r\n    return this.runtimeConfigService.config$.pipe(\r\n      switchMap(config => {\r\n        if (!config) {\r\n          throw new Error('Runtime config not loaded');\r\n        }\r\n        return this.get<T>(endpoint, options);\r\n      })\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Método para POST que necesitan esperar a que la config esté cargada\r\n   */\r\n  postWithConfig<T>(endpoint: string, data: any, options: ApiRequestOptions = {}): Observable<T> {\r\n    return this.runtimeConfigService.config$.pipe(\r\n      switchMap(config => {\r\n        if (!config) {\r\n          throw new Error('Runtime config not loaded');\r\n        }\r\n        return this.post<T>(endpoint, data, options);\r\n      })\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Combina headers personalizados con los headers comunes\r\n   */\r\n  private mergeHeaders(customHeaders?: HttpHeaders | { [header: string]: string | string[] }): HttpHeaders {\r\n    let headers = this.getCommonHeaders();\r\n\r\n    if (customHeaders) {\r\n      if (customHeaders instanceof HttpHeaders) {\r\n        customHeaders.keys().forEach(key => {\r\n          const values = customHeaders.getAll(key);\r\n          if (values) {\r\n            headers = headers.set(key, values);\r\n          }\r\n        });\r\n      } else {\r\n        Object.keys(customHeaders).forEach(key => {\r\n          headers = headers.set(key, customHeaders[key]);\r\n        });\r\n      }\r\n    }\r\n\r\n    return headers;\r\n  }\r\n}"]}
|
|
@@ -1,149 +0,0 @@
|
|
|
1
|
-
import { Injectable, Inject, PLATFORM_ID } from '@angular/core';
|
|
2
|
-
import { isPlatformBrowser } from '@angular/common';
|
|
3
|
-
import { of, BehaviorSubject } from 'rxjs';
|
|
4
|
-
import { catchError, tap } from 'rxjs/operators';
|
|
5
|
-
import * as i0 from "@angular/core";
|
|
6
|
-
import * as i1 from "@angular/common/http";
|
|
7
|
-
export class RuntimeConfigService {
|
|
8
|
-
platformId;
|
|
9
|
-
http;
|
|
10
|
-
configSubject = new BehaviorSubject(null);
|
|
11
|
-
config$ = this.configSubject.asObservable();
|
|
12
|
-
_config = null;
|
|
13
|
-
constructor(platformId, http) {
|
|
14
|
-
this.platformId = platformId;
|
|
15
|
-
this.http = http;
|
|
16
|
-
}
|
|
17
|
-
/**
|
|
18
|
-
* Carga la configuración en runtime
|
|
19
|
-
* - En SSR: Lee desde el objeto window inyectado por el servidor
|
|
20
|
-
* - En Browser: Hace petición HTTP a /runtime-config.json
|
|
21
|
-
*/
|
|
22
|
-
loadConfig() {
|
|
23
|
-
// Si ya tenemos la config cargada, la devolvemos
|
|
24
|
-
if (this._config) {
|
|
25
|
-
return of(this._config);
|
|
26
|
-
}
|
|
27
|
-
if (isPlatformBrowser(this.platformId)) {
|
|
28
|
-
// En el navegador, primero intentamos obtener la config desde window
|
|
29
|
-
if (window.__RUNTIME_CONFIG__) {
|
|
30
|
-
this._config = window.__RUNTIME_CONFIG__;
|
|
31
|
-
this.configSubject.next(this._config);
|
|
32
|
-
return of(this._config);
|
|
33
|
-
}
|
|
34
|
-
// Si no está en window, hacemos petición HTTP
|
|
35
|
-
return this.http.get('/runtime-config.json').pipe(tap(config => {
|
|
36
|
-
this._config = config;
|
|
37
|
-
this.configSubject.next(config);
|
|
38
|
-
// Guardamos en window para siguientes accesos
|
|
39
|
-
window.__RUNTIME_CONFIG__ = config;
|
|
40
|
-
}), catchError(error => {
|
|
41
|
-
console.error('Error loading runtime config:', error);
|
|
42
|
-
// Fallback config si falla la carga
|
|
43
|
-
const fallbackConfig = {
|
|
44
|
-
apiUrl: 'https://elden-preprod.backend.easycommerce.com.ar/',
|
|
45
|
-
appEnv: 'preprod',
|
|
46
|
-
production: false,
|
|
47
|
-
locale: 'es_AR',
|
|
48
|
-
channel: 'minorista'
|
|
49
|
-
};
|
|
50
|
-
this._config = fallbackConfig;
|
|
51
|
-
this.configSubject.next(fallbackConfig);
|
|
52
|
-
return of(fallbackConfig);
|
|
53
|
-
}));
|
|
54
|
-
}
|
|
55
|
-
else {
|
|
56
|
-
// En SSR, leemos desde window que fue inyectado por el servidor
|
|
57
|
-
if (typeof window !== 'undefined' && window.__RUNTIME_CONFIG__) {
|
|
58
|
-
this._config = window.__RUNTIME_CONFIG__;
|
|
59
|
-
this.configSubject.next(this._config);
|
|
60
|
-
return of(this._config);
|
|
61
|
-
}
|
|
62
|
-
// Fallback para SSR si no hay config inyectada
|
|
63
|
-
// En el servidor, las variables de entorno se configuran desde el server.ts
|
|
64
|
-
const fallbackConfig = {
|
|
65
|
-
apiUrl: 'https://elden-preprod.backend.easycommerce.com.ar/',
|
|
66
|
-
appEnv: 'preprod',
|
|
67
|
-
production: false,
|
|
68
|
-
locale: 'es_AR',
|
|
69
|
-
channel: 'minorista'
|
|
70
|
-
};
|
|
71
|
-
this._config = fallbackConfig;
|
|
72
|
-
this.configSubject.next(fallbackConfig);
|
|
73
|
-
return of(fallbackConfig);
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
/**
|
|
77
|
-
* Obtiene la configuración actual (síncrono)
|
|
78
|
-
*/
|
|
79
|
-
getConfig() {
|
|
80
|
-
return this._config;
|
|
81
|
-
}
|
|
82
|
-
/**
|
|
83
|
-
* Obtiene la API URL actual
|
|
84
|
-
*/
|
|
85
|
-
getApiUrl() {
|
|
86
|
-
return this._config?.apiUrl || 'https://elden-preprod.backend.easycommerce.com.ar/';
|
|
87
|
-
}
|
|
88
|
-
/**
|
|
89
|
-
* Obtiene la Frontend URL actual
|
|
90
|
-
*/
|
|
91
|
-
getFrontendUrl() {
|
|
92
|
-
return this._config?.frontendUrl;
|
|
93
|
-
}
|
|
94
|
-
/**
|
|
95
|
-
* Obtiene el entorno actual
|
|
96
|
-
*/
|
|
97
|
-
getAppEnv() {
|
|
98
|
-
return this._config?.appEnv || 'development';
|
|
99
|
-
}
|
|
100
|
-
/**
|
|
101
|
-
* Verifica si estamos en producción
|
|
102
|
-
*/
|
|
103
|
-
isProduction() {
|
|
104
|
-
return this._config?.production || false;
|
|
105
|
-
}
|
|
106
|
-
/**
|
|
107
|
-
* Obtiene el locale actual
|
|
108
|
-
*/
|
|
109
|
-
getLocale() {
|
|
110
|
-
return this._config?.locale || 'es_AR';
|
|
111
|
-
}
|
|
112
|
-
/**
|
|
113
|
-
* Obtiene el canal actual
|
|
114
|
-
*/
|
|
115
|
-
getChannel() {
|
|
116
|
-
return this._config?.channel || 'minorista';
|
|
117
|
-
}
|
|
118
|
-
/**
|
|
119
|
-
* Método helper para construir URLs de API
|
|
120
|
-
*/
|
|
121
|
-
buildApiUrl(endpoint) {
|
|
122
|
-
const apiUrl = this.getApiUrl();
|
|
123
|
-
const cleanEndpoint = endpoint.startsWith('/') ? endpoint.slice(1) : endpoint;
|
|
124
|
-
return `${apiUrl}${cleanEndpoint}`;
|
|
125
|
-
}
|
|
126
|
-
/**
|
|
127
|
-
* Método helper para construir URLs del frontend
|
|
128
|
-
*/
|
|
129
|
-
buildFrontendUrl(path) {
|
|
130
|
-
const frontendUrl = this.getFrontendUrl();
|
|
131
|
-
if (!frontendUrl) {
|
|
132
|
-
return path;
|
|
133
|
-
}
|
|
134
|
-
const cleanPath = path.startsWith('/') ? path.slice(1) : path;
|
|
135
|
-
return `${frontendUrl}${cleanPath}`;
|
|
136
|
-
}
|
|
137
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: RuntimeConfigService, deps: [{ token: PLATFORM_ID }, { token: i1.HttpClient }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
138
|
-
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: RuntimeConfigService, providedIn: 'root' });
|
|
139
|
-
}
|
|
140
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: RuntimeConfigService, decorators: [{
|
|
141
|
-
type: Injectable,
|
|
142
|
-
args: [{
|
|
143
|
-
providedIn: 'root'
|
|
144
|
-
}]
|
|
145
|
-
}], ctorParameters: () => [{ type: Object, decorators: [{
|
|
146
|
-
type: Inject,
|
|
147
|
-
args: [PLATFORM_ID]
|
|
148
|
-
}] }, { type: i1.HttpClient }] });
|
|
149
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"runtime-config.service.js","sourceRoot":"","sources":["../../../../../projects/ng-easycommerce-v18/src/lib/ec-services/runtime-config.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAChE,OAAO,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;AAEpD,OAAO,EAAc,EAAE,EAAE,eAAe,EAAE,MAAM,MAAM,CAAC;AACvD,OAAO,EAAE,UAAU,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;;;AAQjD,MAAM,OAAO,oBAAoB;IAOA;IACrB;IAPF,aAAa,GAAG,IAAI,eAAe,CAAuB,IAAI,CAAC,CAAC;IACjE,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC,YAAY,EAAE,CAAC;IAE3C,OAAO,GAAyB,IAAI,CAAC;IAE7C,YAC+B,UAAkB,EACvC,IAAgB;QADK,eAAU,GAAV,UAAU,CAAQ;QACvC,SAAI,GAAJ,IAAI,CAAY;IACvB,CAAC;IAEJ;;;;OAIG;IACH,UAAU;QACR,iDAAiD;QACjD,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,OAAO,EAAE,CAAC,IAAI,CAAC,OAAwB,CAAC,CAAC;QAC3C,CAAC;QAED,IAAI,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;YACvC,qEAAqE;YACrE,IAAI,MAAM,CAAC,kBAAkB,EAAE,CAAC;gBAC9B,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,kBAAkB,CAAC;gBACzC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;gBACtC,OAAO,EAAE,CAAC,IAAI,CAAC,OAAwB,CAAC,CAAC;YAC3C,CAAC;YAED,8CAA8C;YAC9C,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAgB,sBAAsB,CAAC,CAAC,IAAI,CAC9D,GAAG,CAAC,MAAM,CAAC,EAAE;gBACX,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC;gBACtB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;gBAChC,8CAA8C;gBAC9C,MAAM,CAAC,kBAAkB,GAAG,MAAM,CAAC;YACrC,CAAC,CAAC,EACF,UAAU,CAAC,KAAK,CAAC,EAAE;gBACjB,OAAO,CAAC,KAAK,CAAC,+BAA+B,EAAE,KAAK,CAAC,CAAC;gBACtD,oCAAoC;gBACpC,MAAM,cAAc,GAAkB;oBACpC,MAAM,EAAE,oDAAoD;oBAC5D,MAAM,EAAE,SAAS;oBACjB,UAAU,EAAE,KAAK;oBACjB,MAAM,EAAE,OAAO;oBACf,OAAO,EAAE,WAAW;iBACrB,CAAC;gBACF,IAAI,CAAC,OAAO,GAAG,cAAc,CAAC;gBAC9B,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;gBACxC,OAAO,EAAE,CAAC,cAAc,CAAC,CAAC;YAC5B,CAAC,CAAC,CACH,CAAC;QACJ,CAAC;aAAM,CAAC;YACN,gEAAgE;YAChE,IAAI,OAAO,MAAM,KAAK,WAAW,IAAI,MAAM,CAAC,kBAAkB,EAAE,CAAC;gBAC/D,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,kBAAkB,CAAC;gBACzC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;gBACtC,OAAO,EAAE,CAAC,IAAI,CAAC,OAAwB,CAAC,CAAC;YAC3C,CAAC;YAED,+CAA+C;YAC/C,4EAA4E;YAC5E,MAAM,cAAc,GAAkB;gBACpC,MAAM,EAAE,oDAAoD;gBAC5D,MAAM,EAAE,SAAS;gBACjB,UAAU,EAAE,KAAK;gBACjB,MAAM,EAAE,OAAO;gBACf,OAAO,EAAE,WAAW;aACrB,CAAC;YAEF,IAAI,CAAC,OAAO,GAAG,cAAc,CAAC;YAC9B,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;YACxC,OAAO,EAAE,CAAC,cAAc,CAAC,CAAC;QAC5B,CAAC;IACH,CAAC;IAED;;OAEG;IACH,SAAS;QACP,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAED;;OAEG;IACH,SAAS;QACP,OAAO,IAAI,CAAC,OAAO,EAAE,MAAM,IAAI,oDAAoD,CAAC;IACtF,CAAC;IAED;;OAEG;IACH,cAAc;QACZ,OAAO,IAAI,CAAC,OAAO,EAAE,WAAW,CAAC;IACnC,CAAC;IAED;;OAEG;IACH,SAAS;QACP,OAAO,IAAI,CAAC,OAAO,EAAE,MAAM,IAAI,aAAa,CAAC;IAC/C,CAAC;IAED;;OAEG;IACH,YAAY;QACV,OAAO,IAAI,CAAC,OAAO,EAAE,UAAU,IAAI,KAAK,CAAC;IAC3C,CAAC;IAED;;OAEG;IACH,SAAS;QACP,OAAO,IAAI,CAAC,OAAO,EAAE,MAAM,IAAI,OAAO,CAAC;IACzC,CAAC;IAED;;OAEG;IACH,UAAU;QACR,OAAO,IAAI,CAAC,OAAO,EAAE,OAAO,IAAI,WAAW,CAAC;IAC9C,CAAC;IAED;;OAEG;IACH,WAAW,CAAC,QAAgB;QAC1B,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC;QAChC,MAAM,aAAa,GAAG,QAAQ,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC;QAC9E,OAAO,GAAG,MAAM,GAAG,aAAa,EAAE,CAAC;IACrC,CAAC;IAED;;OAEG;IACH,gBAAgB,CAAC,IAAY;QAC3B,MAAM,WAAW,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;QAC1C,IAAI,CAAC,WAAW,EAAE,CAAC;YACjB,OAAO,IAAI,CAAC;QACd,CAAC;QACD,MAAM,SAAS,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;QAC9D,OAAO,GAAG,WAAW,GAAG,SAAS,EAAE,CAAC;IACtC,CAAC;wGAjJU,oBAAoB,kBAOrB,WAAW;4GAPV,oBAAoB,cAFnB,MAAM;;4FAEP,oBAAoB;kBAHhC,UAAU;mBAAC;oBACV,UAAU,EAAE,MAAM;iBACnB;;0BAQI,MAAM;2BAAC,WAAW","sourcesContent":["import { Injectable, Inject, PLATFORM_ID } from '@angular/core';\r\nimport { isPlatformBrowser } from '@angular/common';\r\nimport { HttpClient } from '@angular/common/http';\r\nimport { Observable, of, BehaviorSubject } from 'rxjs';\r\nimport { catchError, tap } from 'rxjs/operators';\r\nimport { RuntimeConfig } from '../interfaces/runtime-config';\r\n\r\ndeclare const window: any;\r\n\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class RuntimeConfigService {\r\n  private configSubject = new BehaviorSubject<RuntimeConfig | null>(null);\r\n  public config$ = this.configSubject.asObservable();\r\n  \r\n  private _config: RuntimeConfig | null = null;\r\n\r\n  constructor(\r\n    @Inject(PLATFORM_ID) private platformId: Object,\r\n    private http: HttpClient\r\n  ) {}\r\n\r\n  /**\r\n   * Carga la configuración en runtime\r\n   * - En SSR: Lee desde el objeto window inyectado por el servidor\r\n   * - En Browser: Hace petición HTTP a /runtime-config.json\r\n   */\r\n  loadConfig(): Observable<RuntimeConfig> {\r\n    // Si ya tenemos la config cargada, la devolvemos\r\n    if (this._config) {\r\n      return of(this._config as RuntimeConfig);\r\n    }\r\n\r\n    if (isPlatformBrowser(this.platformId)) {\r\n      // En el navegador, primero intentamos obtener la config desde window\r\n      if (window.__RUNTIME_CONFIG__) {\r\n        this._config = window.__RUNTIME_CONFIG__;\r\n        this.configSubject.next(this._config);\r\n        return of(this._config as RuntimeConfig);\r\n      }\r\n\r\n      // Si no está en window, hacemos petición HTTP\r\n      return this.http.get<RuntimeConfig>('/runtime-config.json').pipe(\r\n        tap(config => {\r\n          this._config = config;\r\n          this.configSubject.next(config);\r\n          // Guardamos en window para siguientes accesos\r\n          window.__RUNTIME_CONFIG__ = config;\r\n        }),\r\n        catchError(error => {\r\n          console.error('Error loading runtime config:', error);\r\n          // Fallback config si falla la carga\r\n          const fallbackConfig: RuntimeConfig = {\r\n            apiUrl: 'https://elden-preprod.backend.easycommerce.com.ar/',\r\n            appEnv: 'preprod',\r\n            production: false,\r\n            locale: 'es_AR',\r\n            channel: 'minorista'\r\n          };\r\n          this._config = fallbackConfig;\r\n          this.configSubject.next(fallbackConfig);\r\n          return of(fallbackConfig);\r\n        })\r\n      );\r\n    } else {\r\n      // En SSR, leemos desde window que fue inyectado por el servidor\r\n      if (typeof window !== 'undefined' && window.__RUNTIME_CONFIG__) {\r\n        this._config = window.__RUNTIME_CONFIG__;\r\n        this.configSubject.next(this._config);\r\n        return of(this._config as RuntimeConfig);\r\n      }\r\n\r\n      // Fallback para SSR si no hay config inyectada\r\n      // En el servidor, las variables de entorno se configuran desde el server.ts\r\n      const fallbackConfig: RuntimeConfig = {\r\n        apiUrl: 'https://elden-preprod.backend.easycommerce.com.ar/',\r\n        appEnv: 'preprod',\r\n        production: false,\r\n        locale: 'es_AR',\r\n        channel: 'minorista'\r\n      };\r\n      \r\n      this._config = fallbackConfig;\r\n      this.configSubject.next(fallbackConfig);\r\n      return of(fallbackConfig);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Obtiene la configuración actual (síncrono)\r\n   */\r\n  getConfig(): RuntimeConfig | null {\r\n    return this._config;\r\n  }\r\n\r\n  /**\r\n   * Obtiene la API URL actual\r\n   */\r\n  getApiUrl(): string {\r\n    return this._config?.apiUrl || 'https://elden-preprod.backend.easycommerce.com.ar/';\r\n  }\r\n\r\n  /**\r\n   * Obtiene la Frontend URL actual\r\n   */\r\n  getFrontendUrl(): string | undefined {\r\n    return this._config?.frontendUrl;\r\n  }\r\n\r\n  /**\r\n   * Obtiene el entorno actual\r\n   */\r\n  getAppEnv(): string {\r\n    return this._config?.appEnv || 'development';\r\n  }\r\n\r\n  /**\r\n   * Verifica si estamos en producción\r\n   */\r\n  isProduction(): boolean {\r\n    return this._config?.production || false;\r\n  }\r\n\r\n  /**\r\n   * Obtiene el locale actual\r\n   */\r\n  getLocale(): string {\r\n    return this._config?.locale || 'es_AR';\r\n  }\r\n\r\n  /**\r\n   * Obtiene el canal actual\r\n   */\r\n  getChannel(): string {\r\n    return this._config?.channel || 'minorista';\r\n  }\r\n\r\n  /**\r\n   * Método helper para construir URLs de API\r\n   */\r\n  buildApiUrl(endpoint: string): string {\r\n    const apiUrl = this.getApiUrl();\r\n    const cleanEndpoint = endpoint.startsWith('/') ? endpoint.slice(1) : endpoint;\r\n    return `${apiUrl}${cleanEndpoint}`;\r\n  }\r\n\r\n  /**\r\n   * Método helper para construir URLs del frontend\r\n   */\r\n  buildFrontendUrl(path: string): string {\r\n    const frontendUrl = this.getFrontendUrl();\r\n    if (!frontendUrl) {\r\n      return path;\r\n    }\r\n    const cleanPath = path.startsWith('/') ? path.slice(1) : path;\r\n    return `${frontendUrl}${cleanPath}`;\r\n  }\r\n}"]}
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicnVudGltZS1jb25maWcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1lYXN5Y29tbWVyY2UtdjE4L3NyYy9saWIvaW50ZXJmYWNlcy9ydW50aW1lLWNvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBSdW50aW1lQ29uZmlnIHtcclxuICBhcGlVcmw6IHN0cmluZztcclxuICBmcm9udGVuZFVybD86IHN0cmluZztcclxuICAvKiogQW1iaWVudGUgZGUgbGEgYXBsaWNhY2nDs24uIFZhbG9yZXMgdsOhbGlkb3M6ICdwcm9kJywgJ3ByZXByb2QnLCAndGVzdCcgKi9cclxuICBhcHBFbnY6ICdwcm9kJyB8ICdwcmVwcm9kJyB8ICd0ZXN0JztcclxuICBwcm9kdWN0aW9uOiBib29sZWFuO1xyXG4gIGxvY2FsZTogc3RyaW5nO1xyXG4gIGNoYW5uZWw6IHN0cmluZztcclxuICBwb3J0PzogbnVtYmVyO1xyXG4gIGhvc3Q/OiBzdHJpbmc7XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgU2VydmVyRW52aXJvbm1lbnRWYXJpYWJsZXMge1xyXG4gIEFQSV9VUkw/OiBzdHJpbmc7XHJcbiAgRlJPTlRFTkRfVVJMPzogc3RyaW5nO1xyXG4gIC8qKiBBbWJpZW50ZSBkZSBsYSBhcGxpY2FjacOzbi4gVmFsb3JlcyB2w6FsaWRvczogJ3Byb2QnLCAncHJlcHJvZCcsICd0ZXN0JyAqL1xyXG4gIEFQUF9FTlY/OiAncHJvZCcgfCAncHJlcHJvZCcgfCAndGVzdCc7XHJcbiAgUE9SVD86IHN0cmluZztcclxuICBIT1NUPzogc3RyaW5nO1xyXG4gIE5PREVfRU5WPzogJ2RldmVsb3BtZW50JyB8ICdwcm9kdWN0aW9uJztcclxuICBMT0NBTEU/OiBzdHJpbmc7XHJcbiAgQ0hBTk5FTD86IHN0cmluZztcclxufSJdfQ==
|
|
@@ -1,39 +0,0 @@
|
|
|
1
|
-
import { APP_INITIALIZER, makeEnvironmentProviders } from '@angular/core';
|
|
2
|
-
import { RuntimeConfigService } from '../ec-services/runtime-config.service';
|
|
3
|
-
/**
|
|
4
|
-
* Factory function para APP_INITIALIZER
|
|
5
|
-
* Carga la configuración runtime antes de que Angular bootstrap la aplicación
|
|
6
|
-
*/
|
|
7
|
-
export function initializeRuntimeConfig(runtimeConfigService) {
|
|
8
|
-
return () => {
|
|
9
|
-
return new Promise((resolve, reject) => {
|
|
10
|
-
runtimeConfigService.loadConfig().subscribe({
|
|
11
|
-
next: (config) => {
|
|
12
|
-
console.log('🔧 Runtime config loaded:', config);
|
|
13
|
-
resolve(config);
|
|
14
|
-
},
|
|
15
|
-
error: (error) => {
|
|
16
|
-
console.error('❌ Failed to load runtime config:', error);
|
|
17
|
-
// Aún en caso de error, resolvemos para no bloquear la app
|
|
18
|
-
resolve(null);
|
|
19
|
-
}
|
|
20
|
-
});
|
|
21
|
-
});
|
|
22
|
-
};
|
|
23
|
-
}
|
|
24
|
-
/**
|
|
25
|
-
* Función que configura el RuntimeConfigService y su inicialización
|
|
26
|
-
* Debe ser usado en app.config.ts junto con provideEnvironment
|
|
27
|
-
*/
|
|
28
|
-
export function provideRuntimeConfig() {
|
|
29
|
-
return makeEnvironmentProviders([
|
|
30
|
-
RuntimeConfigService,
|
|
31
|
-
{
|
|
32
|
-
provide: APP_INITIALIZER,
|
|
33
|
-
useFactory: initializeRuntimeConfig,
|
|
34
|
-
deps: [RuntimeConfigService],
|
|
35
|
-
multi: true
|
|
36
|
-
}
|
|
37
|
-
]);
|
|
38
|
-
}
|
|
39
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvdmlkZVJ1bnRpbWVDb25maWcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1lYXN5Y29tbWVyY2UtdjE4L3NyYy9saWIvcHJvdmlkZXJzL3Byb3ZpZGVSdW50aW1lQ29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxlQUFlLEVBQXdCLHdCQUF3QixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2hHLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBRTdFOzs7R0FHRztBQUNILE1BQU0sVUFBVSx1QkFBdUIsQ0FBQyxvQkFBMEM7SUFDaEYsT0FBTyxHQUFpQixFQUFFO1FBQ3hCLE9BQU8sSUFBSSxPQUFPLENBQUMsQ0FBQyxPQUFPLEVBQUUsTUFBTSxFQUFFLEVBQUU7WUFDckMsb0JBQW9CLENBQUMsVUFBVSxFQUFFLENBQUMsU0FBUyxDQUFDO2dCQUMxQyxJQUFJLEVBQUUsQ0FBQyxNQUFNLEVBQUUsRUFBRTtvQkFDZixPQUFPLENBQUMsR0FBRyxDQUFDLDJCQUEyQixFQUFFLE1BQU0sQ0FBQyxDQUFDO29CQUNqRCxPQUFPLENBQUMsTUFBTSxDQUFDLENBQUM7Z0JBQ2xCLENBQUM7Z0JBQ0QsS0FBSyxFQUFFLENBQUMsS0FBSyxFQUFFLEVBQUU7b0JBQ2YsT0FBTyxDQUFDLEtBQUssQ0FBQyxrQ0FBa0MsRUFBRSxLQUFLLENBQUMsQ0FBQztvQkFDekQsMkRBQTJEO29CQUMzRCxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUM7Z0JBQ2hCLENBQUM7YUFDRixDQUFDLENBQUM7UUFDTCxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUMsQ0FBQztBQUNKLENBQUM7QUFFRDs7O0dBR0c7QUFDSCxNQUFNLFVBQVUsb0JBQW9CO0lBQ2xDLE9BQU8sd0JBQXdCLENBQUM7UUFDOUIsb0JBQW9CO1FBQ3BCO1lBQ0UsT0FBTyxFQUFFLGVBQWU7WUFDeEIsVUFBVSxFQUFFLHVCQUF1QjtZQUNuQyxJQUFJLEVBQUUsQ0FBQyxvQkFBb0IsQ0FBQztZQUM1QixLQUFLLEVBQUUsSUFBSTtTQUNaO0tBQ0YsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFQUF9JTklUSUFMSVpFUiwgRW52aXJvbm1lbnRQcm92aWRlcnMsIG1ha2VFbnZpcm9ubWVudFByb3ZpZGVycyB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBSdW50aW1lQ29uZmlnU2VydmljZSB9IGZyb20gJy4uL2VjLXNlcnZpY2VzL3J1bnRpbWUtY29uZmlnLnNlcnZpY2UnO1xyXG5cclxuLyoqXHJcbiAqIEZhY3RvcnkgZnVuY3Rpb24gcGFyYSBBUFBfSU5JVElBTElaRVJcclxuICogQ2FyZ2EgbGEgY29uZmlndXJhY2nDs24gcnVudGltZSBhbnRlcyBkZSBxdWUgQW5ndWxhciBib290c3RyYXAgbGEgYXBsaWNhY2nDs25cclxuICovXHJcbmV4cG9ydCBmdW5jdGlvbiBpbml0aWFsaXplUnVudGltZUNvbmZpZyhydW50aW1lQ29uZmlnU2VydmljZTogUnVudGltZUNvbmZpZ1NlcnZpY2UpOiAoKSA9PiBQcm9taXNlPGFueT4ge1xyXG4gIHJldHVybiAoKTogUHJvbWlzZTxhbnk+ID0+IHtcclxuICAgIHJldHVybiBuZXcgUHJvbWlzZSgocmVzb2x2ZSwgcmVqZWN0KSA9PiB7XHJcbiAgICAgIHJ1bnRpbWVDb25maWdTZXJ2aWNlLmxvYWRDb25maWcoKS5zdWJzY3JpYmUoe1xyXG4gICAgICAgIG5leHQ6IChjb25maWcpID0+IHtcclxuICAgICAgICAgIGNvbnNvbGUubG9nKCfwn5SnIFJ1bnRpbWUgY29uZmlnIGxvYWRlZDonLCBjb25maWcpO1xyXG4gICAgICAgICAgcmVzb2x2ZShjb25maWcpO1xyXG4gICAgICAgIH0sXHJcbiAgICAgICAgZXJyb3I6IChlcnJvcikgPT4ge1xyXG4gICAgICAgICAgY29uc29sZS5lcnJvcign4p2MIEZhaWxlZCB0byBsb2FkIHJ1bnRpbWUgY29uZmlnOicsIGVycm9yKTtcclxuICAgICAgICAgIC8vIEHDum4gZW4gY2FzbyBkZSBlcnJvciwgcmVzb2x2ZW1vcyBwYXJhIG5vIGJsb3F1ZWFyIGxhIGFwcFxyXG4gICAgICAgICAgcmVzb2x2ZShudWxsKTtcclxuICAgICAgICB9XHJcbiAgICAgIH0pO1xyXG4gICAgfSk7XHJcbiAgfTtcclxufVxyXG5cclxuLyoqXHJcbiAqIEZ1bmNpw7NuIHF1ZSBjb25maWd1cmEgZWwgUnVudGltZUNvbmZpZ1NlcnZpY2UgeSBzdSBpbmljaWFsaXphY2nDs25cclxuICogRGViZSBzZXIgdXNhZG8gZW4gYXBwLmNvbmZpZy50cyBqdW50byBjb24gcHJvdmlkZUVudmlyb25tZW50XHJcbiAqL1xyXG5leHBvcnQgZnVuY3Rpb24gcHJvdmlkZVJ1bnRpbWVDb25maWcoKTogRW52aXJvbm1lbnRQcm92aWRlcnMge1xyXG4gIHJldHVybiBtYWtlRW52aXJvbm1lbnRQcm92aWRlcnMoW1xyXG4gICAgUnVudGltZUNvbmZpZ1NlcnZpY2UsXHJcbiAgICB7XHJcbiAgICAgIHByb3ZpZGU6IEFQUF9JTklUSUFMSVpFUixcclxuICAgICAgdXNlRmFjdG9yeTogaW5pdGlhbGl6ZVJ1bnRpbWVDb25maWcsXHJcbiAgICAgIGRlcHM6IFtSdW50aW1lQ29uZmlnU2VydmljZV0sXHJcbiAgICAgIG11bHRpOiB0cnVlXHJcbiAgICB9XHJcbiAgXSk7XHJcbn0iXX0=
|
|
@@ -1,64 +0,0 @@
|
|
|
1
|
-
import { HttpClient, HttpHeaders, HttpParams } from '@angular/common/http';
|
|
2
|
-
import { Observable } from 'rxjs';
|
|
3
|
-
import { RuntimeConfigService } from './runtime-config.service';
|
|
4
|
-
import * as i0 from "@angular/core";
|
|
5
|
-
export interface ApiRequestOptions {
|
|
6
|
-
headers?: HttpHeaders | {
|
|
7
|
-
[header: string]: string | string[];
|
|
8
|
-
};
|
|
9
|
-
params?: HttpParams | {
|
|
10
|
-
[param: string]: string | string[];
|
|
11
|
-
};
|
|
12
|
-
withCredentials?: boolean;
|
|
13
|
-
}
|
|
14
|
-
/**
|
|
15
|
-
* Servicio base para realizar peticiones HTTP usando configuración dinámica
|
|
16
|
-
* Todos los servicios de la aplicación deben extender este servicio o usar sus métodos
|
|
17
|
-
*/
|
|
18
|
-
export declare class BaseApiService {
|
|
19
|
-
protected http: HttpClient;
|
|
20
|
-
protected runtimeConfigService: RuntimeConfigService;
|
|
21
|
-
constructor(http: HttpClient, runtimeConfigService: RuntimeConfigService);
|
|
22
|
-
/**
|
|
23
|
-
* Construye una URL completa usando la API_URL del runtime
|
|
24
|
-
*/
|
|
25
|
-
protected buildApiUrl(endpoint: string): string;
|
|
26
|
-
/**
|
|
27
|
-
* Obtiene headers comunes que incluyen información del runtime
|
|
28
|
-
*/
|
|
29
|
-
protected getCommonHeaders(): HttpHeaders;
|
|
30
|
-
/**
|
|
31
|
-
* Método GET genérico
|
|
32
|
-
*/
|
|
33
|
-
get<T>(endpoint: string, options?: ApiRequestOptions): Observable<T>;
|
|
34
|
-
/**
|
|
35
|
-
* Método POST genérico
|
|
36
|
-
*/
|
|
37
|
-
post<T>(endpoint: string, data: any, options?: ApiRequestOptions): Observable<T>;
|
|
38
|
-
/**
|
|
39
|
-
* Método PUT genérico
|
|
40
|
-
*/
|
|
41
|
-
put<T>(endpoint: string, data: any, options?: ApiRequestOptions): Observable<T>;
|
|
42
|
-
/**
|
|
43
|
-
* Método PATCH genérico
|
|
44
|
-
*/
|
|
45
|
-
patch<T>(endpoint: string, data: any, options?: ApiRequestOptions): Observable<T>;
|
|
46
|
-
/**
|
|
47
|
-
* Método DELETE genérico
|
|
48
|
-
*/
|
|
49
|
-
delete<T>(endpoint: string, options?: ApiRequestOptions): Observable<T>;
|
|
50
|
-
/**
|
|
51
|
-
* Método para peticiones que necesitan esperar a que la config esté cargada
|
|
52
|
-
*/
|
|
53
|
-
getWithConfig<T>(endpoint: string, options?: ApiRequestOptions): Observable<T>;
|
|
54
|
-
/**
|
|
55
|
-
* Método para POST que necesitan esperar a que la config esté cargada
|
|
56
|
-
*/
|
|
57
|
-
postWithConfig<T>(endpoint: string, data: any, options?: ApiRequestOptions): Observable<T>;
|
|
58
|
-
/**
|
|
59
|
-
* Combina headers personalizados con los headers comunes
|
|
60
|
-
*/
|
|
61
|
-
private mergeHeaders;
|
|
62
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<BaseApiService, never>;
|
|
63
|
-
static ɵprov: i0.ɵɵInjectableDeclaration<BaseApiService>;
|
|
64
|
-
}
|
|
@@ -1,56 +0,0 @@
|
|
|
1
|
-
import { HttpClient } from '@angular/common/http';
|
|
2
|
-
import { Observable } from 'rxjs';
|
|
3
|
-
import { RuntimeConfig } from '../interfaces/runtime-config';
|
|
4
|
-
import * as i0 from "@angular/core";
|
|
5
|
-
export declare class RuntimeConfigService {
|
|
6
|
-
private platformId;
|
|
7
|
-
private http;
|
|
8
|
-
private configSubject;
|
|
9
|
-
config$: Observable<RuntimeConfig | null>;
|
|
10
|
-
private _config;
|
|
11
|
-
constructor(platformId: Object, http: HttpClient);
|
|
12
|
-
/**
|
|
13
|
-
* Carga la configuración en runtime
|
|
14
|
-
* - En SSR: Lee desde el objeto window inyectado por el servidor
|
|
15
|
-
* - En Browser: Hace petición HTTP a /runtime-config.json
|
|
16
|
-
*/
|
|
17
|
-
loadConfig(): Observable<RuntimeConfig>;
|
|
18
|
-
/**
|
|
19
|
-
* Obtiene la configuración actual (síncrono)
|
|
20
|
-
*/
|
|
21
|
-
getConfig(): RuntimeConfig | null;
|
|
22
|
-
/**
|
|
23
|
-
* Obtiene la API URL actual
|
|
24
|
-
*/
|
|
25
|
-
getApiUrl(): string;
|
|
26
|
-
/**
|
|
27
|
-
* Obtiene la Frontend URL actual
|
|
28
|
-
*/
|
|
29
|
-
getFrontendUrl(): string | undefined;
|
|
30
|
-
/**
|
|
31
|
-
* Obtiene el entorno actual
|
|
32
|
-
*/
|
|
33
|
-
getAppEnv(): string;
|
|
34
|
-
/**
|
|
35
|
-
* Verifica si estamos en producción
|
|
36
|
-
*/
|
|
37
|
-
isProduction(): boolean;
|
|
38
|
-
/**
|
|
39
|
-
* Obtiene el locale actual
|
|
40
|
-
*/
|
|
41
|
-
getLocale(): string;
|
|
42
|
-
/**
|
|
43
|
-
* Obtiene el canal actual
|
|
44
|
-
*/
|
|
45
|
-
getChannel(): string;
|
|
46
|
-
/**
|
|
47
|
-
* Método helper para construir URLs de API
|
|
48
|
-
*/
|
|
49
|
-
buildApiUrl(endpoint: string): string;
|
|
50
|
-
/**
|
|
51
|
-
* Método helper para construir URLs del frontend
|
|
52
|
-
*/
|
|
53
|
-
buildFrontendUrl(path: string): string;
|
|
54
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<RuntimeConfigService, never>;
|
|
55
|
-
static ɵprov: i0.ɵɵInjectableDeclaration<RuntimeConfigService>;
|
|
56
|
-
}
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
export interface RuntimeConfig {
|
|
2
|
-
apiUrl: string;
|
|
3
|
-
frontendUrl?: string;
|
|
4
|
-
/** Ambiente de la aplicación. Valores válidos: 'prod', 'preprod', 'test' */
|
|
5
|
-
appEnv: 'prod' | 'preprod' | 'test';
|
|
6
|
-
production: boolean;
|
|
7
|
-
locale: string;
|
|
8
|
-
channel: string;
|
|
9
|
-
port?: number;
|
|
10
|
-
host?: string;
|
|
11
|
-
}
|
|
12
|
-
export interface ServerEnvironmentVariables {
|
|
13
|
-
API_URL?: string;
|
|
14
|
-
FRONTEND_URL?: string;
|
|
15
|
-
/** Ambiente de la aplicación. Valores válidos: 'prod', 'preprod', 'test' */
|
|
16
|
-
APP_ENV?: 'prod' | 'preprod' | 'test';
|
|
17
|
-
PORT?: string;
|
|
18
|
-
HOST?: string;
|
|
19
|
-
NODE_ENV?: 'development' | 'production';
|
|
20
|
-
LOCALE?: string;
|
|
21
|
-
CHANNEL?: string;
|
|
22
|
-
}
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import { EnvironmentProviders } from '@angular/core';
|
|
2
|
-
import { RuntimeConfigService } from '../ec-services/runtime-config.service';
|
|
3
|
-
/**
|
|
4
|
-
* Factory function para APP_INITIALIZER
|
|
5
|
-
* Carga la configuración runtime antes de que Angular bootstrap la aplicación
|
|
6
|
-
*/
|
|
7
|
-
export declare function initializeRuntimeConfig(runtimeConfigService: RuntimeConfigService): () => Promise<any>;
|
|
8
|
-
/**
|
|
9
|
-
* Función que configura el RuntimeConfigService y su inicialización
|
|
10
|
-
* Debe ser usado en app.config.ts junto con provideEnvironment
|
|
11
|
-
*/
|
|
12
|
-
export declare function provideRuntimeConfig(): EnvironmentProviders;
|