@kaokei/di 1.0.21 → 1.0.25

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.
Files changed (42) hide show
  1. package/CHANGELOG.md +128 -0
  2. package/README.md +20 -103
  3. package/dist/index.cjs.js +450 -233
  4. package/dist/index.cjs.js.map +1 -1
  5. package/dist/index.cjs.min.js +3 -3
  6. package/dist/index.cjs.min.js.map +1 -1
  7. package/dist/index.cjs.runtime.js +444 -229
  8. package/dist/index.cjs.runtime.js.map +1 -1
  9. package/dist/index.cjs.runtime.min.js +3 -3
  10. package/dist/index.cjs.runtime.min.js.map +1 -1
  11. package/dist/index.esm.js +451 -219
  12. package/dist/index.esm.js.map +1 -1
  13. package/dist/index.esm.min.js +4 -4
  14. package/dist/index.esm.min.js.map +1 -1
  15. package/dist/index.esm.runtime.js +439 -214
  16. package/dist/index.esm.runtime.js.map +1 -1
  17. package/dist/index.esm.runtime.min.js +4 -4
  18. package/dist/index.esm.runtime.min.js.map +1 -1
  19. package/dist/index.iife.js +457 -237
  20. package/dist/index.iife.js.map +1 -1
  21. package/dist/index.iife.min.js +4 -4
  22. package/dist/index.iife.min.js.map +1 -1
  23. package/dist/src/Injector.d.ts +67 -32
  24. package/dist/src/Injector.d.ts.map +1 -1
  25. package/dist/src/constants.d.ts +5 -11
  26. package/dist/src/constants.d.ts.map +1 -1
  27. package/dist/src/decorator.d.ts +13 -1
  28. package/dist/src/decorator.d.ts.map +1 -1
  29. package/dist/src/errors/CircularDependencyError.d.ts +6 -0
  30. package/dist/src/errors/CircularDependencyError.d.ts.map +1 -0
  31. package/dist/src/errors/InjectFailedError.d.ts +6 -0
  32. package/dist/src/errors/InjectFailedError.d.ts.map +1 -0
  33. package/dist/src/errors/ProviderNotValidError.d.ts +6 -0
  34. package/dist/src/errors/ProviderNotValidError.d.ts.map +1 -0
  35. package/dist/src/errors/TokenNotFoundError.d.ts +6 -0
  36. package/dist/src/errors/TokenNotFoundError.d.ts.map +1 -0
  37. package/dist/src/errors/index.d.ts +5 -0
  38. package/dist/src/errors/index.d.ts.map +1 -0
  39. package/dist/src/index.d.ts +1 -1
  40. package/dist/src/index.d.ts.map +1 -1
  41. package/package.json +5 -7
  42. package/dist/.DS_Store +0 -0
@@ -1,8 +1,8 @@
1
1
  /**
2
2
  * @kaokei/di
3
- * jsbridge for iframes or windows by window.postMessage
3
+ * Tiny di library depend on typescript and reflect-metadata
4
4
  *
5
- * @version 1.0.21
5
+ * @version 1.0.25
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 _defineProperty = require("@babel/runtime/helpers/defineProperty");
18
+ var _classCallCheck = require("@babel/runtime/helpers/classCallCheck");
21
19
 
22
- var _typeof = require("@babel/runtime/helpers/typeof");
20
+ var _assertThisInitialized = require("@babel/runtime/helpers/assertThisInitialized");
23
21
 
24
- Object.defineProperty(exports, '__esModule', {
25
- value: true
26
- });
22
+ var _inherits = require("@babel/runtime/helpers/inherits");
27
23
 
28
- var autobindDecorator = require('autobind-decorator');
24
+ var _possibleConstructorReturn = require("@babel/runtime/helpers/possibleConstructorReturn");
29
25
 
30
- function _interopDefaultLegacy(e) {
31
- return e && _typeof(e) === 'object' && 'default' in e ? e['default'] : e;
32
- }
26
+ var _getPrototypeOf = require("@babel/runtime/helpers/getPrototypeOf");
33
27
 
34
- var autobindDecorator__default = /*#__PURE__*/_interopDefaultLegacy(autobindDecorator);
28
+ var _wrapNativeSuper = require("@babel/runtime/helpers/wrapNativeSuper");
35
29
 
36
- var DESIGN_PARAM_TYPES = 'design:paramtypes'; // ts自带的类的构造函数的参数的类型信息的key
30
+ var _defineProperty = require("@babel/runtime/helpers/defineProperty");
31
+
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 SERVICE_PARAM_TYPES = 'service:paramtypes'; // 构造函数原始的类型数据,可能会被@Inject等覆盖
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 SERVICE_INJECTED_PARAMS = 'service:injected:params'; // 构造函数使用@Inject注入的数据
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
- var SERVICE_INJECTED_PROPS = 'service:injected:props'; // @Inject注入的properties
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
- OPTIONAL: 'optional',
50
- DEFAULT_VALUE: 'defaultValue'
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
- INITED: Symbol('inited')
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
- function createPropertyDecorator(decoratorKey, defaultValue) {
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
- var isParameterDecorator = typeof index === 'number';
86
- var Ctor = isParameterDecorator ? target : target.constructor;
87
- var key = index !== undefined && isParameterDecorator ? index : targetKey;
88
- var metadataKey = isParameterDecorator ? SERVICE_INJECTED_PARAMS : SERVICE_INJECTED_PROPS;
108
+ // 如果indexnumber,那么代表是构造函数的参数的装饰器
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
- value: decoratorValue || defaultValue
129
+ // 装饰器的值,即装饰器函数的实参
130
+ // 很多装饰器具有默认值,可以不提供实参,而是使用默认值
131
+ value: decoratorValue === void 0 ? defaultValue : decoratorValue
95
132
  };
96
133
 
97
- if (decoratorKey === DECORATOR_KEYS.INJECT) {
98
- if (!decoratorValue) {
99
- throw new Error('没有提供Inject Key');
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 = createPropertyDecorator(DECORATOR_KEYS.INJECT); // 指定只在当前injector中寻找服务
155
+ var Inject = createDecorator(DECORATOR_KEYS.INJECT); // 指定只在当前injector中寻找服务
112
156
 
113
- var Self = createPropertyDecorator(DECORATOR_KEYS.SELF, true); // 指定跳过当前injector寻找服务
157
+ var Self = createDecorator(DECORATOR_KEYS.SELF, true); // 指定跳过当前injector寻找服务
114
158
 
115
- var Skip = createPropertyDecorator(DECORATOR_KEYS.SKIP_SELF, true); // 指定服务是可选的,找不到服务时返回undefined,否则抛出异常
159
+ var Skip = createDecorator(DECORATOR_KEYS.SKIP_SELF, true); // 指定服务是可选的,找不到服务时返回undefined,否则抛出异常
160
+ // 其实应该说是默认情况下找不到服务时,会抛出异常,除非明确指定是optional的
116
161
 
117
- var Optional = createPropertyDecorator(DECORATOR_KEYS.OPTIONAL, true);
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
- if (Reflect.hasOwnMetadata(SERVICE_PARAM_TYPES, target)) {
129
- throw new Error(ERROR_DISABLE_MULTIPLE_INJECTABLE);
130
- }
173
+ // 标记这个类可以注入
174
+ Reflect.defineMetadata(DECORATOR_KEYS.INJECTABLE, true, target); // 获取ts编译器默认的类型数据
175
+ // 经过测试,如果是基本类型string、number、boolean,那么会变成相对应的构造函数String,Number,Boolean
176
+ // 如果只是指定了interface类型,那么会变成Object构造函数
131
177
 
132
- var types = Reflect.getMetadata(DESIGN_PARAM_TYPES, target) || []; // 存储构造函数的类型信息
178
+ var types = Reflect.getMetadata(DECORATOR_KEYS.DESIGN_PARAM_TYPES, target) || []; // 存储构造函数的类型信息
179
+ // 这里只是转存了一下数据,并没有特殊逻辑
133
180
 
134
- Reflect.defineMetadata(SERVICE_PARAM_TYPES, types, target); // 标记这个类可以注入
135
-
136
- Reflect.defineMetadata(DECORATOR_KEYS.INJECTABLE, true, target);
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. \n ".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, "options", void 0);
347
+ _defineProperty(this, "providerMap", new Map());
348
+
349
+ _defineProperty(this, "beforeCacheHook", void 0);
191
350
 
192
- _defineProperty(this, "postHook", void 0);
351
+ _defineProperty(this, "mergePropertyHook", void 0);
193
352
 
194
- _defineProperty(this, "mergeHook", void 0);
353
+ // 引用父级Injector
354
+ this.parent = parent; // 在把服务实例放到缓存中之前,可以调用这个钩子让服务响应化
195
355
 
196
- this.parent = parent;
197
- this.options = options; // 在获取服务实例之后,在更新provider.useValue之前,使服务响应化
356
+ this.beforeCacheHook = options.beforeCacheHook || NOOP; // 在注入实例属性时,需要把属性merge到服务实例对象上,合并过程需要保持响应式
198
357
 
199
- this.postHook = options.postHook || NOOP;
200
- this.mergeHook = options.mergeHook || merge;
201
- this.resolveProviders(providers);
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.self) {
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 Error("".concat(ERROR_CIRCULAR_DEPENDENCY, " ").concat(token, " and ").concat(this.parentToken, " depent on each other."));
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
- return this.getServiceByClass(token, token);
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
- if (this.parent) {
233
- return this.parent.get(token, options);
391
+ return this.getServiceByProvider(_provider, options);
234
392
  } else {
235
- if (DECORATOR_KEYS.OPTIONAL in options || DECORATOR_KEYS.DEFAULT_VALUE in options) {
236
- return options.defaultValue;
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 _provider = this.providerMap.get(token);
398
+ var _provider2 = this.providerMap.get(token);
243
399
 
244
- if (_provider.status === SERVICE_STATUS.INITING) {
245
- throw new Error("".concat(ERROR_CIRCULAR_DEPENDENCY, " ").concat(token, " and ").concat(this.parentToken, " depent on each other."));
400
+ if (_provider2.status === SERVICE_STATUS.INITING) {
401
+ throw new CircularDependencyError(_provider2, options);
246
402
  }
247
403
 
248
- return this.getServiceByProvider(_provider, options);
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
- return this.getServiceByClass(token, token);
408
+ var _provider3 = this.getProviderByToken(token);
409
+
410
+ return this.getServiceByProvider(_provider3, options);
253
411
  } else {
254
- if (DECORATOR_KEYS.OPTIONAL in options || DECORATOR_KEYS.DEFAULT_VALUE in options) {
255
- return options.defaultValue;
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
  }
261
417
  /**
262
- * 获取构造函数的参数-返回数组
263
- * @done
418
+ * 如果token对应的provider不存在
419
+ * 那么就创建一个
420
+ * 调用该方法之前需要保证token对应的provider已经存在或者token本身是一个可注入的类
421
+ *
264
422
  * @param {*} token
265
423
  * @return {*}
266
424
  * @memberof Injector
267
425
  */
268
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
+ *
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);
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) {
473
+ var cacheValue = this.beforeCacheHook(provider.useValue);
474
+ provider.useCacheValue = cacheValue;
475
+ return cacheValue;
476
+ }
477
+ /**
478
+ * 通过useClass获取服务实例
479
+ *
480
+ * @param {*} provider
481
+ * @param {*} options
482
+ * @return {*}
483
+ * @memberof Injector
484
+ */
485
+
486
+ }, {
487
+ key: "getServiceUseClassWithProvider",
488
+ value: function getServiceUseClassWithProvider(provider, options) {
489
+ provider.parent = options.provider;
490
+ provider.status = SERVICE_STATUS.INITING;
491
+ var ClassName = provider.useClass;
492
+ var params = this.getContructorParameters(ClassName, provider);
493
+ var cacheValue = this.beforeCacheHook(_construct(ClassName, _toConsumableArray(params)));
494
+ provider.useCacheValue = cacheValue;
495
+ provider.status = SERVICE_STATUS.CONSTRUCTED;
496
+ var properties = this.getInjectProperties(ClassName, provider);
497
+ this.mergePropertyHook(cacheValue, properties);
498
+ provider.status = SERVICE_STATUS.MERGED;
499
+ provider.parent = void 0;
500
+ return cacheValue;
501
+ }
502
+ /**
503
+ * 通过useExisting获取服务实例
504
+ *
505
+ * @param {*} provider
506
+ * @param {*} options
507
+ * @return {*}
508
+ * @memberof Injector
509
+ */
510
+
511
+ }, {
512
+ key: "getServiceUseExistingWithProvider",
513
+ value: function getServiceUseExistingWithProvider(provider, options) {
514
+ provider.parent = options.provider;
515
+ provider.status = SERVICE_STATUS.INITING;
516
+ var cacheValue = this.get(provider.useExisting, _objectSpread(_objectSpread({}, options), {}, {
517
+ provider: provider
518
+ }));
519
+ provider.useCacheValue = cacheValue;
520
+ provider.status = SERVICE_STATUS.CONSTRUCTED;
521
+ provider.parent = void 0;
522
+ return cacheValue;
523
+ }
524
+ /**
525
+ * 通过useFactory获取服务实例
526
+ *
527
+ * @param {*} provider
528
+ * @param {*} options
529
+ * @return {*}
530
+ * @memberof Injector
531
+ */
532
+
533
+ }, {
534
+ key: "getServiceUseFactoryWithProvider",
535
+ value: function getServiceUseFactoryWithProvider(provider, options) {
536
+ var _this5 = this;
537
+
538
+ provider.parent = options.provider;
539
+ provider.status = SERVICE_STATUS.INITING;
540
+ var deps = provider.deps || [];
541
+ var args = deps.map(function (dep) {
542
+ return _this5.get(dep, {
543
+ provider: provider
544
+ });
545
+ });
546
+ var serviceValue = provider.useFactory.apply(provider, _toConsumableArray(args));
547
+ var cacheValue = this.beforeCacheHook(serviceValue);
548
+ provider.useCacheValue = cacheValue;
549
+ provider.status = SERVICE_STATUS.CONSTRUCTED;
550
+ provider.parent = void 0;
551
+ return cacheValue;
552
+ }
553
+ /**
554
+ * 获取构造函数的参数-返回数组
555
+ *
556
+ * @param {*} ClassName
557
+ * @param {*} provider
558
+ * @return {*}
559
+ * @memberof Injector
560
+ */
561
+
269
562
  }, {
270
563
  key: "getContructorParameters",
271
- value: function getContructorParameters(token) {
272
- var _this = this;
564
+ value: function getContructorParameters(ClassName, provider) {
565
+ var _this6 = this;
273
566
 
274
- var currentParentToken = this.parentToken;
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 _this.get(meta.key, meta.value);
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
- * @done
286
- * @param {*} token
577
+ *
578
+ * @param {*} ClassName
287
579
  * @return {*}
288
580
  * @memberof Injector
289
581
  */
290
582
 
291
583
  }, {
292
584
  key: "getContructorParametersMetas",
293
- value: function getContructorParametersMetas(token) {
585
+ value: function getContructorParametersMetas(ClassName) {
294
586
  // 构造函数的参数的类型数据-原始数据-是一个数组
295
- var params = Reflect.getMetadata(SERVICE_PARAM_TYPES, token) || []; // 构造函数的参数的类型数据-通过@Inject等装饰器实现-是一个对象-key是数字-对应第几个参数的类型数据
587
+ var params = Reflect.getMetadata(DECORATOR_KEYS.SERVICE_PARAM_TYPES, ClassName) || []; // 构造函数的参数的类型数据-通过@Inject等装饰器实现-是一个对象-key是数字-对应第几个参数的类型数据
296
588
 
297
- var propertiesMetadatas = Reflect.getMetadata(SERVICE_INJECTED_PARAMS, token) || {};
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 ctor = propertyMetadatas.find(function (meta) {
594
+ var injectMeta = propertyMetadatas.find(function (meta) {
303
595
  return meta.key === DECORATOR_KEYS.INJECT;
304
- }); // 把装饰器列表收集为对象,并且排除掉@Inject
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,67 +609,67 @@ var Injector = /*#__PURE__*/function () {
311
609
  return acc;
312
610
  }, {});
313
611
  return {
314
- key: resolveForwardRef(ctor && ctor.value) || paramType,
612
+ key: resolveForwardRef(injectMeta && injectMeta.value) || paramType,
315
613
  value: options
316
614
  };
317
615
  });
318
616
  }
319
617
  /**
320
618
  * 获取注入的实例属性-返回对象
321
- * @done
322
- * @param {*} token
619
+ *
620
+ * @param {*} ClassName
621
+ * @param {*} provider
323
622
  * @return {*}
324
623
  * @memberof Injector
325
624
  */
326
625
 
327
626
  }, {
328
627
  key: "getInjectProperties",
329
- value: function getInjectProperties(token) {
330
- var _this2 = this;
628
+ value: function getInjectProperties(ClassName, provider) {
629
+ var _this7 = this;
331
630
 
332
- var currentParentToken = this.parentToken;
333
- this.parentToken = token;
334
- var metas = this.getInjectPropertiesMetas(token);
631
+ var metas = this.getInjectPropertiesMetas(ClassName);
335
632
  var properties = {};
336
633
  metas.forEach(function (meta) {
337
634
  var _meta$value;
338
635
 
339
- var property = _this2.get(meta.provide, meta.value);
636
+ var property = _this7.get(meta.provide, _objectSpread(_objectSpread({}, meta.value), {}, {
637
+ provider: provider
638
+ }));
340
639
 
341
- if (!(property === undefined && (_meta$value = meta.value) !== null && _meta$value !== void 0 && _meta$value.optional)) {
342
- properties[meta.key] = _this2.get(meta.provide, meta.value);
640
+ if (!(property === void 0 && (_meta$value = meta.value) !== null && _meta$value !== void 0 && _meta$value.optional)) {
641
+ properties[meta.key] = property;
343
642
  }
344
643
  });
345
- this.parentToken = currentParentToken;
346
644
  return properties;
347
645
  }
348
646
  /**
349
647
  * 获取注入属性的装饰器数据
350
- * @done
351
- * @param {*} token
648
+ *
649
+ * @param {*} ClassName
352
650
  * @return {*}
353
651
  * @memberof Injector
354
652
  */
355
653
 
356
654
  }, {
357
655
  key: "getInjectPropertiesMetas",
358
- value: function getInjectPropertiesMetas(token) {
656
+ value: function getInjectPropertiesMetas(ClassName) {
359
657
  // 获取注入属性的metas-类型是Recors<string, Array>
360
- var propertiesMetadatas = Reflect.getMetadata(SERVICE_INJECTED_PROPS, token) || {};
658
+ var propertiesMetadatas = Reflect.getMetadata(DECORATOR_KEYS.SERVICE_INJECTED_PROPS, ClassName) || {};
361
659
  var propertiesMetas = [];
362
660
 
363
661
  for (var key in propertiesMetadatas) {
364
662
  if (has(propertiesMetadatas, key)) {
365
663
  // 当前key属性对应的所有的装饰器
366
- var propertyMetadatas = propertiesMetadatas[key] || []; // 当前key属性对应的@Inject
664
+ var propertyMetadatas = propertiesMetadatas[key]; // 当前key属性对应的@Inject装饰器的数据
367
665
 
368
- var ctor = propertyMetadatas.find(function (meta) {
666
+ var injectMeta = propertyMetadatas.find(function (meta) {
369
667
  return meta.key === DECORATOR_KEYS.INJECT;
370
668
  });
371
669
 
372
- if (!ctor) {
670
+ if (!injectMeta || injectMeta.value === Object) {
373
671
  // 属性一定要手动指定@Inject
374
- throw new Error(ERROR_INJECT_NOT_VALID);
672
+ throw new InjectFailedError(injectMeta, ClassName, key);
375
673
  }
376
674
 
377
675
  var options = propertyMetadatas.reduce(function (acc, meta) {
@@ -383,7 +681,7 @@ var Injector = /*#__PURE__*/function () {
383
681
  }, {});
384
682
  propertiesMetas.push({
385
683
  key: key,
386
- provide: resolveForwardRef(ctor.value),
684
+ provide: resolveForwardRef(injectMeta.value),
387
685
  value: options
388
686
  });
389
687
  }
@@ -391,103 +689,25 @@ var Injector = /*#__PURE__*/function () {
391
689
 
392
690
  return propertiesMetas;
393
691
  }
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
692
  /**
473
693
  * 把providers数组转换成map,避免后续的遍历
474
- * @done
694
+ *
475
695
  * @param {any[]} providers
476
696
  * @memberof Injector
477
697
  */
478
698
 
479
699
  }, {
480
- key: "resolveProviders",
481
- value: function resolveProviders(providers) {
482
- var _this4 = this;
700
+ key: "addProviders",
701
+ value: function addProviders(providers) {
702
+ var _this8 = this;
483
703
 
484
704
  providers.forEach(function (provider) {
485
- _this4.addProvider(provider);
705
+ _this8.addProvider(provider);
486
706
  });
487
707
  }
488
708
  /**
489
709
  * 添加新的provider
490
- * @done
710
+ *
491
711
  * @param {*} provider
492
712
  * @memberof Injector
493
713
  */
@@ -496,10 +716,6 @@ var Injector = /*#__PURE__*/function () {
496
716
  key: "addProvider",
497
717
  value: function addProvider(provider) {
498
718
  if (provider.provide) {
499
- if ('useValue' in provider) {
500
- provider.useValue = this.postHook(provider.useValue);
501
- }
502
-
503
719
  this.providerMap.set(provider.provide, provider);
504
720
  } else {
505
721
  this.providerMap.set(provider, {
@@ -518,8 +734,12 @@ var Injector = /*#__PURE__*/function () {
518
734
  key: "dispose",
519
735
  value: function dispose() {
520
736
  this.providerMap.forEach(function (value) {
521
- if (value && value.dispose) {
522
- value.dispose();
737
+ if (value && value.useCacheValue && value.useCacheValue.dispose) {
738
+ try {
739
+ value.useCacheValue.dispose();
740
+ } catch (error) {
741
+ console.error(error);
742
+ }
523
743
  }
524
744
  });
525
745
  this.providerMap = null;
@@ -530,24 +750,19 @@ var Injector = /*#__PURE__*/function () {
530
750
  return Injector;
531
751
  }();
532
752
 
533
- exports.autobind = autobindDecorator__default;
753
+ exports.CircularDependencyError = CircularDependencyError;
534
754
  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
755
  exports.Inject = Inject;
756
+ exports.InjectFailedError = InjectFailedError;
542
757
  exports.Injectable = Injectable;
543
758
  exports.Injector = Injector;
544
759
  exports.Optional = Optional;
545
- exports.SERVICE_INJECTED_PARAMS = SERVICE_INJECTED_PARAMS;
546
- exports.SERVICE_INJECTED_PROPS = SERVICE_INJECTED_PROPS;
547
- exports.SERVICE_PARAM_TYPES = SERVICE_PARAM_TYPES;
760
+ exports.ProviderNotValidError = ProviderNotValidError;
548
761
  exports.SERVICE_STATUS = SERVICE_STATUS;
549
762
  exports.Self = Self;
550
763
  exports.Skip = Skip;
764
+ exports.TokenNotFoundError = TokenNotFoundError;
765
+ exports.createDecorator = createDecorator;
551
766
  exports.forwardRef = forwardRef;
552
767
  exports.has = has;
553
768
  exports.isForwardRef = isForwardRef;