@joist/di 4.0.0-next.1 → 4.0.0-next.11
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +52 -34
- package/package.json +4 -14
- package/src/lib/dom-injector.test.ts +16 -18
- package/src/lib/dom-injector.ts +3 -4
- package/src/lib/inject.test.ts +33 -56
- package/src/lib/inject.ts +4 -6
- package/src/lib/injectable-el.test.ts +130 -0
- package/src/lib/injectable-el.ts +63 -0
- package/src/lib/injectable.test.ts +19 -116
- package/src/lib/injectable.ts +21 -57
- package/src/lib/injector.test.ts +132 -130
- package/src/lib/injector.ts +33 -19
- package/src/lib/lifecycle.test.ts +68 -64
- package/src/lib/lifecycle.ts +19 -4
- package/src/lib/metadata.ts +12 -0
- package/src/lib/provider.ts +16 -8
- package/src/lib.ts +1 -1
- package/target/lib/dom-injector.js +3 -4
- package/target/lib/dom-injector.js.map +1 -1
- package/target/lib/dom-injector.test.js +16 -18
- package/target/lib/dom-injector.test.js.map +1 -1
- package/target/lib/inject.js +3 -3
- package/target/lib/inject.js.map +1 -1
- package/target/lib/inject.test.js +58 -90
- package/target/lib/inject.test.js.map +1 -1
- package/target/lib/injectable-el.d.ts +334 -0
- package/target/lib/injectable-el.js +40 -0
- package/target/lib/injectable-el.js.map +1 -0
- package/target/lib/injectable-el.test.js +238 -0
- package/target/lib/injectable-el.test.js.map +1 -0
- package/target/lib/injectable.d.ts +5 -7
- package/target/lib/injectable.js +13 -42
- package/target/lib/injectable.js.map +1 -1
- package/target/lib/injectable.test.js +49 -204
- package/target/lib/injectable.test.js.map +1 -1
- package/target/lib/injector.d.ts +1 -1
- package/target/lib/injector.js +18 -14
- package/target/lib/injector.js.map +1 -1
- package/target/lib/injector.test.js +215 -216
- package/target/lib/injector.test.js.map +1 -1
- package/target/lib/lifecycle.d.ts +2 -4
- package/target/lib/lifecycle.js +15 -4
- package/target/lib/lifecycle.js.map +1 -1
- package/target/lib/lifecycle.test.js +142 -123
- package/target/lib/lifecycle.test.js.map +1 -1
- package/target/lib/metadata.d.ts +6 -0
- package/target/lib/metadata.js +5 -0
- package/target/lib/metadata.js.map +1 -0
- package/target/lib/provider.d.ts +6 -5
- package/target/lib/provider.js +10 -4
- package/target/lib/provider.js.map +1 -1
- package/target/lib.d.ts +1 -1
- package/target/lib.js +1 -1
- package/target/lib.js.map +1 -1
- package/src/lib/injectable-map.test.ts +0 -18
- package/src/lib/injectable-map.ts +0 -3
- package/src/lib/injector.test-node.ts +0 -187
- package/target/lib/injectable-map.d.ts +0 -3
- package/target/lib/injectable-map.js +0 -3
- package/target/lib/injectable-map.js.map +0 -1
- package/target/lib/injectable-map.test.js +0 -15
- package/target/lib/injectable-map.test.js.map +0 -1
- package/target/lib/injector.test-node.d.ts +0 -1
- package/target/lib/injector.test-node.js +0 -231
- package/target/lib/injector.test-node.js.map +0 -1
- /package/target/lib/{injectable-map.test.d.ts → injectable-el.test.d.ts} +0 -0
|
@@ -1,96 +1,100 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { assert } from 'chai';
|
|
2
2
|
|
|
3
3
|
import { Injector } from './injector.js';
|
|
4
|
-
import {
|
|
5
|
-
import { injectable } from './injectable';
|
|
4
|
+
import { injected, created } from './lifecycle.js';
|
|
5
|
+
import { injectable } from './injectable.js';
|
|
6
6
|
import { inject } from './inject.js';
|
|
7
7
|
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
const i = new Injector();
|
|
8
|
+
it('should call onInit and onInject when a service is first created', () => {
|
|
9
|
+
const i = new Injector();
|
|
11
10
|
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
11
|
+
@injectable()
|
|
12
|
+
class MyService {
|
|
13
|
+
res = {
|
|
14
|
+
onCreated: 0,
|
|
15
|
+
onInjected: 0
|
|
15
16
|
};
|
|
16
17
|
|
|
17
|
-
@
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
}
|
|
18
|
+
@created()
|
|
19
|
+
onCreated() {
|
|
20
|
+
this.res.onCreated++;
|
|
21
|
+
}
|
|
22
22
|
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
23
|
+
@injected()
|
|
24
|
+
onInjected() {
|
|
25
|
+
this.res.onInjected++;
|
|
26
26
|
}
|
|
27
|
+
}
|
|
27
28
|
|
|
28
|
-
|
|
29
|
+
const service = i.inject(MyService);
|
|
29
30
|
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
});
|
|
31
|
+
assert.deepEqual(service.res, {
|
|
32
|
+
onCreated: 1,
|
|
33
|
+
onInjected: 1
|
|
34
34
|
});
|
|
35
|
+
});
|
|
35
36
|
|
|
36
|
-
|
|
37
|
-
|
|
37
|
+
it('should call onInject any time a service is returned', () => {
|
|
38
|
+
const i = new Injector();
|
|
38
39
|
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
40
|
+
@injectable()
|
|
41
|
+
class MyService {
|
|
42
|
+
res = {
|
|
43
|
+
onCreated: 0,
|
|
44
|
+
onInjected: 0
|
|
42
45
|
};
|
|
43
46
|
|
|
44
|
-
@
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
}
|
|
47
|
+
@created()
|
|
48
|
+
onCreated() {
|
|
49
|
+
this.res.onCreated++;
|
|
50
|
+
}
|
|
49
51
|
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
52
|
+
@injected()
|
|
53
|
+
onInjected() {
|
|
54
|
+
this.res.onInjected++;
|
|
53
55
|
}
|
|
56
|
+
}
|
|
54
57
|
|
|
55
|
-
|
|
56
|
-
|
|
58
|
+
i.inject(MyService);
|
|
59
|
+
const service = i.inject(MyService);
|
|
57
60
|
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
});
|
|
61
|
+
assert.deepEqual(service.res, {
|
|
62
|
+
onCreated: 1,
|
|
63
|
+
onInjected: 2
|
|
62
64
|
});
|
|
65
|
+
});
|
|
63
66
|
|
|
64
|
-
|
|
65
|
-
|
|
67
|
+
it('should call onInject and on init when injected from another service', () => {
|
|
68
|
+
const i = new Injector();
|
|
66
69
|
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
+
@injectable()
|
|
71
|
+
class MyService {
|
|
72
|
+
res = {
|
|
73
|
+
onCreated: 0,
|
|
74
|
+
onInjected: 0
|
|
70
75
|
};
|
|
71
76
|
|
|
72
|
-
@
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
res.onInit++;
|
|
76
|
-
}
|
|
77
|
-
|
|
78
|
-
[LifeCycle.onInject]() {
|
|
79
|
-
res.onInject++;
|
|
80
|
-
}
|
|
77
|
+
@created()
|
|
78
|
+
onCreated() {
|
|
79
|
+
this.res.onCreated++;
|
|
81
80
|
}
|
|
82
81
|
|
|
83
|
-
@
|
|
84
|
-
|
|
85
|
-
|
|
82
|
+
@injected()
|
|
83
|
+
onInjected() {
|
|
84
|
+
this.res.onInjected++;
|
|
86
85
|
}
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
@injectable()
|
|
89
|
+
class MyApp {
|
|
90
|
+
service = inject(MyService);
|
|
91
|
+
}
|
|
87
92
|
|
|
88
|
-
|
|
89
|
-
|
|
93
|
+
i.inject(MyApp).service();
|
|
94
|
+
const service = i.inject(MyService);
|
|
90
95
|
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
});
|
|
96
|
+
assert.deepEqual(service.res, {
|
|
97
|
+
onCreated: 1,
|
|
98
|
+
onInjected: 2
|
|
95
99
|
});
|
|
96
100
|
});
|
package/src/lib/lifecycle.ts
CHANGED
|
@@ -1,4 +1,19 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
1
|
+
import { InjectableMetadata } from './metadata';
|
|
2
|
+
|
|
3
|
+
(Symbol as any).metadata ??= Symbol('Symbol.metadata');
|
|
4
|
+
|
|
5
|
+
export function injected() {
|
|
6
|
+
return function onInjectDecorator(val: Function, ctx: ClassMethodDecoratorContext) {
|
|
7
|
+
const metadata: InjectableMetadata = ctx.metadata;
|
|
8
|
+
metadata.onInjected ??= [];
|
|
9
|
+
metadata.onInjected.push(val);
|
|
10
|
+
};
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
export function created() {
|
|
14
|
+
return function onInjectDecorator(val: Function, ctx: ClassMethodDecoratorContext) {
|
|
15
|
+
const metadata: InjectableMetadata = ctx.metadata;
|
|
16
|
+
metadata.onCreated ??= [];
|
|
17
|
+
metadata.onCreated.push(val);
|
|
18
|
+
};
|
|
19
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { ConstructableToken } from './provider.js';
|
|
2
|
+
|
|
3
|
+
export interface InjectableMetadata {
|
|
4
|
+
onCreated?: Function[];
|
|
5
|
+
onInjected?: Function[];
|
|
6
|
+
}
|
|
7
|
+
|
|
8
|
+
export function readMetadata<T>(target: ConstructableToken<T>) {
|
|
9
|
+
const metadata: InjectableMetadata | null = target[Symbol.metadata];
|
|
10
|
+
|
|
11
|
+
return metadata;
|
|
12
|
+
}
|
package/src/lib/provider.ts
CHANGED
|
@@ -1,18 +1,26 @@
|
|
|
1
1
|
import { Injector } from './injector.js';
|
|
2
2
|
|
|
3
|
+
export type ProviderFactory<T> = (injector: Injector) => T;
|
|
4
|
+
|
|
3
5
|
export class StaticToken<T> {
|
|
4
|
-
name;
|
|
5
|
-
factory;
|
|
6
|
+
#name;
|
|
7
|
+
#factory;
|
|
8
|
+
|
|
9
|
+
get name() {
|
|
10
|
+
return this.#name;
|
|
11
|
+
}
|
|
6
12
|
|
|
7
|
-
|
|
8
|
-
this
|
|
9
|
-
|
|
13
|
+
get factory() {
|
|
14
|
+
return this.#factory;
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
constructor(name: string, factory?: ProviderFactory<T>) {
|
|
18
|
+
this.#name = name;
|
|
19
|
+
this.#factory = factory;
|
|
10
20
|
}
|
|
11
21
|
}
|
|
12
22
|
|
|
13
23
|
export interface ConstructableToken<T> {
|
|
14
|
-
providers?: Provider<any>[];
|
|
15
|
-
|
|
16
24
|
new (...args: any[]): T;
|
|
17
25
|
}
|
|
18
26
|
|
|
@@ -21,5 +29,5 @@ export type InjectionToken<T> = ConstructableToken<T> | StaticToken<T>;
|
|
|
21
29
|
export interface Provider<T> {
|
|
22
30
|
provide: InjectionToken<T>;
|
|
23
31
|
use?: ConstructableToken<T>;
|
|
24
|
-
factory
|
|
32
|
+
factory?: ProviderFactory<T>;
|
|
25
33
|
}
|
package/src/lib.ts
CHANGED
|
@@ -2,5 +2,5 @@ export { Injector } from './lib/injector.js';
|
|
|
2
2
|
export { Provider, ConstructableToken, StaticToken } from './lib/provider.js';
|
|
3
3
|
export { injectable } from './lib/injectable.js';
|
|
4
4
|
export { inject, Injected } from './lib/inject.js';
|
|
5
|
-
export {
|
|
5
|
+
export { injected, created } from './lib/lifecycle.js';
|
|
6
6
|
export { DOMInjector } from './lib/dom-injector.js';
|
|
@@ -1,11 +1,10 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { Injector } from './injector.js';
|
|
1
|
+
import { injectables, Injector } from './injector.js';
|
|
3
2
|
export class DOMInjector extends Injector {
|
|
4
3
|
attach(root) {
|
|
5
|
-
|
|
4
|
+
injectables.set(root, this);
|
|
6
5
|
}
|
|
7
6
|
detach(root) {
|
|
8
|
-
|
|
7
|
+
injectables.delete(root);
|
|
9
8
|
}
|
|
10
9
|
}
|
|
11
10
|
//# sourceMappingURL=dom-injector.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"dom-injector.js","sourceRoot":"","sources":["../../src/lib/dom-injector.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"dom-injector.js","sourceRoot":"","sources":["../../src/lib/dom-injector.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AAEtD,MAAM,OAAO,WAAY,SAAQ,QAAQ;IACvC,MAAM,CAAC,IAAiB;QACtB,WAAW,CAAC,GAAG,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;IAC9B,CAAC;IAED,MAAM,CAAC,IAAiB;QACtB,WAAW,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAC3B,CAAC;CACF"}
|
|
@@ -1,21 +1,19 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { assert } from 'chai';
|
|
2
2
|
import { DOMInjector } from './dom-injector.js';
|
|
3
|
-
import {
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
expect(INJECTABLE_MAP.get(root)).to.equal(undefined);
|
|
19
|
-
});
|
|
3
|
+
import { injectables } from './injector.js';
|
|
4
|
+
it('should attach an injector to a dom element', () => {
|
|
5
|
+
const root = document.createElement('div');
|
|
6
|
+
const app = new DOMInjector();
|
|
7
|
+
app.attach(root);
|
|
8
|
+
const injector = injectables.get(root);
|
|
9
|
+
assert.strictEqual(injector, app);
|
|
10
|
+
});
|
|
11
|
+
it('should remove an injector associated with a dom element', () => {
|
|
12
|
+
const root = document.createElement('div');
|
|
13
|
+
const app = new DOMInjector();
|
|
14
|
+
app.attach(root);
|
|
15
|
+
assert.strictEqual(injectables.get(root), app);
|
|
16
|
+
app.detach(root);
|
|
17
|
+
assert.strictEqual(injectables.get(root), undefined);
|
|
20
18
|
});
|
|
21
19
|
//# sourceMappingURL=dom-injector.test.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"dom-injector.test.js","sourceRoot":"","sources":["../../src/lib/dom-injector.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"dom-injector.test.js","sourceRoot":"","sources":["../../src/lib/dom-injector.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,MAAM,CAAC;AAE9B,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAChD,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAE5C,EAAE,CAAC,4CAA4C,EAAE,GAAG,EAAE;IACpD,MAAM,IAAI,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;IAC3C,MAAM,GAAG,GAAG,IAAI,WAAW,EAAE,CAAC;IAE9B,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAEjB,MAAM,QAAQ,GAAG,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IAEvC,MAAM,CAAC,WAAW,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC;AACpC,CAAC,CAAC,CAAC;AAEH,EAAE,CAAC,yDAAyD,EAAE,GAAG,EAAE;IACjE,MAAM,IAAI,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;IAC3C,MAAM,GAAG,GAAG,IAAI,WAAW,EAAE,CAAC;IAE9B,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAEjB,MAAM,CAAC,WAAW,CAAC,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,GAAG,CAAC,CAAC;IAE/C,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAEjB,MAAM,CAAC,WAAW,CAAC,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,SAAS,CAAC,CAAC;AACvD,CAAC,CAAC,CAAC"}
|
package/target/lib/inject.js
CHANGED
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { injectables } from './injector.js';
|
|
2
2
|
export function inject(token) {
|
|
3
3
|
return function () {
|
|
4
|
-
const injector =
|
|
4
|
+
const injector = injectables.get(this);
|
|
5
5
|
if (injector === undefined) {
|
|
6
6
|
const name = Object.getPrototypeOf(this.constructor).name;
|
|
7
|
-
throw new Error(`${name} is either not injectable or a service is being called in the constructor. \n Either add the @injectable to your class or use the [LifeCycle.onInject] callback method.`);
|
|
7
|
+
throw new Error(`${name} is either not injectable or a service is being called in the constructor. \n Either add the @injectable() to your class or use the [LifeCycle.onInject] callback method.`);
|
|
8
8
|
}
|
|
9
9
|
return injector.inject(token);
|
|
10
10
|
};
|
package/target/lib/inject.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"inject.js","sourceRoot":"","sources":["../../src/lib/inject.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"inject.js","sourceRoot":"","sources":["../../src/lib/inject.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAI5C,MAAM,UAAU,MAAM,CAAyB,KAAwB;IACrE,OAAO;QACL,MAAM,QAAQ,GAAG,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAEvC,IAAI,QAAQ,KAAK,SAAS,EAAE,CAAC;YAC3B,MAAM,IAAI,GAAG,MAAM,CAAC,cAAc,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC;YAE1D,MAAM,IAAI,KAAK,CACb,GAAG,IAAI,2KAA2K,CACnL,CAAC;QACJ,CAAC;QAED,OAAO,QAAQ,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IAChC,CAAC,CAAC;AACJ,CAAC"}
|
|
@@ -1,41 +1,16 @@
|
|
|
1
1
|
import { __esDecorate, __runInitializers } from "tslib";
|
|
2
|
-
import {
|
|
2
|
+
import { assert } from 'chai';
|
|
3
3
|
import { inject } from './inject.js';
|
|
4
4
|
import { injectable } from './injectable.js';
|
|
5
5
|
import { Injector } from './injector.js';
|
|
6
6
|
import { StaticToken } from './provider.js';
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
class HelloService {
|
|
10
|
-
}
|
|
11
|
-
let HelloWorld = (() => {
|
|
12
|
-
let _classDecorators = [injectable];
|
|
13
|
-
let _classDescriptor;
|
|
14
|
-
let _classExtraInitializers = [];
|
|
15
|
-
let _classThis;
|
|
16
|
-
let _classSuper = HTMLElement;
|
|
17
|
-
var HelloWorld = class extends _classSuper {
|
|
18
|
-
static { _classThis = this; }
|
|
19
|
-
static {
|
|
20
|
-
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
|
|
21
|
-
__esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
|
|
22
|
-
HelloWorld = _classThis = _classDescriptor.value;
|
|
23
|
-
if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
|
|
24
|
-
__runInitializers(_classThis, _classExtraInitializers);
|
|
25
|
-
}
|
|
26
|
-
hello = inject(HelloService);
|
|
27
|
-
};
|
|
28
|
-
return HelloWorld = _classThis;
|
|
29
|
-
})();
|
|
30
|
-
customElements.define('inject-1', HelloWorld);
|
|
31
|
-
expect(new HelloWorld().hello()).to.be.instanceOf(HelloService);
|
|
32
|
-
});
|
|
33
|
-
it('should throw error if called in constructor', () => {
|
|
7
|
+
it('should throw error if called in constructor', () => {
|
|
8
|
+
assert.throws(() => {
|
|
34
9
|
class FooService {
|
|
35
10
|
value = '1';
|
|
36
11
|
}
|
|
37
12
|
let BarService = (() => {
|
|
38
|
-
let _classDecorators = [injectable];
|
|
13
|
+
let _classDecorators = [injectable()];
|
|
39
14
|
let _classDescriptor;
|
|
40
15
|
let _classExtraInitializers = [];
|
|
41
16
|
let _classThis;
|
|
@@ -56,68 +31,61 @@ describe('inject', () => {
|
|
|
56
31
|
return BarService = _classThis;
|
|
57
32
|
})();
|
|
58
33
|
const parent = new Injector();
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
34
|
+
parent.inject(BarService);
|
|
35
|
+
}, 'BarService is either not injectable or a service is being called in the constructor.');
|
|
36
|
+
});
|
|
37
|
+
it('should use the calling injector as parent', () => {
|
|
38
|
+
class FooService {
|
|
39
|
+
value = '1';
|
|
40
|
+
}
|
|
41
|
+
let BarService = (() => {
|
|
42
|
+
let _classDecorators = [injectable()];
|
|
43
|
+
let _classDescriptor;
|
|
44
|
+
let _classExtraInitializers = [];
|
|
45
|
+
let _classThis;
|
|
46
|
+
var BarService = class {
|
|
47
|
+
static { _classThis = this; }
|
|
48
|
+
static {
|
|
49
|
+
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(null) : void 0;
|
|
50
|
+
__esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
|
|
51
|
+
BarService = _classThis = _classDescriptor.value;
|
|
52
|
+
if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
|
|
53
|
+
__runInitializers(_classThis, _classExtraInitializers);
|
|
54
|
+
}
|
|
55
|
+
foo = inject(FooService);
|
|
56
|
+
};
|
|
57
|
+
return BarService = _classThis;
|
|
58
|
+
})();
|
|
59
|
+
const parent = new Injector([
|
|
60
|
+
{
|
|
61
|
+
provide: FooService,
|
|
62
|
+
use: class extends FooService {
|
|
63
|
+
value = '100';
|
|
64
|
+
}
|
|
71
65
|
}
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
const parent = new Injector([
|
|
91
|
-
{
|
|
92
|
-
provide: FooService,
|
|
93
|
-
use: class extends FooService {
|
|
94
|
-
value = '100';
|
|
95
|
-
}
|
|
66
|
+
]);
|
|
67
|
+
assert.strictEqual(parent.inject(BarService).foo().value, '100');
|
|
68
|
+
});
|
|
69
|
+
it('should inject a static token', () => {
|
|
70
|
+
const TOKEN = new StaticToken('test', () => 'Hello World');
|
|
71
|
+
let HelloWorld = (() => {
|
|
72
|
+
let _classDecorators = [injectable()];
|
|
73
|
+
let _classDescriptor;
|
|
74
|
+
let _classExtraInitializers = [];
|
|
75
|
+
let _classThis;
|
|
76
|
+
var HelloWorld = class {
|
|
77
|
+
static { _classThis = this; }
|
|
78
|
+
static {
|
|
79
|
+
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(null) : void 0;
|
|
80
|
+
__esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
|
|
81
|
+
HelloWorld = _classThis = _classDescriptor.value;
|
|
82
|
+
if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
|
|
83
|
+
__runInitializers(_classThis, _classExtraInitializers);
|
|
96
84
|
}
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
let HelloWorld = (() => {
|
|
103
|
-
let _classDecorators = [injectable];
|
|
104
|
-
let _classDescriptor;
|
|
105
|
-
let _classExtraInitializers = [];
|
|
106
|
-
let _classThis;
|
|
107
|
-
var HelloWorld = class {
|
|
108
|
-
static { _classThis = this; }
|
|
109
|
-
static {
|
|
110
|
-
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(null) : void 0;
|
|
111
|
-
__esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
|
|
112
|
-
HelloWorld = _classThis = _classDescriptor.value;
|
|
113
|
-
if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
|
|
114
|
-
__runInitializers(_classThis, _classExtraInitializers);
|
|
115
|
-
}
|
|
116
|
-
hello = inject(TOKEN);
|
|
117
|
-
};
|
|
118
|
-
return HelloWorld = _classThis;
|
|
119
|
-
})();
|
|
120
|
-
expect(new HelloWorld().hello()).to.equal('Hello World');
|
|
121
|
-
});
|
|
85
|
+
hello = inject(TOKEN);
|
|
86
|
+
};
|
|
87
|
+
return HelloWorld = _classThis;
|
|
88
|
+
})();
|
|
89
|
+
assert.strictEqual(new HelloWorld().hello(), 'Hello World');
|
|
122
90
|
});
|
|
123
91
|
//# sourceMappingURL=inject.test.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"inject.test.js","sourceRoot":"","sources":["../../src/lib/inject.test.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"inject.test.js","sourceRoot":"","sources":["../../src/lib/inject.test.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,MAAM,CAAC;AAE9B,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AACrC,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AACzC,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAE5C,EAAE,CAAC,6CAA6C,EAAE,GAAG,EAAE;IACrD,MAAM,CAAC,MAAM,CAAC,GAAG,EAAE;QACjB,MAAM,UAAU;YACd,KAAK,GAAG,GAAG,CAAC;SACb;YAGK,UAAU;oCADf,UAAU,EAAE;;;;;;;;oBACb,6KAMC;;;oBANK,uDAAU;;gBACd,GAAG,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;gBAEzB;oBACE,IAAI,CAAC,GAAG,EAAE,CAAC;gBACb,CAAC;;;;QAGH,MAAM,MAAM,GAAG,IAAI,QAAQ,EAAE,CAAC;QAE9B,MAAM,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;IAC5B,CAAC,EAAE,sFAAsF,CAAC,CAAC;AAC7F,CAAC,CAAC,CAAC;AAEH,EAAE,CAAC,2CAA2C,EAAE,GAAG,EAAE;IACnD,MAAM,UAAU;QACd,KAAK,GAAG,GAAG,CAAC;KACb;QAGK,UAAU;gCADf,UAAU,EAAE;;;;;;;;gBACb,6KAEC;;;gBAFK,uDAAU;;YACd,GAAG,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;;;;IAG3B,MAAM,MAAM,GAAG,IAAI,QAAQ,CAAC;QAC1B;YACE,OAAO,EAAE,UAAU;YACnB,GAAG,EAAE,KAAM,SAAQ,UAAU;gBAC3B,KAAK,GAAG,KAAK,CAAC;aACf;SACF;KACF,CAAC,CAAC;IAEH,MAAM,CAAC,WAAW,CAAC,MAAM,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,GAAG,EAAE,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;AACnE,CAAC,CAAC,CAAC;AAEH,EAAE,CAAC,8BAA8B,EAAE,GAAG,EAAE;IACtC,MAAM,KAAK,GAAG,IAAI,WAAW,CAAC,MAAM,EAAE,GAAG,EAAE,CAAC,aAAa,CAAC,CAAC;QAGrD,UAAU;gCADf,UAAU,EAAE;;;;;;;;gBACb,6KAEC;;;gBAFK,uDAAU;;YACd,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;;;;IAGxB,MAAM,CAAC,WAAW,CAAC,IAAI,UAAU,EAAE,CAAC,KAAK,EAAE,EAAE,aAAa,CAAC,CAAC;AAC9D,CAAC,CAAC,CAAC"}
|