@opra/angular 0.14.0 → 0.15.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.
- package/client.module.d.ts +8 -5
- package/esm2020/client.module.mjs +46 -57
- package/esm2020/interfaces/module-options.interface.mjs +1 -1
- package/fesm2015/opra-angular.mjs +45 -56
- package/fesm2015/opra-angular.mjs.map +1 -1
- package/fesm2020/opra-angular.mjs +45 -56
- package/fesm2020/opra-angular.mjs.map +1 -1
- package/interfaces/module-options.interface.d.ts +4 -7
- package/package.json +4 -5
package/client.module.d.ts
CHANGED
|
@@ -1,11 +1,14 @@
|
|
|
1
|
-
import { ModuleWithProviders } from '@angular/core';
|
|
1
|
+
import { ModuleWithProviders, Type } from '@angular/core';
|
|
2
|
+
import { HttpServiceBase } from '@opra/client';
|
|
2
3
|
import { OpraClientModuleAsyncOptions, OpraClientModuleOptions } from './interfaces/module-options.interface';
|
|
3
4
|
import * as i0 from "@angular/core";
|
|
4
5
|
export declare class OpraClientModule {
|
|
5
|
-
static
|
|
6
|
-
static
|
|
7
|
-
|
|
8
|
-
|
|
6
|
+
static registerClient(options: OpraClientModuleOptions): ModuleWithProviders<OpraClientModule>;
|
|
7
|
+
static registerService<T extends HttpServiceBase>(serviceClass: Type<T>, options: OpraClientModuleOptions): ModuleWithProviders<OpraClientModule>;
|
|
8
|
+
static registerClientAsync(options: OpraClientModuleAsyncOptions): ModuleWithProviders<OpraClientModule>;
|
|
9
|
+
static registerServiceAsync<T extends HttpServiceBase>(serviceClass: Type<T>, options: OpraClientModuleAsyncOptions): ModuleWithProviders<OpraClientModule>;
|
|
10
|
+
private static _createAsyncProviders;
|
|
11
|
+
private static _createAsyncOptionsProvider;
|
|
9
12
|
static ɵfac: i0.ɵɵFactoryDeclaration<OpraClientModule, never>;
|
|
10
13
|
static ɵmod: i0.ɵɵNgModuleDeclaration<OpraClientModule, never, never, never>;
|
|
11
14
|
static ɵinj: i0.ɵɵInjectorDeclaration<OpraClientModule>;
|
|
@@ -1,86 +1,75 @@
|
|
|
1
1
|
/* eslint-disable import/extensions */
|
|
2
|
-
import {
|
|
2
|
+
import { NgModule } from '@angular/core';
|
|
3
3
|
import { OpraHttpClient } from '@opra/client';
|
|
4
4
|
import { OPRA_CLIENT_MODULE_OPTIONS } from './constants';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
export class OpraClientModule {
|
|
7
|
-
static
|
|
8
|
-
const
|
|
9
|
-
const CLIENT_TOKEN = options.clientToken || OpraHttpClient;
|
|
10
|
-
const SERVICE_TOKEN = options.serviceToken || serviceClass;
|
|
7
|
+
static registerClient(options) {
|
|
8
|
+
const CLIENT_TOKEN = options.token || OpraHttpClient;
|
|
11
9
|
const client = new OpraHttpClient(options.serviceUrl, options);
|
|
12
|
-
const serviceProviders = [];
|
|
13
|
-
if (serviceClass)
|
|
14
|
-
serviceProviders.push({
|
|
15
|
-
provide: SERVICE_TOKEN,
|
|
16
|
-
deps: [CLIENT_TOKEN],
|
|
17
|
-
useFactory: (opraHttpClient) => {
|
|
18
|
-
return new serviceClass(opraHttpClient);
|
|
19
|
-
}
|
|
20
|
-
});
|
|
21
10
|
return {
|
|
22
11
|
ngModule: OpraClientModule,
|
|
23
12
|
providers: [
|
|
24
|
-
...serviceProviders,
|
|
25
|
-
{
|
|
26
|
-
provide: OPRA_CLIENT_MODULE_OPTIONS,
|
|
27
|
-
useValue: options,
|
|
28
|
-
},
|
|
29
13
|
{
|
|
30
14
|
provide: CLIENT_TOKEN,
|
|
31
15
|
useValue: client
|
|
32
|
-
}
|
|
33
|
-
{
|
|
34
|
-
provide: APP_INITIALIZER,
|
|
35
|
-
useFactory: () => {
|
|
36
|
-
return () => client.init();
|
|
37
|
-
},
|
|
38
|
-
multi: true
|
|
39
|
-
},
|
|
16
|
+
}
|
|
40
17
|
]
|
|
41
18
|
};
|
|
42
19
|
}
|
|
43
|
-
static
|
|
44
|
-
const
|
|
45
|
-
const
|
|
46
|
-
const
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
useFactory: (opraHttpClient) => {
|
|
54
|
-
return new serviceClass(opraHttpClient);
|
|
20
|
+
static registerService(serviceClass, options) {
|
|
21
|
+
const SERVICE_TOKEN = options.token || serviceClass;
|
|
22
|
+
const client = new OpraHttpClient(options.serviceUrl, options);
|
|
23
|
+
const service = new serviceClass(client);
|
|
24
|
+
return {
|
|
25
|
+
ngModule: OpraClientModule,
|
|
26
|
+
providers: [
|
|
27
|
+
{
|
|
28
|
+
provide: SERVICE_TOKEN,
|
|
29
|
+
useValue: service
|
|
55
30
|
}
|
|
56
|
-
|
|
31
|
+
]
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
static registerClientAsync(options) {
|
|
35
|
+
const CLIENT_TOKEN = options.token || OpraHttpClient;
|
|
36
|
+
const asyncProviders = this._createAsyncProviders(options);
|
|
57
37
|
return {
|
|
58
38
|
ngModule: OpraClientModule,
|
|
59
39
|
providers: [
|
|
60
40
|
...asyncProviders,
|
|
61
|
-
...serviceProviders,
|
|
62
41
|
{
|
|
63
42
|
provide: CLIENT_TOKEN,
|
|
64
43
|
deps: [OPRA_CLIENT_MODULE_OPTIONS],
|
|
65
44
|
useFactory: (opts) => new OpraHttpClient(opts.serviceUrl, opts)
|
|
66
|
-
}
|
|
45
|
+
}
|
|
46
|
+
]
|
|
47
|
+
};
|
|
48
|
+
}
|
|
49
|
+
static registerServiceAsync(serviceClass, options) {
|
|
50
|
+
const SERVICE_TOKEN = options.token || serviceClass;
|
|
51
|
+
const asyncProviders = this._createAsyncProviders(options);
|
|
52
|
+
return {
|
|
53
|
+
ngModule: OpraClientModule,
|
|
54
|
+
providers: [
|
|
55
|
+
...asyncProviders,
|
|
67
56
|
{
|
|
68
|
-
provide:
|
|
69
|
-
deps: [
|
|
70
|
-
useFactory: (
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
57
|
+
provide: SERVICE_TOKEN,
|
|
58
|
+
deps: [OPRA_CLIENT_MODULE_OPTIONS],
|
|
59
|
+
useFactory: (opts) => {
|
|
60
|
+
const client = new OpraHttpClient(opts.serviceUrl, opts);
|
|
61
|
+
return new serviceClass(client);
|
|
62
|
+
}
|
|
74
63
|
}
|
|
75
64
|
]
|
|
76
65
|
};
|
|
77
66
|
}
|
|
78
|
-
static
|
|
67
|
+
static _createAsyncProviders(options) {
|
|
79
68
|
if (options.useExisting || options.useFactory)
|
|
80
|
-
return [this.
|
|
69
|
+
return [this._createAsyncOptionsProvider(options)];
|
|
81
70
|
if (options.useClass)
|
|
82
71
|
return [
|
|
83
|
-
this.
|
|
72
|
+
this._createAsyncOptionsProvider(options),
|
|
84
73
|
{
|
|
85
74
|
provide: options.useClass,
|
|
86
75
|
useClass: options.useClass
|
|
@@ -88,7 +77,7 @@ export class OpraClientModule {
|
|
|
88
77
|
];
|
|
89
78
|
throw new Error('Invalid configuration. Must provide useFactory, useClass or useExisting');
|
|
90
79
|
}
|
|
91
|
-
static
|
|
80
|
+
static _createAsyncOptionsProvider(options) {
|
|
92
81
|
if (options.useFactory) {
|
|
93
82
|
return {
|
|
94
83
|
provide: OPRA_CLIENT_MODULE_OPTIONS,
|
|
@@ -107,11 +96,11 @@ export class OpraClientModule {
|
|
|
107
96
|
throw new Error('Invalid configuration. Must provide useFactory, useClass or useExisting');
|
|
108
97
|
}
|
|
109
98
|
}
|
|
110
|
-
OpraClientModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.
|
|
111
|
-
OpraClientModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.
|
|
112
|
-
OpraClientModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.
|
|
113
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.
|
|
99
|
+
OpraClientModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: OpraClientModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
100
|
+
OpraClientModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.7", ngImport: i0, type: OpraClientModule });
|
|
101
|
+
OpraClientModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: OpraClientModule });
|
|
102
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: OpraClientModule, decorators: [{
|
|
114
103
|
type: NgModule,
|
|
115
104
|
args: [{}]
|
|
116
105
|
}] });
|
|
117
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
106
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"client.module.js","sourceRoot":"","sources":["../../../packages/angular/src/client.module.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable import/extensions */\nimport { ModuleWithProviders, NgModule, Provider, Type } from '@angular/core';\nimport { HttpServiceBase, OpraHttpClient } from '@opra/client';\nimport { OPRA_CLIENT_MODULE_OPTIONS } from './constants';\nimport {\n  OpraClientModuleAsyncOptions,\n  OpraClientModuleOptions\n} from './interfaces/module-options.interface';\n\n@NgModule({})\nexport class OpraClientModule {\n\n  public static registerClient(options: OpraClientModuleOptions): ModuleWithProviders<OpraClientModule> {\n    const CLIENT_TOKEN = options.token || OpraHttpClient;\n    const client = new OpraHttpClient(options.serviceUrl, options);\n    return {\n      ngModule: OpraClientModule,\n      providers: [\n        {\n          provide: CLIENT_TOKEN,\n          useValue: client\n        }\n      ]\n    };\n  }\n\n  public static registerService<T extends HttpServiceBase>(\n      serviceClass: Type<T>,\n      options: OpraClientModuleOptions\n  ): ModuleWithProviders<OpraClientModule> {\n    const SERVICE_TOKEN = options.token || serviceClass;\n    const client = new OpraHttpClient(options.serviceUrl, options);\n    const service = new serviceClass(client);\n    return {\n      ngModule: OpraClientModule,\n      providers: [\n        {\n          provide: SERVICE_TOKEN,\n          useValue: service\n        }\n      ]\n    };\n  }\n\n  public static registerClientAsync(\n      options: OpraClientModuleAsyncOptions\n  ): ModuleWithProviders<OpraClientModule> {\n    const CLIENT_TOKEN = options.token || OpraHttpClient;\n    const asyncProviders = this._createAsyncProviders(options);\n    return {\n      ngModule: OpraClientModule,\n      providers: [\n        ...asyncProviders,\n        {\n          provide: CLIENT_TOKEN,\n          deps: [OPRA_CLIENT_MODULE_OPTIONS],\n          useFactory: (opts: OpraClientModuleOptions) =>\n              new OpraHttpClient(opts.serviceUrl, opts)\n        }\n      ]\n    };\n  }\n\n  public static registerServiceAsync<T extends HttpServiceBase>(\n      serviceClass: Type<T>,\n      options: OpraClientModuleAsyncOptions\n  ): ModuleWithProviders<OpraClientModule> {\n    const SERVICE_TOKEN = options.token || serviceClass;\n    const asyncProviders = this._createAsyncProviders(options);\n    return {\n      ngModule: OpraClientModule,\n      providers: [\n        ...asyncProviders,\n        {\n          provide: SERVICE_TOKEN,\n          deps: [OPRA_CLIENT_MODULE_OPTIONS],\n          useFactory: (opts: OpraClientModuleOptions) => {\n            const client = new OpraHttpClient(opts.serviceUrl, opts)\n            return new serviceClass(client);\n          }\n        }\n      ]\n    };\n  }\n\n  private static _createAsyncProviders(options: OpraClientModuleAsyncOptions): Provider[] {\n    if (options.useExisting || options.useFactory)\n      return [this._createAsyncOptionsProvider(options)];\n\n    if (options.useClass)\n      return [\n        this._createAsyncOptionsProvider(options),\n        {\n          provide: options.useClass,\n          useClass: options.useClass\n        }\n      ];\n\n    throw new Error('Invalid configuration. Must provide useFactory, useClass or useExisting');\n  }\n\n  private static _createAsyncOptionsProvider(options: OpraClientModuleAsyncOptions): Provider {\n    if (options.useFactory) {\n      return {\n        provide: OPRA_CLIENT_MODULE_OPTIONS,\n        useFactory: options.useFactory,\n        deps: options.deps || [],\n      };\n    }\n    const useClass = options.useClass || options.useExisting;\n    if (useClass) {\n      return {\n        provide: OPRA_CLIENT_MODULE_OPTIONS,\n        useFactory: (o) => o,\n        deps: [useClass],\n      };\n    }\n    throw new Error('Invalid configuration. Must provide useFactory, useClass or useExisting');\n  }\n\n\n}\n"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kdWxlLW9wdGlvbnMuaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvYW5ndWxhci9zcmMvaW50ZXJmYWNlcy9tb2R1bGUtb3B0aW9ucy5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgU3RyaWN0T21pdCB9IGZyb20gJ3RzLWdlbXMnO1xuaW1wb3J0IHsgSW5qZWN0aW9uVG9rZW4sIE5nTW9kdWxlLCBUeXBlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBPcHJhSHR0cENsaWVudE9wdGlvbnMgfSBmcm9tICdAb3ByYS9jbGllbnQnO1xuXG5leHBvcnQgdHlwZSBPcHJhQ2xpZW50TW9kdWxlT3B0aW9ucyA9IE9wcmFIdHRwQ2xpZW50T3B0aW9ucyAmIHtcbiAgc2VydmljZVVybDogc3RyaW5nO1xuICB0b2tlbj86IHN0cmluZyB8IEluamVjdGlvblRva2VuPGFueT47XG59XG5cbnR5cGUgX09wcmFDbGllbnRNb2R1bGVPcHRpb25zID0gU3RyaWN0T21pdDxPcHJhQ2xpZW50TW9kdWxlT3B0aW9ucywgJ3Rva2VuJz47XG5cbmV4cG9ydCBpbnRlcmZhY2UgT3ByYU1vZHVsZU9wdGlvbnNGYWN0b3J5IHtcbiAgY3JlYXRlT3B0aW9ucygpOiBQcm9taXNlPF9PcHJhQ2xpZW50TW9kdWxlT3B0aW9ucz4gfCBfT3ByYUNsaWVudE1vZHVsZU9wdGlvbnM7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgT3ByYUNsaWVudE1vZHVsZUFzeW5jT3B0aW9uc1xuICAgIGV4dGVuZHMgUGljazxOZ01vZHVsZSwgJ2ltcG9ydHMnIHwgJ3Byb3ZpZGVycyc+IHtcbiAgdG9rZW4/OiBzdHJpbmcgfCBJbmplY3Rpb25Ub2tlbjxhbnk+O1xuICB1c2VFeGlzdGluZz86IFR5cGU8T3ByYU1vZHVsZU9wdGlvbnNGYWN0b3J5PjtcbiAgdXNlQ2xhc3M/OiBUeXBlPGFueT47XG4gIHVzZUZhY3Rvcnk/OiAoLi4uYXJnczogYW55W10pID0+IFByb21pc2U8X09wcmFDbGllbnRNb2R1bGVPcHRpb25zPiB8IF9PcHJhQ2xpZW50TW9kdWxlT3B0aW9ucztcbiAgZGVwcz86IGFueVtdO1xufVxuXG4iXX0=
|
|
@@ -1,88 +1,77 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
|
-
import {
|
|
2
|
+
import { NgModule } from '@angular/core';
|
|
3
3
|
import { OpraHttpClient } from '@opra/client';
|
|
4
4
|
|
|
5
5
|
const OPRA_CLIENT_MODULE_OPTIONS = 'OPRA_CLIENT_MODULE_OPTIONS';
|
|
6
6
|
|
|
7
7
|
/* eslint-disable import/extensions */
|
|
8
8
|
class OpraClientModule {
|
|
9
|
-
static
|
|
10
|
-
const
|
|
11
|
-
const CLIENT_TOKEN = options.clientToken || OpraHttpClient;
|
|
12
|
-
const SERVICE_TOKEN = options.serviceToken || serviceClass;
|
|
9
|
+
static registerClient(options) {
|
|
10
|
+
const CLIENT_TOKEN = options.token || OpraHttpClient;
|
|
13
11
|
const client = new OpraHttpClient(options.serviceUrl, options);
|
|
14
|
-
const serviceProviders = [];
|
|
15
|
-
if (serviceClass)
|
|
16
|
-
serviceProviders.push({
|
|
17
|
-
provide: SERVICE_TOKEN,
|
|
18
|
-
deps: [CLIENT_TOKEN],
|
|
19
|
-
useFactory: (opraHttpClient) => {
|
|
20
|
-
return new serviceClass(opraHttpClient);
|
|
21
|
-
}
|
|
22
|
-
});
|
|
23
12
|
return {
|
|
24
13
|
ngModule: OpraClientModule,
|
|
25
14
|
providers: [
|
|
26
|
-
...serviceProviders,
|
|
27
|
-
{
|
|
28
|
-
provide: OPRA_CLIENT_MODULE_OPTIONS,
|
|
29
|
-
useValue: options,
|
|
30
|
-
},
|
|
31
15
|
{
|
|
32
16
|
provide: CLIENT_TOKEN,
|
|
33
17
|
useValue: client
|
|
34
|
-
}
|
|
35
|
-
{
|
|
36
|
-
provide: APP_INITIALIZER,
|
|
37
|
-
useFactory: () => {
|
|
38
|
-
return () => client.init();
|
|
39
|
-
},
|
|
40
|
-
multi: true
|
|
41
|
-
},
|
|
18
|
+
}
|
|
42
19
|
]
|
|
43
20
|
};
|
|
44
21
|
}
|
|
45
|
-
static
|
|
46
|
-
const
|
|
47
|
-
const
|
|
48
|
-
const
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
useFactory: (opraHttpClient) => {
|
|
56
|
-
return new serviceClass(opraHttpClient);
|
|
22
|
+
static registerService(serviceClass, options) {
|
|
23
|
+
const SERVICE_TOKEN = options.token || serviceClass;
|
|
24
|
+
const client = new OpraHttpClient(options.serviceUrl, options);
|
|
25
|
+
const service = new serviceClass(client);
|
|
26
|
+
return {
|
|
27
|
+
ngModule: OpraClientModule,
|
|
28
|
+
providers: [
|
|
29
|
+
{
|
|
30
|
+
provide: SERVICE_TOKEN,
|
|
31
|
+
useValue: service
|
|
57
32
|
}
|
|
58
|
-
|
|
33
|
+
]
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
static registerClientAsync(options) {
|
|
37
|
+
const CLIENT_TOKEN = options.token || OpraHttpClient;
|
|
38
|
+
const asyncProviders = this._createAsyncProviders(options);
|
|
59
39
|
return {
|
|
60
40
|
ngModule: OpraClientModule,
|
|
61
41
|
providers: [
|
|
62
42
|
...asyncProviders,
|
|
63
|
-
...serviceProviders,
|
|
64
43
|
{
|
|
65
44
|
provide: CLIENT_TOKEN,
|
|
66
45
|
deps: [OPRA_CLIENT_MODULE_OPTIONS],
|
|
67
46
|
useFactory: (opts) => new OpraHttpClient(opts.serviceUrl, opts)
|
|
68
|
-
}
|
|
47
|
+
}
|
|
48
|
+
]
|
|
49
|
+
};
|
|
50
|
+
}
|
|
51
|
+
static registerServiceAsync(serviceClass, options) {
|
|
52
|
+
const SERVICE_TOKEN = options.token || serviceClass;
|
|
53
|
+
const asyncProviders = this._createAsyncProviders(options);
|
|
54
|
+
return {
|
|
55
|
+
ngModule: OpraClientModule,
|
|
56
|
+
providers: [
|
|
57
|
+
...asyncProviders,
|
|
69
58
|
{
|
|
70
|
-
provide:
|
|
71
|
-
deps: [
|
|
72
|
-
useFactory: (
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
59
|
+
provide: SERVICE_TOKEN,
|
|
60
|
+
deps: [OPRA_CLIENT_MODULE_OPTIONS],
|
|
61
|
+
useFactory: (opts) => {
|
|
62
|
+
const client = new OpraHttpClient(opts.serviceUrl, opts);
|
|
63
|
+
return new serviceClass(client);
|
|
64
|
+
}
|
|
76
65
|
}
|
|
77
66
|
]
|
|
78
67
|
};
|
|
79
68
|
}
|
|
80
|
-
static
|
|
69
|
+
static _createAsyncProviders(options) {
|
|
81
70
|
if (options.useExisting || options.useFactory)
|
|
82
|
-
return [this.
|
|
71
|
+
return [this._createAsyncOptionsProvider(options)];
|
|
83
72
|
if (options.useClass)
|
|
84
73
|
return [
|
|
85
|
-
this.
|
|
74
|
+
this._createAsyncOptionsProvider(options),
|
|
86
75
|
{
|
|
87
76
|
provide: options.useClass,
|
|
88
77
|
useClass: options.useClass
|
|
@@ -90,7 +79,7 @@ class OpraClientModule {
|
|
|
90
79
|
];
|
|
91
80
|
throw new Error('Invalid configuration. Must provide useFactory, useClass or useExisting');
|
|
92
81
|
}
|
|
93
|
-
static
|
|
82
|
+
static _createAsyncOptionsProvider(options) {
|
|
94
83
|
if (options.useFactory) {
|
|
95
84
|
return {
|
|
96
85
|
provide: OPRA_CLIENT_MODULE_OPTIONS,
|
|
@@ -109,10 +98,10 @@ class OpraClientModule {
|
|
|
109
98
|
throw new Error('Invalid configuration. Must provide useFactory, useClass or useExisting');
|
|
110
99
|
}
|
|
111
100
|
}
|
|
112
|
-
OpraClientModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.
|
|
113
|
-
OpraClientModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.
|
|
114
|
-
OpraClientModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.
|
|
115
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.
|
|
101
|
+
OpraClientModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: OpraClientModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
102
|
+
OpraClientModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.7", ngImport: i0, type: OpraClientModule });
|
|
103
|
+
OpraClientModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: OpraClientModule });
|
|
104
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: OpraClientModule, decorators: [{
|
|
116
105
|
type: NgModule,
|
|
117
106
|
args: [{}]
|
|
118
107
|
}] });
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"opra-angular.mjs","sources":["../../../packages/angular/src/constants.ts","../../../packages/angular/src/client.module.ts","../../../packages/angular/src/public_api.ts","../../../packages/angular/src/opra-angular.ts"],"sourcesContent":["export const OPRA_CLIENT_MODULE_OPTIONS = 'OPRA_CLIENT_MODULE_OPTIONS';\n","/* eslint-disable import/extensions */\nimport {
|
|
1
|
+
{"version":3,"file":"opra-angular.mjs","sources":["../../../packages/angular/src/constants.ts","../../../packages/angular/src/client.module.ts","../../../packages/angular/src/public_api.ts","../../../packages/angular/src/opra-angular.ts"],"sourcesContent":["export const OPRA_CLIENT_MODULE_OPTIONS = 'OPRA_CLIENT_MODULE_OPTIONS';\n","/* eslint-disable import/extensions */\nimport { ModuleWithProviders, NgModule, Provider, Type } from '@angular/core';\nimport { HttpServiceBase, OpraHttpClient } from '@opra/client';\nimport { OPRA_CLIENT_MODULE_OPTIONS } from './constants';\nimport {\n OpraClientModuleAsyncOptions,\n OpraClientModuleOptions\n} from './interfaces/module-options.interface';\n\n@NgModule({})\nexport class OpraClientModule {\n\n public static registerClient(options: OpraClientModuleOptions): ModuleWithProviders<OpraClientModule> {\n const CLIENT_TOKEN = options.token || OpraHttpClient;\n const client = new OpraHttpClient(options.serviceUrl, options);\n return {\n ngModule: OpraClientModule,\n providers: [\n {\n provide: CLIENT_TOKEN,\n useValue: client\n }\n ]\n };\n }\n\n public static registerService<T extends HttpServiceBase>(\n serviceClass: Type<T>,\n options: OpraClientModuleOptions\n ): ModuleWithProviders<OpraClientModule> {\n const SERVICE_TOKEN = options.token || serviceClass;\n const client = new OpraHttpClient(options.serviceUrl, options);\n const service = new serviceClass(client);\n return {\n ngModule: OpraClientModule,\n providers: [\n {\n provide: SERVICE_TOKEN,\n useValue: service\n }\n ]\n };\n }\n\n public static registerClientAsync(\n options: OpraClientModuleAsyncOptions\n ): ModuleWithProviders<OpraClientModule> {\n const CLIENT_TOKEN = options.token || OpraHttpClient;\n const asyncProviders = this._createAsyncProviders(options);\n return {\n ngModule: OpraClientModule,\n providers: [\n ...asyncProviders,\n {\n provide: CLIENT_TOKEN,\n deps: [OPRA_CLIENT_MODULE_OPTIONS],\n useFactory: (opts: OpraClientModuleOptions) =>\n new OpraHttpClient(opts.serviceUrl, opts)\n }\n ]\n };\n }\n\n public static registerServiceAsync<T extends HttpServiceBase>(\n serviceClass: Type<T>,\n options: OpraClientModuleAsyncOptions\n ): ModuleWithProviders<OpraClientModule> {\n const SERVICE_TOKEN = options.token || serviceClass;\n const asyncProviders = this._createAsyncProviders(options);\n return {\n ngModule: OpraClientModule,\n providers: [\n ...asyncProviders,\n {\n provide: SERVICE_TOKEN,\n deps: [OPRA_CLIENT_MODULE_OPTIONS],\n useFactory: (opts: OpraClientModuleOptions) => {\n const client = new OpraHttpClient(opts.serviceUrl, opts)\n return new serviceClass(client);\n }\n }\n ]\n };\n }\n\n private static _createAsyncProviders(options: OpraClientModuleAsyncOptions): Provider[] {\n if (options.useExisting || options.useFactory)\n return [this._createAsyncOptionsProvider(options)];\n\n if (options.useClass)\n return [\n this._createAsyncOptionsProvider(options),\n {\n provide: options.useClass,\n useClass: options.useClass\n }\n ];\n\n throw new Error('Invalid configuration. Must provide useFactory, useClass or useExisting');\n }\n\n private static _createAsyncOptionsProvider(options: OpraClientModuleAsyncOptions): Provider {\n if (options.useFactory) {\n return {\n provide: OPRA_CLIENT_MODULE_OPTIONS,\n useFactory: options.useFactory,\n deps: options.deps || [],\n };\n }\n const useClass = options.useClass || options.useExisting;\n if (useClass) {\n return {\n provide: OPRA_CLIENT_MODULE_OPTIONS,\n useFactory: (o) => o,\n deps: [useClass],\n };\n }\n throw new Error('Invalid configuration. Must provide useFactory, useClass or useExisting');\n }\n\n\n}\n","/* eslint-disable import/extensions */\nexport * from './client.module';\nexport * from './interfaces/module-options.interface';\nexport * from './constants';\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public_api';\n"],"names":[],"mappings":"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"}
|
|
@@ -1,88 +1,77 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
|
-
import {
|
|
2
|
+
import { NgModule } from '@angular/core';
|
|
3
3
|
import { OpraHttpClient } from '@opra/client';
|
|
4
4
|
|
|
5
5
|
const OPRA_CLIENT_MODULE_OPTIONS = 'OPRA_CLIENT_MODULE_OPTIONS';
|
|
6
6
|
|
|
7
7
|
/* eslint-disable import/extensions */
|
|
8
8
|
class OpraClientModule {
|
|
9
|
-
static
|
|
10
|
-
const
|
|
11
|
-
const CLIENT_TOKEN = options.clientToken || OpraHttpClient;
|
|
12
|
-
const SERVICE_TOKEN = options.serviceToken || serviceClass;
|
|
9
|
+
static registerClient(options) {
|
|
10
|
+
const CLIENT_TOKEN = options.token || OpraHttpClient;
|
|
13
11
|
const client = new OpraHttpClient(options.serviceUrl, options);
|
|
14
|
-
const serviceProviders = [];
|
|
15
|
-
if (serviceClass)
|
|
16
|
-
serviceProviders.push({
|
|
17
|
-
provide: SERVICE_TOKEN,
|
|
18
|
-
deps: [CLIENT_TOKEN],
|
|
19
|
-
useFactory: (opraHttpClient) => {
|
|
20
|
-
return new serviceClass(opraHttpClient);
|
|
21
|
-
}
|
|
22
|
-
});
|
|
23
12
|
return {
|
|
24
13
|
ngModule: OpraClientModule,
|
|
25
14
|
providers: [
|
|
26
|
-
...serviceProviders,
|
|
27
|
-
{
|
|
28
|
-
provide: OPRA_CLIENT_MODULE_OPTIONS,
|
|
29
|
-
useValue: options,
|
|
30
|
-
},
|
|
31
15
|
{
|
|
32
16
|
provide: CLIENT_TOKEN,
|
|
33
17
|
useValue: client
|
|
34
|
-
}
|
|
35
|
-
{
|
|
36
|
-
provide: APP_INITIALIZER,
|
|
37
|
-
useFactory: () => {
|
|
38
|
-
return () => client.init();
|
|
39
|
-
},
|
|
40
|
-
multi: true
|
|
41
|
-
},
|
|
18
|
+
}
|
|
42
19
|
]
|
|
43
20
|
};
|
|
44
21
|
}
|
|
45
|
-
static
|
|
46
|
-
const
|
|
47
|
-
const
|
|
48
|
-
const
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
useFactory: (opraHttpClient) => {
|
|
56
|
-
return new serviceClass(opraHttpClient);
|
|
22
|
+
static registerService(serviceClass, options) {
|
|
23
|
+
const SERVICE_TOKEN = options.token || serviceClass;
|
|
24
|
+
const client = new OpraHttpClient(options.serviceUrl, options);
|
|
25
|
+
const service = new serviceClass(client);
|
|
26
|
+
return {
|
|
27
|
+
ngModule: OpraClientModule,
|
|
28
|
+
providers: [
|
|
29
|
+
{
|
|
30
|
+
provide: SERVICE_TOKEN,
|
|
31
|
+
useValue: service
|
|
57
32
|
}
|
|
58
|
-
|
|
33
|
+
]
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
static registerClientAsync(options) {
|
|
37
|
+
const CLIENT_TOKEN = options.token || OpraHttpClient;
|
|
38
|
+
const asyncProviders = this._createAsyncProviders(options);
|
|
59
39
|
return {
|
|
60
40
|
ngModule: OpraClientModule,
|
|
61
41
|
providers: [
|
|
62
42
|
...asyncProviders,
|
|
63
|
-
...serviceProviders,
|
|
64
43
|
{
|
|
65
44
|
provide: CLIENT_TOKEN,
|
|
66
45
|
deps: [OPRA_CLIENT_MODULE_OPTIONS],
|
|
67
46
|
useFactory: (opts) => new OpraHttpClient(opts.serviceUrl, opts)
|
|
68
|
-
}
|
|
47
|
+
}
|
|
48
|
+
]
|
|
49
|
+
};
|
|
50
|
+
}
|
|
51
|
+
static registerServiceAsync(serviceClass, options) {
|
|
52
|
+
const SERVICE_TOKEN = options.token || serviceClass;
|
|
53
|
+
const asyncProviders = this._createAsyncProviders(options);
|
|
54
|
+
return {
|
|
55
|
+
ngModule: OpraClientModule,
|
|
56
|
+
providers: [
|
|
57
|
+
...asyncProviders,
|
|
69
58
|
{
|
|
70
|
-
provide:
|
|
71
|
-
deps: [
|
|
72
|
-
useFactory: (
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
59
|
+
provide: SERVICE_TOKEN,
|
|
60
|
+
deps: [OPRA_CLIENT_MODULE_OPTIONS],
|
|
61
|
+
useFactory: (opts) => {
|
|
62
|
+
const client = new OpraHttpClient(opts.serviceUrl, opts);
|
|
63
|
+
return new serviceClass(client);
|
|
64
|
+
}
|
|
76
65
|
}
|
|
77
66
|
]
|
|
78
67
|
};
|
|
79
68
|
}
|
|
80
|
-
static
|
|
69
|
+
static _createAsyncProviders(options) {
|
|
81
70
|
if (options.useExisting || options.useFactory)
|
|
82
|
-
return [this.
|
|
71
|
+
return [this._createAsyncOptionsProvider(options)];
|
|
83
72
|
if (options.useClass)
|
|
84
73
|
return [
|
|
85
|
-
this.
|
|
74
|
+
this._createAsyncOptionsProvider(options),
|
|
86
75
|
{
|
|
87
76
|
provide: options.useClass,
|
|
88
77
|
useClass: options.useClass
|
|
@@ -90,7 +79,7 @@ class OpraClientModule {
|
|
|
90
79
|
];
|
|
91
80
|
throw new Error('Invalid configuration. Must provide useFactory, useClass or useExisting');
|
|
92
81
|
}
|
|
93
|
-
static
|
|
82
|
+
static _createAsyncOptionsProvider(options) {
|
|
94
83
|
if (options.useFactory) {
|
|
95
84
|
return {
|
|
96
85
|
provide: OPRA_CLIENT_MODULE_OPTIONS,
|
|
@@ -109,10 +98,10 @@ class OpraClientModule {
|
|
|
109
98
|
throw new Error('Invalid configuration. Must provide useFactory, useClass or useExisting');
|
|
110
99
|
}
|
|
111
100
|
}
|
|
112
|
-
OpraClientModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.
|
|
113
|
-
OpraClientModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.
|
|
114
|
-
OpraClientModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.
|
|
115
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.
|
|
101
|
+
OpraClientModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: OpraClientModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
102
|
+
OpraClientModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.7", ngImport: i0, type: OpraClientModule });
|
|
103
|
+
OpraClientModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: OpraClientModule });
|
|
104
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: OpraClientModule, decorators: [{
|
|
116
105
|
type: NgModule,
|
|
117
106
|
args: [{}]
|
|
118
107
|
}] });
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"opra-angular.mjs","sources":["../../../packages/angular/src/constants.ts","../../../packages/angular/src/client.module.ts","../../../packages/angular/src/public_api.ts","../../../packages/angular/src/opra-angular.ts"],"sourcesContent":["export const OPRA_CLIENT_MODULE_OPTIONS = 'OPRA_CLIENT_MODULE_OPTIONS';\n","/* eslint-disable import/extensions */\nimport {
|
|
1
|
+
{"version":3,"file":"opra-angular.mjs","sources":["../../../packages/angular/src/constants.ts","../../../packages/angular/src/client.module.ts","../../../packages/angular/src/public_api.ts","../../../packages/angular/src/opra-angular.ts"],"sourcesContent":["export const OPRA_CLIENT_MODULE_OPTIONS = 'OPRA_CLIENT_MODULE_OPTIONS';\n","/* eslint-disable import/extensions */\nimport { ModuleWithProviders, NgModule, Provider, Type } from '@angular/core';\nimport { HttpServiceBase, OpraHttpClient } from '@opra/client';\nimport { OPRA_CLIENT_MODULE_OPTIONS } from './constants';\nimport {\n OpraClientModuleAsyncOptions,\n OpraClientModuleOptions\n} from './interfaces/module-options.interface';\n\n@NgModule({})\nexport class OpraClientModule {\n\n public static registerClient(options: OpraClientModuleOptions): ModuleWithProviders<OpraClientModule> {\n const CLIENT_TOKEN = options.token || OpraHttpClient;\n const client = new OpraHttpClient(options.serviceUrl, options);\n return {\n ngModule: OpraClientModule,\n providers: [\n {\n provide: CLIENT_TOKEN,\n useValue: client\n }\n ]\n };\n }\n\n public static registerService<T extends HttpServiceBase>(\n serviceClass: Type<T>,\n options: OpraClientModuleOptions\n ): ModuleWithProviders<OpraClientModule> {\n const SERVICE_TOKEN = options.token || serviceClass;\n const client = new OpraHttpClient(options.serviceUrl, options);\n const service = new serviceClass(client);\n return {\n ngModule: OpraClientModule,\n providers: [\n {\n provide: SERVICE_TOKEN,\n useValue: service\n }\n ]\n };\n }\n\n public static registerClientAsync(\n options: OpraClientModuleAsyncOptions\n ): ModuleWithProviders<OpraClientModule> {\n const CLIENT_TOKEN = options.token || OpraHttpClient;\n const asyncProviders = this._createAsyncProviders(options);\n return {\n ngModule: OpraClientModule,\n providers: [\n ...asyncProviders,\n {\n provide: CLIENT_TOKEN,\n deps: [OPRA_CLIENT_MODULE_OPTIONS],\n useFactory: (opts: OpraClientModuleOptions) =>\n new OpraHttpClient(opts.serviceUrl, opts)\n }\n ]\n };\n }\n\n public static registerServiceAsync<T extends HttpServiceBase>(\n serviceClass: Type<T>,\n options: OpraClientModuleAsyncOptions\n ): ModuleWithProviders<OpraClientModule> {\n const SERVICE_TOKEN = options.token || serviceClass;\n const asyncProviders = this._createAsyncProviders(options);\n return {\n ngModule: OpraClientModule,\n providers: [\n ...asyncProviders,\n {\n provide: SERVICE_TOKEN,\n deps: [OPRA_CLIENT_MODULE_OPTIONS],\n useFactory: (opts: OpraClientModuleOptions) => {\n const client = new OpraHttpClient(opts.serviceUrl, opts)\n return new serviceClass(client);\n }\n }\n ]\n };\n }\n\n private static _createAsyncProviders(options: OpraClientModuleAsyncOptions): Provider[] {\n if (options.useExisting || options.useFactory)\n return [this._createAsyncOptionsProvider(options)];\n\n if (options.useClass)\n return [\n this._createAsyncOptionsProvider(options),\n {\n provide: options.useClass,\n useClass: options.useClass\n }\n ];\n\n throw new Error('Invalid configuration. Must provide useFactory, useClass or useExisting');\n }\n\n private static _createAsyncOptionsProvider(options: OpraClientModuleAsyncOptions): Provider {\n if (options.useFactory) {\n return {\n provide: OPRA_CLIENT_MODULE_OPTIONS,\n useFactory: options.useFactory,\n deps: options.deps || [],\n };\n }\n const useClass = options.useClass || options.useExisting;\n if (useClass) {\n return {\n provide: OPRA_CLIENT_MODULE_OPTIONS,\n useFactory: (o) => o,\n deps: [useClass],\n };\n }\n throw new Error('Invalid configuration. Must provide useFactory, useClass or useExisting');\n }\n\n\n}\n","/* eslint-disable import/extensions */\nexport * from './client.module';\nexport * from './interfaces/module-options.interface';\nexport * from './constants';\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public_api';\n"],"names":[],"mappings":"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"}
|
|
@@ -1,19 +1,16 @@
|
|
|
1
|
+
import type { StrictOmit } from 'ts-gems';
|
|
1
2
|
import { InjectionToken, NgModule, Type } from '@angular/core';
|
|
2
3
|
import { OpraHttpClientOptions } from '@opra/client';
|
|
3
4
|
export type OpraClientModuleOptions = OpraHttpClientOptions & {
|
|
4
5
|
serviceUrl: string;
|
|
5
|
-
|
|
6
|
-
serviceToken?: string | InjectionToken<any>;
|
|
7
|
-
serviceClass?: Type<any>;
|
|
6
|
+
token?: string | InjectionToken<any>;
|
|
8
7
|
};
|
|
9
|
-
type _OpraClientModuleOptions =
|
|
8
|
+
type _OpraClientModuleOptions = StrictOmit<OpraClientModuleOptions, 'token'>;
|
|
10
9
|
export interface OpraModuleOptionsFactory {
|
|
11
10
|
createOptions(): Promise<_OpraClientModuleOptions> | _OpraClientModuleOptions;
|
|
12
11
|
}
|
|
13
12
|
export interface OpraClientModuleAsyncOptions extends Pick<NgModule, 'imports' | 'providers'> {
|
|
14
|
-
|
|
15
|
-
serviceToken?: string | InjectionToken<any>;
|
|
16
|
-
serviceClass?: Type<any>;
|
|
13
|
+
token?: string | InjectionToken<any>;
|
|
17
14
|
useExisting?: Type<OpraModuleOptionsFactory>;
|
|
18
15
|
useClass?: Type<any>;
|
|
19
16
|
useFactory?: (...args: any[]) => Promise<_OpraClientModuleOptions> | _OpraClientModuleOptions;
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@opra/angular",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.15.0",
|
|
4
4
|
"description": "Opra internationalization package",
|
|
5
5
|
"author": "Panates",
|
|
6
6
|
"license": "MIT",
|
|
@@ -10,10 +10,9 @@
|
|
|
10
10
|
"directory": "packages/angular"
|
|
11
11
|
},
|
|
12
12
|
"peerDependencies": {
|
|
13
|
-
"@angular/common": "
|
|
14
|
-
"@angular/core": "
|
|
15
|
-
"@opra/client": "^0.
|
|
16
|
-
"ts-gems": "^2.3.0"
|
|
13
|
+
"@angular/common": "14.x.x || 15.x.x || 16.x.x",
|
|
14
|
+
"@angular/core": "14.x.x || 15.x.x || 16.x.x",
|
|
15
|
+
"@opra/client": "^0.15.0"
|
|
17
16
|
},
|
|
18
17
|
"engines": {
|
|
19
18
|
"node": ">=16.0",
|