react-elmish 6.5.0-beta.1 → 6.5.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +12 -9
- package/dist/cmd.d.ts +3 -3
- package/dist/cmd.js +10 -13
- 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
|
@@ -22,21 +22,21 @@ declare const cmd: {
|
|
|
22
22
|
* @param ofError Creates the message to dispatch when the function throws an error or, for an async function, the promise is rejected.
|
|
23
23
|
* @param args The parameters of the task.
|
|
24
24
|
*/
|
|
25
|
-
|
|
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
26
|
/**
|
|
27
27
|
* Creates a command out of a function and ignores the error case. This can also be an async function.
|
|
28
28
|
* @param task The async function to call.
|
|
29
29
|
* @param ofSuccess Creates the message to dispatch when the function runs successfully or, for an async function, the promise is resolved.
|
|
30
30
|
* @param args The parameters of the task.
|
|
31
31
|
*/
|
|
32
|
-
|
|
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
33
|
/**
|
|
34
34
|
* Creates a command out of a function and ignores the success case. This can also be an async function.
|
|
35
35
|
* @param task The function to call.
|
|
36
36
|
* @param ofError Creates the message to dispatch when the function runs successfully or, for an async function, the promise is rejected.
|
|
37
37
|
* @param args The parameters of the task.
|
|
38
38
|
*/
|
|
39
|
-
|
|
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>;
|
|
40
40
|
/**
|
|
41
41
|
* Provides functionalities to create commands from simple functions.
|
|
42
42
|
*/
|
package/dist/cmd.js
CHANGED
|
@@ -38,7 +38,7 @@ var cmd = {
|
|
|
38
38
|
* @param ofError Creates the message to dispatch when the function throws an error or, for an async function, the promise is rejected.
|
|
39
39
|
* @param args The parameters of the task.
|
|
40
40
|
*/
|
|
41
|
-
|
|
41
|
+
ofEither: function ofEither(task, ofSuccess, ofError) {
|
|
42
42
|
for (var _len2 = arguments.length, args = new Array(_len2 > 3 ? _len2 - 3 : 0), _key2 = 3; _key2 < _len2; _key2++) {
|
|
43
43
|
args[_key2 - 3] = arguments[_key2];
|
|
44
44
|
}
|
|
@@ -62,19 +62,16 @@ var cmd = {
|
|
|
62
62
|
* @param ofSuccess Creates the message to dispatch when the function runs successfully or, for an async function, the promise is resolved.
|
|
63
63
|
* @param args The parameters of the task.
|
|
64
64
|
*/
|
|
65
|
-
|
|
65
|
+
ofSuccess: function ofSuccess(task, _ofSuccess) {
|
|
66
66
|
for (var _len3 = arguments.length, args = new Array(_len3 > 2 ? _len3 - 2 : 0), _key3 = 2; _key3 < _len3; _key3++) {
|
|
67
67
|
args[_key3 - 2] = arguments[_key3];
|
|
68
68
|
}
|
|
69
|
-
var defaultFallbackHandler = function defaultFallbackHandler() {
|
|
70
|
-
// blank
|
|
71
|
-
};
|
|
72
69
|
var bind = function bind(dispatch) {
|
|
73
70
|
var fallback = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : defaultFallbackHandler;
|
|
74
71
|
try {
|
|
75
72
|
var taskResult = task.apply(void 0, args);
|
|
76
73
|
Promise.resolve(taskResult).then(function (result) {
|
|
77
|
-
return dispatch(
|
|
74
|
+
return dispatch(_ofSuccess(result));
|
|
78
75
|
})["catch"](fallback);
|
|
79
76
|
} catch (ex) {
|
|
80
77
|
fallback(ex);
|
|
@@ -88,7 +85,7 @@ var cmd = {
|
|
|
88
85
|
* @param ofError Creates the message to dispatch when the function runs successfully or, for an async function, the promise is rejected.
|
|
89
86
|
* @param args The parameters of the task.
|
|
90
87
|
*/
|
|
91
|
-
|
|
88
|
+
ofError: function ofError(task, _ofError) {
|
|
92
89
|
for (var _len4 = arguments.length, args = new Array(_len4 > 2 ? _len4 - 2 : 0), _key4 = 2; _key4 < _len4; _key4++) {
|
|
93
90
|
args[_key4 - 2] = arguments[_key4];
|
|
94
91
|
}
|
|
@@ -98,10 +95,10 @@ var cmd = {
|
|
|
98
95
|
Promise.resolve(taskResult).then(function () {
|
|
99
96
|
return fallback === null || fallback === void 0 ? void 0 : fallback();
|
|
100
97
|
})["catch"](function (ex) {
|
|
101
|
-
return dispatch(
|
|
98
|
+
return dispatch(_ofError(ex));
|
|
102
99
|
});
|
|
103
100
|
} catch (ex) {
|
|
104
|
-
dispatch(
|
|
101
|
+
dispatch(_ofError(ex));
|
|
105
102
|
}
|
|
106
103
|
};
|
|
107
104
|
return [bind];
|
|
@@ -210,9 +207,6 @@ var cmd = {
|
|
|
210
207
|
for (var _len9 = arguments.length, args = new Array(_len9 > 2 ? _len9 - 2 : 0), _key9 = 2; _key9 < _len9; _key9++) {
|
|
211
208
|
args[_key9 - 2] = arguments[_key9];
|
|
212
209
|
}
|
|
213
|
-
var defaultFallbackHandler = function defaultFallbackHandler() {
|
|
214
|
-
// blank
|
|
215
|
-
};
|
|
216
210
|
var bind = function bind(dispatch) {
|
|
217
211
|
var fallback = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : defaultFallbackHandler;
|
|
218
212
|
task.apply(void 0, args).then(function (result) {
|
|
@@ -245,4 +239,7 @@ var cmd = {
|
|
|
245
239
|
}
|
|
246
240
|
};
|
|
247
241
|
exports.cmd = cmd;
|
|
248
|
-
//# 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","either","task","ofSuccess","ofError","_len2","args","_key2","bind","taskResult","apply","Promise","resolve","then","result","ex","perform","_len3","_key3","defaultFallbackHandler","fallback","undefined","attempt","_len4","_key4","ofFunc","_len5","_key5","_len6","_key6","_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     * 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    /**\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    either<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    * 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    perform<TMessage extends Message, TArgs extends unknown [], TReturn>(task: (...args: TArgs) => TReturn, ofSuccess: (result: Awaited<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            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    * 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    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                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        * 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":";;;;;;AAEA,IAAMA,GAAG,GAAG;EACR;AACJ;AACA;AACA;EACIC,KAAK,WAAAA,MAA4BC,GAAa,EAAiB;IAC3D,OAAO,CAAC,UAAAC,QAAQ;MAAA,OAAIA,QAAQ,CAACD,GAAG,CAAC;IAAA,EAAC;EACtC,CAAC;EACD;AACJ;AACA;AACA;EACIE,KAAK,WAAAA,MAAA,EAA+F;IAAA,SAAAC,IAAA,GAAAC,SAAA,CAAAC,MAAA,EAAhEC,QAAQ,OAAAC,KAAA,CAAAJ,IAAA,GAAAK,IAAA,MAAAA,IAAA,GAAAL,IAAA,EAAAK,IAAA;MAARF,QAAQ,CAAAE,IAAA,IAAAJ,SAAA,CAAAI,IAAA;IAAA;IACxC,OAAQF,QAAQ,CAACG,MAAM,CAACC,OAAO,CAAC,CAAsBC,IAAI,EAAE;EAChE,CAAC;EACD;AACJ;AACA;AACA;EACIC,KAAK,WAAAA,MAA4BC,GAAkB,EAAiB;IAChE,OAAO,CAACA,GAAG,CAAC;EAChB,CAAC;EAED;AACJ;AACA;AACA;AACA;AACA;AACA;EACIC,MAAM,WAAAA,OAA8DC,IAAiC,EAAEC,SAAiD,EAAEC,OAAmC,EAAiC;IAAA,SAAAC,KAAA,GAAAd,SAAA,CAAAC,MAAA,EAA5Bc,IAAI,OAAAZ,KAAA,CAAAW,KAAA,OAAAA,KAAA,WAAAE,KAAA,MAAAA,KAAA,GAAAF,KAAA,EAAAE,KAAA;MAAJD,IAAI,CAAAC,KAAA,QAAAhB,SAAA,CAAAgB,KAAA;IAAA;IAClM,IAAMC,IAAI,GAAG,SAAPA,IAAIA,CAAIpB,QAA4B,EAAW;MACjD,IAAI;QACA,IAAMqB,UAAU,GAAGP,IAAI,CAAAQ,KAAA,SAAIJ,IAAI,CAAC;QAEhCK,OAAO,CAACC,OAAO,CAACH,UAAU,CAAC,CACtBI,IAAI,CAAC,UAAAC,MAAM;UAAA,OAAI1B,QAAQ,CAACe,SAAS,CAACW,MAAM,CAAC,CAAC;QAAA,EAAC,SACtC,CAAC,UAACC,EAAS;UAAA,OAAK3B,QAAQ,CAACgB,OAAO,CAACW,EAAE,CAAC,CAAC;QAAA,EAAC;MACpD,CAAC,CAAC,OAAOA,EAAW,EAAE;QAClB3B,QAAQ,CAACgB,OAAO,CAACW,EAAE,CAAU,CAAC;MAClC;IACJ,CAAC;IAED,OAAO,CAACP,IAAI,CAAC;EACjB,CAAC;EACD;AACJ;AACA;AACA;AACA;AACA;EACIQ,OAAO,WAAAA,QAA8Dd,IAAiC,EAAEC,SAAiD,EAAiC;IAAA,SAAAc,KAAA,GAAA1B,SAAA,CAAAC,MAAA,EAA5Bc,IAAI,OAAAZ,KAAA,CAAAuB,KAAA,OAAAA,KAAA,WAAAC,KAAA,MAAAA,KAAA,GAAAD,KAAA,EAAAC,KAAA;MAAJZ,IAAI,CAAAY,KAAA,QAAA3B,SAAA,CAAA2B,KAAA;IAAA;IAC9J,IAAMC,sBAAsB,GAAG,SAAzBA,sBAAsBA,CAAA,EAAe;MACvC;IAAA,CACH;IAED,IAAMX,IAAI,GAAG,SAAPA,IAAIA,CAAIpB,QAA4B,EAA+D;MAAA,IAA7DgC,QAAyB,GAAA7B,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAA8B,SAAA,GAAA9B,SAAA,MAAG4B,sBAAsB;MAC1F,IAAI;QACA,IAAMV,UAAU,GAAGP,IAAI,CAAAQ,KAAA,SAAIJ,IAAI,CAAC;QAEhCK,OAAO,CAACC,OAAO,CAACH,UAAU,CAAC,CACtBI,IAAI,CAAC,UAAAC,MAAM;UAAA,OAAI1B,QAAQ,CAACe,SAAS,CAACW,MAAM,CAAC,CAAC;QAAA,EAAC,SACtC,CAACM,QAAQ,CAAC;MACxB,CAAC,CAAC,OAAOL,EAAW,EAAE;QAClBK,QAAQ,CAACL,EAAE,CAAU;MACzB;IACJ,CAAC;IAED,OAAO,CAACP,IAAI,CAAC;EACjB,CAAC;EACD;AACJ;AACA;AACA;AACA;AACA;EACIc,OAAO,WAAAA,QAA8DpB,IAAiC,EAAEE,OAAmC,EAAiC;IAAA,SAAAmB,KAAA,GAAAhC,SAAA,CAAAC,MAAA,EAA5Bc,IAAI,OAAAZ,KAAA,CAAA6B,KAAA,OAAAA,KAAA,WAAAC,KAAA,MAAAA,KAAA,GAAAD,KAAA,EAAAC,KAAA;MAAJlB,IAAI,CAAAkB,KAAA,QAAAjC,SAAA,CAAAiC,KAAA;IAAA;IAChJ,IAAMhB,IAAI,GAAG,SAAPA,IAAIA,CAAIpB,QAA4B,EAAEgC,QAA0B,EAAW;MAC7E,IAAI;QACA,IAAMX,UAAU,GAAGP,IAAI,CAAAQ,KAAA,SAAIJ,IAAI,CAAC;QAEhCK,OAAO,CAACC,OAAO,CAACH,UAAU,CAAC,CACtBI,IAAI,CAAC;UAAA,OAAMO,QAAQ,aAARA,QAAQ,uBAARA,QAAQ,EAAI;QAAA,EAAC,SACnB,CAAC,UAACL,EAAS;UAAA,OAAK3B,QAAQ,CAACgB,OAAO,CAACW,EAAE,CAAC,CAAC;QAAA,EAAC;MACpD,CAAC,CAAC,OAAOA,EAAW,EAAE;QAClB3B,QAAQ,CAACgB,OAAO,CAACW,EAAE,CAAU,CAAC;MAClC;IACJ,CAAC;IAED,OAAO,CAACP,IAAI,CAAC;EACjB,CAAC;EAED;AACJ;AACA;EACIiB,MAAM,EAAE;IACJ;AACR;AACA;AACA;AACA;AACA;AACA;IACQxB,MAAM,WAAAA,OAA8DC,IAAiC,EAAEC,SAAwC,EAAEC,OAAmC,EAAiC;MAAA,SAAAsB,KAAA,GAAAnC,SAAA,CAAAC,MAAA,EAA5Bc,IAAI,OAAAZ,KAAA,CAAAgC,KAAA,OAAAA,KAAA,WAAAC,KAAA,MAAAA,KAAA,GAAAD,KAAA,EAAAC,KAAA;QAAJrB,IAAI,CAAAqB,KAAA,QAAApC,SAAA,CAAAoC,KAAA;MAAA;MACzL,IAAMnB,IAAI,GAAG,SAAPA,IAAIA,CAAIpB,QAA4B,EAAW;QACjD,IAAI;UACA,IAAM0B,OAAM,GAAGZ,IAAI,CAAAQ,KAAA,SAAIJ,IAAI,CAAC;UAE5BlB,QAAQ,CAACe,SAAS,CAACW,OAAM,CAAC,CAAC;QAC/B,CAAC,CAAC,OAAOC,EAAW,EAAE;UAClB3B,QAAQ,CAACgB,OAAO,CAACW,EAAE,CAAU,CAAC;QAClC;MACJ,CAAC;MAED,OAAO,CAACP,IAAI,CAAC;IACjB,CAAC;IACD;AACR;AACA;AACA;AACA;AACA;IACQQ,OAAO,WAAAA,QAA8Dd,IAAiC,EAAEC,SAAwC,EAAiC;MAAA,SAAAyB,KAAA,GAAArC,SAAA,CAAAC,MAAA,EAA5Bc,IAAI,OAAAZ,KAAA,CAAAkC,KAAA,OAAAA,KAAA,WAAAC,KAAA,MAAAA,KAAA,GAAAD,KAAA,EAAAC,KAAA;QAAJvB,IAAI,CAAAuB,KAAA,QAAAtC,SAAA,CAAAsC,KAAA;MAAA;MACrJ,IAAMrB,IAAI,GAAG,SAAPA,IAAIA,CAAIpB,QAA4B,EAAEgC,QAA0B,EAAW;QAC7E,IAAI;UACA,IAAMN,QAAM,GAAGZ,IAAI,CAAAQ,KAAA,SAAIJ,IAAI,CAAC;UAE5BlB,QAAQ,CAACe,SAAS,CAACW,QAAM,CAAC,CAAC;QAC/B,CAAC,CAAC,OAAOC,EAAW,EAAE;UAClB,IAAIK,QAAQ,EAAE;YACVA,QAAQ,CAACL,EAAE,CAAU;UACzB;QACJ;MACJ,CAAC;MAED,OAAO,CAACP,IAAI,CAAC;IACjB,CAAC;IACD;AACR;AACA;AACA;AACA;AACA;IACQc,OAAO,WAAAA,QAA8DpB,IAAiC,EAAEE,OAAmC,EAAiC;MAAA,SAAA0B,KAAA,GAAAvC,SAAA,CAAAC,MAAA,EAA5Bc,IAAI,OAAAZ,KAAA,CAAAoC,KAAA,OAAAA,KAAA,WAAAC,KAAA,MAAAA,KAAA,GAAAD,KAAA,EAAAC,KAAA;QAAJzB,IAAI,CAAAyB,KAAA,QAAAxC,SAAA,CAAAwC,KAAA;MAAA;MAChJ,IAAMvB,IAAI,GAAG,SAAPA,IAAIA,CAAIpB,QAA4B,EAAEgC,QAA0B,EAAW;QAC7E,IAAI;UACAlB,IAAI,CAAAQ,KAAA,SAAIJ,IAAI,CAAC;UAEb,IAAIc,QAAQ,EAAE;YACVA,QAAQ,EAAE;UACd;QACJ,CAAC,CAAC,OAAOL,EAAW,EAAE;UAClB3B,QAAQ,CAACgB,OAAO,CAACW,EAAE,CAAU,CAAC;QAClC;MACJ,CAAC;MAED,OAAO,CAACP,IAAI,CAAC;IACjB;EACJ,CAAC;EACD;AACJ;AACA;EACIwB,SAAS,EAAE;IACP;AACR;AACA;AACA;AACA;AACA;AACA;IACQ/B,MAAM,WAAAA,OAA8DC,IAA0C,EAAEC,SAAwC,EAAEC,OAAmC,EAAiC;MAAA,SAAA6B,KAAA,GAAA1C,SAAA,CAAAC,MAAA,EAA5Bc,IAAI,OAAAZ,KAAA,CAAAuC,KAAA,OAAAA,KAAA,WAAAC,KAAA,MAAAA,KAAA,GAAAD,KAAA,EAAAC,KAAA;QAAJ5B,IAAI,CAAA4B,KAAA,QAAA3C,SAAA,CAAA2C,KAAA;MAAA;MAClM,IAAM1B,IAAI,GAAG,SAAPA,IAAIA,CAAIpB,QAA4B,EAAW;QACjDc,IAAI,CAAAQ,KAAA,SAAIJ,IAAI,CAAC,CAACO,IAAI,CAAC,UAAAC,MAAM;UAAA,OAAI1B,QAAQ,CAACe,SAAS,CAACW,MAAM,CAAC,CAAC;QAAA,EAAC,SAC/C,CAAC,UAACC,EAAS;UAAA,OAAK3B,QAAQ,CAACgB,OAAO,CAACW,EAAE,CAAC,CAAC;QAAA,EAAC;MACpD,CAAC;MAED,OAAO,CAACP,IAAI,CAAC;IACjB,CAAC;IACD;AACR;AACA;AACA;AACA;AACA;IACQQ,OAAO,WAAAA,QAA8Dd,IAA0C,EAAEC,SAAwC,EAAiC;MAAA,SAAAgC,KAAA,GAAA5C,SAAA,CAAAC,MAAA,EAA5Bc,IAAI,OAAAZ,KAAA,CAAAyC,KAAA,OAAAA,KAAA,WAAAC,KAAA,MAAAA,KAAA,GAAAD,KAAA,EAAAC,KAAA;QAAJ9B,IAAI,CAAA8B,KAAA,QAAA7C,SAAA,CAAA6C,KAAA;MAAA;MAC9J,IAAMjB,sBAAsB,GAAG,SAAzBA,sBAAsBA,CAAA,EAAe;QACvC;MAAA,CACH;MAED,IAAMX,IAAI,GAAG,SAAPA,IAAIA,CAAIpB,QAA4B,EAA+D;QAAA,IAA7DgC,QAAyB,GAAA7B,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAA8B,SAAA,GAAA9B,SAAA,MAAG4B,sBAAsB;QAC1FjB,IAAI,CAAAQ,KAAA,SAAIJ,IAAI,CAAC,CAACO,IAAI,CAAC,UAAAC,MAAM;UAAA,OAAI1B,QAAQ,CAACe,SAAS,CAACW,MAAM,CAAC,CAAC;QAAA,EAAC,SAC/C,CAACM,QAAQ,CAAC;MACxB,CAAC;MAED,OAAO,CAACZ,IAAI,CAAC;IACjB,CAAC;IACD;AACR;AACA;AACA;AACA;AACA;IACQc,OAAO,WAAAA,QAA8DpB,IAA0C,EAAEE,OAAmC,EAAiC;MAAA,SAAAiC,MAAA,GAAA9C,SAAA,CAAAC,MAAA,EAA5Bc,IAAI,OAAAZ,KAAA,CAAA2C,MAAA,OAAAA,MAAA,WAAAC,MAAA,MAAAA,MAAA,GAAAD,MAAA,EAAAC,MAAA;QAAJhC,IAAI,CAAAgC,MAAA,QAAA/C,SAAA,CAAA+C,MAAA;MAAA;MACzJ,IAAM9B,IAAI,GAAG,SAAPA,IAAIA,CAAIpB,QAA4B,EAAEgC,QAA0B,EAAW;QAC7ElB,IAAI,CAAAQ,KAAA,SAAIJ,IAAI,CAAC,CAACO,IAAI,CAAC,YAAM;UACrB,IAAIO,QAAQ,EAAE;YACVA,QAAQ,EAAE;UACd;QACJ,CAAC,CAAC,SACQ,CAAC,UAACL,EAAS;UAAA,OAAK3B,QAAQ,CAACgB,OAAO,CAACW,EAAE,CAAC,CAAC;QAAA,EAAC;MACpD,CAAC;MAED,OAAO,CAACP,IAAI,CAAC;IACjB;EACJ;AACJ,CAAC;AAAC+B,OAAA,CAAAtD,GAAA,GAAAA,GAAA"}
|
|
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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"}
|