react-elmish 5.0.1 → 5.1.1-beta.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.
- package/README.md +80 -105
- package/dist/Cmd.js +3 -20
- package/dist/Common.js +1 -6
- package/dist/ElmComponent.js +14 -68
- package/dist/ErrorHandling.js +3 -9
- package/dist/Init.js +2 -3
- package/dist/Testing/createUpdateArgsFactory.js +1 -5
- package/dist/Testing/execCmd.js +2 -16
- package/dist/Testing/fakeOptions.js +2 -4
- package/dist/Testing/getOfMsgParams.js +1 -4
- package/dist/Testing/getUpdateFn.js +1 -3
- package/dist/Testing/index.js +1 -6
- package/dist/Testing/renderWithModel.js +1 -4
- package/dist/index.js +1 -6
- package/dist/useElmish.js +19 -55
- package/installScript.js +4 -0
- package/package.json +13 -12
package/README.md
CHANGED
|
@@ -7,9 +7,8 @@ This library brings the elmish pattern to react.
|
|
|
7
7
|
|
|
8
8
|
- [Installation](#installation)
|
|
9
9
|
- [Basic Usage](#basic-usage)
|
|
10
|
-
- [More
|
|
11
|
-
- [Message
|
|
12
|
-
- [Symbols instead of strings](#symbols-instead-of-strings)
|
|
10
|
+
- [More about messages](#more-about-messages)
|
|
11
|
+
- [Message parameters](#message-parameters)
|
|
13
12
|
- [Dispatch commands in the update map or update function](#dispatch-commands-in-the-update-map-or-update-function)
|
|
14
13
|
- [Dispatch a message](#dispatch-a-message)
|
|
15
14
|
- [Call an async function](#call-an-async-function)
|
|
@@ -25,9 +24,8 @@ This library brings the elmish pattern to react.
|
|
|
25
24
|
- [With an update function](#with-an-update-function)
|
|
26
25
|
- [Call back parent components](#call-back-parent-components)
|
|
27
26
|
- [Testing](#testing)
|
|
28
|
-
- [Testing the
|
|
27
|
+
- [Testing the update handler](#testing-the-update-handler)
|
|
29
28
|
- [Testing all (async) messages](#testing-all-async-messages)
|
|
30
|
-
- [Testing with an UpdateMap](#testing-with-an-updatemap)
|
|
31
29
|
- [UI Tests](#ui-tests)
|
|
32
30
|
- [Migrations](#migrations)
|
|
33
31
|
- [From v1.x to v2.x](#from-v1x-to-v2x)
|
|
@@ -112,9 +110,9 @@ export const update: UpdateMap<Props, Model, Message> = {
|
|
|
112
110
|
};
|
|
113
111
|
```
|
|
114
112
|
|
|
115
|
-
**Note:** When using an `UpdateMap` it is recommended to use camelCase for message names ("increment" instead of "Increment").
|
|
113
|
+
**Note:** When using an `UpdateMap` it is recommended to use camelCase for message names (e.g. "increment" instead of "Increment").
|
|
116
114
|
|
|
117
|
-
Alternatively we can use an
|
|
115
|
+
Alternatively we can use an `update` function:
|
|
118
116
|
|
|
119
117
|
```ts
|
|
120
118
|
export const update = (model: Model, msg: Msg, props: Props): UpdateReturnType<Model, Message> => {
|
|
@@ -159,12 +157,12 @@ function App (props: Props): JSX.Element {
|
|
|
159
157
|
}
|
|
160
158
|
```
|
|
161
159
|
|
|
162
|
-
|
|
160
|
+
You can also write the component as a **class component**:
|
|
163
161
|
|
|
164
162
|
```tsx
|
|
165
163
|
// Import everything from the App.ts
|
|
166
164
|
import { Model, Message, Props, init, update, Msg } as Shared from "../App";
|
|
167
|
-
// Import the ElmComponent which extends
|
|
165
|
+
// Import the ElmComponent which extends React.Component
|
|
168
166
|
import { ElmComponent } from "react-elmish";
|
|
169
167
|
import React from "react";
|
|
170
168
|
|
|
@@ -195,17 +193,19 @@ class App extends ElmComponent<Model, Message, Props> {
|
|
|
195
193
|
}
|
|
196
194
|
```
|
|
197
195
|
|
|
196
|
+
> **Note**: When using a class component, you can only use an `update` function. Class components do not support `UpdateMap`s.
|
|
197
|
+
|
|
198
198
|
You can use these components like any other React component.
|
|
199
199
|
|
|
200
200
|
> **Note**: It is recommended to separate business logic and the view into separate modules. Here we put the `Messages`, `Model`, `Props`, `init`, and `update` functions into **App.ts**. The elmish React Component resides in a **Components** subfolder and is named **App.tsx**.
|
|
201
201
|
>
|
|
202
202
|
> You can even split the contents of the **App.ts** into two files: **Types.ts** (`Message`, `Model`, and `Props`) and **State.ts** (`init` and `update`).
|
|
203
203
|
|
|
204
|
-
## More
|
|
204
|
+
## More about messages
|
|
205
205
|
|
|
206
|
-
### Message
|
|
206
|
+
### Message parameters
|
|
207
207
|
|
|
208
|
-
Messages can also have
|
|
208
|
+
Messages can also have parameters. You can modify the example above and pass an optional step value to the **Increment** message:
|
|
209
209
|
|
|
210
210
|
```ts
|
|
211
211
|
export type Message =
|
|
@@ -218,13 +218,17 @@ export const Msg = {
|
|
|
218
218
|
}
|
|
219
219
|
```
|
|
220
220
|
|
|
221
|
-
Then use this
|
|
221
|
+
Then use this parameter in the update handler:
|
|
222
222
|
|
|
223
223
|
```ts
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
224
|
+
{
|
|
225
|
+
// ...
|
|
226
|
+
// We destructure the message parameter here
|
|
227
|
+
increment ({ step }) {
|
|
228
|
+
return [{ value: model.value + (step ?? 1)}]
|
|
229
|
+
}
|
|
230
|
+
// ...
|
|
231
|
+
};
|
|
228
232
|
```
|
|
229
233
|
|
|
230
234
|
In the **render** method you can add another button to increment the value by 10:
|
|
@@ -235,44 +239,6 @@ In the **render** method you can add another button to increment the value by 10
|
|
|
235
239
|
...
|
|
236
240
|
```
|
|
237
241
|
|
|
238
|
-
### Symbols instead of strings
|
|
239
|
-
|
|
240
|
-
You can also use **Symbols** for the message type instead of strings:
|
|
241
|
-
|
|
242
|
-
1. Declare a Symbol for the message:
|
|
243
|
-
|
|
244
|
-
```ts
|
|
245
|
-
const ResetMsg = Symbol("reset");
|
|
246
|
-
```
|
|
247
|
-
|
|
248
|
-
1. Use this Symbol as message name:
|
|
249
|
-
|
|
250
|
-
```ts
|
|
251
|
-
export type Message =
|
|
252
|
-
...
|
|
253
|
-
| { name: typeof ResetMsg }
|
|
254
|
-
...
|
|
255
|
-
```
|
|
256
|
-
|
|
257
|
-
1. Create the convenient function
|
|
258
|
-
|
|
259
|
-
```ts
|
|
260
|
-
export const Msg = {
|
|
261
|
-
...
|
|
262
|
-
reset: (): Message => ({ name: ResetMsg }),
|
|
263
|
-
...
|
|
264
|
-
}
|
|
265
|
-
```
|
|
266
|
-
|
|
267
|
-
1. Handle the new message in the **update** function:
|
|
268
|
-
|
|
269
|
-
```ts
|
|
270
|
-
...
|
|
271
|
-
case ResetMsg:
|
|
272
|
-
return [{ value: 0 }];
|
|
273
|
-
...
|
|
274
|
-
```
|
|
275
|
-
|
|
276
242
|
## Dispatch commands in the update map or update function
|
|
277
243
|
|
|
278
244
|
In addition to modifying the model, you can dispatch new commands here.
|
|
@@ -319,14 +285,17 @@ export const Msg = {
|
|
|
319
285
|
const cmd = createCmd<Message>();
|
|
320
286
|
```
|
|
321
287
|
|
|
322
|
-
In the **update** function you can dispatch that message like this:
|
|
288
|
+
In the **update map** or **update** function you can dispatch that message like this:
|
|
323
289
|
|
|
324
290
|
```ts
|
|
325
|
-
|
|
326
|
-
|
|
291
|
+
{
|
|
292
|
+
increment () {
|
|
293
|
+
return [{ value: model.value + 1 }, cmd.ofMsg(Msg.printLastMessage("Incremented by one"))];
|
|
294
|
+
}
|
|
295
|
+
}
|
|
327
296
|
```
|
|
328
297
|
|
|
329
|
-
This new message will immediately be dispatched after returning from the **update
|
|
298
|
+
This new message will immediately be dispatched after returning from the **update** handler.
|
|
330
299
|
|
|
331
300
|
### Call an async function
|
|
332
301
|
|
|
@@ -361,20 +330,25 @@ export const Msg = {
|
|
|
361
330
|
and handle the messages in the **update** function:
|
|
362
331
|
|
|
363
332
|
```ts
|
|
364
|
-
|
|
365
|
-
|
|
366
|
-
|
|
367
|
-
|
|
368
|
-
|
|
369
|
-
|
|
370
|
-
|
|
371
|
-
|
|
372
|
-
|
|
373
|
-
|
|
374
|
-
|
|
375
|
-
|
|
376
|
-
|
|
377
|
-
|
|
333
|
+
{
|
|
334
|
+
// ...
|
|
335
|
+
loadSettings () {
|
|
336
|
+
// Create a command out of the async function with the provided arguments
|
|
337
|
+
// If loadSettings resolves it dispatches "SettingsLoaded"
|
|
338
|
+
// If it fails it dispatches "Error"
|
|
339
|
+
// The return type of loadSettings must fit Msg.settingsLoaded
|
|
340
|
+
return [{}, cmd.ofPromise.either(loadSettings, Msg.settingsLoaded, Msg.error, "firstArg", 123)];
|
|
341
|
+
},
|
|
342
|
+
|
|
343
|
+
settingsLoaded () {
|
|
344
|
+
return [{ settings: msg.settings }];
|
|
345
|
+
},
|
|
346
|
+
|
|
347
|
+
error () {
|
|
348
|
+
return handleError(msg.error);
|
|
349
|
+
},
|
|
350
|
+
// ...
|
|
351
|
+
};
|
|
378
352
|
```
|
|
379
353
|
|
|
380
354
|
### Dispatch a command from `init`
|
|
@@ -855,10 +829,13 @@ To inform the parent component about some action, let's say to close a dialog fo
|
|
|
855
829
|
1. Handle the message and call the callback function:
|
|
856
830
|
|
|
857
831
|
```ts Dialog.ts
|
|
858
|
-
|
|
859
|
-
|
|
860
|
-
|
|
861
|
-
|
|
832
|
+
{
|
|
833
|
+
// ...
|
|
834
|
+
close () {
|
|
835
|
+
return [{}, cmd.ofFunc.attempt(props.onClose, Msg.error)];
|
|
836
|
+
}
|
|
837
|
+
// ...
|
|
838
|
+
};
|
|
862
839
|
```
|
|
863
840
|
|
|
864
841
|
1. In the **render** method of the parent component pass the callback as prop
|
|
@@ -871,7 +848,7 @@ To inform the parent component about some action, let's say to close a dialog fo
|
|
|
871
848
|
|
|
872
849
|
## Testing
|
|
873
850
|
|
|
874
|
-
To test your **update**
|
|
851
|
+
To test your **update** handler you can use some helper functions in `react-elmish/dist/Testing`:
|
|
875
852
|
|
|
876
853
|
| Function | Description |
|
|
877
854
|
| --- | --- |
|
|
@@ -880,7 +857,20 @@ To test your **update** function you can use some helper functions in `react-elm
|
|
|
880
857
|
| `getUpdateFn` | Returns an `update` function for your update map object. |
|
|
881
858
|
| `createUpdateArgsFactory` | Creates a factory function to create a message, a model, and props in a test. |
|
|
882
859
|
|
|
883
|
-
### Testing the
|
|
860
|
+
### Testing the update handler
|
|
861
|
+
|
|
862
|
+
**Note**: When using an `UpdateMap`, you can get an `update` function by calling `getUpdateFn`:
|
|
863
|
+
|
|
864
|
+
```ts
|
|
865
|
+
import { getUpdateFn } from "react-elmish/dist/Testing";
|
|
866
|
+
|
|
867
|
+
const update = getUpdateFn(updateMap);
|
|
868
|
+
|
|
869
|
+
// Call the update function in the test
|
|
870
|
+
const [model, cmd] = update(msg, model, props);
|
|
871
|
+
```
|
|
872
|
+
|
|
873
|
+
A simple test:
|
|
884
874
|
|
|
885
875
|
```ts
|
|
886
876
|
import * as Testing from "react-elmish/dist/Testing";
|
|
@@ -890,20 +880,18 @@ const createUpdateArgs = Testing.createUpdateArgsFactory(() => ({ /* initial mod
|
|
|
890
880
|
...
|
|
891
881
|
it("returns the correct model and cmd", () => {
|
|
892
882
|
// arrange
|
|
893
|
-
const
|
|
894
|
-
|
|
895
|
-
const expectedValue = // what you expect in the model
|
|
896
|
-
const expectedCmds = [
|
|
897
|
-
Shared.Msg.expectedMsg1("arg"),
|
|
898
|
-
Shared.Msg.expectedMsg2(),
|
|
899
|
-
];
|
|
883
|
+
const args = createUpdateArgs(Msg.test(), { /* optionally override model here */ }, { /* optionally override props here */ });
|
|
900
884
|
|
|
901
885
|
// act
|
|
902
|
-
|
|
886
|
+
// Call the update handler
|
|
887
|
+
const [newModel, cmd] = update(..args);
|
|
903
888
|
|
|
904
889
|
// assert
|
|
905
|
-
expect(newModel
|
|
906
|
-
expect(Testing.getOfMsgParams(cmd)).toEqual(
|
|
890
|
+
expect(newModel).toStrictEqual({ /* what you expect in the model */ });
|
|
891
|
+
expect(Testing.getOfMsgParams(cmd)).toEqual([
|
|
892
|
+
Msg.expectedMsg1("arg"),
|
|
893
|
+
Msg.expectedMsg2(),
|
|
894
|
+
]);
|
|
907
895
|
});
|
|
908
896
|
...
|
|
909
897
|
```
|
|
@@ -920,35 +908,22 @@ import * as Testing from "react-elmish/dist/Testing";
|
|
|
920
908
|
...
|
|
921
909
|
it("returns the correct cmd", () => {
|
|
922
910
|
// arrange
|
|
923
|
-
const
|
|
911
|
+
const args = createUpdateArgs(Msg.asyncTest());
|
|
924
912
|
|
|
925
913
|
// mock function which is called when the "AsyncTest" message is handled
|
|
926
914
|
const functionMock = jest.fn();
|
|
927
915
|
|
|
928
916
|
// act
|
|
929
|
-
const [, cmd] =
|
|
917
|
+
const [, cmd] = update(...args);
|
|
930
918
|
const messages = await Testing.execCmd(cmd);
|
|
931
919
|
|
|
932
920
|
// assert
|
|
933
921
|
expect(functionMock).toBeCalled();
|
|
934
|
-
expect(messages).toEqual([
|
|
922
|
+
expect(messages).toEqual([Msg.asyncTestSuccess()])
|
|
935
923
|
});
|
|
936
924
|
...
|
|
937
925
|
```
|
|
938
926
|
|
|
939
|
-
### Testing with an UpdateMap
|
|
940
|
-
|
|
941
|
-
To test your update map, you can get an `update` function by calling `getUpdateFn`:
|
|
942
|
-
|
|
943
|
-
```ts
|
|
944
|
-
import { getUpdateFn } from "react-elmish/dist/Testing";
|
|
945
|
-
|
|
946
|
-
const update = getUpdateFn(updateMap);
|
|
947
|
-
|
|
948
|
-
// in your test call update as usual
|
|
949
|
-
const [model, cmd] = update(msg, model, props);
|
|
950
|
-
```
|
|
951
|
-
|
|
952
927
|
### UI Tests
|
|
953
928
|
|
|
954
929
|
To test UI components with a fake model you can use `renderWithModel` from the Testing namespace. The first parameter is a function to render your component (e.g. with **@testing-library/react**). The second parameter is the fake model or an options object, where you can also pass a fake `dispatch` function.
|
package/dist/Cmd.js
CHANGED
|
@@ -4,7 +4,6 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
exports.createCmd = createCmd;
|
|
7
|
-
|
|
8
7
|
/**
|
|
9
8
|
* Type of the dispatch function.
|
|
10
9
|
*/
|
|
@@ -34,7 +33,6 @@ function createCmd() {
|
|
|
34
33
|
for (var _len = arguments.length, commands = new Array(_len), _key = 0; _key < _len; _key++) {
|
|
35
34
|
commands[_key] = arguments[_key];
|
|
36
35
|
}
|
|
37
|
-
|
|
38
36
|
return commands.filter(Boolean).flat();
|
|
39
37
|
},
|
|
40
38
|
ofSub: function ofSub(sub) {
|
|
@@ -45,28 +43,23 @@ function createCmd() {
|
|
|
45
43
|
for (var _len2 = arguments.length, args = new Array(_len2 > 3 ? _len2 - 3 : 0), _key2 = 3; _key2 < _len2; _key2++) {
|
|
46
44
|
args[_key2 - 3] = arguments[_key2];
|
|
47
45
|
}
|
|
48
|
-
|
|
49
46
|
var bind = function bind(dispatch) {
|
|
50
47
|
try {
|
|
51
48
|
var _result = task.apply(void 0, args);
|
|
52
|
-
|
|
53
49
|
dispatch(ofSuccess(_result));
|
|
54
50
|
} catch (ex) {
|
|
55
51
|
dispatch(ofError(ex));
|
|
56
52
|
}
|
|
57
53
|
};
|
|
58
|
-
|
|
59
54
|
return [bind];
|
|
60
55
|
},
|
|
61
56
|
perform: function perform(task, ofSuccess) {
|
|
62
57
|
for (var _len3 = arguments.length, args = new Array(_len3 > 2 ? _len3 - 2 : 0), _key3 = 2; _key3 < _len3; _key3++) {
|
|
63
58
|
args[_key3 - 2] = arguments[_key3];
|
|
64
59
|
}
|
|
65
|
-
|
|
66
60
|
var bind = function bind(dispatch, fallback) {
|
|
67
61
|
try {
|
|
68
62
|
var _result2 = task.apply(void 0, args);
|
|
69
|
-
|
|
70
63
|
dispatch(ofSuccess(_result2));
|
|
71
64
|
} catch (ex) {
|
|
72
65
|
if (fallback) {
|
|
@@ -74,18 +67,15 @@ function createCmd() {
|
|
|
74
67
|
}
|
|
75
68
|
}
|
|
76
69
|
};
|
|
77
|
-
|
|
78
70
|
return [bind];
|
|
79
71
|
},
|
|
80
72
|
attempt: function attempt(task, ofError) {
|
|
81
73
|
for (var _len4 = arguments.length, args = new Array(_len4 > 2 ? _len4 - 2 : 0), _key4 = 2; _key4 < _len4; _key4++) {
|
|
82
74
|
args[_key4 - 2] = arguments[_key4];
|
|
83
75
|
}
|
|
84
|
-
|
|
85
76
|
var bind = function bind(dispatch, fallback) {
|
|
86
77
|
try {
|
|
87
78
|
task.apply(void 0, args);
|
|
88
|
-
|
|
89
79
|
if (fallback) {
|
|
90
80
|
fallback();
|
|
91
81
|
}
|
|
@@ -93,7 +83,6 @@ function createCmd() {
|
|
|
93
83
|
dispatch(ofError(ex));
|
|
94
84
|
}
|
|
95
85
|
};
|
|
96
|
-
|
|
97
86
|
return [bind];
|
|
98
87
|
}
|
|
99
88
|
},
|
|
@@ -102,7 +91,6 @@ function createCmd() {
|
|
|
102
91
|
for (var _len5 = arguments.length, args = new Array(_len5 > 3 ? _len5 - 3 : 0), _key5 = 3; _key5 < _len5; _key5++) {
|
|
103
92
|
args[_key5 - 3] = arguments[_key5];
|
|
104
93
|
}
|
|
105
|
-
|
|
106
94
|
var bind = function bind(dispatch) {
|
|
107
95
|
task.apply(void 0, args).then(function (result) {
|
|
108
96
|
return dispatch(ofSuccess(result));
|
|
@@ -110,31 +98,27 @@ function createCmd() {
|
|
|
110
98
|
return dispatch(ofError(ex));
|
|
111
99
|
});
|
|
112
100
|
};
|
|
113
|
-
|
|
114
101
|
return [bind];
|
|
115
102
|
},
|
|
116
103
|
perform: function perform(task, ofSuccess) {
|
|
117
104
|
for (var _len6 = arguments.length, args = new Array(_len6 > 2 ? _len6 - 2 : 0), _key6 = 2; _key6 < _len6; _key6++) {
|
|
118
105
|
args[_key6 - 2] = arguments[_key6];
|
|
119
106
|
}
|
|
120
|
-
|
|
121
|
-
|
|
107
|
+
var defaultFallbackHandler = function defaultFallbackHandler() {
|
|
108
|
+
// blank
|
|
122
109
|
};
|
|
123
|
-
|
|
124
110
|
var bind = function bind(dispatch) {
|
|
125
111
|
var fallback = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : defaultFallbackHandler;
|
|
126
112
|
task.apply(void 0, args).then(function (result) {
|
|
127
113
|
return dispatch(ofSuccess(result));
|
|
128
114
|
})["catch"](fallback);
|
|
129
115
|
};
|
|
130
|
-
|
|
131
116
|
return [bind];
|
|
132
117
|
},
|
|
133
118
|
attempt: function attempt(task, ofError) {
|
|
134
119
|
for (var _len7 = arguments.length, args = new Array(_len7 > 2 ? _len7 - 2 : 0), _key7 = 2; _key7 < _len7; _key7++) {
|
|
135
120
|
args[_key7 - 2] = arguments[_key7];
|
|
136
121
|
}
|
|
137
|
-
|
|
138
122
|
var bind = function bind(dispatch, fallback) {
|
|
139
123
|
task.apply(void 0, args).then(function () {
|
|
140
124
|
if (fallback) {
|
|
@@ -144,10 +128,9 @@ function createCmd() {
|
|
|
144
128
|
return dispatch(ofError(ex));
|
|
145
129
|
});
|
|
146
130
|
};
|
|
147
|
-
|
|
148
131
|
return [bind];
|
|
149
132
|
}
|
|
150
133
|
}
|
|
151
134
|
};
|
|
152
135
|
}
|
|
153
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["createCmd","none","ofMsg","msg","dispatch","batch","commands","filter","Boolean","flat","ofSub","sub","ofFunc","either","task","ofSuccess","ofError","args","bind","result","ex","perform","fallback","attempt","ofPromise","then","defaultFallbackHandler"],"sources":["../src/Cmd.ts"],"sourcesContent":["/**\n * Type of the dispatch function.\n */\ntype Dispatch<TMessage> = (msg: TMessage) => void;\n\ntype FallbackHandler = (error?: Error) => void;\ntype Sub<TMsg> = (dispatch: Dispatch<TMsg>, fallback?: FallbackHandler) => void;\n\n/**\n * Type of a command.\n */\ntype Cmd<TMessage> = Sub<TMessage> [];\n\n/**\n * Contains functions to create commands.\n * @template TMessage Type of the Message discriminated union.\n */\ninterface Command<TMessage> {\n    /**\n     * Represents an empty command.\n     * @deprecated Do return nothing (`undefined`) instead.\n     */\n    none: [],\n    /**\n     * Creates a command out of a specific message.\n     * @param {TMessage} msg The specific message.\n     */\n    ofMsg: (msg: TMessage) => Cmd<TMessage>,\n    /**\n     * Aggregates multiple commands.\n     * @param {Cmd<TMessage> []} commands Array of commands.\n     */\n    batch: (...commands: (Cmd<TMessage> | undefined | null) []) => Cmd<TMessage>,\n    /**\n     * Command to call the subscriber.\n     * @param {Sub<TMessage>} sub The subscriber function.\n     */\n    ofSub: (sub: Sub<TMessage>) => Cmd<TMessage>,\n    /**\n     * Provides functionalities to create commands from simple functions.\n     */\n    ofFunc: {\n        /**\n        * Creates a command out of a simple function and maps the result.\n        * @param task The function to call.\n        * @param ofSuccess Creates the message to dispatch after a successful call of the task.\n        * @param ofError Creates the message to dispatch when an error occurred.\n        * @param args The parameters of the task.\n        */\n        either: <TArgs extends unknown [], TReturn>(task: (...args: TArgs) => TReturn, ofSuccess: (result: TReturn) => TMessage, ofError: (error: Error) => TMessage, ...args: TArgs) => Cmd<TMessage>,\n        /**\n        * Creates a command out of a simple function and ignores the error case.\n        * @param task The function to call.\n        * @param ofSuccess Creates the message to dispatch after a successful call of the task.\n        * @param args The parameters of the task.\n        */\n        perform: <TArgs extends unknown [], TReturn>(task: (...args: TArgs) => TReturn, ofSuccess: (result: TReturn) => TMessage, ...args: TArgs) => Cmd<TMessage>,\n        /**\n        * Creates a command out of a simple function and ignores the success case.\n        * @param task The function to call.\n        * @param ofError Creates the message to dispatch when an error occurred.\n        * @param args The parameters of the task.\n        */\n        attempt: <TArgs extends unknown [], TReturn>(task: (...args: TArgs) => TReturn, ofError: (error: Error) => TMessage, ...args: TArgs) => Cmd<TMessage>,\n    },\n    /**\n     * Provides functionalities to create commands from async functions.\n     */\n    ofPromise: {\n        /**\n        * Creates a command out of an async function and maps the result.\n        * @param task The async function to call.\n        * @param ofSuccess Creates the message to dispatch when the promise is resolved.\n        * @param ofError Creates the message to dispatch when the promise is rejected.\n        * @param args The parameters of the task.\n        */\n        either: <TArgs extends unknown [], TReturn>(task: (...args: TArgs) => Promise<TReturn>, ofSuccess: (result: TReturn) => TMessage, ofError: (error: Error) => TMessage, ...args: TArgs) => Cmd<TMessage>,\n        /**\n        * Creates a command out of an async function and ignores the error case.\n        * @param task The async function to call.\n        * @param ofSuccess Creates the message to dispatch when the promise is resolved.\n        * @param args The parameters of the task.\n        */\n        perform: <TArgs extends unknown [], TReturn>(task: (...args: TArgs) => Promise<TReturn>, ofSuccess: (result: TReturn) => TMessage, ...args: TArgs) => Cmd<TMessage>,\n        /**\n        * Creates a command out of an async function and ignores the success case.\n        * @param task The async function to call.\n        * @param ofError Creates the message to dispatch when the promise is rejected.\n        * @param args The parameters of the task.\n        */\n        attempt: <TArgs extends unknown [], TReturn>(task: (...args: TArgs) => Promise<TReturn>, ofError: (error: Error) => TMessage, ...args: TArgs) => Cmd<TMessage>,\n    },\n}\n\n/**\n * Creates a typed instance of the Command class.\n * @template TMessage The type of the Msg discriminated union.\n */\nfunction createCmd<TMessage> (): Command<TMessage> {\n    return {\n        none: [],\n        ofMsg (msg: TMessage): Cmd<TMessage> {\n            return [dispatch => dispatch(msg)];\n        },\n        batch (...commands: (Cmd<TMessage> | undefined | null) []): Cmd<TMessage> {\n            return (commands.filter(Boolean) as Cmd<TMessage> []).flat();\n        },\n        ofSub (sub: Sub<TMessage>): Cmd<TMessage> {\n            return [sub];\n        },\n        ofFunc: {\n            either<TArgs extends unknown [], TReturn>(task: (...args: TArgs) => TReturn, ofSuccess: (result: TReturn) => TMessage, ofError: (error: Error) => TMessage, ...args: TArgs): Cmd<TMessage> {\n                const bind = (dispatch: Dispatch<TMessage>): void => {\n                    try {\n                        const result = task(...args);\n\n                        dispatch(ofSuccess(result));\n                    } catch (ex: unknown) {\n                        dispatch(ofError(ex as Error));\n                    }\n                };\n\n                return [bind];\n            },\n            perform<TArgs extends unknown [], TReturn>(task: (...args: TArgs) => TReturn, ofSuccess: (result: TReturn) => TMessage, ...args: TArgs): Cmd<TMessage> {\n                const bind = (dispatch: Dispatch<TMessage>, fallback?: FallbackHandler): void => {\n                    try {\n                        const result = task(...args);\n\n                        dispatch(ofSuccess(result));\n                    } catch (ex: unknown) {\n                        if (fallback) {\n                            fallback(ex as Error);\n                        }\n                    }\n                };\n\n                return [bind];\n            },\n            attempt<TArgs extends unknown [], TReturn>(task: (...args: TArgs) => TReturn, ofError: (error: Error) => TMessage, ...args: TArgs): Cmd<TMessage> {\n                const bind = (dispatch: Dispatch<TMessage>, fallback?: FallbackHandler): void => {\n                    try {\n                        task(...args);\n\n                        if (fallback) {\n                            fallback();\n                        }\n                    } catch (ex: unknown) {\n                        dispatch(ofError(ex as Error));\n                    }\n                };\n\n                return [bind];\n            },\n        },\n        ofPromise: {\n            either<TArgs extends unknown [], TReturn>(task: (...args: TArgs) => Promise<TReturn>, ofSuccess: (result: TReturn) => TMessage, ofError: (error: Error) => TMessage, ...args: TArgs): Cmd<TMessage> {\n                const bind = (dispatch: Dispatch<TMessage>): void => {\n                    task(...args).then(result => dispatch(ofSuccess(result)))\n                        .catch((ex: Error) => dispatch(ofError(ex)));\n                };\n\n                return [bind];\n            },\n            perform<TArgs extends unknown [], TReturn>(task: (...args: TArgs) => Promise<TReturn>, ofSuccess: (result: TReturn) => TMessage, ...args: TArgs): Cmd<TMessage> {\n                const defaultFallbackHandler = (): void => {\n                    // blank\n                };\n\n                const bind = (dispatch: Dispatch<TMessage>, fallback: FallbackHandler = defaultFallbackHandler): void => {\n                    task(...args).then(result => dispatch(ofSuccess(result)))\n                        .catch(fallback);\n                };\n\n                return [bind];\n            },\n            attempt<TArgs extends unknown [], TReturn>(task: (...args: TArgs) => Promise<TReturn>, ofError: (error: Error) => TMessage, ...args: TArgs): Cmd<TMessage> {\n                const bind = (dispatch: Dispatch<TMessage>, fallback?: FallbackHandler): void => {\n                    task(...args).then(() => {\n                        if (fallback) {\n                            fallback();\n                        }\n                    })\n                        .catch((ex: Error) => dispatch(ofError(ex)));\n                };\n\n                return [bind];\n            },\n        },\n    };\n}\n\nexport type {\n    Dispatch,\n    Cmd,\n};\n\nexport {\n    createCmd,\n};"],"mappings":"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"}
|
|
136
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["createCmd","none","ofMsg","msg","dispatch","batch","commands","filter","Boolean","flat","ofSub","sub","ofFunc","either","task","ofSuccess","ofError","args","bind","result","ex","perform","fallback","attempt","ofPromise","then","defaultFallbackHandler"],"sources":["../src/Cmd.ts"],"sourcesContent":["/**\n * Type of the dispatch function.\n */\ntype Dispatch<TMessage> = (msg: TMessage) => void;\n\ntype FallbackHandler = (error?: Error) => void;\ntype Sub<TMsg> = (dispatch: Dispatch<TMsg>, fallback?: FallbackHandler) => void;\n\n/**\n * Type of a command.\n */\ntype Cmd<TMessage> = Sub<TMessage> [];\n\n/**\n * Contains functions to create commands.\n * @template TMessage Type of the Message discriminated union.\n */\ninterface Command<TMessage> {\n    /**\n     * Represents an empty command.\n     * @deprecated Do return nothing (`undefined`) instead.\n     */\n    none: [],\n    /**\n     * Creates a command out of a specific message.\n     * @param {TMessage} msg The specific message.\n     */\n    ofMsg: (msg: TMessage) => Cmd<TMessage>,\n    /**\n     * Aggregates multiple commands.\n     * @param {Cmd<TMessage> []} commands Array of commands.\n     */\n    batch: (...commands: (Cmd<TMessage> | undefined | null) []) => Cmd<TMessage>,\n    /**\n     * Command to call the subscriber.\n     * @param {Sub<TMessage>} sub The subscriber function.\n     */\n    ofSub: (sub: Sub<TMessage>) => Cmd<TMessage>,\n    /**\n     * Provides functionalities to create commands from simple functions.\n     */\n    ofFunc: {\n        /**\n        * Creates a command out of a simple function and maps the result.\n        * @param task The function to call.\n        * @param ofSuccess Creates the message to dispatch after a successful call of the task.\n        * @param ofError Creates the message to dispatch when an error occurred.\n        * @param args The parameters of the task.\n        */\n        either: <TArgs extends unknown [], TReturn>(task: (...args: TArgs) => TReturn, ofSuccess: (result: TReturn) => TMessage, ofError: (error: Error) => TMessage, ...args: TArgs) => Cmd<TMessage>,\n        /**\n        * Creates a command out of a simple function and ignores the error case.\n        * @param task The function to call.\n        * @param ofSuccess Creates the message to dispatch after a successful call of the task.\n        * @param args The parameters of the task.\n        */\n        perform: <TArgs extends unknown [], TReturn>(task: (...args: TArgs) => TReturn, ofSuccess: (result: TReturn) => TMessage, ...args: TArgs) => Cmd<TMessage>,\n        /**\n        * Creates a command out of a simple function and ignores the success case.\n        * @param task The function to call.\n        * @param ofError Creates the message to dispatch when an error occurred.\n        * @param args The parameters of the task.\n        */\n        attempt: <TArgs extends unknown [], TReturn>(task: (...args: TArgs) => TReturn, ofError: (error: Error) => TMessage, ...args: TArgs) => Cmd<TMessage>,\n    },\n    /**\n     * Provides functionalities to create commands from async functions.\n     */\n    ofPromise: {\n        /**\n        * Creates a command out of an async function and maps the result.\n        * @param task The async function to call.\n        * @param ofSuccess Creates the message to dispatch when the promise is resolved.\n        * @param ofError Creates the message to dispatch when the promise is rejected.\n        * @param args The parameters of the task.\n        */\n        either: <TArgs extends unknown [], TReturn>(task: (...args: TArgs) => Promise<TReturn>, ofSuccess: (result: TReturn) => TMessage, ofError: (error: Error) => TMessage, ...args: TArgs) => Cmd<TMessage>,\n        /**\n        * Creates a command out of an async function and ignores the error case.\n        * @param task The async function to call.\n        * @param ofSuccess Creates the message to dispatch when the promise is resolved.\n        * @param args The parameters of the task.\n        */\n        perform: <TArgs extends unknown [], TReturn>(task: (...args: TArgs) => Promise<TReturn>, ofSuccess: (result: TReturn) => TMessage, ...args: TArgs) => Cmd<TMessage>,\n        /**\n        * Creates a command out of an async function and ignores the success case.\n        * @param task The async function to call.\n        * @param ofError Creates the message to dispatch when the promise is rejected.\n        * @param args The parameters of the task.\n        */\n        attempt: <TArgs extends unknown [], TReturn>(task: (...args: TArgs) => Promise<TReturn>, ofError: (error: Error) => TMessage, ...args: TArgs) => Cmd<TMessage>,\n    },\n}\n\n/**\n * Creates a typed instance of the Command class.\n * @template TMessage The type of the Msg discriminated union.\n */\nfunction createCmd<TMessage> (): Command<TMessage> {\n    return {\n        none: [],\n        ofMsg (msg: TMessage): Cmd<TMessage> {\n            return [dispatch => dispatch(msg)];\n        },\n        batch (...commands: (Cmd<TMessage> | undefined | null) []): Cmd<TMessage> {\n            return (commands.filter(Boolean) as Cmd<TMessage> []).flat();\n        },\n        ofSub (sub: Sub<TMessage>): Cmd<TMessage> {\n            return [sub];\n        },\n        ofFunc: {\n            either<TArgs extends unknown [], TReturn>(task: (...args: TArgs) => TReturn, ofSuccess: (result: TReturn) => TMessage, ofError: (error: Error) => TMessage, ...args: TArgs): Cmd<TMessage> {\n                const bind = (dispatch: Dispatch<TMessage>): void => {\n                    try {\n                        const result = task(...args);\n\n                        dispatch(ofSuccess(result));\n                    } catch (ex: unknown) {\n                        dispatch(ofError(ex as Error));\n                    }\n                };\n\n                return [bind];\n            },\n            perform<TArgs extends unknown [], TReturn>(task: (...args: TArgs) => TReturn, ofSuccess: (result: TReturn) => TMessage, ...args: TArgs): Cmd<TMessage> {\n                const bind = (dispatch: Dispatch<TMessage>, fallback?: FallbackHandler): void => {\n                    try {\n                        const result = task(...args);\n\n                        dispatch(ofSuccess(result));\n                    } catch (ex: unknown) {\n                        if (fallback) {\n                            fallback(ex as Error);\n                        }\n                    }\n                };\n\n                return [bind];\n            },\n            attempt<TArgs extends unknown [], TReturn>(task: (...args: TArgs) => TReturn, ofError: (error: Error) => TMessage, ...args: TArgs): Cmd<TMessage> {\n                const bind = (dispatch: Dispatch<TMessage>, fallback?: FallbackHandler): void => {\n                    try {\n                        task(...args);\n\n                        if (fallback) {\n                            fallback();\n                        }\n                    } catch (ex: unknown) {\n                        dispatch(ofError(ex as Error));\n                    }\n                };\n\n                return [bind];\n            },\n        },\n        ofPromise: {\n            either<TArgs extends unknown [], TReturn>(task: (...args: TArgs) => Promise<TReturn>, ofSuccess: (result: TReturn) => TMessage, ofError: (error: Error) => TMessage, ...args: TArgs): Cmd<TMessage> {\n                const bind = (dispatch: Dispatch<TMessage>): void => {\n                    task(...args).then(result => dispatch(ofSuccess(result)))\n                        .catch((ex: Error) => dispatch(ofError(ex)));\n                };\n\n                return [bind];\n            },\n            perform<TArgs extends unknown [], TReturn>(task: (...args: TArgs) => Promise<TReturn>, ofSuccess: (result: TReturn) => TMessage, ...args: TArgs): Cmd<TMessage> {\n                const defaultFallbackHandler = (): void => {\n                    // blank\n                };\n\n                const bind = (dispatch: Dispatch<TMessage>, fallback: FallbackHandler = defaultFallbackHandler): void => {\n                    task(...args).then(result => dispatch(ofSuccess(result)))\n                        .catch(fallback);\n                };\n\n                return [bind];\n            },\n            attempt<TArgs extends unknown [], TReturn>(task: (...args: TArgs) => Promise<TReturn>, ofError: (error: Error) => TMessage, ...args: TArgs): Cmd<TMessage> {\n                const bind = (dispatch: Dispatch<TMessage>, fallback?: FallbackHandler): void => {\n                    task(...args).then(() => {\n                        if (fallback) {\n                            fallback();\n                        }\n                    })\n                        .catch((ex: Error) => dispatch(ofError(ex)));\n                };\n\n                return [bind];\n            },\n        },\n    };\n}\n\nexport type {\n    Dispatch,\n    Cmd,\n};\n\nexport {\n    createCmd,\n};"],"mappings":"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"}
|
package/dist/Common.js
CHANGED
|
@@ -6,24 +6,19 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
6
6
|
exports.execCmd = execCmd;
|
|
7
7
|
exports.logMessage = logMessage;
|
|
8
8
|
exports.modelHasChanged = modelHasChanged;
|
|
9
|
-
|
|
10
9
|
var _Init = require("./Init");
|
|
11
|
-
|
|
12
10
|
function logMessage(name, msg) {
|
|
13
11
|
var _Services$logger, _Services$logger2, _Services$dispatchMid;
|
|
14
|
-
|
|
15
12
|
(_Services$logger = _Init.Services.logger) === null || _Services$logger === void 0 ? void 0 : _Services$logger.info("Elm", "message from", name, msg.name);
|
|
16
13
|
(_Services$logger2 = _Init.Services.logger) === null || _Services$logger2 === void 0 ? void 0 : _Services$logger2.debug("Elm", "message from", name, msg);
|
|
17
14
|
(_Services$dispatchMid = _Init.Services.dispatchMiddleware) === null || _Services$dispatchMid === void 0 ? void 0 : _Services$dispatchMid.call(_Init.Services, msg);
|
|
18
15
|
}
|
|
19
|
-
|
|
20
16
|
function modelHasChanged(currentModel, model) {
|
|
21
17
|
return !Object.is(model, currentModel) && Object.getOwnPropertyNames(model).length > 0;
|
|
22
18
|
}
|
|
23
|
-
|
|
24
19
|
function execCmd(cmd, dispatch) {
|
|
25
20
|
cmd.forEach(function (call) {
|
|
26
21
|
return call(dispatch);
|
|
27
22
|
});
|
|
28
23
|
}
|
|
29
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJsb2dNZXNzYWdlIiwibmFtZSIsIm1zZyIsIlNlcnZpY2VzIiwibG9nZ2VyIiwiaW5mbyIsImRlYnVnIiwiZGlzcGF0Y2hNaWRkbGV3YXJlIiwibW9kZWxIYXNDaGFuZ2VkIiwiY3VycmVudE1vZGVsIiwibW9kZWwiLCJPYmplY3QiLCJpcyIsImdldE93blByb3BlcnR5TmFtZXMiLCJsZW5ndGgiLCJleGVjQ21kIiwiY21kIiwiZGlzcGF0Y2giLCJmb3JFYWNoIiwiY2FsbCJdLCJzb3VyY2VzIjpbIi4uL3NyYy9Db21tb24udHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ21kLCBEaXNwYXRjaCB9IGZyb20gXCIuL0NtZFwiO1xuaW1wb3J0IHsgU2VydmljZXMgfSBmcm9tIFwiLi9Jbml0XCI7XG5pbXBvcnQgeyBNZXNzYWdlQmFzZSB9IGZyb20gXCIuL1R5cGVzXCI7XG5cbmZ1bmN0aW9uIGxvZ01lc3NhZ2U8VE1lc3NhZ2UgZXh0ZW5kcyBNZXNzYWdlQmFzZT4gKG5hbWU6IHN0cmluZywgbXNnOiBUTWVzc2FnZSk6IHZvaWQge1xuICAgIFNlcnZpY2VzLmxvZ2dlcj8uaW5mbyhcIkVsbVwiLCBcIm1lc3NhZ2UgZnJvbVwiLCBuYW1lLCBtc2cubmFtZSk7XG4gICAgU2VydmljZXMubG9nZ2VyPy5kZWJ1ZyhcIkVsbVwiLCBcIm1lc3NhZ2UgZnJvbVwiLCBuYW1lLCBtc2cpO1xuXG4gICAgU2VydmljZXMuZGlzcGF0Y2hNaWRkbGV3YXJlPy4obXNnKTtcbn1cblxuZnVuY3Rpb24gbW9kZWxIYXNDaGFuZ2VkPFRNb2RlbD4gKGN1cnJlbnRNb2RlbDogVE1vZGVsLCBtb2RlbDogUGFydGlhbDxUTW9kZWw+KTogYm9vbGVhbiB7XG4gICAgcmV0dXJuICFPYmplY3QuaXMobW9kZWwsIGN1cnJlbnRNb2RlbCkgJiYgT2JqZWN0LmdldE93blByb3BlcnR5TmFtZXMobW9kZWwpLmxlbmd0aCA+IDA7XG59XG5cbmZ1bmN0aW9uIGV4ZWNDbWQ8VE1lc3NhZ2U+IChjbWQ6IENtZDxUTWVzc2FnZT4sIGRpc3BhdGNoOiBEaXNwYXRjaDxUTWVzc2FnZT4pOiB2b2lkIHtcbiAgICBjbWQuZm9yRWFjaChjYWxsID0+
|
|
24
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJsb2dNZXNzYWdlIiwibmFtZSIsIm1zZyIsIlNlcnZpY2VzIiwibG9nZ2VyIiwiaW5mbyIsImRlYnVnIiwiZGlzcGF0Y2hNaWRkbGV3YXJlIiwibW9kZWxIYXNDaGFuZ2VkIiwiY3VycmVudE1vZGVsIiwibW9kZWwiLCJPYmplY3QiLCJpcyIsImdldE93blByb3BlcnR5TmFtZXMiLCJsZW5ndGgiLCJleGVjQ21kIiwiY21kIiwiZGlzcGF0Y2giLCJmb3JFYWNoIiwiY2FsbCJdLCJzb3VyY2VzIjpbIi4uL3NyYy9Db21tb24udHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ21kLCBEaXNwYXRjaCB9IGZyb20gXCIuL0NtZFwiO1xuaW1wb3J0IHsgU2VydmljZXMgfSBmcm9tIFwiLi9Jbml0XCI7XG5pbXBvcnQgeyBNZXNzYWdlQmFzZSB9IGZyb20gXCIuL1R5cGVzXCI7XG5cbmZ1bmN0aW9uIGxvZ01lc3NhZ2U8VE1lc3NhZ2UgZXh0ZW5kcyBNZXNzYWdlQmFzZT4gKG5hbWU6IHN0cmluZywgbXNnOiBUTWVzc2FnZSk6IHZvaWQge1xuICAgIFNlcnZpY2VzLmxvZ2dlcj8uaW5mbyhcIkVsbVwiLCBcIm1lc3NhZ2UgZnJvbVwiLCBuYW1lLCBtc2cubmFtZSk7XG4gICAgU2VydmljZXMubG9nZ2VyPy5kZWJ1ZyhcIkVsbVwiLCBcIm1lc3NhZ2UgZnJvbVwiLCBuYW1lLCBtc2cpO1xuXG4gICAgU2VydmljZXMuZGlzcGF0Y2hNaWRkbGV3YXJlPy4obXNnKTtcbn1cblxuZnVuY3Rpb24gbW9kZWxIYXNDaGFuZ2VkPFRNb2RlbD4gKGN1cnJlbnRNb2RlbDogVE1vZGVsLCBtb2RlbDogUGFydGlhbDxUTW9kZWw+KTogYm9vbGVhbiB7XG4gICAgcmV0dXJuICFPYmplY3QuaXMobW9kZWwsIGN1cnJlbnRNb2RlbCkgJiYgT2JqZWN0LmdldE93blByb3BlcnR5TmFtZXMobW9kZWwpLmxlbmd0aCA+IDA7XG59XG5cbmZ1bmN0aW9uIGV4ZWNDbWQ8VE1lc3NhZ2U+IChjbWQ6IENtZDxUTWVzc2FnZT4sIGRpc3BhdGNoOiBEaXNwYXRjaDxUTWVzc2FnZT4pOiB2b2lkIHtcbiAgICBjbWQuZm9yRWFjaChjYWxsID0+IGNhbGwoZGlzcGF0Y2gpKTtcbn1cblxuZXhwb3J0IHtcbiAgICBsb2dNZXNzYWdlLFxuICAgIG1vZGVsSGFzQ2hhbmdlZCxcbiAgICBleGVjQ21kLFxufTsiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7O0FBQ0E7QUFHQSxTQUFTQSxVQUFVLENBQWdDQyxJQUFZLEVBQUVDLEdBQWEsRUFBUTtFQUFBO0VBQ2xGLG9CQUFBQyxjQUFRLENBQUNDLE1BQU0scURBQWYsaUJBQWlCQyxJQUFJLENBQUMsS0FBSyxFQUFFLGNBQWMsRUFBRUosSUFBSSxFQUFFQyxHQUFHLENBQUNELElBQUksQ0FBQztFQUM1RCxxQkFBQUUsY0FBUSxDQUFDQyxNQUFNLHNEQUFmLGtCQUFpQkUsS0FBSyxDQUFDLEtBQUssRUFBRSxjQUFjLEVBQUVMLElBQUksRUFBRUMsR0FBRyxDQUFDO0VBRXhELHlCQUFBQyxjQUFRLENBQUNJLGtCQUFrQiwwREFBM0IsMkJBQUFKLGNBQVEsRUFBc0JELEdBQUcsQ0FBQztBQUN0QztBQUVBLFNBQVNNLGVBQWUsQ0FBVUMsWUFBb0IsRUFBRUMsS0FBc0IsRUFBVztFQUNyRixPQUFPLENBQUNDLE1BQU0sQ0FBQ0MsRUFBRSxDQUFDRixLQUFLLEVBQUVELFlBQVksQ0FBQyxJQUFJRSxNQUFNLENBQUNFLG1CQUFtQixDQUFDSCxLQUFLLENBQUMsQ0FBQ0ksTUFBTSxHQUFHLENBQUM7QUFDMUY7QUFFQSxTQUFTQyxPQUFPLENBQVlDLEdBQWtCLEVBQUVDLFFBQTRCLEVBQVE7RUFDaEZELEdBQUcsQ0FBQ0UsT0FBTyxDQUFDLFVBQUFDLElBQUk7SUFBQSxPQUFJQSxJQUFJLENBQUNGLFFBQVEsQ0FBQztFQUFBLEVBQUM7QUFDdkMifQ==
|