react-elmish 7.0.1 → 7.1.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.
Files changed (39) hide show
  1. package/README.md +28 -0
  2. package/dist/Common.d.ts +1 -1
  3. package/dist/Common.js +21 -9
  4. package/dist/ElmComponent.d.ts +2 -2
  5. package/dist/ElmComponent.js +30 -30
  6. package/dist/ErrorHandling.d.ts +1 -1
  7. package/dist/ErrorHandling.js +2 -2
  8. package/dist/Init.d.ts +2 -2
  9. package/dist/Init.js +1 -1
  10. package/dist/Testing/createModelAndProps.d.ts +3 -0
  11. package/dist/Testing/createModelAndProps.js +26 -0
  12. package/dist/Testing/createUpdateArgsFactory.d.ts +3 -2
  13. package/dist/Testing/createUpdateArgsFactory.js +5 -5
  14. package/dist/Testing/execCmd.d.ts +3 -1
  15. package/dist/Testing/execCmd.js +38 -3
  16. package/dist/Testing/getCreateUpdateArgs.d.ts +14 -2
  17. package/dist/Testing/getCreateUpdateArgs.js +26 -17
  18. package/dist/Testing/getUpdateFn.d.ts +2 -2
  19. package/dist/Testing/getUpdateFn.js +10 -9
  20. package/dist/Testing/index.d.ts +6 -5
  21. package/dist/Testing/index.js +14 -1
  22. package/dist/Testing/initAndExecCmd.d.ts +1 -1
  23. package/dist/Testing/initAndExecCmd.js +3 -3
  24. package/dist/Testing/renderWithModel.d.ts +2 -2
  25. package/dist/Testing/renderWithModel.js +5 -5
  26. package/dist/Testing/runSubscription.d.ts +5 -0
  27. package/dist/Testing/runSubscription.js +22 -0
  28. package/dist/Types.d.ts +3 -3
  29. package/dist/Types.js +1 -1
  30. package/dist/cmd.d.ts +49 -49
  31. package/dist/cmd.js +49 -49
  32. package/dist/{Testing/fakeOptions.d.ts → fakeOptions.d.ts} +3 -3
  33. package/dist/fakeOptions.js +31 -0
  34. package/dist/index.d.ts +6 -6
  35. package/dist/index.js +2 -2
  36. package/dist/useElmish.d.ts +3 -3
  37. package/dist/useElmish.js +46 -39
  38. package/package.json +17 -16
  39. package/dist/Testing/fakeOptions.js +0 -31
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>(...commands: (Cmd<TMessage> | undefined | null)[]): 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<TSuccessMessage extends Message, TErrorMessage extends Message, TArgs extends unknown[], TReturn>(\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 = (dispatch: Dispatch<TSuccessMessage | TErrorMessage>): 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 = (dispatch: Dispatch<TSuccessMessage>, fallback: FallbackHandler = defaultFallbackHandler): 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 = (dispatch: Dispatch<TErrorMessage>, fallback?: FallbackHandler): 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<TSuccessMessage extends Message, TErrorMessage extends Message, TArgs extends unknown[], TReturn>(\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 = (dispatch: Dispatch<TSuccessMessage | TErrorMessage>): 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 = (dispatch: Dispatch<TSuccessMessage>, fallback?: FallbackHandler): 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 = (dispatch: Dispatch<TErrorMessage>, fallback?: FallbackHandler): 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<TSuccessMessage extends Message, TErrorMessage extends Message, TArgs extends unknown[], TReturn>(\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 = (dispatch: Dispatch<TSuccessMessage | TErrorMessage>): 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 = (dispatch: Dispatch<TSuccessMessage>, fallback: FallbackHandler = defaultFallbackHandler): 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 = (dispatch: Dispatch<TErrorMessage>, fallback?: FallbackHandler): 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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"}
@@ -1,4 +1,4 @@
1
- import { Dispatch, Message, Nullable } from "../Types";
1
+ import { Dispatch, Message, Nullable } from "./Types";
2
2
  /**
3
3
  * Options for the `renderWithModel` function.
4
4
  * @interface RenderWithModelOptions
@@ -27,5 +27,5 @@ interface RenderWithModelConfig<TModel, TMessage extends Message> extends Render
27
27
  }
28
28
  declare function setFakeOptions<TModel extends object, TMessage extends Message>(options: Nullable<RenderWithModelConfig<TModel, TMessage>>): void;
29
29
  declare function getFakeOptionsOnce<TModel, TMessage extends Message>(): Nullable<RenderWithModelConfig<TModel, TMessage>>;
30
- export type { RenderWithModelOptions, };
31
- export { setFakeOptions, getFakeOptionsOnce, };
30
+ export type { RenderWithModelOptions };
31
+ export { getFakeOptionsOnce, setFakeOptions };
@@ -0,0 +1,31 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.getFakeOptionsOnce = getFakeOptionsOnce;
7
+ exports.setFakeOptions = setFakeOptions;
8
+ /**
9
+ * Options for the `renderWithModel` function.
10
+ * @interface RenderWithModelOptions
11
+ * @template TModel The type of the model.
12
+ * @template TMessage The type of the messages discriminated union.
13
+ */
14
+
15
+ /**
16
+ * Options for the `renderWithModel` function.
17
+ * @interface RenderWithModelOptions
18
+ * @template TModel The type of the model.
19
+ * @template TMessage The type of the messages discriminated union.
20
+ */
21
+
22
+ var currentFakeOptions;
23
+ function setFakeOptions(options) {
24
+ currentFakeOptions = options;
25
+ }
26
+ function getFakeOptionsOnce() {
27
+ var temp = currentFakeOptions;
28
+ currentFakeOptions = null;
29
+ return temp;
30
+ }
31
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjdXJyZW50RmFrZU9wdGlvbnMiLCJzZXRGYWtlT3B0aW9ucyIsIm9wdGlvbnMiLCJnZXRGYWtlT3B0aW9uc09uY2UiLCJ0ZW1wIl0sInNvdXJjZXMiOlsiLi4vc3JjL2Zha2VPcHRpb25zLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpc3BhdGNoLCBNZXNzYWdlLCBOdWxsYWJsZSB9IGZyb20gXCIuL1R5cGVzXCI7XG5cbi8qKlxuICogT3B0aW9ucyBmb3IgdGhlIGByZW5kZXJXaXRoTW9kZWxgIGZ1bmN0aW9uLlxuICogQGludGVyZmFjZSBSZW5kZXJXaXRoTW9kZWxPcHRpb25zXG4gKiBAdGVtcGxhdGUgVE1vZGVsIFRoZSB0eXBlIG9mIHRoZSBtb2RlbC5cbiAqIEB0ZW1wbGF0ZSBUTWVzc2FnZSBUaGUgdHlwZSBvZiB0aGUgbWVzc2FnZXMgZGlzY3JpbWluYXRlZCB1bmlvbi5cbiAqL1xuaW50ZXJmYWNlIFJlbmRlcldpdGhNb2RlbE9wdGlvbnM8VE1lc3NhZ2UgZXh0ZW5kcyBNZXNzYWdlPiB7XG5cdC8qKlxuXHQgKiBBIGZha2UgZGlzcGF0Y2ggZnVuY3Rpb24gdG8gdXNlIHdoZW4gcHJvY2Vzc2luZyBtZXNzYWdlcy5cblx0ICogQHR5cGUge0Rpc3BhdGNoPFRNZXNzYWdlPn1cblx0ICovXG5cdGRpc3BhdGNoPzogRGlzcGF0Y2g8VE1lc3NhZ2U+O1xufVxuXG4vKipcbiAqIE9wdGlvbnMgZm9yIHRoZSBgcmVuZGVyV2l0aE1vZGVsYCBmdW5jdGlvbi5cbiAqIEBpbnRlcmZhY2UgUmVuZGVyV2l0aE1vZGVsT3B0aW9uc1xuICogQHRlbXBsYXRlIFRNb2RlbCBUaGUgdHlwZSBvZiB0aGUgbW9kZWwuXG4gKiBAdGVtcGxhdGUgVE1lc3NhZ2UgVGhlIHR5cGUgb2YgdGhlIG1lc3NhZ2VzIGRpc2NyaW1pbmF0ZWQgdW5pb24uXG4gKi9cbmludGVyZmFjZSBSZW5kZXJXaXRoTW9kZWxDb25maWc8VE1vZGVsLCBUTWVzc2FnZSBleHRlbmRzIE1lc3NhZ2U+IGV4dGVuZHMgUmVuZGVyV2l0aE1vZGVsT3B0aW9uczxUTWVzc2FnZT4ge1xuXHQvKipcblx0ICogVGhlIG1vZGVsIHRvIHVzZSB3aGVuIHJlbmRlcmluZyB0aGUgY29tcG9uZW50LlxuXHQgKiBAdHlwZSB7VE1vZGVsfVxuXHQgKi9cblx0bW9kZWw6IFRNb2RlbDtcbn1cblxubGV0IGN1cnJlbnRGYWtlT3B0aW9uczogTnVsbGFibGU8UmVuZGVyV2l0aE1vZGVsQ29uZmlnPHVua25vd24sIE1lc3NhZ2U+PjtcblxuZnVuY3Rpb24gc2V0RmFrZU9wdGlvbnM8VE1vZGVsIGV4dGVuZHMgb2JqZWN0LCBUTWVzc2FnZSBleHRlbmRzIE1lc3NhZ2U+KFxuXHRvcHRpb25zOiBOdWxsYWJsZTxSZW5kZXJXaXRoTW9kZWxDb25maWc8VE1vZGVsLCBUTWVzc2FnZT4+LFxuKTogdm9pZCB7XG5cdGN1cnJlbnRGYWtlT3B0aW9ucyA9IG9wdGlvbnMgYXMgUmVuZGVyV2l0aE1vZGVsQ29uZmlnPHVua25vd24sIE1lc3NhZ2U+O1xufVxuXG5mdW5jdGlvbiBnZXRGYWtlT3B0aW9uc09uY2U8VE1vZGVsLCBUTWVzc2FnZSBleHRlbmRzIE1lc3NhZ2U+KCk6IE51bGxhYmxlPFJlbmRlcldpdGhNb2RlbENvbmZpZzxUTW9kZWwsIFRNZXNzYWdlPj4ge1xuXHRjb25zdCB0ZW1wID0gY3VycmVudEZha2VPcHRpb25zO1xuXG5cdGN1cnJlbnRGYWtlT3B0aW9ucyA9IG51bGw7XG5cblx0cmV0dXJuIHRlbXAgYXMgUmVuZGVyV2l0aE1vZGVsQ29uZmlnPFRNb2RlbCwgVE1lc3NhZ2U+O1xufVxuXG5leHBvcnQgdHlwZSB7IFJlbmRlcldpdGhNb2RlbE9wdGlvbnMgfTtcblxuZXhwb3J0IHsgZ2V0RmFrZU9wdGlvbnNPbmNlLCBzZXRGYWtlT3B0aW9ucyB9O1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQVNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTs7QUFTQSxJQUFJQSxrQkFBcUU7QUFFekUsU0FBU0MsY0FBY0EsQ0FDdEJDLE9BQTBELEVBQ25EO0VBQ1BGLGtCQUFrQixHQUFHRSxPQUFrRDtBQUN4RTtBQUVBLFNBQVNDLGtCQUFrQkEsQ0FBQSxFQUF3RjtFQUNsSCxJQUFNQyxJQUFJLEdBQUdKLGtCQUFrQjtFQUUvQkEsa0JBQWtCLEdBQUcsSUFBSTtFQUV6QixPQUFPSSxJQUFJO0FBQ1oifQ==
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 { Subscription, SubscriptionResult, UseElmishOptions };
53
+ export { callUpdate, callUpdateMap, useElmish };
package/dist/useElmish.js CHANGED
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
 
3
- function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
3
+ function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
4
4
  Object.defineProperty(exports, "__esModule", {
5
5
  value: true
6
6
  });
@@ -10,22 +10,22 @@ exports.useElmish = useElmish;
10
10
  var _react = require("react");
11
11
  var _Common = require("./Common");
12
12
  var _Init = require("./Init");
13
- var _fakeOptions = require("./Testing/fakeOptions");
13
+ var _fakeOptions = require("./fakeOptions");
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); }
17
- function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
18
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
17
+ function _toArray(arr) { return _arrayWithHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableRest(); }
18
+ function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
19
+ function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
20
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
19
21
  function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
20
22
  function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); }
21
23
  function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
22
- function _toArray(arr) { return _arrayWithHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableRest(); }
23
- function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
24
24
  function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
25
25
  function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
26
26
  function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
27
27
  function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
28
- function _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : "undefined" != typeof Symbol && arr[Symbol.iterator] || arr["@@iterator"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i["return"] && (_r = _i["return"](), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }
28
+ function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t["return"] && (u = t["return"](), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
29
29
  function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; } /* eslint-disable react-hooks/exhaustive-deps */
30
30
  /**
31
31
  * The return type of the `subscription` function.
@@ -54,7 +54,7 @@ function useElmish(_ref) {
54
54
  init = _ref.init,
55
55
  update = _ref.update,
56
56
  subscription = _ref.subscription;
57
- var reentered = false;
57
+ var running = false;
58
58
  var buffer = [];
59
59
  var currentModel = {};
60
60
  var _useState = (0, _react.useState)(null),
@@ -75,37 +75,25 @@ function useElmish(_ref) {
75
75
  }
76
76
  var fakeOptions = (0, _fakeOptions.getFakeOptionsOnce)();
77
77
  var dispatch = (0, _react.useCallback)((_fakeOptions$dispatch = fakeOptions === null || fakeOptions === void 0 ? void 0 : fakeOptions.dispatch) !== null && _fakeOptions$dispatch !== void 0 ? _fakeOptions$dispatch : function (msg) {
78
- if (!initializedModel) {
78
+ if (running) {
79
+ buffer.push(msg);
79
80
  return;
80
81
  }
81
- if (reentered) {
82
- buffer.push(msg);
83
- } else {
84
- reentered = true;
85
- var nextMsg = msg;
86
- var modified = false;
87
- while (nextMsg) {
88
- (0, _Common.logMessage)(name, nextMsg);
89
- var _callUpdate = callUpdate(update, nextMsg, _objectSpread(_objectSpread({}, initializedModel), currentModel), propsRef.current),
90
- _callUpdate2 = _toArray(_callUpdate),
91
- newModel = _callUpdate2[0],
92
- commands = _callUpdate2.slice(1);
93
- if ((0, _Common.modelHasChanged)(currentModel, newModel)) {
94
- currentModel = _objectSpread(_objectSpread({}, currentModel), newModel);
95
- modified = true;
96
- }
97
- _Common.execCmd.apply(void 0, [dispatch].concat(_toConsumableArray(commands)));
98
- nextMsg = buffer.shift();
99
- }
100
- reentered = false;
101
- if (isMountedRef.current && modified) {
102
- setModel(function (prevModel) {
103
- var _Services$logger;
104
- var updatedModel = _objectSpread(_objectSpread({}, prevModel), currentModel);
105
- (_Services$logger = _Init.Services.logger) === null || _Services$logger === void 0 ? void 0 : _Services$logger.debug("Update model for", name, updatedModel);
106
- return updatedModel;
107
- });
108
- }
82
+ running = true;
83
+ var nextMsg = msg;
84
+ var modified = false;
85
+ do {
86
+ modified = handleMessage(nextMsg);
87
+ nextMsg = buffer.shift();
88
+ } while (nextMsg);
89
+ running = false;
90
+ if (isMountedRef.current && modified) {
91
+ setModel(function (prevModel) {
92
+ var _Services$logger;
93
+ var updatedModel = _objectSpread(_objectSpread({}, prevModel), currentModel);
94
+ (_Services$logger = _Init.Services.logger) === null || _Services$logger === void 0 || _Services$logger.debug("Update model for", name, updatedModel);
95
+ return updatedModel;
96
+ });
109
97
  }
110
98
  }, []);
111
99
  if (!initializedModel) {
@@ -116,9 +104,11 @@ function useElmish(_ref) {
116
104
  initCommands = _ref3.slice(1);
117
105
  initializedModel = initModel;
118
106
  setModel(initializedModel);
119
- (_Services$logger2 = _Init.Services.logger) === null || _Services$logger2 === void 0 ? void 0 : _Services$logger2.debug("Initial model for", name, initializedModel);
107
+ (_Services$logger2 = _Init.Services.logger) === null || _Services$logger2 === void 0 || _Services$logger2.debug("Initial model for", name, initializedModel);
120
108
  _Common.execCmd.apply(void 0, [dispatch].concat(_toConsumableArray(initCommands)));
121
109
  }
110
+
111
+ // biome-ignore lint/nursery/useExhaustiveDependencies: We want to run this effect only once
122
112
  (0, _react.useEffect)(function () {
123
113
  if (subscription) {
124
114
  var _subscription = subscription(initializedModel, props),
@@ -130,6 +120,23 @@ function useElmish(_ref) {
130
120
  }
131
121
  }, []);
132
122
  return [initializedModel, dispatch];
123
+ function handleMessage(nextMsg) {
124
+ if (!initializedModel) {
125
+ return false;
126
+ }
127
+ var modified = false;
128
+ (0, _Common.logMessage)(name, nextMsg);
129
+ var _callUpdate = callUpdate(update, nextMsg, _objectSpread(_objectSpread({}, initializedModel), currentModel), propsRef.current),
130
+ _callUpdate2 = _toArray(_callUpdate),
131
+ newModel = _callUpdate2[0],
132
+ commands = _callUpdate2.slice(1);
133
+ if ((0, _Common.modelHasChanged)(currentModel, newModel)) {
134
+ currentModel = _objectSpread(_objectSpread({}, currentModel), newModel);
135
+ modified = true;
136
+ }
137
+ _Common.execCmd.apply(void 0, [dispatch].concat(_toConsumableArray(commands)));
138
+ return modified;
139
+ }
133
140
  }
134
141
  function callUpdate(update, msg, model, props) {
135
142
  if (typeof update === "function") {
@@ -141,4 +148,4 @@ function callUpdateMap(updateMap, msg, model, props) {
141
148
  var msgName = msg.name;
142
149
  return updateMap[msgName](msg, model, props);
143
150
  }
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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"}
151
+ //# 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","_toArray","_arrayWithHoles","_nonIterableRest","iter","Symbol","iterator","from","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty","getOwnPropertyDescriptors","defineProperties","defineProperty","obj","key","value","_toPropertyKey","configurable","writable","arg","_toPrimitive","_typeof","String","input","hint","prim","toPrimitive","undefined","res","call","Number","_slicedToArray","i","_iterableToArrayLimit","minLen","n","prototype","toString","slice","constructor","name","test","len","arr2","l","u","a","f","next","done","useElmish","_ref","_fakeOptions$dispatch","props","init","update","subscription","running","buffer","currentModel","_useState","useState","_useState2","model","setModel","propsRef","useRef","isMountedRef","useEffect","current","initializedModel","fakeOptions","getFakeOptionsOnce","dispatch","useCallback","msg","nextMsg","modified","handleMessage","shift","prevModel","_Services$logger","updatedModel","Services","logger","debug","_Services$logger2","_ref2","_ref3","initModel","initCommands","execCmd","concat","_subscription","_subscription2","subCmd","destructor","logMessage","_callUpdate","callUpdate","_callUpdate2","newModel","commands","modelHasChanged","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 { Cmd, Dispatch, InitFunction, Message, Nullable, UpdateFunction, UpdateMap, UpdateReturnType } from \"./Types\";\nimport { getFakeOptionsOnce } from \"./fakeOptions\";\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 running = 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 (running) {\n\t\t\t\t\tbuffer.push(msg);\n\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\trunning = true;\n\n\t\t\t\tlet nextMsg: TMessage | undefined = msg;\n\t\t\t\tlet modified = false;\n\n\t\t\t\tdo {\n\t\t\t\t\tmodified = handleMessage(nextMsg);\n\n\t\t\t\t\tnextMsg = buffer.shift();\n\t\t\t\t} while (nextMsg);\n\n\t\t\t\trunning = false;\n\n\t\t\t\tif (isMountedRef.current && modified) {\n\t\t\t\t\tsetModel((prevModel) => {\n\t\t\t\t\t\tconst updatedModel = { ...(prevModel as TModel), ...currentModel };\n\n\t\t\t\t\t\tServices.logger?.debug(\"Update model for\", name, updatedModel);\n\n\t\t\t\t\t\treturn updatedModel;\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// biome-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\tfunction handleMessage(nextMsg: TMessage): boolean {\n\t\tif (!initializedModel) {\n\t\t\treturn false;\n\t\t}\n\n\t\tlet modified = false;\n\n\t\tlogMessage(name, nextMsg);\n\n\t\tconst [newModel, ...commands] = callUpdate(update, nextMsg, { ...initializedModel, ...currentModel }, propsRef.current);\n\n\t\tif (modelHasChanged(currentModel, newModel)) {\n\t\t\tcurrentModel = { ...currentModel, ...newModel };\n\n\t\t\tmodified = true;\n\t\t}\n\n\t\texecCmd(dispatch, ...commands);\n\n\t\treturn modified;\n\t}\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 { Subscription, SubscriptionResult, UseElmishOptions };\n\nexport { callUpdate, callUpdateMap, useElmish };\n"],"mappings":"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"}