react-elmish 6.4.1 → 6.5.0-beta.2
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 +12 -9
- package/dist/cmd.d.ts +28 -6
- package/dist/cmd.js +88 -16
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -257,12 +257,15 @@ You can call one of the functions of that object:
|
|
|
257
257
|
|---|---|
|
|
258
258
|
| `cmd.ofMsg` | Dispatches a new message. |
|
|
259
259
|
| `cmd.batch` | Aggregates an array of messages. |
|
|
260
|
+
| `cmd.ofEither` | Calls a function (sync or async) and maps the result into a message. |
|
|
261
|
+
| `cmd.ofSuccess` | Same as `ofEither` but ignores the error case. |
|
|
262
|
+
| `cmd.ofError` | Same as `ofEither` but ignores the success case. |
|
|
260
263
|
| `cmd.ofFunc.either` | Calls a synchronous function and maps the result into a message. |
|
|
261
|
-
| `cmd.ofFunc.
|
|
262
|
-
| `cmd.ofFunc.
|
|
264
|
+
| `cmd.ofFunc.perform` | Same as `either` but ignores the error case. |
|
|
265
|
+
| `cmd.ofFunc.attempt` | Same as `either` but ignores the success case. |
|
|
263
266
|
| `cmd.ofPromise.either` | Calls an async function and maps the result into a message. |
|
|
264
|
-
| `cmd.ofPromise.
|
|
265
|
-
| `cmd.ofPromise.
|
|
267
|
+
| `cmd.ofPromise.perform` | Same as `either` but ignores the error case. |
|
|
268
|
+
| `cmd.ofPromise.attempt` | Same as `either` but ignores the success case. |
|
|
266
269
|
| `cmd.ofSub` | Use this function to trigger a command in a subscription. |
|
|
267
270
|
|
|
268
271
|
### Dispatch a message
|
|
@@ -334,7 +337,7 @@ and handle the messages in the **update** function:
|
|
|
334
337
|
// If loadSettings resolves it dispatches "SettingsLoaded"
|
|
335
338
|
// If it fails it dispatches "Error"
|
|
336
339
|
// The return type of loadSettings must fit Msg.settingsLoaded
|
|
337
|
-
return [{}, cmd.
|
|
340
|
+
return [{}, cmd.ofEither(loadSettings, Msg.settingsLoaded, Msg.error, "firstArg", 123)];
|
|
338
341
|
},
|
|
339
342
|
|
|
340
343
|
settingsLoaded () {
|
|
@@ -368,7 +371,7 @@ export function init (props: Props): InitResult {
|
|
|
368
371
|
To dispatch more than one command from `init` or `update` you can either use the `cmd.batch` function or simply return multiple commands:
|
|
369
372
|
|
|
370
373
|
```ts
|
|
371
|
-
return [{}, cmd.ofMsg(Msg.loadData()), cmd.
|
|
374
|
+
return [{}, cmd.ofMsg(Msg.loadData()), cmd.ofEither(doStuff, Msg.success, Msg.error)];
|
|
372
375
|
```
|
|
373
376
|
|
|
374
377
|
## Subscriptions
|
|
@@ -601,7 +604,7 @@ export function init (): Model {
|
|
|
601
604
|
|
|
602
605
|
export const update: UpdateMap<Props, Model, Message> = {
|
|
603
606
|
loadSettings () {
|
|
604
|
-
return [{}, cmd.
|
|
607
|
+
return [{}, cmd.ofEither(loadSettings, Msg.settingsLoaded, Msg.error)];
|
|
605
608
|
}
|
|
606
609
|
|
|
607
610
|
settingsLoaded ({ settings }) {
|
|
@@ -708,7 +711,7 @@ export function init (): InitResult<Model, Message> {
|
|
|
708
711
|
export function update (_model: Model, msg: Message): UpdateReturnType<Model, Message> {
|
|
709
712
|
switch (msg.name) {
|
|
710
713
|
case "loadSettings":
|
|
711
|
-
return [{}, cmd.
|
|
714
|
+
return [{}, cmd.ofEither(loadSettings, Msg.settingsLoaded, Msg.error)];
|
|
712
715
|
|
|
713
716
|
case "settingsLoaded":
|
|
714
717
|
return [{ settings: msg.settings }];
|
|
@@ -827,7 +830,7 @@ To inform the parent component about some action, let's say to close a dialog fo
|
|
|
827
830
|
{
|
|
828
831
|
// ...
|
|
829
832
|
close () {
|
|
830
|
-
return [{}, cmd.
|
|
833
|
+
return [{}, cmd.ofError(props.onClose, Msg.error)];
|
|
831
834
|
}
|
|
832
835
|
// ...
|
|
833
836
|
};
|
package/dist/cmd.d.ts
CHANGED
|
@@ -15,6 +15,28 @@ declare const cmd: {
|
|
|
15
15
|
* @param {Sub<TMessage>} sub The subscriber function.
|
|
16
16
|
*/
|
|
17
17
|
ofSub<TMessage_2 extends Message>(sub: Sub<TMessage_2>): Cmd<TMessage_2>;
|
|
18
|
+
/**
|
|
19
|
+
* Creates a command out of a function and maps the result. This can also be an async function.
|
|
20
|
+
* @param task The function to call.
|
|
21
|
+
* @param ofSuccess Creates the message to dispatch when the function runs successfully or, for an async function, the promise is resolved.
|
|
22
|
+
* @param ofError Creates the message to dispatch when the function throws an error or, for an async function, the promise is rejected.
|
|
23
|
+
* @param args The parameters of the task.
|
|
24
|
+
*/
|
|
25
|
+
ofEither<TMessage_3 extends Message, TArgs extends unknown[], TReturn>(task: (...args: TArgs) => TReturn, ofSuccess: (result: Awaited<TReturn>) => TMessage_3, ofError: (error: Error) => TMessage_3, ...args: TArgs): Cmd<TMessage_3>;
|
|
26
|
+
/**
|
|
27
|
+
* Creates a command out of a function and ignores the error case. This can also be an async function.
|
|
28
|
+
* @param task The async function to call.
|
|
29
|
+
* @param ofSuccess Creates the message to dispatch when the function runs successfully or, for an async function, the promise is resolved.
|
|
30
|
+
* @param args The parameters of the task.
|
|
31
|
+
*/
|
|
32
|
+
ofSuccess<TMessage_4 extends Message, TArgs_1 extends unknown[], TReturn_1>(task: (...args: TArgs_1) => TReturn_1, ofSuccess: (result: Awaited<TReturn_1>) => TMessage_4, ...args: TArgs_1): Cmd<TMessage_4>;
|
|
33
|
+
/**
|
|
34
|
+
* Creates a command out of a function and ignores the success case. This can also be an async function.
|
|
35
|
+
* @param task The function to call.
|
|
36
|
+
* @param ofError Creates the message to dispatch when the function runs successfully or, for an async function, the promise is rejected.
|
|
37
|
+
* @param args The parameters of the task.
|
|
38
|
+
*/
|
|
39
|
+
ofError<TMessage_5 extends Message, TArgs_2 extends unknown[], TReturn_2>(task: (...args: TArgs_2) => TReturn_2, ofError: (error: Error) => TMessage_5, ...args: TArgs_2): Cmd<TMessage_5>;
|
|
18
40
|
/**
|
|
19
41
|
* Provides functionalities to create commands from simple functions.
|
|
20
42
|
*/
|
|
@@ -26,21 +48,21 @@ declare const cmd: {
|
|
|
26
48
|
* @param ofError Creates the message to dispatch when an error occurred.
|
|
27
49
|
* @param args The parameters of the task.
|
|
28
50
|
*/
|
|
29
|
-
either<
|
|
51
|
+
either<TMessage_6 extends Message, TArgs_3 extends unknown[], TReturn_3>(task: (...args: TArgs_3) => TReturn_3, ofSuccess: (result: TReturn_3) => TMessage_6, ofError: (error: Error) => TMessage_6, ...args: TArgs_3): Cmd<TMessage_6>;
|
|
30
52
|
/**
|
|
31
53
|
* Creates a command out of a simple function and ignores the error case.
|
|
32
54
|
* @param task The function to call.
|
|
33
55
|
* @param ofSuccess Creates the message to dispatch after a successful call of the task.
|
|
34
56
|
* @param args The parameters of the task.
|
|
35
57
|
*/
|
|
36
|
-
perform<
|
|
58
|
+
perform<TMessage_7 extends Message, TArgs_4 extends unknown[], TReturn_4>(task: (...args: TArgs_4) => TReturn_4, ofSuccess: (result: TReturn_4) => TMessage_7, ...args: TArgs_4): Cmd<TMessage_7>;
|
|
37
59
|
/**
|
|
38
60
|
* Creates a command out of a simple function and ignores the success case.
|
|
39
61
|
* @param task The function to call.
|
|
40
62
|
* @param ofError Creates the message to dispatch when an error occurred.
|
|
41
63
|
* @param args The parameters of the task.
|
|
42
64
|
*/
|
|
43
|
-
attempt<
|
|
65
|
+
attempt<TMessage_8 extends Message, TArgs_5 extends unknown[], TReturn_5>(task: (...args: TArgs_5) => TReturn_5, ofError: (error: Error) => TMessage_8, ...args: TArgs_5): Cmd<TMessage_8>;
|
|
44
66
|
};
|
|
45
67
|
/**
|
|
46
68
|
* Provides functionalities to create commands from async functions.
|
|
@@ -53,21 +75,21 @@ declare const cmd: {
|
|
|
53
75
|
* @param ofError Creates the message to dispatch when the promise is rejected.
|
|
54
76
|
* @param args The parameters of the task.
|
|
55
77
|
*/
|
|
56
|
-
either<
|
|
78
|
+
either<TMessage_9 extends Message, TArgs_6 extends unknown[], TReturn_6>(task: (...args: TArgs_6) => Promise<TReturn_6>, ofSuccess: (result: TReturn_6) => TMessage_9, ofError: (error: Error) => TMessage_9, ...args: TArgs_6): Cmd<TMessage_9>;
|
|
57
79
|
/**
|
|
58
80
|
* Creates a command out of an async function and ignores the error case.
|
|
59
81
|
* @param task The async function to call.
|
|
60
82
|
* @param ofSuccess Creates the message to dispatch when the promise is resolved.
|
|
61
83
|
* @param args The parameters of the task.
|
|
62
84
|
*/
|
|
63
|
-
perform<
|
|
85
|
+
perform<TMessage_10 extends Message, TArgs_7 extends unknown[], TReturn_7>(task: (...args: TArgs_7) => Promise<TReturn_7>, ofSuccess: (result: TReturn_7) => TMessage_10, ...args: TArgs_7): Cmd<TMessage_10>;
|
|
64
86
|
/**
|
|
65
87
|
* Creates a command out of an async function and ignores the success case.
|
|
66
88
|
* @param task The async function to call.
|
|
67
89
|
* @param ofError Creates the message to dispatch when the promise is rejected.
|
|
68
90
|
* @param args The parameters of the task.
|
|
69
91
|
*/
|
|
70
|
-
attempt<
|
|
92
|
+
attempt<TMessage_11 extends Message, TArgs_8 extends unknown[], TReturn_8>(task: (...args: TArgs_8) => Promise<TReturn_8>, ofError: (error: Error) => TMessage_11, ...args: TArgs_8): Cmd<TMessage_11>;
|
|
71
93
|
};
|
|
72
94
|
};
|
|
73
95
|
export { cmd, };
|
package/dist/cmd.js
CHANGED
|
@@ -31,6 +31,78 @@ var cmd = {
|
|
|
31
31
|
ofSub: function ofSub(sub) {
|
|
32
32
|
return [sub];
|
|
33
33
|
},
|
|
34
|
+
/**
|
|
35
|
+
* Creates a command out of a function and maps the result. This can also be an async function.
|
|
36
|
+
* @param task The function to call.
|
|
37
|
+
* @param ofSuccess Creates the message to dispatch when the function runs successfully or, for an async function, the promise is resolved.
|
|
38
|
+
* @param ofError Creates the message to dispatch when the function throws an error or, for an async function, the promise is rejected.
|
|
39
|
+
* @param args The parameters of the task.
|
|
40
|
+
*/
|
|
41
|
+
ofEither: function ofEither(task, ofSuccess, ofError) {
|
|
42
|
+
for (var _len2 = arguments.length, args = new Array(_len2 > 3 ? _len2 - 3 : 0), _key2 = 3; _key2 < _len2; _key2++) {
|
|
43
|
+
args[_key2 - 3] = arguments[_key2];
|
|
44
|
+
}
|
|
45
|
+
var bind = function bind(dispatch) {
|
|
46
|
+
try {
|
|
47
|
+
var taskResult = task.apply(void 0, args);
|
|
48
|
+
Promise.resolve(taskResult).then(function (result) {
|
|
49
|
+
return dispatch(ofSuccess(result));
|
|
50
|
+
})["catch"](function (ex) {
|
|
51
|
+
return dispatch(ofError(ex));
|
|
52
|
+
});
|
|
53
|
+
} catch (ex) {
|
|
54
|
+
dispatch(ofError(ex));
|
|
55
|
+
}
|
|
56
|
+
};
|
|
57
|
+
return [bind];
|
|
58
|
+
},
|
|
59
|
+
/**
|
|
60
|
+
* Creates a command out of a function and ignores the error case. This can also be an async function.
|
|
61
|
+
* @param task The async function to call.
|
|
62
|
+
* @param ofSuccess Creates the message to dispatch when the function runs successfully or, for an async function, the promise is resolved.
|
|
63
|
+
* @param args The parameters of the task.
|
|
64
|
+
*/
|
|
65
|
+
ofSuccess: function ofSuccess(task, _ofSuccess) {
|
|
66
|
+
for (var _len3 = arguments.length, args = new Array(_len3 > 2 ? _len3 - 2 : 0), _key3 = 2; _key3 < _len3; _key3++) {
|
|
67
|
+
args[_key3 - 2] = arguments[_key3];
|
|
68
|
+
}
|
|
69
|
+
var bind = function bind(dispatch) {
|
|
70
|
+
var fallback = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : defaultFallbackHandler;
|
|
71
|
+
try {
|
|
72
|
+
var taskResult = task.apply(void 0, args);
|
|
73
|
+
Promise.resolve(taskResult).then(function (result) {
|
|
74
|
+
return dispatch(_ofSuccess(result));
|
|
75
|
+
})["catch"](fallback);
|
|
76
|
+
} catch (ex) {
|
|
77
|
+
fallback(ex);
|
|
78
|
+
}
|
|
79
|
+
};
|
|
80
|
+
return [bind];
|
|
81
|
+
},
|
|
82
|
+
/**
|
|
83
|
+
* Creates a command out of a function and ignores the success case. This can also be an async function.
|
|
84
|
+
* @param task The function to call.
|
|
85
|
+
* @param ofError Creates the message to dispatch when the function runs successfully or, for an async function, the promise is rejected.
|
|
86
|
+
* @param args The parameters of the task.
|
|
87
|
+
*/
|
|
88
|
+
ofError: function ofError(task, _ofError) {
|
|
89
|
+
for (var _len4 = arguments.length, args = new Array(_len4 > 2 ? _len4 - 2 : 0), _key4 = 2; _key4 < _len4; _key4++) {
|
|
90
|
+
args[_key4 - 2] = arguments[_key4];
|
|
91
|
+
}
|
|
92
|
+
var bind = function bind(dispatch, fallback) {
|
|
93
|
+
try {
|
|
94
|
+
var taskResult = task.apply(void 0, args);
|
|
95
|
+
Promise.resolve(taskResult).then(function () {
|
|
96
|
+
return fallback === null || fallback === void 0 ? void 0 : fallback();
|
|
97
|
+
})["catch"](function (ex) {
|
|
98
|
+
return dispatch(_ofError(ex));
|
|
99
|
+
});
|
|
100
|
+
} catch (ex) {
|
|
101
|
+
dispatch(_ofError(ex));
|
|
102
|
+
}
|
|
103
|
+
};
|
|
104
|
+
return [bind];
|
|
105
|
+
},
|
|
34
106
|
/**
|
|
35
107
|
* Provides functionalities to create commands from simple functions.
|
|
36
108
|
*/
|
|
@@ -43,8 +115,8 @@ var cmd = {
|
|
|
43
115
|
* @param args The parameters of the task.
|
|
44
116
|
*/
|
|
45
117
|
either: function either(task, ofSuccess, ofError) {
|
|
46
|
-
for (var
|
|
47
|
-
args[
|
|
118
|
+
for (var _len5 = arguments.length, args = new Array(_len5 > 3 ? _len5 - 3 : 0), _key5 = 3; _key5 < _len5; _key5++) {
|
|
119
|
+
args[_key5 - 3] = arguments[_key5];
|
|
48
120
|
}
|
|
49
121
|
var bind = function bind(dispatch) {
|
|
50
122
|
try {
|
|
@@ -63,8 +135,8 @@ var cmd = {
|
|
|
63
135
|
* @param args The parameters of the task.
|
|
64
136
|
*/
|
|
65
137
|
perform: function perform(task, ofSuccess) {
|
|
66
|
-
for (var
|
|
67
|
-
args[
|
|
138
|
+
for (var _len6 = arguments.length, args = new Array(_len6 > 2 ? _len6 - 2 : 0), _key6 = 2; _key6 < _len6; _key6++) {
|
|
139
|
+
args[_key6 - 2] = arguments[_key6];
|
|
68
140
|
}
|
|
69
141
|
var bind = function bind(dispatch, fallback) {
|
|
70
142
|
try {
|
|
@@ -85,8 +157,8 @@ var cmd = {
|
|
|
85
157
|
* @param args The parameters of the task.
|
|
86
158
|
*/
|
|
87
159
|
attempt: function attempt(task, ofError) {
|
|
88
|
-
for (var
|
|
89
|
-
args[
|
|
160
|
+
for (var _len7 = arguments.length, args = new Array(_len7 > 2 ? _len7 - 2 : 0), _key7 = 2; _key7 < _len7; _key7++) {
|
|
161
|
+
args[_key7 - 2] = arguments[_key7];
|
|
90
162
|
}
|
|
91
163
|
var bind = function bind(dispatch, fallback) {
|
|
92
164
|
try {
|
|
@@ -113,8 +185,8 @@ var cmd = {
|
|
|
113
185
|
* @param args The parameters of the task.
|
|
114
186
|
*/
|
|
115
187
|
either: function either(task, ofSuccess, ofError) {
|
|
116
|
-
for (var
|
|
117
|
-
args[
|
|
188
|
+
for (var _len8 = arguments.length, args = new Array(_len8 > 3 ? _len8 - 3 : 0), _key8 = 3; _key8 < _len8; _key8++) {
|
|
189
|
+
args[_key8 - 3] = arguments[_key8];
|
|
118
190
|
}
|
|
119
191
|
var bind = function bind(dispatch) {
|
|
120
192
|
task.apply(void 0, args).then(function (result) {
|
|
@@ -132,12 +204,9 @@ var cmd = {
|
|
|
132
204
|
* @param args The parameters of the task.
|
|
133
205
|
*/
|
|
134
206
|
perform: function perform(task, ofSuccess) {
|
|
135
|
-
for (var
|
|
136
|
-
args[
|
|
207
|
+
for (var _len9 = arguments.length, args = new Array(_len9 > 2 ? _len9 - 2 : 0), _key9 = 2; _key9 < _len9; _key9++) {
|
|
208
|
+
args[_key9 - 2] = arguments[_key9];
|
|
137
209
|
}
|
|
138
|
-
var defaultFallbackHandler = function defaultFallbackHandler() {
|
|
139
|
-
// blank
|
|
140
|
-
};
|
|
141
210
|
var bind = function bind(dispatch) {
|
|
142
211
|
var fallback = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : defaultFallbackHandler;
|
|
143
212
|
task.apply(void 0, args).then(function (result) {
|
|
@@ -153,8 +222,8 @@ var cmd = {
|
|
|
153
222
|
* @param args The parameters of the task.
|
|
154
223
|
*/
|
|
155
224
|
attempt: function attempt(task, ofError) {
|
|
156
|
-
for (var
|
|
157
|
-
args[
|
|
225
|
+
for (var _len10 = arguments.length, args = new Array(_len10 > 2 ? _len10 - 2 : 0), _key10 = 2; _key10 < _len10; _key10++) {
|
|
226
|
+
args[_key10 - 2] = arguments[_key10];
|
|
158
227
|
}
|
|
159
228
|
var bind = function bind(dispatch, fallback) {
|
|
160
229
|
task.apply(void 0, args).then(function () {
|
|
@@ -170,4 +239,7 @@ var cmd = {
|
|
|
170
239
|
}
|
|
171
240
|
};
|
|
172
241
|
exports.cmd = cmd;
|
|
173
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["cmd","ofMsg","msg","dispatch","batch","_len","arguments","length","commands","Array","_key","filter","Boolean","flat","ofSub","sub","ofFunc","either","task","ofSuccess","ofError","_len2","args","_key2","bind","result","apply","ex","perform","_len3","_key3","fallback","attempt","_len4","_key4","ofPromise","_len5","_key5","then","_len6","_key6","defaultFallbackHandler","undefined","_len7","_key7","exports"],"sources":["../src/cmd.ts"],"sourcesContent":["import { Cmd, Dispatch, FallbackHandler, Message, Sub } from \"./Types\";\n\nconst cmd = {\n    /**\n     * Creates a command out of a specific message.\n     * @param {TMessage} msg The specific message.\n     */\n    ofMsg<TMessage extends Message> (msg: TMessage): Cmd<TMessage> {\n        return [dispatch => dispatch(msg)];\n    },\n    /**\n     * Aggregates multiple commands.\n     * @param {Cmd<TMessage> []} commands Array of commands.\n     */\n    batch<TMessage extends Message> (...commands: (Cmd<TMessage> | undefined | null) []): Cmd<TMessage> {\n        return (commands.filter(Boolean) as Cmd<TMessage> []).flat();\n    },\n    /**\n     * Command to call the subscriber.\n     * @param {Sub<TMessage>} sub The subscriber function.\n     */\n    ofSub<TMessage extends Message> (sub: Sub<TMessage>): Cmd<TMessage> {\n        return [sub];\n    },\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<TMessage extends Message, 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        /**\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<TMessage extends Message, 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        /**\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<TMessage extends Message, 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    /**\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<TMessage extends Message, 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        /**\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<TMessage extends Message, 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        /**\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<TMessage extends Message, 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\nexport {\n    cmd,\n};"],"mappings":"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"}
|
|
242
|
+
function defaultFallbackHandler() {
|
|
243
|
+
// blank
|
|
244
|
+
}
|
|
245
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["cmd","ofMsg","msg","dispatch","batch","_len","arguments","length","commands","Array","_key","filter","Boolean","flat","ofSub","sub","ofEither","task","ofSuccess","ofError","_len2","args","_key2","bind","taskResult","apply","Promise","resolve","then","result","ex","_len3","_key3","fallback","undefined","defaultFallbackHandler","_len4","_key4","ofFunc","either","_len5","_key5","perform","_len6","_key6","attempt","_len7","_key7","ofPromise","_len8","_key8","_len9","_key9","_len10","_key10","exports"],"sources":["../src/cmd.ts"],"sourcesContent":["import { Cmd, Dispatch, FallbackHandler, Message, Sub } from \"./Types\";\n\nconst cmd = {\n    /**\n     * Creates a command out of a specific message.\n     * @param {TMessage} msg The specific message.\n     */\n    ofMsg<TMessage extends Message> (msg: TMessage): Cmd<TMessage> {\n        return [dispatch => dispatch(msg)];\n    },\n\n    /**\n     * Aggregates multiple commands.\n     * @param {Cmd<TMessage> []} commands Array of commands.\n     */\n    batch<TMessage extends Message> (...commands: (Cmd<TMessage> | undefined | null) []): Cmd<TMessage> {\n        return (commands.filter(Boolean) as Cmd<TMessage> []).flat();\n    },\n\n    /**\n     * Command to call the subscriber.\n     * @param {Sub<TMessage>} sub The subscriber function.\n     */\n    ofSub<TMessage extends Message> (sub: Sub<TMessage>): Cmd<TMessage> {\n        return [sub];\n    },\n\n    /**\n    * Creates a command out of a function and maps the result. This can also be an async function.\n    * @param task The function to call.\n    * @param ofSuccess Creates the message to dispatch when the function runs successfully or, for an async function, the promise is resolved.\n    * @param ofError Creates the message to dispatch when the function throws an error or, for an async function, the promise is rejected.\n    * @param args The parameters of the task.\n    */\n    ofEither<TMessage extends Message, TArgs extends unknown [], TReturn>(task: (...args: TArgs) => TReturn, ofSuccess: (result: Awaited<TReturn>) => TMessage, ofError: (error: Error) => TMessage, ...args: TArgs): Cmd<TMessage> {\n        const bind = (dispatch: Dispatch<TMessage>): void => {\n            try {\n                const taskResult = task(...args);\n\n                Promise.resolve(taskResult)\n                    .then(result => dispatch(ofSuccess(result)))\n                    .catch((ex: Error) => dispatch(ofError(ex)));\n            } catch (ex: unknown) {\n                dispatch(ofError(ex as Error));\n            }\n        };\n\n        return [bind];\n    },\n\n    /**\n    * Creates a command out of a function and ignores the error case. This can also be an async function.\n    * @param task The async function to call.\n    * @param ofSuccess Creates the message to dispatch when the function runs successfully or, for an async function, the promise is resolved.\n    * @param args The parameters of the task.\n    */\n    ofSuccess<TMessage extends Message, TArgs extends unknown [], TReturn>(task: (...args: TArgs) => TReturn, ofSuccess: (result: Awaited<TReturn>) => TMessage, ...args: TArgs): Cmd<TMessage> {\n        const bind = (dispatch: Dispatch<TMessage>, fallback: FallbackHandler = defaultFallbackHandler): void => {\n            try {\n                const taskResult = task(...args);\n\n                Promise.resolve(taskResult)\n                    .then(result => dispatch(ofSuccess(result)))\n                    .catch(fallback);\n            } catch (ex: unknown) {\n                fallback(ex as Error);\n            }\n        };\n\n        return [bind];\n    },\n\n    /**\n    * Creates a command out of a function and ignores the success case. This can also be an async function.\n    * @param task The function to call.\n    * @param ofError Creates the message to dispatch when the function runs successfully or, for an async function, the promise is rejected.\n    * @param args The parameters of the task.\n    */\n    ofError<TMessage extends Message, 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                const taskResult = task(...args);\n\n                Promise.resolve(taskResult)\n                    .then(() => fallback?.())\n                    .catch((ex: Error) => dispatch(ofError(ex)));\n            } catch (ex: unknown) {\n                dispatch(ofError(ex as Error));\n            }\n        };\n\n        return [bind];\n    },\n\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<TMessage extends Message, 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\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<TMessage extends Message, 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\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<TMessage extends Message, 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\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<TMessage extends Message, 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)\n                    .then(result => dispatch(ofSuccess(result)))\n                    .catch((ex: Error) => dispatch(ofError(ex)));\n            };\n\n            return [bind];\n        },\n\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<TMessage extends Message, TArgs extends unknown [], TReturn>(task: (...args: TArgs) => Promise<TReturn>, ofSuccess: (result: TReturn) => TMessage, ...args: TArgs): Cmd<TMessage> {\n            const bind = (dispatch: Dispatch<TMessage>, fallback: FallbackHandler = defaultFallbackHandler): void => {\n                task(...args)\n                    .then(result => dispatch(ofSuccess(result)))\n                    .catch(fallback);\n            };\n\n            return [bind];\n        },\n\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<TMessage extends Message, 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\nfunction defaultFallbackHandler (): void {\n    // blank\n}\n\nexport {\n    cmd,\n};"],"mappings":"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"}
|