ts-ioc-container 20.2.7 → 20.2.9
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 +43 -3
- package/cjm/container/IContainer.d.ts +2 -2
- package/cjm/provider/Provider.js +2 -2
- package/cjm/provider/Provider.js.map +1 -1
- package/esm/container/IContainer.d.ts +2 -2
- package/esm/provider/Provider.js +1 -1
- package/esm/provider/Provider.js.map +1 -1
- package/package.json +2 -2
package/README.md
CHANGED
|
@@ -68,11 +68,23 @@ container.register('ILogger5', fromValue(new Logger()).build());
|
|
|
68
68
|
|
|
69
69
|
```typescript
|
|
70
70
|
import { asSingleton, perTags, forKey, by } from "ts-ioc-container";
|
|
71
|
-
import { inject } from "ts-constructor-injector";
|
|
71
|
+
import { composeDecorators, inject } from "ts-constructor-injector";
|
|
72
72
|
|
|
73
73
|
@asSingleton
|
|
74
|
+
@perTags('root')
|
|
75
|
+
@forKey('IEngine')
|
|
76
|
+
class Engine {
|
|
77
|
+
constructor(@inject(by('ILogger')) private logger: ILogger) {
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
const perRoot = composeDecorators(
|
|
82
|
+
asSingleton,
|
|
83
|
+
perTags('root'),
|
|
84
|
+
);
|
|
85
|
+
|
|
86
|
+
@perRoot
|
|
74
87
|
@forKey('IEngine')
|
|
75
|
-
@perTags('tag1', 'tag2')
|
|
76
88
|
class Engine {
|
|
77
89
|
constructor(@inject(by('ILogger')) private logger: ILogger) {
|
|
78
90
|
}
|
|
@@ -129,7 +141,35 @@ for (const instance of container.getInstances()) {
|
|
|
129
141
|
- tags - you can add tag to scope and root container. And register provider per tag.
|
|
130
142
|
|
|
131
143
|
```typescript
|
|
132
|
-
|
|
144
|
+
import { composeDecorators } from "ts-constructor-injector";
|
|
145
|
+
import { forKey } from "ts-ioc-container";
|
|
146
|
+
|
|
147
|
+
const perRoot = composeDecorators(
|
|
148
|
+
asSingleton,
|
|
149
|
+
perTags('root'),
|
|
150
|
+
);
|
|
151
|
+
|
|
152
|
+
const perHome = composeDecorators(
|
|
153
|
+
asSingleton,
|
|
154
|
+
perTags('home'),
|
|
155
|
+
);
|
|
156
|
+
|
|
157
|
+
@perRoot
|
|
158
|
+
@forKey('IEngine')
|
|
159
|
+
class Logger {
|
|
160
|
+
}
|
|
161
|
+
|
|
162
|
+
@perHome
|
|
163
|
+
@forKey('IEngine')
|
|
164
|
+
class Engine {
|
|
165
|
+
constructor(@inject(by('ILogger')) private logger: ILogger) {
|
|
166
|
+
}
|
|
167
|
+
}
|
|
168
|
+
|
|
169
|
+
const container = new Container(injector, { tags: ['root'] })
|
|
170
|
+
.register('ILogger', fromClass(Logger).build())
|
|
171
|
+
.register('IEngine', fromClass(Engine).build());
|
|
172
|
+
|
|
133
173
|
const scope = container.createScope(['home', 'child']);
|
|
134
174
|
const logger = scope.resolve('ILogger');
|
|
135
175
|
scope.dispose();
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import { IProvider, ProviderKey, Tag } from '../provider/IProvider';
|
|
2
2
|
import { constructor, Disposable } from '../utils/types';
|
|
3
3
|
import { Registration } from '../registration/Registration';
|
|
4
|
-
export declare type InjectionToken<T =
|
|
4
|
+
export declare type InjectionToken<T = unknown> = constructor<T> | ProviderKey;
|
|
5
5
|
export interface Resolveable {
|
|
6
|
-
resolve<T>(key: InjectionToken<T>, ...args:
|
|
6
|
+
resolve<T>(key: InjectionToken<T>, ...args: unknown[]): T;
|
|
7
7
|
}
|
|
8
8
|
export interface IContainer extends Disposable, Resolveable {
|
|
9
9
|
createScope(tags?: Tag[]): IContainer;
|
package/cjm/provider/Provider.js
CHANGED
|
@@ -31,12 +31,12 @@ var Provider = /** @class */ (function () {
|
|
|
31
31
|
this.resolveDependency = resolveDependency;
|
|
32
32
|
}
|
|
33
33
|
Provider.fromClass = function (value) {
|
|
34
|
-
return new Provider(function (
|
|
34
|
+
return new Provider(function (container) {
|
|
35
35
|
var args = [];
|
|
36
36
|
for (var _i = 1; _i < arguments.length; _i++) {
|
|
37
37
|
args[_i - 1] = arguments[_i];
|
|
38
38
|
}
|
|
39
|
-
return
|
|
39
|
+
return container.resolve.apply(container, __spreadArray([value], __read(args), false));
|
|
40
40
|
});
|
|
41
41
|
};
|
|
42
42
|
Provider.fromValue = function (value) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Provider.js","sourceRoot":"","sources":["../../lib/provider/Provider.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAIA;IASI,kBAA6B,iBAAuC;QAAvC,sBAAiB,GAAjB,iBAAiB,CAAsB;IAAG,CAAC;IARjE,kBAAS,GAAhB,UAAoB,KAAqB;QACrC,OAAO,IAAI,QAAQ,CAAC,UAAC,
|
|
1
|
+
{"version":3,"file":"Provider.js","sourceRoot":"","sources":["../../lib/provider/Provider.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAIA;IASI,kBAA6B,iBAAuC;QAAvC,sBAAiB,GAAjB,iBAAiB,CAAsB;IAAG,CAAC;IARjE,kBAAS,GAAhB,UAAoB,KAAqB;QACrC,OAAO,IAAI,QAAQ,CAAC,UAAC,SAAS;YAAE,cAAO;iBAAP,UAAO,EAAP,qBAAO,EAAP,IAAO;gBAAP,6BAAO;;YAAK,OAAA,SAAS,CAAC,OAAO,OAAjB,SAAS,iBAAS,KAAK,UAAK,IAAI;QAAhC,CAAiC,CAAC,CAAC;IACnF,CAAC;IAEM,kBAAS,GAAhB,UAAoB,KAAQ;QACxB,OAAO,IAAI,QAAQ,CAAC,cAAM,OAAA,KAAK,EAAL,CAAK,CAAC,CAAC;IACrC,CAAC;IAID,wBAAK,GAAL;QACI,OAAO,IAAI,QAAQ,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;IAChD,CAAC;IAED,0BAAO,GAAP,UAAQ,SAAsB;QAAE,cAAkB;aAAlB,UAAkB,EAAlB,qBAAkB,EAAlB,IAAkB;YAAlB,6BAAkB;;QAC9C,OAAO,IAAI,CAAC,iBAAiB,OAAtB,IAAI,iBAAmB,SAAS,UAAK,IAAI,WAAE;IACtD,CAAC;IAED,0BAAO,GAAP,cAAiB,CAAC;IAElB,0BAAO,GAAP;QACI,OAAO,IAAI,CAAC;IAChB,CAAC;IACL,eAAC;AAAD,CAAC,AAxBD,IAwBC;AAxBY,4BAAQ"}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import { IProvider, ProviderKey, Tag } from '../provider/IProvider';
|
|
2
2
|
import { constructor, Disposable } from '../utils/types';
|
|
3
3
|
import { Registration } from '../registration/Registration';
|
|
4
|
-
export declare type InjectionToken<T =
|
|
4
|
+
export declare type InjectionToken<T = unknown> = constructor<T> | ProviderKey;
|
|
5
5
|
export interface Resolveable {
|
|
6
|
-
resolve<T>(key: InjectionToken<T>, ...args:
|
|
6
|
+
resolve<T>(key: InjectionToken<T>, ...args: unknown[]): T;
|
|
7
7
|
}
|
|
8
8
|
export interface IContainer extends Disposable, Resolveable {
|
|
9
9
|
createScope(tags?: Tag[]): IContainer;
|
package/esm/provider/Provider.js
CHANGED
|
@@ -3,7 +3,7 @@ export class Provider {
|
|
|
3
3
|
this.resolveDependency = resolveDependency;
|
|
4
4
|
}
|
|
5
5
|
static fromClass(value) {
|
|
6
|
-
return new Provider((
|
|
6
|
+
return new Provider((container, ...args) => container.resolve(value, ...args));
|
|
7
7
|
}
|
|
8
8
|
static fromValue(value) {
|
|
9
9
|
return new Provider(() => value);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Provider.js","sourceRoot":"","sources":["../../lib/provider/Provider.ts"],"names":[],"mappings":"AAIA,MAAM,OAAO,QAAQ;IASjB,YAA6B,iBAAuC;QAAvC,sBAAiB,GAAjB,iBAAiB,CAAsB;IAAG,CAAC;IARxE,MAAM,CAAC,SAAS,CAAI,KAAqB;QACrC,OAAO,IAAI,QAAQ,CAAC,CAAC,
|
|
1
|
+
{"version":3,"file":"Provider.js","sourceRoot":"","sources":["../../lib/provider/Provider.ts"],"names":[],"mappings":"AAIA,MAAM,OAAO,QAAQ;IASjB,YAA6B,iBAAuC;QAAvC,sBAAiB,GAAjB,iBAAiB,CAAsB;IAAG,CAAC;IARxE,MAAM,CAAC,SAAS,CAAI,KAAqB;QACrC,OAAO,IAAI,QAAQ,CAAC,CAAC,SAAS,EAAE,GAAG,IAAI,EAAE,EAAE,CAAC,SAAS,CAAC,OAAO,CAAC,KAAK,EAAE,GAAG,IAAI,CAAC,CAAC,CAAC;IACnF,CAAC;IAED,MAAM,CAAC,SAAS,CAAI,KAAQ;QACxB,OAAO,IAAI,QAAQ,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC;IACrC,CAAC;IAID,KAAK;QACD,OAAO,IAAI,QAAQ,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;IAChD,CAAC;IAED,OAAO,CAAC,SAAsB,EAAE,GAAG,IAAe;QAC9C,OAAO,IAAI,CAAC,iBAAiB,CAAC,SAAS,EAAE,GAAG,IAAI,CAAC,CAAC;IACtD,CAAC;IAED,OAAO,KAAU,CAAC;IAElB,OAAO;QACH,OAAO,IAAI,CAAC;IAChB,CAAC;CACJ"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "ts-ioc-container",
|
|
3
|
-
"version": "20.2.
|
|
3
|
+
"version": "20.2.9",
|
|
4
4
|
"description": "Typescript IoC container",
|
|
5
5
|
"author": "ibabkin <igba14@gmail.com>",
|
|
6
6
|
"homepage": "https://github.com/IgorBabkin/ts-ioc-container/tree/master/packages/ts-ioc-container",
|
|
@@ -48,5 +48,5 @@
|
|
|
48
48
|
"ts-jest": "27.0.5",
|
|
49
49
|
"typescript": "4.4.3"
|
|
50
50
|
},
|
|
51
|
-
"gitHead": "
|
|
51
|
+
"gitHead": "3865a51aa5718e7ece326dd4e1352c5957fec6ee"
|
|
52
52
|
}
|