valtech-components 2.0.503 → 2.0.505
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/esm2022/lib/components/molecules/ad-slot/ad-slot.component.mjs +75 -107
- package/esm2022/lib/services/ads/ads-loader.service.mjs +47 -87
- package/esm2022/lib/services/ads/ads.service.mjs +62 -246
- package/esm2022/lib/services/ads/config.mjs +12 -49
- package/esm2022/lib/services/ads/index.mjs +3 -4
- package/esm2022/lib/services/ads/types.mjs +4 -4
- package/esm2022/lib/services/firebase/shared-config.mjs +4 -2
- package/fesm2022/valtech-components.mjs +218 -659
- package/fesm2022/valtech-components.mjs.map +1 -1
- package/lib/components/molecules/ad-slot/ad-slot.component.d.ts +25 -39
- package/lib/components/organisms/article/article.component.d.ts +3 -3
- package/lib/services/ads/ads-loader.service.d.ts +12 -17
- package/lib/services/ads/ads.service.d.ts +26 -44
- package/lib/services/ads/config.d.ts +9 -25
- package/lib/services/ads/index.d.ts +3 -4
- package/lib/services/ads/types.d.ts +34 -99
- package/lib/services/firebase/shared-config.d.ts +11 -0
- package/package.json +1 -1
- package/esm2022/lib/services/ads/ads-consent.service.mjs +0 -152
- package/lib/services/ads/ads-consent.service.d.ts +0 -59
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* Ads Configuration
|
|
3
3
|
*
|
|
4
|
-
* Configuracion e inicializacion de Google
|
|
4
|
+
* Configuracion e inicializacion de Google AdSense para Angular.
|
|
5
5
|
* Usa provideValtechAds() en el bootstrap de tu aplicacion.
|
|
6
6
|
*/
|
|
7
7
|
import { InjectionToken, makeEnvironmentProviders, APP_INITIALIZER, } from '@angular/core';
|
|
@@ -11,30 +11,13 @@ import { AdsService } from './ads.service';
|
|
|
11
11
|
* Usado internamente por los servicios de ads.
|
|
12
12
|
*/
|
|
13
13
|
export const VALTECH_ADS_CONFIG = new InjectionToken('ValtechAdsConfig');
|
|
14
|
-
/**
|
|
15
|
-
* Configuracion por defecto de lazy loading.
|
|
16
|
-
*/
|
|
17
|
-
export const DEFAULT_LAZY_LOAD_CONFIG = {
|
|
18
|
-
rootMargin: '200px',
|
|
19
|
-
threshold: 0,
|
|
20
|
-
fetchMarginPercent: 200,
|
|
21
|
-
renderMarginPercent: 100,
|
|
22
|
-
};
|
|
23
14
|
/**
|
|
24
15
|
* Configuracion por defecto del servicio de ads.
|
|
25
16
|
*/
|
|
26
17
|
export const DEFAULT_ADS_CONFIG = {
|
|
27
18
|
debugMode: false,
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
enablePersonalization: true,
|
|
31
|
-
showNonPersonalizedAds: true,
|
|
32
|
-
autoRefreshInterval: 0, // Deshabilitado por defecto
|
|
33
|
-
defaultSlotConfig: {
|
|
34
|
-
collapseEmpty: true,
|
|
35
|
-
showSkeleton: true,
|
|
36
|
-
minHeight: '90px',
|
|
37
|
-
},
|
|
19
|
+
testMode: false,
|
|
20
|
+
autoAds: false,
|
|
38
21
|
};
|
|
39
22
|
/**
|
|
40
23
|
* Factory para inicializar AdsService.
|
|
@@ -46,42 +29,30 @@ function initializeAds(adsService) {
|
|
|
46
29
|
/**
|
|
47
30
|
* Provee el servicio de Ads a la aplicacion Angular.
|
|
48
31
|
*
|
|
49
|
-
* @param config - Configuracion de Google
|
|
32
|
+
* @param config - Configuracion de Google AdSense
|
|
50
33
|
* @returns EnvironmentProviders para usar en bootstrapApplication
|
|
51
34
|
*
|
|
52
35
|
* @example
|
|
53
36
|
* ```typescript
|
|
54
37
|
* // main.ts
|
|
55
38
|
* import { bootstrapApplication } from '@angular/platform-browser';
|
|
56
|
-
* import { provideValtechAds
|
|
57
|
-
* import { environment } from './environments/environment';
|
|
39
|
+
* import { provideValtechAds } from 'valtech-components';
|
|
58
40
|
*
|
|
59
41
|
* bootstrapApplication(AppComponent, {
|
|
60
42
|
* providers: [
|
|
61
|
-
* // Firebase primero (para consent mode)
|
|
62
|
-
* provideValtechFirebase({
|
|
63
|
-
* firebase: environment.firebase,
|
|
64
|
-
* enableAnalytics: true,
|
|
65
|
-
* }),
|
|
66
|
-
*
|
|
67
|
-
* // Luego Ads
|
|
68
43
|
* provideValtechAds({
|
|
69
|
-
*
|
|
70
|
-
*
|
|
71
|
-
*
|
|
44
|
+
* adClient: 'ca-pub-XXXXXXXXXXXXXXXX',
|
|
45
|
+
* testMode: true, // Usa ads de prueba en desarrollo
|
|
46
|
+
* debugMode: true,
|
|
72
47
|
* }),
|
|
73
48
|
* ],
|
|
74
49
|
* });
|
|
75
50
|
* ```
|
|
76
51
|
*
|
|
77
|
-
* @example Con
|
|
52
|
+
* @example Con rutas excluidas
|
|
78
53
|
* ```typescript
|
|
79
54
|
* provideValtechAds({
|
|
80
|
-
*
|
|
81
|
-
* globalTargeting: {
|
|
82
|
-
* site: 'myvaltech',
|
|
83
|
-
* section: 'app',
|
|
84
|
-
* },
|
|
55
|
+
* adClient: 'ca-pub-XXXXXXXXXXXXXXXX',
|
|
85
56
|
* excludeRoutes: [
|
|
86
57
|
* '^/checkout',
|
|
87
58
|
* '^/payment',
|
|
@@ -95,18 +66,10 @@ export function provideValtechAds(config) {
|
|
|
95
66
|
const mergedConfig = {
|
|
96
67
|
...DEFAULT_ADS_CONFIG,
|
|
97
68
|
...config,
|
|
98
|
-
lazyLoadConfig: {
|
|
99
|
-
...DEFAULT_LAZY_LOAD_CONFIG,
|
|
100
|
-
...config.lazyLoadConfig,
|
|
101
|
-
},
|
|
102
|
-
defaultSlotConfig: {
|
|
103
|
-
...DEFAULT_ADS_CONFIG.defaultSlotConfig,
|
|
104
|
-
...config.defaultSlotConfig,
|
|
105
|
-
},
|
|
106
69
|
};
|
|
107
70
|
return makeEnvironmentProviders([
|
|
108
71
|
{ provide: VALTECH_ADS_CONFIG, useValue: mergedConfig },
|
|
109
|
-
// Inicializar AdsService al arrancar (pero NO cargar script
|
|
72
|
+
// Inicializar AdsService al arrancar (pero NO cargar script AdSense aun)
|
|
110
73
|
{
|
|
111
74
|
provide: APP_INITIALIZER,
|
|
112
75
|
useFactory: initializeAds,
|
|
@@ -115,4 +78,4 @@ export function provideValtechAds(config) {
|
|
|
115
78
|
},
|
|
116
79
|
]);
|
|
117
80
|
}
|
|
118
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
81
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL2xpYi9zZXJ2aWNlcy9hZHMvY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7OztHQUtHO0FBRUgsT0FBTyxFQUVMLGNBQWMsRUFDZCx3QkFBd0IsRUFDeEIsZUFBZSxHQUNoQixNQUFNLGVBQWUsQ0FBQztBQUV2QixPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTNDOzs7R0FHRztBQUNILE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUFHLElBQUksY0FBYyxDQUFtQixrQkFBa0IsQ0FBQyxDQUFDO0FBRTNGOztHQUVHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sa0JBQWtCLEdBQThCO0lBQzNELFNBQVMsRUFBRSxLQUFLO0lBQ2hCLFFBQVEsRUFBRSxLQUFLO0lBQ2YsT0FBTyxFQUFFLEtBQUs7Q0FDZixDQUFDO0FBRUY7OztHQUdHO0FBQ0gsU0FBUyxhQUFhLENBQUMsVUFBc0I7SUFDM0MsT0FBTyxHQUFHLEVBQUUsQ0FBQyxVQUFVLENBQUMsVUFBVSxFQUFFLENBQUM7QUFDdkMsQ0FBQztBQUVEOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBa0NHO0FBQ0gsTUFBTSxVQUFVLGlCQUFpQixDQUFDLE1BQXdCO0lBQ3hELDRCQUE0QjtJQUM1QixNQUFNLFlBQVksR0FBcUI7UUFDckMsR0FBRyxrQkFBa0I7UUFDckIsR0FBRyxNQUFNO0tBQ1YsQ0FBQztJQUVGLE9BQU8sd0JBQXdCLENBQUM7UUFDOUIsRUFBRSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsUUFBUSxFQUFFLFlBQVksRUFBRTtRQUN2RCx5RUFBeUU7UUFDekU7WUFDRSxPQUFPLEVBQUUsZUFBZTtZQUN4QixVQUFVLEVBQUUsYUFBYTtZQUN6QixJQUFJLEVBQUUsQ0FBQyxVQUFVLENBQUM7WUFDbEIsS0FBSyxFQUFFLElBQUk7U0FDWjtLQUNGLENBQUMsQ0FBQztBQUNMLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEFkcyBDb25maWd1cmF0aW9uXG4gKlxuICogQ29uZmlndXJhY2lvbiBlIGluaWNpYWxpemFjaW9uIGRlIEdvb2dsZSBBZFNlbnNlIHBhcmEgQW5ndWxhci5cbiAqIFVzYSBwcm92aWRlVmFsdGVjaEFkcygpIGVuIGVsIGJvb3RzdHJhcCBkZSB0dSBhcGxpY2FjaW9uLlxuICovXG5cbmltcG9ydCB7XG4gIEVudmlyb25tZW50UHJvdmlkZXJzLFxuICBJbmplY3Rpb25Ub2tlbixcbiAgbWFrZUVudmlyb25tZW50UHJvdmlkZXJzLFxuICBBUFBfSU5JVElBTElaRVIsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgVmFsdGVjaEFkc0NvbmZpZyB9IGZyb20gJy4vdHlwZXMnO1xuaW1wb3J0IHsgQWRzU2VydmljZSB9IGZyb20gJy4vYWRzLnNlcnZpY2UnO1xuXG4vKipcbiAqIFRva2VuIGRlIGlueWVjY2lvbiBwYXJhIGxhIGNvbmZpZ3VyYWNpb24gZGUgQWRzLlxuICogVXNhZG8gaW50ZXJuYW1lbnRlIHBvciBsb3Mgc2VydmljaW9zIGRlIGFkcy5cbiAqL1xuZXhwb3J0IGNvbnN0IFZBTFRFQ0hfQURTX0NPTkZJRyA9IG5ldyBJbmplY3Rpb25Ub2tlbjxWYWx0ZWNoQWRzQ29uZmlnPignVmFsdGVjaEFkc0NvbmZpZycpO1xuXG4vKipcbiAqIENvbmZpZ3VyYWNpb24gcG9yIGRlZmVjdG8gZGVsIHNlcnZpY2lvIGRlIGFkcy5cbiAqL1xuZXhwb3J0IGNvbnN0IERFRkFVTFRfQURTX0NPTkZJRzogUGFydGlhbDxWYWx0ZWNoQWRzQ29uZmlnPiA9IHtcbiAgZGVidWdNb2RlOiBmYWxzZSxcbiAgdGVzdE1vZGU6IGZhbHNlLFxuICBhdXRvQWRzOiBmYWxzZSxcbn07XG5cbi8qKlxuICogRmFjdG9yeSBwYXJhIGluaWNpYWxpemFyIEFkc1NlcnZpY2UuXG4gKiBTZSBlamVjdXRhIGR1cmFudGUgZWwgYm9vdHN0cmFwIGRlIGxhIGFwbGljYWNpb24uXG4gKi9cbmZ1bmN0aW9uIGluaXRpYWxpemVBZHMoYWRzU2VydmljZTogQWRzU2VydmljZSk6ICgpID0+IFByb21pc2U8dm9pZD4ge1xuICByZXR1cm4gKCkgPT4gYWRzU2VydmljZS5pbml0aWFsaXplKCk7XG59XG5cbi8qKlxuICogUHJvdmVlIGVsIHNlcnZpY2lvIGRlIEFkcyBhIGxhIGFwbGljYWNpb24gQW5ndWxhci5cbiAqXG4gKiBAcGFyYW0gY29uZmlnIC0gQ29uZmlndXJhY2lvbiBkZSBHb29nbGUgQWRTZW5zZVxuICogQHJldHVybnMgRW52aXJvbm1lbnRQcm92aWRlcnMgcGFyYSB1c2FyIGVuIGJvb3RzdHJhcEFwcGxpY2F0aW9uXG4gKlxuICogQGV4YW1wbGVcbiAqIGBgYHR5cGVzY3JpcHRcbiAqIC8vIG1haW4udHNcbiAqIGltcG9ydCB7IGJvb3RzdHJhcEFwcGxpY2F0aW9uIH0gZnJvbSAnQGFuZ3VsYXIvcGxhdGZvcm0tYnJvd3Nlcic7XG4gKiBpbXBvcnQgeyBwcm92aWRlVmFsdGVjaEFkcyB9IGZyb20gJ3ZhbHRlY2gtY29tcG9uZW50cyc7XG4gKlxuICogYm9vdHN0cmFwQXBwbGljYXRpb24oQXBwQ29tcG9uZW50LCB7XG4gKiAgIHByb3ZpZGVyczogW1xuICogICAgIHByb3ZpZGVWYWx0ZWNoQWRzKHtcbiAqICAgICAgIGFkQ2xpZW50OiAnY2EtcHViLVhYWFhYWFhYWFhYWFhYWFgnLFxuICogICAgICAgdGVzdE1vZGU6IHRydWUsIC8vIFVzYSBhZHMgZGUgcHJ1ZWJhIGVuIGRlc2Fycm9sbG9cbiAqICAgICAgIGRlYnVnTW9kZTogdHJ1ZSxcbiAqICAgICB9KSxcbiAqICAgXSxcbiAqIH0pO1xuICogYGBgXG4gKlxuICogQGV4YW1wbGUgQ29uIHJ1dGFzIGV4Y2x1aWRhc1xuICogYGBgdHlwZXNjcmlwdFxuICogcHJvdmlkZVZhbHRlY2hBZHMoe1xuICogICBhZENsaWVudDogJ2NhLXB1Yi1YWFhYWFhYWFhYWFhYWFhYJyxcbiAqICAgZXhjbHVkZVJvdXRlczogW1xuICogICAgICdeL2NoZWNrb3V0JyxcbiAqICAgICAnXi9wYXltZW50JyxcbiAqICAgICAnXi9wcmVtaXVtJyxcbiAqICAgXSxcbiAqIH0pXG4gKiBgYGBcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHByb3ZpZGVWYWx0ZWNoQWRzKGNvbmZpZzogVmFsdGVjaEFkc0NvbmZpZyk6IEVudmlyb25tZW50UHJvdmlkZXJzIHtcbiAgLy8gTWVyZ2UgY29uZmlnIGNvbiBkZWZhdWx0c1xuICBjb25zdCBtZXJnZWRDb25maWc6IFZhbHRlY2hBZHNDb25maWcgPSB7XG4gICAgLi4uREVGQVVMVF9BRFNfQ09ORklHLFxuICAgIC4uLmNvbmZpZyxcbiAgfTtcblxuICByZXR1cm4gbWFrZUVudmlyb25tZW50UHJvdmlkZXJzKFtcbiAgICB7IHByb3ZpZGU6IFZBTFRFQ0hfQURTX0NPTkZJRywgdXNlVmFsdWU6IG1lcmdlZENvbmZpZyB9LFxuICAgIC8vIEluaWNpYWxpemFyIEFkc1NlcnZpY2UgYWwgYXJyYW5jYXIgKHBlcm8gTk8gY2FyZ2FyIHNjcmlwdCBBZFNlbnNlIGF1bilcbiAgICB7XG4gICAgICBwcm92aWRlOiBBUFBfSU5JVElBTElaRVIsXG4gICAgICB1c2VGYWN0b3J5OiBpbml0aWFsaXplQWRzLFxuICAgICAgZGVwczogW0Fkc1NlcnZpY2VdLFxuICAgICAgbXVsdGk6IHRydWUsXG4gICAgfSxcbiAgXSk7XG59XG4iXX0=
|
|
@@ -1,14 +1,13 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* Ads Module
|
|
3
3
|
*
|
|
4
|
-
* Exports publicos para el servicio de Google
|
|
4
|
+
* Exports publicos para el servicio de Google AdSense.
|
|
5
5
|
*/
|
|
6
6
|
// Configuration
|
|
7
|
-
export { provideValtechAds, VALTECH_ADS_CONFIG, DEFAULT_ADS_CONFIG
|
|
7
|
+
export { provideValtechAds, VALTECH_ADS_CONFIG, DEFAULT_ADS_CONFIG } from './config';
|
|
8
8
|
// Services
|
|
9
9
|
export { AdsService } from './ads.service';
|
|
10
|
-
export { AdsConsentService } from './ads-consent.service';
|
|
11
10
|
export { AdsLoaderService } from './ads-loader.service';
|
|
12
11
|
// Types
|
|
13
12
|
export { AD_SIZE_MAP, } from './types';
|
|
14
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
13
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL3NlcnZpY2VzL2Fkcy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7OztHQUlHO0FBRUgsZ0JBQWdCO0FBQ2hCLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxrQkFBa0IsRUFBRSxrQkFBa0IsRUFBRSxNQUFNLFVBQVUsQ0FBQztBQUVyRixXQUFXO0FBQ1gsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUV4RCxRQUFRO0FBQ1IsT0FBTyxFQVlMLFdBQVcsR0FFWixNQUFNLFNBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQWRzIE1vZHVsZVxuICpcbiAqIEV4cG9ydHMgcHVibGljb3MgcGFyYSBlbCBzZXJ2aWNpbyBkZSBHb29nbGUgQWRTZW5zZS5cbiAqL1xuXG4vLyBDb25maWd1cmF0aW9uXG5leHBvcnQgeyBwcm92aWRlVmFsdGVjaEFkcywgVkFMVEVDSF9BRFNfQ09ORklHLCBERUZBVUxUX0FEU19DT05GSUcgfSBmcm9tICcuL2NvbmZpZyc7XG5cbi8vIFNlcnZpY2VzXG5leHBvcnQgeyBBZHNTZXJ2aWNlIH0gZnJvbSAnLi9hZHMuc2VydmljZSc7XG5leHBvcnQgeyBBZHNMb2FkZXJTZXJ2aWNlIH0gZnJvbSAnLi9hZHMtbG9hZGVyLnNlcnZpY2UnO1xuXG4vLyBUeXBlc1xuZXhwb3J0IHtcbiAgLy8gQ29uZmlnIHR5cGVzXG4gIFZhbHRlY2hBZHNDb25maWcsXG4gIC8vIFNsb3QgdHlwZXNcbiAgQWRTbG90Q29uZmlnLFxuICBBZEZvcm1hdCxcbiAgLy8gU3RhdGUgdHlwZXNcbiAgQWRTbG90U3RhdGUsXG4gIEFkRXZlbnQsXG4gIEFkc0NvbnNlbnRTdGF0ZSxcbiAgLy8gTGVnYWN5IHR5cGVzIChkZXByZWNhdGVkKVxuICBBZFNsb3RTaXplLFxuICBBRF9TSVpFX01BUCxcbiAgU2l6ZU1hcHBpbmcsXG59IGZyb20gJy4vdHlwZXMnO1xuIl19
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* Ads Types
|
|
3
3
|
*
|
|
4
|
-
* Tipos e interfaces para el servicio de Google
|
|
5
|
-
*
|
|
4
|
+
* Tipos e interfaces para el servicio de Google AdSense.
|
|
5
|
+
* Simplificado para usar AdSense en lugar de GPT (Ad Manager).
|
|
6
6
|
*/
|
|
7
7
|
/**
|
|
8
|
-
*
|
|
8
|
+
* @deprecated AdSense handles sizes automatically
|
|
9
9
|
*/
|
|
10
10
|
export const AD_SIZE_MAP = {
|
|
11
11
|
leaderboard: [728, 90],
|
|
@@ -20,4 +20,4 @@ export const AD_SIZE_MAP = {
|
|
|
20
20
|
native: 'fluid',
|
|
21
21
|
custom: 'fluid',
|
|
22
22
|
};
|
|
23
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../../../src/lib/services/ads/types.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAqFH;;GAEG;AACH,MAAM,CAAC,MAAM,WAAW,GAAmD;IACzE,WAAW,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC;IACtB,SAAS,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC;IACrB,kBAAkB,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC;IAC9B,iBAAiB,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC;IAC7B,WAAW,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC;IACvB,UAAU,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC;IACtB,eAAe,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC;IAC1B,oBAAoB,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC;IAChC,KAAK,EAAE,OAAO;IACd,MAAM,EAAE,OAAO;IACf,MAAM,EAAE,OAAO;CAChB,CAAC","sourcesContent":["/**\n * Ads Types\n *\n * Tipos e interfaces para el servicio de Google Ad Manager.\n * Usa Google Publisher Tags (GPT) para renderizar ads.\n */\n\n// ============================================================================\n// CONFIGURACION\n// ============================================================================\n\n/**\n * Configuracion del servicio de Ads.\n * Pasada a provideValtechAds() en el bootstrap de la aplicacion.\n */\nexport interface ValtechAdsConfig {\n  /** Network ID de Google Ad Manager (ej: '/12345678') */\n  networkId: string;\n\n  /** Habilitar modo debug (muestra info de ads en consola) */\n  debugMode?: boolean;\n\n  /** Activar lazy loading de ads (viewport intersection) */\n  lazyLoad?: boolean;\n\n  /** Configuracion de lazy loading */\n  lazyLoadConfig?: LazyLoadConfig;\n\n  /** Configuracion por defecto para ad slots */\n  defaultSlotConfig?: Partial<AdSlotConfig>;\n\n  /** Targeting global (aplica a todos los slots) */\n  globalTargeting?: Record<string, string | string[]>;\n\n  /** Habilitar personalizacion de ads (requiere consent) */\n  enablePersonalization?: boolean;\n\n  /** Mostrar ads de fallback si no hay consent */\n  showNonPersonalizedAds?: boolean;\n\n  /** Callback cuando se carga un ad */\n  onAdLoaded?: (slotId: string, isEmpty: boolean) => void;\n\n  /** Callback cuando falla un ad */\n  onAdError?: (slotId: string, error: Error) => void;\n\n  /** Refresh automatico de ads (en segundos, 0 = deshabilitado) */\n  autoRefreshInterval?: number;\n\n  /** Rutas donde NO mostrar ads (regex patterns) */\n  excludeRoutes?: string[];\n}\n\n/**\n * Configuracion de lazy loading para GPT.\n */\nexport interface LazyLoadConfig {\n  /** Margen del viewport para cargar (ej: '200px') */\n  rootMargin?: string;\n\n  /** Threshold de interseccion (0-1) */\n  threshold?: number;\n\n  /** Fetch margin para GPT (pixels antes del viewport) */\n  fetchMarginPercent?: number;\n\n  /** Render margin para GPT */\n  renderMarginPercent?: number;\n}\n\n// ============================================================================\n// AD SLOTS\n// ============================================================================\n\n/**\n * Tamanos de ad predefinidos (IAB standard).\n */\nexport type AdSlotSize =\n  | 'leaderboard' // 728x90 - Desktop header\n  | 'billboard' // 970x250 - Large desktop\n  | 'medium-rectangle' // 300x250 - Universal\n  | 'large-rectangle' // 336x280 - Large rectangle\n  | 'half-page' // 300x600 - Sidebar\n  | 'skyscraper' // 160x600 - Sidebar\n  | 'mobile-banner' // 320x50 - Mobile\n  | 'mobile-leaderboard' // 320x100 - Mobile large\n  | 'fluid' // Responsive\n  | 'native' // Native ad format\n  | 'custom'; // Tamano custom\n\n/**\n * Mapeo de tamanos predefinidos a dimensiones.\n */\nexport const AD_SIZE_MAP: Record<AdSlotSize, [number, number] | 'fluid'> = {\n  leaderboard: [728, 90],\n  billboard: [970, 250],\n  'medium-rectangle': [300, 250],\n  'large-rectangle': [336, 280],\n  'half-page': [300, 600],\n  skyscraper: [160, 600],\n  'mobile-banner': [320, 50],\n  'mobile-leaderboard': [320, 100],\n  fluid: 'fluid',\n  native: 'fluid',\n  custom: 'fluid',\n};\n\n/**\n * Configuracion de un ad slot individual.\n */\nexport interface AdSlotConfig {\n  /** ID unico del slot (usado para el div container) */\n  slotId: string;\n\n  /** Ad unit path (ej: '/homepage/top') - se concatena con networkId */\n  adUnitPath: string;\n\n  /** Tamano del ad o tamanos responsivos */\n  size: AdSlotSize | AdSlotSize[] | [number, number] | [number, number][];\n\n  /** Mapping responsivo: [viewport-width, sizes] */\n  sizeMapping?: SizeMapping[];\n\n  /** Targeting especifico para este slot */\n  targeting?: Record<string, string | string[]>;\n\n  /** Colapsar slot si esta vacio */\n  collapseEmpty?: boolean;\n\n  /** Es un native ad */\n  isNative?: boolean;\n\n  /** CSS class adicional */\n  cssClass?: string;\n\n  /** Altura minima mientras carga */\n  minHeight?: string;\n\n  /** Mostrar skeleton mientras carga */\n  showSkeleton?: boolean;\n}\n\n/**\n * Mapping de tamanos responsivos.\n * Define que tamanos de ad mostrar segun el viewport.\n */\nexport interface SizeMapping {\n  /** Ancho minimo del viewport */\n  viewportWidth: number;\n  /** Tamanos de ad para este viewport */\n  sizes: ([number, number] | 'fluid')[];\n}\n\n// ============================================================================\n// ESTADO\n// ============================================================================\n\n/**\n * Estado de un ad slot.\n */\nexport type AdSlotState =\n  | 'idle' // No cargado\n  | 'loading' // Script/ad cargando\n  | 'rendered' // Ad visible\n  | 'empty' // Sin ad disponible\n  | 'hidden' // Usuario premium o sin consent\n  | 'error'; // Error de carga\n\n/**\n * Evento emitido por el servicio de ads.\n */\nexport interface AdEvent {\n  type: 'loaded' | 'empty' | 'error' | 'viewable' | 'clicked';\n  slotId: string;\n  timestamp: Date;\n  isEmpty?: boolean;\n  error?: Error;\n}\n\n// ============================================================================\n// CONSENT\n// ============================================================================\n\n/**\n * Estado de consent para ads (mapeado desde AnalyticsService).\n */\nexport interface AdsConsentState {\n  /** Permite almacenamiento de ads */\n  adStorage: boolean;\n\n  /** Permite personalizacion de ads */\n  adPersonalization: boolean;\n\n  /** Permite datos de usuario para ads */\n  adUserData: boolean;\n}\n\n// ============================================================================\n// GPT (Google Publisher Tag) Types\n// ============================================================================\n\n/** GPT Slot reference */\nexport interface GPTSlot {\n  getSlotElementId(): string;\n  getAdUnitPath(): string;\n  addService(service: unknown): GPTSlot;\n  defineSizeMapping(mapping: unknown): GPTSlot;\n  setTargeting(key: string, value: string | string[]): GPTSlot;\n  setCollapseEmptyDiv(collapse: boolean, collapseBeforeAdFetch?: boolean): GPTSlot;\n}\n\n/** GPT global namespace (window.googletag) */\nexport interface GPTNamespace {\n  cmd: Array<() => void>;\n  defineSlot(adUnitPath: string, size: unknown, divId: string): GPTSlot | null;\n  pubads(): GPTPubadsService;\n  enableServices(): void;\n  display(divId: string): void;\n  destroySlots(slots?: GPTSlot[]): boolean;\n  sizeMapping(): GPTSizeMappingBuilder;\n}\n\n/** GPT Pubads Service */\nexport interface GPTPubadsService {\n  enableSingleRequest(): void;\n  enableLazyLoad(config?: object): void;\n  setTargeting(key: string, value: string | string[]): void;\n  setRequestNonPersonalizedAds(value: 0 | 1): void;\n  addEventListener(event: string, callback: (event: GPTEvent) => void): void;\n  refresh(slots?: GPTSlot[]): void;\n  collapseEmptyDivs(collapseBeforeAdFetch?: boolean): void;\n}\n\n/** GPT Size Mapping Builder */\nexport interface GPTSizeMappingBuilder {\n  addSize(viewport: [number, number], sizes: unknown): GPTSizeMappingBuilder;\n  build(): unknown;\n}\n\n/** GPT Event */\nexport interface GPTEvent {\n  slot: GPTSlot;\n  isEmpty?: boolean;\n}\n\n// Extend Window interface for googletag\ndeclare global {\n  interface Window {\n    googletag?: GPTNamespace;\n  }\n}\n"]}
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL3NlcnZpY2VzL2Fkcy90eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7R0FLRztBQWtKSDs7R0FFRztBQUNILE1BQU0sQ0FBQyxNQUFNLFdBQVcsR0FBbUQ7SUFDekUsV0FBVyxFQUFFLENBQUMsR0FBRyxFQUFFLEVBQUUsQ0FBQztJQUN0QixTQUFTLEVBQUUsQ0FBQyxHQUFHLEVBQUUsR0FBRyxDQUFDO0lBQ3JCLGtCQUFrQixFQUFFLENBQUMsR0FBRyxFQUFFLEdBQUcsQ0FBQztJQUM5QixpQkFBaUIsRUFBRSxDQUFDLEdBQUcsRUFBRSxHQUFHLENBQUM7SUFDN0IsV0FBVyxFQUFFLENBQUMsR0FBRyxFQUFFLEdBQUcsQ0FBQztJQUN2QixVQUFVLEVBQUUsQ0FBQyxHQUFHLEVBQUUsR0FBRyxDQUFDO0lBQ3RCLGVBQWUsRUFBRSxDQUFDLEdBQUcsRUFBRSxFQUFFLENBQUM7SUFDMUIsb0JBQW9CLEVBQUUsQ0FBQyxHQUFHLEVBQUUsR0FBRyxDQUFDO0lBQ2hDLEtBQUssRUFBRSxPQUFPO0lBQ2QsTUFBTSxFQUFFLE9BQU87SUFDZixNQUFNLEVBQUUsT0FBTztDQUNoQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBBZHMgVHlwZXNcbiAqXG4gKiBUaXBvcyBlIGludGVyZmFjZXMgcGFyYSBlbCBzZXJ2aWNpbyBkZSBHb29nbGUgQWRTZW5zZS5cbiAqIFNpbXBsaWZpY2FkbyBwYXJhIHVzYXIgQWRTZW5zZSBlbiBsdWdhciBkZSBHUFQgKEFkIE1hbmFnZXIpLlxuICovXG5cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cbi8vIENPTkZJR1VSQUNJT05cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuLyoqXG4gKiBDb25maWd1cmFjaW9uIGRlbCBzZXJ2aWNpbyBkZSBBZHMuXG4gKiBQYXNhZGEgYSBwcm92aWRlVmFsdGVjaEFkcygpIGVuIGVsIGJvb3RzdHJhcCBkZSBsYSBhcGxpY2FjaW9uLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFZhbHRlY2hBZHNDb25maWcge1xuICAvKiogUHVibGlzaGVyIElEIGRlIEFkU2Vuc2UgKGZvcm1hdG86IGNhLXB1Yi1YWFhYWFhYWFhYWFhYWFhYKSAqL1xuICBhZENsaWVudDogc3RyaW5nO1xuXG4gIC8qKiBIYWJpbGl0YXIgbW9kbyBkZWJ1ZyAobXVlc3RyYSBpbmZvIGRlIGFkcyBlbiBjb25zb2xhKSAqL1xuICBkZWJ1Z01vZGU/OiBib29sZWFuO1xuXG4gIC8qKiBUZXN0IG1vZGUgLSB1c2EgYWRzIGRlIHBydWViYSBkdXJhbnRlIGRlc2Fycm9sbG8gKi9cbiAgdGVzdE1vZGU/OiBib29sZWFuO1xuXG4gIC8qKiBIYWJpbGl0YXIgQXV0byBBZHMgKEdvb2dsZSBkZWNpZGUgdWJpY2FjaW9uIGF1dG9tYXRpY2FtZW50ZSkgKi9cbiAgYXV0b0Fkcz86IGJvb2xlYW47XG5cbiAgLyoqIENhbGxiYWNrIGN1YW5kbyBzZSBjYXJnYSB1biBhZCAqL1xuICBvbkFkTG9hZGVkPzogKHNsb3RJZDogc3RyaW5nLCBpc0VtcHR5OiBib29sZWFuKSA9PiB2b2lkO1xuXG4gIC8qKiBDYWxsYmFjayBjdWFuZG8gZmFsbGEgdW4gYWQgKi9cbiAgb25BZEVycm9yPzogKHNsb3RJZDogc3RyaW5nLCBlcnJvcjogRXJyb3IpID0+IHZvaWQ7XG5cbiAgLyoqIFJ1dGFzIGRvbmRlIE5PIG1vc3RyYXIgYWRzIChyZWdleCBwYXR0ZXJucykgKi9cbiAgZXhjbHVkZVJvdXRlcz86IHN0cmluZ1tdO1xufVxuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBBRCBTTE9UU1xuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuXG4vKipcbiAqIEZvcm1hdG8gZGUgYWQgcGFyYSBBZFNlbnNlLlxuICovXG5leHBvcnQgdHlwZSBBZEZvcm1hdCA9ICdhdXRvJyB8ICdmbHVpZCcgfCAncmVjdGFuZ2xlJyB8ICdob3Jpem9udGFsJyB8ICd2ZXJ0aWNhbCc7XG5cbi8qKlxuICogQ29uZmlndXJhY2lvbiBkZSB1biBhZCBzbG90IGluZGl2aWR1YWwuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQWRTbG90Q29uZmlnIHtcbiAgLyoqIElEIHVuaWNvIGRlbCBzbG90ICh1c2FkbyBwYXJhIGVsIGRpdiBjb250YWluZXIpICovXG4gIHNsb3RJZDogc3RyaW5nO1xuXG4gIC8qKiBBZCBTbG90IElEIGRlIEFkU2Vuc2UgKG51bWVybyBkZSB1bmlkYWQgZGUgYW51bmNpbykgKi9cbiAgYWRTbG90Pzogc3RyaW5nO1xuXG4gIC8qKiBGb3JtYXRvIGRlbCBhZCAqL1xuICBmb3JtYXQ/OiBBZEZvcm1hdDtcblxuICAvKiogUmVzcG9uc2l2ZSAtIG9jdXBhIHRvZG8gZWwgYW5jaG8gZGlzcG9uaWJsZSAqL1xuICBmdWxsV2lkdGg/OiBib29sZWFuO1xuXG4gIC8qKiBDU1MgY2xhc3MgYWRpY2lvbmFsICovXG4gIGNzc0NsYXNzPzogc3RyaW5nO1xuXG4gIC8qKiBBbHR1cmEgbWluaW1hIG1pZW50cmFzIGNhcmdhICovXG4gIG1pbkhlaWdodD86IHN0cmluZztcblxuICAvKiogTW9zdHJhciBza2VsZXRvbiBtaWVudHJhcyBjYXJnYSAqL1xuICBzaG93U2tlbGV0b24/OiBib29sZWFuO1xufVxuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBFU1RBRE9cbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuLyoqXG4gKiBFc3RhZG8gZGUgdW4gYWQgc2xvdC5cbiAqL1xuZXhwb3J0IHR5cGUgQWRTbG90U3RhdGUgPVxuICB8ICdpZGxlJyAvLyBObyBjYXJnYWRvXG4gIHwgJ2xvYWRpbmcnIC8vIFNjcmlwdC9hZCBjYXJnYW5kb1xuICB8ICdyZW5kZXJlZCcgLy8gQWQgdmlzaWJsZVxuICB8ICdlbXB0eScgLy8gU2luIGFkIGRpc3BvbmlibGVcbiAgfCAnaGlkZGVuJyAvLyBVc3VhcmlvIHByZW1pdW0gbyBzaW4gY29uc2VudFxuICB8ICdlcnJvcic7IC8vIEVycm9yIGRlIGNhcmdhXG5cbi8qKlxuICogRXZlbnRvIGVtaXRpZG8gcG9yIGVsIHNlcnZpY2lvIGRlIGFkcy5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBBZEV2ZW50IHtcbiAgdHlwZTogJ2xvYWRlZCcgfCAnZW1wdHknIHwgJ2Vycm9yJyB8ICd2aWV3YWJsZScgfCAnY2xpY2tlZCc7XG4gIHNsb3RJZDogc3RyaW5nO1xuICB0aW1lc3RhbXA6IERhdGU7XG4gIGlzRW1wdHk/OiBib29sZWFuO1xuICBlcnJvcj86IEVycm9yO1xufVxuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBDT05TRU5UXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbi8qKlxuICogRXN0YWRvIGRlIGNvbnNlbnQgcGFyYSBhZHMgKG1hcGVhZG8gZGVzZGUgQW5hbHl0aWNzU2VydmljZSkuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQWRzQ29uc2VudFN0YXRlIHtcbiAgLyoqIFBlcm1pdGUgYWxtYWNlbmFtaWVudG8gZGUgYWRzICovXG4gIGFkU3RvcmFnZTogYm9vbGVhbjtcblxuICAvKiogUGVybWl0ZSBwZXJzb25hbGl6YWNpb24gZGUgYWRzICovXG4gIGFkUGVyc29uYWxpemF0aW9uOiBib29sZWFuO1xuXG4gIC8qKiBQZXJtaXRlIGRhdG9zIGRlIHVzdWFyaW8gcGFyYSBhZHMgKi9cbiAgYWRVc2VyRGF0YTogYm9vbGVhbjtcbn1cblxuLy8gPT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PVxuLy8gQURTRU5TRSAoR29vZ2xlIEFkU2Vuc2UpIFR5cGVzXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG5cbi8qKiBBZFNlbnNlIGdsb2JhbCBhcnJheSAqL1xuZXhwb3J0IHR5cGUgQWRTZW5zZUNvbW1hbmQgPSBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPjtcblxuLy8gRXh0ZW5kIFdpbmRvdyBpbnRlcmZhY2UgZm9yIGFkc2J5Z29vZ2xlXG5kZWNsYXJlIGdsb2JhbCB7XG4gIGludGVyZmFjZSBXaW5kb3cge1xuICAgIGFkc2J5Z29vZ2xlPzogQWRTZW5zZUNvbW1hbmRbXTtcbiAgfVxufVxuXG4vLyA9PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09XG4vLyBMRUdBQ1kgVFlQRVMgKG1hbnRlbmlkb3MgcGFyYSBjb21wYXRpYmlsaWRhZClcbi8vID09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT09PT1cblxuLyoqXG4gKiBAZGVwcmVjYXRlZCBVc2UgQWRGb3JtYXQgaW5zdGVhZFxuICovXG5leHBvcnQgdHlwZSBBZFNsb3RTaXplID1cbiAgfCAnbGVhZGVyYm9hcmQnXG4gIHwgJ2JpbGxib2FyZCdcbiAgfCAnbWVkaXVtLXJlY3RhbmdsZSdcbiAgfCAnbGFyZ2UtcmVjdGFuZ2xlJ1xuICB8ICdoYWxmLXBhZ2UnXG4gIHwgJ3NreXNjcmFwZXInXG4gIHwgJ21vYmlsZS1iYW5uZXInXG4gIHwgJ21vYmlsZS1sZWFkZXJib2FyZCdcbiAgfCAnZmx1aWQnXG4gIHwgJ25hdGl2ZSdcbiAgfCAnY3VzdG9tJztcblxuLyoqXG4gKiBAZGVwcmVjYXRlZCBBZFNlbnNlIGhhbmRsZXMgc2l6ZXMgYXV0b21hdGljYWxseVxuICovXG5leHBvcnQgY29uc3QgQURfU0laRV9NQVA6IFJlY29yZDxBZFNsb3RTaXplLCBbbnVtYmVyLCBudW1iZXJdIHwgJ2ZsdWlkJz4gPSB7XG4gIGxlYWRlcmJvYXJkOiBbNzI4LCA5MF0sXG4gIGJpbGxib2FyZDogWzk3MCwgMjUwXSxcbiAgJ21lZGl1bS1yZWN0YW5nbGUnOiBbMzAwLCAyNTBdLFxuICAnbGFyZ2UtcmVjdGFuZ2xlJzogWzMzNiwgMjgwXSxcbiAgJ2hhbGYtcGFnZSc6IFszMDAsIDYwMF0sXG4gIHNreXNjcmFwZXI6IFsxNjAsIDYwMF0sXG4gICdtb2JpbGUtYmFubmVyJzogWzMyMCwgNTBdLFxuICAnbW9iaWxlLWxlYWRlcmJvYXJkJzogWzMyMCwgMTAwXSxcbiAgZmx1aWQ6ICdmbHVpZCcsXG4gIG5hdGl2ZTogJ2ZsdWlkJyxcbiAgY3VzdG9tOiAnZmx1aWQnLFxufTtcblxuLyoqXG4gKiBAZGVwcmVjYXRlZCBOb3QgdXNlZCB3aXRoIEFkU2Vuc2VcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBTaXplTWFwcGluZyB7XG4gIHZpZXdwb3J0V2lkdGg6IG51bWJlcjtcbiAgc2l6ZXM6IChbbnVtYmVyLCBudW1iZXJdIHwgJ2ZsdWlkJylbXTtcbn1cbiJdfQ==
|
|
@@ -88,7 +88,7 @@ export const collections = {
|
|
|
88
88
|
* };
|
|
89
89
|
*/
|
|
90
90
|
export function createFirebaseConfig(config, options = {}) {
|
|
91
|
-
const { emulator, persistence = true, appId } = options;
|
|
91
|
+
const { emulator, persistence = true, appId, enableAnalytics, analyticsConfig } = options;
|
|
92
92
|
// Extraer campos de messaging del config (nuevos campos opcionales)
|
|
93
93
|
const { enableMessaging = false, messagingVapidKey, ...firebaseCore } = config;
|
|
94
94
|
return {
|
|
@@ -98,6 +98,8 @@ export function createFirebaseConfig(config, options = {}) {
|
|
|
98
98
|
messagingVapidKey,
|
|
99
99
|
emulator,
|
|
100
100
|
appId,
|
|
101
|
+
enableAnalytics,
|
|
102
|
+
analyticsConfig,
|
|
101
103
|
};
|
|
102
104
|
}
|
|
103
105
|
// ============================================================================
|
|
@@ -109,4 +111,4 @@ export function createFirebaseConfig(config, options = {}) {
|
|
|
109
111
|
export function isEmulatorMode(config) {
|
|
110
112
|
return config.emulator !== undefined;
|
|
111
113
|
}
|
|
112
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
114
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"shared-config.js","sourceRoot":"","sources":["../../../../../../src/lib/services/firebase/shared-config.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAQH,+EAA+E;AAC/E,wBAAwB;AACxB,+EAA+E;AAE/E;;;;;;;;;;;GAWG;AACH,MAAM,CAAC,MAAM,YAAY,GAAG;IAC1B,uDAAuD;IACvD,MAAM,EAAE,CAAC,KAAY,EAAE,GAAG,KAAe,EAAU,EAAE,CAAC,CAAC,KAAK,EAAE,GAAG,KAAK,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC;IAEjF,2CAA2C;IAC3C,MAAM,EAAE;QACN,gCAAgC;QAChC,YAAY,EAAE,CAAC,MAAc,EAAE,QAAgB,EAAU,EAAE,CACzD,kBAAkB,MAAM,IAAI,QAAQ,EAAE;QAExC,qDAAqD;QACrD,MAAM,EAAE,CAAC,GAAG,KAAe,EAAU,EAAE,CAAC,UAAU,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE;KACpE;CACF,CAAC;AAEF,+EAA+E;AAC/E,gCAAgC;AAChC,+EAA+E;AAE/E;;;;;;;;;;;;;;GAcG;AACH,MAAM,CAAC,MAAM,WAAW,GAAG;IACzB,gEAAgE;IAChE,MAAM,EAAE,CAAC,KAAY,EAAE,cAAsB,EAAU,EAAE,CAAC,QAAQ,KAAK,IAAI,cAAc,EAAE;IAE3F,0DAA0D;IAC1D,MAAM,EAAE;QACN,2BAA2B;QAC3B,KAAK,EAAE,OAAO;QACd,wBAAwB;QACxB,QAAQ,EAAE,UAAU;QACpB,iCAAiC;QACjC,aAAa,EAAE,eAAe;KAC/B;CACF,CAAC;AAkCF;;;;;;;;;;;;;;;;;;;;;;;;GAwBG;AACH,MAAM,UAAU,oBAAoB,CAClC,MAAsB,EACtB,UAAuC,EAAE;IAEzC,MAAM,EAAE,QAAQ,EAAE,WAAW,GAAG,IAAI,EAAE,KAAK,EAAE,eAAe,EAAE,eAAe,EAAE,GAAG,OAAO,CAAC;IAE1F,oEAAoE;IACpE,MAAM,EAAE,eAAe,GAAG,KAAK,EAAE,iBAAiB,EAAE,GAAG,YAAY,EAAE,GAAG,MAAM,CAAC;IAE/E,OAAO;QACL,QAAQ,EAAE,YAA8B;QACxC,WAAW;QACX,eAAe;QACf,iBAAiB;QACjB,QAAQ;QACR,KAAK;QACL,eAAe;QACf,eAAe;KAChB,CAAC;AACJ,CAAC;AAED,+EAA+E;AAC/E,6CAA6C;AAC7C,+EAA+E;AAE/E;;GAEG;AACH,MAAM,UAAU,cAAc,CAAC,MAA6B;IAC1D,OAAO,MAAM,CAAC,QAAQ,KAAK,SAAS,CAAC;AACvC,CAAC","sourcesContent":["/**\n * Firebase Shared Configuration\n *\n * Utilidades genéricas para configuración de Firebase.\n * Las constantes específicas del proyecto (APP_IDS, FIREBASE_PROJECTS, EMULATOR_CONFIG)\n * deben definirse en cada app consumidora.\n */\n\nimport { AppId, EmulatorConfig, FirebaseConfig, ValtechFirebaseConfig } from './types';\nimport type { AnalyticsConfig } from './analytics-types';\n\n// Re-export types for convenience\nexport type { AppId } from './types';\n\n// ============================================================================\n// STORAGE PATH BUILDERS\n// ============================================================================\n\n/**\n * Genera paths de Storage con namespace por app.\n *\n * @example\n * // Path específico de la app\n * storagePaths.forApp('showcase', 'uploads', 'image.jpg')\n * // => 'showcase/uploads/image.jpg'\n *\n * // Path compartido\n * storagePaths.shared.profilePhoto('user123', 'avatar.jpg')\n * // => 'profile-photos/user123/avatar.jpg'\n */\nexport const storagePaths = {\n  /** Carpeta específica de la app: {appId}/{...paths} */\n  forApp: (appId: AppId, ...paths: string[]): string => [appId, ...paths].join('/'),\n\n  /** Carpetas compartidas (sin namespace) */\n  shared: {\n    /** Foto de perfil de usuario */\n    profilePhoto: (userId: string, fileName: string): string =>\n      `profile-photos/${userId}/${fileName}`,\n\n    /** Archivos públicos accesibles sin autenticación */\n    public: (...paths: string[]): string => `public/${paths.join('/')}`,\n  },\n};\n\n// ============================================================================\n// FIRESTORE COLLECTION BUILDERS\n// ============================================================================\n\n/**\n * Genera paths de colecciones con namespace por app.\n *\n * IMPORTANTE: La estructura es /apps/{appId}/{collection}/{docId}\n * Firestore requiere número impar de segmentos para paths de colección.\n *\n * @example\n * // Colección específica de la app\n * collections.forApp('showcase', 'items')\n * // => 'apps/showcase/items'\n *\n * // Colección compartida\n * collections.shared.users\n * // => 'users'\n */\nexport const collections = {\n  /** Colección específica de la app: apps/{appId}/{collection} */\n  forApp: (appId: AppId, collectionName: string): string => `apps/${appId}/${collectionName}`,\n\n  /** Colecciones compartidas (sin namespace, nivel raíz) */\n  shared: {\n    /** Usuarios del sistema */\n    users: 'users',\n    /** Perfiles públicos */\n    profiles: 'profiles',\n    /** Notificaciones de usuarios */\n    notifications: 'notifications',\n  },\n};\n\n// ============================================================================\n// HELPER: Create Firebase Config from Environment\n// ============================================================================\n\n/**\n * Opciones para crear la configuración de Firebase\n */\nexport interface CreateFirebaseConfigOptions {\n  /**\n   * Configuración de emuladores (para desarrollo local).\n   * Pasa tu propia configuración con hosts y puertos.\n   */\n  emulator?: EmulatorConfig;\n  /** Habilitar persistencia offline de Firestore */\n  persistence?: boolean;\n  /**\n   * ID de la aplicación para namespacing automático.\n   * Cuando se configura, FirestoreService y StorageService prefijan automáticamente los paths.\n   */\n  appId?: string;\n  /**\n   * Habilitar Firebase Analytics / GA4.\n   * Requiere measurementId en firebase config.\n   */\n  enableAnalytics?: boolean;\n  /**\n   * Configuración detallada de Analytics.\n   * Solo aplica si enableAnalytics es true.\n   */\n  analyticsConfig?: AnalyticsConfig;\n}\n\n/**\n * Crea la configuración completa de Firebase desde variables de entorno.\n * Usa esto en el environment.ts de cada app.\n *\n * @example\n * // environment.ts\n * import { createFirebaseConfig } from 'valtech-components';\n * import { APP_IDS, EMULATOR_CONFIG, USE_EMULATORS } from '../config/app-config';\n * import firebaseConfig from '../config/firebase.config.json';\n *\n * export const environment = {\n *   valtechFirebase: createFirebaseConfig(\n *     {\n *       ...firebaseConfig,\n *       enableMessaging: true,\n *       messagingVapidKey: 'BHLx...',\n *     },\n *     {\n *       emulator: USE_EMULATORS ? EMULATOR_CONFIG : undefined,\n *       persistence: true,\n *       appId: APP_IDS.MY_APP,\n *     }\n *   ),\n * };\n */\nexport function createFirebaseConfig(\n  config: FirebaseConfig,\n  options: CreateFirebaseConfigOptions = {}\n): ValtechFirebaseConfig {\n  const { emulator, persistence = true, appId, enableAnalytics, analyticsConfig } = options;\n\n  // Extraer campos de messaging del config (nuevos campos opcionales)\n  const { enableMessaging = false, messagingVapidKey, ...firebaseCore } = config;\n\n  return {\n    firebase: firebaseCore as FirebaseConfig,\n    persistence,\n    enableMessaging,\n    messagingVapidKey,\n    emulator,\n    appId,\n    enableAnalytics,\n    analyticsConfig,\n  };\n}\n\n// ============================================================================\n// UTILITY: Check if running in emulator mode\n// ============================================================================\n\n/**\n * Verifica si la configuración tiene emuladores habilitados\n */\nexport function isEmulatorMode(config: ValtechFirebaseConfig): boolean {\n  return config.emulator !== undefined;\n}\n"]}
|