@rxap/config 12.3.0 → 13.0.0-next.0

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.
@@ -0,0 +1,4 @@
1
+ export * from './lib/config.service';
2
+ export * from './lib/tokens';
3
+ export * from './lib/config-loader.service';
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJzL2NvbmZpZy9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLDZCQUE2QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvY29uZmlnLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdG9rZW5zJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbmZpZy1sb2FkZXIuc2VydmljZSc7XG4iXX0=
@@ -0,0 +1,33 @@
1
+ import { Injectable, Inject } from '@angular/core';
2
+ import { HttpClient } from '@angular/common/http';
3
+ import { finalize, share } from 'rxjs/operators';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "@angular/common/http";
6
+ export class ConfigLoaderService {
7
+ constructor(http) {
8
+ this.http = http;
9
+ this.configs = new Map();
10
+ this.configLoading = new Map();
11
+ }
12
+ async load$(url) {
13
+ if (this.configs.has(url)) {
14
+ return this.configs.get(url);
15
+ }
16
+ if (this.configLoading.has(url)) {
17
+ return this.configLoading.get(url).toPromise();
18
+ }
19
+ const loading$ = this.http.get(url).pipe(finalize(() => this.configLoading.delete(url)), share());
20
+ this.configLoading.set(url, loading$);
21
+ return loading$.toPromise();
22
+ }
23
+ }
24
+ ConfigLoaderService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: ConfigLoaderService, deps: [{ token: HttpClient }], target: i0.ɵɵFactoryTarget.Injectable });
25
+ ConfigLoaderService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: ConfigLoaderService, providedIn: 'root' });
26
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: ConfigLoaderService, decorators: [{
27
+ type: Injectable,
28
+ args: [{ providedIn: 'root' }]
29
+ }], ctorParameters: function () { return [{ type: i1.HttpClient, decorators: [{
30
+ type: Inject,
31
+ args: [HttpClient]
32
+ }] }]; } });
33
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnLWxvYWRlci5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicy9jb25maWcvc3JjL2xpYi9jb25maWctbG9hZGVyLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFbkQsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ2xELE9BQU8sRUFBRSxRQUFRLEVBQUUsS0FBSyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7OztBQUdqRCxNQUFNLE9BQU8sbUJBQW1CO0lBSzlCLFlBRWtCLElBQWdCO1FBQWhCLFNBQUksR0FBSixJQUFJLENBQVk7UUFObEIsWUFBTyxHQUFHLElBQUksR0FBRyxFQUFlLENBQUM7UUFFakMsa0JBQWEsR0FBRyxJQUFJLEdBQUcsRUFBMkIsQ0FBQztJQUtoRSxDQUFDO0lBRUcsS0FBSyxDQUFDLEtBQUssQ0FBVSxHQUFXO1FBQ3JDLElBQUksSUFBSSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLEVBQUU7WUFDekIsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQztTQUM5QjtRQUVELElBQUksSUFBSSxDQUFDLGFBQWEsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLEVBQUU7WUFDL0IsT0FBTyxJQUFJLENBQUMsYUFBYSxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUUsQ0FBQyxTQUFTLEVBQUUsQ0FBQztTQUNqRDtRQUVELE1BQU0sUUFBUSxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFJLEdBQUcsQ0FBQyxDQUFDLElBQUksQ0FDekMsUUFBUSxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDLEVBQzlDLEtBQUssRUFBRSxDQUNSLENBQUM7UUFFRixJQUFJLENBQUMsYUFBYSxDQUFDLEdBQUcsQ0FBQyxHQUFHLEVBQUUsUUFBUSxDQUFDLENBQUM7UUFFdEMsT0FBTyxRQUFRLENBQUMsU0FBUyxFQUFFLENBQUM7SUFDOUIsQ0FBQzs7Z0hBM0JVLG1CQUFtQixrQkFNcEIsVUFBVTtvSEFOVCxtQkFBbUIsY0FETixNQUFNOzJGQUNuQixtQkFBbUI7a0JBRC9CLFVBQVU7bUJBQUMsRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFOzswQkFPN0IsTUFBTTsyQkFBQyxVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSwgSW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBIdHRwQ2xpZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xuaW1wb3J0IHsgZmluYWxpemUsIHNoYXJlIH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuXG5ASW5qZWN0YWJsZSh7IHByb3ZpZGVkSW46ICdyb290JyB9KVxuZXhwb3J0IGNsYXNzIENvbmZpZ0xvYWRlclNlcnZpY2Uge1xuICBwdWJsaWMgcmVhZG9ubHkgY29uZmlncyA9IG5ldyBNYXA8c3RyaW5nLCBhbnk+KCk7XG5cbiAgcHVibGljIHJlYWRvbmx5IGNvbmZpZ0xvYWRpbmcgPSBuZXcgTWFwPHN0cmluZywgT2JzZXJ2YWJsZTxhbnk+PigpO1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIEBJbmplY3QoSHR0cENsaWVudClcbiAgICBwdWJsaWMgcmVhZG9ubHkgaHR0cDogSHR0cENsaWVudFxuICApIHt9XG5cbiAgcHVibGljIGFzeW5jIGxvYWQkPFQgPSBhbnk+KHVybDogc3RyaW5nKTogUHJvbWlzZTxUPiB7XG4gICAgaWYgKHRoaXMuY29uZmlncy5oYXModXJsKSkge1xuICAgICAgcmV0dXJuIHRoaXMuY29uZmlncy5nZXQodXJsKTtcbiAgICB9XG5cbiAgICBpZiAodGhpcy5jb25maWdMb2FkaW5nLmhhcyh1cmwpKSB7XG4gICAgICByZXR1cm4gdGhpcy5jb25maWdMb2FkaW5nLmdldCh1cmwpIS50b1Byb21pc2UoKTtcbiAgICB9XG5cbiAgICBjb25zdCBsb2FkaW5nJCA9IHRoaXMuaHR0cC5nZXQ8VD4odXJsKS5waXBlKFxuICAgICAgZmluYWxpemUoKCkgPT4gdGhpcy5jb25maWdMb2FkaW5nLmRlbGV0ZSh1cmwpKSxcbiAgICAgIHNoYXJlKClcbiAgICApO1xuXG4gICAgdGhpcy5jb25maWdMb2FkaW5nLnNldCh1cmwsIGxvYWRpbmckKTtcblxuICAgIHJldHVybiBsb2FkaW5nJC50b1Byb21pc2UoKTtcbiAgfVxufVxuIl19
@@ -0,0 +1,156 @@
1
+ import { Injectable, Optional, Inject } from '@angular/core';
2
+ import { deepMerge, SetObjectValue } from '@rxap/utilities';
3
+ import { RXAP_CONFIG } from './tokens';
4
+ import * as i0 from "@angular/core";
5
+ export class ConfigService {
6
+ constructor(config = null) {
7
+ this.config = ConfigService.Config;
8
+ if (config) {
9
+ this.config = deepMerge(this.config ?? {}, config);
10
+ }
11
+ if (!this.config) {
12
+ throw new Error('config not available');
13
+ }
14
+ }
15
+ static async SideLoad(url, propertyPath, required) {
16
+ if (!this.Config) {
17
+ throw new Error('Config side load is only possible after the initial config load.');
18
+ }
19
+ try {
20
+ const response = await fetch(url);
21
+ SetObjectValue(this.Config, propertyPath, await response.json());
22
+ }
23
+ catch (error) {
24
+ if (required) {
25
+ throw new Error(`Could not side load config '${url}': ${error.message}`);
26
+ }
27
+ else {
28
+ console.warn(url, error.message);
29
+ }
30
+ }
31
+ console.debug(`app config side load '${propertyPath}'`, this.Config);
32
+ }
33
+ /**
34
+ * Used to load the app config from a remote resource.
35
+ *
36
+ * Promise.all([ ConfigService.Load() ])
37
+ * .then(() => platformBrowserDynamic().bootstrapModule(AppModule))
38
+ * .catch(err => console.error(err))
39
+ *
40
+ */
41
+ static async Load(options) {
42
+ let config = this.Defaults;
43
+ for (const url of ConfigService.Urls) {
44
+ try {
45
+ const response = await fetch(url);
46
+ config = deepMerge(config, await response.json());
47
+ }
48
+ catch (error) {
49
+ console.error(url, error.message);
50
+ }
51
+ }
52
+ config = deepMerge(config, this.Overwrites);
53
+ if (options?.fromLocalStorage !== false) {
54
+ const localConfig = localStorage.getItem(ConfigService.LocalStorageKey);
55
+ if (localConfig) {
56
+ try {
57
+ config = deepMerge(config, JSON.parse(localConfig));
58
+ }
59
+ catch (e) {
60
+ console.error('local config could not be parsed');
61
+ }
62
+ }
63
+ }
64
+ if (options?.fromUrlParam) {
65
+ const param = typeof options.fromUrlParam === 'string' ? options.fromUrlParam : 'config';
66
+ config = deepMerge(config, this.LoadConfigDefaultFromUrlParam(param));
67
+ }
68
+ console.debug('app config', config);
69
+ ConfigService.Config = config;
70
+ }
71
+ static LoadConfigDefaultFromUrlParam(param = 'config') {
72
+ const queryString = window.location.search;
73
+ const urlParams = new URLSearchParams(queryString);
74
+ const configFromParams = {};
75
+ for (const configParam of urlParams.getAll('config')) {
76
+ try {
77
+ const split = configParam.split(';');
78
+ if (split.length === 2) {
79
+ const keyPath = split[0];
80
+ const value = split[1];
81
+ SetObjectValue(configFromParams, keyPath, value);
82
+ }
83
+ }
84
+ catch (e) {
85
+ console.warn(`Parsing of url config param failed for '${configParam}': ${e.message}`);
86
+ }
87
+ }
88
+ return configFromParams;
89
+ }
90
+ static Get(path, defaultValue, config = this.Config) {
91
+ if (!config) {
92
+ throw new Error('config not loaded');
93
+ }
94
+ let configValue = config;
95
+ if (typeof path !== 'string') {
96
+ throw new Error('The config property path is not a string');
97
+ }
98
+ for (const fragment of path.split('.')) {
99
+ if (configValue.hasOwnProperty(fragment)) {
100
+ configValue = configValue[fragment];
101
+ }
102
+ else {
103
+ if (defaultValue !== undefined) {
104
+ return defaultValue;
105
+ }
106
+ console.warn(`Config with path '${path}' not found`);
107
+ return undefined;
108
+ }
109
+ }
110
+ return configValue;
111
+ }
112
+ setLocalConfig(config) {
113
+ localStorage.setItem(ConfigService.LocalStorageKey, JSON.stringify(config));
114
+ }
115
+ clearLocalConfig() {
116
+ localStorage.removeItem(ConfigService.LocalStorageKey);
117
+ }
118
+ get(propertyPath, defaultValue) {
119
+ return ConfigService.Get(propertyPath, defaultValue, this.config);
120
+ }
121
+ getOrThrow(propertyPath, defaultValue) {
122
+ const value = ConfigService.Get(propertyPath, defaultValue, this.config);
123
+ if (value === undefined) {
124
+ throw new Error(`Could not find config in path '${propertyPath}'`);
125
+ }
126
+ return value;
127
+ }
128
+ }
129
+ ConfigService.Config = null;
130
+ /**
131
+ * Static default values for the config object.
132
+ * Will be overwritten by an dynamic config file specified in
133
+ * the Urls array.
134
+ */
135
+ ConfigService.Defaults = {};
136
+ /**
137
+ * Any value definition in the Overwrites object will overwrite any
138
+ * value form the Defaults values or dynamic config files
139
+ */
140
+ ConfigService.Overwrites = {};
141
+ ConfigService.LocalStorageKey = 'rxap/config/local-config';
142
+ ConfigService.Urls = ['config.json'];
143
+ ConfigService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: ConfigService, deps: [{ token: RXAP_CONFIG, optional: true }], target: i0.ɵɵFactoryTarget.Injectable });
144
+ ConfigService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: ConfigService, providedIn: 'root' });
145
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: ConfigService, decorators: [{
146
+ type: Injectable,
147
+ args: [{
148
+ providedIn: 'root'
149
+ }]
150
+ }], ctorParameters: function () { return [{ type: undefined, decorators: [{
151
+ type: Optional
152
+ }, {
153
+ type: Inject,
154
+ args: [RXAP_CONFIG]
155
+ }] }]; } });
156
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"config.service.js","sourceRoot":"","sources":["../../../../../libs/config/src/lib/config.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Injectable,\n  Optional,\n  Inject\n} from '@angular/core';\nimport {\n  deepMerge,\n  SetObjectValue\n} from '@rxap/utilities';\nimport { RXAP_CONFIG } from './tokens';\nimport { NoInferType } from './types';\n\nexport interface ConfigLoadOptions {\n  fromUrlParam?: string | boolean;\n  fromLocalStorage?: boolean;\n}\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class ConfigService<Config extends Record<string, any> = Record<string, any>> {\n\n  public static Config: any = null;\n\n  /**\n   * Static default values for the config object.\n   * Will be overwritten by an dynamic config file specified in\n   * the Urls array.\n   */\n  public static Defaults: any = {};\n\n  /**\n   * Any value definition in the Overwrites object will overwrite any\n   * value form the Defaults values or dynamic config files\n   */\n  public static Overwrites: any = {};\n\n  public static LocalStorageKey = 'rxap/config/local-config';\n\n  public static Urls = [ 'config.json' ];\n\n  public static async SideLoad(url: string, propertyPath: string, required?: boolean): Promise<void> {\n\n    if (!this.Config) {\n      throw new Error('Config side load is only possible after the initial config load.');\n    }\n\n    try {\n\n      const response = await fetch(url);\n      SetObjectValue(this.Config, propertyPath, await response.json());\n\n    } catch (error: any) {\n      if (required) {\n        throw new Error(`Could not side load config '${url}': ${error.message}`);\n      } else {\n        console.warn(url, error.message);\n      }\n    }\n\n    console.debug(`app config side load '${propertyPath}'`, this.Config);\n\n  }\n\n  /**\n   * Used to load the app config from a remote resource.\n   *\n   * Promise.all([ ConfigService.Load() ])\n   * .then(() => platformBrowserDynamic().bootstrapModule(AppModule))\n   * .catch(err => console.error(err))\n   *\n   */\n  public static async Load(options?: ConfigLoadOptions): Promise<void> {\n    let config = this.Defaults;\n    for (const url of ConfigService.Urls) {\n      try {\n\n        const response = await fetch(url);\n        config         = deepMerge(config, await response.json());\n\n      } catch (error: any) {\n        console.error(url, error.message);\n      }\n    }\n\n    config = deepMerge(config, this.Overwrites);\n\n    if (options?.fromLocalStorage !== false) {\n\n      const localConfig = localStorage.getItem(ConfigService.LocalStorageKey);\n\n      if (localConfig) {\n        try {\n          config = deepMerge(config, JSON.parse(localConfig));\n        } catch (e: any) {\n          console.error('local config could not be parsed');\n        }\n      }\n\n    }\n\n    if (options?.fromUrlParam) {\n      const param = typeof options.fromUrlParam === 'string' ? options.fromUrlParam : 'config';\n      config      = deepMerge(config, this.LoadConfigDefaultFromUrlParam(param));\n    }\n\n    console.debug('app config', config);\n\n    ConfigService.Config = config;\n  }\n\n  private static LoadConfigDefaultFromUrlParam(param: string = 'config') {\n\n    const queryString = window.location.search;\n    const urlParams   = new URLSearchParams(queryString);\n\n    const configFromParams = {};\n\n    for (const configParam of urlParams.getAll('config')) {\n\n      try {\n        const split = configParam.split(';');\n        if (split.length === 2) {\n          const keyPath = split[ 0 ];\n          const value   = split[ 1 ];\n          SetObjectValue(configFromParams, keyPath, value);\n        }\n      } catch (e: any) {\n        console.warn(`Parsing of url config param failed for '${configParam}': ${e.message}`);\n      }\n\n    }\n\n    return configFromParams;\n\n  }\n\n  public static Get<T = any, K extends Record<string, any> = Record<string, any>>(path: string, defaultValue: T | undefined, config: Record<string, any>): T\n  public static Get<T = any, K extends Record<string, any> = Record<string, any>>(\n    path: string,\n    defaultValue: NoInferType<T>,\n    config: Record<string, any> = this.Config\n  ): T {\n    if (!config) {\n      throw new Error('config not loaded');\n    }\n    let configValue: any = config;\n    if (typeof path !== 'string') {\n      throw new Error('The config property path is not a string');\n    }\n    for (const fragment of (path as any).split('.')) {\n      if (configValue.hasOwnProperty(fragment)) {\n        configValue = configValue[ fragment ];\n      } else {\n        if (defaultValue !== undefined) {\n          return defaultValue;\n        }\n        console.warn(`Config with path '${path}' not found`);\n        return undefined as any;\n      }\n    }\n    return configValue;\n  }\n\n  public readonly config!: Config;\n\n  constructor(@Optional() @Inject(RXAP_CONFIG) config: any | null = null) {\n    this.config = ConfigService.Config;\n    if (config) {\n      this.config = deepMerge(this.config ?? {}, config);\n    }\n    if (!this.config) {\n      throw new Error('config not available');\n    }\n  }\n\n  public setLocalConfig(config: Config): void {\n    localStorage.setItem(ConfigService.LocalStorageKey, JSON.stringify(config));\n  }\n\n  public clearLocalConfig(): void {\n    localStorage.removeItem(ConfigService.LocalStorageKey);\n  }\n\n  public get<T = any>(propertyPath: string): T | undefined;\n  public get<T = any>(propertyPath: string, defaultValue: NoInferType<T>): T;\n  public get<T = any>(propertyPath: string, defaultValue?: T): T | undefined {\n    return ConfigService.Get(propertyPath, defaultValue, this.config);\n  }\n\n  public getOrThrow<T = any>(propertyPath: string): T;\n  public getOrThrow<T = any>(propertyPath: string, defaultValue: NoInferType<T>): T;\n  public getOrThrow<T = any>(propertyPath: string, defaultValue?: T): T {\n    const value = ConfigService.Get(propertyPath, defaultValue, this.config);\n    if (value === undefined) {\n      throw new Error(`Could not find config in path '${propertyPath}'`);\n    }\n    return value;\n  }\n\n}\n"]}
@@ -0,0 +1,3 @@
1
+ import { InjectionToken } from '@angular/core';
2
+ export const RXAP_CONFIG = new InjectionToken('rxap/config');
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9rZW5zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicy9jb25maWcvc3JjL2xpYi90b2tlbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUvQyxNQUFNLENBQUMsTUFBTSxXQUFXLEdBQUcsSUFBSSxjQUFjLENBQUMsYUFBYSxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3Rpb25Ub2tlbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5leHBvcnQgY29uc3QgUlhBUF9DT05GSUcgPSBuZXcgSW5qZWN0aW9uVG9rZW4oJ3J4YXAvY29uZmlnJyk7XG4iXX0=
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2NvbmZpZy9zcmMvbGliL3R5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZGVjbGFyZSB0eXBlIE5vSW5mZXJUeXBlPFQ+ID0gWyBUIF1bVCBleHRlbmRzIGFueSA/IDAgOiBuZXZlcl07XG5cbnR5cGUgUHJldiA9IFtcbiAgbmV2ZXIsIDAsIDEsIDIsIDMsIDQsIDUsIDYsIDcsIDgsIDksIDEwLFxuICAxMSwgMTIsIDEzLCAxNCwgMTUsIDE2LCAxNywgMTgsIDE5LCAyMCwgLi4uMFtdXG5dXG5cbmV4cG9ydCB0eXBlIEpvaW48SywgUD4gPSBLIGV4dGVuZHMgc3RyaW5nIHwgbnVtYmVyID9cbiAgICAgICAgICAgICAgICAgICAgICAgICBQIGV4dGVuZHMgc3RyaW5nIHwgbnVtYmVyID9cbiAgICAgICAgICAgICAgICAgICAgICAgICBgJHtLfSR7JycgZXh0ZW5kcyBQID8gJycgOiAnLid9JHtQfWBcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIDogbmV2ZXIgOiBuZXZlcjtcblxuZXhwb3J0IHR5cGUgUGF0aHM8VCwgRCBleHRlbmRzIG51bWJlciA9IDEwPiA9IFsgRCBdIGV4dGVuZHMgWyBuZXZlciBdID8gbmV2ZXIgOiBUIGV4dGVuZHMgb2JqZWN0ID9cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFtLIGluIGtleW9mIFRdLT86IEsgZXh0ZW5kcyBzdHJpbmcgfCBudW1iZXIgP1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGAke0t9YCB8IEpvaW48SywgUGF0aHM8VFtLXSwgUHJldltEXT4+XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICA6IG5ldmVyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIH1ba2V5b2YgVF0gOiAnJztcblxuZXhwb3J0IHR5cGUgTGVhdmVzPFQsIEQgZXh0ZW5kcyBudW1iZXIgPSAxMD4gPSBbIEQgXSBleHRlbmRzIFsgbmV2ZXIgXSA/IG5ldmVyIDogVCBleHRlbmRzIG9iamVjdCA/XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB7IFtLIGluIGtleW9mIFRdLT86IEpvaW48SywgTGVhdmVzPFRbS10sIFByZXZbRF0+PiB9W2tleW9mIFRdIDogJyc7XG4iXX0=
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './index';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicnhhcC1jb25maWcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJzL2NvbmZpZy9zcmMvcnhhcC1jb25maWcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLFNBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9pbmRleCc7XG4iXX0=
@@ -151,19 +151,21 @@ ConfigService.Defaults = {};
151
151
  ConfigService.Overwrites = {};
152
152
  ConfigService.LocalStorageKey = 'rxap/config/local-config';
153
153
  ConfigService.Urls = ['config.json'];
154
- ConfigService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.1", ngImport: i0, type: ConfigService, deps: [{ token: RXAP_CONFIG, optional: true }], target: i0.ɵɵFactoryTarget.Injectable });
155
- ConfigService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.0.1", ngImport: i0, type: ConfigService, providedIn: 'root' });
156
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.1", ngImport: i0, type: ConfigService, decorators: [{
154
+ ConfigService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: ConfigService, deps: [{ token: RXAP_CONFIG, optional: true }], target: i0.ɵɵFactoryTarget.Injectable });
155
+ ConfigService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: ConfigService, providedIn: 'root' });
156
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: ConfigService, decorators: [{
157
157
  type: Injectable,
158
158
  args: [{
159
159
  providedIn: 'root'
160
160
  }]
161
- }], ctorParameters: function () { return [{ type: undefined, decorators: [{
162
- type: Optional
163
- }, {
164
- type: Inject,
165
- args: [RXAP_CONFIG]
166
- }] }]; } });
161
+ }], ctorParameters: function () {
162
+ return [{ type: undefined, decorators: [{
163
+ type: Optional
164
+ }, {
165
+ type: Inject,
166
+ args: [RXAP_CONFIG]
167
+ }] }];
168
+ } });
167
169
 
168
170
  class ConfigLoaderService {
169
171
  constructor(http) {
@@ -185,19 +187,21 @@ class ConfigLoaderService {
185
187
  });
186
188
  }
187
189
  }
188
- ConfigLoaderService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.1", ngImport: i0, type: ConfigLoaderService, deps: [{ token: HttpClient }], target: i0.ɵɵFactoryTarget.Injectable });
189
- ConfigLoaderService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.0.1", ngImport: i0, type: ConfigLoaderService, providedIn: 'root' });
190
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.1", ngImport: i0, type: ConfigLoaderService, decorators: [{
190
+ ConfigLoaderService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: ConfigLoaderService, deps: [{ token: HttpClient }], target: i0.ɵɵFactoryTarget.Injectable });
191
+ ConfigLoaderService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: ConfigLoaderService, providedIn: 'root' });
192
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: ConfigLoaderService, decorators: [{
191
193
  type: Injectable,
192
194
  args: [{ providedIn: 'root' }]
193
- }], ctorParameters: function () { return [{ type: i1.HttpClient, decorators: [{
194
- type: Inject,
195
- args: [HttpClient]
196
- }] }]; } });
195
+ }], ctorParameters: function () {
196
+ return [{ type: i1.HttpClient, decorators: [{
197
+ type: Inject,
198
+ args: [HttpClient]
199
+ }] }];
200
+ } });
197
201
 
198
202
  /**
199
203
  * Generated bundle index. Do not edit.
200
204
  */
201
205
 
202
206
  export { ConfigLoaderService, ConfigService, RXAP_CONFIG };
203
- //# sourceMappingURL=rxap-config.js.map
207
+ //# sourceMappingURL=rxap-config.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rxap-config.mjs","sources":["../../../../libs/config/src/lib/tokens.ts","../../../../libs/config/src/lib/config.service.ts","../../../../libs/config/src/lib/config-loader.service.ts","../../../../libs/config/src/rxap-config.ts"],"sourcesContent":["import { InjectionToken } from '@angular/core';\n\nexport const RXAP_CONFIG = new InjectionToken('rxap/config');\n","import {\n Injectable,\n Optional,\n Inject\n} from '@angular/core';\nimport {\n deepMerge,\n SetObjectValue\n} from '@rxap/utilities';\nimport { RXAP_CONFIG } from './tokens';\nimport { NoInferType } from './types';\n\nexport interface ConfigLoadOptions {\n fromUrlParam?: string | boolean;\n fromLocalStorage?: boolean;\n}\n\n@Injectable({\n providedIn: 'root'\n})\nexport class ConfigService<Config extends Record<string, any> = Record<string, any>> {\n\n public static Config: any = null;\n\n /**\n * Static default values for the config object.\n * Will be overwritten by an dynamic config file specified in\n * the Urls array.\n */\n public static Defaults: any = {};\n\n /**\n * Any value definition in the Overwrites object will overwrite any\n * value form the Defaults values or dynamic config files\n */\n public static Overwrites: any = {};\n\n public static LocalStorageKey = 'rxap/config/local-config';\n\n public static Urls = [ 'config.json' ];\n\n public static async SideLoad(url: string, propertyPath: string, required?: boolean): Promise<void> {\n\n if (!this.Config) {\n throw new Error('Config side load is only possible after the initial config load.');\n }\n\n try {\n\n const response = await fetch(url);\n SetObjectValue(this.Config, propertyPath, await response.json());\n\n } catch (error: any) {\n if (required) {\n throw new Error(`Could not side load config '${url}': ${error.message}`);\n } else {\n console.warn(url, error.message);\n }\n }\n\n console.debug(`app config side load '${propertyPath}'`, this.Config);\n\n }\n\n /**\n * Used to load the app config from a remote resource.\n *\n * Promise.all([ ConfigService.Load() ])\n * .then(() => platformBrowserDynamic().bootstrapModule(AppModule))\n * .catch(err => console.error(err))\n *\n */\n public static async Load(options?: ConfigLoadOptions): Promise<void> {\n let config = this.Defaults;\n for (const url of ConfigService.Urls) {\n try {\n\n const response = await fetch(url);\n config = deepMerge(config, await response.json());\n\n } catch (error: any) {\n console.error(url, error.message);\n }\n }\n\n config = deepMerge(config, this.Overwrites);\n\n if (options?.fromLocalStorage !== false) {\n\n const localConfig = localStorage.getItem(ConfigService.LocalStorageKey);\n\n if (localConfig) {\n try {\n config = deepMerge(config, JSON.parse(localConfig));\n } catch (e: any) {\n console.error('local config could not be parsed');\n }\n }\n\n }\n\n if (options?.fromUrlParam) {\n const param = typeof options.fromUrlParam === 'string' ? options.fromUrlParam : 'config';\n config = deepMerge(config, this.LoadConfigDefaultFromUrlParam(param));\n }\n\n console.debug('app config', config);\n\n ConfigService.Config = config;\n }\n\n private static LoadConfigDefaultFromUrlParam(param: string = 'config') {\n\n const queryString = window.location.search;\n const urlParams = new URLSearchParams(queryString);\n\n const configFromParams = {};\n\n for (const configParam of urlParams.getAll('config')) {\n\n try {\n const split = configParam.split(';');\n if (split.length === 2) {\n const keyPath = split[ 0 ];\n const value = split[ 1 ];\n SetObjectValue(configFromParams, keyPath, value);\n }\n } catch (e: any) {\n console.warn(`Parsing of url config param failed for '${configParam}': ${e.message}`);\n }\n\n }\n\n return configFromParams;\n\n }\n\n public static Get<T = any, K extends Record<string, any> = Record<string, any>>(path: string, defaultValue: T | undefined, config: Record<string, any>): T\n public static Get<T = any, K extends Record<string, any> = Record<string, any>>(\n path: string,\n defaultValue: NoInferType<T>,\n config: Record<string, any> = this.Config\n ): T {\n if (!config) {\n throw new Error('config not loaded');\n }\n let configValue: any = config;\n if (typeof path !== 'string') {\n throw new Error('The config property path is not a string');\n }\n for (const fragment of (path as any).split('.')) {\n if (configValue.hasOwnProperty(fragment)) {\n configValue = configValue[ fragment ];\n } else {\n if (defaultValue !== undefined) {\n return defaultValue;\n }\n console.warn(`Config with path '${path}' not found`);\n return undefined as any;\n }\n }\n return configValue;\n }\n\n public readonly config!: Config;\n\n constructor(@Optional() @Inject(RXAP_CONFIG) config: any | null = null) {\n this.config = ConfigService.Config;\n if (config) {\n this.config = deepMerge(this.config ?? {}, config);\n }\n if (!this.config) {\n throw new Error('config not available');\n }\n }\n\n public setLocalConfig(config: Config): void {\n localStorage.setItem(ConfigService.LocalStorageKey, JSON.stringify(config));\n }\n\n public clearLocalConfig(): void {\n localStorage.removeItem(ConfigService.LocalStorageKey);\n }\n\n public get<T = any>(propertyPath: string): T | undefined;\n public get<T = any>(propertyPath: string, defaultValue: NoInferType<T>): T;\n public get<T = any>(propertyPath: string, defaultValue?: T): T | undefined {\n return ConfigService.Get(propertyPath, defaultValue, this.config);\n }\n\n public getOrThrow<T = any>(propertyPath: string): T;\n public getOrThrow<T = any>(propertyPath: string, defaultValue: NoInferType<T>): T;\n public getOrThrow<T = any>(propertyPath: string, defaultValue?: T): T {\n const value = ConfigService.Get(propertyPath, defaultValue, this.config);\n if (value === undefined) {\n throw new Error(`Could not find config in path '${propertyPath}'`);\n }\n return value;\n }\n\n}\n","import { Injectable, Inject } from '@angular/core';\nimport { Observable } from 'rxjs';\nimport { HttpClient } from '@angular/common/http';\nimport { finalize, share } from 'rxjs/operators';\n\n@Injectable({ providedIn: 'root' })\nexport class ConfigLoaderService {\n public readonly configs = new Map<string, any>();\n\n public readonly configLoading = new Map<string, Observable<any>>();\n\n constructor(\n @Inject(HttpClient)\n public readonly http: HttpClient\n ) {}\n\n public async load$<T = any>(url: string): Promise<T> {\n if (this.configs.has(url)) {\n return this.configs.get(url);\n }\n\n if (this.configLoading.has(url)) {\n return this.configLoading.get(url)!.toPromise();\n }\n\n const loading$ = this.http.get<T>(url).pipe(\n finalize(() => this.configLoading.delete(url)),\n share()\n );\n\n this.configLoading.set(url, loading$);\n\n return loading$.toPromise();\n }\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
@@ -1,38 +1,39 @@
1
- import { __awaiter } from "tslib";
2
- import { Injectable, Optional, Inject } from '@angular/core';
1
+ import * as i0 from '@angular/core';
2
+ import { InjectionToken, Injectable, Optional, Inject } from '@angular/core';
3
3
  import { deepMerge, SetObjectValue } from '@rxap/utilities';
4
- import { RXAP_CONFIG } from './tokens';
5
- import * as i0 from "@angular/core";
6
- export class ConfigService {
4
+ import * as i1 from '@angular/common/http';
5
+ import { HttpClient } from '@angular/common/http';
6
+ import { finalize, share } from 'rxjs/operators';
7
+
8
+ const RXAP_CONFIG = new InjectionToken('rxap/config');
9
+
10
+ class ConfigService {
7
11
  constructor(config = null) {
8
- var _a;
9
12
  this.config = ConfigService.Config;
10
13
  if (config) {
11
- this.config = deepMerge((_a = this.config) !== null && _a !== void 0 ? _a : {}, config);
14
+ this.config = deepMerge(this.config ?? {}, config);
12
15
  }
13
16
  if (!this.config) {
14
17
  throw new Error('config not available');
15
18
  }
16
19
  }
17
- static SideLoad(url, propertyPath, required) {
18
- return __awaiter(this, void 0, void 0, function* () {
19
- if (!this.Config) {
20
- throw new Error('Config side load is only possible after the initial config load.');
21
- }
22
- try {
23
- const response = yield fetch(url);
24
- SetObjectValue(this.Config, propertyPath, yield response.json());
20
+ static async SideLoad(url, propertyPath, required) {
21
+ if (!this.Config) {
22
+ throw new Error('Config side load is only possible after the initial config load.');
23
+ }
24
+ try {
25
+ const response = await fetch(url);
26
+ SetObjectValue(this.Config, propertyPath, await response.json());
27
+ }
28
+ catch (error) {
29
+ if (required) {
30
+ throw new Error(`Could not side load config '${url}': ${error.message}`);
25
31
  }
26
- catch (error) {
27
- if (required) {
28
- throw new Error(`Could not side load config '${url}': ${error.message}`);
29
- }
30
- else {
31
- console.warn(url, error.message);
32
- }
32
+ else {
33
+ console.warn(url, error.message);
33
34
  }
34
- console.debug(`app config side load '${propertyPath}'`, this.Config);
35
- });
35
+ }
36
+ console.debug(`app config side load '${propertyPath}'`, this.Config);
36
37
  }
37
38
  /**
38
39
  * Used to load the app config from a remote resource.
@@ -42,37 +43,35 @@ export class ConfigService {
42
43
  * .catch(err => console.error(err))
43
44
  *
44
45
  */
45
- static Load(options) {
46
- return __awaiter(this, void 0, void 0, function* () {
47
- let config = this.Defaults;
48
- for (const url of ConfigService.Urls) {
46
+ static async Load(options) {
47
+ let config = this.Defaults;
48
+ for (const url of ConfigService.Urls) {
49
+ try {
50
+ const response = await fetch(url);
51
+ config = deepMerge(config, await response.json());
52
+ }
53
+ catch (error) {
54
+ console.error(url, error.message);
55
+ }
56
+ }
57
+ config = deepMerge(config, this.Overwrites);
58
+ if (options?.fromLocalStorage !== false) {
59
+ const localConfig = localStorage.getItem(ConfigService.LocalStorageKey);
60
+ if (localConfig) {
49
61
  try {
50
- const response = yield fetch(url);
51
- config = deepMerge(config, yield response.json());
62
+ config = deepMerge(config, JSON.parse(localConfig));
52
63
  }
53
- catch (error) {
54
- console.error(url, error.message);
64
+ catch (e) {
65
+ console.error('local config could not be parsed');
55
66
  }
56
67
  }
57
- config = deepMerge(config, this.Overwrites);
58
- if ((options === null || options === void 0 ? void 0 : options.fromLocalStorage) !== false) {
59
- const localConfig = localStorage.getItem(ConfigService.LocalStorageKey);
60
- if (localConfig) {
61
- try {
62
- config = deepMerge(config, JSON.parse(localConfig));
63
- }
64
- catch (e) {
65
- console.error('local config could not be parsed');
66
- }
67
- }
68
- }
69
- if (options === null || options === void 0 ? void 0 : options.fromUrlParam) {
70
- const param = typeof options.fromUrlParam === 'string' ? options.fromUrlParam : 'config';
71
- config = deepMerge(config, this.LoadConfigDefaultFromUrlParam(param));
72
- }
73
- console.debug('app config', config);
74
- ConfigService.Config = config;
75
- });
68
+ }
69
+ if (options?.fromUrlParam) {
70
+ const param = typeof options.fromUrlParam === 'string' ? options.fromUrlParam : 'config';
71
+ config = deepMerge(config, this.LoadConfigDefaultFromUrlParam(param));
72
+ }
73
+ console.debug('app config', config);
74
+ ConfigService.Config = config;
76
75
  }
77
76
  static LoadConfigDefaultFromUrlParam(param = 'config') {
78
77
  const queryString = window.location.search;
@@ -146,9 +145,9 @@ ConfigService.Defaults = {};
146
145
  ConfigService.Overwrites = {};
147
146
  ConfigService.LocalStorageKey = 'rxap/config/local-config';
148
147
  ConfigService.Urls = ['config.json'];
149
- ConfigService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.1", ngImport: i0, type: ConfigService, deps: [{ token: RXAP_CONFIG, optional: true }], target: i0.ɵɵFactoryTarget.Injectable });
150
- ConfigService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.0.1", ngImport: i0, type: ConfigService, providedIn: 'root' });
151
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.1", ngImport: i0, type: ConfigService, decorators: [{
148
+ ConfigService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: ConfigService, deps: [{ token: RXAP_CONFIG, optional: true }], target: i0.ɵɵFactoryTarget.Injectable });
149
+ ConfigService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: ConfigService, providedIn: 'root' });
150
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: ConfigService, decorators: [{
152
151
  type: Injectable,
153
152
  args: [{
154
153
  providedIn: 'root'
@@ -159,4 +158,38 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.1", ngImpor
159
158
  type: Inject,
160
159
  args: [RXAP_CONFIG]
161
160
  }] }]; } });
162
- //# sourceMappingURL=config.service.js.map
161
+
162
+ class ConfigLoaderService {
163
+ constructor(http) {
164
+ this.http = http;
165
+ this.configs = new Map();
166
+ this.configLoading = new Map();
167
+ }
168
+ async load$(url) {
169
+ if (this.configs.has(url)) {
170
+ return this.configs.get(url);
171
+ }
172
+ if (this.configLoading.has(url)) {
173
+ return this.configLoading.get(url).toPromise();
174
+ }
175
+ const loading$ = this.http.get(url).pipe(finalize(() => this.configLoading.delete(url)), share());
176
+ this.configLoading.set(url, loading$);
177
+ return loading$.toPromise();
178
+ }
179
+ }
180
+ ConfigLoaderService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: ConfigLoaderService, deps: [{ token: HttpClient }], target: i0.ɵɵFactoryTarget.Injectable });
181
+ ConfigLoaderService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: ConfigLoaderService, providedIn: 'root' });
182
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: ConfigLoaderService, decorators: [{
183
+ type: Injectable,
184
+ args: [{ providedIn: 'root' }]
185
+ }], ctorParameters: function () { return [{ type: i1.HttpClient, decorators: [{
186
+ type: Inject,
187
+ args: [HttpClient]
188
+ }] }]; } });
189
+
190
+ /**
191
+ * Generated bundle index. Do not edit.
192
+ */
193
+
194
+ export { ConfigLoaderService, ConfigService, RXAP_CONFIG };
195
+ //# sourceMappingURL=rxap-config.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rxap-config.mjs","sources":["../../../../libs/config/src/lib/tokens.ts","../../../../libs/config/src/lib/config.service.ts","../../../../libs/config/src/lib/config-loader.service.ts","../../../../libs/config/src/rxap-config.ts"],"sourcesContent":["import { InjectionToken } from '@angular/core';\n\nexport const RXAP_CONFIG = new InjectionToken('rxap/config');\n","import {\n Injectable,\n Optional,\n Inject\n} from '@angular/core';\nimport {\n deepMerge,\n SetObjectValue\n} from '@rxap/utilities';\nimport { RXAP_CONFIG } from './tokens';\nimport { NoInferType } from './types';\n\nexport interface ConfigLoadOptions {\n fromUrlParam?: string | boolean;\n fromLocalStorage?: boolean;\n}\n\n@Injectable({\n providedIn: 'root'\n})\nexport class ConfigService<Config extends Record<string, any> = Record<string, any>> {\n\n public static Config: any = null;\n\n /**\n * Static default values for the config object.\n * Will be overwritten by an dynamic config file specified in\n * the Urls array.\n */\n public static Defaults: any = {};\n\n /**\n * Any value definition in the Overwrites object will overwrite any\n * value form the Defaults values or dynamic config files\n */\n public static Overwrites: any = {};\n\n public static LocalStorageKey = 'rxap/config/local-config';\n\n public static Urls = [ 'config.json' ];\n\n public static async SideLoad(url: string, propertyPath: string, required?: boolean): Promise<void> {\n\n if (!this.Config) {\n throw new Error('Config side load is only possible after the initial config load.');\n }\n\n try {\n\n const response = await fetch(url);\n SetObjectValue(this.Config, propertyPath, await response.json());\n\n } catch (error: any) {\n if (required) {\n throw new Error(`Could not side load config '${url}': ${error.message}`);\n } else {\n console.warn(url, error.message);\n }\n }\n\n console.debug(`app config side load '${propertyPath}'`, this.Config);\n\n }\n\n /**\n * Used to load the app config from a remote resource.\n *\n * Promise.all([ ConfigService.Load() ])\n * .then(() => platformBrowserDynamic().bootstrapModule(AppModule))\n * .catch(err => console.error(err))\n *\n */\n public static async Load(options?: ConfigLoadOptions): Promise<void> {\n let config = this.Defaults;\n for (const url of ConfigService.Urls) {\n try {\n\n const response = await fetch(url);\n config = deepMerge(config, await response.json());\n\n } catch (error: any) {\n console.error(url, error.message);\n }\n }\n\n config = deepMerge(config, this.Overwrites);\n\n if (options?.fromLocalStorage !== false) {\n\n const localConfig = localStorage.getItem(ConfigService.LocalStorageKey);\n\n if (localConfig) {\n try {\n config = deepMerge(config, JSON.parse(localConfig));\n } catch (e: any) {\n console.error('local config could not be parsed');\n }\n }\n\n }\n\n if (options?.fromUrlParam) {\n const param = typeof options.fromUrlParam === 'string' ? options.fromUrlParam : 'config';\n config = deepMerge(config, this.LoadConfigDefaultFromUrlParam(param));\n }\n\n console.debug('app config', config);\n\n ConfigService.Config = config;\n }\n\n private static LoadConfigDefaultFromUrlParam(param: string = 'config') {\n\n const queryString = window.location.search;\n const urlParams = new URLSearchParams(queryString);\n\n const configFromParams = {};\n\n for (const configParam of urlParams.getAll('config')) {\n\n try {\n const split = configParam.split(';');\n if (split.length === 2) {\n const keyPath = split[ 0 ];\n const value = split[ 1 ];\n SetObjectValue(configFromParams, keyPath, value);\n }\n } catch (e: any) {\n console.warn(`Parsing of url config param failed for '${configParam}': ${e.message}`);\n }\n\n }\n\n return configFromParams;\n\n }\n\n public static Get<T = any, K extends Record<string, any> = Record<string, any>>(path: string, defaultValue: T | undefined, config: Record<string, any>): T\n public static Get<T = any, K extends Record<string, any> = Record<string, any>>(\n path: string,\n defaultValue: NoInferType<T>,\n config: Record<string, any> = this.Config\n ): T {\n if (!config) {\n throw new Error('config not loaded');\n }\n let configValue: any = config;\n if (typeof path !== 'string') {\n throw new Error('The config property path is not a string');\n }\n for (const fragment of (path as any).split('.')) {\n if (configValue.hasOwnProperty(fragment)) {\n configValue = configValue[ fragment ];\n } else {\n if (defaultValue !== undefined) {\n return defaultValue;\n }\n console.warn(`Config with path '${path}' not found`);\n return undefined as any;\n }\n }\n return configValue;\n }\n\n public readonly config!: Config;\n\n constructor(@Optional() @Inject(RXAP_CONFIG) config: any | null = null) {\n this.config = ConfigService.Config;\n if (config) {\n this.config = deepMerge(this.config ?? {}, config);\n }\n if (!this.config) {\n throw new Error('config not available');\n }\n }\n\n public setLocalConfig(config: Config): void {\n localStorage.setItem(ConfigService.LocalStorageKey, JSON.stringify(config));\n }\n\n public clearLocalConfig(): void {\n localStorage.removeItem(ConfigService.LocalStorageKey);\n }\n\n public get<T = any>(propertyPath: string): T | undefined;\n public get<T = any>(propertyPath: string, defaultValue: NoInferType<T>): T;\n public get<T = any>(propertyPath: string, defaultValue?: T): T | undefined {\n return ConfigService.Get(propertyPath, defaultValue, this.config);\n }\n\n public getOrThrow<T = any>(propertyPath: string): T;\n public getOrThrow<T = any>(propertyPath: string, defaultValue: NoInferType<T>): T;\n public getOrThrow<T = any>(propertyPath: string, defaultValue?: T): T {\n const value = ConfigService.Get(propertyPath, defaultValue, this.config);\n if (value === undefined) {\n throw new Error(`Could not find config in path '${propertyPath}'`);\n }\n return value;\n }\n\n}\n","import { Injectable, Inject } from '@angular/core';\nimport { Observable } from 'rxjs';\nimport { HttpClient } from '@angular/common/http';\nimport { finalize, share } from 'rxjs/operators';\n\n@Injectable({ providedIn: 'root' })\nexport class ConfigLoaderService {\n public readonly configs = new Map<string, any>();\n\n public readonly configLoading = new Map<string, Observable<any>>();\n\n constructor(\n @Inject(HttpClient)\n public readonly http: HttpClient\n ) {}\n\n public async load$<T = any>(url: string): Promise<T> {\n if (this.configs.has(url)) {\n return this.configs.get(url);\n }\n\n if (this.configLoading.has(url)) {\n return this.configLoading.get(url)!.toPromise();\n }\n\n const loading$ = this.http.get<T>(url).pipe(\n finalize(() => this.configLoading.delete(url)),\n share()\n );\n\n this.configLoading.set(url, loading$);\n\n return loading$.toPromise();\n }\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@rxap/config",
3
- "version": "12.3.0",
3
+ "version": "13.0.0-next.0",
4
4
  "private": false,
5
5
  "author": "Merzough Münker",
6
6
  "homepage": "https://gitlab.com/rxap/packages/libs/config",
@@ -17,9 +17,11 @@
17
17
  },
18
18
  "description": "Simple config file manager for angular applications.",
19
19
  "peerDependencies": {
20
- "@angular/common": "^12.0.1",
21
- "@angular/core": "^12.0.1",
22
- "@rxap/utilities": "^12.2.1",
20
+ "@angular-devkit/schematics": "^13.2.4",
21
+ "@angular/common": "^13.2.3",
22
+ "@angular/core": "^13.2.3",
23
+ "@angular/platform-browser-dynamic": "^13.2.3",
24
+ "@rxap/utilities": "^13.0.0-next.0",
23
25
  "reflect-metadata": "^0.1.13",
24
26
  "rxjs": "^6.5.5"
25
27
  },
@@ -39,16 +41,29 @@
39
41
  "save": "dependencies"
40
42
  },
41
43
  "dependencies": {
42
- "@rxap/schematics-ts-morph": "^12.3.0",
43
- "@rxap/schematics-utilities": "^12.6.0",
44
- "ts-morph": "^10.1.0",
45
- "tslib": "^2.2.0"
44
+ "@rxap/schematics-ts-morph": "^13.0.0-next.0",
45
+ "@rxap/schematics-utilities": "^13.0.0-next.0",
46
+ "ts-morph": "^13.0.3",
47
+ "tslib": "^2.3.1"
46
48
  },
47
- "main": "bundles/rxap-config.umd.js",
48
- "module": "fesm2015/rxap-config.js",
49
- "es2015": "fesm2015/rxap-config.js",
50
- "esm2015": "esm2015/rxap-config.js",
51
- "fesm2015": "fesm2015/rxap-config.js",
49
+ "module": "fesm2015/rxap-config.mjs",
50
+ "es2020": "fesm2020/rxap-config.mjs",
51
+ "esm2020": "esm2020/rxap-config.mjs",
52
+ "fesm2020": "fesm2020/rxap-config.mjs",
53
+ "fesm2015": "fesm2015/rxap-config.mjs",
52
54
  "typings": "rxap-config.d.ts",
55
+ "exports": {
56
+ "./package.json": {
57
+ "default": "./package.json"
58
+ },
59
+ ".": {
60
+ "types": "./rxap-config.d.ts",
61
+ "esm2020": "./esm2020/rxap-config.mjs",
62
+ "es2020": "./fesm2020/rxap-config.mjs",
63
+ "es2015": "./fesm2015/rxap-config.mjs",
64
+ "node": "./fesm2015/rxap-config.mjs",
65
+ "default": "./fesm2020/rxap-config.mjs"
66
+ }
67
+ },
53
68
  "sideEffects": false
54
69
  }