@ngxs/store 3.6.2-dev.master-8e14fe1 → 3.7.0

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 (231) hide show
  1. package/README.md +16 -16
  2. package/bundles/ngxs-store-internals.umd.js +210 -210
  3. package/bundles/ngxs-store-internals.umd.js.map +1 -1
  4. package/bundles/ngxs-store-internals.umd.min.js.map +1 -1
  5. package/bundles/ngxs-store-operators.umd.js +326 -321
  6. package/bundles/ngxs-store-operators.umd.js.map +1 -1
  7. package/bundles/ngxs-store-operators.umd.min.js +10 -10
  8. package/bundles/ngxs-store-operators.umd.min.js.map +1 -1
  9. package/bundles/ngxs-store.umd.js +4401 -4386
  10. package/bundles/ngxs-store.umd.js.map +1 -1
  11. package/bundles/ngxs-store.umd.min.js +11 -11
  12. package/bundles/ngxs-store.umd.min.js.map +1 -1
  13. package/esm2015/index.js +13 -13
  14. package/esm2015/internals/angular.js +40 -40
  15. package/esm2015/internals/index.js +10 -10
  16. package/esm2015/internals/initial-state.js +34 -34
  17. package/esm2015/internals/internal-tokens.js +16 -16
  18. package/esm2015/internals/memoize.js +70 -70
  19. package/esm2015/internals/ngxs-bootstrapper.js +41 -41
  20. package/esm2015/internals/ngxs-store-internals.js +8 -8
  21. package/esm2015/internals/src/symbols.js +14 -14
  22. package/esm2015/internals/symbols.js +14 -14
  23. package/esm2015/ngxs-store.js +25 -25
  24. package/esm2015/operators/append.js +31 -31
  25. package/esm2015/operators/compose.js +24 -24
  26. package/esm2015/operators/iif.js +56 -56
  27. package/esm2015/operators/index.js +18 -18
  28. package/esm2015/operators/insert-item.js +41 -41
  29. package/esm2015/operators/internals.js +5 -5
  30. package/esm2015/operators/ngxs-store-operators.js +8 -8
  31. package/esm2015/operators/patch.js +39 -39
  32. package/esm2015/operators/remove-item.js +34 -34
  33. package/esm2015/operators/update-item.js +52 -52
  34. package/esm2015/operators/utils.js +50 -50
  35. package/esm2015/src/actions/actions.js +39 -39
  36. package/esm2015/src/actions/symbols.js +39 -39
  37. package/esm2015/src/actions-stream.js +140 -140
  38. package/esm2015/src/configs/messages.config.js +87 -87
  39. package/esm2015/src/decorators/action.js +44 -44
  40. package/esm2015/src/decorators/select/select-factory.js +39 -39
  41. package/esm2015/src/decorators/select/select.js +45 -46
  42. package/esm2015/src/decorators/select/symbols.js +50 -50
  43. package/esm2015/src/decorators/selector/selector.js +55 -55
  44. package/esm2015/src/decorators/selector/symbols.js +5 -5
  45. package/esm2015/src/decorators/selector-options.js +34 -34
  46. package/esm2015/src/decorators/state.js +75 -75
  47. package/esm2015/src/execution/dispatch-outside-zone-ngxs-execution-strategy.js +96 -96
  48. package/esm2015/src/execution/internal-ngxs-execution-strategy.js +45 -45
  49. package/esm2015/src/execution/noop-ngxs-execution-strategy.js +27 -27
  50. package/esm2015/src/execution/symbols.js +29 -29
  51. package/esm2015/src/host-environment/host-environment.js +31 -31
  52. package/esm2015/src/internal/config-validator.js +67 -67
  53. package/esm2015/src/internal/dispatcher.js +210 -202
  54. package/esm2015/src/internal/internals.js +489 -489
  55. package/esm2015/src/internal/lifecycle-state-manager.js +129 -129
  56. package/esm2015/src/internal/state-context-factory.js +138 -138
  57. package/esm2015/src/internal/state-factory.js +401 -392
  58. package/esm2015/src/internal/state-operations.js +125 -125
  59. package/esm2015/src/internal/state-operators.js +33 -33
  60. package/esm2015/src/internal/state-stream.js +21 -21
  61. package/esm2015/src/ivy/ensure-state-class-is-injectable.js +34 -34
  62. package/esm2015/src/ivy/ivy-enabled-in-dev-mode.js +40 -50
  63. package/esm2015/src/module.js +171 -171
  64. package/esm2015/src/modules/ngxs-feature.module.js +63 -63
  65. package/esm2015/src/modules/ngxs-root.module.js +52 -52
  66. package/esm2015/src/operators/leave-ngxs.js +58 -58
  67. package/esm2015/src/operators/of-action.js +191 -188
  68. package/esm2015/src/plugin-manager.js +70 -70
  69. package/esm2015/src/plugin_api.js +10 -10
  70. package/esm2015/src/public_api.js +29 -29
  71. package/esm2015/src/public_to_deprecate.js +64 -64
  72. package/esm2015/src/state-token/state-token.js +45 -45
  73. package/esm2015/src/state-token/symbols.js +5 -5
  74. package/esm2015/src/store.js +174 -174
  75. package/esm2015/src/symbols.js +221 -221
  76. package/esm2015/src/utils/compose.js +44 -44
  77. package/esm2015/src/utils/freeze.js +35 -35
  78. package/esm2015/src/utils/selector-utils.js +221 -221
  79. package/esm2015/src/utils/store-validators.js +65 -65
  80. package/esm2015/src/utils/utils.js +95 -93
  81. package/esm5/index.js +13 -13
  82. package/esm5/internals/angular.js +40 -40
  83. package/esm5/internals/index.js +10 -10
  84. package/esm5/internals/initial-state.js +45 -45
  85. package/esm5/internals/internal-tokens.js +16 -16
  86. package/esm5/internals/memoize.js +71 -71
  87. package/esm5/internals/ngxs-bootstrapper.js +56 -56
  88. package/esm5/internals/ngxs-store-internals.js +8 -8
  89. package/esm5/internals/src/symbols.js +14 -14
  90. package/esm5/internals/symbols.js +14 -14
  91. package/esm5/ngxs-store.js +25 -25
  92. package/esm5/operators/append.js +31 -31
  93. package/esm5/operators/compose.js +28 -28
  94. package/esm5/operators/iif.js +56 -56
  95. package/esm5/operators/index.js +18 -18
  96. package/esm5/operators/insert-item.js +41 -41
  97. package/esm5/operators/internals.js +5 -5
  98. package/esm5/operators/ngxs-store-operators.js +8 -8
  99. package/esm5/operators/patch.js +40 -40
  100. package/esm5/operators/remove-item.js +34 -34
  101. package/esm5/operators/update-item.js +52 -52
  102. package/esm5/operators/utils.js +50 -50
  103. package/esm5/src/actions/actions.js +62 -62
  104. package/esm5/src/actions/symbols.js +39 -39
  105. package/esm5/src/actions-stream.js +186 -186
  106. package/esm5/src/configs/messages.config.js +104 -104
  107. package/esm5/src/decorators/action.js +56 -56
  108. package/esm5/src/decorators/select/select-factory.js +37 -37
  109. package/esm5/src/decorators/select/select.js +50 -51
  110. package/esm5/src/decorators/select/symbols.js +51 -51
  111. package/esm5/src/decorators/selector/selector.js +55 -55
  112. package/esm5/src/decorators/selector/symbols.js +5 -5
  113. package/esm5/src/decorators/selector-options.js +34 -34
  114. package/esm5/src/decorators/state.js +76 -76
  115. package/esm5/src/execution/dispatch-outside-zone-ngxs-execution-strategy.js +121 -121
  116. package/esm5/src/execution/internal-ngxs-execution-strategy.js +54 -54
  117. package/esm5/src/execution/noop-ngxs-execution-strategy.js +41 -41
  118. package/esm5/src/execution/symbols.js +29 -29
  119. package/esm5/src/host-environment/host-environment.js +29 -29
  120. package/esm5/src/internal/config-validator.js +76 -76
  121. package/esm5/src/internal/dispatcher.js +246 -238
  122. package/esm5/src/internal/internals.js +491 -491
  123. package/esm5/src/internal/lifecycle-state-manager.js +177 -177
  124. package/esm5/src/internal/state-context-factory.js +146 -146
  125. package/esm5/src/internal/state-factory.js +528 -519
  126. package/esm5/src/internal/state-operations.js +139 -139
  127. package/esm5/src/internal/state-operators.js +34 -34
  128. package/esm5/src/internal/state-stream.js +25 -25
  129. package/esm5/src/ivy/ensure-state-class-is-injectable.js +34 -34
  130. package/esm5/src/ivy/ivy-enabled-in-dev-mode.js +40 -50
  131. package/esm5/src/module.js +214 -214
  132. package/esm5/src/modules/ngxs-feature.module.js +65 -65
  133. package/esm5/src/modules/ngxs-root.module.js +47 -47
  134. package/esm5/src/operators/leave-ngxs.js +58 -58
  135. package/esm5/src/operators/of-action.js +217 -214
  136. package/esm5/src/plugin-manager.js +82 -82
  137. package/esm5/src/plugin_api.js +10 -10
  138. package/esm5/src/public_api.js +29 -29
  139. package/esm5/src/public_to_deprecate.js +64 -64
  140. package/esm5/src/state-token/state-token.js +57 -57
  141. package/esm5/src/state-token/symbols.js +5 -5
  142. package/esm5/src/store.js +225 -225
  143. package/esm5/src/symbols.js +230 -230
  144. package/esm5/src/utils/compose.js +55 -55
  145. package/esm5/src/utils/freeze.js +35 -35
  146. package/esm5/src/utils/selector-utils.js +230 -230
  147. package/esm5/src/utils/store-validators.js +86 -86
  148. package/esm5/src/utils/utils.js +98 -96
  149. package/fesm2015/ngxs-store-internals.js +191 -191
  150. package/fesm2015/ngxs-store-internals.js.map +1 -1
  151. package/fesm2015/ngxs-store-operators.js +312 -312
  152. package/fesm2015/ngxs-store-operators.js.map +1 -1
  153. package/fesm2015/ngxs-store.js +3878 -3868
  154. package/fesm2015/ngxs-store.js.map +1 -1
  155. package/fesm5/ngxs-store-internals.js +216 -216
  156. package/fesm5/ngxs-store-internals.js.map +1 -1
  157. package/fesm5/ngxs-store-operators.js +316 -316
  158. package/fesm5/ngxs-store-operators.js.map +1 -1
  159. package/fesm5/ngxs-store.js +4397 -4387
  160. package/fesm5/ngxs-store.js.map +1 -1
  161. package/index.d.ts +8 -8
  162. package/internals/angular.d.ts +3 -3
  163. package/internals/index.d.ts +6 -6
  164. package/internals/initial-state.d.ts +8 -8
  165. package/internals/internal-tokens.d.ts +9 -9
  166. package/internals/memoize.d.ts +9 -9
  167. package/internals/ngxs-bootstrapper.d.ts +13 -13
  168. package/internals/ngxs-store-internals.d.ts +4 -4
  169. package/internals/src/symbols.d.ts +7 -7
  170. package/internals/symbols.d.ts +7 -7
  171. package/ngxs-store.d.ts +22 -22
  172. package/ngxs-store.metadata.json +1 -1
  173. package/operators/append.d.ts +6 -6
  174. package/operators/compose.d.ts +2 -2
  175. package/operators/iif.d.ts +11 -11
  176. package/operators/index.d.ts +13 -13
  177. package/operators/insert-item.d.ts +7 -7
  178. package/operators/internals.d.ts +2 -2
  179. package/operators/ngxs-store-operators.d.ts +4 -4
  180. package/operators/patch.d.ts +10 -10
  181. package/operators/remove-item.d.ts +7 -7
  182. package/operators/update-item.d.ts +10 -10
  183. package/operators/utils.d.ts +9 -9
  184. package/package.json +4 -4
  185. package/src/actions/actions.d.ts +15 -15
  186. package/src/actions/symbols.d.ts +21 -21
  187. package/src/actions-stream.d.ts +49 -49
  188. package/src/configs/messages.config.d.ts +30 -30
  189. package/src/decorators/action.d.ts +5 -5
  190. package/src/decorators/select/select-factory.d.ts +12 -12
  191. package/src/decorators/select/select.d.ts +4 -5
  192. package/src/decorators/select/symbols.d.ts +10 -14
  193. package/src/decorators/selector/selector.d.ts +5 -5
  194. package/src/decorators/selector/symbols.d.ts +4 -4
  195. package/src/decorators/selector-options.d.ts +5 -5
  196. package/src/decorators/state.d.ts +6 -6
  197. package/src/execution/dispatch-outside-zone-ngxs-execution-strategy.d.ts +12 -12
  198. package/src/execution/internal-ngxs-execution-strategy.d.ts +7 -7
  199. package/src/execution/noop-ngxs-execution-strategy.d.ts +5 -5
  200. package/src/execution/symbols.d.ts +6 -6
  201. package/src/host-environment/host-environment.d.ts +6 -6
  202. package/src/internal/config-validator.d.ts +10 -10
  203. package/src/internal/dispatcher.d.ts +31 -31
  204. package/src/internal/internals.d.ts +167 -167
  205. package/src/internal/lifecycle-state-manager.d.ts +20 -20
  206. package/src/internal/state-context-factory.d.ts +15 -15
  207. package/src/internal/state-factory.d.ts +57 -57
  208. package/src/internal/state-operations.d.ts +21 -21
  209. package/src/internal/state-operators.d.ts +2 -2
  210. package/src/internal/state-stream.d.ts +9 -9
  211. package/src/ivy/ensure-state-class-is-injectable.d.ts +6 -6
  212. package/src/ivy/ivy-enabled-in-dev-mode.d.ts +14 -14
  213. package/src/module.d.ts +23 -23
  214. package/src/modules/ngxs-feature.module.d.ts +13 -13
  215. package/src/modules/ngxs-root.module.d.ts +13 -13
  216. package/src/operators/leave-ngxs.d.ts +7 -7
  217. package/src/operators/of-action.d.ts +43 -42
  218. package/src/plugin-manager.d.ts +10 -10
  219. package/src/plugin_api.d.ts +5 -5
  220. package/src/public_api.d.ts +17 -17
  221. package/src/public_to_deprecate.d.ts +21 -21
  222. package/src/state-token/state-token.d.ts +7 -7
  223. package/src/state-token/symbols.d.ts +5 -5
  224. package/src/store.d.ts +53 -53
  225. package/src/symbols.d.ts +137 -137
  226. package/src/utils/compose.d.ts +23 -23
  227. package/src/utils/freeze.d.ts +5 -5
  228. package/src/utils/selector-utils.d.ts +23 -23
  229. package/src/utils/store-validators.d.ts +8 -8
  230. package/src/utils/utils.d.ts +29 -29
  231. package/types/index.d.ts +2 -2
@@ -1,339 +1,339 @@
1
1
  import { __assign } from 'tslib';
2
2
 
3
- /**
4
- * @fileoverview added by tsickle
5
- * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
6
- */
7
- /**
8
- * @template T
9
- * @param {?} items - Specific items to append to the end of an array
10
- * @return {?}
11
- */
12
- function append(items) {
13
- return (/**
14
- * @param {?} existing
15
- * @return {?}
16
- */
17
- function appendOperator(existing) {
18
- // If `items` is `undefined` or `null` or `[]` but `existing` is provided
19
- // just return `existing`
20
- /** @type {?} */
21
- var itemsNotProvidedButExistingIs = (!items || !items.length) && existing;
22
- if (itemsNotProvidedButExistingIs) {
23
- return (/** @type {?} */ (existing));
24
- }
25
- if (Array.isArray(existing)) {
26
- return existing.concat((/** @type {?} */ (items)));
27
- }
28
- // For example if some property is added dynamically
29
- // and didn't exist before thus it's not `ArrayLike`
30
- return (/** @type {?} */ (items));
31
- });
3
+ /**
4
+ * @fileoverview added by tsickle
5
+ * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
6
+ */
7
+ /**
8
+ * @template T
9
+ * @param {?} items - Specific items to append to the end of an array
10
+ * @return {?}
11
+ */
12
+ function append(items) {
13
+ return (/**
14
+ * @param {?} existing
15
+ * @return {?}
16
+ */
17
+ function appendOperator(existing) {
18
+ // If `items` is `undefined` or `null` or `[]` but `existing` is provided
19
+ // just return `existing`
20
+ /** @type {?} */
21
+ var itemsNotProvidedButExistingIs = (!items || !items.length) && existing;
22
+ if (itemsNotProvidedButExistingIs) {
23
+ return (/** @type {?} */ (existing));
24
+ }
25
+ if (Array.isArray(existing)) {
26
+ return existing.concat((/** @type {?} */ (items)));
27
+ }
28
+ // For example if some property is added dynamically
29
+ // and didn't exist before thus it's not `ArrayLike`
30
+ return (/** @type {?} */ (items));
31
+ });
32
32
  }
33
33
 
34
- /**
35
- * @fileoverview added by tsickle
36
- * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
37
- */
38
- /**
39
- * @template T
40
- * @param {...?} operators
41
- * @return {?}
42
- */
43
- function compose() {
44
- var operators = [];
45
- for (var _i = 0; _i < arguments.length; _i++) {
46
- operators[_i] = arguments[_i];
47
- }
48
- return (/**
49
- * @param {?} existing
50
- * @return {?}
51
- */
52
- function composeOperator(existing) {
53
- return operators.reduce((/**
54
- * @param {?} accumulator
55
- * @param {?} operator
56
- * @return {?}
57
- */
58
- function (accumulator, operator) { return operator(accumulator); }), existing);
59
- });
34
+ /**
35
+ * @fileoverview added by tsickle
36
+ * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
37
+ */
38
+ /**
39
+ * @template T
40
+ * @param {...?} operators
41
+ * @return {?}
42
+ */
43
+ function compose() {
44
+ var operators = [];
45
+ for (var _i = 0; _i < arguments.length; _i++) {
46
+ operators[_i] = arguments[_i];
47
+ }
48
+ return (/**
49
+ * @param {?} existing
50
+ * @return {?}
51
+ */
52
+ function composeOperator(existing) {
53
+ return operators.reduce((/**
54
+ * @param {?} accumulator
55
+ * @param {?} operator
56
+ * @return {?}
57
+ */
58
+ function (accumulator, operator) { return operator(accumulator); }), existing);
59
+ });
60
60
  }
61
61
 
62
- /**
63
- * @fileoverview added by tsickle
64
- * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
65
- */
66
- /**
67
- * @template T
68
- * @param {?} value
69
- * @return {?}
70
- */
71
- function isStateOperator(value) {
72
- return typeof value === 'function';
73
- }
74
- /**
75
- * @param {?} value
76
- * @return {?}
77
- */
78
- function isUndefined(value) {
79
- return typeof value === 'undefined';
80
- }
81
- /**
82
- * @template T
83
- * @param {?} value
84
- * @return {?}
85
- */
86
- function isPredicate(value) {
87
- return typeof value === 'function';
88
- }
89
- /**
90
- * @param {?} value
91
- * @return {?}
92
- */
93
- function isNumber(value) {
94
- return typeof value === 'number';
95
- }
96
- /**
97
- * @param {?} index
98
- * @return {?}
99
- */
100
- function invalidIndex(index) {
101
- return Number.isNaN(index) || index === -1;
102
- }
103
- /**
104
- * @template T
105
- * @param {?} value
106
- * @return {?}
107
- */
108
- function isNil(value) {
109
- return value === null || isUndefined(value);
62
+ /**
63
+ * @fileoverview added by tsickle
64
+ * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
65
+ */
66
+ /**
67
+ * @template T
68
+ * @param {?} value
69
+ * @return {?}
70
+ */
71
+ function isStateOperator(value) {
72
+ return typeof value === 'function';
73
+ }
74
+ /**
75
+ * @param {?} value
76
+ * @return {?}
77
+ */
78
+ function isUndefined(value) {
79
+ return typeof value === 'undefined';
80
+ }
81
+ /**
82
+ * @template T
83
+ * @param {?} value
84
+ * @return {?}
85
+ */
86
+ function isPredicate(value) {
87
+ return typeof value === 'function';
88
+ }
89
+ /**
90
+ * @param {?} value
91
+ * @return {?}
92
+ */
93
+ function isNumber(value) {
94
+ return typeof value === 'number';
95
+ }
96
+ /**
97
+ * @param {?} index
98
+ * @return {?}
99
+ */
100
+ function invalidIndex(index) {
101
+ return Number.isNaN(index) || index === -1;
102
+ }
103
+ /**
104
+ * @template T
105
+ * @param {?} value
106
+ * @return {?}
107
+ */
108
+ function isNil(value) {
109
+ return value === null || isUndefined(value);
110
110
  }
111
111
 
112
- /**
113
- * @fileoverview added by tsickle
114
- * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
115
- */
116
- /**
117
- * @template T
118
- * @param {?} operatorOrValue
119
- * @param {?=} existing
120
- * @return {?}
121
- */
122
- function retrieveValue(operatorOrValue, existing) {
123
- // If state operator is a function
124
- // then call it with an original value
125
- if (isStateOperator(operatorOrValue)) {
126
- /** @type {?} */
127
- var value = operatorOrValue((/** @type {?} */ ((/** @type {?} */ (existing)))));
128
- return (/** @type {?} */ (value));
129
- }
130
- // If operator or value was not provided
131
- // e.g. `elseOperatorOrValue` is `undefined`
132
- // then we just return an original value
133
- if (isUndefined(operatorOrValue)) {
134
- return (/** @type {?} */ ((/** @type {?} */ (((/** @type {?} */ (existing)))))));
135
- }
136
- return (/** @type {?} */ (operatorOrValue));
137
- }
138
- /**
139
- * @template T
140
- * @param {?} condition - Condition can be a plain boolean value or a function,
141
- * that returns boolean, also this function can take a value as an argument
142
- * to which this state operator applies
143
- * @param {?} trueOperatorOrValue - Any value or a state operator
144
- * @param {?=} elseOperatorOrValue - Any value or a state operator
145
- * @return {?}
146
- */
147
- function iif(condition, trueOperatorOrValue, elseOperatorOrValue) {
148
- return (/**
149
- * @param {?} existing
150
- * @return {?}
151
- */
152
- function iifOperator(existing) {
153
- // Convert the value to a boolean
154
- /** @type {?} */
155
- var result = !!condition;
156
- // but if it is a function then run it to get the result
157
- if (isPredicate(condition)) {
158
- result = condition(existing);
159
- }
160
- if (result) {
161
- return retrieveValue(trueOperatorOrValue, (/** @type {?} */ (existing)));
162
- }
163
- return retrieveValue((/** @type {?} */ (elseOperatorOrValue)), (/** @type {?} */ (existing)));
164
- });
112
+ /**
113
+ * @fileoverview added by tsickle
114
+ * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
115
+ */
116
+ /**
117
+ * @template T
118
+ * @param {?} operatorOrValue
119
+ * @param {?=} existing
120
+ * @return {?}
121
+ */
122
+ function retrieveValue(operatorOrValue, existing) {
123
+ // If state operator is a function
124
+ // then call it with an original value
125
+ if (isStateOperator(operatorOrValue)) {
126
+ /** @type {?} */
127
+ var value = operatorOrValue((/** @type {?} */ ((/** @type {?} */ (existing)))));
128
+ return (/** @type {?} */ (value));
129
+ }
130
+ // If operator or value was not provided
131
+ // e.g. `elseOperatorOrValue` is `undefined`
132
+ // then we just return an original value
133
+ if (isUndefined(operatorOrValue)) {
134
+ return (/** @type {?} */ ((/** @type {?} */ (((/** @type {?} */ (existing)))))));
135
+ }
136
+ return (/** @type {?} */ (operatorOrValue));
137
+ }
138
+ /**
139
+ * @template T
140
+ * @param {?} condition - Condition can be a plain boolean value or a function,
141
+ * that returns boolean, also this function can take a value as an argument
142
+ * to which this state operator applies
143
+ * @param {?} trueOperatorOrValue - Any value or a state operator
144
+ * @param {?=} elseOperatorOrValue - Any value or a state operator
145
+ * @return {?}
146
+ */
147
+ function iif(condition, trueOperatorOrValue, elseOperatorOrValue) {
148
+ return (/**
149
+ * @param {?} existing
150
+ * @return {?}
151
+ */
152
+ function iifOperator(existing) {
153
+ // Convert the value to a boolean
154
+ /** @type {?} */
155
+ var result = !!condition;
156
+ // but if it is a function then run it to get the result
157
+ if (isPredicate(condition)) {
158
+ result = condition(existing);
159
+ }
160
+ if (result) {
161
+ return retrieveValue(trueOperatorOrValue, (/** @type {?} */ (existing)));
162
+ }
163
+ return retrieveValue((/** @type {?} */ (elseOperatorOrValue)), (/** @type {?} */ (existing)));
164
+ });
165
165
  }
166
166
 
167
- /**
168
- * @fileoverview added by tsickle
169
- * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
170
- */
171
- /**
172
- * @template T
173
- * @param {?} value - Value to insert
174
- * @param {?=} beforePosition
175
- * @return {?}
176
- */
177
- function insertItem(value, beforePosition) {
178
- return (/**
179
- * @param {?} existing
180
- * @return {?}
181
- */
182
- function insertItemOperator(existing) {
183
- // Have to check explicitly for `null` and `undefined`
184
- // because `value` can be `0`, thus `!value` will return `true`
185
- if (isNil(value) && existing) {
186
- return (/** @type {?} */ (existing));
187
- }
188
- // Property may be dynamic and might not existed before
189
- if (!Array.isArray(existing)) {
190
- return [(/** @type {?} */ (value))];
191
- }
192
- /** @type {?} */
193
- var clone = existing.slice();
194
- /** @type {?} */
195
- var index = 0;
196
- // No need to call `isNumber`
197
- // as we are checking `> 0` not `>= 0`
198
- // everything except number will return false here
199
- if ((/** @type {?} */ (beforePosition)) > 0) {
200
- index = (/** @type {?} */ (beforePosition));
201
- }
202
- clone.splice(index, 0, (/** @type {?} */ (value)));
203
- return clone;
204
- });
167
+ /**
168
+ * @fileoverview added by tsickle
169
+ * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
170
+ */
171
+ /**
172
+ * @template T
173
+ * @param {?} value - Value to insert
174
+ * @param {?=} beforePosition
175
+ * @return {?}
176
+ */
177
+ function insertItem(value, beforePosition) {
178
+ return (/**
179
+ * @param {?} existing
180
+ * @return {?}
181
+ */
182
+ function insertItemOperator(existing) {
183
+ // Have to check explicitly for `null` and `undefined`
184
+ // because `value` can be `0`, thus `!value` will return `true`
185
+ if (isNil(value) && existing) {
186
+ return (/** @type {?} */ (existing));
187
+ }
188
+ // Property may be dynamic and might not existed before
189
+ if (!Array.isArray(existing)) {
190
+ return [(/** @type {?} */ (value))];
191
+ }
192
+ /** @type {?} */
193
+ var clone = existing.slice();
194
+ /** @type {?} */
195
+ var index = 0;
196
+ // No need to call `isNumber`
197
+ // as we are checking `> 0` not `>= 0`
198
+ // everything except number will return false here
199
+ if ((/** @type {?} */ (beforePosition)) > 0) {
200
+ index = (/** @type {?} */ (beforePosition));
201
+ }
202
+ clone.splice(index, 0, (/** @type {?} */ (value)));
203
+ return clone;
204
+ });
205
205
  }
206
206
 
207
- /**
208
- * @fileoverview added by tsickle
209
- * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
210
- */
211
- /**
212
- * @template T
213
- * @param {?} patchObject
214
- * @return {?}
215
- */
216
- function patch(patchObject) {
217
- return (/**
218
- * @template U
219
- * @param {?} existing
220
- * @return {?}
221
- */
222
- function patchStateOperator(existing) {
223
- /** @type {?} */
224
- var clone = null;
225
- for (var k in patchObject) {
226
- /** @type {?} */
227
- var newValue = patchObject[k];
228
- /** @type {?} */
229
- var existingPropValue = existing[k];
230
- /** @type {?} */
231
- var newPropValue = isStateOperator(newValue)
232
- ? newValue((/** @type {?} */ (existingPropValue)))
233
- : newValue;
234
- if (newPropValue !== existingPropValue) {
235
- if (!clone) {
236
- clone = __assign({}, ((/** @type {?} */ (existing))));
237
- }
238
- clone[k] = newPropValue;
239
- }
240
- }
241
- return clone || existing;
242
- });
207
+ /**
208
+ * @fileoverview added by tsickle
209
+ * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
210
+ */
211
+ /**
212
+ * @template T
213
+ * @param {?} patchObject
214
+ * @return {?}
215
+ */
216
+ function patch(patchObject) {
217
+ return (/**
218
+ * @template U
219
+ * @param {?} existing
220
+ * @return {?}
221
+ */
222
+ function patchStateOperator(existing) {
223
+ /** @type {?} */
224
+ var clone = null;
225
+ for (var k in patchObject) {
226
+ /** @type {?} */
227
+ var newValue = patchObject[k];
228
+ /** @type {?} */
229
+ var existingPropValue = existing[k];
230
+ /** @type {?} */
231
+ var newPropValue = isStateOperator(newValue)
232
+ ? newValue((/** @type {?} */ (existingPropValue)))
233
+ : newValue;
234
+ if (newPropValue !== existingPropValue) {
235
+ if (!clone) {
236
+ clone = __assign({}, ((/** @type {?} */ (existing))));
237
+ }
238
+ clone[k] = newPropValue;
239
+ }
240
+ }
241
+ return clone || existing;
242
+ });
243
243
  }
244
244
 
245
- /**
246
- * @fileoverview added by tsickle
247
- * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
248
- */
249
- /**
250
- * @template T
251
- * @param {?} selector - Index of item in the array or a predicate function
252
- * that can be provided in `Array.prototype.findIndex`
253
- * @param {?} operatorOrValue - New value under the `selector` index or a
254
- * function that can be applied to an existing value
255
- * @return {?}
256
- */
257
- function updateItem(selector, operatorOrValue) {
258
- return (/**
259
- * @param {?} existing
260
- * @return {?}
261
- */
262
- function updateItemOperator(existing) {
263
- /** @type {?} */
264
- var index = -1;
265
- if (isPredicate(selector)) {
266
- index = existing.findIndex(selector);
267
- }
268
- else if (isNumber(selector)) {
269
- index = selector;
270
- }
271
- if (invalidIndex(index)) {
272
- return (/** @type {?} */ (existing));
273
- }
274
- /** @type {?} */
275
- var value = (/** @type {?} */ (null));
276
- // Need to check if the new item value will change the existing item value
277
- // then, only if it will change it then clone the array and set the item
278
- if (isStateOperator(operatorOrValue)) {
279
- value = operatorOrValue((/** @type {?} */ (existing[index])));
280
- }
281
- else {
282
- value = operatorOrValue;
283
- }
284
- // If the value hasn't been mutated
285
- // then we just return `existing` array
286
- if (value === existing[index]) {
287
- return (/** @type {?} */ (existing));
288
- }
289
- /** @type {?} */
290
- var clone = existing.slice();
291
- clone[index] = (/** @type {?} */ (value));
292
- return clone;
293
- });
245
+ /**
246
+ * @fileoverview added by tsickle
247
+ * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
248
+ */
249
+ /**
250
+ * @template T
251
+ * @param {?} selector - Index of item in the array or a predicate function
252
+ * that can be provided in `Array.prototype.findIndex`
253
+ * @param {?} operatorOrValue - New value under the `selector` index or a
254
+ * function that can be applied to an existing value
255
+ * @return {?}
256
+ */
257
+ function updateItem(selector, operatorOrValue) {
258
+ return (/**
259
+ * @param {?} existing
260
+ * @return {?}
261
+ */
262
+ function updateItemOperator(existing) {
263
+ /** @type {?} */
264
+ var index = -1;
265
+ if (isPredicate(selector)) {
266
+ index = existing.findIndex(selector);
267
+ }
268
+ else if (isNumber(selector)) {
269
+ index = selector;
270
+ }
271
+ if (invalidIndex(index)) {
272
+ return (/** @type {?} */ (existing));
273
+ }
274
+ /** @type {?} */
275
+ var value = (/** @type {?} */ (null));
276
+ // Need to check if the new item value will change the existing item value
277
+ // then, only if it will change it then clone the array and set the item
278
+ if (isStateOperator(operatorOrValue)) {
279
+ value = operatorOrValue((/** @type {?} */ (existing[index])));
280
+ }
281
+ else {
282
+ value = operatorOrValue;
283
+ }
284
+ // If the value hasn't been mutated
285
+ // then we just return `existing` array
286
+ if (value === existing[index]) {
287
+ return (/** @type {?} */ (existing));
288
+ }
289
+ /** @type {?} */
290
+ var clone = existing.slice();
291
+ clone[index] = (/** @type {?} */ (value));
292
+ return clone;
293
+ });
294
294
  }
295
295
 
296
- /**
297
- * @fileoverview added by tsickle
298
- * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
299
- */
300
- /**
301
- * @template T
302
- * @param {?} selector - index or predicate to remove an item from an array by
303
- * @return {?}
304
- */
305
- function removeItem(selector) {
306
- return (/**
307
- * @param {?} existing
308
- * @return {?}
309
- */
310
- function removeItemOperator(existing) {
311
- /** @type {?} */
312
- var index = -1;
313
- if (isPredicate(selector)) {
314
- index = existing.findIndex(selector);
315
- }
316
- else if (isNumber(selector)) {
317
- index = selector;
318
- }
319
- if (invalidIndex(index)) {
320
- return (/** @type {?} */ (existing));
321
- }
322
- /** @type {?} */
323
- var clone = existing.slice();
324
- clone.splice(index, 1);
325
- return clone;
326
- });
296
+ /**
297
+ * @fileoverview added by tsickle
298
+ * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
299
+ */
300
+ /**
301
+ * @template T
302
+ * @param {?} selector - index or predicate to remove an item from an array by
303
+ * @return {?}
304
+ */
305
+ function removeItem(selector) {
306
+ return (/**
307
+ * @param {?} existing
308
+ * @return {?}
309
+ */
310
+ function removeItemOperator(existing) {
311
+ /** @type {?} */
312
+ var index = -1;
313
+ if (isPredicate(selector)) {
314
+ index = existing.findIndex(selector);
315
+ }
316
+ else if (isNumber(selector)) {
317
+ index = selector;
318
+ }
319
+ if (invalidIndex(index)) {
320
+ return (/** @type {?} */ (existing));
321
+ }
322
+ /** @type {?} */
323
+ var clone = existing.slice();
324
+ clone.splice(index, 1);
325
+ return clone;
326
+ });
327
327
  }
328
328
 
329
- /**
330
- * @fileoverview added by tsickle
331
- * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
329
+ /**
330
+ * @fileoverview added by tsickle
331
+ * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
332
332
  */
333
333
 
334
- /**
335
- * @fileoverview added by tsickle
336
- * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
334
+ /**
335
+ * @fileoverview added by tsickle
336
+ * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
337
337
  */
338
338
 
339
339
  export { append, compose, iif, insertItem, isStateOperator, patch, removeItem, updateItem };