react-elmish 7.0.1 → 7.0.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/dist/cmd.d.ts CHANGED
@@ -16,52 +16,52 @@ declare const cmd: {
16
16
  */
17
17
  ofSub<TMessage_2 extends Message>(sub: Sub<TMessage_2>): Cmd<TMessage_2>;
18
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
- */
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
25
  ofEither<TSuccessMessage extends Message, TErrorMessage extends Message, TArgs extends unknown[], TReturn>(task: (...args: TArgs) => TReturn, ofSuccess: (result: Awaited<TReturn>) => TSuccessMessage, ofError: (error: Error) => TErrorMessage, ...args: TArgs): Cmd<TSuccessMessage | TErrorMessage>;
26
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
- */
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
32
  ofSuccess<TSuccessMessage_1 extends Message, TArgs_1 extends unknown[], TReturn_1>(task: (...args: TArgs_1) => TReturn_1, ofSuccess: (result: Awaited<TReturn_1>) => TSuccessMessage_1, ...args: TArgs_1): Cmd<TSuccessMessage_1>;
33
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
- */
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
39
  ofError<TErrorMessage_1 extends Message, TArgs_2 extends unknown[], TReturn_2>(task: (...args: TArgs_2) => TReturn_2, ofError: (error: Error) => TErrorMessage_1, ...args: TArgs_2): Cmd<TErrorMessage_1>;
40
40
  /**
41
41
  * Provides functionalities to create commands from simple functions.
42
42
  */
43
43
  ofFunc: {
44
44
  /**
45
- * Creates a command out of a simple function and maps the result.
46
- * @param task The function to call.
47
- * @param ofSuccess Creates the message to dispatch after a successful call of the task.
48
- * @param ofError Creates the message to dispatch when an error occurred.
49
- * @param args The parameters of the task.
50
- */
45
+ * Creates a command out of a simple function and maps the result.
46
+ * @param task The function to call.
47
+ * @param ofSuccess Creates the message to dispatch after a successful call of the task.
48
+ * @param ofError Creates the message to dispatch when an error occurred.
49
+ * @param args The parameters of the task.
50
+ */
51
51
  either<TSuccessMessage_2 extends Message, TErrorMessage_2 extends Message, TArgs_3 extends unknown[], TReturn_3>(task: (...args: TArgs_3) => TReturn_3, ofSuccess: (result: TReturn_3) => TSuccessMessage_2, ofError: (error: Error) => TErrorMessage_2, ...args: TArgs_3): Cmd<TSuccessMessage_2 | TErrorMessage_2>;
52
52
  /**
53
- * Creates a command out of a simple function and ignores the error case.
54
- * @param task The function to call.
55
- * @param ofSuccess Creates the message to dispatch after a successful call of the task.
56
- * @param args The parameters of the task.
57
- */
53
+ * Creates a command out of a simple function and ignores the error case.
54
+ * @param task The function to call.
55
+ * @param ofSuccess Creates the message to dispatch after a successful call of the task.
56
+ * @param args The parameters of the task.
57
+ */
58
58
  perform<TSuccessMessage_3 extends Message, TArgs_4 extends unknown[], TReturn_4>(task: (...args: TArgs_4) => TReturn_4, ofSuccess: (result: TReturn_4) => TSuccessMessage_3, ...args: TArgs_4): Cmd<TSuccessMessage_3>;
59
59
  /**
60
- * Creates a command out of a simple function and ignores the success case.
61
- * @param task The function to call.
62
- * @param ofError Creates the message to dispatch when an error occurred.
63
- * @param args The parameters of the task.
64
- */
60
+ * Creates a command out of a simple function and ignores the success case.
61
+ * @param task The function to call.
62
+ * @param ofError Creates the message to dispatch when an error occurred.
63
+ * @param args The parameters of the task.
64
+ */
65
65
  attempt<TErrorMessage_3 extends Message, TArgs_5 extends unknown[], TReturn_5>(task: (...args: TArgs_5) => TReturn_5, ofError: (error: Error) => TErrorMessage_3, ...args: TArgs_5): Cmd<TErrorMessage_3>;
66
66
  };
67
67
  /**
@@ -69,27 +69,27 @@ declare const cmd: {
69
69
  */
70
70
  ofPromise: {
71
71
  /**
72
- * Creates a command out of an async function and maps the result.
73
- * @param task The async function to call.
74
- * @param ofSuccess Creates the message to dispatch when the promise is resolved.
75
- * @param ofError Creates the message to dispatch when the promise is rejected.
76
- * @param args The parameters of the task.
77
- */
72
+ * Creates a command out of an async function and maps the result.
73
+ * @param task The async function to call.
74
+ * @param ofSuccess Creates the message to dispatch when the promise is resolved.
75
+ * @param ofError Creates the message to dispatch when the promise is rejected.
76
+ * @param args The parameters of the task.
77
+ */
78
78
  either<TSuccessMessage_4 extends Message, TErrorMessage_4 extends Message, TArgs_6 extends unknown[], TReturn_6>(task: (...args: TArgs_6) => Promise<TReturn_6>, ofSuccess: (result: TReturn_6) => TSuccessMessage_4, ofError: (error: Error) => TErrorMessage_4, ...args: TArgs_6): Cmd<TSuccessMessage_4 | TErrorMessage_4>;
79
79
  /**
80
- * Creates a command out of an async function and ignores the error case.
81
- * @param task The async function to call.
82
- * @param ofSuccess Creates the message to dispatch when the promise is resolved.
83
- * @param args The parameters of the task.
84
- */
80
+ * Creates a command out of an async function and ignores the error case.
81
+ * @param task The async function to call.
82
+ * @param ofSuccess Creates the message to dispatch when the promise is resolved.
83
+ * @param args The parameters of the task.
84
+ */
85
85
  perform<TSuccessMessage_5 extends Message, TArgs_7 extends unknown[], TReturn_7>(task: (...args: TArgs_7) => Promise<TReturn_7>, ofSuccess: (result: TReturn_7) => TSuccessMessage_5, ...args: TArgs_7): Cmd<TSuccessMessage_5>;
86
86
  /**
87
- * Creates a command out of an async function and ignores the success case.
88
- * @param task The async function to call.
89
- * @param ofError Creates the message to dispatch when the promise is rejected.
90
- * @param args The parameters of the task.
91
- */
87
+ * Creates a command out of an async function and ignores the success case.
88
+ * @param task The async function to call.
89
+ * @param ofError Creates the message to dispatch when the promise is rejected.
90
+ * @param args The parameters of the task.
91
+ */
92
92
  attempt<TErrorMessage_5 extends Message, TArgs_8 extends unknown[], TReturn_8>(task: (...args: TArgs_8) => Promise<TReturn_8>, ofError: (error: Error) => TErrorMessage_5, ...args: TArgs_8): Cmd<TErrorMessage_5>;
93
93
  };
94
94
  };
95
- export { cmd, };
95
+ export { cmd };
package/dist/cmd.js CHANGED
@@ -32,12 +32,12 @@ var cmd = {
32
32
  return [sub];
33
33
  },
34
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
- */
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
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];
@@ -57,11 +57,11 @@ var cmd = {
57
57
  return [bind];
58
58
  },
59
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
- */
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
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];
@@ -80,11 +80,11 @@ var cmd = {
80
80
  return [bind];
81
81
  },
82
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
- */
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
88
  ofError: function ofError(task, _ofError) {
89
89
  for (var _len4 = arguments.length, args = new Array(_len4 > 2 ? _len4 - 2 : 0), _key4 = 2; _key4 < _len4; _key4++) {
90
90
  args[_key4 - 2] = arguments[_key4];
@@ -108,12 +108,12 @@ var cmd = {
108
108
  */
109
109
  ofFunc: {
110
110
  /**
111
- * Creates a command out of a simple function and maps the result.
112
- * @param task The function to call.
113
- * @param ofSuccess Creates the message to dispatch after a successful call of the task.
114
- * @param ofError Creates the message to dispatch when an error occurred.
115
- * @param args The parameters of the task.
116
- */
111
+ * Creates a command out of a simple function and maps the result.
112
+ * @param task The function to call.
113
+ * @param ofSuccess Creates the message to dispatch after a successful call of the task.
114
+ * @param ofError Creates the message to dispatch when an error occurred.
115
+ * @param args The parameters of the task.
116
+ */
117
117
  either: function either(task, ofSuccess, ofError) {
118
118
  for (var _len5 = arguments.length, args = new Array(_len5 > 3 ? _len5 - 3 : 0), _key5 = 3; _key5 < _len5; _key5++) {
119
119
  args[_key5 - 3] = arguments[_key5];
@@ -129,11 +129,11 @@ var cmd = {
129
129
  return [bind];
130
130
  },
131
131
  /**
132
- * Creates a command out of a simple function and ignores the error case.
133
- * @param task The function to call.
134
- * @param ofSuccess Creates the message to dispatch after a successful call of the task.
135
- * @param args The parameters of the task.
136
- */
132
+ * Creates a command out of a simple function and ignores the error case.
133
+ * @param task The function to call.
134
+ * @param ofSuccess Creates the message to dispatch after a successful call of the task.
135
+ * @param args The parameters of the task.
136
+ */
137
137
  perform: function perform(task, ofSuccess) {
138
138
  for (var _len6 = arguments.length, args = new Array(_len6 > 2 ? _len6 - 2 : 0), _key6 = 2; _key6 < _len6; _key6++) {
139
139
  args[_key6 - 2] = arguments[_key6];
@@ -151,11 +151,11 @@ var cmd = {
151
151
  return [bind];
152
152
  },
153
153
  /**
154
- * Creates a command out of a simple function and ignores the success case.
155
- * @param task The function to call.
156
- * @param ofError Creates the message to dispatch when an error occurred.
157
- * @param args The parameters of the task.
158
- */
154
+ * Creates a command out of a simple function and ignores the success case.
155
+ * @param task The function to call.
156
+ * @param ofError Creates the message to dispatch when an error occurred.
157
+ * @param args The parameters of the task.
158
+ */
159
159
  attempt: function attempt(task, ofError) {
160
160
  for (var _len7 = arguments.length, args = new Array(_len7 > 2 ? _len7 - 2 : 0), _key7 = 2; _key7 < _len7; _key7++) {
161
161
  args[_key7 - 2] = arguments[_key7];
@@ -178,12 +178,12 @@ var cmd = {
178
178
  */
179
179
  ofPromise: {
180
180
  /**
181
- * Creates a command out of an async function and maps the result.
182
- * @param task The async function to call.
183
- * @param ofSuccess Creates the message to dispatch when the promise is resolved.
184
- * @param ofError Creates the message to dispatch when the promise is rejected.
185
- * @param args The parameters of the task.
186
- */
181
+ * Creates a command out of an async function and maps the result.
182
+ * @param task The async function to call.
183
+ * @param ofSuccess Creates the message to dispatch when the promise is resolved.
184
+ * @param ofError Creates the message to dispatch when the promise is rejected.
185
+ * @param args The parameters of the task.
186
+ */
187
187
  either: function either(task, ofSuccess, ofError) {
188
188
  for (var _len8 = arguments.length, args = new Array(_len8 > 3 ? _len8 - 3 : 0), _key8 = 3; _key8 < _len8; _key8++) {
189
189
  args[_key8 - 3] = arguments[_key8];
@@ -198,11 +198,11 @@ var cmd = {
198
198
  return [bind];
199
199
  },
200
200
  /**
201
- * Creates a command out of an async function and ignores the error case.
202
- * @param task The async function to call.
203
- * @param ofSuccess Creates the message to dispatch when the promise is resolved.
204
- * @param args The parameters of the task.
205
- */
201
+ * Creates a command out of an async function and ignores the error case.
202
+ * @param task The async function to call.
203
+ * @param ofSuccess Creates the message to dispatch when the promise is resolved.
204
+ * @param args The parameters of the task.
205
+ */
206
206
  perform: function perform(task, ofSuccess) {
207
207
  for (var _len9 = arguments.length, args = new Array(_len9 > 2 ? _len9 - 2 : 0), _key9 = 2; _key9 < _len9; _key9++) {
208
208
  args[_key9 - 2] = arguments[_key9];
@@ -216,11 +216,11 @@ var cmd = {
216
216
  return [bind];
217
217
  },
218
218
  /**
219
- * Creates a command out of an async function and ignores the success case.
220
- * @param task The async function to call.
221
- * @param ofError Creates the message to dispatch when the promise is rejected.
222
- * @param args The parameters of the task.
223
- */
219
+ * Creates a command out of an async function and ignores the success case.
220
+ * @param task The async function to call.
221
+ * @param ofError Creates the message to dispatch when the promise is rejected.
222
+ * @param args The parameters of the task.
223
+ */
224
224
  attempt: function attempt(task, ofError) {
225
225
  for (var _len10 = arguments.length, args = new Array(_len10 > 2 ? _len10 - 2 : 0), _key10 = 2; _key10 < _len10; _key10++) {
226
226
  args[_key10 - 2] = arguments[_key10];
@@ -242,4 +242,4 @@ exports.cmd = cmd;
242
242
  function defaultFallbackHandler() {
243
243
  // blank
244
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<TSuccessMessage extends Message, TErrorMessage extends Message, TArgs extends unknown [], TReturn>(task: (...args: TArgs) => TReturn, ofSuccess: (result: Awaited<TReturn>) => TSuccessMessage, ofError: (error: Error) => TErrorMessage, ...args: TArgs): Cmd<TSuccessMessage | TErrorMessage> {\n        const bind = (dispatch: Dispatch<TSuccessMessage | TErrorMessage>): 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<TSuccessMessage extends Message, TArgs extends unknown [], TReturn>(task: (...args: TArgs) => TReturn, ofSuccess: (result: Awaited<TReturn>) => TSuccessMessage, ...args: TArgs): Cmd<TSuccessMessage> {\n        const bind = (dispatch: Dispatch<TSuccessMessage>, 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<TErrorMessage extends Message, TArgs extends unknown [], TReturn>(task: (...args: TArgs) => TReturn, ofError: (error: Error) => TErrorMessage, ...args: TArgs): Cmd<TErrorMessage> {\n        const bind = (dispatch: Dispatch<TErrorMessage>, 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<TSuccessMessage extends Message, TErrorMessage extends Message, TArgs extends unknown [], TReturn>(task: (...args: TArgs) => TReturn, ofSuccess: (result: TReturn) => TSuccessMessage, ofError: (error: Error) => TErrorMessage, ...args: TArgs): Cmd<TSuccessMessage | TErrorMessage> {\n            const bind = (dispatch: Dispatch<TSuccessMessage | TErrorMessage>): 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<TSuccessMessage extends Message, TArgs extends unknown [], TReturn>(task: (...args: TArgs) => TReturn, ofSuccess: (result: TReturn) => TSuccessMessage, ...args: TArgs): Cmd<TSuccessMessage> {\n            const bind = (dispatch: Dispatch<TSuccessMessage>, 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<TErrorMessage extends Message, TArgs extends unknown [], TReturn>(task: (...args: TArgs) => TReturn, ofError: (error: Error) => TErrorMessage, ...args: TArgs): Cmd<TErrorMessage> {\n            const bind = (dispatch: Dispatch<TErrorMessage>, 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<TSuccessMessage extends Message, TErrorMessage extends Message, TArgs extends unknown [], TReturn>(task: (...args: TArgs) => Promise<TReturn>, ofSuccess: (result: TReturn) => TSuccessMessage, ofError: (error: Error) => TErrorMessage, ...args: TArgs): Cmd<TSuccessMessage | TErrorMessage> {\n            const bind = (dispatch: Dispatch<TSuccessMessage | TErrorMessage>): 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<TSuccessMessage extends Message, TArgs extends unknown [], TReturn>(task: (...args: TArgs) => Promise<TReturn>, ofSuccess: (result: TReturn) => TSuccessMessage, ...args: TArgs): Cmd<TSuccessMessage> {\n            const bind = (dispatch: Dispatch<TSuccessMessage>, 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<TErrorMessage extends Message, TArgs extends unknown [], TReturn>(task: (...args: TArgs) => Promise<TReturn>, ofError: (error: Error) => TErrorMessage, ...args: TArgs): Cmd<TErrorMessage> {\n            const bind = (dispatch: Dispatch<TErrorMessage>, 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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"}
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\t/**\n\t * Creates a command out of a specific message.\n\t * @param {TMessage} msg The specific message.\n\t */\n\tofMsg<TMessage extends Message>(msg: TMessage): Cmd<TMessage> {\n\t\treturn [(dispatch) => dispatch(msg)];\n\t},\n\n\t/**\n\t * Aggregates multiple commands.\n\t * @param {Cmd<TMessage> []} commands Array of commands.\n\t */\n\tbatch<TMessage extends Message>(\n\t\t...commands: (Cmd<TMessage> | undefined | null)[]\n\t): Cmd<TMessage> {\n\t\treturn (commands.filter(Boolean) as Cmd<TMessage>[]).flat();\n\t},\n\n\t/**\n\t * Command to call the subscriber.\n\t * @param {Sub<TMessage>} sub The subscriber function.\n\t */\n\tofSub<TMessage extends Message>(sub: Sub<TMessage>): Cmd<TMessage> {\n\t\treturn [sub];\n\t},\n\n\t/**\n\t * Creates a command out of a function and maps the result. This can also be an async function.\n\t * @param task The function to call.\n\t * @param ofSuccess Creates the message to dispatch when the function runs successfully or, for an async function, the promise is resolved.\n\t * @param ofError Creates the message to dispatch when the function throws an error or, for an async function, the promise is rejected.\n\t * @param args The parameters of the task.\n\t */\n\tofEither<\n\t\tTSuccessMessage extends Message,\n\t\tTErrorMessage extends Message,\n\t\tTArgs extends unknown[],\n\t\tTReturn,\n\t>(\n\t\ttask: (...args: TArgs) => TReturn,\n\t\tofSuccess: (result: Awaited<TReturn>) => TSuccessMessage,\n\t\tofError: (error: Error) => TErrorMessage,\n\t\t...args: TArgs\n\t): Cmd<TSuccessMessage | TErrorMessage> {\n\t\tconst bind = (\n\t\t\tdispatch: Dispatch<TSuccessMessage | TErrorMessage>,\n\t\t): void => {\n\t\t\ttry {\n\t\t\t\tconst taskResult = task(...args);\n\n\t\t\t\tPromise.resolve(taskResult)\n\t\t\t\t\t.then((result) => dispatch(ofSuccess(result)))\n\t\t\t\t\t.catch((ex: Error) => dispatch(ofError(ex)));\n\t\t\t} catch (ex: unknown) {\n\t\t\t\tdispatch(ofError(ex as Error));\n\t\t\t}\n\t\t};\n\n\t\treturn [bind];\n\t},\n\n\t/**\n\t * Creates a command out of a function and ignores the error case. This can also be an async function.\n\t * @param task The async function to call.\n\t * @param ofSuccess Creates the message to dispatch when the function runs successfully or, for an async function, the promise is resolved.\n\t * @param args The parameters of the task.\n\t */\n\tofSuccess<TSuccessMessage extends Message, TArgs extends unknown[], TReturn>(\n\t\ttask: (...args: TArgs) => TReturn,\n\t\tofSuccess: (result: Awaited<TReturn>) => TSuccessMessage,\n\t\t...args: TArgs\n\t): Cmd<TSuccessMessage> {\n\t\tconst bind = (\n\t\t\tdispatch: Dispatch<TSuccessMessage>,\n\t\t\tfallback: FallbackHandler = defaultFallbackHandler,\n\t\t): void => {\n\t\t\ttry {\n\t\t\t\tconst taskResult = task(...args);\n\n\t\t\t\tPromise.resolve(taskResult)\n\t\t\t\t\t.then((result) => dispatch(ofSuccess(result)))\n\t\t\t\t\t.catch(fallback);\n\t\t\t} catch (ex: unknown) {\n\t\t\t\tfallback(ex as Error);\n\t\t\t}\n\t\t};\n\n\t\treturn [bind];\n\t},\n\n\t/**\n\t * Creates a command out of a function and ignores the success case. This can also be an async function.\n\t * @param task The function to call.\n\t * @param ofError Creates the message to dispatch when the function runs successfully or, for an async function, the promise is rejected.\n\t * @param args The parameters of the task.\n\t */\n\tofError<TErrorMessage extends Message, TArgs extends unknown[], TReturn>(\n\t\ttask: (...args: TArgs) => TReturn,\n\t\tofError: (error: Error) => TErrorMessage,\n\t\t...args: TArgs\n\t): Cmd<TErrorMessage> {\n\t\tconst bind = (\n\t\t\tdispatch: Dispatch<TErrorMessage>,\n\t\t\tfallback?: FallbackHandler,\n\t\t): void => {\n\t\t\ttry {\n\t\t\t\tconst taskResult = task(...args);\n\n\t\t\t\tPromise.resolve(taskResult)\n\t\t\t\t\t.then(() => fallback?.())\n\t\t\t\t\t.catch((ex: Error) => dispatch(ofError(ex)));\n\t\t\t} catch (ex: unknown) {\n\t\t\t\tdispatch(ofError(ex as Error));\n\t\t\t}\n\t\t};\n\n\t\treturn [bind];\n\t},\n\n\t/**\n\t * Provides functionalities to create commands from simple functions.\n\t */\n\tofFunc: {\n\t\t/**\n\t\t * Creates a command out of a simple function and maps the result.\n\t\t * @param task The function to call.\n\t\t * @param ofSuccess Creates the message to dispatch after a successful call of the task.\n\t\t * @param ofError Creates the message to dispatch when an error occurred.\n\t\t * @param args The parameters of the task.\n\t\t */\n\t\teither<\n\t\t\tTSuccessMessage extends Message,\n\t\t\tTErrorMessage extends Message,\n\t\t\tTArgs extends unknown[],\n\t\t\tTReturn,\n\t\t>(\n\t\t\ttask: (...args: TArgs) => TReturn,\n\t\t\tofSuccess: (result: TReturn) => TSuccessMessage,\n\t\t\tofError: (error: Error) => TErrorMessage,\n\t\t\t...args: TArgs\n\t\t): Cmd<TSuccessMessage | TErrorMessage> {\n\t\t\tconst bind = (\n\t\t\t\tdispatch: Dispatch<TSuccessMessage | TErrorMessage>,\n\t\t\t): void => {\n\t\t\t\ttry {\n\t\t\t\t\tconst result = task(...args);\n\n\t\t\t\t\tdispatch(ofSuccess(result));\n\t\t\t\t} catch (ex: unknown) {\n\t\t\t\t\tdispatch(ofError(ex as Error));\n\t\t\t\t}\n\t\t\t};\n\n\t\t\treturn [bind];\n\t\t},\n\n\t\t/**\n\t\t * Creates a command out of a simple function and ignores the error case.\n\t\t * @param task The function to call.\n\t\t * @param ofSuccess Creates the message to dispatch after a successful call of the task.\n\t\t * @param args The parameters of the task.\n\t\t */\n\t\tperform<TSuccessMessage extends Message, TArgs extends unknown[], TReturn>(\n\t\t\ttask: (...args: TArgs) => TReturn,\n\t\t\tofSuccess: (result: TReturn) => TSuccessMessage,\n\t\t\t...args: TArgs\n\t\t): Cmd<TSuccessMessage> {\n\t\t\tconst bind = (\n\t\t\t\tdispatch: Dispatch<TSuccessMessage>,\n\t\t\t\tfallback?: FallbackHandler,\n\t\t\t): void => {\n\t\t\t\ttry {\n\t\t\t\t\tconst result = task(...args);\n\n\t\t\t\t\tdispatch(ofSuccess(result));\n\t\t\t\t} catch (ex: unknown) {\n\t\t\t\t\tif (fallback) {\n\t\t\t\t\t\tfallback(ex as Error);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t};\n\n\t\t\treturn [bind];\n\t\t},\n\n\t\t/**\n\t\t * Creates a command out of a simple function and ignores the success case.\n\t\t * @param task The function to call.\n\t\t * @param ofError Creates the message to dispatch when an error occurred.\n\t\t * @param args The parameters of the task.\n\t\t */\n\t\tattempt<TErrorMessage extends Message, TArgs extends unknown[], TReturn>(\n\t\t\ttask: (...args: TArgs) => TReturn,\n\t\t\tofError: (error: Error) => TErrorMessage,\n\t\t\t...args: TArgs\n\t\t): Cmd<TErrorMessage> {\n\t\t\tconst bind = (\n\t\t\t\tdispatch: Dispatch<TErrorMessage>,\n\t\t\t\tfallback?: FallbackHandler,\n\t\t\t): void => {\n\t\t\t\ttry {\n\t\t\t\t\ttask(...args);\n\n\t\t\t\t\tif (fallback) {\n\t\t\t\t\t\tfallback();\n\t\t\t\t\t}\n\t\t\t\t} catch (ex: unknown) {\n\t\t\t\t\tdispatch(ofError(ex as Error));\n\t\t\t\t}\n\t\t\t};\n\n\t\t\treturn [bind];\n\t\t},\n\t},\n\n\t/**\n\t * Provides functionalities to create commands from async functions.\n\t */\n\tofPromise: {\n\t\t/**\n\t\t * Creates a command out of an async function and maps the result.\n\t\t * @param task The async function to call.\n\t\t * @param ofSuccess Creates the message to dispatch when the promise is resolved.\n\t\t * @param ofError Creates the message to dispatch when the promise is rejected.\n\t\t * @param args The parameters of the task.\n\t\t */\n\t\teither<\n\t\t\tTSuccessMessage extends Message,\n\t\t\tTErrorMessage extends Message,\n\t\t\tTArgs extends unknown[],\n\t\t\tTReturn,\n\t\t>(\n\t\t\ttask: (...args: TArgs) => Promise<TReturn>,\n\t\t\tofSuccess: (result: TReturn) => TSuccessMessage,\n\t\t\tofError: (error: Error) => TErrorMessage,\n\t\t\t...args: TArgs\n\t\t): Cmd<TSuccessMessage | TErrorMessage> {\n\t\t\tconst bind = (\n\t\t\t\tdispatch: Dispatch<TSuccessMessage | TErrorMessage>,\n\t\t\t): void => {\n\t\t\t\ttask(...args)\n\t\t\t\t\t.then((result) => dispatch(ofSuccess(result)))\n\t\t\t\t\t.catch((ex: Error) => dispatch(ofError(ex)));\n\t\t\t};\n\n\t\t\treturn [bind];\n\t\t},\n\n\t\t/**\n\t\t * Creates a command out of an async function and ignores the error case.\n\t\t * @param task The async function to call.\n\t\t * @param ofSuccess Creates the message to dispatch when the promise is resolved.\n\t\t * @param args The parameters of the task.\n\t\t */\n\t\tperform<TSuccessMessage extends Message, TArgs extends unknown[], TReturn>(\n\t\t\ttask: (...args: TArgs) => Promise<TReturn>,\n\t\t\tofSuccess: (result: TReturn) => TSuccessMessage,\n\t\t\t...args: TArgs\n\t\t): Cmd<TSuccessMessage> {\n\t\t\tconst bind = (\n\t\t\t\tdispatch: Dispatch<TSuccessMessage>,\n\t\t\t\tfallback: FallbackHandler = defaultFallbackHandler,\n\t\t\t): void => {\n\t\t\t\ttask(...args)\n\t\t\t\t\t.then((result) => dispatch(ofSuccess(result)))\n\t\t\t\t\t.catch(fallback);\n\t\t\t};\n\n\t\t\treturn [bind];\n\t\t},\n\n\t\t/**\n\t\t * Creates a command out of an async function and ignores the success case.\n\t\t * @param task The async function to call.\n\t\t * @param ofError Creates the message to dispatch when the promise is rejected.\n\t\t * @param args The parameters of the task.\n\t\t */\n\t\tattempt<TErrorMessage extends Message, TArgs extends unknown[], TReturn>(\n\t\t\ttask: (...args: TArgs) => Promise<TReturn>,\n\t\t\tofError: (error: Error) => TErrorMessage,\n\t\t\t...args: TArgs\n\t\t): Cmd<TErrorMessage> {\n\t\t\tconst bind = (\n\t\t\t\tdispatch: Dispatch<TErrorMessage>,\n\t\t\t\tfallback?: FallbackHandler,\n\t\t\t): void => {\n\t\t\t\ttask(...args)\n\t\t\t\t\t.then(() => {\n\t\t\t\t\t\tif (fallback) {\n\t\t\t\t\t\t\tfallback();\n\t\t\t\t\t\t}\n\t\t\t\t\t})\n\t\t\t\t\t.catch((ex: Error) => dispatch(ofError(ex)));\n\t\t\t};\n\n\t\t\treturn [bind];\n\t\t},\n\t},\n};\n\nfunction defaultFallbackHandler(): void {\n\t// blank\n}\n\nexport { cmd };\n"],"mappings":"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"}
package/dist/index.d.ts CHANGED
@@ -1,8 +1,8 @@
1
- import { cmd } from "./cmd";
2
1
  import { ElmComponent } from "./ElmComponent";
3
- import { errorHandler, ErrorMessage, errorMsg, handleError } from "./ErrorHandling";
4
- import { init, Logger } from "./Init";
2
+ import { ErrorMessage, errorHandler, errorMsg, handleError } from "./ErrorHandling";
3
+ import { ElmOptions, Logger, init } from "./Init";
5
4
  import { Cmd, Dispatch, InitResult, Message, MsgSource, UpdateMap, UpdateReturnType } from "./Types";
6
- import { SubscriptionResult, useElmish } from "./useElmish";
7
- export type { Logger, Message, Cmd, Dispatch, InitResult, UpdateReturnType, SubscriptionResult, MsgSource, UpdateMap, ErrorMessage, };
8
- export { init, cmd, ElmComponent, errorMsg, errorHandler, handleError, useElmish, };
5
+ import { cmd } from "./cmd";
6
+ import { SubscriptionResult, UseElmishOptions, useElmish } from "./useElmish";
7
+ export type { Cmd, Dispatch, ElmOptions, ErrorMessage, InitResult, Logger, Message, MsgSource, SubscriptionResult, UpdateMap, UpdateReturnType, UseElmishOptions, };
8
+ export { ElmComponent, cmd, errorHandler, errorMsg, handleError, init, useElmish };
package/dist/index.js CHANGED
@@ -45,9 +45,9 @@ Object.defineProperty(exports, "useElmish", {
45
45
  return _useElmish.useElmish;
46
46
  }
47
47
  });
48
- var _cmd = require("./cmd");
49
48
  var _ElmComponent = require("./ElmComponent");
50
49
  var _ErrorHandling = require("./ErrorHandling");
51
50
  var _Init = require("./Init");
51
+ var _cmd = require("./cmd");
52
52
  var _useElmish = require("./useElmish");
53
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfY21kIiwicmVxdWlyZSIsIl9FbG1Db21wb25lbnQiLCJfRXJyb3JIYW5kbGluZyIsIl9Jbml0IiwiX3VzZUVsbWlzaCJdLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjbWQgfSBmcm9tIFwiLi9jbWRcIjtcbmltcG9ydCB7IEVsbUNvbXBvbmVudCB9IGZyb20gXCIuL0VsbUNvbXBvbmVudFwiO1xuaW1wb3J0IHsgZXJyb3JIYW5kbGVyLCBFcnJvck1lc3NhZ2UsIGVycm9yTXNnLCBoYW5kbGVFcnJvciB9IGZyb20gXCIuL0Vycm9ySGFuZGxpbmdcIjtcbmltcG9ydCB7IGluaXQsIExvZ2dlciB9IGZyb20gXCIuL0luaXRcIjtcbmltcG9ydCB7IENtZCwgRGlzcGF0Y2gsIEluaXRSZXN1bHQsIE1lc3NhZ2UsIE1zZ1NvdXJjZSwgVXBkYXRlTWFwLCBVcGRhdGVSZXR1cm5UeXBlIH0gZnJvbSBcIi4vVHlwZXNcIjtcbmltcG9ydCB7IFN1YnNjcmlwdGlvblJlc3VsdCwgdXNlRWxtaXNoIH0gZnJvbSBcIi4vdXNlRWxtaXNoXCI7XG5cbmV4cG9ydCB0eXBlIHtcbiAgICBMb2dnZXIsXG4gICAgTWVzc2FnZSxcbiAgICBDbWQsXG4gICAgRGlzcGF0Y2gsXG4gICAgSW5pdFJlc3VsdCxcbiAgICBVcGRhdGVSZXR1cm5UeXBlLFxuICAgIFN1YnNjcmlwdGlvblJlc3VsdCxcbiAgICBNc2dTb3VyY2UsXG4gICAgVXBkYXRlTWFwLFxuICAgIEVycm9yTWVzc2FnZSxcbn07XG5cbmV4cG9ydCB7XG4gICAgaW5pdCxcbiAgICBjbWQsXG4gICAgRWxtQ29tcG9uZW50LFxuICAgIGVycm9yTXNnLFxuICAgIGVycm9ySGFuZGxlcixcbiAgICBoYW5kbGVFcnJvcixcbiAgICB1c2VFbG1pc2gsXG59OyJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSxJQUFBQSxJQUFBLEdBQUFDLE9BQUE7QUFDQSxJQUFBQyxhQUFBLEdBQUFELE9BQUE7QUFDQSxJQUFBRSxjQUFBLEdBQUFGLE9BQUE7QUFDQSxJQUFBRyxLQUFBLEdBQUFILE9BQUE7QUFFQSxJQUFBSSxVQUFBLEdBQUFKLE9BQUEifQ==
53
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfRWxtQ29tcG9uZW50IiwicmVxdWlyZSIsIl9FcnJvckhhbmRsaW5nIiwiX0luaXQiLCJfY21kIiwiX3VzZUVsbWlzaCJdLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBFbG1Db21wb25lbnQgfSBmcm9tIFwiLi9FbG1Db21wb25lbnRcIjtcbmltcG9ydCB7IEVycm9yTWVzc2FnZSwgZXJyb3JIYW5kbGVyLCBlcnJvck1zZywgaGFuZGxlRXJyb3IgfSBmcm9tIFwiLi9FcnJvckhhbmRsaW5nXCI7XG5pbXBvcnQgeyBFbG1PcHRpb25zLCBMb2dnZXIsIGluaXQgfSBmcm9tIFwiLi9Jbml0XCI7XG5pbXBvcnQgeyBDbWQsIERpc3BhdGNoLCBJbml0UmVzdWx0LCBNZXNzYWdlLCBNc2dTb3VyY2UsIFVwZGF0ZU1hcCwgVXBkYXRlUmV0dXJuVHlwZSB9IGZyb20gXCIuL1R5cGVzXCI7XG5pbXBvcnQgeyBjbWQgfSBmcm9tIFwiLi9jbWRcIjtcbmltcG9ydCB7IFN1YnNjcmlwdGlvblJlc3VsdCwgVXNlRWxtaXNoT3B0aW9ucywgdXNlRWxtaXNoIH0gZnJvbSBcIi4vdXNlRWxtaXNoXCI7XG5cbmV4cG9ydCB0eXBlIHtcblx0Q21kLFxuXHREaXNwYXRjaCxcblx0RWxtT3B0aW9ucyxcblx0RXJyb3JNZXNzYWdlLFxuXHRJbml0UmVzdWx0LFxuXHRMb2dnZXIsXG5cdE1lc3NhZ2UsXG5cdE1zZ1NvdXJjZSxcblx0U3Vic2NyaXB0aW9uUmVzdWx0LFxuXHRVcGRhdGVNYXAsXG5cdFVwZGF0ZVJldHVyblR5cGUsXG5cdFVzZUVsbWlzaE9wdGlvbnMsXG59O1xuXG5leHBvcnQgeyBFbG1Db21wb25lbnQsIGNtZCwgZXJyb3JIYW5kbGVyLCBlcnJvck1zZywgaGFuZGxlRXJyb3IsIGluaXQsIHVzZUVsbWlzaCB9O1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLElBQUFBLGFBQUEsR0FBQUMsT0FBQTtBQUNBLElBQUFDLGNBQUEsR0FBQUQsT0FBQTtBQUNBLElBQUFFLEtBQUEsR0FBQUYsT0FBQTtBQUVBLElBQUFHLElBQUEsR0FBQUgsT0FBQTtBQUNBLElBQUFJLFVBQUEsR0FBQUosT0FBQSJ9
@@ -46,8 +46,8 @@ interface UseElmishOptions<TProps, TModel, TMessage extends Message> {
46
46
  * @example
47
47
  * const [model, dispatch] = useElmish({ props, init, update, name: "MyComponent" });
48
48
  */
49
- declare function useElmish<TProps, TModel, TMessage extends Message>({ name, props, init, update, subscription }: UseElmishOptions<TProps, TModel, TMessage>): [TModel, Dispatch<TMessage>];
49
+ declare function useElmish<TProps, TModel, TMessage extends Message>({ name, props, init, update, subscription, }: UseElmishOptions<TProps, TModel, TMessage>): [TModel, Dispatch<TMessage>];
50
50
  declare function callUpdate<TProps, TModel, TMessage extends Message>(update: UpdateFunction<TProps, TModel, TMessage> | UpdateMap<TProps, TModel, TMessage>, msg: TMessage, model: TModel, props: TProps): UpdateReturnType<TModel, TMessage>;
51
51
  declare function callUpdateMap<TProps, TModel, TMessage extends Message>(updateMap: UpdateMap<TProps, TModel, TMessage>, msg: TMessage, model: TModel, props: TProps): UpdateReturnType<TModel, TMessage>;
52
- export type { SubscriptionResult, };
53
- export { useElmish, callUpdate, callUpdateMap, };
52
+ export type { SubscriptionResult, UseElmishOptions };
53
+ export { callUpdate, callUpdateMap, useElmish };
package/dist/useElmish.js CHANGED
@@ -7,10 +7,10 @@ Object.defineProperty(exports, "__esModule", {
7
7
  exports.callUpdate = callUpdate;
8
8
  exports.callUpdateMap = callUpdateMap;
9
9
  exports.useElmish = useElmish;
10
- var _react = require("react");
11
10
  var _Common = require("./Common");
12
11
  var _Init = require("./Init");
13
12
  var _fakeOptions = require("./Testing/fakeOptions");
13
+ var _react = require("react");
14
14
  function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
15
15
  function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
16
16
  function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
@@ -119,6 +119,8 @@ function useElmish(_ref) {
119
119
  (_Services$logger2 = _Init.Services.logger) === null || _Services$logger2 === void 0 ? void 0 : _Services$logger2.debug("Initial model for", name, initializedModel);
120
120
  _Common.execCmd.apply(void 0, [dispatch].concat(_toConsumableArray(initCommands)));
121
121
  }
122
+
123
+ // rome-ignore lint/nursery/useExhaustiveDependencies: We want to run this effect only once
122
124
  (0, _react.useEffect)(function () {
123
125
  if (subscription) {
124
126
  var _subscription = subscription(initializedModel, props),
@@ -141,4 +143,4 @@ function callUpdateMap(updateMap, msg, model, props) {
141
143
  var msgName = msg.name;
142
144
  return updateMap[msgName](msg, model, props);
143
145
  }
144
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","require","_Common","_Init","_fakeOptions","_toConsumableArray","arr","_arrayWithoutHoles","_iterableToArray","_unsupportedIterableToArray","_nonIterableSpread","TypeError","Array","isArray","_arrayLikeToArray","ownKeys","object","enumerableOnly","keys","Object","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","key","_defineProperty","getOwnPropertyDescriptors","defineProperties","defineProperty","obj","value","_toPropertyKey","configurable","writable","arg","_toPrimitive","_typeof","String","input","hint","prim","Symbol","toPrimitive","undefined","res","call","Number","_toArray","_arrayWithHoles","_nonIterableRest","iter","iterator","from","_slicedToArray","_iterableToArrayLimit","o","minLen","n","prototype","toString","slice","constructor","name","test","len","arr2","_i","_s","_e","_x","_r","_arr","_n","_d","next","done","err","useElmish","_ref","_fakeOptions$dispatch","props","init","update","subscription","reentered","buffer","currentModel","_useState","useState","_useState2","model","setModel","propsRef","useRef","isMountedRef","useEffect","current","initializedModel","fakeOptions","getFakeOptionsOnce","dispatch","useCallback","msg","nextMsg","modified","logMessage","_callUpdate","callUpdate","_callUpdate2","newModel","commands","modelHasChanged","execCmd","concat","shift","prevModel","_Services$logger","updatedModel","Services","logger","debug","_Services$logger2","_ref2","_ref3","initModel","initCommands","_subscription","_subscription2","subCmd","destructor","callUpdateMap","updateMap","msgName"],"sources":["../src/useElmish.ts"],"sourcesContent":["/* eslint-disable react-hooks/exhaustive-deps */\nimport { useCallback, useEffect, useRef, useState } from \"react\";\nimport { execCmd, logMessage, modelHasChanged } from \"./Common\";\nimport { Services } from \"./Init\";\nimport { getFakeOptionsOnce } from \"./Testing/fakeOptions\";\nimport { Cmd, Dispatch, InitFunction, Message, Nullable, UpdateFunction, UpdateMap, UpdateReturnType } from \"./Types\";\n\n/**\n * The return type of the `subscription` function.\n * @template TMessage The type of the messages discriminated union.\n */\ntype SubscriptionResult<TMessage> = [Cmd<TMessage>, (() => void)?];\ntype Subscription<TProps, TModel, TMessage> = (model: TModel, props: TProps) => SubscriptionResult<TMessage>;\n\n/**\n * Options for the `useElmish` hook.\n * @interface UseElmishOptions\n * @template TProps The type of the props.\n * @template TModel The type of the model.\n * @template TMessage The type of the messages discriminated union.\n */\ninterface UseElmishOptions<TProps, TModel, TMessage extends Message> {\n    /**\n     * The name of the component. This is used for logging only.\n     * @type {string}\n     */\n    name: string,\n    /**\n     * The props passed to the component.\n     * @type {TProps}\n     */\n    props: TProps,\n    /**\n     * The function to initialize the components model. This function is only called once.\n     * @type {InitFunction<TProps, TModel, TMessage>}\n     */\n    init: InitFunction<TProps, TModel, TMessage>,\n    /**\n     * The `update` function or update map object.\n     * @type {(UpdateFunction<TProps, TModel, TMessage> | UpdateMap<TProps, TModel, TMessage>)}\n     */\n    update: UpdateFunction<TProps, TModel, TMessage> | UpdateMap<TProps, TModel, TMessage>,\n    /**\n     * The optional `subscription` function. This function is only called once.\n     * @type {(UpdateFunction<TProps, TModel, TMessage> | UpdateMap<TProps, TModel, TMessage>)}\n     */\n    subscription?: Subscription<TProps, TModel, TMessage>,\n}\n\n/**\n * Hook to use the Elm architecture pattern in a function component.\n * @param {UseElmishOptions} options The options passed the the hook.\n * @returns A tuple containing the current model and the dispatcher.\n * @example\n * const [model, dispatch] = useElmish({ props, init, update, name: \"MyComponent\" });\n */\nfunction useElmish<TProps, TModel, TMessage extends Message> ({ name, props, init, update, subscription }: UseElmishOptions<TProps, TModel, TMessage>): [TModel, Dispatch<TMessage>] {\n    let reentered = false;\n    const buffer: TMessage [] = [];\n    let currentModel: Partial<TModel> = {};\n\n    const [model, setModel] = useState<Nullable<TModel>>(null);\n    const propsRef = useRef(props);\n    const isMountedRef = useRef(true);\n\n    useEffect(() => {\n        isMountedRef.current = true;\n\n        return () => {\n            isMountedRef.current = false;\n        };\n    }, []);\n\n    let initializedModel = model;\n\n    if (propsRef.current !== props) {\n        propsRef.current = props;\n    }\n\n    const fakeOptions = getFakeOptionsOnce();\n    const dispatch = useCallback(fakeOptions?.dispatch ?? ((msg: TMessage): void => {\n        if (!initializedModel) {\n            return;\n        }\n\n        if (reentered) {\n            buffer.push(msg);\n        } else {\n            reentered = true;\n\n            let nextMsg: TMessage | undefined = msg;\n            let modified = false;\n\n            while (nextMsg) {\n                logMessage(name, nextMsg);\n\n                const [newModel, ...commands] = callUpdate(update, nextMsg, { ...initializedModel, ...currentModel }, propsRef.current);\n\n                if (modelHasChanged(currentModel, newModel)) {\n                    currentModel = { ...currentModel, ...newModel };\n\n                    modified = true;\n                }\n\n                execCmd(dispatch, ...commands);\n\n                nextMsg = buffer.shift();\n            }\n            reentered = false;\n\n            if (isMountedRef.current && modified) {\n                setModel(prevModel => {\n                    const updatedModel = { ...prevModel as TModel, ...currentModel };\n\n                    Services.logger?.debug(\"Update model for\", name, updatedModel);\n\n                    return updatedModel;\n                });\n            }\n        }\n    }), []);\n\n    if (!initializedModel) {\n        const [initModel, ...initCommands] = fakeOptions?.model ? [fakeOptions.model as TModel] : init(props);\n\n        initializedModel = initModel;\n        setModel(initializedModel);\n\n        Services.logger?.debug(\"Initial model for\", name, initializedModel);\n\n        execCmd(dispatch, ...initCommands);\n    }\n\n    useEffect(() => {\n        if (subscription) {\n            const [subCmd, destructor] = subscription(initializedModel as TModel, props);\n\n            execCmd(dispatch, subCmd);\n\n            return destructor;\n        }\n    }, []);\n\n    return [initializedModel, dispatch];\n}\n\nfunction callUpdate<TProps, TModel, TMessage extends Message> (update: UpdateFunction<TProps, TModel, TMessage> | UpdateMap<TProps, TModel, TMessage>, msg: TMessage, model: TModel, props: TProps): UpdateReturnType<TModel, TMessage> {\n    if (typeof update === \"function\") {\n        return update(model, msg, props);\n    }\n\n    return callUpdateMap(update, msg, model, props);\n}\n\nfunction callUpdateMap<TProps, TModel, TMessage extends Message> (updateMap: UpdateMap<TProps, TModel, TMessage>, msg: TMessage, model: TModel, props: TProps): UpdateReturnType<TModel, TMessage> {\n    const msgName: TMessage[\"name\"] = msg.name;\n\n    return updateMap[msgName](msg, model, props);\n}\n\nexport type {\n    SubscriptionResult,\n};\n\nexport {\n    useElmish,\n    callUpdate,\n    callUpdateMap,\n};"],"mappings":"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"}
146
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_Common","require","_Init","_fakeOptions","_react","_toConsumableArray","arr","_arrayWithoutHoles","_iterableToArray","_unsupportedIterableToArray","_nonIterableSpread","TypeError","Array","isArray","_arrayLikeToArray","ownKeys","object","enumerableOnly","keys","Object","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","key","_defineProperty","getOwnPropertyDescriptors","defineProperties","defineProperty","obj","value","_toPropertyKey","configurable","writable","arg","_toPrimitive","_typeof","String","input","hint","prim","Symbol","toPrimitive","undefined","res","call","Number","_toArray","_arrayWithHoles","_nonIterableRest","iter","iterator","from","_slicedToArray","_iterableToArrayLimit","o","minLen","n","prototype","toString","slice","constructor","name","test","len","arr2","_i","_s","_e","_x","_r","_arr","_n","_d","next","done","err","useElmish","_ref","_fakeOptions$dispatch","props","init","update","subscription","reentered","buffer","currentModel","_useState","useState","_useState2","model","setModel","propsRef","useRef","isMountedRef","useEffect","current","initializedModel","fakeOptions","getFakeOptionsOnce","dispatch","useCallback","msg","nextMsg","modified","logMessage","_callUpdate","callUpdate","_callUpdate2","newModel","commands","modelHasChanged","execCmd","concat","shift","prevModel","_Services$logger","updatedModel","Services","logger","debug","_Services$logger2","_ref2","_ref3","initModel","initCommands","_subscription","_subscription2","subCmd","destructor","callUpdateMap","updateMap","msgName"],"sources":["../src/useElmish.ts"],"sourcesContent":["import { execCmd, logMessage, modelHasChanged } from \"./Common\";\nimport { Services } from \"./Init\";\nimport { getFakeOptionsOnce } from \"./Testing/fakeOptions\";\nimport { Cmd, Dispatch, InitFunction, Message, Nullable, UpdateFunction, UpdateMap, UpdateReturnType } from \"./Types\";\n/* eslint-disable react-hooks/exhaustive-deps */\nimport { useCallback, useEffect, useRef, useState } from \"react\";\n\n/**\n * The return type of the `subscription` function.\n * @template TMessage The type of the messages discriminated union.\n */\ntype SubscriptionResult<TMessage> = [Cmd<TMessage>, (() => void)?];\ntype Subscription<TProps, TModel, TMessage> = (model: TModel, props: TProps) => SubscriptionResult<TMessage>;\n\n/**\n * Options for the `useElmish` hook.\n * @interface UseElmishOptions\n * @template TProps The type of the props.\n * @template TModel The type of the model.\n * @template TMessage The type of the messages discriminated union.\n */\ninterface UseElmishOptions<TProps, TModel, TMessage extends Message> {\n\t/**\n\t * The name of the component. This is used for logging only.\n\t * @type {string}\n\t */\n\tname: string;\n\t/**\n\t * The props passed to the component.\n\t * @type {TProps}\n\t */\n\tprops: TProps;\n\t/**\n\t * The function to initialize the components model. This function is only called once.\n\t * @type {InitFunction<TProps, TModel, TMessage>}\n\t */\n\tinit: InitFunction<TProps, TModel, TMessage>;\n\t/**\n\t * The `update` function or update map object.\n\t * @type {(UpdateFunction<TProps, TModel, TMessage> | UpdateMap<TProps, TModel, TMessage>)}\n\t */\n\tupdate: UpdateFunction<TProps, TModel, TMessage> | UpdateMap<TProps, TModel, TMessage>;\n\t/**\n\t * The optional `subscription` function. This function is only called once.\n\t * @type {(UpdateFunction<TProps, TModel, TMessage> | UpdateMap<TProps, TModel, TMessage>)}\n\t */\n\tsubscription?: Subscription<TProps, TModel, TMessage>;\n}\n\n/**\n * Hook to use the Elm architecture pattern in a function component.\n * @param {UseElmishOptions} options The options passed the the hook.\n * @returns A tuple containing the current model and the dispatcher.\n * @example\n * const [model, dispatch] = useElmish({ props, init, update, name: \"MyComponent\" });\n */\nfunction useElmish<TProps, TModel, TMessage extends Message>({\n\tname,\n\tprops,\n\tinit,\n\tupdate,\n\tsubscription,\n}: UseElmishOptions<TProps, TModel, TMessage>): [TModel, Dispatch<TMessage>] {\n\tlet reentered = false;\n\tconst buffer: TMessage[] = [];\n\tlet currentModel: Partial<TModel> = {};\n\n\tconst [model, setModel] = useState<Nullable<TModel>>(null);\n\tconst propsRef = useRef(props);\n\tconst isMountedRef = useRef(true);\n\n\tuseEffect(() => {\n\t\tisMountedRef.current = true;\n\n\t\treturn () => {\n\t\t\tisMountedRef.current = false;\n\t\t};\n\t}, []);\n\n\tlet initializedModel = model;\n\n\tif (propsRef.current !== props) {\n\t\tpropsRef.current = props;\n\t}\n\n\tconst fakeOptions = getFakeOptionsOnce();\n\tconst dispatch = useCallback(\n\t\tfakeOptions?.dispatch ??\n\t\t\t((msg: TMessage): void => {\n\t\t\t\tif (!initializedModel) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tif (reentered) {\n\t\t\t\t\tbuffer.push(msg);\n\t\t\t\t} else {\n\t\t\t\t\treentered = true;\n\n\t\t\t\t\tlet nextMsg: TMessage | undefined = msg;\n\t\t\t\t\tlet modified = false;\n\n\t\t\t\t\twhile (nextMsg) {\n\t\t\t\t\t\tlogMessage(name, nextMsg);\n\n\t\t\t\t\t\tconst [newModel, ...commands] = callUpdate(\n\t\t\t\t\t\t\tupdate,\n\t\t\t\t\t\t\tnextMsg,\n\t\t\t\t\t\t\t{ ...initializedModel, ...currentModel },\n\t\t\t\t\t\t\tpropsRef.current,\n\t\t\t\t\t\t);\n\n\t\t\t\t\t\tif (modelHasChanged(currentModel, newModel)) {\n\t\t\t\t\t\t\tcurrentModel = { ...currentModel, ...newModel };\n\n\t\t\t\t\t\t\tmodified = true;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\texecCmd(dispatch, ...commands);\n\n\t\t\t\t\t\tnextMsg = buffer.shift();\n\t\t\t\t\t}\n\t\t\t\t\treentered = false;\n\n\t\t\t\t\tif (isMountedRef.current && modified) {\n\t\t\t\t\t\tsetModel((prevModel) => {\n\t\t\t\t\t\t\tconst updatedModel = {\n\t\t\t\t\t\t\t\t...(prevModel as TModel),\n\t\t\t\t\t\t\t\t...currentModel,\n\t\t\t\t\t\t\t};\n\n\t\t\t\t\t\t\tServices.logger?.debug(\"Update model for\", name, updatedModel);\n\n\t\t\t\t\t\t\treturn updatedModel;\n\t\t\t\t\t\t});\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}),\n\t\t[],\n\t);\n\n\tif (!initializedModel) {\n\t\tconst [initModel, ...initCommands] = fakeOptions?.model ? [fakeOptions.model as TModel] : init(props);\n\n\t\tinitializedModel = initModel;\n\t\tsetModel(initializedModel);\n\n\t\tServices.logger?.debug(\"Initial model for\", name, initializedModel);\n\n\t\texecCmd(dispatch, ...initCommands);\n\t}\n\n\t// rome-ignore lint/nursery/useExhaustiveDependencies: We want to run this effect only once\n\tuseEffect(() => {\n\t\tif (subscription) {\n\t\t\tconst [subCmd, destructor] = subscription(initializedModel as TModel, props);\n\n\t\t\texecCmd(dispatch, subCmd);\n\n\t\t\treturn destructor;\n\t\t}\n\t}, []);\n\n\treturn [initializedModel, dispatch];\n}\n\nfunction callUpdate<TProps, TModel, TMessage extends Message>(\n\tupdate: UpdateFunction<TProps, TModel, TMessage> | UpdateMap<TProps, TModel, TMessage>,\n\tmsg: TMessage,\n\tmodel: TModel,\n\tprops: TProps,\n): UpdateReturnType<TModel, TMessage> {\n\tif (typeof update === \"function\") {\n\t\treturn update(model, msg, props);\n\t}\n\n\treturn callUpdateMap(update, msg, model, props);\n}\n\nfunction callUpdateMap<TProps, TModel, TMessage extends Message>(\n\tupdateMap: UpdateMap<TProps, TModel, TMessage>,\n\tmsg: TMessage,\n\tmodel: TModel,\n\tprops: TProps,\n): UpdateReturnType<TModel, TMessage> {\n\tconst msgName: TMessage[\"name\"] = msg.name;\n\n\treturn updateMap[msgName](msg, model, props);\n}\n\nexport type { SubscriptionResult, UseElmishOptions };\n\nexport { callUpdate, callUpdateMap, useElmish };\n"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "react-elmish",
3
- "version": "7.0.1",
3
+ "version": "7.0.2",
4
4
  "description": "Elmish for React using Typescript",
5
5
  "author": "atheck",
6
6
  "license": "MIT",
@@ -10,28 +10,29 @@
10
10
  "build:js": "babel src --out-dir dist --extensions \".ts,.tsx\" --ignore \"./**/*.spec.ts\",\"./**/*.spec.tsx\" --source-maps inline",
11
11
  "test": "jest --coverage",
12
12
  "test:watch": "jest --watch --coverage",
13
- "lint": "npx eslint \"src/**/*.ts[x]\"",
14
- "update": "npx npm-check-updates -i",
13
+ "lint": "rome check src --max-diagnostics 200 && npx eslint \"src/**/*.ts[x]\"",
14
+ "update": "npx -y npm-check-updates -i --install always",
15
15
  "semantic-release": "semantic-release"
16
16
  },
17
17
  "peerDependencies": {
18
18
  "react": ">=16.8.0"
19
19
  },
20
20
  "devDependencies": {
21
- "@babel/cli": "7.22.9",
22
- "@babel/core": "7.22.9",
21
+ "@babel/cli": "7.22.10",
22
+ "@babel/core": "7.22.10",
23
23
  "@babel/plugin-proposal-class-properties": "7.18.6",
24
- "@babel/preset-env": "7.22.9",
24
+ "@babel/preset-env": "7.22.10",
25
25
  "@babel/preset-react": "7.22.5",
26
26
  "@babel/preset-typescript": "7.22.5",
27
27
  "@testing-library/react": "14.0.0",
28
- "@types/jest": "29.5.3",
29
- "@types/react": "18.2.18",
30
- "eslint": "8.46.0",
31
- "eslint-config-heck": "1.45.2",
32
- "jest": "29.6.2",
33
- "jest-environment-jsdom": "29.6.2",
34
- "semantic-release": "21.0.7",
28
+ "@types/jest": "29.5.4",
29
+ "@types/react": "18.2.21",
30
+ "eslint": "8.47.0",
31
+ "eslint-config-heck": "1.47.1",
32
+ "jest": "29.6.4",
33
+ "jest-environment-jsdom": "29.6.4",
34
+ "rome": "12.1.3",
35
+ "semantic-release": "21.1.0",
35
36
  "ts-jest": "29.1.1",
36
37
  "typescript": "5.1.6"
37
38
  },