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