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