@kaokei/di 1.0.18 → 1.0.23
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/CHANGELOG.md +124 -0
- package/README.md +20 -102
- package/dist/index.cjs.js +442 -231
- package/dist/index.cjs.js.map +1 -1
- package/dist/index.cjs.min.js +3 -3
- package/dist/index.cjs.min.js.map +1 -1
- package/dist/index.cjs.runtime.js +436 -227
- package/dist/index.cjs.runtime.js.map +1 -1
- package/dist/index.cjs.runtime.min.js +3 -3
- package/dist/index.cjs.runtime.min.js.map +1 -1
- package/dist/index.esm.js +444 -214
- package/dist/index.esm.js.map +1 -1
- package/dist/index.esm.min.js +4 -4
- package/dist/index.esm.min.js.map +1 -1
- package/dist/index.esm.runtime.js +432 -209
- package/dist/index.esm.runtime.js.map +1 -1
- package/dist/index.esm.runtime.min.js +4 -4
- package/dist/index.esm.runtime.min.js.map +1 -1
- package/dist/index.iife.js +450 -234
- package/dist/index.iife.js.map +1 -1
- package/dist/index.iife.min.js +4 -4
- package/dist/index.iife.min.js.map +1 -1
- package/dist/src/Injector.d.ts +61 -27
- package/dist/src/Injector.d.ts.map +1 -1
- package/dist/src/constants.d.ts +5 -11
- package/dist/src/constants.d.ts.map +1 -1
- package/dist/src/decorator.d.ts +12 -0
- package/dist/src/decorator.d.ts.map +1 -1
- package/dist/src/errors/CircularDependencyError.d.ts +6 -0
- package/dist/src/errors/CircularDependencyError.d.ts.map +1 -0
- package/dist/src/errors/InjectFailedError.d.ts +6 -0
- package/dist/src/errors/InjectFailedError.d.ts.map +1 -0
- package/dist/src/errors/ProviderNotValidError.d.ts +6 -0
- package/dist/src/errors/ProviderNotValidError.d.ts.map +1 -0
- package/dist/src/errors/TokenNotFoundError.d.ts +6 -0
- package/dist/src/errors/TokenNotFoundError.d.ts.map +1 -0
- package/dist/src/errors/index.d.ts +5 -0
- package/dist/src/errors/index.d.ts.map +1 -0
- package/dist/src/index.d.ts +2 -3
- package/dist/src/index.d.ts.map +1 -1
- package/package.json +5 -7
|
@@ -1,49 +1,61 @@
|
|
|
1
1
|
import _construct from "@babel/runtime/helpers/esm/construct";
|
|
2
2
|
import _toConsumableArray from "@babel/runtime/helpers/esm/toConsumableArray";
|
|
3
|
-
import _classCallCheck from "@babel/runtime/helpers/esm/classCallCheck";
|
|
4
3
|
import _createClass from "@babel/runtime/helpers/esm/createClass";
|
|
4
|
+
import _classCallCheck from "@babel/runtime/helpers/esm/classCallCheck";
|
|
5
|
+
import _assertThisInitialized from "@babel/runtime/helpers/esm/assertThisInitialized";
|
|
6
|
+
import _inherits from "@babel/runtime/helpers/esm/inherits";
|
|
7
|
+
import _possibleConstructorReturn from "@babel/runtime/helpers/esm/possibleConstructorReturn";
|
|
8
|
+
import _getPrototypeOf from "@babel/runtime/helpers/esm/getPrototypeOf";
|
|
9
|
+
import _wrapNativeSuper from "@babel/runtime/helpers/esm/wrapNativeSuper";
|
|
5
10
|
import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
|
|
6
11
|
|
|
12
|
+
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
|
|
13
|
+
|
|
14
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
15
|
+
|
|
16
|
+
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
|
|
17
|
+
|
|
18
|
+
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
|
|
19
|
+
|
|
7
20
|
/**
|
|
8
21
|
* @kaokei/di
|
|
9
|
-
*
|
|
22
|
+
* Tiny di library depend on typescript and reflect-metadata
|
|
10
23
|
*
|
|
11
|
-
* @version 1.0.
|
|
24
|
+
* @version 1.0.23
|
|
12
25
|
* @author kaokei
|
|
13
26
|
* @license MIT
|
|
14
27
|
* @link https://github.com/kaokei/di
|
|
15
28
|
*/
|
|
16
|
-
export * from 'reflect-metadata';
|
|
17
|
-
export { default as autobind } from 'autobind-decorator';
|
|
18
|
-
var DESIGN_PARAM_TYPES = 'design:paramtypes'; // ts自带的类的构造函数的参数的类型信息的key
|
|
19
|
-
|
|
20
|
-
var SERVICE_PARAM_TYPES = 'service:paramtypes'; // 构造函数原始的类型数据,可能会被@Inject等覆盖
|
|
21
|
-
|
|
22
|
-
var SERVICE_INJECTED_PARAMS = 'service:injected:params'; // 构造函数使用@Inject注入的数据
|
|
23
|
-
|
|
24
|
-
var SERVICE_INJECTED_PROPS = 'service:injected:props'; // @Inject注入的properties
|
|
25
|
-
|
|
26
29
|
var DECORATOR_KEYS = {
|
|
30
|
+
// ts自带的类的实例属性的类型的key
|
|
31
|
+
DESIGN_PROPERTY_TYPE: 'design:type',
|
|
32
|
+
// ts自带的类的构造函数的参数的类型信息的key
|
|
33
|
+
DESIGN_PARAM_TYPES: 'design:paramtypes',
|
|
34
|
+
// 记录构造函数原始的类型数据的key,其实就是转存了DESIGN_PARAM_TYPES对应的数据
|
|
35
|
+
SERVICE_PARAM_TYPES: 'service:paramtypes',
|
|
36
|
+
// 记录构造函数参数装饰器对应的数据的key
|
|
37
|
+
SERVICE_INJECTED_PARAMS: 'service:injected:params',
|
|
38
|
+
// 记录实例属性装饰器对应的数据的key
|
|
39
|
+
SERVICE_INJECTED_PROPS: 'service:injected:props',
|
|
40
|
+
// Inject装饰器的key
|
|
27
41
|
INJECT: Symbol('inject'),
|
|
42
|
+
// Injectable装饰器的key
|
|
28
43
|
INJECTABLE: Symbol('injectable'),
|
|
44
|
+
// Self装饰器的key
|
|
29
45
|
SELF: 'self',
|
|
46
|
+
// Skip装饰器的key
|
|
30
47
|
SKIP_SELF: 'skip',
|
|
31
|
-
|
|
32
|
-
|
|
48
|
+
// Optional装饰器的key
|
|
49
|
+
OPTIONAL: 'optional'
|
|
33
50
|
};
|
|
34
51
|
var SERVICE_STATUS = {
|
|
35
52
|
INITING: Symbol('initing'),
|
|
36
53
|
CONSTRUCTED: Symbol('constructed'),
|
|
37
|
-
MERGED: Symbol('merged')
|
|
38
|
-
|
|
39
|
-
}; // 以下是error message常量
|
|
40
|
-
|
|
41
|
-
var ERROR_CIRCULAR_DEPENDENCY = 'CIRCULAR DEPENDENCY DETECTED. PLEASE FIX IT MANUALLY.';
|
|
42
|
-
var ERROR_DISABLE_MULTIPLE_INJECTABLE = 'Use multiple @Injectable on same class is not valid.';
|
|
43
|
-
var ERROR_TOKEN_NOT_FOUND = 'Token not found.';
|
|
44
|
-
var ERROR_INJECT_NOT_VALID = "You may forget to use @Inject on class property or @Injects's parameter is undefined.";
|
|
45
|
-
var ERROR_PROVIDER_NOT_VALID = "Provider is not valid.";
|
|
54
|
+
MERGED: Symbol('merged')
|
|
55
|
+
};
|
|
46
56
|
/**
|
|
57
|
+
* 这里记录不同的装饰器的参数的含义
|
|
58
|
+
*
|
|
47
59
|
* class decorator:
|
|
48
60
|
* 只有一个参数:构造函数
|
|
49
61
|
* property decorator:
|
|
@@ -61,42 +73,79 @@ var ERROR_PROVIDER_NOT_VALID = "Provider is not valid.";
|
|
|
61
73
|
* 实例访问器:原型, 方法名, 属性描述符
|
|
62
74
|
*/
|
|
63
75
|
|
|
64
|
-
|
|
76
|
+
/**
|
|
77
|
+
* 创建装饰器的高阶函数
|
|
78
|
+
* 装饰器的通用逻辑就是通过Reflect记录到全局的Map中
|
|
79
|
+
* 所以可以抽象出一个通用逻辑,这里需要注意对Inject装饰器有特殊判断
|
|
80
|
+
*
|
|
81
|
+
* @param {(string | symbol)} decoratorKey 代表某个装饰器的名称
|
|
82
|
+
* @param {*} [defaultValue] 该装饰器函数的默认参数
|
|
83
|
+
* @return {*} 一个装饰器
|
|
84
|
+
*/
|
|
85
|
+
|
|
86
|
+
function createDecorator(decoratorKey, defaultValue) {
|
|
87
|
+
// 因为装饰器本身作为一个函数是有参数的,此处的decoratorValue就是实际使用装饰器的实参
|
|
65
88
|
return function (decoratorValue) {
|
|
89
|
+
// 目前的装饰器只支持类的构造函数参数装饰器和类的实例属性装饰器
|
|
90
|
+
// target可能是构造函数或者类的原型
|
|
91
|
+
// 如果target是构造函数,targetKey是undefined,index是参数的位置下标
|
|
92
|
+
// 如果target是原型,targetKey是属姓名,index是undefined
|
|
66
93
|
return function (target, targetKey, index) {
|
|
67
|
-
|
|
68
|
-
var
|
|
69
|
-
|
|
70
|
-
var
|
|
94
|
+
// 如果index是number,那么代表是构造函数的参数的装饰器
|
|
95
|
+
var isParameterDecorator = typeof index === 'number'; // 统一把装饰器数据绑定到构造函数上,后续获取数据比较方便
|
|
96
|
+
|
|
97
|
+
var Ctor = isParameterDecorator ? target : target.constructor; // 如果是构造函数的参数装饰器,取参数位置下标,否则取实例属性的属性名
|
|
98
|
+
|
|
99
|
+
var key = isParameterDecorator ? index : targetKey; // 区分构造函数的参数装饰器和实例属性的装饰器
|
|
100
|
+
// 分别记录到全局Map的不同位置,metadataKey不一样
|
|
101
|
+
|
|
102
|
+
var metadataKey = isParameterDecorator ? DECORATOR_KEYS.SERVICE_INJECTED_PARAMS : DECORATOR_KEYS.SERVICE_INJECTED_PROPS; // 这里是一个大对象,对应的key是metadataKey
|
|
103
|
+
// 所以全局Map中有两个不同的metadataKey,以及对应的数据对象
|
|
104
|
+
// 如果是构造函数参数装饰器,这个对象中的key是参数位置下标
|
|
105
|
+
// 如果是实例属性装饰器,这个对象中的key是属性名
|
|
106
|
+
|
|
71
107
|
var paramsOrPropertiesMetadata = Reflect.getMetadata(metadataKey, Ctor) || {}; // 每个参数或者实例属性都可以有多个装饰器
|
|
108
|
+
// 所以paramsOrPropertiesMetadata这个大对象的每个key对应的value都是一个数组
|
|
109
|
+
// 该数组中的每一个元素是一个对象,保存着每一个装饰器的数据
|
|
72
110
|
|
|
73
111
|
var paramOrPropertyMetadata = paramsOrPropertiesMetadata[key] || [];
|
|
74
112
|
var metadata = {
|
|
113
|
+
// 装饰器的名称
|
|
75
114
|
key: decoratorKey,
|
|
76
|
-
|
|
115
|
+
// 装饰器的值,即装饰器函数的实参
|
|
116
|
+
// 很多装饰器具有默认值,可以不提供实参,而是使用默认值
|
|
117
|
+
value: decoratorValue === void 0 ? defaultValue : decoratorValue
|
|
77
118
|
};
|
|
78
119
|
|
|
79
|
-
if (
|
|
80
|
-
if (
|
|
81
|
-
|
|
120
|
+
if (!isParameterDecorator) {
|
|
121
|
+
if (decoratorKey === DECORATOR_KEYS.INJECT) {
|
|
122
|
+
if (decoratorValue === void 0) {
|
|
123
|
+
// 是实例属性装饰器,且是Inject装饰器,且没有指定参数
|
|
124
|
+
// 需要获取默认的类型数据
|
|
125
|
+
metadata.value = Reflect.getMetadata(DECORATOR_KEYS.DESIGN_PROPERTY_TYPE, target, targetKey);
|
|
126
|
+
}
|
|
82
127
|
}
|
|
83
|
-
}
|
|
128
|
+
} // 把当前装饰器的数据对象放到数组中
|
|
129
|
+
|
|
130
|
+
|
|
131
|
+
paramOrPropertyMetadata.push(metadata); // 关联这个数组和对应的key
|
|
132
|
+
|
|
133
|
+
paramsOrPropertiesMetadata[key] = paramOrPropertyMetadata; // 再把整个大对象放到全局Map中
|
|
84
134
|
|
|
85
|
-
paramOrPropertyMetadata.push(metadata);
|
|
86
|
-
paramsOrPropertiesMetadata[key] = paramOrPropertyMetadata;
|
|
87
135
|
Reflect.defineMetadata(metadataKey, paramsOrPropertiesMetadata, Ctor);
|
|
88
136
|
};
|
|
89
137
|
};
|
|
90
138
|
} // 可以使用在类构造函数的参数中和类的实例属性中
|
|
91
139
|
|
|
92
140
|
|
|
93
|
-
var Inject =
|
|
141
|
+
var Inject = createDecorator(DECORATOR_KEYS.INJECT); // 指定只在当前injector中寻找服务
|
|
94
142
|
|
|
95
|
-
var Self =
|
|
143
|
+
var Self = createDecorator(DECORATOR_KEYS.SELF, true); // 指定跳过当前injector寻找服务
|
|
96
144
|
|
|
97
|
-
var Skip =
|
|
145
|
+
var Skip = createDecorator(DECORATOR_KEYS.SKIP_SELF, true); // 指定服务是可选的,找不到服务时返回undefined,否则抛出异常
|
|
146
|
+
// 其实应该说是默认情况下找不到服务时,会抛出异常,除非明确指定是optional的
|
|
98
147
|
|
|
99
|
-
var Optional =
|
|
148
|
+
var Optional = createDecorator(DECORATOR_KEYS.OPTIONAL, true);
|
|
100
149
|
/**
|
|
101
150
|
* 表明服务可注入
|
|
102
151
|
* 主要工作就是收集构造函数的参数类型信息
|
|
@@ -107,15 +156,15 @@ var Optional = createPropertyDecorator(DECORATOR_KEYS.OPTIONAL, true);
|
|
|
107
156
|
|
|
108
157
|
function Injectable() {
|
|
109
158
|
return function (target) {
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
var types = Reflect.getMetadata(DESIGN_PARAM_TYPES, target) || []; // 存储构造函数的类型信息
|
|
159
|
+
// 标记这个类可以注入
|
|
160
|
+
Reflect.defineMetadata(DECORATOR_KEYS.INJECTABLE, true, target); // 获取ts编译器默认的类型数据
|
|
161
|
+
// 经过测试,如果是基本类型string、number、boolean,那么会变成相对应的构造函数String,Number,Boolean
|
|
162
|
+
// 如果只是指定了interface类型,那么会变成Object构造函数
|
|
115
163
|
|
|
116
|
-
Reflect.
|
|
164
|
+
var types = Reflect.getMetadata(DECORATOR_KEYS.DESIGN_PARAM_TYPES, target) || []; // 存储构造函数的类型信息
|
|
165
|
+
// 这里只是转存了一下数据,并没有特殊逻辑
|
|
117
166
|
|
|
118
|
-
Reflect.defineMetadata(DECORATOR_KEYS.
|
|
167
|
+
Reflect.defineMetadata(DECORATOR_KEYS.SERVICE_PARAM_TYPES, types, target);
|
|
119
168
|
return target;
|
|
120
169
|
};
|
|
121
170
|
}
|
|
@@ -147,6 +196,122 @@ function resolveForwardRef(type) {
|
|
|
147
196
|
return isForwardRef(type) ? type() : type;
|
|
148
197
|
}
|
|
149
198
|
|
|
199
|
+
var CircularDependencyError = /*#__PURE__*/function (_Error) {
|
|
200
|
+
_inherits(CircularDependencyError, _Error);
|
|
201
|
+
|
|
202
|
+
var _super = _createSuper(CircularDependencyError);
|
|
203
|
+
|
|
204
|
+
function CircularDependencyError(provider, options) {
|
|
205
|
+
var _this;
|
|
206
|
+
|
|
207
|
+
_classCallCheck(this, CircularDependencyError);
|
|
208
|
+
|
|
209
|
+
_this = _super.call(this);
|
|
210
|
+
|
|
211
|
+
_defineProperty(_assertThisInitialized(_this), "name", 'CIRCULAR_DEPENDENCY_ERROR');
|
|
212
|
+
|
|
213
|
+
_defineProperty(_assertThisInitialized(_this), "message", _this.name);
|
|
214
|
+
|
|
215
|
+
var tokenArr = [provider.provide];
|
|
216
|
+
var currentProvider = options === null || options === void 0 ? void 0 : options.provider;
|
|
217
|
+
|
|
218
|
+
while (currentProvider && currentProvider.provide) {
|
|
219
|
+
tokenArr.push(currentProvider.provide);
|
|
220
|
+
currentProvider = currentProvider.parent;
|
|
221
|
+
}
|
|
222
|
+
|
|
223
|
+
var tokenListText = tokenArr.join(' <-- ');
|
|
224
|
+
_this.message = "CIRCULAR DEPENDENCY DETECTED. PLEASE FIX IT MANUALLY. ".concat(tokenListText);
|
|
225
|
+
return _this;
|
|
226
|
+
}
|
|
227
|
+
|
|
228
|
+
return CircularDependencyError;
|
|
229
|
+
}( /*#__PURE__*/_wrapNativeSuper(Error));
|
|
230
|
+
|
|
231
|
+
var InjectFailedError = /*#__PURE__*/function (_Error2) {
|
|
232
|
+
_inherits(InjectFailedError, _Error2);
|
|
233
|
+
|
|
234
|
+
var _super2 = _createSuper(InjectFailedError);
|
|
235
|
+
|
|
236
|
+
function InjectFailedError(injectMeta, ClassName, key, paramType) {
|
|
237
|
+
var _this2;
|
|
238
|
+
|
|
239
|
+
_classCallCheck(this, InjectFailedError);
|
|
240
|
+
|
|
241
|
+
_this2 = _super2.call(this);
|
|
242
|
+
|
|
243
|
+
_defineProperty(_assertThisInitialized(_this2), "name", 'INJECT_FAILED_ERROR');
|
|
244
|
+
|
|
245
|
+
_defineProperty(_assertThisInitialized(_this2), "message", _this2.name);
|
|
246
|
+
|
|
247
|
+
if (paramType) {
|
|
248
|
+
// 是构造函数的参数装饰器
|
|
249
|
+
if (injectMeta && injectMeta.value === Object) {
|
|
250
|
+
_this2.message = "CAN NOT USE OBJECT AS INJECTION TOKEN. PARAMETER ".concat(key, " OF CLASS ").concat(ClassName, ".");
|
|
251
|
+
} else if (paramType === Object) {
|
|
252
|
+
_this2.message = "CONSTRUCTOR PARAMETER TYPE IS OBJECT OR INTERFACE, MUST USE @INJECT TO SPECIFY INJECTION TOKEN. PARAMETER ".concat(key, " OF CLASS ").concat(ClassName, ".");
|
|
253
|
+
}
|
|
254
|
+
} else {
|
|
255
|
+
// 是属性装饰器
|
|
256
|
+
if (!injectMeta) {
|
|
257
|
+
_this2.message = "INJECT PROPERTY REQUIRE @INJECT() DECORATOR. PROPERTY ".concat(key, " OF CLASS ").concat(ClassName, ".");
|
|
258
|
+
} else if (injectMeta.value === Object) {
|
|
259
|
+
_this2.message = "CAN NOT USE OBJECT AS INJECTION TOKEN. PROPERTY ".concat(key, " OF CLASS ").concat(ClassName, ".");
|
|
260
|
+
}
|
|
261
|
+
}
|
|
262
|
+
|
|
263
|
+
return _this2;
|
|
264
|
+
}
|
|
265
|
+
|
|
266
|
+
return InjectFailedError;
|
|
267
|
+
}( /*#__PURE__*/_wrapNativeSuper(Error));
|
|
268
|
+
|
|
269
|
+
var ProviderNotValidError = /*#__PURE__*/function (_Error3) {
|
|
270
|
+
_inherits(ProviderNotValidError, _Error3);
|
|
271
|
+
|
|
272
|
+
var _super3 = _createSuper(ProviderNotValidError);
|
|
273
|
+
|
|
274
|
+
function ProviderNotValidError(provider) {
|
|
275
|
+
var _this3;
|
|
276
|
+
|
|
277
|
+
_classCallCheck(this, ProviderNotValidError);
|
|
278
|
+
|
|
279
|
+
_this3 = _super3.call(this);
|
|
280
|
+
|
|
281
|
+
_defineProperty(_assertThisInitialized(_this3), "name", 'PROVIDER_NOT_VALID_ERROR');
|
|
282
|
+
|
|
283
|
+
_defineProperty(_assertThisInitialized(_this3), "message", _this3.name);
|
|
284
|
+
|
|
285
|
+
_this3.message = "PROVIDER NOT VALID. ".concat(provider);
|
|
286
|
+
return _this3;
|
|
287
|
+
}
|
|
288
|
+
|
|
289
|
+
return ProviderNotValidError;
|
|
290
|
+
}( /*#__PURE__*/_wrapNativeSuper(Error));
|
|
291
|
+
|
|
292
|
+
var TokenNotFoundError = /*#__PURE__*/function (_Error4) {
|
|
293
|
+
_inherits(TokenNotFoundError, _Error4);
|
|
294
|
+
|
|
295
|
+
var _super4 = _createSuper(TokenNotFoundError);
|
|
296
|
+
|
|
297
|
+
function TokenNotFoundError(token) {
|
|
298
|
+
var _this4;
|
|
299
|
+
|
|
300
|
+
_classCallCheck(this, TokenNotFoundError);
|
|
301
|
+
|
|
302
|
+
_this4 = _super4.call(this);
|
|
303
|
+
|
|
304
|
+
_defineProperty(_assertThisInitialized(_this4), "name", 'TOKEN_NOT_FOUND_ERROR');
|
|
305
|
+
|
|
306
|
+
_defineProperty(_assertThisInitialized(_this4), "message", _this4.name);
|
|
307
|
+
|
|
308
|
+
_this4.message = "TOKEN IS NOT A INJECTABLE CLASS OR SKIP OUT OF ROOT INJECTOR. YOU CAN USE @Optional DECORATOR TO IGNORE THIS ERROR IF THIS SERVICE IS OPTIONAL. ".concat(token);
|
|
309
|
+
return _this4;
|
|
310
|
+
}
|
|
311
|
+
|
|
312
|
+
return TokenNotFoundError;
|
|
313
|
+
}( /*#__PURE__*/_wrapNativeSuper(Error));
|
|
314
|
+
|
|
150
315
|
var NOOP = function NOOP(n) {
|
|
151
316
|
return n;
|
|
152
317
|
}; // 第一步:准备构造函数的依赖对象
|
|
@@ -163,24 +328,21 @@ var Injector = /*#__PURE__*/function () {
|
|
|
163
328
|
|
|
164
329
|
_classCallCheck(this, Injector);
|
|
165
330
|
|
|
166
|
-
_defineProperty(this, "providerMap", new Map());
|
|
167
|
-
|
|
168
|
-
_defineProperty(this, "parentToken", null);
|
|
169
|
-
|
|
170
331
|
_defineProperty(this, "parent", void 0);
|
|
171
332
|
|
|
172
|
-
_defineProperty(this, "
|
|
333
|
+
_defineProperty(this, "providerMap", new Map());
|
|
334
|
+
|
|
335
|
+
_defineProperty(this, "beforeCacheHook", void 0);
|
|
173
336
|
|
|
174
|
-
_defineProperty(this, "
|
|
337
|
+
_defineProperty(this, "mergePropertyHook", void 0);
|
|
175
338
|
|
|
176
|
-
|
|
339
|
+
// 引用父级Injector
|
|
340
|
+
this.parent = parent; // 在把服务实例放到缓存中之前,可以调用这个钩子让服务响应化
|
|
177
341
|
|
|
178
|
-
this.
|
|
179
|
-
this.options = options; // 在获取服务实例之后,在更新provider.useValue之前,使服务响应化
|
|
342
|
+
this.beforeCacheHook = options.beforeCacheHook || NOOP; // 在注入实例属性时,需要把属性merge到服务实例对象上,合并过程需要保持响应式
|
|
180
343
|
|
|
181
|
-
this.
|
|
182
|
-
this.
|
|
183
|
-
this.resolveProviders(providers);
|
|
344
|
+
this.mergePropertyHook = options.mergePropertyHook || merge;
|
|
345
|
+
this.addProviders(providers);
|
|
184
346
|
}
|
|
185
347
|
|
|
186
348
|
_createClass(Injector, [{
|
|
@@ -188,102 +350,242 @@ var Injector = /*#__PURE__*/function () {
|
|
|
188
350
|
value: function get(token) {
|
|
189
351
|
var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
|
|
190
352
|
|
|
191
|
-
if (options.
|
|
353
|
+
if (options.skip) {
|
|
354
|
+
if (this.parent) {
|
|
355
|
+
return this.parent.get(token, _objectSpread(_objectSpread({}, options), {}, {
|
|
356
|
+
skip: false
|
|
357
|
+
}));
|
|
358
|
+
} else {
|
|
359
|
+
if (!options.optional) {
|
|
360
|
+
throw new TokenNotFoundError(token);
|
|
361
|
+
}
|
|
362
|
+
}
|
|
363
|
+
} else if (options.self) {
|
|
192
364
|
if (this.providerMap.has(token)) {
|
|
193
365
|
var provider = this.providerMap.get(token);
|
|
194
366
|
|
|
195
367
|
if (provider.status === SERVICE_STATUS.INITING) {
|
|
196
|
-
throw new
|
|
368
|
+
throw new CircularDependencyError(provider, options);
|
|
197
369
|
}
|
|
198
370
|
|
|
199
371
|
return this.getServiceByProvider(provider, options);
|
|
200
372
|
} else if (!this.parent && typeof token === 'function' && Reflect.getMetadata(DECORATOR_KEYS.INJECTABLE, token)) {
|
|
201
373
|
// 如果当前Injector已经是根Injector
|
|
202
374
|
// 就必须要考虑self的限制
|
|
203
|
-
|
|
204
|
-
} else {
|
|
205
|
-
if (DECORATOR_KEYS.OPTIONAL in options || DECORATOR_KEYS.DEFAULT_VALUE in options) {
|
|
206
|
-
return options.defaultValue;
|
|
207
|
-
} else {
|
|
208
|
-
throw new Error("".concat(token, " ").concat(ERROR_TOKEN_NOT_FOUND));
|
|
209
|
-
}
|
|
210
|
-
}
|
|
211
|
-
} else if (options.skip) {
|
|
212
|
-
options.skip = false;
|
|
375
|
+
var _provider = this.getProviderByToken(token);
|
|
213
376
|
|
|
214
|
-
|
|
215
|
-
return this.parent.get(token, options);
|
|
377
|
+
return this.getServiceByProvider(_provider, options);
|
|
216
378
|
} else {
|
|
217
|
-
if (
|
|
218
|
-
|
|
219
|
-
} else {
|
|
220
|
-
throw new Error("".concat(token, " ").concat(ERROR_TOKEN_NOT_FOUND));
|
|
379
|
+
if (!options.optional) {
|
|
380
|
+
throw new TokenNotFoundError(token);
|
|
221
381
|
}
|
|
222
382
|
}
|
|
223
383
|
} else if (this.providerMap.has(token)) {
|
|
224
|
-
var
|
|
384
|
+
var _provider2 = this.providerMap.get(token);
|
|
225
385
|
|
|
226
|
-
if (
|
|
227
|
-
throw new
|
|
386
|
+
if (_provider2.status === SERVICE_STATUS.INITING) {
|
|
387
|
+
throw new CircularDependencyError(_provider2, options);
|
|
228
388
|
}
|
|
229
389
|
|
|
230
|
-
return this.getServiceByProvider(
|
|
390
|
+
return this.getServiceByProvider(_provider2, options);
|
|
231
391
|
} else if (this.parent) {
|
|
232
392
|
return this.parent.get(token, options);
|
|
233
393
|
} else if (typeof token === 'function' && Reflect.getMetadata(DECORATOR_KEYS.INJECTABLE, token)) {
|
|
234
|
-
|
|
394
|
+
var _provider3 = this.getProviderByToken(token);
|
|
395
|
+
|
|
396
|
+
return this.getServiceByProvider(_provider3, options);
|
|
235
397
|
} else {
|
|
236
|
-
if (
|
|
237
|
-
|
|
238
|
-
} else {
|
|
239
|
-
throw new Error("".concat(token, " ").concat(ERROR_TOKEN_NOT_FOUND));
|
|
398
|
+
if (!options.optional) {
|
|
399
|
+
throw new TokenNotFoundError(token);
|
|
240
400
|
}
|
|
241
401
|
}
|
|
242
402
|
}
|
|
403
|
+
/**
|
|
404
|
+
* 如果token对应的provider不存在
|
|
405
|
+
* 那么就创建一个
|
|
406
|
+
* 调用该方法之前需要保证token对应的provider已经存在或者token本身是一个可注入的类
|
|
407
|
+
*
|
|
408
|
+
* @param {*} token
|
|
409
|
+
* @return {*}
|
|
410
|
+
* @memberof Injector
|
|
411
|
+
*/
|
|
412
|
+
|
|
413
|
+
}, {
|
|
414
|
+
key: "getProviderByToken",
|
|
415
|
+
value: function getProviderByToken(token) {
|
|
416
|
+
if (!this.providerMap.has(token)) {
|
|
417
|
+
this.addProvider(token);
|
|
418
|
+
}
|
|
419
|
+
|
|
420
|
+
return this.providerMap.get(token);
|
|
421
|
+
}
|
|
422
|
+
/**
|
|
423
|
+
* 通过provider直接获取service实例
|
|
424
|
+
* @done
|
|
425
|
+
* @param {*} provider
|
|
426
|
+
* @param {*} options
|
|
427
|
+
* @return {*}
|
|
428
|
+
* @memberof Injector
|
|
429
|
+
*/
|
|
430
|
+
|
|
431
|
+
}, {
|
|
432
|
+
key: "getServiceByProvider",
|
|
433
|
+
value: function getServiceByProvider(provider, options) {
|
|
434
|
+
if ('useCacheValue' in provider) {
|
|
435
|
+
return provider.useCacheValue;
|
|
436
|
+
} else if ('useValue' in provider) {
|
|
437
|
+
return this.getServiceUseValueWithProvider(provider, options);
|
|
438
|
+
} else if (provider.useClass) {
|
|
439
|
+
return this.getServiceUseClassWithProvider(provider, options);
|
|
440
|
+
} else if (provider.useExisting) {
|
|
441
|
+
return this.getServiceUseExistingWithProvider(provider, options);
|
|
442
|
+
} else if (provider.useFactory) {
|
|
443
|
+
return this.getServiceUseFactoryWithProvider(provider, options);
|
|
444
|
+
} else {
|
|
445
|
+
throw new ProviderNotValidError(provider);
|
|
446
|
+
}
|
|
447
|
+
}
|
|
448
|
+
/**
|
|
449
|
+
* 通过useValue获取服务实例
|
|
450
|
+
*
|
|
451
|
+
* @param {*} provider
|
|
452
|
+
* @return {*}
|
|
453
|
+
* @memberof Injector
|
|
454
|
+
*/
|
|
455
|
+
|
|
456
|
+
}, {
|
|
457
|
+
key: "getServiceUseValueWithProvider",
|
|
458
|
+
value: function getServiceUseValueWithProvider(provider, options) {
|
|
459
|
+
var cacheValue = this.beforeCacheHook(provider.useValue);
|
|
460
|
+
provider.useCacheValue = cacheValue;
|
|
461
|
+
return cacheValue;
|
|
462
|
+
}
|
|
463
|
+
/**
|
|
464
|
+
* 通过useClass获取服务实例
|
|
465
|
+
* @done
|
|
466
|
+
* @template T
|
|
467
|
+
* @param {new (...args: any[]) => T} ClassName
|
|
468
|
+
* @param {*} options
|
|
469
|
+
* @return {*}
|
|
470
|
+
* @memberof Injector
|
|
471
|
+
*/
|
|
472
|
+
|
|
473
|
+
}, {
|
|
474
|
+
key: "getServiceUseClassWithProvider",
|
|
475
|
+
value: function getServiceUseClassWithProvider(provider, options) {
|
|
476
|
+
provider.parent = options.provider;
|
|
477
|
+
provider.status = SERVICE_STATUS.INITING;
|
|
478
|
+
var ClassName = provider.useClass;
|
|
479
|
+
var params = this.getContructorParameters(ClassName, provider);
|
|
480
|
+
var cacheValue = this.beforeCacheHook(_construct(ClassName, _toConsumableArray(params)));
|
|
481
|
+
provider.useCacheValue = cacheValue;
|
|
482
|
+
provider.status = SERVICE_STATUS.CONSTRUCTED;
|
|
483
|
+
var properties = this.getInjectProperties(ClassName, provider);
|
|
484
|
+
this.mergePropertyHook(cacheValue, properties);
|
|
485
|
+
provider.status = SERVICE_STATUS.MERGED;
|
|
486
|
+
provider.parent = void 0;
|
|
487
|
+
return cacheValue;
|
|
488
|
+
}
|
|
489
|
+
/**
|
|
490
|
+
* 通过useExisting获取服务实例
|
|
491
|
+
*
|
|
492
|
+
* @param {*} provider
|
|
493
|
+
* @param {*} options
|
|
494
|
+
* @return {*}
|
|
495
|
+
* @memberof Injector
|
|
496
|
+
*/
|
|
497
|
+
|
|
498
|
+
}, {
|
|
499
|
+
key: "getServiceUseExistingWithProvider",
|
|
500
|
+
value: function getServiceUseExistingWithProvider(provider, options) {
|
|
501
|
+
provider.parent = options.provider;
|
|
502
|
+
provider.status = SERVICE_STATUS.INITING;
|
|
503
|
+
var cacheValue = this.get(provider.useExisting, _objectSpread(_objectSpread({}, options), {}, {
|
|
504
|
+
provider: provider
|
|
505
|
+
}));
|
|
506
|
+
provider.useCacheValue = cacheValue;
|
|
507
|
+
provider.status = SERVICE_STATUS.CONSTRUCTED;
|
|
508
|
+
provider.parent = void 0;
|
|
509
|
+
return cacheValue;
|
|
510
|
+
}
|
|
511
|
+
/**
|
|
512
|
+
* 通过useFactory获取服务实例
|
|
513
|
+
*
|
|
514
|
+
* @param {*} provider
|
|
515
|
+
* @param {*} options
|
|
516
|
+
* @return {*}
|
|
517
|
+
* @memberof Injector
|
|
518
|
+
*/
|
|
519
|
+
|
|
520
|
+
}, {
|
|
521
|
+
key: "getServiceUseFactoryWithProvider",
|
|
522
|
+
value: function getServiceUseFactoryWithProvider(provider, options) {
|
|
523
|
+
var _this5 = this;
|
|
524
|
+
|
|
525
|
+
provider.parent = options.provider;
|
|
526
|
+
provider.status = SERVICE_STATUS.INITING;
|
|
527
|
+
var deps = provider.deps || [];
|
|
528
|
+
var args = deps.map(function (dep) {
|
|
529
|
+
return _this5.get(dep, {
|
|
530
|
+
provider: provider
|
|
531
|
+
});
|
|
532
|
+
});
|
|
533
|
+
var serviceValue = provider.useFactory.apply(provider, _toConsumableArray(args));
|
|
534
|
+
var cacheValue = this.beforeCacheHook(serviceValue);
|
|
535
|
+
provider.useCacheValue = cacheValue;
|
|
536
|
+
provider.status = SERVICE_STATUS.CONSTRUCTED;
|
|
537
|
+
provider.parent = void 0;
|
|
538
|
+
return cacheValue;
|
|
539
|
+
}
|
|
243
540
|
/**
|
|
244
541
|
* 获取构造函数的参数-返回数组
|
|
245
542
|
* @done
|
|
246
|
-
* @param {*}
|
|
543
|
+
* @param {*} ClassName
|
|
247
544
|
* @return {*}
|
|
248
545
|
* @memberof Injector
|
|
249
546
|
*/
|
|
250
547
|
|
|
251
548
|
}, {
|
|
252
549
|
key: "getContructorParameters",
|
|
253
|
-
value: function getContructorParameters(
|
|
254
|
-
var
|
|
550
|
+
value: function getContructorParameters(ClassName, provider) {
|
|
551
|
+
var _this6 = this;
|
|
255
552
|
|
|
256
|
-
var
|
|
257
|
-
this.parentToken = token;
|
|
258
|
-
var params = this.getContructorParametersMetas(token);
|
|
553
|
+
var params = this.getContructorParametersMetas(ClassName);
|
|
259
554
|
var result = params.map(function (meta) {
|
|
260
|
-
return
|
|
555
|
+
return _this6.get(meta.key, _objectSpread(_objectSpread({}, meta.value), {}, {
|
|
556
|
+
provider: provider
|
|
557
|
+
}));
|
|
261
558
|
});
|
|
262
|
-
this.parentToken = currentParentToken;
|
|
263
559
|
return result;
|
|
264
560
|
}
|
|
265
561
|
/**
|
|
266
562
|
* 获取构造函数的参数的装饰器元数据
|
|
267
563
|
* @done
|
|
268
|
-
* @param {*}
|
|
564
|
+
* @param {*} ClassName
|
|
269
565
|
* @return {*}
|
|
270
566
|
* @memberof Injector
|
|
271
567
|
*/
|
|
272
568
|
|
|
273
569
|
}, {
|
|
274
570
|
key: "getContructorParametersMetas",
|
|
275
|
-
value: function getContructorParametersMetas(
|
|
571
|
+
value: function getContructorParametersMetas(ClassName) {
|
|
276
572
|
// 构造函数的参数的类型数据-原始数据-是一个数组
|
|
277
|
-
var params = Reflect.getMetadata(SERVICE_PARAM_TYPES,
|
|
573
|
+
var params = Reflect.getMetadata(DECORATOR_KEYS.SERVICE_PARAM_TYPES, ClassName) || []; // 构造函数的参数的类型数据-通过@Inject等装饰器实现-是一个对象-key是数字-对应第几个参数的类型数据
|
|
278
574
|
|
|
279
|
-
var propertiesMetadatas = Reflect.getMetadata(SERVICE_INJECTED_PARAMS,
|
|
575
|
+
var propertiesMetadatas = Reflect.getMetadata(DECORATOR_KEYS.SERVICE_INJECTED_PARAMS, ClassName) || {};
|
|
280
576
|
return params.map(function (paramType, index) {
|
|
281
577
|
// 查找当前index对应的参数有没有使用装饰器
|
|
282
|
-
var propertyMetadatas = propertiesMetadatas[index] || []; // 查找装饰器列表中有没有@Inject
|
|
578
|
+
var propertyMetadatas = propertiesMetadatas[index] || []; // 查找装饰器列表中有没有@Inject装饰器的数据
|
|
283
579
|
|
|
284
|
-
var
|
|
580
|
+
var injectMeta = propertyMetadatas.find(function (meta) {
|
|
285
581
|
return meta.key === DECORATOR_KEYS.INJECT;
|
|
286
|
-
});
|
|
582
|
+
});
|
|
583
|
+
|
|
584
|
+
if (injectMeta && injectMeta.value === Object || !injectMeta && paramType === Object) {
|
|
585
|
+
// 构造函数的参数可以不使用@Inject,但是一定不能是interface
|
|
586
|
+
throw new InjectFailedError(injectMeta, ClassName, index, paramType);
|
|
587
|
+
} // 把装饰器列表收集为对象,并且排除掉@Inject
|
|
588
|
+
|
|
287
589
|
|
|
288
590
|
var options = propertyMetadatas.reduce(function (acc, meta) {
|
|
289
591
|
if (meta.key !== DECORATOR_KEYS.INJECT) {
|
|
@@ -293,7 +595,7 @@ var Injector = /*#__PURE__*/function () {
|
|
|
293
595
|
return acc;
|
|
294
596
|
}, {});
|
|
295
597
|
return {
|
|
296
|
-
key: resolveForwardRef(
|
|
598
|
+
key: resolveForwardRef(injectMeta && injectMeta.value) || paramType,
|
|
297
599
|
value: options
|
|
298
600
|
};
|
|
299
601
|
});
|
|
@@ -301,59 +603,58 @@ var Injector = /*#__PURE__*/function () {
|
|
|
301
603
|
/**
|
|
302
604
|
* 获取注入的实例属性-返回对象
|
|
303
605
|
* @done
|
|
304
|
-
* @param {*}
|
|
606
|
+
* @param {*} ClassName
|
|
305
607
|
* @return {*}
|
|
306
608
|
* @memberof Injector
|
|
307
609
|
*/
|
|
308
610
|
|
|
309
611
|
}, {
|
|
310
612
|
key: "getInjectProperties",
|
|
311
|
-
value: function getInjectProperties(
|
|
312
|
-
var
|
|
613
|
+
value: function getInjectProperties(ClassName, provider) {
|
|
614
|
+
var _this7 = this;
|
|
313
615
|
|
|
314
|
-
var
|
|
315
|
-
this.parentToken = token;
|
|
316
|
-
var metas = this.getInjectPropertiesMetas(token);
|
|
616
|
+
var metas = this.getInjectPropertiesMetas(ClassName);
|
|
317
617
|
var properties = {};
|
|
318
618
|
metas.forEach(function (meta) {
|
|
319
619
|
var _meta$value;
|
|
320
620
|
|
|
321
|
-
var property =
|
|
621
|
+
var property = _this7.get(meta.provide, _objectSpread(_objectSpread({}, meta.value), {}, {
|
|
622
|
+
provider: provider
|
|
623
|
+
}));
|
|
322
624
|
|
|
323
|
-
if (!(property ===
|
|
324
|
-
properties[meta.key] =
|
|
625
|
+
if (!(property === void 0 && (_meta$value = meta.value) !== null && _meta$value !== void 0 && _meta$value.optional)) {
|
|
626
|
+
properties[meta.key] = property;
|
|
325
627
|
}
|
|
326
628
|
});
|
|
327
|
-
this.parentToken = currentParentToken;
|
|
328
629
|
return properties;
|
|
329
630
|
}
|
|
330
631
|
/**
|
|
331
632
|
* 获取注入属性的装饰器数据
|
|
332
633
|
* @done
|
|
333
|
-
* @param {*}
|
|
634
|
+
* @param {*} ClassName
|
|
334
635
|
* @return {*}
|
|
335
636
|
* @memberof Injector
|
|
336
637
|
*/
|
|
337
638
|
|
|
338
639
|
}, {
|
|
339
640
|
key: "getInjectPropertiesMetas",
|
|
340
|
-
value: function getInjectPropertiesMetas(
|
|
641
|
+
value: function getInjectPropertiesMetas(ClassName) {
|
|
341
642
|
// 获取注入属性的metas-类型是Recors<string, Array>
|
|
342
|
-
var propertiesMetadatas = Reflect.getMetadata(SERVICE_INJECTED_PROPS,
|
|
643
|
+
var propertiesMetadatas = Reflect.getMetadata(DECORATOR_KEYS.SERVICE_INJECTED_PROPS, ClassName) || {};
|
|
343
644
|
var propertiesMetas = [];
|
|
344
645
|
|
|
345
646
|
for (var key in propertiesMetadatas) {
|
|
346
647
|
if (has(propertiesMetadatas, key)) {
|
|
347
648
|
// 当前key属性对应的所有的装饰器
|
|
348
|
-
var propertyMetadatas = propertiesMetadatas[key] || []; // 当前key属性对应的@Inject
|
|
649
|
+
var propertyMetadatas = propertiesMetadatas[key] || []; // 当前key属性对应的@Inject装饰器的数据
|
|
349
650
|
|
|
350
|
-
var
|
|
651
|
+
var injectMeta = propertyMetadatas.find(function (meta) {
|
|
351
652
|
return meta.key === DECORATOR_KEYS.INJECT;
|
|
352
653
|
});
|
|
353
654
|
|
|
354
|
-
if (!
|
|
655
|
+
if (!injectMeta || injectMeta.value === Object) {
|
|
355
656
|
// 属性一定要手动指定@Inject
|
|
356
|
-
throw new
|
|
657
|
+
throw new InjectFailedError(injectMeta, ClassName, key);
|
|
357
658
|
}
|
|
358
659
|
|
|
359
660
|
var options = propertyMetadatas.reduce(function (acc, meta) {
|
|
@@ -365,7 +666,7 @@ var Injector = /*#__PURE__*/function () {
|
|
|
365
666
|
}, {});
|
|
366
667
|
propertiesMetas.push({
|
|
367
668
|
key: key,
|
|
368
|
-
provide: resolveForwardRef(
|
|
669
|
+
provide: resolveForwardRef(injectMeta.value),
|
|
369
670
|
value: options
|
|
370
671
|
});
|
|
371
672
|
}
|
|
@@ -373,84 +674,6 @@ var Injector = /*#__PURE__*/function () {
|
|
|
373
674
|
|
|
374
675
|
return propertiesMetas;
|
|
375
676
|
}
|
|
376
|
-
/**
|
|
377
|
-
* 通过provider直接获取service实例
|
|
378
|
-
* @done
|
|
379
|
-
* @param {*} provider
|
|
380
|
-
* @param {*} options
|
|
381
|
-
* @return {*}
|
|
382
|
-
* @memberof Injector
|
|
383
|
-
*/
|
|
384
|
-
|
|
385
|
-
}, {
|
|
386
|
-
key: "getServiceByProvider",
|
|
387
|
-
value: function getServiceByProvider(provider, options) {
|
|
388
|
-
var _this3 = this;
|
|
389
|
-
|
|
390
|
-
if ('useValue' in provider) {
|
|
391
|
-
return provider.useValue;
|
|
392
|
-
} else if (provider.useClass) {
|
|
393
|
-
var serviceValue = this.getServiceByClass(provider.useClass, provider.provide);
|
|
394
|
-
provider.useValue = this.postHook(serviceValue);
|
|
395
|
-
return provider.useValue;
|
|
396
|
-
} else if (provider.useExisting) {
|
|
397
|
-
var _serviceValue = this.get(provider.useExisting, options);
|
|
398
|
-
|
|
399
|
-
provider.useValue = this.postHook(_serviceValue);
|
|
400
|
-
return provider.useValue;
|
|
401
|
-
} else if (provider.useFactory) {
|
|
402
|
-
var deps = provider.deps || [];
|
|
403
|
-
var args = deps.map(function (dep) {
|
|
404
|
-
return _this3.get(dep);
|
|
405
|
-
});
|
|
406
|
-
|
|
407
|
-
var _serviceValue2 = provider.useFactory.apply(provider, _toConsumableArray(args));
|
|
408
|
-
|
|
409
|
-
provider.useValue = this.postHook(_serviceValue2);
|
|
410
|
-
return provider.useValue;
|
|
411
|
-
} else {
|
|
412
|
-
throw new Error(ERROR_PROVIDER_NOT_VALID);
|
|
413
|
-
}
|
|
414
|
-
}
|
|
415
|
-
/**
|
|
416
|
-
* 通过类名获取服务实例
|
|
417
|
-
* @done
|
|
418
|
-
* @template T
|
|
419
|
-
* @param {new (...args: any[]) => T} ClassName
|
|
420
|
-
* @param {*} options
|
|
421
|
-
* @return {*}
|
|
422
|
-
* @memberof Injector
|
|
423
|
-
*/
|
|
424
|
-
|
|
425
|
-
}, {
|
|
426
|
-
key: "getServiceByClass",
|
|
427
|
-
value: function getServiceByClass(ClassName, provide) {
|
|
428
|
-
var provider = this.providerMap.get(provide);
|
|
429
|
-
|
|
430
|
-
if (!provider) {
|
|
431
|
-
this.addProvider({
|
|
432
|
-
provide: provide,
|
|
433
|
-
useClass: ClassName
|
|
434
|
-
});
|
|
435
|
-
provider = this.providerMap.get(provide);
|
|
436
|
-
}
|
|
437
|
-
|
|
438
|
-
provider.status = SERVICE_STATUS.INITING;
|
|
439
|
-
var params = this.getContructorParameters(ClassName);
|
|
440
|
-
var service = this.postHook(_construct(ClassName, _toConsumableArray(params)));
|
|
441
|
-
provider.useValue = service;
|
|
442
|
-
provider.status = SERVICE_STATUS.CONSTRUCTED;
|
|
443
|
-
var properties = this.getInjectProperties(ClassName);
|
|
444
|
-
this.mergeHook(service, properties);
|
|
445
|
-
provider.status = SERVICE_STATUS.MERGED;
|
|
446
|
-
|
|
447
|
-
if (service.onInit && typeof service.onInit === 'function') {
|
|
448
|
-
service.onInit();
|
|
449
|
-
}
|
|
450
|
-
|
|
451
|
-
provider.status = SERVICE_STATUS.INITED;
|
|
452
|
-
return service;
|
|
453
|
-
}
|
|
454
677
|
/**
|
|
455
678
|
* 把providers数组转换成map,避免后续的遍历
|
|
456
679
|
* @done
|
|
@@ -459,12 +682,12 @@ var Injector = /*#__PURE__*/function () {
|
|
|
459
682
|
*/
|
|
460
683
|
|
|
461
684
|
}, {
|
|
462
|
-
key: "
|
|
463
|
-
value: function
|
|
464
|
-
var
|
|
685
|
+
key: "addProviders",
|
|
686
|
+
value: function addProviders(providers) {
|
|
687
|
+
var _this8 = this;
|
|
465
688
|
|
|
466
689
|
providers.forEach(function (provider) {
|
|
467
|
-
|
|
690
|
+
_this8.addProvider(provider);
|
|
468
691
|
});
|
|
469
692
|
}
|
|
470
693
|
/**
|
|
@@ -478,10 +701,6 @@ var Injector = /*#__PURE__*/function () {
|
|
|
478
701
|
key: "addProvider",
|
|
479
702
|
value: function addProvider(provider) {
|
|
480
703
|
if (provider.provide) {
|
|
481
|
-
if ('useValue' in provider) {
|
|
482
|
-
provider.useValue = this.postHook(provider.useValue);
|
|
483
|
-
}
|
|
484
|
-
|
|
485
704
|
this.providerMap.set(provider.provide, provider);
|
|
486
705
|
} else {
|
|
487
706
|
this.providerMap.set(provider, {
|
|
@@ -500,8 +719,12 @@ var Injector = /*#__PURE__*/function () {
|
|
|
500
719
|
key: "dispose",
|
|
501
720
|
value: function dispose() {
|
|
502
721
|
this.providerMap.forEach(function (value) {
|
|
503
|
-
if (value && value.dispose) {
|
|
504
|
-
|
|
722
|
+
if (value && value.useCacheValue && value.useCacheValue.dispose) {
|
|
723
|
+
try {
|
|
724
|
+
value.useCacheValue.dispose();
|
|
725
|
+
} catch (error) {
|
|
726
|
+
console.error(error);
|
|
727
|
+
}
|
|
505
728
|
}
|
|
506
729
|
});
|
|
507
730
|
this.providerMap = null;
|
|
@@ -512,5 +735,5 @@ var Injector = /*#__PURE__*/function () {
|
|
|
512
735
|
return Injector;
|
|
513
736
|
}();
|
|
514
737
|
|
|
515
|
-
export {
|
|
738
|
+
export { CircularDependencyError, DECORATOR_KEYS, Inject, InjectFailedError, Injectable, Injector, Optional, ProviderNotValidError, SERVICE_STATUS, Self, Skip, TokenNotFoundError, createDecorator, forwardRef, has, isForwardRef, merge, resolveForwardRef };
|
|
516
739
|
//# sourceMappingURL=index.esm.runtime.js.map
|