xstate 4.35.2 → 5.0.0-alpha.1

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 (203) hide show
  1. package/README.md +25 -16
  2. package/actions/dist/xstate-actions.cjs.d.ts +1 -0
  3. package/actions/dist/xstate-actions.cjs.dev.js +30 -0
  4. package/actions/dist/xstate-actions.cjs.js +7 -0
  5. package/actions/dist/xstate-actions.cjs.prod.js +30 -0
  6. package/actions/dist/xstate-actions.esm.js +2 -0
  7. package/actions/dist/xstate-actions.umd.min.js +2 -0
  8. package/actions/dist/xstate-actions.umd.min.js.map +1 -0
  9. package/actions/dynamicAction.ts +34 -0
  10. package/actions/package.json +8 -0
  11. package/actors/dist/xstate-actors.cjs.d.ts +1 -0
  12. package/actors/dist/xstate-actors.cjs.dev.js +20 -0
  13. package/actors/dist/xstate-actors.cjs.js +7 -0
  14. package/actors/dist/xstate-actors.cjs.prod.js +20 -0
  15. package/actors/dist/xstate-actors.esm.js +2 -0
  16. package/actors/dist/xstate-actors.umd.min.js +2 -0
  17. package/actors/dist/xstate-actors.umd.min.js.map +1 -0
  18. package/actors/package.json +8 -0
  19. package/dev/dist/xstate-dev.cjs.d.ts +1 -0
  20. package/dev/dist/xstate-dev.cjs.dev.js +11 -0
  21. package/dev/dist/xstate-dev.cjs.js +7 -0
  22. package/{lib/devTools.js → dev/dist/xstate-dev.cjs.prod.js} +17 -10
  23. package/dev/dist/xstate-dev.esm.js +1 -0
  24. package/dev/dist/xstate-dev.umd.min.js +2 -0
  25. package/dev/dist/xstate-dev.umd.min.js.map +1 -0
  26. package/dev/package.json +8 -0
  27. package/dist/actions-7ea9280f.cjs.prod.js +4674 -0
  28. package/dist/actions-b08d0da8.cjs.dev.js +4718 -0
  29. package/dist/actions-b673cb13.esm.js +4660 -0
  30. package/dist/declarations/actions/dynamicAction.d.ts +5 -0
  31. package/dist/declarations/src/Machine.d.ts +4 -0
  32. package/dist/declarations/src/Mailbox.d.ts +12 -0
  33. package/{es → dist/declarations/src}/SimulatedClock.d.ts +16 -17
  34. package/dist/declarations/src/State.d.ts +97 -0
  35. package/dist/declarations/src/StateMachine.d.ts +120 -0
  36. package/dist/declarations/src/StateNode.d.ts +127 -0
  37. package/{es → dist/declarations/src}/actionTypes.d.ts +16 -20
  38. package/dist/declarations/src/actions/assign.d.ts +7 -0
  39. package/dist/declarations/src/actions/cancel.d.ts +10 -0
  40. package/dist/declarations/src/actions/choose.d.ts +3 -0
  41. package/dist/declarations/src/actions/invoke.d.ts +3 -0
  42. package/dist/declarations/src/actions/log.d.ts +11 -0
  43. package/dist/declarations/src/actions/pure.d.ts +3 -0
  44. package/dist/declarations/src/actions/raise.d.ts +9 -0
  45. package/dist/declarations/src/actions/send.d.ts +51 -0
  46. package/dist/declarations/src/actions/stop.d.ts +7 -0
  47. package/dist/declarations/src/actions.d.ts +43 -0
  48. package/dist/declarations/src/actors.d.ts +37 -0
  49. package/dist/declarations/src/constants.d.ts +5 -0
  50. package/{lib/devTools.d.ts → dist/declarations/src/dev/index.d.ts} +14 -14
  51. package/{es → dist/declarations/src}/environment.d.ts +1 -2
  52. package/dist/declarations/src/guards.d.ts +8 -0
  53. package/dist/declarations/src/index.d.ts +44 -0
  54. package/dist/declarations/src/interpreter.d.ts +108 -0
  55. package/{es → dist/declarations/src}/mapState.d.ts +3 -4
  56. package/dist/declarations/src/memo.d.ts +2 -0
  57. package/dist/declarations/src/registry.d.ts +8 -0
  58. package/{es → dist/declarations/src}/schema.d.ts +2 -3
  59. package/dist/declarations/src/spawn.d.ts +2 -0
  60. package/dist/declarations/src/stateUtils.d.ts +70 -0
  61. package/dist/declarations/src/symbolObservable.d.ts +1 -0
  62. package/{lib → dist/declarations/src}/typegenTypes.d.ts +132 -133
  63. package/dist/declarations/src/types.d.ts +1001 -0
  64. package/dist/declarations/src/utils.d.ts +54 -0
  65. package/{es/devTools.js → dist/index-20b364c4.esm.js} +18 -6
  66. package/dist/index-2a564d03.cjs.dev.js +64 -0
  67. package/dist/xstate.cjs.d.ts +1 -0
  68. package/dist/xstate.cjs.dev.js +993 -0
  69. package/dist/xstate.cjs.js +7 -0
  70. package/dist/xstate.cjs.prod.js +993 -0
  71. package/dist/xstate.esm.js +952 -0
  72. package/dist/xstate.umd.min.js +2 -0
  73. package/dist/xstate.umd.min.js.map +1 -0
  74. package/guards/dist/xstate-guards.cjs.d.ts +1 -0
  75. package/guards/dist/xstate-guards.cjs.dev.js +15 -0
  76. package/guards/dist/xstate-guards.cjs.js +7 -0
  77. package/guards/dist/xstate-guards.cjs.prod.js +15 -0
  78. package/guards/dist/xstate-guards.esm.js +2 -0
  79. package/guards/dist/xstate-guards.umd.min.js +2 -0
  80. package/guards/dist/xstate-guards.umd.min.js.map +1 -0
  81. package/guards/package.json +8 -0
  82. package/invoke/package.json +4 -0
  83. package/package.json +44 -30
  84. package/dist/xstate.interpreter.js +0 -15
  85. package/dist/xstate.js +0 -15
  86. package/dist/xstate.web.js +0 -15
  87. package/es/Actor.d.ts +0 -25
  88. package/es/Actor.js +0 -99
  89. package/es/Machine.d.ts +0 -12
  90. package/es/Machine.js +0 -21
  91. package/es/SimulatedClock.js +0 -81
  92. package/es/State.d.ts +0 -123
  93. package/es/State.js +0 -274
  94. package/es/StateNode.d.ts +0 -282
  95. package/es/StateNode.js +0 -1587
  96. package/es/_virtual/_tslib.js +0 -78
  97. package/es/actionTypes.js +0 -22
  98. package/es/actions.d.ts +0 -157
  99. package/es/actions.js +0 -630
  100. package/es/behaviors.d.ts +0 -37
  101. package/es/behaviors.js +0 -131
  102. package/es/constants.d.ts +0 -6
  103. package/es/constants.js +0 -6
  104. package/es/devTools.d.ts +0 -14
  105. package/es/each.d.ts +0 -4
  106. package/es/each.js +0 -13
  107. package/es/environment.js +0 -3
  108. package/es/index.d.ts +0 -22
  109. package/es/index.js +0 -25
  110. package/es/interpreter.d.ts +0 -217
  111. package/es/interpreter.js +0 -1488
  112. package/es/invoke.d.ts +0 -11
  113. package/es/invokeUtils.d.ts +0 -7
  114. package/es/invokeUtils.js +0 -40
  115. package/es/json.d.ts +0 -31
  116. package/es/json.js +0 -86
  117. package/es/mapState.js +0 -32
  118. package/es/match.d.ts +0 -9
  119. package/es/match.js +0 -34
  120. package/es/model.d.ts +0 -8
  121. package/es/model.js +0 -50
  122. package/es/model.types.d.ts +0 -56
  123. package/es/patterns.d.ts +0 -14
  124. package/es/patterns.js +0 -48
  125. package/es/registry.d.ts +0 -9
  126. package/es/registry.js +0 -19
  127. package/es/scheduler.d.ts +0 -17
  128. package/es/scheduler.js +0 -79
  129. package/es/schema.js +0 -6
  130. package/es/scxml.d.ts +0 -6
  131. package/es/serviceScope.d.ts +0 -4
  132. package/es/serviceScope.js +0 -16
  133. package/es/stateUtils.d.ts +0 -18
  134. package/es/stateUtils.js +0 -262
  135. package/es/typegenTypes.d.ts +0 -133
  136. package/es/types.d.ts +0 -1040
  137. package/es/types.js +0 -33
  138. package/es/utils.d.ts +0 -72
  139. package/es/utils.js +0 -622
  140. package/es/waitFor.d.ts +0 -34
  141. package/es/waitFor.js +0 -73
  142. package/lib/Actor.d.ts +0 -25
  143. package/lib/Actor.js +0 -108
  144. package/lib/Machine.d.ts +0 -12
  145. package/lib/Machine.js +0 -26
  146. package/lib/SimulatedClock.d.ts +0 -17
  147. package/lib/SimulatedClock.js +0 -85
  148. package/lib/State.d.ts +0 -123
  149. package/lib/State.js +0 -282
  150. package/lib/StateNode.d.ts +0 -282
  151. package/lib/StateNode.js +0 -1591
  152. package/lib/_virtual/_tslib.js +0 -85
  153. package/lib/actionTypes.d.ts +0 -20
  154. package/lib/actionTypes.js +0 -43
  155. package/lib/actions.d.ts +0 -157
  156. package/lib/actions.js +0 -662
  157. package/lib/behaviors.d.ts +0 -37
  158. package/lib/behaviors.js +0 -137
  159. package/lib/constants.d.ts +0 -6
  160. package/lib/constants.js +0 -13
  161. package/lib/each.d.ts +0 -4
  162. package/lib/each.js +0 -17
  163. package/lib/environment.d.ts +0 -2
  164. package/lib/environment.js +0 -7
  165. package/lib/index.d.ts +0 -22
  166. package/lib/index.js +0 -64
  167. package/lib/interpreter.d.ts +0 -217
  168. package/lib/interpreter.js +0 -1494
  169. package/lib/invoke.d.ts +0 -11
  170. package/lib/invoke.js +0 -20
  171. package/lib/invokeUtils.d.ts +0 -7
  172. package/lib/invokeUtils.js +0 -45
  173. package/lib/json.d.ts +0 -31
  174. package/lib/json.js +0 -94
  175. package/lib/mapState.d.ts +0 -4
  176. package/lib/mapState.js +0 -36
  177. package/lib/match.d.ts +0 -9
  178. package/lib/match.js +0 -38
  179. package/lib/model.d.ts +0 -8
  180. package/lib/model.js +0 -54
  181. package/lib/model.types.d.ts +0 -56
  182. package/lib/model.types.js +0 -2
  183. package/lib/patterns.d.ts +0 -14
  184. package/lib/patterns.js +0 -53
  185. package/lib/registry.d.ts +0 -9
  186. package/lib/registry.js +0 -23
  187. package/lib/scheduler.d.ts +0 -17
  188. package/lib/scheduler.js +0 -83
  189. package/lib/schema.d.ts +0 -3
  190. package/lib/schema.js +0 -11
  191. package/lib/scxml.d.ts +0 -6
  192. package/lib/scxml.js +0 -350
  193. package/lib/serviceScope.d.ts +0 -4
  194. package/lib/serviceScope.js +0 -21
  195. package/lib/stateUtils.d.ts +0 -18
  196. package/lib/stateUtils.js +0 -277
  197. package/lib/typegenTypes.js +0 -2
  198. package/lib/types.d.ts +0 -1040
  199. package/lib/types.js +0 -35
  200. package/lib/utils.d.ts +0 -72
  201. package/lib/utils.js +0 -669
  202. package/lib/waitFor.d.ts +0 -34
  203. package/lib/waitFor.js +0 -77
@@ -0,0 +1,4660 @@
1
+ import { I as IS_PRODUCTION, d as devToolsAdapter } from './index-20b364c4.esm.js';
2
+
3
+ // https://github.com/microsoft/TypeScript/issues/23182#issuecomment-379091887
4
+ // TODO: replace in v5 with:
5
+ // export type IndexByType<T extends { type: string }> = { [E in T as E['type']]: E; };
6
+
7
+ /**
8
+ * The full definition of an event, with a string `type`.
9
+ */
10
+ // TODO: do not accept machines without all implementations
11
+ // we should also accept a raw machine as a behavior here
12
+ // or just make machine a behavior
13
+ // TODO: narrow this to behaviors from machine
14
+ // TODO: fix last param
15
+
16
+ /**
17
+ * Extracts action objects that have no extra properties.
18
+ */
19
+
20
+ /**
21
+ * The string or object representing the state value relative to the parent state node.
22
+ *
23
+ * - For a child atomic state node, this is a string, e.g., `"pending"`.
24
+ * - For complex state nodes, this is an object, e.g., `{ success: "someChildState" }`.
25
+ */
26
+ // TODO: remove once TS fixes this type-widening issue
27
+ // TODO: possibly refactor this somehow, use even a simpler type, and maybe even make `machine.options` private or something
28
+ var ActionTypes;
29
+
30
+ (function (ActionTypes) {
31
+ ActionTypes["Stop"] = "xstate.stop";
32
+ ActionTypes["Raise"] = "xstate.raise";
33
+ ActionTypes["Send"] = "xstate.send";
34
+ ActionTypes["Cancel"] = "xstate.cancel";
35
+ ActionTypes["Assign"] = "xstate.assign";
36
+ ActionTypes["After"] = "xstate.after";
37
+ ActionTypes["DoneState"] = "done.state";
38
+ ActionTypes["DoneInvoke"] = "done.invoke";
39
+ ActionTypes["Log"] = "xstate.log";
40
+ ActionTypes["Init"] = "xstate.init";
41
+ ActionTypes["Invoke"] = "xstate.invoke";
42
+ ActionTypes["ErrorExecution"] = "error.execution";
43
+ ActionTypes["ErrorCommunication"] = "error.communication";
44
+ ActionTypes["ErrorPlatform"] = "error.platform";
45
+ ActionTypes["ErrorCustom"] = "xstate.error";
46
+ ActionTypes["Pure"] = "xstate.pure";
47
+ ActionTypes["Choose"] = "xstate.choose";
48
+ })(ActionTypes || (ActionTypes = {}));
49
+
50
+ var SpecialTargets;
51
+
52
+ (function (SpecialTargets) {
53
+ SpecialTargets["Parent"] = "#_parent";
54
+ SpecialTargets["Internal"] = "#_internal";
55
+ })(SpecialTargets || (SpecialTargets = {}));
56
+
57
+ var stop = ActionTypes.Stop;
58
+ var raise = ActionTypes.Raise;
59
+ var send = ActionTypes.Send;
60
+ var cancel = ActionTypes.Cancel;
61
+ var assign = ActionTypes.Assign;
62
+ var after = ActionTypes.After;
63
+ var doneState = ActionTypes.DoneState;
64
+ var log = ActionTypes.Log;
65
+ var init = ActionTypes.Init;
66
+ var invoke = ActionTypes.Invoke;
67
+ var errorExecution = ActionTypes.ErrorExecution;
68
+ var errorPlatform = ActionTypes.ErrorPlatform;
69
+ var error = ActionTypes.ErrorCustom;
70
+ var choose = ActionTypes.Choose;
71
+ var pure = ActionTypes.Pure;
72
+
73
+ var actionTypes = /*#__PURE__*/Object.freeze({
74
+ __proto__: null,
75
+ stop: stop,
76
+ raise: raise,
77
+ send: send,
78
+ cancel: cancel,
79
+ assign: assign,
80
+ after: after,
81
+ doneState: doneState,
82
+ log: log,
83
+ init: init,
84
+ invoke: invoke,
85
+ errorExecution: errorExecution,
86
+ errorPlatform: errorPlatform,
87
+ error: error,
88
+ choose: choose,
89
+ pure: pure
90
+ });
91
+
92
+ function _defineProperty(obj, key, value) {
93
+ if (key in obj) {
94
+ Object.defineProperty(obj, key, {
95
+ value: value,
96
+ enumerable: true,
97
+ configurable: true,
98
+ writable: true
99
+ });
100
+ } else {
101
+ obj[key] = value;
102
+ }
103
+
104
+ return obj;
105
+ }
106
+
107
+ function ownKeys(object, enumerableOnly) {
108
+ var keys = Object.keys(object);
109
+
110
+ if (Object.getOwnPropertySymbols) {
111
+ var symbols = Object.getOwnPropertySymbols(object);
112
+ if (enumerableOnly) symbols = symbols.filter(function (sym) {
113
+ return Object.getOwnPropertyDescriptor(object, sym).enumerable;
114
+ });
115
+ keys.push.apply(keys, symbols);
116
+ }
117
+
118
+ return keys;
119
+ }
120
+
121
+ function _objectSpread2(target) {
122
+ for (var i = 1; i < arguments.length; i++) {
123
+ var source = arguments[i] != null ? arguments[i] : {};
124
+
125
+ if (i % 2) {
126
+ ownKeys(Object(source), true).forEach(function (key) {
127
+ _defineProperty(target, key, source[key]);
128
+ });
129
+ } else if (Object.getOwnPropertyDescriptors) {
130
+ Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));
131
+ } else {
132
+ ownKeys(Object(source)).forEach(function (key) {
133
+ Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
134
+ });
135
+ }
136
+ }
137
+
138
+ return target;
139
+ }
140
+
141
+ function _arrayWithHoles(arr) {
142
+ if (Array.isArray(arr)) return arr;
143
+ }
144
+
145
+ function _iterableToArrayLimit(arr, i) {
146
+ if (typeof Symbol === "undefined" || !(Symbol.iterator in Object(arr))) return;
147
+ var _arr = [];
148
+ var _n = true;
149
+ var _d = false;
150
+ var _e = undefined;
151
+
152
+ try {
153
+ for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) {
154
+ _arr.push(_s.value);
155
+
156
+ if (i && _arr.length === i) break;
157
+ }
158
+ } catch (err) {
159
+ _d = true;
160
+ _e = err;
161
+ } finally {
162
+ try {
163
+ if (!_n && _i["return"] != null) _i["return"]();
164
+ } finally {
165
+ if (_d) throw _e;
166
+ }
167
+ }
168
+
169
+ return _arr;
170
+ }
171
+
172
+ function _arrayLikeToArray(arr, len) {
173
+ if (len == null || len > arr.length) len = arr.length;
174
+
175
+ for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i];
176
+
177
+ return arr2;
178
+ }
179
+
180
+ function _unsupportedIterableToArray(o, minLen) {
181
+ if (!o) return;
182
+ if (typeof o === "string") return _arrayLikeToArray(o, minLen);
183
+ var n = Object.prototype.toString.call(o).slice(8, -1);
184
+ if (n === "Object" && o.constructor) n = o.constructor.name;
185
+ if (n === "Map" || n === "Set") return Array.from(o);
186
+ if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen);
187
+ }
188
+
189
+ function _nonIterableRest() {
190
+ throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
191
+ }
192
+
193
+ function _slicedToArray(arr, i) {
194
+ return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest();
195
+ }
196
+
197
+ function _arrayWithoutHoles(arr) {
198
+ if (Array.isArray(arr)) return _arrayLikeToArray(arr);
199
+ }
200
+
201
+ function _iterableToArray(iter) {
202
+ if (typeof Symbol !== "undefined" && Symbol.iterator in Object(iter)) return Array.from(iter);
203
+ }
204
+
205
+ function _nonIterableSpread() {
206
+ throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
207
+ }
208
+
209
+ function _toConsumableArray(arr) {
210
+ return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread();
211
+ }
212
+
213
+ function _createForOfIteratorHelper(o, allowArrayLike) {
214
+ var it;
215
+
216
+ if (typeof Symbol === "undefined" || o[Symbol.iterator] == null) {
217
+ if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") {
218
+ if (it) o = it;
219
+ var i = 0;
220
+
221
+ var F = function () {};
222
+
223
+ return {
224
+ s: F,
225
+ n: function () {
226
+ if (i >= o.length) return {
227
+ done: true
228
+ };
229
+ return {
230
+ done: false,
231
+ value: o[i++]
232
+ };
233
+ },
234
+ e: function (e) {
235
+ throw e;
236
+ },
237
+ f: F
238
+ };
239
+ }
240
+
241
+ throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
242
+ }
243
+
244
+ var normalCompletion = true,
245
+ didErr = false,
246
+ err;
247
+ return {
248
+ s: function () {
249
+ it = o[Symbol.iterator]();
250
+ },
251
+ n: function () {
252
+ var step = it.next();
253
+ normalCompletion = step.done;
254
+ return step;
255
+ },
256
+ e: function (e) {
257
+ didErr = true;
258
+ err = e;
259
+ },
260
+ f: function () {
261
+ try {
262
+ if (!normalCompletion && it.return != null) it.return();
263
+ } finally {
264
+ if (didErr) throw err;
265
+ }
266
+ }
267
+ };
268
+ }
269
+
270
+ function _typeof(obj) {
271
+ "@babel/helpers - typeof";
272
+
273
+ if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") {
274
+ _typeof = function (obj) {
275
+ return typeof obj;
276
+ };
277
+ } else {
278
+ _typeof = function (obj) {
279
+ return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj;
280
+ };
281
+ }
282
+
283
+ return _typeof(obj);
284
+ }
285
+
286
+ var STATE_DELIMITER = '.';
287
+ var TARGETLESS_KEY = '';
288
+ var NULL_EVENT = '';
289
+ var STATE_IDENTIFIER = '#';
290
+ var WILDCARD = '*';
291
+
292
+ function matchesState(parentStateId, childStateId) {
293
+ var delimiter = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : STATE_DELIMITER;
294
+ var parentStateValue = toStateValue(parentStateId, delimiter);
295
+ var childStateValue = toStateValue(childStateId, delimiter);
296
+
297
+ if (isString(childStateValue)) {
298
+ if (isString(parentStateValue)) {
299
+ return childStateValue === parentStateValue;
300
+ } // Parent more specific than child
301
+
302
+
303
+ return false;
304
+ }
305
+
306
+ if (isString(parentStateValue)) {
307
+ return parentStateValue in childStateValue;
308
+ }
309
+
310
+ return Object.keys(parentStateValue).every(function (key) {
311
+ if (!(key in childStateValue)) {
312
+ return false;
313
+ }
314
+
315
+ return matchesState(parentStateValue[key], childStateValue[key]);
316
+ });
317
+ }
318
+ function toStatePath(stateId, delimiter) {
319
+ try {
320
+ if (isArray(stateId)) {
321
+ return stateId;
322
+ }
323
+
324
+ return stateId.toString().split(delimiter);
325
+ } catch (e) {
326
+ throw new Error("'".concat(stateId, "' is not a valid state path."));
327
+ }
328
+ }
329
+ function isStateLike(state) {
330
+ return _typeof(state) === 'object' && 'value' in state && 'context' in state && 'event' in state && '_event' in state;
331
+ }
332
+ function toStateValue(stateValue, delimiter) {
333
+ if (isStateLike(stateValue)) {
334
+ return stateValue.value;
335
+ }
336
+
337
+ if (isArray(stateValue)) {
338
+ return pathToStateValue(stateValue);
339
+ }
340
+
341
+ if (typeof stateValue !== 'string') {
342
+ return stateValue;
343
+ }
344
+
345
+ var statePath = toStatePath(stateValue, delimiter);
346
+ return pathToStateValue(statePath);
347
+ }
348
+ function pathToStateValue(statePath) {
349
+ if (statePath.length === 1) {
350
+ return statePath[0];
351
+ }
352
+
353
+ var value = {};
354
+ var marker = value;
355
+
356
+ for (var _i = 0; _i < statePath.length - 1; _i++) {
357
+ if (_i === statePath.length - 2) {
358
+ marker[statePath[_i]] = statePath[_i + 1];
359
+ } else {
360
+ marker[statePath[_i]] = {};
361
+ marker = marker[statePath[_i]];
362
+ }
363
+ }
364
+
365
+ return value;
366
+ }
367
+ function mapValues(collection, iteratee) {
368
+ var result = {};
369
+ var collectionKeys = Object.keys(collection);
370
+
371
+ for (var _i2 = 0; _i2 < collectionKeys.length; _i2++) {
372
+ var _key = collectionKeys[_i2];
373
+ result[_key] = iteratee(collection[_key], _key, collection, _i2);
374
+ }
375
+
376
+ return result;
377
+ }
378
+ function flatten(array) {
379
+ var _ref;
380
+
381
+ return (_ref = []).concat.apply(_ref, _toConsumableArray(array));
382
+ }
383
+ function toArrayStrict(value) {
384
+ if (isArray(value)) {
385
+ return value;
386
+ }
387
+
388
+ return [value];
389
+ }
390
+ function toArray(value) {
391
+ if (value === undefined) {
392
+ return [];
393
+ }
394
+
395
+ return toArrayStrict(value);
396
+ }
397
+ function mapContext(mapper, context, _event) {
398
+ if (isFunction(mapper)) {
399
+ return mapper(context, _event.data);
400
+ }
401
+
402
+ var result = {};
403
+
404
+ for (var _i4 = 0, _Object$keys2 = Object.keys(mapper); _i4 < _Object$keys2.length; _i4++) {
405
+ var _key3 = _Object$keys2[_i4];
406
+ var subMapper = mapper[_key3];
407
+
408
+ if (isFunction(subMapper)) {
409
+ result[_key3] = subMapper(context, _event.data);
410
+ } else {
411
+ result[_key3] = subMapper;
412
+ }
413
+ }
414
+
415
+ return result;
416
+ }
417
+ function isPromiseLike(value) {
418
+ if (value instanceof Promise) {
419
+ return true;
420
+ } // Check if shape matches the Promise/A+ specification for a "thenable".
421
+
422
+
423
+ if (value !== null && (isFunction(value) || _typeof(value) === 'object') && isFunction(value.then)) {
424
+ return true;
425
+ }
426
+
427
+ return false;
428
+ }
429
+
430
+ var warn = function warn() {};
431
+
432
+ if (!IS_PRODUCTION) {
433
+ warn = function warn(condition, message) {
434
+ var error = condition instanceof Error ? condition : undefined;
435
+
436
+ if (!error && condition) {
437
+ return;
438
+ }
439
+
440
+ if (console !== undefined) {
441
+ var args = ["Warning: ".concat(message)];
442
+
443
+ if (error) {
444
+ args.push(error);
445
+ } // tslint:disable-next-line:no-console
446
+
447
+
448
+ console.warn.apply(console, args);
449
+ }
450
+ };
451
+ }
452
+
453
+ function isArray(value) {
454
+ return Array.isArray(value);
455
+ } // tslint:disable-next-line:ban-types
456
+
457
+ function isFunction(value) {
458
+ return typeof value === 'function';
459
+ }
460
+ function isString(value) {
461
+ return typeof value === 'string';
462
+ }
463
+ function isStateMachine(value) {
464
+ return !!value && '__xstatenode' in value;
465
+ }
466
+ function isSCXMLEvent(event) {
467
+ return '$$type' in event && event.$$type === 'scxml';
468
+ }
469
+ function isSCXMLErrorEvent(event) {
470
+ return typeof event.name === 'string' && (event.name === errorExecution || event.name.startsWith(errorPlatform));
471
+ }
472
+ function toSCXMLEvent(event, scxmlEvent) {
473
+ if (isSCXMLEvent(event)) {
474
+ return event;
475
+ }
476
+
477
+ return _objectSpread2({
478
+ name: event.type,
479
+ data: event,
480
+ $$type: 'scxml',
481
+ type: 'external'
482
+ }, scxmlEvent);
483
+ }
484
+ function toTransitionConfigArray(event, configLike) {
485
+ var transitions = toArrayStrict(configLike).map(function (transitionLike) {
486
+ if (typeof transitionLike === 'undefined' || typeof transitionLike === 'string' || isStateMachine(transitionLike)) {
487
+ return {
488
+ target: transitionLike,
489
+ event: event
490
+ };
491
+ }
492
+
493
+ return _objectSpread2(_objectSpread2({}, transitionLike), {}, {
494
+ event: event
495
+ });
496
+ });
497
+ return transitions;
498
+ }
499
+ function normalizeTarget(target) {
500
+ if (target === undefined || target === TARGETLESS_KEY) {
501
+ return undefined;
502
+ }
503
+
504
+ return toArray(target);
505
+ }
506
+ function toInvokeConfig(invocable, id) {
507
+ if (_typeof(invocable) === 'object') {
508
+ if ('src' in invocable) {
509
+ return invocable;
510
+ }
511
+
512
+ if ('transition' in invocable) {
513
+ return {
514
+ id: id,
515
+ src: invocable
516
+ };
517
+ }
518
+ }
519
+
520
+ return {
521
+ id: id,
522
+ src: invocable
523
+ };
524
+ }
525
+ function toInvokeSource(src) {
526
+ if (typeof src === 'string') {
527
+ return {
528
+ type: src
529
+ };
530
+ }
531
+
532
+ return src;
533
+ }
534
+ function toObserver(nextHandler, errorHandler, completionHandler) {
535
+ var noop = function noop() {};
536
+
537
+ var isObserver = _typeof(nextHandler) === 'object';
538
+ var self = isObserver ? nextHandler : null;
539
+ return {
540
+ next: ((isObserver ? nextHandler.next : nextHandler) || noop).bind(self),
541
+ error: ((isObserver ? nextHandler.error : errorHandler) || noop).bind(self),
542
+ complete: ((isObserver ? nextHandler.complete : completionHandler) || noop).bind(self)
543
+ };
544
+ }
545
+ function createInvokeId(stateNodeId, index) {
546
+ return "".concat(stateNodeId, ":invocation[").concat(index, "]");
547
+ }
548
+
549
+ function createDynamicAction(action, resolve) {
550
+ return {
551
+ type: action.type,
552
+ params: action.params,
553
+ resolve: resolve
554
+ };
555
+ }
556
+ function isDynamicAction(action) {
557
+ return _typeof(action) === 'object' && action !== null && 'resolve' in action;
558
+ }
559
+
560
+ /**
561
+ * Sends an event. This returns an action that will be read by an interpreter to
562
+ * send the event in the next step, after the current step is finished executing.
563
+ *
564
+ * @param event The event to send.
565
+ * @param options Options to pass into the send event:
566
+ * - `id` - The unique send event identifier (used with `cancel()`).
567
+ * - `delay` - The number of milliseconds to delay the sending of the event.
568
+ * - `to` - The target of this event (by default, the machine the event was sent from).
569
+ */
570
+
571
+ function send$1(event, options) {
572
+ var eventOrExpr = isFunction(event) ? event : event;
573
+ return createDynamicAction({
574
+ type: send,
575
+ params: {
576
+ to: options ? options.to : undefined,
577
+ delay: options ? options.delay : undefined,
578
+ event: eventOrExpr,
579
+ id: options && options.id !== undefined ? options.id : isFunction(event) ? event.name : event.type
580
+ }
581
+ }, function (_event, _ref) {
582
+ var actorContext = _ref.actorContext,
583
+ state = _ref.state;
584
+ var params = {
585
+ to: options ? options.to : undefined,
586
+ delay: options ? options.delay : undefined,
587
+ event: eventOrExpr,
588
+ id: options && options.id !== undefined ? options.id : isFunction(event) ? event.name : event.type
589
+ };
590
+ var meta = {
591
+ _event: _event
592
+ };
593
+ var delaysMap = state.machine.options.delays; // TODO: helper function for resolving Expr
594
+
595
+ var resolvedEvent = toSCXMLEvent(isFunction(eventOrExpr) ? eventOrExpr(state.context, _event.data, meta) : eventOrExpr);
596
+ var resolvedDelay;
597
+
598
+ if (isString(params.delay)) {
599
+ var configDelay = delaysMap && delaysMap[params.delay];
600
+ resolvedDelay = isFunction(configDelay) ? configDelay(state.context, _event.data, meta) : configDelay;
601
+ } else {
602
+ resolvedDelay = isFunction(params.delay) ? params.delay(state.context, _event.data, meta) : params.delay;
603
+ }
604
+
605
+ var resolvedTarget = isFunction(params.to) ? params.to(state.context, _event.data, meta) : params.to;
606
+ var targetActorRef;
607
+
608
+ if (typeof resolvedTarget === 'string') {
609
+ if (resolvedTarget === SpecialTargets.Parent) {
610
+ targetActorRef = actorContext === null || actorContext === void 0 ? void 0 : actorContext.self._parent;
611
+ } else if (resolvedTarget === SpecialTargets.Internal) {
612
+ targetActorRef = actorContext === null || actorContext === void 0 ? void 0 : actorContext.self;
613
+ } else if (resolvedTarget.startsWith('#_')) {
614
+ // SCXML compatibility: https://www.w3.org/TR/scxml/#SCXMLEventProcessor
615
+ // #_invokeid. If the target is the special term '#_invokeid', where invokeid is the invokeid of an SCXML session that the sending session has created by <invoke>, the Processor must add the event to the external queue of that session.
616
+ targetActorRef = state.children[resolvedTarget.slice(2)];
617
+ } else {
618
+ targetActorRef = state.children[resolvedTarget];
619
+ }
620
+
621
+ if (!targetActorRef) {
622
+ throw new Error("Unable to send event to actor '".concat(resolvedTarget, "' from machine '").concat(state.machine.id, "'."));
623
+ }
624
+ } else {
625
+ targetActorRef = resolvedTarget || (actorContext === null || actorContext === void 0 ? void 0 : actorContext.self);
626
+ }
627
+
628
+ var resolvedAction = {
629
+ type: send,
630
+ params: _objectSpread2(_objectSpread2({}, params), {}, {
631
+ to: targetActorRef,
632
+ _event: resolvedEvent,
633
+ event: resolvedEvent.data,
634
+ delay: resolvedDelay,
635
+ internal: resolvedTarget === SpecialTargets.Internal
636
+ }),
637
+ execute: function execute(actorCtx) {
638
+ var sendAction = resolvedAction;
639
+
640
+ if (typeof sendAction.params.delay === 'number') {
641
+ actorCtx.self.delaySend(sendAction);
642
+ return;
643
+ } else {
644
+ var target = sendAction.params.to;
645
+ var _event2 = sendAction.params._event;
646
+ actorCtx.defer(function () {
647
+ var origin = actorCtx.self;
648
+
649
+ var resolvedEvent = _objectSpread2(_objectSpread2({}, _event2), {}, {
650
+ name: _event2.name === error ? "".concat(error$1(origin.id)) : _event2.name,
651
+ origin: origin
652
+ });
653
+
654
+ target.send(resolvedEvent);
655
+ });
656
+ }
657
+ }
658
+ };
659
+ return [state, resolvedAction];
660
+ });
661
+ }
662
+ /**
663
+ * Sends an event to this machine's parent.
664
+ *
665
+ * @param event The event to send to the parent machine.
666
+ * @param options Options to pass into the send event.
667
+ */
668
+
669
+ function sendParent(event, options) {
670
+ return send$1(event, _objectSpread2(_objectSpread2({}, options), {}, {
671
+ to: SpecialTargets.Parent
672
+ }));
673
+ }
674
+ /**
675
+ * Sends an event back to the sender of the original event.
676
+ *
677
+ * @param event The event to send back to the sender
678
+ * @param options Options to pass into the send event
679
+ */
680
+
681
+ function respond(event, options) {
682
+ return send$1(event, _objectSpread2(_objectSpread2({}, options), {}, {
683
+ to: function to(_, __, _ref2) {
684
+ var _event = _ref2._event;
685
+ return _event.origin; // TODO: handle when _event.origin is undefined
686
+ }
687
+ }));
688
+ }
689
+ /**
690
+ * Forwards (sends) an event to a specified service.
691
+ *
692
+ * @param target The target service to forward the event to.
693
+ * @param options Options to pass into the send action creator.
694
+ */
695
+
696
+ function forwardTo(target, options) {
697
+ if (process.env.NODE_END !== 'production' && (!target || typeof target === 'function')) {
698
+ var originalTarget = target;
699
+
700
+ target = function target() {
701
+ var resolvedTarget = typeof originalTarget === 'function' ? originalTarget.apply(void 0, arguments) : originalTarget;
702
+
703
+ if (!resolvedTarget) {
704
+ throw new Error("Attempted to forward event to undefined actor. This risks an infinite loop in the sender.");
705
+ }
706
+
707
+ return resolvedTarget;
708
+ };
709
+ }
710
+
711
+ return send$1(function (_, event) {
712
+ return event;
713
+ }, _objectSpread2(_objectSpread2({}, options), {}, {
714
+ to: target
715
+ }));
716
+ }
717
+ /**
718
+ * Escalates an error by sending it as an event to this machine's parent.
719
+ *
720
+ * @param errorData The error data to send, or the expression function that
721
+ * takes in the `context`, `event`, and `meta`, and returns the error data to send.
722
+ * @param options Options to pass into the send action creator.
723
+ */
724
+
725
+ function escalate(errorData, options) {
726
+ return sendParent(function (context, event, meta) {
727
+ return {
728
+ type: error,
729
+ data: isFunction(errorData) ? errorData(context, event, meta) : errorData
730
+ };
731
+ }, _objectSpread2(_objectSpread2({}, options), {}, {
732
+ to: SpecialTargets.Parent
733
+ }));
734
+ }
735
+ /**
736
+ * Sends an event to an actor.
737
+ *
738
+ * @param actor The `ActorRef` to send the event to.
739
+ * @param event The event to send, or an expression that evaluates to the event to send
740
+ * @param options Send action options
741
+ * @returns An XState send action object
742
+ */
743
+
744
+ function sendTo(actor, event, options) {
745
+ return send$1(event, _objectSpread2(_objectSpread2({}, options), {}, {
746
+ to: actor
747
+ }));
748
+ }
749
+
750
+ function _classCallCheck(instance, Constructor) {
751
+ if (!(instance instanceof Constructor)) {
752
+ throw new TypeError("Cannot call a class as a function");
753
+ }
754
+ }
755
+
756
+ function _defineProperties(target, props) {
757
+ for (var i = 0; i < props.length; i++) {
758
+ var descriptor = props[i];
759
+ descriptor.enumerable = descriptor.enumerable || false;
760
+ descriptor.configurable = true;
761
+ if ("value" in descriptor) descriptor.writable = true;
762
+ Object.defineProperty(target, descriptor.key, descriptor);
763
+ }
764
+ }
765
+
766
+ function _createClass(Constructor, protoProps, staticProps) {
767
+ if (protoProps) _defineProperties(Constructor.prototype, protoProps);
768
+ if (staticProps) _defineProperties(Constructor, staticProps);
769
+ return Constructor;
770
+ }
771
+
772
+ var symbolObservable = function () {
773
+ return typeof Symbol === 'function' && Symbol.observable || '@@observable';
774
+ }();
775
+
776
+ /**
777
+ * Returns an actor behavior from a reducer and its initial state.
778
+ *
779
+ * @param transition The pure reducer that returns the next state given the current state and event.
780
+ * @param initialState The initial state of the reducer.
781
+ * @returns An actor behavior
782
+ */
783
+
784
+ function fromReducer(_transition, initialState) {
785
+ return {
786
+ transition: function transition(state, event, actorCtx) {
787
+ // @ts-ignore TODO
788
+ var resolvedEvent = isSCXMLEvent(event) ? event.data : event; // @ts-ignore TODO
789
+
790
+ return _transition(state, resolvedEvent, actorCtx);
791
+ },
792
+ getInitialState: function getInitialState() {
793
+ return initialState;
794
+ },
795
+ getSnapshot: function getSnapshot(state) {
796
+ return state;
797
+ }
798
+ };
799
+ }
800
+ var startSignalType = 'xstate.init';
801
+ var stopSignalType = 'xstate.stop';
802
+ var startSignal = {
803
+ type: 'xstate.init'
804
+ };
805
+ var stopSignal = {
806
+ type: 'xstate.stop'
807
+ };
808
+
809
+ /**
810
+ * An object that expresses the behavior of an actor in reaction to received events,
811
+ * as well as an optionally emitted stream of values.
812
+ *
813
+ * @template TReceived The received event
814
+ * @template TSnapshot The emitted value
815
+ */
816
+ function isSignal(eventType) {
817
+ return eventType === startSignalType || eventType === stopSignalType;
818
+ }
819
+
820
+ function fromCallback(invokeCallback) {
821
+ var behavior = {
822
+ start: function start(state, _ref) {
823
+ var self = _ref.self;
824
+ self.send({
825
+ type: startSignalType
826
+ });
827
+ return state;
828
+ },
829
+ transition: function transition(state, event, _ref2) {
830
+ var self = _ref2.self,
831
+ id = _ref2.id;
832
+
833
+ var _event = toSCXMLEvent(event);
834
+
835
+ if (_event.name === startSignalType) {
836
+ var sender = function sender(eventForParent) {
837
+ var _self$_parent;
838
+
839
+ if (state.canceled) {
840
+ return state;
841
+ }
842
+
843
+ (_self$_parent = self._parent) === null || _self$_parent === void 0 ? void 0 : _self$_parent.send(toSCXMLEvent(eventForParent, {
844
+ origin: self
845
+ }));
846
+ };
847
+
848
+ var receiver = function receiver(newListener) {
849
+ state.receivers.add(newListener);
850
+ };
851
+
852
+ state.dispose = invokeCallback(sender, receiver);
853
+
854
+ if (isPromiseLike(state.dispose)) {
855
+ state.dispose.then(function (resolved) {
856
+ var _self$_parent2;
857
+
858
+ (_self$_parent2 = self._parent) === null || _self$_parent2 === void 0 ? void 0 : _self$_parent2.send(toSCXMLEvent(doneInvoke(id, resolved), {
859
+ origin: self
860
+ }));
861
+ state.canceled = true;
862
+ }, function (errorData) {
863
+ var _self$_parent3;
864
+
865
+ var errorEvent = error$1(id, errorData);
866
+ (_self$_parent3 = self._parent) === null || _self$_parent3 === void 0 ? void 0 : _self$_parent3.send(toSCXMLEvent(errorEvent, {
867
+ origin: self
868
+ }));
869
+ state.canceled = true;
870
+ });
871
+ }
872
+
873
+ return state;
874
+ }
875
+
876
+ if (_event.name === stopSignalType) {
877
+ state.canceled = true;
878
+
879
+ if (isFunction(state.dispose)) {
880
+ state.dispose();
881
+ }
882
+
883
+ return state;
884
+ }
885
+
886
+ if (isSignal(_event.name)) {
887
+ // TODO: unrecognized signal
888
+ return state;
889
+ }
890
+
891
+ var plainEvent = isSCXMLEvent(event) ? event.data : event;
892
+
893
+ if (!isSignal(plainEvent.type)) {
894
+ state.receivers.forEach(function (receiver) {
895
+ return receiver(plainEvent);
896
+ });
897
+ }
898
+
899
+ return state;
900
+ },
901
+ getInitialState: function getInitialState() {
902
+ return {
903
+ canceled: false,
904
+ receivers: new Set(),
905
+ dispose: undefined
906
+ };
907
+ },
908
+ getSnapshot: function getSnapshot() {
909
+ return undefined;
910
+ }
911
+ };
912
+ return behavior;
913
+ }
914
+ function fromPromise(lazyPromise) {
915
+ var resolveEventType = '$$xstate.resolve';
916
+ var rejectEventType = '$$xstate.reject'; // TODO: add event types
917
+
918
+ var behavior = {
919
+ transition: function transition(state, event) {
920
+ var _event = toSCXMLEvent(event);
921
+
922
+ if (state.canceled) {
923
+ return state;
924
+ }
925
+
926
+ var eventObject = _event.data;
927
+
928
+ switch (_event.name) {
929
+ case resolveEventType:
930
+ state.status = 'done';
931
+ state.data = eventObject.data;
932
+ return state;
933
+
934
+ case rejectEventType:
935
+ state.status = 'error';
936
+ state.data = eventObject.data;
937
+ return state;
938
+
939
+ case stopSignalType:
940
+ state.canceled = true;
941
+ return state;
942
+
943
+ default:
944
+ return state;
945
+ }
946
+ },
947
+ start: function start(state, _ref3) {
948
+ var self = _ref3.self;
949
+ var resolvedPromise = Promise.resolve(lazyPromise());
950
+ resolvedPromise.then(function (response) {
951
+ self.send({
952
+ type: resolveEventType,
953
+ data: response
954
+ });
955
+ }, function (errorData) {
956
+ self.send({
957
+ type: rejectEventType,
958
+ data: errorData
959
+ });
960
+ });
961
+ return state;
962
+ },
963
+ getInitialState: function getInitialState() {
964
+ return {
965
+ canceled: false,
966
+ status: 'active',
967
+ data: undefined
968
+ };
969
+ },
970
+ getSnapshot: function getSnapshot(state) {
971
+ return state.data;
972
+ },
973
+ getStatus: function getStatus(state) {
974
+ return state;
975
+ }
976
+ };
977
+ return behavior;
978
+ }
979
+ function fromObservable(lazyObservable) {
980
+ var nextEventType = '$$xstate.next';
981
+ var errorEventType = '$$xstate.error';
982
+ var completeEventType = '$$xstate.complete'; // TODO: add event types
983
+
984
+ var behavior = {
985
+ transition: function transition(state, event, _ref4) {
986
+ var self = _ref4.self,
987
+ id = _ref4.id,
988
+ defer = _ref4.defer;
989
+
990
+ var _event = toSCXMLEvent(event);
991
+
992
+ if (state.canceled) {
993
+ return state;
994
+ }
995
+
996
+ switch (_event.name) {
997
+ case nextEventType:
998
+ state.data = event.data.data; // match the exact timing of events sent by machines
999
+ // send actions are not executed immediately
1000
+
1001
+ defer(function () {
1002
+ var _self$_parent4;
1003
+
1004
+ (_self$_parent4 = self._parent) === null || _self$_parent4 === void 0 ? void 0 : _self$_parent4.send(toSCXMLEvent({
1005
+ type: "xstate.snapshot.".concat(id),
1006
+ data: _event.data.data
1007
+ }, {
1008
+ origin: self
1009
+ }));
1010
+ });
1011
+ return state;
1012
+
1013
+ case errorEventType:
1014
+ state.status = 'error';
1015
+ state.data = _event.data.data;
1016
+ return state;
1017
+
1018
+ case completeEventType:
1019
+ state.status = 'done';
1020
+ return state;
1021
+
1022
+ case stopSignalType:
1023
+ state.canceled = true;
1024
+ state.subscription.unsubscribe();
1025
+ return state;
1026
+
1027
+ default:
1028
+ return state;
1029
+ }
1030
+ },
1031
+ getInitialState: function getInitialState() {
1032
+ return {
1033
+ subscription: undefined,
1034
+ canceled: false,
1035
+ status: 'active',
1036
+ data: undefined
1037
+ };
1038
+ },
1039
+ start: function start(state, _ref5) {
1040
+ var self = _ref5.self;
1041
+ state.subscription = lazyObservable().subscribe({
1042
+ next: function next(value) {
1043
+ self.send({
1044
+ type: nextEventType,
1045
+ data: value
1046
+ });
1047
+ },
1048
+ error: function error(err) {
1049
+ self.send({
1050
+ type: errorEventType,
1051
+ data: err
1052
+ });
1053
+ },
1054
+ complete: function complete() {
1055
+ self.send({
1056
+ type: completeEventType
1057
+ });
1058
+ }
1059
+ });
1060
+ return state;
1061
+ },
1062
+ getSnapshot: function getSnapshot(state) {
1063
+ return state.data;
1064
+ },
1065
+ getStatus: function getStatus(state) {
1066
+ return state;
1067
+ }
1068
+ };
1069
+ return behavior;
1070
+ }
1071
+ /**
1072
+ * Creates an event observable behavior that listens to an observable
1073
+ * that delivers event objects.
1074
+ *
1075
+ *
1076
+ * @param lazyObservable A function that creates an observable
1077
+ * @returns An event observable behavior
1078
+ */
1079
+
1080
+ function fromEventObservable(lazyObservable) {
1081
+ var errorEventType = '$$xstate.error';
1082
+ var completeEventType = '$$xstate.complete'; // TODO: event types
1083
+
1084
+ var behavior = {
1085
+ transition: function transition(state, event) {
1086
+ var _event = toSCXMLEvent(event);
1087
+
1088
+ if (state.canceled) {
1089
+ return state;
1090
+ }
1091
+
1092
+ switch (_event.name) {
1093
+ case errorEventType:
1094
+ state.status = 'error';
1095
+ state.data = _event.data.data;
1096
+ return state;
1097
+
1098
+ case completeEventType:
1099
+ state.status = 'done';
1100
+ return state;
1101
+
1102
+ case stopSignalType:
1103
+ state.canceled = true;
1104
+ state.subscription.unsubscribe();
1105
+ return state;
1106
+
1107
+ default:
1108
+ return state;
1109
+ }
1110
+ },
1111
+ getInitialState: function getInitialState() {
1112
+ return {
1113
+ subscription: undefined,
1114
+ canceled: false,
1115
+ status: 'active',
1116
+ data: undefined
1117
+ };
1118
+ },
1119
+ start: function start(state, _ref6) {
1120
+ var self = _ref6.self;
1121
+ state.subscription = lazyObservable().subscribe({
1122
+ next: function next(value) {
1123
+ var _self$_parent5;
1124
+
1125
+ (_self$_parent5 = self._parent) === null || _self$_parent5 === void 0 ? void 0 : _self$_parent5.send(toSCXMLEvent(value, {
1126
+ origin: self
1127
+ }));
1128
+ },
1129
+ error: function error(err) {
1130
+ self.send({
1131
+ type: errorEventType,
1132
+ data: err
1133
+ });
1134
+ },
1135
+ complete: function complete() {
1136
+ self.send({
1137
+ type: completeEventType
1138
+ });
1139
+ }
1140
+ });
1141
+ return state;
1142
+ },
1143
+ getSnapshot: function getSnapshot(_) {
1144
+ return undefined;
1145
+ },
1146
+ getStatus: function getStatus(state) {
1147
+ return state;
1148
+ }
1149
+ };
1150
+ return behavior;
1151
+ }
1152
+ function isActorRef(item) {
1153
+ return !!item && _typeof(item) === 'object' && typeof item.send === 'function';
1154
+ } // TODO: refactor the return type, this could be written in a better way
1155
+ // but it's best to avoid unneccessary breaking changes now
1156
+ // @deprecated use `interpret(behavior)` instead
1157
+
1158
+ function toActorRef(actorRefLike) {
1159
+ var _objectSpread2$1;
1160
+
1161
+ return _objectSpread2((_objectSpread2$1 = {
1162
+ subscribe: function subscribe() {
1163
+ return {
1164
+ unsubscribe: function unsubscribe() {
1165
+ return void 0;
1166
+ }
1167
+ };
1168
+ },
1169
+ id: 'anonymous',
1170
+ getSnapshot: function getSnapshot() {
1171
+ return undefined;
1172
+ }
1173
+ }, _defineProperty(_objectSpread2$1, symbolObservable, function () {
1174
+ return this;
1175
+ }), _defineProperty(_objectSpread2$1, "status", ActorStatus.Running), _objectSpread2$1), actorRefLike);
1176
+ }
1177
+
1178
+ var Mailbox = /*#__PURE__*/function () {
1179
+ function Mailbox(_process) {
1180
+ _classCallCheck(this, Mailbox);
1181
+
1182
+ this._process = _process;
1183
+
1184
+ _defineProperty(this, "_active", false);
1185
+
1186
+ _defineProperty(this, "_current", null);
1187
+
1188
+ _defineProperty(this, "_last", null);
1189
+ }
1190
+
1191
+ _createClass(Mailbox, [{
1192
+ key: "start",
1193
+ value: function start() {
1194
+ this._active = true;
1195
+ this.flush();
1196
+ }
1197
+ }, {
1198
+ key: "clear",
1199
+ value: function clear() {
1200
+ // we can't set _current to null because we might be currently processing
1201
+ // and enqueue following clear shouldnt start processing the enqueued item immediately
1202
+ if (this._current) {
1203
+ this._current.next = null;
1204
+ this._last = this._current;
1205
+ }
1206
+ } // TODO: rethink this design
1207
+
1208
+ }, {
1209
+ key: "prepend",
1210
+ value: function prepend(event) {
1211
+ if (!this._current) {
1212
+ this.enqueue(event);
1213
+ return;
1214
+ } // we know that something is already queued up
1215
+ // so the mailbox is already flushing or it's inactive
1216
+ // therefore the only thing that we need to do is to reassign `this._current`
1217
+
1218
+
1219
+ this._current = {
1220
+ value: event,
1221
+ next: this._current
1222
+ };
1223
+ }
1224
+ }, {
1225
+ key: "enqueue",
1226
+ value: function enqueue(event) {
1227
+ var enqueued = {
1228
+ value: event,
1229
+ next: null
1230
+ };
1231
+
1232
+ if (this._current) {
1233
+ this._last.next = enqueued;
1234
+ this._last = enqueued;
1235
+ return;
1236
+ }
1237
+
1238
+ this._current = enqueued;
1239
+ this._last = enqueued;
1240
+
1241
+ if (this._active) {
1242
+ this.flush();
1243
+ }
1244
+ }
1245
+ }, {
1246
+ key: "flush",
1247
+ value: function flush() {
1248
+ while (this._current) {
1249
+ // atm the given _process is responsible for implementing proper try/catch handling
1250
+ // we assume here that this won't throw in a way that can affect this mailbox
1251
+ var consumed = this._current;
1252
+
1253
+ this._process(consumed.value); // something could have been prepended in the meantime
1254
+ // so we need to be defensive here to avoid skipping over a prepended item
1255
+
1256
+
1257
+ if (consumed === this._current) {
1258
+ this._current = this._current.next;
1259
+ }
1260
+ }
1261
+
1262
+ this._last = null;
1263
+ }
1264
+ }]);
1265
+
1266
+ return Mailbox;
1267
+ }();
1268
+
1269
+ var children = new Map();
1270
+ var sessionIdIndex = 0;
1271
+ var registry = {
1272
+ bookId: function bookId() {
1273
+ return "x:".concat(sessionIdIndex++);
1274
+ },
1275
+ register: function register(id, actor) {
1276
+ children.set(id, actor);
1277
+ return id;
1278
+ },
1279
+ get: function get(id) {
1280
+ return children.get(id);
1281
+ },
1282
+ free: function free(id) {
1283
+ children["delete"](id);
1284
+ }
1285
+ };
1286
+
1287
+ var cache = new WeakMap();
1288
+ function memo(object, key, fn) {
1289
+ var memoizedData = cache.get(object);
1290
+
1291
+ if (!memoizedData) {
1292
+ memoizedData = _defineProperty({}, key, fn());
1293
+ cache.set(object, memoizedData);
1294
+ } else if (!(key in memoizedData)) {
1295
+ memoizedData[key] = fn();
1296
+ }
1297
+
1298
+ return memoizedData[key];
1299
+ }
1300
+ function evict(object, key) {
1301
+ if (!key) {
1302
+ return void cache["delete"](object);
1303
+ }
1304
+
1305
+ var memoizedData = cache.get(object);
1306
+
1307
+ if (memoizedData) {
1308
+ delete memoizedData[key];
1309
+ }
1310
+ }
1311
+
1312
+ var ActorStatus;
1313
+
1314
+ (function (ActorStatus) {
1315
+ ActorStatus[ActorStatus["NotStarted"] = 0] = "NotStarted";
1316
+ ActorStatus[ActorStatus["Running"] = 1] = "Running";
1317
+ ActorStatus[ActorStatus["Stopped"] = 2] = "Stopped";
1318
+ })(ActorStatus || (ActorStatus = {}));
1319
+
1320
+ var defaultOptions = {
1321
+ deferEvents: true,
1322
+ clock: {
1323
+ setTimeout: function (_setTimeout) {
1324
+ function setTimeout(_x, _x2) {
1325
+ return _setTimeout.apply(this, arguments);
1326
+ }
1327
+
1328
+ setTimeout.toString = function () {
1329
+ return _setTimeout.toString();
1330
+ };
1331
+
1332
+ return setTimeout;
1333
+ }(function (fn, ms) {
1334
+ return setTimeout(fn, ms);
1335
+ }),
1336
+ clearTimeout: function (_clearTimeout) {
1337
+ function clearTimeout(_x3) {
1338
+ return _clearTimeout.apply(this, arguments);
1339
+ }
1340
+
1341
+ clearTimeout.toString = function () {
1342
+ return _clearTimeout.toString();
1343
+ };
1344
+
1345
+ return clearTimeout;
1346
+ }(function (id) {
1347
+ return clearTimeout(id);
1348
+ })
1349
+ },
1350
+ logger: console.log.bind(console),
1351
+ devTools: false
1352
+ };
1353
+ var Interpreter = /*#__PURE__*/function () {
1354
+ /**
1355
+ * The current state of the interpreted behavior.
1356
+ */
1357
+
1358
+ /**
1359
+ * The clock that is responsible for setting and clearing timeouts, such as delayed events and transitions.
1360
+ */
1361
+
1362
+ /**
1363
+ * The unique identifier for this actor relative to its parent.
1364
+ */
1365
+
1366
+ /**
1367
+ * Whether the service is started.
1368
+ */
1369
+ // Actor Ref
1370
+
1371
+ /**
1372
+ * The globally unique process ID for this invocation.
1373
+ */
1374
+ // TODO: remove
1375
+
1376
+ /**
1377
+ * Creates a new Interpreter instance (i.e., service) for the given behavior with the provided options, if any.
1378
+ *
1379
+ * @param behavior The behavior to be interpreted
1380
+ * @param options Interpreter options
1381
+ */
1382
+ function Interpreter(behavior, options) {
1383
+ var _this = this;
1384
+
1385
+ _classCallCheck(this, Interpreter);
1386
+
1387
+ this.behavior = behavior;
1388
+
1389
+ _defineProperty(this, "_state", void 0);
1390
+
1391
+ _defineProperty(this, "clock", void 0);
1392
+
1393
+ _defineProperty(this, "options", void 0);
1394
+
1395
+ _defineProperty(this, "id", void 0);
1396
+
1397
+ _defineProperty(this, "mailbox", new Mailbox(this._process.bind(this)));
1398
+
1399
+ _defineProperty(this, "delayedEventsMap", {});
1400
+
1401
+ _defineProperty(this, "observers", new Set());
1402
+
1403
+ _defineProperty(this, "logger", void 0);
1404
+
1405
+ _defineProperty(this, "status", ActorStatus.NotStarted);
1406
+
1407
+ _defineProperty(this, "_parent", void 0);
1408
+
1409
+ _defineProperty(this, "ref", void 0);
1410
+
1411
+ _defineProperty(this, "_actorContext", void 0);
1412
+
1413
+ _defineProperty(this, "sessionId", void 0);
1414
+
1415
+ _defineProperty(this, "_forwardTo", new Set());
1416
+
1417
+ _defineProperty(this, "_deferred", []);
1418
+
1419
+ var resolvedOptions = _objectSpread2(_objectSpread2({}, defaultOptions), options);
1420
+
1421
+ var clock = resolvedOptions.clock,
1422
+ logger = resolvedOptions.logger,
1423
+ parent = resolvedOptions.parent,
1424
+ id = resolvedOptions.id;
1425
+ var self = this; // TODO: this should come from a "system"
1426
+
1427
+ this.sessionId = registry.bookId();
1428
+ this.id = id !== null && id !== void 0 ? id : this.sessionId;
1429
+ this.logger = logger;
1430
+ this.clock = clock;
1431
+ this._parent = parent;
1432
+ this.options = resolvedOptions;
1433
+ this.ref = this;
1434
+ this._actorContext = {
1435
+ self: self,
1436
+ id: this.id,
1437
+ sessionId: this.sessionId,
1438
+ logger: this.logger,
1439
+ defer: function defer(fn) {
1440
+ _this._deferred.push(fn);
1441
+ }
1442
+ }; // Ensure that the send method is bound to this interpreter instance
1443
+ // if destructured
1444
+
1445
+ this.send = this.send.bind(this);
1446
+ } // array of functions to defer
1447
+
1448
+
1449
+ _createClass(Interpreter, [{
1450
+ key: "_getInitialState",
1451
+ value: function _getInitialState() {
1452
+ var _this2 = this;
1453
+
1454
+ return memo(this, 'initial', function () {
1455
+ return _this2.behavior.getInitialState(_this2._actorContext);
1456
+ });
1457
+ }
1458
+ }, {
1459
+ key: "update",
1460
+ value: function update(state) {
1461
+ var _this$behavior$getSta, _this$behavior, _this$_parent, _this$_parent2;
1462
+
1463
+ // Update state
1464
+ this._state = state;
1465
+ var snapshot = this.getSnapshot(); // Execute deferred effects
1466
+
1467
+ var deferredFn;
1468
+
1469
+ while (deferredFn = this._deferred.shift()) {
1470
+ deferredFn(state);
1471
+ }
1472
+
1473
+ var _iterator = _createForOfIteratorHelper(this.observers),
1474
+ _step;
1475
+
1476
+ try {
1477
+ for (_iterator.s(); !(_step = _iterator.n()).done;) {
1478
+ var _observer2$next;
1479
+
1480
+ var _observer2 = _step.value;
1481
+ (_observer2$next = _observer2.next) === null || _observer2$next === void 0 ? void 0 : _observer2$next.call(_observer2, snapshot);
1482
+ }
1483
+ } catch (err) {
1484
+ _iterator.e(err);
1485
+ } finally {
1486
+ _iterator.f();
1487
+ }
1488
+
1489
+ var status = (_this$behavior$getSta = (_this$behavior = this.behavior).getStatus) === null || _this$behavior$getSta === void 0 ? void 0 : _this$behavior$getSta.call(_this$behavior, state);
1490
+
1491
+ switch (status === null || status === void 0 ? void 0 : status.status) {
1492
+ case 'done':
1493
+ (_this$_parent = this._parent) === null || _this$_parent === void 0 ? void 0 : _this$_parent.send(toSCXMLEvent(doneInvoke(this.id, status.data), {
1494
+ origin: this,
1495
+ invokeid: this.id
1496
+ }));
1497
+
1498
+ this._stop();
1499
+
1500
+ break;
1501
+
1502
+ case 'error':
1503
+ (_this$_parent2 = this._parent) === null || _this$_parent2 === void 0 ? void 0 : _this$_parent2.send(toSCXMLEvent(error$1(this.id, status.data), {
1504
+ origin: this
1505
+ }));
1506
+
1507
+ var _iterator2 = _createForOfIteratorHelper(this.observers),
1508
+ _step2;
1509
+
1510
+ try {
1511
+ for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
1512
+ var _observer$error;
1513
+
1514
+ var _observer = _step2.value;
1515
+ (_observer$error = _observer.error) === null || _observer$error === void 0 ? void 0 : _observer$error.call(_observer, status.data);
1516
+ }
1517
+ } catch (err) {
1518
+ _iterator2.e(err);
1519
+ } finally {
1520
+ _iterator2.f();
1521
+ }
1522
+
1523
+ break;
1524
+ }
1525
+ }
1526
+ /*
1527
+ * Adds a listener that is notified whenever a state transition happens. The listener is called with
1528
+ * the next state and the event object that caused the state transition.
1529
+ *
1530
+ * @param listener The state listener
1531
+ * @deprecated Use .subscribe(listener) instead
1532
+ */
1533
+
1534
+ }, {
1535
+ key: "onTransition",
1536
+ value: function onTransition(listener) {
1537
+ var observer = toObserver(listener);
1538
+ this.observers.add(observer); // Send current state to listener
1539
+
1540
+ if (this.status === ActorStatus.Running) {
1541
+ var _observer$next;
1542
+
1543
+ (_observer$next = observer.next) === null || _observer$next === void 0 ? void 0 : _observer$next.call(observer, this.getSnapshot());
1544
+ }
1545
+
1546
+ return this;
1547
+ }
1548
+ }, {
1549
+ key: "subscribe",
1550
+ value: function subscribe(nextListenerOrObserver, errorListener, completeListener) {
1551
+ var _this3 = this;
1552
+
1553
+ var observer = toObserver(nextListenerOrObserver, errorListener, completeListener);
1554
+ this.observers.add(observer); // Send current state to listener
1555
+
1556
+ if (this.status !== ActorStatus.NotStarted) {
1557
+ var _observer$next2;
1558
+
1559
+ (_observer$next2 = observer.next) === null || _observer$next2 === void 0 ? void 0 : _observer$next2.call(observer, this.getSnapshot());
1560
+ }
1561
+
1562
+ if (this.status === ActorStatus.Stopped) {
1563
+ var _observer$complete;
1564
+
1565
+ (_observer$complete = observer.complete) === null || _observer$complete === void 0 ? void 0 : _observer$complete.call(observer);
1566
+ this.observers["delete"](observer);
1567
+ }
1568
+
1569
+ return {
1570
+ unsubscribe: function unsubscribe() {
1571
+ _this3.observers["delete"](observer);
1572
+ }
1573
+ };
1574
+ }
1575
+ /**
1576
+ * Adds a state listener that is notified when the statechart has reached its final state.
1577
+ * @param listener The state listener
1578
+ */
1579
+
1580
+ }, {
1581
+ key: "onDone",
1582
+ value: function onDone(listener) {
1583
+ var _this4 = this;
1584
+
1585
+ this.observers.add({
1586
+ complete: function complete() {
1587
+ var snapshot = _this4.getSnapshot();
1588
+
1589
+ if (snapshot.done) {
1590
+ listener(doneInvoke(_this4.id, snapshot.output));
1591
+ }
1592
+ }
1593
+ });
1594
+ return this;
1595
+ }
1596
+ /**
1597
+ * Starts the interpreter from the given state, or the initial state.
1598
+ * @param initialState The state to start the statechart from
1599
+ */
1600
+
1601
+ }, {
1602
+ key: "start",
1603
+ value: function start( // TODO: remove this argument
1604
+ initialState) {
1605
+ var _this$behavior$restor, _this$behavior2, _this$_getInitialStat;
1606
+
1607
+ if (this.status === ActorStatus.Running) {
1608
+ // Do not restart the service if it is already started
1609
+ return this;
1610
+ }
1611
+
1612
+ registry.register(this.sessionId, this.ref);
1613
+ this.status = ActorStatus.Running;
1614
+ var resolvedState = initialState ? (_this$behavior$restor = (_this$behavior2 = this.behavior).restoreState) === null || _this$behavior$restor === void 0 ? void 0 : _this$behavior$restor.call(_this$behavior2, initialState, this._actorContext) : (_this$_getInitialStat = this._getInitialState()) !== null && _this$_getInitialStat !== void 0 ? _this$_getInitialStat : undefined;
1615
+
1616
+ if (this.behavior.start) {
1617
+ resolvedState = this.behavior.start(resolvedState, this._actorContext);
1618
+ } // TODO: this notifies all subscribers but usually this is redundant
1619
+ // if we are using the initialState as `resolvedState` then there is no real change happening here
1620
+ // we need to rethink if this needs to be refactored
1621
+
1622
+
1623
+ this.update(resolvedState);
1624
+
1625
+ if (this.options.devTools) {
1626
+ this.attachDevTools();
1627
+ }
1628
+
1629
+ this.mailbox.start();
1630
+ return this;
1631
+ }
1632
+ }, {
1633
+ key: "_process",
1634
+ value: function _process(event) {
1635
+ this.forward(event);
1636
+
1637
+ try {
1638
+ var nextState = this.behavior.transition(this._state, event, this._actorContext);
1639
+ this.update(nextState);
1640
+
1641
+ if (event.name === stopSignalType) {
1642
+ this._stop();
1643
+ }
1644
+ } catch (err) {
1645
+ // TODO: properly handle errors
1646
+ if (this.observers.size > 0) {
1647
+ this.observers.forEach(function (observer) {
1648
+ var _observer$error2;
1649
+
1650
+ (_observer$error2 = observer.error) === null || _observer$error2 === void 0 ? void 0 : _observer$error2.call(observer, err);
1651
+ });
1652
+ this.stop();
1653
+ } else {
1654
+ throw err;
1655
+ }
1656
+ }
1657
+ }
1658
+ /**
1659
+ * Stops the interpreter and unsubscribe all listeners.
1660
+ */
1661
+
1662
+ }, {
1663
+ key: "stop",
1664
+ value: function stop() {
1665
+ evict(this, 'initial');
1666
+
1667
+ if (this.status === ActorStatus.Stopped) {
1668
+ return this;
1669
+ }
1670
+
1671
+ this.mailbox.clear();
1672
+
1673
+ if (this.status === ActorStatus.NotStarted) {
1674
+ this.status = ActorStatus.Stopped;
1675
+ return this;
1676
+ }
1677
+
1678
+ this.mailbox.enqueue(toSCXMLEvent({
1679
+ type: stopSignalType
1680
+ }));
1681
+ return this;
1682
+ }
1683
+ }, {
1684
+ key: "_complete",
1685
+ value: function _complete() {
1686
+ var _iterator3 = _createForOfIteratorHelper(this.observers),
1687
+ _step3;
1688
+
1689
+ try {
1690
+ for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) {
1691
+ var _observer3$complete;
1692
+
1693
+ var _observer3 = _step3.value;
1694
+ (_observer3$complete = _observer3.complete) === null || _observer3$complete === void 0 ? void 0 : _observer3$complete.call(_observer3);
1695
+ }
1696
+ } catch (err) {
1697
+ _iterator3.e(err);
1698
+ } finally {
1699
+ _iterator3.f();
1700
+ }
1701
+
1702
+ this.observers.clear();
1703
+ }
1704
+ }, {
1705
+ key: "_stop",
1706
+ value: function _stop() {
1707
+ this._complete();
1708
+
1709
+ if (this.status !== ActorStatus.Running) {
1710
+ // Interpreter already stopped; do nothing
1711
+ return this;
1712
+ } // Cancel all delayed events
1713
+
1714
+
1715
+ for (var _i = 0, _Object$keys = Object.keys(this.delayedEventsMap); _i < _Object$keys.length; _i++) {
1716
+ var key = _Object$keys[_i];
1717
+ this.clock.clearTimeout(this.delayedEventsMap[key]);
1718
+ } // TODO: mailbox.reset
1719
+
1720
+
1721
+ this.mailbox.clear(); // TODO: after `stop` we must prepare ourselves for receiving events again
1722
+ // events sent *after* stop signal must be queued
1723
+ // it seems like this should be the common behavior for all of our consumers
1724
+ // so perhaps this should be unified somehow for all of them
1725
+
1726
+ this.mailbox = new Mailbox(this._process.bind(this));
1727
+ this.status = ActorStatus.Stopped;
1728
+ registry.free(this.sessionId);
1729
+ return this;
1730
+ }
1731
+ /**
1732
+ * Sends an event to the running interpreter to trigger a transition.
1733
+ *
1734
+ * An array of events (batched) can be sent as well, which will send all
1735
+ * batched events to the running interpreter. The listeners will be
1736
+ * notified only **once** when all events are processed.
1737
+ *
1738
+ * @param event The event(s) to send
1739
+ */
1740
+
1741
+ }, {
1742
+ key: "send",
1743
+ value: function send(event) {
1744
+ var _event = toSCXMLEvent(event);
1745
+
1746
+ if (this.status === ActorStatus.Stopped) {
1747
+ // do nothing
1748
+ if (!IS_PRODUCTION) {
1749
+ var eventString = JSON.stringify(_event.data);
1750
+ warn(false, "Event \"".concat(_event.name.toString(), "\" was sent to stopped actor \"").concat(this.id, " (").concat(this.sessionId, ")\". This actor has already reached its final state, and will not transition.\nEvent: ").concat(eventString));
1751
+ }
1752
+
1753
+ return;
1754
+ }
1755
+
1756
+ if (this.status !== ActorStatus.Running && !this.options.deferEvents) {
1757
+ throw new Error("Event \"".concat(_event.name, "\" was sent to uninitialized actor \"").concat(this.id // tslint:disable-next-line:max-line-length
1758
+ , "\". Make sure .start() is called for this actor, or set { deferEvents: true } in the actor options.\nEvent: ").concat(JSON.stringify(_event.data)));
1759
+ }
1760
+
1761
+ this.mailbox.enqueue(_event);
1762
+ } // TODO: remove
1763
+
1764
+ }, {
1765
+ key: "forward",
1766
+ value: function forward(event) {
1767
+ // The _forwardTo set will be empty for non-machine actors anyway
1768
+ var _iterator4 = _createForOfIteratorHelper(this._forwardTo),
1769
+ _step4;
1770
+
1771
+ try {
1772
+ for (_iterator4.s(); !(_step4 = _iterator4.n()).done;) {
1773
+ var child = _step4.value;
1774
+ child.send(event);
1775
+ }
1776
+ } catch (err) {
1777
+ _iterator4.e(err);
1778
+ } finally {
1779
+ _iterator4.f();
1780
+ }
1781
+ } // TODO: make private (and figure out a way to do this within the machine)
1782
+
1783
+ }, {
1784
+ key: "delaySend",
1785
+ value: function delaySend(sendAction) {
1786
+ var _this5 = this;
1787
+
1788
+ this.delayedEventsMap[sendAction.params.id] = this.clock.setTimeout(function () {
1789
+ if (sendAction.params.to) {
1790
+ sendAction.params.to.send(sendAction.params._event);
1791
+ } else {
1792
+ _this5.send(sendAction.params._event);
1793
+ }
1794
+ }, sendAction.params.delay);
1795
+ } // TODO: make private (and figure out a way to do this within the machine)
1796
+
1797
+ }, {
1798
+ key: "cancel",
1799
+ value: function cancel(sendId) {
1800
+ this.clock.clearTimeout(this.delayedEventsMap[sendId]);
1801
+ delete this.delayedEventsMap[sendId];
1802
+ }
1803
+ }, {
1804
+ key: "attachDevTools",
1805
+ value: function attachDevTools() {
1806
+ var devTools = this.options.devTools;
1807
+
1808
+ if (devTools) {
1809
+ var resolvedDevToolsAdapter = typeof devTools === 'function' ? devTools : devToolsAdapter;
1810
+ resolvedDevToolsAdapter(this);
1811
+ }
1812
+ }
1813
+ }, {
1814
+ key: "toJSON",
1815
+ value: function toJSON() {
1816
+ return {
1817
+ id: this.id
1818
+ };
1819
+ }
1820
+ }, {
1821
+ key: symbolObservable,
1822
+ value: function value() {
1823
+ return this;
1824
+ }
1825
+ }, {
1826
+ key: "getSnapshot",
1827
+ value: function getSnapshot() {
1828
+ var _this$behavior$getSna;
1829
+
1830
+ var getter = (_this$behavior$getSna = this.behavior.getSnapshot) !== null && _this$behavior$getSna !== void 0 ? _this$behavior$getSna : function (s) {
1831
+ return s;
1832
+ };
1833
+
1834
+ if (this.status === ActorStatus.NotStarted) {
1835
+ return getter(this._getInitialState());
1836
+ }
1837
+
1838
+ return getter(this._state);
1839
+ }
1840
+ }]);
1841
+
1842
+ return Interpreter;
1843
+ }();
1844
+ /**
1845
+ * Creates a new Interpreter instance for the given machine with the provided options, if any.
1846
+ *
1847
+ * @param machine The machine to interpret
1848
+ * @param options Interpreter options
1849
+ */
1850
+
1851
+ function interpret(behavior, options) {
1852
+ var interpreter = new Interpreter(behavior, options);
1853
+ return interpreter;
1854
+ }
1855
+
1856
+ /**
1857
+ * Stops an actor.
1858
+ *
1859
+ * @param actorRef The actor to stop.
1860
+ */
1861
+
1862
+ function stop$1(actorRef) {
1863
+ var actor = actorRef;
1864
+ return createDynamicAction({
1865
+ type: stop,
1866
+ params: {
1867
+ actor: actor
1868
+ }
1869
+ }, function (_event, _ref) {
1870
+ var state = _ref.state;
1871
+ var actorRefOrString = isFunction(actor) ? actor(state.context, _event.data) : actor;
1872
+ var actorRef = typeof actorRefOrString === 'string' ? state.children[actorRefOrString] : actorRefOrString;
1873
+ return [state, {
1874
+ type: 'xstate.stop',
1875
+ params: {
1876
+ actor: actorRef
1877
+ },
1878
+ execute: function execute(actorCtx) {
1879
+ if (!actorRef) {
1880
+ return;
1881
+ }
1882
+
1883
+ if (actorRef.status !== ActorStatus.Running) {
1884
+ var _actorRef$stop;
1885
+
1886
+ (_actorRef$stop = actorRef.stop) === null || _actorRef$stop === void 0 ? void 0 : _actorRef$stop.call(actorRef);
1887
+ return;
1888
+ }
1889
+
1890
+ actorCtx.defer(function () {
1891
+ var _actorRef$stop2;
1892
+
1893
+ (_actorRef$stop2 = actorRef.stop) === null || _actorRef$stop2 === void 0 ? void 0 : _actorRef$stop2.call(actorRef);
1894
+ });
1895
+ }
1896
+ }];
1897
+ });
1898
+ }
1899
+
1900
+ var defaultLogExpr = function defaultLogExpr(context, event) {
1901
+ return {
1902
+ context: context,
1903
+ event: event
1904
+ };
1905
+ };
1906
+ /**
1907
+ *
1908
+ * @param expr The expression function to evaluate which will be logged.
1909
+ * Takes in 2 arguments:
1910
+ * - `ctx` - the current state context
1911
+ * - `event` - the event that caused this action to be executed.
1912
+ * @param label The label to give to the logged expression.
1913
+ */
1914
+
1915
+
1916
+ function log$1() {
1917
+ var expr = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : defaultLogExpr;
1918
+ var label = arguments.length > 1 ? arguments[1] : undefined;
1919
+ return createDynamicAction({
1920
+ type: log,
1921
+ params: {
1922
+ label: label,
1923
+ expr: expr
1924
+ }
1925
+ }, function (_event, _ref) {
1926
+ var state = _ref.state;
1927
+ var resolvedValue = typeof expr === 'function' ? expr(state.context, _event.data, {
1928
+ _event: _event
1929
+ }) : expr;
1930
+ return [state, {
1931
+ type: 'xstate.log',
1932
+ params: {
1933
+ label: label,
1934
+ value: resolvedValue
1935
+ },
1936
+ execute: function execute(actorCtx) {
1937
+ if (label) {
1938
+ var _actorCtx$logger;
1939
+
1940
+ (_actorCtx$logger = actorCtx.logger) === null || _actorCtx$logger === void 0 ? void 0 : _actorCtx$logger.call(actorCtx, label, resolvedValue);
1941
+ } else {
1942
+ var _actorCtx$logger2;
1943
+
1944
+ (_actorCtx$logger2 = actorCtx.logger) === null || _actorCtx$logger2 === void 0 ? void 0 : _actorCtx$logger2.call(actorCtx, resolvedValue);
1945
+ }
1946
+ }
1947
+ }];
1948
+ });
1949
+ }
1950
+
1951
+ /**
1952
+ * Cancels an in-flight `send(...)` action. A canceled sent action will not
1953
+ * be executed, nor will its event be sent, unless it has already been sent
1954
+ * (e.g., if `cancel(...)` is called after the `send(...)` action's `delay`).
1955
+ *
1956
+ * @param sendId The `id` of the `send(...)` action to cancel.
1957
+ */
1958
+
1959
+ function cancel$1(sendId) {
1960
+ return createDynamicAction({
1961
+ type: cancel,
1962
+ params: {
1963
+ sendId: sendId
1964
+ }
1965
+ }, function (_event, _ref) {
1966
+ var state = _ref.state;
1967
+ var resolvedSendId = isFunction(sendId) ? sendId(state.context, _event.data, {
1968
+ _event: _event
1969
+ }) : sendId;
1970
+ return [state, {
1971
+ type: 'xstate.cancel',
1972
+ params: {
1973
+ sendId: resolvedSendId
1974
+ },
1975
+ execute: function execute(actorCtx) {
1976
+ var interpreter = actorCtx.self;
1977
+ interpreter.cancel(resolvedSendId);
1978
+ }
1979
+ }];
1980
+ });
1981
+ }
1982
+
1983
+ function _objectWithoutPropertiesLoose(source, excluded) {
1984
+ if (source == null) return {};
1985
+ var target = {};
1986
+ var sourceKeys = Object.keys(source);
1987
+ var key, i;
1988
+
1989
+ for (i = 0; i < sourceKeys.length; i++) {
1990
+ key = sourceKeys[i];
1991
+ if (excluded.indexOf(key) >= 0) continue;
1992
+ target[key] = source[key];
1993
+ }
1994
+
1995
+ return target;
1996
+ }
1997
+
1998
+ function _objectWithoutProperties(source, excluded) {
1999
+ if (source == null) return {};
2000
+ var target = _objectWithoutPropertiesLoose(source, excluded);
2001
+ var key, i;
2002
+
2003
+ if (Object.getOwnPropertySymbols) {
2004
+ var sourceSymbolKeys = Object.getOwnPropertySymbols(source);
2005
+
2006
+ for (i = 0; i < sourceSymbolKeys.length; i++) {
2007
+ key = sourceSymbolKeys[i];
2008
+ if (excluded.indexOf(key) >= 0) continue;
2009
+ if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;
2010
+ target[key] = source[key];
2011
+ }
2012
+ }
2013
+
2014
+ return target;
2015
+ }
2016
+
2017
+ function _toPrimitive(input, hint) {
2018
+ if (typeof input !== "object" || input === null) return input;
2019
+ var prim = input[Symbol.toPrimitive];
2020
+
2021
+ if (prim !== undefined) {
2022
+ var res = prim.call(input, hint || "default");
2023
+ if (typeof res !== "object") return res;
2024
+ throw new TypeError("@@toPrimitive must return a primitive value.");
2025
+ }
2026
+
2027
+ return (hint === "string" ? String : Number)(input);
2028
+ }
2029
+
2030
+ function _toPropertyKey(arg) {
2031
+ var key = _toPrimitive(arg, "string");
2032
+ return typeof key === "symbol" ? key : String(key);
2033
+ }
2034
+
2035
+ function stateIn(stateValue) {
2036
+ return {
2037
+ type: 'xstate.guard:in',
2038
+ params: {
2039
+ stateValue: stateValue
2040
+ },
2041
+ predicate: function predicate(_, __, _ref) {
2042
+ var state = _ref.state;
2043
+
2044
+ if (isString(stateValue) && isStateId(stateValue)) {
2045
+ return state.configuration.some(function (sn) {
2046
+ return sn.id === stateValue.slice(1);
2047
+ });
2048
+ }
2049
+
2050
+ return state.matches(stateValue);
2051
+ }
2052
+ };
2053
+ }
2054
+ function not(guard) {
2055
+ return {
2056
+ type: 'xstate.boolean',
2057
+ params: {
2058
+ op: 'not'
2059
+ },
2060
+ children: [toGuardDefinition(guard)],
2061
+ predicate: function predicate(ctx, _, meta) {
2062
+ return !meta.evaluate(meta.guard.children[0], ctx, meta._event, meta.state, meta.state.machine);
2063
+ }
2064
+ };
2065
+ }
2066
+ function and(guards) {
2067
+ return {
2068
+ type: 'xstate.boolean',
2069
+ params: {
2070
+ op: 'and'
2071
+ },
2072
+ children: guards.map(function (guard) {
2073
+ return toGuardDefinition(guard);
2074
+ }),
2075
+ predicate: function predicate(ctx, _, meta) {
2076
+ return meta.guard.children.every(function (childGuard) {
2077
+ return meta.evaluate(childGuard, ctx, meta._event, meta.state, meta.state.machine);
2078
+ });
2079
+ }
2080
+ };
2081
+ }
2082
+ function or(guards) {
2083
+ return {
2084
+ type: 'xstate.boolean',
2085
+ params: {
2086
+ op: 'or'
2087
+ },
2088
+ children: guards.map(function (guard) {
2089
+ return toGuardDefinition(guard);
2090
+ }),
2091
+ predicate: function predicate(ctx, _, meta) {
2092
+ return meta.guard.children.some(function (childGuard) {
2093
+ return meta.evaluate(childGuard, ctx, meta._event, meta.state, meta.state.machine);
2094
+ });
2095
+ }
2096
+ };
2097
+ }
2098
+ function evaluateGuard(guard, context, _event, state) {
2099
+ var _machine$options$guar, _machine$options, _machine$options$guar2;
2100
+
2101
+ var machine = state.machine;
2102
+ var guardMeta = {
2103
+ state: state,
2104
+ guard: guard,
2105
+ _event: _event,
2106
+ evaluate: evaluateGuard
2107
+ };
2108
+ var predicate = (_machine$options$guar = machine === null || machine === void 0 ? void 0 : (_machine$options = machine.options) === null || _machine$options === void 0 ? void 0 : (_machine$options$guar2 = _machine$options.guards) === null || _machine$options$guar2 === void 0 ? void 0 : _machine$options$guar2[guard.type]) !== null && _machine$options$guar !== void 0 ? _machine$options$guar : guard.predicate;
2109
+
2110
+ if (!predicate) {
2111
+ throw new Error("Guard '".concat(guard.type, "' is not implemented.'."));
2112
+ }
2113
+
2114
+ return predicate(context, _event.data, guardMeta);
2115
+ }
2116
+ function toGuardDefinition(guardConfig, getPredicate) {
2117
+ var _guardConfig$children;
2118
+
2119
+ if (isString(guardConfig)) {
2120
+ return {
2121
+ type: guardConfig,
2122
+ predicate: (getPredicate === null || getPredicate === void 0 ? void 0 : getPredicate(guardConfig)) || undefined,
2123
+ params: {
2124
+ type: guardConfig
2125
+ }
2126
+ };
2127
+ }
2128
+
2129
+ if (isFunction(guardConfig)) {
2130
+ return {
2131
+ type: guardConfig.name,
2132
+ predicate: guardConfig,
2133
+ params: {
2134
+ type: guardConfig.name,
2135
+ name: guardConfig.name
2136
+ }
2137
+ };
2138
+ }
2139
+
2140
+ return {
2141
+ type: guardConfig.type,
2142
+ params: guardConfig.params || guardConfig,
2143
+ children: (_guardConfig$children = guardConfig.children) === null || _guardConfig$children === void 0 ? void 0 : _guardConfig$children.map(function (childGuard) {
2144
+ return toGuardDefinition(childGuard, getPredicate);
2145
+ }),
2146
+ predicate: (getPredicate === null || getPredicate === void 0 ? void 0 : getPredicate(guardConfig.type)) || guardConfig.predicate
2147
+ };
2148
+ }
2149
+
2150
+ function getOutput(configuration, context, _event) {
2151
+ var machine = configuration[0].machine;
2152
+ var finalChildStateNode = configuration.find(function (stateNode) {
2153
+ return stateNode.type === 'final' && stateNode.parent === machine.root;
2154
+ });
2155
+ var doneData = finalChildStateNode && finalChildStateNode.doneData ? mapContext(finalChildStateNode.doneData, context, _event) : undefined;
2156
+ return doneData;
2157
+ }
2158
+
2159
+ var isAtomicStateNode = function isAtomicStateNode(stateNode) {
2160
+ return stateNode.type === 'atomic' || stateNode.type === 'final';
2161
+ };
2162
+
2163
+ function getChildren(stateNode) {
2164
+ return Object.values(stateNode.states).filter(function (sn) {
2165
+ return sn.type !== 'history';
2166
+ });
2167
+ }
2168
+
2169
+ function getProperAncestors(stateNode, toStateNode) {
2170
+ var ancestors = []; // add all ancestors
2171
+
2172
+ var m = stateNode.parent;
2173
+
2174
+ while (m && m !== toStateNode) {
2175
+ ancestors.push(m);
2176
+ m = m.parent;
2177
+ }
2178
+
2179
+ return ancestors;
2180
+ }
2181
+
2182
+ function getConfiguration(stateNodes) {
2183
+ var configuration = new Set(stateNodes);
2184
+ var configurationSet = new Set(stateNodes);
2185
+ var adjList = getAdjList(configurationSet); // add descendants
2186
+
2187
+ var _iterator = _createForOfIteratorHelper(configuration),
2188
+ _step;
2189
+
2190
+ try {
2191
+ for (_iterator.s(); !(_step = _iterator.n()).done;) {
2192
+ var s = _step.value;
2193
+
2194
+ // if previously active, add existing child nodes
2195
+ if (s.type === 'compound' && (!adjList.get(s) || !adjList.get(s).length)) {
2196
+ getInitialStateNodes(s).forEach(function (sn) {
2197
+ return configurationSet.add(sn);
2198
+ });
2199
+ } else {
2200
+ if (s.type === 'parallel') {
2201
+ var _iterator3 = _createForOfIteratorHelper(getChildren(s)),
2202
+ _step3;
2203
+
2204
+ try {
2205
+ for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) {
2206
+ var child = _step3.value;
2207
+
2208
+ if (child.type === 'history') {
2209
+ continue;
2210
+ }
2211
+
2212
+ if (!configurationSet.has(child)) {
2213
+ var _iterator4 = _createForOfIteratorHelper(getInitialStateNodes(child)),
2214
+ _step4;
2215
+
2216
+ try {
2217
+ for (_iterator4.s(); !(_step4 = _iterator4.n()).done;) {
2218
+ var initialStateNode = _step4.value;
2219
+ configurationSet.add(initialStateNode);
2220
+ }
2221
+ } catch (err) {
2222
+ _iterator4.e(err);
2223
+ } finally {
2224
+ _iterator4.f();
2225
+ }
2226
+ }
2227
+ }
2228
+ } catch (err) {
2229
+ _iterator3.e(err);
2230
+ } finally {
2231
+ _iterator3.f();
2232
+ }
2233
+ }
2234
+ }
2235
+ } // add all ancestors
2236
+
2237
+ } catch (err) {
2238
+ _iterator.e(err);
2239
+ } finally {
2240
+ _iterator.f();
2241
+ }
2242
+
2243
+ var _iterator2 = _createForOfIteratorHelper(configurationSet),
2244
+ _step2;
2245
+
2246
+ try {
2247
+ for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
2248
+ var _s = _step2.value;
2249
+ var m = _s.parent;
2250
+
2251
+ while (m) {
2252
+ configurationSet.add(m);
2253
+ m = m.parent;
2254
+ }
2255
+ }
2256
+ } catch (err) {
2257
+ _iterator2.e(err);
2258
+ } finally {
2259
+ _iterator2.f();
2260
+ }
2261
+
2262
+ return configurationSet;
2263
+ }
2264
+
2265
+ function getValueFromAdj(baseNode, adjList) {
2266
+ var childStateNodes = adjList.get(baseNode);
2267
+
2268
+ if (!childStateNodes) {
2269
+ return {}; // todo: fix?
2270
+ }
2271
+
2272
+ if (baseNode.type === 'compound') {
2273
+ var childStateNode = childStateNodes[0];
2274
+
2275
+ if (childStateNode) {
2276
+ if (isAtomicStateNode(childStateNode)) {
2277
+ return childStateNode.key;
2278
+ }
2279
+ } else {
2280
+ return {};
2281
+ }
2282
+ }
2283
+
2284
+ var stateValue = {};
2285
+
2286
+ var _iterator5 = _createForOfIteratorHelper(childStateNodes),
2287
+ _step5;
2288
+
2289
+ try {
2290
+ for (_iterator5.s(); !(_step5 = _iterator5.n()).done;) {
2291
+ var _childStateNode = _step5.value;
2292
+ stateValue[_childStateNode.key] = getValueFromAdj(_childStateNode, adjList);
2293
+ }
2294
+ } catch (err) {
2295
+ _iterator5.e(err);
2296
+ } finally {
2297
+ _iterator5.f();
2298
+ }
2299
+
2300
+ return stateValue;
2301
+ }
2302
+
2303
+ function getAdjList(configuration) {
2304
+ var adjList = new Map();
2305
+
2306
+ var _iterator6 = _createForOfIteratorHelper(configuration),
2307
+ _step6;
2308
+
2309
+ try {
2310
+ for (_iterator6.s(); !(_step6 = _iterator6.n()).done;) {
2311
+ var s = _step6.value;
2312
+
2313
+ if (!adjList.has(s)) {
2314
+ adjList.set(s, []);
2315
+ }
2316
+
2317
+ if (s.parent) {
2318
+ if (!adjList.has(s.parent)) {
2319
+ adjList.set(s.parent, []);
2320
+ }
2321
+
2322
+ adjList.get(s.parent).push(s);
2323
+ }
2324
+ }
2325
+ } catch (err) {
2326
+ _iterator6.e(err);
2327
+ } finally {
2328
+ _iterator6.f();
2329
+ }
2330
+
2331
+ return adjList;
2332
+ }
2333
+ function getStateValue(rootNode, configuration) {
2334
+ var config = getConfiguration(configuration);
2335
+ return getValueFromAdj(rootNode, getAdjList(config));
2336
+ }
2337
+ function isInFinalState(configuration) {
2338
+ var stateNode = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : configuration[0].machine.root;
2339
+
2340
+ if (stateNode.type === 'compound') {
2341
+ return getChildren(stateNode).some(function (s) {
2342
+ return s.type === 'final' && configuration.includes(s);
2343
+ });
2344
+ }
2345
+
2346
+ if (stateNode.type === 'parallel') {
2347
+ return getChildren(stateNode).every(function (sn) {
2348
+ return isInFinalState(configuration, sn);
2349
+ });
2350
+ }
2351
+
2352
+ return false;
2353
+ }
2354
+ var isStateId = function isStateId(str) {
2355
+ return str[0] === STATE_IDENTIFIER;
2356
+ };
2357
+ function getCandidates(stateNode, receivedEventType) {
2358
+ var partialMatch = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;
2359
+ var candidates = stateNode.transitions.filter(function (transition) {
2360
+ var eventType = transition.eventType; // First, check the trivial case: event names are exactly equal
2361
+
2362
+ if (eventType === receivedEventType) {
2363
+ return true;
2364
+ } // Then, check if transition is a wildcard transition,
2365
+ // which matches any non-transient events
2366
+
2367
+
2368
+ if (eventType === WILDCARD) {
2369
+ return true;
2370
+ }
2371
+
2372
+ if (!partialMatch && !eventType.endsWith('.*')) {
2373
+ return false;
2374
+ }
2375
+
2376
+ if (!IS_PRODUCTION) {
2377
+ warn(!/.*\*.+/.test(eventType), "Wildcards can only be the last token of an event descriptor (e.g., \"event.*\") or the entire event descriptor (\"*\"). Check the \"".concat(eventType, "\" event."));
2378
+ }
2379
+
2380
+ var partialEventTokens = eventType.split('.');
2381
+ var eventTokens = receivedEventType.split('.');
2382
+
2383
+ for (var tokenIndex = 0; tokenIndex < partialEventTokens.length; tokenIndex++) {
2384
+ var partialEventToken = partialEventTokens[tokenIndex];
2385
+ var eventToken = eventTokens[tokenIndex];
2386
+
2387
+ if (partialEventToken === '*') {
2388
+ var isLastToken = tokenIndex === partialEventTokens.length - 1;
2389
+
2390
+ if (!IS_PRODUCTION) {
2391
+ warn(isLastToken, "Infix wildcards in transition events are not allowed. Check the \"".concat(eventType, "\" event."));
2392
+ }
2393
+
2394
+ return isLastToken;
2395
+ }
2396
+
2397
+ if (partialEventToken !== eventToken) {
2398
+ return false;
2399
+ }
2400
+ }
2401
+
2402
+ return true;
2403
+ });
2404
+ return candidates;
2405
+ }
2406
+ /**
2407
+ * All delayed transitions from the config.
2408
+ */
2409
+
2410
+ function getDelayedTransitions(stateNode) {
2411
+ var afterConfig = stateNode.config.after;
2412
+
2413
+ if (!afterConfig) {
2414
+ return [];
2415
+ }
2416
+
2417
+ var mutateEntryExit = function mutateEntryExit(delay, i) {
2418
+ var delayRef = isFunction(delay) ? "".concat(stateNode.id, ":delay[").concat(i, "]") : delay;
2419
+ var eventType = after$1(delayRef, stateNode.id);
2420
+ stateNode.entry.push(send$1({
2421
+ type: eventType
2422
+ }, {
2423
+ delay: delay
2424
+ }));
2425
+ stateNode.exit.push(cancel$1(eventType));
2426
+ return eventType;
2427
+ };
2428
+
2429
+ var delayedTransitions = isArray(afterConfig) ? afterConfig.map(function (transition, i) {
2430
+ var eventType = mutateEntryExit(transition.delay, i);
2431
+ return _objectSpread2(_objectSpread2({}, transition), {}, {
2432
+ event: eventType
2433
+ });
2434
+ }) : Object.keys(afterConfig).flatMap(function (delay, i) {
2435
+ var configTransition = afterConfig[delay];
2436
+ var resolvedTransition = isString(configTransition) ? {
2437
+ target: configTransition
2438
+ } : configTransition;
2439
+ var resolvedDelay = !isNaN(+delay) ? +delay : delay;
2440
+ var eventType = mutateEntryExit(resolvedDelay, i);
2441
+ return toArray(resolvedTransition).map(function (transition) {
2442
+ return _objectSpread2(_objectSpread2({}, transition), {}, {
2443
+ event: eventType,
2444
+ delay: resolvedDelay
2445
+ });
2446
+ });
2447
+ });
2448
+ return delayedTransitions.map(function (delayedTransition) {
2449
+ var delay = delayedTransition.delay;
2450
+ return _objectSpread2(_objectSpread2({}, formatTransition(stateNode, delayedTransition)), {}, {
2451
+ delay: delay
2452
+ });
2453
+ });
2454
+ }
2455
+ function formatTransition(stateNode, transitionConfig) {
2456
+ var normalizedTarget = normalizeTarget(transitionConfig.target);
2457
+ var internal = stateNode === stateNode.machine.root ? true // always internal for root
2458
+ : 'internal' in transitionConfig ? transitionConfig.internal : normalizedTarget ? normalizedTarget.some(function (_target) {
2459
+ return isString(_target) && _target[0] === stateNode.machine.delimiter;
2460
+ }) : true;
2461
+ var guards = stateNode.machine.options.guards;
2462
+ var target = resolveTarget(stateNode, normalizedTarget); // TODO: should this be part of a lint rule instead?
2463
+
2464
+ if (!IS_PRODUCTION && transitionConfig.cond) {
2465
+ throw new Error("State \"".concat(stateNode.id, "\" has declared `cond` for one of its transitions. This property has been renamed to `guard`. Please update your code."));
2466
+ }
2467
+
2468
+ var transition = _objectSpread2(_objectSpread2({}, transitionConfig), {}, {
2469
+ actions: toActionObjects(toArray(transitionConfig.actions)),
2470
+ guard: transitionConfig.guard ? toGuardDefinition(transitionConfig.guard, function (guardType) {
2471
+ return guards[guardType];
2472
+ }) : undefined,
2473
+ target: target,
2474
+ source: stateNode,
2475
+ internal: internal,
2476
+ eventType: transitionConfig.event,
2477
+ toJSON: function toJSON() {
2478
+ return _objectSpread2(_objectSpread2({}, transition), {}, {
2479
+ source: "#".concat(stateNode.id),
2480
+ target: target ? target.map(function (t) {
2481
+ return "#".concat(t.id);
2482
+ }) : undefined
2483
+ });
2484
+ }
2485
+ });
2486
+
2487
+ return transition;
2488
+ }
2489
+ function formatTransitions(stateNode) {
2490
+ var transitionConfigs = [];
2491
+
2492
+ if (Array.isArray(stateNode.config.on)) {
2493
+ transitionConfigs.push.apply(transitionConfigs, _toConsumableArray(stateNode.config.on));
2494
+ } else if (stateNode.config.on) {
2495
+ var _stateNode$config$on = stateNode.config.on,
2496
+ _stateNode$config$on$ = _stateNode$config$on[WILDCARD],
2497
+ wildcardConfigs = _stateNode$config$on$ === void 0 ? [] : _stateNode$config$on$,
2498
+ namedTransitionConfigs = _objectWithoutProperties(_stateNode$config$on, [WILDCARD].map(_toPropertyKey));
2499
+
2500
+ for (var _i = 0, _Object$keys = Object.keys(namedTransitionConfigs); _i < _Object$keys.length; _i++) {
2501
+ var eventType = _Object$keys[_i];
2502
+
2503
+ if (eventType === NULL_EVENT) {
2504
+ throw new Error('Null events ("") cannot be specified as a transition key. Use `always: { ... }` instead.');
2505
+ }
2506
+
2507
+ var eventTransitionConfigs = toTransitionConfigArray(eventType, namedTransitionConfigs[eventType]);
2508
+ transitionConfigs.push.apply(transitionConfigs, _toConsumableArray(eventTransitionConfigs)); // TODO: add dev-mode validation for unreachable transitions
2509
+ }
2510
+
2511
+ transitionConfigs.push.apply(transitionConfigs, _toConsumableArray(toTransitionConfigArray(WILDCARD, wildcardConfigs)));
2512
+ }
2513
+
2514
+ var doneConfig = stateNode.config.onDone ? toTransitionConfigArray(String(done(stateNode.id)), stateNode.config.onDone) : [];
2515
+ var invokeConfig = stateNode.invoke.flatMap(function (invokeDef) {
2516
+ var settleTransitions = [];
2517
+
2518
+ if (invokeDef.onDone) {
2519
+ settleTransitions.push.apply(settleTransitions, _toConsumableArray(toTransitionConfigArray("done.invoke.".concat(invokeDef.id), invokeDef.onDone)));
2520
+ }
2521
+
2522
+ if (invokeDef.onError) {
2523
+ settleTransitions.push.apply(settleTransitions, _toConsumableArray(toTransitionConfigArray("error.platform.".concat(invokeDef.id), invokeDef.onError)));
2524
+ }
2525
+
2526
+ if (invokeDef.onSnapshot) {
2527
+ settleTransitions.push.apply(settleTransitions, _toConsumableArray(toTransitionConfigArray("xstate.snapshot.".concat(invokeDef.id), invokeDef.onSnapshot)));
2528
+ }
2529
+
2530
+ return settleTransitions;
2531
+ });
2532
+ var delayedTransitions = stateNode.after;
2533
+ var formattedTransitions = [].concat(_toConsumableArray(doneConfig), _toConsumableArray(invokeConfig), transitionConfigs).flatMap(function (transitionConfig) {
2534
+ return toArray(transitionConfig).map(function (transition) {
2535
+ return formatTransition(stateNode, transition);
2536
+ });
2537
+ });
2538
+
2539
+ var _iterator7 = _createForOfIteratorHelper(delayedTransitions),
2540
+ _step7;
2541
+
2542
+ try {
2543
+ for (_iterator7.s(); !(_step7 = _iterator7.n()).done;) {
2544
+ var delayedTransition = _step7.value;
2545
+ formattedTransitions.push(delayedTransition);
2546
+ }
2547
+ } catch (err) {
2548
+ _iterator7.e(err);
2549
+ } finally {
2550
+ _iterator7.f();
2551
+ }
2552
+
2553
+ return formattedTransitions;
2554
+ }
2555
+ function formatInitialTransition(stateNode, _target) {
2556
+ if (isString(_target) || isArray(_target)) {
2557
+ var targets = toArray(_target).map(function (t) {
2558
+ // Resolve state string keys (which represent children)
2559
+ // to their state node
2560
+ var descStateNode = isString(t) ? isStateId(t) ? stateNode.machine.getStateNodeById(t) : stateNode.states[t] : t;
2561
+
2562
+ if (!descStateNode) {
2563
+ throw new Error("Initial state node \"".concat(t, "\" not found on parent state node #").concat(stateNode.id));
2564
+ }
2565
+
2566
+ if (!isDescendant(descStateNode, stateNode)) {
2567
+ throw new Error("Invalid initial target: state node #".concat(descStateNode.id, " is not a descendant of #").concat(stateNode.id));
2568
+ }
2569
+
2570
+ return descStateNode;
2571
+ });
2572
+ var resolvedTarget = resolveTarget(stateNode, targets);
2573
+ var transition = {
2574
+ source: stateNode,
2575
+ actions: [],
2576
+ eventType: null,
2577
+ target: resolvedTarget,
2578
+ toJSON: function toJSON() {
2579
+ return _objectSpread2(_objectSpread2({}, transition), {}, {
2580
+ source: "#".concat(stateNode.id),
2581
+ target: resolvedTarget ? resolvedTarget.map(function (t) {
2582
+ return "#".concat(t.id);
2583
+ }) : undefined
2584
+ });
2585
+ }
2586
+ };
2587
+ return transition;
2588
+ }
2589
+
2590
+ return formatTransition(stateNode, {
2591
+ target: toArray(_target.target).map(function (t) {
2592
+ if (isString(t)) {
2593
+ return isStateId(t) ? t : "".concat(stateNode.machine.delimiter).concat(t);
2594
+ }
2595
+
2596
+ return t;
2597
+ }),
2598
+ actions: _target.actions,
2599
+ event: null
2600
+ });
2601
+ }
2602
+ function resolveTarget(stateNode, targets) {
2603
+ if (targets === undefined) {
2604
+ // an undefined target signals that the state node should not transition from that state when receiving that event
2605
+ return undefined;
2606
+ }
2607
+
2608
+ return targets.map(function (target) {
2609
+ if (!isString(target)) {
2610
+ return target;
2611
+ }
2612
+
2613
+ var isInternalTarget = target[0] === stateNode.machine.delimiter; // If internal target is defined on machine,
2614
+ // do not include machine key on target
2615
+
2616
+ if (isInternalTarget && !stateNode.parent) {
2617
+ return getStateNodeByPath(stateNode, target.slice(1));
2618
+ }
2619
+
2620
+ var resolvedTarget = isInternalTarget ? stateNode.key + target : target;
2621
+
2622
+ if (stateNode.parent) {
2623
+ try {
2624
+ var targetStateNode = getStateNodeByPath(stateNode.parent, resolvedTarget);
2625
+ return targetStateNode;
2626
+ } catch (err) {
2627
+ throw new Error("Invalid transition definition for state node '".concat(stateNode.id, "':\n").concat(err.message));
2628
+ }
2629
+ } else {
2630
+ return getStateNodeByPath(stateNode, resolvedTarget);
2631
+ }
2632
+ });
2633
+ }
2634
+
2635
+ function resolveHistoryTarget(stateNode) {
2636
+ var normalizedTarget = normalizeTarget(stateNode.target);
2637
+
2638
+ if (!normalizedTarget) {
2639
+ return stateNode.parent.initial.target;
2640
+ }
2641
+
2642
+ return normalizedTarget.map(function (t) {
2643
+ return typeof t === 'string' ? getStateNodeByPath(stateNode.parent, t) : t;
2644
+ });
2645
+ }
2646
+
2647
+ function isHistoryNode(stateNode) {
2648
+ return stateNode.type === 'history';
2649
+ }
2650
+
2651
+ function getInitialStateNodes(stateNode) {
2652
+ var set = new Set();
2653
+
2654
+ function iter(descStateNode) {
2655
+ if (set.has(descStateNode)) {
2656
+ return;
2657
+ }
2658
+
2659
+ set.add(descStateNode);
2660
+
2661
+ if (descStateNode.type === 'compound') {
2662
+ var _iterator8 = _createForOfIteratorHelper(descStateNode.initial.target),
2663
+ _step8;
2664
+
2665
+ try {
2666
+ for (_iterator8.s(); !(_step8 = _iterator8.n()).done;) {
2667
+ var targetStateNode = _step8.value;
2668
+
2669
+ var _iterator9 = _createForOfIteratorHelper(getProperAncestors(targetStateNode, stateNode)),
2670
+ _step9;
2671
+
2672
+ try {
2673
+ for (_iterator9.s(); !(_step9 = _iterator9.n()).done;) {
2674
+ var a = _step9.value;
2675
+ set.add(a);
2676
+ }
2677
+ } catch (err) {
2678
+ _iterator9.e(err);
2679
+ } finally {
2680
+ _iterator9.f();
2681
+ }
2682
+
2683
+ iter(targetStateNode);
2684
+ }
2685
+ } catch (err) {
2686
+ _iterator8.e(err);
2687
+ } finally {
2688
+ _iterator8.f();
2689
+ }
2690
+ } else if (descStateNode.type === 'parallel') {
2691
+ var _iterator10 = _createForOfIteratorHelper(getChildren(descStateNode)),
2692
+ _step10;
2693
+
2694
+ try {
2695
+ for (_iterator10.s(); !(_step10 = _iterator10.n()).done;) {
2696
+ var child = _step10.value;
2697
+ iter(child);
2698
+ }
2699
+ } catch (err) {
2700
+ _iterator10.e(err);
2701
+ } finally {
2702
+ _iterator10.f();
2703
+ }
2704
+ }
2705
+ }
2706
+
2707
+ iter(stateNode);
2708
+ return _toConsumableArray(set);
2709
+ }
2710
+ /**
2711
+ * Returns the child state node from its relative `stateKey`, or throws.
2712
+ */
2713
+
2714
+ function getStateNode(stateNode, stateKey) {
2715
+ if (isStateId(stateKey)) {
2716
+ return stateNode.machine.getStateNodeById(stateKey);
2717
+ }
2718
+
2719
+ if (!stateNode.states) {
2720
+ throw new Error("Unable to retrieve child state '".concat(stateKey, "' from '").concat(stateNode.id, "'; no child states exist."));
2721
+ }
2722
+
2723
+ var result = stateNode.states[stateKey];
2724
+
2725
+ if (!result) {
2726
+ throw new Error("Child state '".concat(stateKey, "' does not exist on '").concat(stateNode.id, "'"));
2727
+ }
2728
+
2729
+ return result;
2730
+ }
2731
+ /**
2732
+ * Returns the relative state node from the given `statePath`, or throws.
2733
+ *
2734
+ * @param statePath The string or string array relative path to the state node.
2735
+ */
2736
+
2737
+ function getStateNodeByPath(stateNode, statePath) {
2738
+ if (typeof statePath === 'string' && isStateId(statePath)) {
2739
+ try {
2740
+ return stateNode.machine.getStateNodeById(statePath);
2741
+ } catch (e) {// try individual paths
2742
+ // throw e;
2743
+ }
2744
+ }
2745
+
2746
+ var arrayStatePath = toStatePath(statePath, stateNode.machine.delimiter).slice();
2747
+ var currentStateNode = stateNode;
2748
+
2749
+ while (arrayStatePath.length) {
2750
+ var key = arrayStatePath.shift();
2751
+
2752
+ if (!key.length) {
2753
+ break;
2754
+ }
2755
+
2756
+ currentStateNode = getStateNode(currentStateNode, key);
2757
+ }
2758
+
2759
+ return currentStateNode;
2760
+ }
2761
+ /**
2762
+ * Returns the state nodes represented by the current state value.
2763
+ *
2764
+ * @param state The state value or State instance
2765
+ */
2766
+
2767
+
2768
+ function getStateNodes(stateNode, state) {
2769
+ var stateValue = state instanceof State ? state.value : toStateValue(state, stateNode.machine.delimiter);
2770
+
2771
+ if (isString(stateValue)) {
2772
+ return [stateNode, stateNode.states[stateValue]];
2773
+ }
2774
+
2775
+ var childStateKeys = Object.keys(stateValue);
2776
+ var childStateNodes = childStateKeys.map(function (subStateKey) {
2777
+ return getStateNode(stateNode, subStateKey);
2778
+ }).filter(Boolean);
2779
+ return [stateNode.machine.root, stateNode].concat(childStateNodes, childStateKeys.reduce(function (allSubStateNodes, subStateKey) {
2780
+ var subStateNode = getStateNode(stateNode, subStateKey);
2781
+
2782
+ if (!subStateNode) {
2783
+ return allSubStateNodes;
2784
+ }
2785
+
2786
+ var subStateNodes = getStateNodes(subStateNode, stateValue[subStateKey]);
2787
+ return allSubStateNodes.concat(subStateNodes);
2788
+ }, []));
2789
+ }
2790
+ function transitionAtomicNode(stateNode, stateValue, state, _event) {
2791
+ var childStateNode = getStateNode(stateNode, stateValue);
2792
+ var next = childStateNode.next(state, _event);
2793
+
2794
+ if (!next || !next.length) {
2795
+ return stateNode.next(state, _event);
2796
+ }
2797
+
2798
+ return next;
2799
+ }
2800
+ function transitionCompoundNode(stateNode, stateValue, state, _event) {
2801
+ var subStateKeys = Object.keys(stateValue);
2802
+ var childStateNode = getStateNode(stateNode, subStateKeys[0]);
2803
+ var next = transitionNode(childStateNode, stateValue[subStateKeys[0]], state, _event);
2804
+
2805
+ if (!next || !next.length) {
2806
+ return stateNode.next(state, _event);
2807
+ }
2808
+
2809
+ return next;
2810
+ }
2811
+ function transitionParallelNode(stateNode, stateValue, state, _event) {
2812
+ var allInnerTransitions = [];
2813
+
2814
+ for (var _i2 = 0, _Object$keys2 = Object.keys(stateValue); _i2 < _Object$keys2.length; _i2++) {
2815
+ var subStateKey = _Object$keys2[_i2];
2816
+ var subStateValue = stateValue[subStateKey];
2817
+
2818
+ if (!subStateValue) {
2819
+ continue;
2820
+ }
2821
+
2822
+ var subStateNode = getStateNode(stateNode, subStateKey);
2823
+ var innerTransitions = transitionNode(subStateNode, subStateValue, state, _event);
2824
+
2825
+ if (innerTransitions) {
2826
+ allInnerTransitions.push.apply(allInnerTransitions, _toConsumableArray(innerTransitions));
2827
+ }
2828
+ }
2829
+
2830
+ if (!allInnerTransitions.length) {
2831
+ return stateNode.next(state, _event);
2832
+ }
2833
+
2834
+ return allInnerTransitions;
2835
+ }
2836
+ function transitionNode(stateNode, stateValue, state, _event) {
2837
+ // leaf node
2838
+ if (isString(stateValue)) {
2839
+ return transitionAtomicNode(stateNode, stateValue, state, _event);
2840
+ } // compound node
2841
+
2842
+
2843
+ if (Object.keys(stateValue).length === 1) {
2844
+ return transitionCompoundNode(stateNode, stateValue, state, _event);
2845
+ } // parallel node
2846
+
2847
+
2848
+ return transitionParallelNode(stateNode, stateValue, state, _event);
2849
+ }
2850
+
2851
+ function getHistoryNodes(stateNode) {
2852
+ return Object.keys(stateNode.states).map(function (key) {
2853
+ return stateNode.states[key];
2854
+ }).filter(function (sn) {
2855
+ return sn.type === 'history';
2856
+ });
2857
+ }
2858
+
2859
+ function isDescendant(childStateNode, parentStateNode) {
2860
+ var marker = childStateNode;
2861
+
2862
+ while (marker.parent && marker.parent !== parentStateNode) {
2863
+ marker = marker.parent;
2864
+ }
2865
+
2866
+ return marker.parent === parentStateNode;
2867
+ }
2868
+
2869
+ function getPathFromRootToNode(stateNode) {
2870
+ var path = [];
2871
+ var marker = stateNode.parent;
2872
+
2873
+ while (marker) {
2874
+ path.unshift(marker);
2875
+ marker = marker.parent;
2876
+ }
2877
+
2878
+ return path;
2879
+ }
2880
+
2881
+ function hasIntersection(s1, s2) {
2882
+ var set1 = new Set(s1);
2883
+ var set2 = new Set(s2);
2884
+
2885
+ var _iterator11 = _createForOfIteratorHelper(set1),
2886
+ _step11;
2887
+
2888
+ try {
2889
+ for (_iterator11.s(); !(_step11 = _iterator11.n()).done;) {
2890
+ var item = _step11.value;
2891
+
2892
+ if (set2.has(item)) {
2893
+ return true;
2894
+ }
2895
+ }
2896
+ } catch (err) {
2897
+ _iterator11.e(err);
2898
+ } finally {
2899
+ _iterator11.f();
2900
+ }
2901
+
2902
+ var _iterator12 = _createForOfIteratorHelper(set2),
2903
+ _step12;
2904
+
2905
+ try {
2906
+ for (_iterator12.s(); !(_step12 = _iterator12.n()).done;) {
2907
+ var _item = _step12.value;
2908
+
2909
+ if (set1.has(_item)) {
2910
+ return true;
2911
+ }
2912
+ }
2913
+ } catch (err) {
2914
+ _iterator12.e(err);
2915
+ } finally {
2916
+ _iterator12.f();
2917
+ }
2918
+
2919
+ return false;
2920
+ }
2921
+
2922
+ function removeConflictingTransitions(enabledTransitions, configuration, historyValue) {
2923
+ var filteredTransitions = new Set();
2924
+
2925
+ var _iterator13 = _createForOfIteratorHelper(enabledTransitions),
2926
+ _step13;
2927
+
2928
+ try {
2929
+ for (_iterator13.s(); !(_step13 = _iterator13.n()).done;) {
2930
+ var t1 = _step13.value;
2931
+ var t1Preempted = false;
2932
+ var transitionsToRemove = new Set();
2933
+
2934
+ var _iterator14 = _createForOfIteratorHelper(filteredTransitions),
2935
+ _step14;
2936
+
2937
+ try {
2938
+ for (_iterator14.s(); !(_step14 = _iterator14.n()).done;) {
2939
+ var t2 = _step14.value;
2940
+
2941
+ if (hasIntersection(computeExitSet([t1], configuration, historyValue), computeExitSet([t2], configuration, historyValue))) {
2942
+ if (isDescendant(t1.source, t2.source)) {
2943
+ transitionsToRemove.add(t2);
2944
+ } else {
2945
+ t1Preempted = true;
2946
+ break;
2947
+ }
2948
+ }
2949
+ }
2950
+ } catch (err) {
2951
+ _iterator14.e(err);
2952
+ } finally {
2953
+ _iterator14.f();
2954
+ }
2955
+
2956
+ if (!t1Preempted) {
2957
+ var _iterator15 = _createForOfIteratorHelper(transitionsToRemove),
2958
+ _step15;
2959
+
2960
+ try {
2961
+ for (_iterator15.s(); !(_step15 = _iterator15.n()).done;) {
2962
+ var t3 = _step15.value;
2963
+ filteredTransitions["delete"](t3);
2964
+ }
2965
+ } catch (err) {
2966
+ _iterator15.e(err);
2967
+ } finally {
2968
+ _iterator15.f();
2969
+ }
2970
+
2971
+ filteredTransitions.add(t1);
2972
+ }
2973
+ }
2974
+ } catch (err) {
2975
+ _iterator13.e(err);
2976
+ } finally {
2977
+ _iterator13.f();
2978
+ }
2979
+
2980
+ return Array.from(filteredTransitions);
2981
+ }
2982
+
2983
+ function findLCCA(stateNodes) {
2984
+ var _stateNodes = _slicedToArray(stateNodes, 1),
2985
+ head = _stateNodes[0];
2986
+
2987
+ var current = getPathFromRootToNode(head);
2988
+ var candidates = [];
2989
+
2990
+ var _iterator16 = _createForOfIteratorHelper(stateNodes),
2991
+ _step16;
2992
+
2993
+ try {
2994
+ var _loop = function _loop() {
2995
+ var stateNode = _step16.value;
2996
+ var path = getPathFromRootToNode(stateNode);
2997
+ candidates = current.filter(function (sn) {
2998
+ return path.includes(sn);
2999
+ });
3000
+ current = candidates;
3001
+ candidates = [];
3002
+ };
3003
+
3004
+ for (_iterator16.s(); !(_step16 = _iterator16.n()).done;) {
3005
+ _loop();
3006
+ }
3007
+ } catch (err) {
3008
+ _iterator16.e(err);
3009
+ } finally {
3010
+ _iterator16.f();
3011
+ }
3012
+
3013
+ return current[current.length - 1];
3014
+ }
3015
+
3016
+ function getEffectiveTargetStates(transition, historyValue) {
3017
+ if (!transition.target) {
3018
+ return [];
3019
+ }
3020
+
3021
+ var targets = new Set();
3022
+
3023
+ var _iterator17 = _createForOfIteratorHelper(transition.target),
3024
+ _step17;
3025
+
3026
+ try {
3027
+ for (_iterator17.s(); !(_step17 = _iterator17.n()).done;) {
3028
+ var targetNode = _step17.value;
3029
+
3030
+ if (isHistoryNode(targetNode)) {
3031
+ if (historyValue[targetNode.id]) {
3032
+ var _iterator18 = _createForOfIteratorHelper(historyValue[targetNode.id]),
3033
+ _step18;
3034
+
3035
+ try {
3036
+ for (_iterator18.s(); !(_step18 = _iterator18.n()).done;) {
3037
+ var node = _step18.value;
3038
+ targets.add(node);
3039
+ }
3040
+ } catch (err) {
3041
+ _iterator18.e(err);
3042
+ } finally {
3043
+ _iterator18.f();
3044
+ }
3045
+ } else {
3046
+ var _iterator19 = _createForOfIteratorHelper(getEffectiveTargetStates({
3047
+ target: resolveHistoryTarget(targetNode)
3048
+ }, historyValue)),
3049
+ _step19;
3050
+
3051
+ try {
3052
+ for (_iterator19.s(); !(_step19 = _iterator19.n()).done;) {
3053
+ var _node = _step19.value;
3054
+ targets.add(_node);
3055
+ }
3056
+ } catch (err) {
3057
+ _iterator19.e(err);
3058
+ } finally {
3059
+ _iterator19.f();
3060
+ }
3061
+ }
3062
+ } else {
3063
+ targets.add(targetNode);
3064
+ }
3065
+ }
3066
+ } catch (err) {
3067
+ _iterator17.e(err);
3068
+ } finally {
3069
+ _iterator17.f();
3070
+ }
3071
+
3072
+ return _toConsumableArray(targets);
3073
+ }
3074
+
3075
+ function getTransitionDomain(transition, historyValue) {
3076
+ var targetStates = getEffectiveTargetStates(transition, historyValue);
3077
+
3078
+ if (!targetStates) {
3079
+ return null;
3080
+ }
3081
+
3082
+ if (transition.internal && transition.source.type === 'compound' && targetStates.every(function (targetStateNode) {
3083
+ return isDescendant(targetStateNode, transition.source);
3084
+ })) {
3085
+ return transition.source;
3086
+ }
3087
+
3088
+ var lcca = findLCCA(targetStates.concat(transition.source));
3089
+ return lcca;
3090
+ }
3091
+
3092
+ function computeExitSet(transitions, configuration, historyValue) {
3093
+ var statesToExit = new Set();
3094
+
3095
+ var _iterator20 = _createForOfIteratorHelper(transitions),
3096
+ _step20;
3097
+
3098
+ try {
3099
+ for (_iterator20.s(); !(_step20 = _iterator20.n()).done;) {
3100
+ var _t$target;
3101
+
3102
+ var t = _step20.value;
3103
+
3104
+ if ((_t$target = t.target) !== null && _t$target !== void 0 && _t$target.length) {
3105
+ var domain = getTransitionDomain(t, historyValue);
3106
+
3107
+ var _iterator21 = _createForOfIteratorHelper(configuration),
3108
+ _step21;
3109
+
3110
+ try {
3111
+ for (_iterator21.s(); !(_step21 = _iterator21.n()).done;) {
3112
+ var stateNode = _step21.value;
3113
+
3114
+ if (isDescendant(stateNode, domain)) {
3115
+ statesToExit.add(stateNode);
3116
+ }
3117
+ }
3118
+ } catch (err) {
3119
+ _iterator21.e(err);
3120
+ } finally {
3121
+ _iterator21.f();
3122
+ }
3123
+ }
3124
+ }
3125
+ } catch (err) {
3126
+ _iterator20.e(err);
3127
+ } finally {
3128
+ _iterator20.f();
3129
+ }
3130
+
3131
+ return _toConsumableArray(statesToExit);
3132
+ }
3133
+ /**
3134
+ * https://www.w3.org/TR/scxml/#microstepProcedure
3135
+ *
3136
+ * @private
3137
+ * @param transitions
3138
+ * @param currentState
3139
+ * @param mutConfiguration
3140
+ */
3141
+
3142
+
3143
+ function microstep(transitions, currentState, actorCtx, scxmlEvent) {
3144
+ var machine = currentState.machine; // Transition will "apply" if:
3145
+ // - the state node is the initial state (there is no current state)
3146
+ // - OR there are transitions
3147
+
3148
+ var willTransition = currentState._initial || transitions.length > 0;
3149
+ var mutConfiguration = new Set(currentState.configuration);
3150
+
3151
+ if (!currentState._initial && !willTransition) {
3152
+ var inertState = cloneState(currentState, {
3153
+ _event: scxmlEvent,
3154
+ actions: [],
3155
+ transitions: []
3156
+ });
3157
+ inertState.changed = false;
3158
+ return inertState;
3159
+ }
3160
+
3161
+ var microstate = microstepProcedure(currentState._initial ? [{
3162
+ target: _toConsumableArray(currentState.configuration).filter(isAtomicStateNode),
3163
+ source: machine.root,
3164
+ actions: [],
3165
+ eventType: null,
3166
+ toJSON: null // TODO: fix
3167
+
3168
+ }] : transitions, currentState, mutConfiguration, scxmlEvent, actorCtx);
3169
+ var context = microstate.context,
3170
+ nonRaisedActions = microstate.actions;
3171
+ var children = setChildren(currentState, nonRaisedActions);
3172
+ var nextState = cloneState(microstate, {
3173
+ value: {},
3174
+ // TODO: make optional
3175
+ transitions: transitions,
3176
+ children: children
3177
+ });
3178
+ nextState.changed = currentState._initial ? undefined : !stateValuesEqual(nextState.value, currentState.value) || nextState.actions.length > 0 || context !== currentState.context;
3179
+ return nextState;
3180
+ }
3181
+
3182
+ function setChildren(currentState, nonRaisedActions) {
3183
+ var children = _objectSpread2({}, currentState.children);
3184
+
3185
+ var _iterator22 = _createForOfIteratorHelper(nonRaisedActions),
3186
+ _step22;
3187
+
3188
+ try {
3189
+ for (_iterator22.s(); !(_step22 = _iterator22.n()).done;) {
3190
+ var action = _step22.value;
3191
+
3192
+ if (action.type === invoke && action.params.ref) {
3193
+ var ref = action.params.ref;
3194
+
3195
+ if (ref) {
3196
+ children[ref.id] = ref;
3197
+ }
3198
+ } else if (action.type === stop) {
3199
+ var _ref = action.params.actor;
3200
+
3201
+ if (_ref) {
3202
+ delete children[_ref.id];
3203
+ }
3204
+ }
3205
+ }
3206
+ } catch (err) {
3207
+ _iterator22.e(err);
3208
+ } finally {
3209
+ _iterator22.f();
3210
+ }
3211
+
3212
+ return children;
3213
+ }
3214
+
3215
+ function microstepProcedure(transitions, currentState, mutConfiguration, scxmlEvent, actorCtx) {
3216
+ var machine = currentState.machine;
3217
+ var actions = [];
3218
+
3219
+ var historyValue = _objectSpread2({}, currentState.historyValue);
3220
+
3221
+ var filteredTransitions = removeConflictingTransitions(transitions, mutConfiguration, historyValue);
3222
+
3223
+ var internalQueue = _toConsumableArray(currentState._internalQueue); // Exit states
3224
+
3225
+
3226
+ if (!currentState._initial) {
3227
+ exitStates(filteredTransitions, mutConfiguration, historyValue, actions);
3228
+ } // Execute transition content
3229
+
3230
+
3231
+ actions.push.apply(actions, _toConsumableArray(filteredTransitions.flatMap(function (t) {
3232
+ return t.actions;
3233
+ }))); // Enter states
3234
+
3235
+ enterStates(filteredTransitions, mutConfiguration, actions, internalQueue, currentState, historyValue);
3236
+
3237
+ var nextConfiguration = _toConsumableArray(mutConfiguration);
3238
+
3239
+ var done = isInFinalState(nextConfiguration);
3240
+
3241
+ if (done) {
3242
+ var finalActions = nextConfiguration.sort(function (a, b) {
3243
+ return b.order - a.order;
3244
+ }).flatMap(function (state) {
3245
+ return state.exit;
3246
+ });
3247
+ actions.push.apply(actions, _toConsumableArray(finalActions));
3248
+ }
3249
+
3250
+ try {
3251
+ var _resolveActionsAndCon = resolveActionsAndContext(actions, scxmlEvent, currentState, actorCtx),
3252
+ nextState = _resolveActionsAndCon.nextState;
3253
+
3254
+ var output = done ? getOutput(nextConfiguration, nextState.context, scxmlEvent) : undefined;
3255
+ internalQueue.push.apply(internalQueue, _toConsumableArray(nextState._internalQueue));
3256
+ return cloneState(currentState, {
3257
+ actions: nextState.actions,
3258
+ configuration: nextConfiguration,
3259
+ historyValue: historyValue,
3260
+ _internalQueue: internalQueue,
3261
+ context: nextState.context,
3262
+ _event: scxmlEvent,
3263
+ done: done,
3264
+ output: output,
3265
+ children: nextState.children
3266
+ });
3267
+ } catch (e) {
3268
+ // TODO: Refactor this once proper error handling is implemented.
3269
+ // See https://github.com/statelyai/rfcs/pull/4
3270
+ if (machine.config.scxml) {
3271
+ return cloneState(currentState, {
3272
+ actions: [],
3273
+ configuration: Array.from(mutConfiguration),
3274
+ historyValue: historyValue,
3275
+ _internalQueue: [toSCXMLEvent({
3276
+ type: 'error.execution'
3277
+ })],
3278
+ context: machine.context
3279
+ });
3280
+ } else {
3281
+ throw e;
3282
+ }
3283
+ }
3284
+ }
3285
+
3286
+ function enterStates(filteredTransitions, mutConfiguration, actions, internalQueue, currentState, historyValue) {
3287
+ var statesToEnter = new Set();
3288
+ var statesForDefaultEntry = new Set();
3289
+ computeEntrySet(filteredTransitions, historyValue, statesForDefaultEntry, statesToEnter); // In the initial state, the root state node is "entered".
3290
+
3291
+ if (currentState._initial) {
3292
+ statesForDefaultEntry.add(currentState.machine.root);
3293
+ }
3294
+
3295
+ var _iterator23 = _createForOfIteratorHelper(_toConsumableArray(statesToEnter).sort(function (a, b) {
3296
+ return a.order - b.order;
3297
+ })),
3298
+ _step23;
3299
+
3300
+ try {
3301
+ for (_iterator23.s(); !(_step23 = _iterator23.n()).done;) {
3302
+ var stateNodeToEnter = _step23.value;
3303
+ mutConfiguration.add(stateNodeToEnter);
3304
+
3305
+ var _iterator24 = _createForOfIteratorHelper(stateNodeToEnter.invoke),
3306
+ _step24;
3307
+
3308
+ try {
3309
+ for (_iterator24.s(); !(_step24 = _iterator24.n()).done;) {
3310
+ var invokeDef = _step24.value;
3311
+ actions.push(invoke$1(invokeDef));
3312
+ } // Add entry actions
3313
+
3314
+ } catch (err) {
3315
+ _iterator24.e(err);
3316
+ } finally {
3317
+ _iterator24.f();
3318
+ }
3319
+
3320
+ actions.push.apply(actions, _toConsumableArray(stateNodeToEnter.entry));
3321
+
3322
+ if (statesForDefaultEntry.has(stateNodeToEnter)) {
3323
+ var _iterator25 = _createForOfIteratorHelper(statesForDefaultEntry),
3324
+ _step25;
3325
+
3326
+ try {
3327
+ for (_iterator25.s(); !(_step25 = _iterator25.n()).done;) {
3328
+ var stateNode = _step25.value;
3329
+ var initialActions = stateNode.initial.actions;
3330
+ actions.push.apply(actions, _toConsumableArray(initialActions));
3331
+ }
3332
+ } catch (err) {
3333
+ _iterator25.e(err);
3334
+ } finally {
3335
+ _iterator25.f();
3336
+ }
3337
+ }
3338
+
3339
+ if (stateNodeToEnter.type === 'final') {
3340
+ var parent = stateNodeToEnter.parent;
3341
+
3342
+ if (!parent.parent) {
3343
+ continue;
3344
+ }
3345
+
3346
+ internalQueue.push(toSCXMLEvent(done(parent.id, stateNodeToEnter.doneData ? mapContext(stateNodeToEnter.doneData, currentState.context, currentState._event) : undefined)));
3347
+
3348
+ if (parent.parent) {
3349
+ var grandparent = parent.parent;
3350
+
3351
+ if (grandparent.type === 'parallel') {
3352
+ if (getChildren(grandparent).every(function (parentNode) {
3353
+ return isInFinalState(_toConsumableArray(mutConfiguration), parentNode);
3354
+ })) {
3355
+ internalQueue.push(toSCXMLEvent(done(grandparent.id)));
3356
+ }
3357
+ }
3358
+ }
3359
+ }
3360
+ }
3361
+ } catch (err) {
3362
+ _iterator23.e(err);
3363
+ } finally {
3364
+ _iterator23.f();
3365
+ }
3366
+ }
3367
+
3368
+ function computeEntrySet(transitions, historyValue, statesForDefaultEntry, statesToEnter) {
3369
+ var _iterator26 = _createForOfIteratorHelper(transitions),
3370
+ _step26;
3371
+
3372
+ try {
3373
+ for (_iterator26.s(); !(_step26 = _iterator26.n()).done;) {
3374
+ var t = _step26.value;
3375
+
3376
+ var _iterator27 = _createForOfIteratorHelper(t.target || []),
3377
+ _step27;
3378
+
3379
+ try {
3380
+ for (_iterator27.s(); !(_step27 = _iterator27.n()).done;) {
3381
+ var s = _step27.value;
3382
+ addDescendantStatesToEnter(s, historyValue, statesForDefaultEntry, statesToEnter);
3383
+ }
3384
+ } catch (err) {
3385
+ _iterator27.e(err);
3386
+ } finally {
3387
+ _iterator27.f();
3388
+ }
3389
+
3390
+ var ancestor = getTransitionDomain(t, historyValue);
3391
+ var targetStates = getEffectiveTargetStates(t, historyValue);
3392
+
3393
+ var _iterator28 = _createForOfIteratorHelper(targetStates),
3394
+ _step28;
3395
+
3396
+ try {
3397
+ for (_iterator28.s(); !(_step28 = _iterator28.n()).done;) {
3398
+ var _s2 = _step28.value;
3399
+ addAncestorStatesToEnter(_s2, ancestor, statesToEnter, historyValue, statesForDefaultEntry);
3400
+ }
3401
+ } catch (err) {
3402
+ _iterator28.e(err);
3403
+ } finally {
3404
+ _iterator28.f();
3405
+ }
3406
+ }
3407
+ } catch (err) {
3408
+ _iterator26.e(err);
3409
+ } finally {
3410
+ _iterator26.f();
3411
+ }
3412
+ }
3413
+
3414
+ function addDescendantStatesToEnter(stateNode, historyValue, statesForDefaultEntry, statesToEnter) {
3415
+ if (isHistoryNode(stateNode)) {
3416
+ if (historyValue[stateNode.id]) {
3417
+ var historyStateNodes = historyValue[stateNode.id];
3418
+
3419
+ var _iterator29 = _createForOfIteratorHelper(historyStateNodes),
3420
+ _step29;
3421
+
3422
+ try {
3423
+ for (_iterator29.s(); !(_step29 = _iterator29.n()).done;) {
3424
+ var s = _step29.value;
3425
+ addDescendantStatesToEnter(s, historyValue, statesForDefaultEntry, statesToEnter);
3426
+ }
3427
+ } catch (err) {
3428
+ _iterator29.e(err);
3429
+ } finally {
3430
+ _iterator29.f();
3431
+ }
3432
+
3433
+ var _iterator30 = _createForOfIteratorHelper(historyStateNodes),
3434
+ _step30;
3435
+
3436
+ try {
3437
+ for (_iterator30.s(); !(_step30 = _iterator30.n()).done;) {
3438
+ var _s3 = _step30.value;
3439
+ addAncestorStatesToEnter(_s3, stateNode.parent, statesToEnter, historyValue, statesForDefaultEntry);
3440
+
3441
+ var _iterator31 = _createForOfIteratorHelper(statesForDefaultEntry),
3442
+ _step31;
3443
+
3444
+ try {
3445
+ for (_iterator31.s(); !(_step31 = _iterator31.n()).done;) {
3446
+ var stateForDefaultEntry = _step31.value;
3447
+ statesForDefaultEntry.add(stateForDefaultEntry);
3448
+ }
3449
+ } catch (err) {
3450
+ _iterator31.e(err);
3451
+ } finally {
3452
+ _iterator31.f();
3453
+ }
3454
+ }
3455
+ } catch (err) {
3456
+ _iterator30.e(err);
3457
+ } finally {
3458
+ _iterator30.f();
3459
+ }
3460
+ } else {
3461
+ var targets = resolveHistoryTarget(stateNode);
3462
+
3463
+ var _iterator32 = _createForOfIteratorHelper(targets),
3464
+ _step32;
3465
+
3466
+ try {
3467
+ for (_iterator32.s(); !(_step32 = _iterator32.n()).done;) {
3468
+ var _s4 = _step32.value;
3469
+ addDescendantStatesToEnter(_s4, historyValue, statesForDefaultEntry, statesToEnter);
3470
+ }
3471
+ } catch (err) {
3472
+ _iterator32.e(err);
3473
+ } finally {
3474
+ _iterator32.f();
3475
+ }
3476
+
3477
+ var _iterator33 = _createForOfIteratorHelper(targets),
3478
+ _step33;
3479
+
3480
+ try {
3481
+ for (_iterator33.s(); !(_step33 = _iterator33.n()).done;) {
3482
+ var _s5 = _step33.value;
3483
+ addAncestorStatesToEnter(_s5, stateNode, statesToEnter, historyValue, statesForDefaultEntry);
3484
+
3485
+ var _iterator34 = _createForOfIteratorHelper(statesForDefaultEntry),
3486
+ _step34;
3487
+
3488
+ try {
3489
+ for (_iterator34.s(); !(_step34 = _iterator34.n()).done;) {
3490
+ var _stateForDefaultEntry = _step34.value;
3491
+ statesForDefaultEntry.add(_stateForDefaultEntry);
3492
+ }
3493
+ } catch (err) {
3494
+ _iterator34.e(err);
3495
+ } finally {
3496
+ _iterator34.f();
3497
+ }
3498
+ }
3499
+ } catch (err) {
3500
+ _iterator33.e(err);
3501
+ } finally {
3502
+ _iterator33.f();
3503
+ }
3504
+ }
3505
+ } else {
3506
+ statesToEnter.add(stateNode);
3507
+
3508
+ if (stateNode.type === 'compound') {
3509
+ statesForDefaultEntry.add(stateNode);
3510
+ var initialStates = stateNode.initial.target;
3511
+
3512
+ var _iterator35 = _createForOfIteratorHelper(initialStates),
3513
+ _step35;
3514
+
3515
+ try {
3516
+ for (_iterator35.s(); !(_step35 = _iterator35.n()).done;) {
3517
+ var initialState = _step35.value;
3518
+ addDescendantStatesToEnter(initialState, historyValue, statesForDefaultEntry, statesToEnter);
3519
+ }
3520
+ } catch (err) {
3521
+ _iterator35.e(err);
3522
+ } finally {
3523
+ _iterator35.f();
3524
+ }
3525
+
3526
+ var _iterator36 = _createForOfIteratorHelper(initialStates),
3527
+ _step36;
3528
+
3529
+ try {
3530
+ for (_iterator36.s(); !(_step36 = _iterator36.n()).done;) {
3531
+ var _initialState = _step36.value;
3532
+ addAncestorStatesToEnter(_initialState, stateNode, statesToEnter, historyValue, statesForDefaultEntry);
3533
+ }
3534
+ } catch (err) {
3535
+ _iterator36.e(err);
3536
+ } finally {
3537
+ _iterator36.f();
3538
+ }
3539
+ } else {
3540
+ if (stateNode.type === 'parallel') {
3541
+ var _iterator37 = _createForOfIteratorHelper(getChildren(stateNode).filter(function (sn) {
3542
+ return !isHistoryNode(sn);
3543
+ })),
3544
+ _step37;
3545
+
3546
+ try {
3547
+ var _loop2 = function _loop2() {
3548
+ var child = _step37.value;
3549
+
3550
+ if (!_toConsumableArray(statesToEnter).some(function (s) {
3551
+ return isDescendant(s, child);
3552
+ })) {
3553
+ addDescendantStatesToEnter(child, historyValue, statesForDefaultEntry, statesToEnter);
3554
+ }
3555
+ };
3556
+
3557
+ for (_iterator37.s(); !(_step37 = _iterator37.n()).done;) {
3558
+ _loop2();
3559
+ }
3560
+ } catch (err) {
3561
+ _iterator37.e(err);
3562
+ } finally {
3563
+ _iterator37.f();
3564
+ }
3565
+ }
3566
+ }
3567
+ }
3568
+ }
3569
+
3570
+ function addAncestorStatesToEnter(stateNode, toStateNode, statesToEnter, historyValue, statesForDefaultEntry) {
3571
+ var properAncestors = getProperAncestors(stateNode, toStateNode);
3572
+
3573
+ var _iterator38 = _createForOfIteratorHelper(properAncestors),
3574
+ _step38;
3575
+
3576
+ try {
3577
+ for (_iterator38.s(); !(_step38 = _iterator38.n()).done;) {
3578
+ var anc = _step38.value;
3579
+ statesToEnter.add(anc);
3580
+
3581
+ if (anc.type === 'parallel') {
3582
+ var _iterator39 = _createForOfIteratorHelper(getChildren(anc).filter(function (sn) {
3583
+ return !isHistoryNode(sn);
3584
+ })),
3585
+ _step39;
3586
+
3587
+ try {
3588
+ var _loop3 = function _loop3() {
3589
+ var child = _step39.value;
3590
+
3591
+ if (!_toConsumableArray(statesToEnter).some(function (s) {
3592
+ return isDescendant(s, child);
3593
+ })) {
3594
+ addDescendantStatesToEnter(child, historyValue, statesForDefaultEntry, statesToEnter);
3595
+ }
3596
+ };
3597
+
3598
+ for (_iterator39.s(); !(_step39 = _iterator39.n()).done;) {
3599
+ _loop3();
3600
+ }
3601
+ } catch (err) {
3602
+ _iterator39.e(err);
3603
+ } finally {
3604
+ _iterator39.f();
3605
+ }
3606
+ }
3607
+ }
3608
+ } catch (err) {
3609
+ _iterator38.e(err);
3610
+ } finally {
3611
+ _iterator38.f();
3612
+ }
3613
+ }
3614
+
3615
+ function exitStates(transitions, mutConfiguration, historyValue, actions) {
3616
+ var statesToExit = computeExitSet(transitions, mutConfiguration, historyValue);
3617
+
3618
+ var _iterator40 = _createForOfIteratorHelper(statesToExit),
3619
+ _step40;
3620
+
3621
+ try {
3622
+ for (_iterator40.s(); !(_step40 = _iterator40.n()).done;) {
3623
+ var _sn = _step40.value;
3624
+ actions.push.apply(actions, _toConsumableArray(_sn.invoke.map(function (def) {
3625
+ return stop$1(def.id);
3626
+ })));
3627
+ }
3628
+ } catch (err) {
3629
+ _iterator40.e(err);
3630
+ } finally {
3631
+ _iterator40.f();
3632
+ }
3633
+
3634
+ statesToExit.sort(function (a, b) {
3635
+ return b.order - a.order;
3636
+ }); // From SCXML algorithm: https://www.w3.org/TR/scxml/#exitStates
3637
+
3638
+ var _iterator41 = _createForOfIteratorHelper(statesToExit),
3639
+ _step41;
3640
+
3641
+ try {
3642
+ var _loop4 = function _loop4() {
3643
+ var exitStateNode = _step41.value;
3644
+
3645
+ var _iterator43 = _createForOfIteratorHelper(getHistoryNodes(exitStateNode)),
3646
+ _step43;
3647
+
3648
+ try {
3649
+ for (_iterator43.s(); !(_step43 = _iterator43.n()).done;) {
3650
+ var historyNode = _step43.value;
3651
+ var predicate = void 0;
3652
+
3653
+ if (historyNode.history === 'deep') {
3654
+ predicate = function predicate(sn) {
3655
+ return isAtomicStateNode(sn) && isDescendant(sn, exitStateNode);
3656
+ };
3657
+ } else {
3658
+ predicate = function predicate(sn) {
3659
+ return sn.parent === exitStateNode;
3660
+ };
3661
+ }
3662
+
3663
+ historyValue[historyNode.id] = Array.from(mutConfiguration).filter(predicate);
3664
+ }
3665
+ } catch (err) {
3666
+ _iterator43.e(err);
3667
+ } finally {
3668
+ _iterator43.f();
3669
+ }
3670
+ };
3671
+
3672
+ for (_iterator41.s(); !(_step41 = _iterator41.n()).done;) {
3673
+ _loop4();
3674
+ }
3675
+ } catch (err) {
3676
+ _iterator41.e(err);
3677
+ } finally {
3678
+ _iterator41.f();
3679
+ }
3680
+
3681
+ var _iterator42 = _createForOfIteratorHelper(statesToExit),
3682
+ _step42;
3683
+
3684
+ try {
3685
+ for (_iterator42.s(); !(_step42 = _iterator42.n()).done;) {
3686
+ var s = _step42.value;
3687
+ actions.push.apply(actions, _toConsumableArray(s.exit.flat()));
3688
+ mutConfiguration["delete"](s);
3689
+ }
3690
+ } catch (err) {
3691
+ _iterator42.e(err);
3692
+ } finally {
3693
+ _iterator42.f();
3694
+ }
3695
+ }
3696
+
3697
+ function resolveActionsAndContext(actions, scxmlEvent, currentState, actorCtx) {
3698
+ var machine = currentState.machine;
3699
+ var resolvedActions = [];
3700
+ var raiseActions = [];
3701
+ var intermediateState = currentState;
3702
+
3703
+ function handleAction(action) {
3704
+ resolvedActions.push(action);
3705
+
3706
+ if ((actorCtx === null || actorCtx === void 0 ? void 0 : actorCtx.self.status) === ActorStatus.Running) {
3707
+ var _action$execute;
3708
+
3709
+ (_action$execute = action.execute) === null || _action$execute === void 0 ? void 0 : _action$execute.call(action, actorCtx); // TODO: this is hacky; re-evaluate
3710
+
3711
+ delete action.execute;
3712
+ }
3713
+ }
3714
+
3715
+ function resolveAction(actionObject) {
3716
+ var executableActionObject = resolveActionObject(actionObject, machine.options.actions);
3717
+
3718
+ if (isDynamicAction(executableActionObject)) {
3719
+ var _resolvedAction$param;
3720
+
3721
+ var _executableActionObje = executableActionObject.resolve(scxmlEvent, {
3722
+ state: intermediateState,
3723
+ action: actionObject,
3724
+ actorContext: actorCtx
3725
+ }),
3726
+ _executableActionObje2 = _slicedToArray(_executableActionObje, 2),
3727
+ nextState = _executableActionObje2[0],
3728
+ resolvedAction = _executableActionObje2[1];
3729
+
3730
+ var matchedActions = (_resolvedAction$param = resolvedAction.params) === null || _resolvedAction$param === void 0 ? void 0 : _resolvedAction$param.actions;
3731
+ intermediateState = nextState;
3732
+
3733
+ if (resolvedAction.type === raise || resolvedAction.type === send && resolvedAction.params.internal) {
3734
+ raiseActions.push(resolvedAction);
3735
+ } // TODO: remove the check; just handleAction
3736
+
3737
+
3738
+ if (resolvedAction.type !== pure) {
3739
+ handleAction(resolvedAction);
3740
+ }
3741
+
3742
+ toActionObjects(matchedActions).forEach(resolveAction);
3743
+ return;
3744
+ }
3745
+
3746
+ handleAction(executableActionObject);
3747
+ }
3748
+
3749
+ var _iterator44 = _createForOfIteratorHelper(actions),
3750
+ _step44;
3751
+
3752
+ try {
3753
+ for (_iterator44.s(); !(_step44 = _iterator44.n()).done;) {
3754
+ var actionObject = _step44.value;
3755
+ resolveAction(actionObject);
3756
+ }
3757
+ } catch (err) {
3758
+ _iterator44.e(err);
3759
+ } finally {
3760
+ _iterator44.f();
3761
+ }
3762
+
3763
+ return {
3764
+ nextState: cloneState(intermediateState, {
3765
+ actions: resolvedActions,
3766
+ _internalQueue: raiseActions.map(function (a) {
3767
+ return a.params._event;
3768
+ })
3769
+ })
3770
+ };
3771
+ }
3772
+ function macrostep(state, scxmlEvent, actorCtx) {
3773
+ if (!IS_PRODUCTION && scxmlEvent.name === WILDCARD) {
3774
+ throw new Error("An event cannot have the wildcard type ('".concat(WILDCARD, "')"));
3775
+ }
3776
+
3777
+ var nextState = state;
3778
+ var states = []; // Handle stop event
3779
+
3780
+ if ((scxmlEvent === null || scxmlEvent === void 0 ? void 0 : scxmlEvent.name) === stopSignalType) {
3781
+ nextState = stopStep(scxmlEvent, nextState, actorCtx);
3782
+ states.push(nextState);
3783
+ return {
3784
+ state: nextState,
3785
+ microstates: states
3786
+ };
3787
+ } // Assume the state is at rest (no raised events)
3788
+ // Determine the next state based on the next microstep
3789
+
3790
+
3791
+ if (scxmlEvent.name !== init) {
3792
+ var transitions = selectTransitions(scxmlEvent, nextState);
3793
+ nextState = microstep(transitions, state, actorCtx, scxmlEvent);
3794
+ states.push(nextState);
3795
+ }
3796
+
3797
+ while (!nextState.done) {
3798
+ var enabledTransitions = selectEventlessTransitions(nextState);
3799
+
3800
+ if (enabledTransitions.length === 0) {
3801
+ // TODO: this is a bit of a hack, we need to review this
3802
+ // this matches the behavior from v4 for eventless transitions
3803
+ // where for `hasAlwaysTransitions` we were always trying to resolve with a NULL event
3804
+ // and if a transition was not selected the `state.transitions` stayed empty
3805
+ // without this we get into an infinite loop in the dieHard test in `@xstate/test` for the `simplePathsTo`
3806
+ if (nextState.configuration.some(function (state) {
3807
+ return state.always;
3808
+ })) {
3809
+ nextState.transitions = [];
3810
+ }
3811
+
3812
+ if (!nextState._internalQueue.length) {
3813
+ break;
3814
+ } else {
3815
+ var _nextState$actions;
3816
+
3817
+ var currentActions = nextState.actions;
3818
+ var nextEvent = nextState._internalQueue[0];
3819
+
3820
+ var _transitions = selectTransitions(nextEvent, nextState);
3821
+
3822
+ nextState = microstep(_transitions, nextState, actorCtx, nextEvent);
3823
+
3824
+ nextState._internalQueue.shift();
3825
+
3826
+ (_nextState$actions = nextState.actions).unshift.apply(_nextState$actions, _toConsumableArray(currentActions));
3827
+
3828
+ states.push(nextState);
3829
+ }
3830
+ }
3831
+
3832
+ if (enabledTransitions.length) {
3833
+ var _nextState$actions2;
3834
+
3835
+ var _currentActions = nextState.actions;
3836
+ nextState = microstep(enabledTransitions, nextState, actorCtx, nextState._event);
3837
+
3838
+ (_nextState$actions2 = nextState.actions).unshift.apply(_nextState$actions2, _toConsumableArray(_currentActions));
3839
+
3840
+ states.push(nextState);
3841
+ }
3842
+ }
3843
+
3844
+ if (nextState.done) {
3845
+ // Perform the stop step to ensure that child actors are stopped
3846
+ stopStep(nextState._event, nextState, actorCtx);
3847
+ }
3848
+
3849
+ return {
3850
+ state: nextState,
3851
+ microstates: states
3852
+ };
3853
+ }
3854
+
3855
+ function stopStep(scxmlEvent, nextState, actorCtx) {
3856
+ var actions = [];
3857
+
3858
+ var _iterator45 = _createForOfIteratorHelper(nextState.configuration.sort(function (a, b) {
3859
+ return b.order - a.order;
3860
+ })),
3861
+ _step45;
3862
+
3863
+ try {
3864
+ for (_iterator45.s(); !(_step45 = _iterator45.n()).done;) {
3865
+ var stateNode = _step45.value;
3866
+ actions.push.apply(actions, _toConsumableArray(stateNode.exit));
3867
+ }
3868
+ } catch (err) {
3869
+ _iterator45.e(err);
3870
+ } finally {
3871
+ _iterator45.f();
3872
+ }
3873
+
3874
+ for (var _i3 = 0, _Object$values = Object.values(nextState.children); _i3 < _Object$values.length; _i3++) {
3875
+ var child = _Object$values[_i3];
3876
+ actions.push(stop$1(child));
3877
+ }
3878
+
3879
+ var _resolveActionsAndCon2 = resolveActionsAndContext(actions, scxmlEvent, nextState, actorCtx),
3880
+ stoppedState = _resolveActionsAndCon2.nextState;
3881
+
3882
+ return stoppedState;
3883
+ }
3884
+
3885
+ function selectTransitions(scxmlEvent, nextState) {
3886
+ return nextState.machine.getTransitionData(nextState, scxmlEvent);
3887
+ }
3888
+
3889
+ function selectEventlessTransitions(nextState) {
3890
+ var enabledTransitionSet = new Set();
3891
+ var atomicStates = nextState.configuration.filter(isAtomicStateNode);
3892
+
3893
+ var _iterator46 = _createForOfIteratorHelper(atomicStates),
3894
+ _step46;
3895
+
3896
+ try {
3897
+ for (_iterator46.s(); !(_step46 = _iterator46.n()).done;) {
3898
+ var stateNode = _step46.value;
3899
+
3900
+ var _iterator47 = _createForOfIteratorHelper([stateNode].concat(getProperAncestors(stateNode, null))),
3901
+ _step47;
3902
+
3903
+ try {
3904
+ loop: for (_iterator47.s(); !(_step47 = _iterator47.n()).done;) {
3905
+ var s = _step47.value;
3906
+
3907
+ if (!s.always) {
3908
+ continue;
3909
+ }
3910
+
3911
+ var _iterator48 = _createForOfIteratorHelper(s.always),
3912
+ _step48;
3913
+
3914
+ try {
3915
+ for (_iterator48.s(); !(_step48 = _iterator48.n()).done;) {
3916
+ var transition = _step48.value;
3917
+
3918
+ if (transition.guard === undefined || evaluateGuard(transition.guard, nextState.context, nextState._event, nextState)) {
3919
+ enabledTransitionSet.add(transition);
3920
+ break loop;
3921
+ }
3922
+ }
3923
+ } catch (err) {
3924
+ _iterator48.e(err);
3925
+ } finally {
3926
+ _iterator48.f();
3927
+ }
3928
+ }
3929
+ } catch (err) {
3930
+ _iterator47.e(err);
3931
+ } finally {
3932
+ _iterator47.f();
3933
+ }
3934
+ }
3935
+ } catch (err) {
3936
+ _iterator46.e(err);
3937
+ } finally {
3938
+ _iterator46.f();
3939
+ }
3940
+
3941
+ return removeConflictingTransitions(Array.from(enabledTransitionSet), new Set(nextState.configuration), nextState.historyValue);
3942
+ }
3943
+ /**
3944
+ * Resolves a partial state value with its full representation in the state node's machine.
3945
+ *
3946
+ * @param stateValue The partial state value to resolve.
3947
+ */
3948
+
3949
+
3950
+ function resolveStateValue(rootNode, stateValue) {
3951
+ var configuration = getConfiguration(getStateNodes(rootNode, stateValue));
3952
+ return getStateValue(rootNode, _toConsumableArray(configuration));
3953
+ }
3954
+ function stateValuesEqual(a, b) {
3955
+ if (a === b) {
3956
+ return true;
3957
+ }
3958
+
3959
+ if (a === undefined || b === undefined) {
3960
+ return false;
3961
+ }
3962
+
3963
+ if (isString(a) || isString(b)) {
3964
+ return a === b;
3965
+ }
3966
+
3967
+ var aKeys = Object.keys(a);
3968
+ var bKeys = Object.keys(b);
3969
+ return aKeys.length === bKeys.length && aKeys.every(function (key) {
3970
+ return stateValuesEqual(a[key], b[key]);
3971
+ });
3972
+ }
3973
+ function getInitialConfiguration(rootNode) {
3974
+ var configuration = [];
3975
+ var initialTransition = rootNode.initial;
3976
+ var statesToEnter = new Set();
3977
+ var statesForDefaultEntry = new Set([rootNode]);
3978
+ computeEntrySet([initialTransition], {}, statesForDefaultEntry, statesToEnter);
3979
+
3980
+ var _iterator49 = _createForOfIteratorHelper(_toConsumableArray(statesToEnter).sort(function (a, b) {
3981
+ return a.order - b.order;
3982
+ })),
3983
+ _step49;
3984
+
3985
+ try {
3986
+ for (_iterator49.s(); !(_step49 = _iterator49.n()).done;) {
3987
+ var stateNodeToEnter = _step49.value;
3988
+ configuration.push(stateNodeToEnter);
3989
+ }
3990
+ } catch (err) {
3991
+ _iterator49.e(err);
3992
+ } finally {
3993
+ _iterator49.f();
3994
+ }
3995
+
3996
+ return configuration;
3997
+ }
3998
+
3999
+ var _excluded = ["configuration", "transitions", "tags", "machine"];
4000
+ function isStateConfig(state) {
4001
+ if (_typeof(state) !== 'object' || state === null) {
4002
+ return false;
4003
+ }
4004
+
4005
+ return 'value' in state && '_event' in state;
4006
+ }
4007
+ var State = /*#__PURE__*/function () {
4008
+ /**
4009
+ * Creates a new `State` instance that represents the current state of a running machine.
4010
+ *
4011
+ * @param config
4012
+ */
4013
+ function State(config, machine) {
4014
+ var _config$_internalQueu, _config$actions, _config$configuration, _config$done;
4015
+
4016
+ _classCallCheck(this, State);
4017
+
4018
+ this.machine = machine;
4019
+
4020
+ _defineProperty(this, "value", void 0);
4021
+
4022
+ _defineProperty(this, "done", void 0);
4023
+
4024
+ _defineProperty(this, "output", void 0);
4025
+
4026
+ _defineProperty(this, "context", void 0);
4027
+
4028
+ _defineProperty(this, "historyValue", {});
4029
+
4030
+ _defineProperty(this, "actions", []);
4031
+
4032
+ _defineProperty(this, "event", void 0);
4033
+
4034
+ _defineProperty(this, "_internalQueue", void 0);
4035
+
4036
+ _defineProperty(this, "_event", void 0);
4037
+
4038
+ _defineProperty(this, "_sessionid", void 0);
4039
+
4040
+ _defineProperty(this, "_initial", false);
4041
+
4042
+ _defineProperty(this, "changed", void 0);
4043
+
4044
+ _defineProperty(this, "configuration", void 0);
4045
+
4046
+ _defineProperty(this, "transitions", void 0);
4047
+
4048
+ _defineProperty(this, "children", void 0);
4049
+
4050
+ this.context = config.context;
4051
+ this._event = config._event;
4052
+ this._sessionid = config._sessionid;
4053
+ this._internalQueue = (_config$_internalQueu = config._internalQueue) !== null && _config$_internalQueu !== void 0 ? _config$_internalQueu : [];
4054
+ this.event = this._event.data;
4055
+ this.historyValue = config.historyValue || {};
4056
+ this.actions = (_config$actions = config.actions) !== null && _config$actions !== void 0 ? _config$actions : [];
4057
+ this.matches = this.matches.bind(this);
4058
+ this.toStrings = this.toStrings.bind(this);
4059
+ this.configuration = (_config$configuration = config.configuration) !== null && _config$configuration !== void 0 ? _config$configuration : Array.from(getConfiguration(getStateNodes(machine.root, config.value)));
4060
+ this.transitions = config.transitions;
4061
+ this.children = config.children;
4062
+ this.value = getStateValue(machine.root, this.configuration);
4063
+ this.done = (_config$done = config.done) !== null && _config$done !== void 0 ? _config$done : false;
4064
+ this.output = config.output;
4065
+ }
4066
+ /**
4067
+ * Returns an array of all the string leaf state node paths.
4068
+ * @param stateValue
4069
+ * @param delimiter The character(s) that separate each subpath in the string state node path.
4070
+ */
4071
+
4072
+
4073
+ _createClass(State, [{
4074
+ key: "toStrings",
4075
+ value: function toStrings() {
4076
+ var _this = this;
4077
+
4078
+ var stateValue = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : this.value;
4079
+ var delimiter = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '.';
4080
+
4081
+ if (isString(stateValue)) {
4082
+ return [stateValue];
4083
+ }
4084
+
4085
+ var valueKeys = Object.keys(stateValue);
4086
+ return valueKeys.concat.apply(valueKeys, _toConsumableArray(valueKeys.map(function (key) {
4087
+ return _this.toStrings(stateValue[key], delimiter).map(function (s) {
4088
+ return key + delimiter + s;
4089
+ });
4090
+ })));
4091
+ }
4092
+ }, {
4093
+ key: "toJSON",
4094
+ value: function toJSON() {
4095
+ var configuration = this.configuration,
4096
+ transitions = this.transitions,
4097
+ tags = this.tags,
4098
+ machine = this.machine,
4099
+ jsonValues = _objectWithoutProperties(this, _excluded);
4100
+
4101
+ return _objectSpread2(_objectSpread2({}, jsonValues), {}, {
4102
+ tags: Array.from(tags),
4103
+ meta: this.meta
4104
+ });
4105
+ }
4106
+ /**
4107
+ * Whether the current state value is a subset of the given parent state value.
4108
+ * @param parentStateValue
4109
+ */
4110
+
4111
+ }, {
4112
+ key: "matches",
4113
+ value: function matches(parentStateValue) {
4114
+ return matchesState(parentStateValue, this.value);
4115
+ }
4116
+ /**
4117
+ * Whether the current state configuration has a state node with the specified `tag`.
4118
+ * @param tag
4119
+ */
4120
+
4121
+ }, {
4122
+ key: "hasTag",
4123
+ value: function hasTag(tag) {
4124
+ return this.tags.has(tag);
4125
+ }
4126
+ /**
4127
+ * Determines whether sending the `event` will cause a non-forbidden transition
4128
+ * to be selected, even if the transitions have no actions nor
4129
+ * change the state value.
4130
+ *
4131
+ * @param event The event to test
4132
+ * @returns Whether the event will cause a transition
4133
+ */
4134
+
4135
+ }, {
4136
+ key: "can",
4137
+ value: function can(event) {
4138
+ if (IS_PRODUCTION) {
4139
+ warn(!!this.machine, "state.can(...) used outside of a machine-created State object; this will always return false.");
4140
+ }
4141
+
4142
+ var transitionData = this.machine.getTransitionData(this, toSCXMLEvent(event));
4143
+ return !!(transitionData !== null && transitionData !== void 0 && transitionData.length) && // Check that at least one transition is not forbidden
4144
+ transitionData.some(function (t) {
4145
+ return t.target !== undefined || t.actions.length;
4146
+ });
4147
+ }
4148
+ /**
4149
+ * The next events that will cause a transition from the current state.
4150
+ */
4151
+
4152
+ }, {
4153
+ key: "nextEvents",
4154
+ get: function get() {
4155
+ var _this2 = this;
4156
+
4157
+ return memo(this, 'nextEvents', function () {
4158
+ return _toConsumableArray(new Set(flatten(_toConsumableArray(_this2.configuration.map(function (sn) {
4159
+ return sn.ownEvents;
4160
+ })))));
4161
+ });
4162
+ }
4163
+ }, {
4164
+ key: "meta",
4165
+ get: function get() {
4166
+ return this.configuration.reduce(function (acc, stateNode) {
4167
+ if (stateNode.meta !== undefined) {
4168
+ acc[stateNode.id] = stateNode.meta;
4169
+ }
4170
+
4171
+ return acc;
4172
+ }, {});
4173
+ }
4174
+ }, {
4175
+ key: "tags",
4176
+ get: function get() {
4177
+ return new Set(flatten(this.configuration.map(function (sn) {
4178
+ return sn.tags;
4179
+ })));
4180
+ }
4181
+ }], [{
4182
+ key: "from",
4183
+ value:
4184
+ /**
4185
+ * Indicates whether the state is a final state.
4186
+ */
4187
+
4188
+ /**
4189
+ * The done data of the top-level finite state.
4190
+ */
4191
+ // TODO: add an explicit type for `output`
4192
+
4193
+ /**
4194
+ * Indicates whether the state has changed from the previous state. A state is considered "changed" if:
4195
+ *
4196
+ * - Its value is not equal to its previous value, or:
4197
+ * - It has any new actions (side-effects) to execute.
4198
+ *
4199
+ * An initial state (with no history) will return `undefined`.
4200
+ */
4201
+
4202
+ /**
4203
+ * The enabled state nodes representative of the state value.
4204
+ */
4205
+
4206
+ /**
4207
+ * The transition definitions that resulted in this state.
4208
+ */
4209
+
4210
+ /**
4211
+ * An object mapping actor names to spawned/invoked actors.
4212
+ */
4213
+
4214
+ /**
4215
+ * Creates a new State instance for the given `stateValue` and `context`.
4216
+ * @param stateValue
4217
+ * @param context
4218
+ */
4219
+ function from(stateValue) {
4220
+ var context = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
4221
+ var machine = arguments.length > 2 ? arguments[2] : undefined;
4222
+
4223
+ if (stateValue instanceof State) {
4224
+ if (stateValue.context !== context) {
4225
+ return new State({
4226
+ value: stateValue.value,
4227
+ context: context,
4228
+ _event: stateValue._event,
4229
+ _sessionid: undefined,
4230
+ actions: [],
4231
+ meta: {},
4232
+ configuration: [],
4233
+ // TODO: fix,
4234
+ transitions: [],
4235
+ children: {}
4236
+ }, machine);
4237
+ }
4238
+
4239
+ return stateValue;
4240
+ }
4241
+
4242
+ var _event = initEvent;
4243
+ var configuration = getConfiguration(getStateNodes(machine.root, stateValue));
4244
+ return new State({
4245
+ value: stateValue,
4246
+ context: context,
4247
+ _event: _event,
4248
+ _sessionid: undefined,
4249
+ actions: [],
4250
+ meta: undefined,
4251
+ configuration: Array.from(configuration),
4252
+ transitions: [],
4253
+ children: {}
4254
+ }, machine);
4255
+ }
4256
+ }]);
4257
+
4258
+ return State;
4259
+ }();
4260
+ function cloneState(state) {
4261
+ var config = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
4262
+ return new State(_objectSpread2(_objectSpread2({}, state), config), state.machine);
4263
+ }
4264
+
4265
+ function invoke$1(invokeDef) {
4266
+ return createDynamicAction({
4267
+ type: invoke,
4268
+ params: invokeDef
4269
+ }, function (_event, _ref) {
4270
+ var state = _ref.state;
4271
+ var type = invoke;
4272
+ var id = invokeDef.id,
4273
+ data = invokeDef.data,
4274
+ src = invokeDef.src,
4275
+ meta = invokeDef.meta;
4276
+ var resolvedInvokeAction;
4277
+
4278
+ if (isActorRef(src)) {
4279
+ resolvedInvokeAction = {
4280
+ type: type,
4281
+ params: _objectSpread2(_objectSpread2({}, invokeDef), {}, {
4282
+ ref: src
4283
+ })
4284
+ };
4285
+ } else {
4286
+ var behaviorImpl = state.machine.options.actors[src.type];
4287
+
4288
+ if (!behaviorImpl) {
4289
+ resolvedInvokeAction = {
4290
+ type: type,
4291
+ params: invokeDef
4292
+ };
4293
+ } else {
4294
+ var behavior = typeof behaviorImpl === 'function' ? behaviorImpl(state.context, _event.data, {
4295
+ id: id,
4296
+ data: data && mapContext(data, state.context, _event),
4297
+ src: src,
4298
+ _event: _event,
4299
+ meta: meta
4300
+ }) : behaviorImpl;
4301
+ resolvedInvokeAction = {
4302
+ type: type,
4303
+ params: _objectSpread2(_objectSpread2({}, invokeDef), {}, {
4304
+ ref: interpret(behavior, {
4305
+ id: id
4306
+ })
4307
+ })
4308
+ };
4309
+ }
4310
+ }
4311
+
4312
+ var actorRef = resolvedInvokeAction.params.ref;
4313
+ var invokedState = cloneState(state, {
4314
+ children: _objectSpread2(_objectSpread2({}, state.children), {}, _defineProperty({}, id, actorRef))
4315
+ });
4316
+
4317
+ resolvedInvokeAction.execute = function (actorCtx) {
4318
+ var interpreter = actorCtx.self;
4319
+ var _resolvedInvokeAction = resolvedInvokeAction.params,
4320
+ id = _resolvedInvokeAction.id,
4321
+ autoForward = _resolvedInvokeAction.autoForward,
4322
+ ref = _resolvedInvokeAction.ref;
4323
+
4324
+ if (!ref) {
4325
+ if (!IS_PRODUCTION) {
4326
+ warn(false, "Actor type '".concat(resolvedInvokeAction.params.src.type, "' not found in machine '").concat(actorCtx.id, "'."));
4327
+ }
4328
+
4329
+ return;
4330
+ }
4331
+
4332
+ ref._parent = interpreter; // TODO: fix
4333
+
4334
+ actorCtx.defer(function () {
4335
+ if (actorRef.status === ActorStatus.Stopped) {
4336
+ return;
4337
+ }
4338
+
4339
+ try {
4340
+ var _actorRef$start;
4341
+
4342
+ if (autoForward) {
4343
+ interpreter._forwardTo.add(actorRef);
4344
+ }
4345
+
4346
+ (_actorRef$start = actorRef.start) === null || _actorRef$start === void 0 ? void 0 : _actorRef$start.call(actorRef);
4347
+ } catch (err) {
4348
+ interpreter.send(error$1(id, err));
4349
+ return;
4350
+ }
4351
+ });
4352
+ };
4353
+
4354
+ return [invokedState, resolvedInvokeAction];
4355
+ });
4356
+ }
4357
+
4358
+ function createSpawner(machine, context, _event, mutCapturedActions) {
4359
+ return function (behavior, name) {
4360
+ if (isString(behavior)) {
4361
+ var behaviorCreator = machine.options.actors[behavior];
4362
+
4363
+ if (behaviorCreator) {
4364
+ var resolvedName = name !== null && name !== void 0 ? name : 'anon'; // TODO: better name
4365
+
4366
+ var createdBehavior = typeof behaviorCreator === 'function' ? behaviorCreator(context, _event.data, {
4367
+ id: resolvedName,
4368
+ src: {
4369
+ type: behavior
4370
+ },
4371
+ _event: _event,
4372
+ meta: undefined
4373
+ }) : behaviorCreator;
4374
+ var actorRef = interpret(createdBehavior, {
4375
+ id: resolvedName
4376
+ });
4377
+ mutCapturedActions.push(invoke$1({
4378
+ id: actorRef.id,
4379
+ // @ts-ignore TODO: fix types
4380
+ src: actorRef,
4381
+ // TODO
4382
+ ref: actorRef,
4383
+ meta: undefined
4384
+ }));
4385
+ return actorRef; // TODO: fix types
4386
+ }
4387
+
4388
+ throw new Error("Behavior '".concat(behavior, "' not implemented in machine '").concat(machine.id, "'"));
4389
+ } else {
4390
+ var _actorRef = interpret(behavior, {
4391
+ id: name || 'anonymous'
4392
+ });
4393
+
4394
+ mutCapturedActions.push(invoke$1({
4395
+ // @ts-ignore TODO: fix types
4396
+ src: _actorRef,
4397
+ ref: _actorRef,
4398
+ id: _actorRef.id,
4399
+ meta: undefined
4400
+ }));
4401
+ return _actorRef; // TODO: fix types
4402
+ }
4403
+ };
4404
+ }
4405
+
4406
+ /**
4407
+ * Updates the current context of the machine.
4408
+ *
4409
+ * @param assignment An object that represents the partial context to update.
4410
+ */
4411
+
4412
+ function assign$1(assignment) {
4413
+ return createDynamicAction({
4414
+ type: assign,
4415
+ params: {
4416
+ assignment: assignment
4417
+ }
4418
+ }, function (_event, _ref) {
4419
+ var state = _ref.state,
4420
+ action = _ref.action;
4421
+ var capturedActions = [];
4422
+
4423
+ if (!state.context) {
4424
+ throw new Error('Cannot assign to undefined `context`. Ensure that `context` is defined in the machine config.');
4425
+ }
4426
+
4427
+ var meta = {
4428
+ state: state,
4429
+ action: action,
4430
+ _event: _event,
4431
+ spawn: createSpawner(state.machine, state.context, _event, capturedActions)
4432
+ };
4433
+ var partialUpdate = {};
4434
+
4435
+ if (isFunction(assignment)) {
4436
+ partialUpdate = assignment(state.context, _event.data, meta);
4437
+ } else {
4438
+ for (var _i = 0, _Object$keys = Object.keys(assignment); _i < _Object$keys.length; _i++) {
4439
+ var key = _Object$keys[_i];
4440
+ var propAssignment = assignment[key];
4441
+ partialUpdate[key] = isFunction(propAssignment) ? propAssignment(state.context, _event.data, meta) : propAssignment;
4442
+ }
4443
+ }
4444
+
4445
+ var updatedContext = Object.assign({}, state.context, partialUpdate);
4446
+ return [cloneState(state, {
4447
+ context: updatedContext
4448
+ }), {
4449
+ type: assign,
4450
+ params: {
4451
+ context: updatedContext,
4452
+ actions: capturedActions
4453
+ }
4454
+ }];
4455
+ });
4456
+ }
4457
+
4458
+ /**
4459
+ * Raises an event. This places the event in the internal event queue, so that
4460
+ * the event is immediately consumed by the machine in the current step.
4461
+ *
4462
+ * @param eventType The event to raise.
4463
+ */
4464
+ function raise$1(event) {
4465
+ return createDynamicAction({
4466
+ type: raise,
4467
+ params: {
4468
+ _event: toSCXMLEvent(event)
4469
+ }
4470
+ }, function (_event, _ref) {
4471
+ var state = _ref.state;
4472
+ return [state, {
4473
+ type: raise,
4474
+ params: {
4475
+ _event: toSCXMLEvent(event)
4476
+ }
4477
+ }];
4478
+ });
4479
+ }
4480
+
4481
+ function choose$1(guards) {
4482
+ return createDynamicAction({
4483
+ type: choose,
4484
+ params: {
4485
+ guards: guards
4486
+ }
4487
+ }, function (_event, _ref) {
4488
+ var _guards$find;
4489
+
4490
+ var state = _ref.state;
4491
+ var matchedActions = (_guards$find = guards.find(function (condition) {
4492
+ var guard = condition.guard && toGuardDefinition(condition.guard, function (guardType) {
4493
+ return state.machine.options.guards[guardType];
4494
+ });
4495
+ return !guard || evaluateGuard(guard, state.context, _event, state);
4496
+ })) === null || _guards$find === void 0 ? void 0 : _guards$find.actions;
4497
+ return [state, {
4498
+ type: choose,
4499
+ params: {
4500
+ actions: toActionObjects(matchedActions)
4501
+ }
4502
+ }];
4503
+ });
4504
+ }
4505
+
4506
+ var initEvent = toSCXMLEvent({
4507
+ type: init
4508
+ });
4509
+ function resolveActionObject(actionObject, actionFunctionMap) {
4510
+ if (isDynamicAction(actionObject)) {
4511
+ return actionObject;
4512
+ }
4513
+
4514
+ var dereferencedAction = actionFunctionMap[actionObject.type];
4515
+
4516
+ if (typeof dereferencedAction === 'function') {
4517
+ var _actionObject$params;
4518
+
4519
+ return createDynamicAction({
4520
+ type: 'xstate.expr',
4521
+ params: (_actionObject$params = actionObject.params) !== null && _actionObject$params !== void 0 ? _actionObject$params : {}
4522
+ }, function (_event, _ref) {
4523
+ var state = _ref.state;
4524
+ var a = {
4525
+ type: actionObject.type,
4526
+ params: actionObject.params,
4527
+ execute: function execute(_actorCtx) {
4528
+ return dereferencedAction(state.context, state.event, {
4529
+ action: a,
4530
+ _event: state._event,
4531
+ state: state
4532
+ });
4533
+ }
4534
+ };
4535
+ return [state, a];
4536
+ });
4537
+ } else if (dereferencedAction) {
4538
+ return dereferencedAction;
4539
+ } else {
4540
+ return actionObject;
4541
+ }
4542
+ }
4543
+ function toActionObject(action) {
4544
+ if (isDynamicAction(action)) {
4545
+ return action;
4546
+ }
4547
+
4548
+ if (typeof action === 'string') {
4549
+ return {
4550
+ type: action,
4551
+ params: {}
4552
+ };
4553
+ }
4554
+
4555
+ if (typeof action === 'function') {
4556
+ var type = 'xstate.function';
4557
+ return createDynamicAction({
4558
+ type: type,
4559
+ params: {}
4560
+ }, function (_event, _ref2) {
4561
+ var state = _ref2.state;
4562
+ var a = {
4563
+ type: type,
4564
+ params: {
4565
+ "function": action
4566
+ },
4567
+ execute: function execute(_actorCtx) {
4568
+ return action(state.context, _event.data, {
4569
+ action: a,
4570
+ _event: _event,
4571
+ state: state
4572
+ });
4573
+ }
4574
+ };
4575
+ return [state, a];
4576
+ });
4577
+ } // action is already a BaseActionObject
4578
+
4579
+
4580
+ return action;
4581
+ }
4582
+ var toActionObjects = function toActionObjects(action) {
4583
+ if (!action) {
4584
+ return [];
4585
+ }
4586
+
4587
+ var actions = isArray(action) ? action : [action];
4588
+ return actions.map(toActionObject);
4589
+ };
4590
+ /**
4591
+ * Returns an event type that represents an implicit event that
4592
+ * is sent after the specified `delay`.
4593
+ *
4594
+ * @param delayRef The delay in milliseconds
4595
+ * @param id The state node ID where this event is handled
4596
+ */
4597
+
4598
+ function after$1(delayRef, id) {
4599
+ var idSuffix = id ? "#".concat(id) : '';
4600
+ return "".concat(ActionTypes.After, "(").concat(delayRef, ")").concat(idSuffix);
4601
+ }
4602
+ /**
4603
+ * Returns an event that represents that a final state node
4604
+ * has been reached in the parent state node.
4605
+ *
4606
+ * @param id The final state node's parent state node `id`
4607
+ * @param data The data to pass into the event
4608
+ */
4609
+
4610
+ function done(id, data) {
4611
+ var type = "".concat(ActionTypes.DoneState, ".").concat(id);
4612
+ var eventObject = {
4613
+ type: type,
4614
+ data: data
4615
+ };
4616
+
4617
+ eventObject.toString = function () {
4618
+ return type;
4619
+ };
4620
+
4621
+ return eventObject;
4622
+ }
4623
+ /**
4624
+ * Returns an event that represents that an invoked service has terminated.
4625
+ *
4626
+ * An invoked service is terminated when it has reached a top-level final state node,
4627
+ * but not when it is canceled.
4628
+ *
4629
+ * @param invokeId The invoked service ID
4630
+ * @param data The data to pass into the event
4631
+ */
4632
+
4633
+ function doneInvoke(invokeId, data) {
4634
+ var type = "".concat(ActionTypes.DoneInvoke, ".").concat(invokeId);
4635
+ var eventObject = {
4636
+ type: type,
4637
+ data: data
4638
+ };
4639
+
4640
+ eventObject.toString = function () {
4641
+ return type;
4642
+ };
4643
+
4644
+ return eventObject;
4645
+ }
4646
+ function error$1(id, data) {
4647
+ var type = "".concat(ActionTypes.ErrorPlatform, ".").concat(id);
4648
+ var eventObject = {
4649
+ type: type,
4650
+ data: data
4651
+ };
4652
+
4653
+ eventObject.toString = function () {
4654
+ return type;
4655
+ };
4656
+
4657
+ return eventObject;
4658
+ }
4659
+
4660
+ export { stop$1 as $, getConfiguration as A, getStateNodes as B, resolveStateValue as C, isInFinalState as D, toSCXMLEvent as E, isSCXMLErrorEvent as F, macrostep as G, transitionNode as H, _slicedToArray as I, getInitialConfiguration as J, initEvent as K, resolveActionsAndContext as L, microstep as M, NULL_EVENT as N, isStateId as O, isStateConfig as P, isFunction as Q, STATE_DELIMITER as R, State as S, matchesState as T, raise$1 as U, send$1 as V, sendParent as W, sendTo as X, log$1 as Y, cancel$1 as Z, _createClass as _, toTransitionConfigArray as a, assign$1 as a0, after$1 as a1, done as a2, respond as a3, forwardTo as a4, escalate as a5, choose$1 as a6, interpret as a7, Interpreter as a8, ActorStatus as a9, doneInvoke as aa, pathToStateValue as ab, toObserver as ac, ActionTypes as ad, SpecialTargets as ae, fromReducer as af, startSignalType as ag, stopSignalType as ah, startSignal as ai, stopSignal as aj, fromCallback as ak, fromPromise as al, fromObservable as am, fromEventObservable as an, isActorRef as ao, toActorRef as ap, stateIn as aq, not as ar, and as as, or as at, toGuardDefinition as au, actionTypes as av, resolveActionObject as aw, toActionObject as ax, error$1 as ay, formatTransition as b, createDynamicAction as c, memo as d, _createForOfIteratorHelper as e, formatTransitions as f, evaluateGuard as g, _toConsumableArray as h, flatten as i, _classCallCheck as j, _defineProperty as k, toActionObjects as l, mapValues as m, createInvokeId as n, toInvokeConfig as o, pure as p, _objectSpread2 as q, invoke as r, _objectWithoutProperties as s, toArray as t, getDelayedTransitions as u, formatInitialTransition as v, getCandidates as w, toInvokeSource as x, isString as y, createSpawner as z };