react-elmish 3.1.0 → 4.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +32 -11
- package/dist/Cmd.d.ts +18 -19
- package/dist/Cmd.js +42 -134
- package/dist/ElmComponent.d.ts +3 -9
- package/dist/ElmComponent.js +29 -23
- package/dist/ErrorHandling.d.ts +33 -0
- package/dist/ErrorHandling.js +58 -0
- package/dist/Init.d.ts +9 -10
- package/dist/Init.js +13 -16
- package/dist/Testing/index.d.ts +5 -11
- package/dist/Testing/index.js +23 -54
- package/dist/Types.d.ts +26 -0
- package/dist/Types.js +6 -0
- package/dist/index.d.ts +4 -3
- package/dist/index.js +12 -6
- package/dist/useElmish.d.ts +9 -9
- package/dist/useElmish.js +22 -13
- package/package.json +18 -16
- package/dist/ElmUtilities.d.ts +0 -32
- package/dist/ElmUtilities.js +0 -35
- package/dist/legacy/useElmish.d.ts +0 -15
- package/dist/legacy/useElmish.js +0 -135
- package/dist/legacy/useElmishMap.d.ts +0 -15
- package/dist/legacy/useElmishMap.js +0 -137
package/README.md
CHANGED
|
@@ -485,30 +485,51 @@ You can handle errors easily with the following pattern.
|
|
|
485
485
|
1. Add an error message:
|
|
486
486
|
|
|
487
487
|
```ts
|
|
488
|
-
import { ErrorMessage, errorMsg, handleError } from "react-elmish";
|
|
488
|
+
import { ErrorMessage, errorHandler, errorMsg, handleError } from "react-elmish";
|
|
489
489
|
|
|
490
490
|
export type Message =
|
|
491
|
-
| ...
|
|
491
|
+
// | ...
|
|
492
492
|
| ErrorMessage;
|
|
493
493
|
```
|
|
494
494
|
|
|
495
|
-
1. Optionally add the convenient function to the
|
|
495
|
+
1. Optionally add the convenient function to the `Msg` object:
|
|
496
496
|
|
|
497
497
|
```ts
|
|
498
498
|
export const Msg = {
|
|
499
|
-
...
|
|
499
|
+
// ...
|
|
500
500
|
...errorMsg,
|
|
501
501
|
}
|
|
502
502
|
```
|
|
503
503
|
|
|
504
|
-
1. Handle the error message
|
|
504
|
+
1. Handle the error message
|
|
505
|
+
1. In the `update` function:
|
|
505
506
|
|
|
506
|
-
|
|
507
|
-
|
|
508
|
-
|
|
509
|
-
|
|
510
|
-
|
|
511
|
-
|
|
507
|
+
```ts
|
|
508
|
+
// ...
|
|
509
|
+
case "error":
|
|
510
|
+
return handleError(msg.error);
|
|
511
|
+
// ...
|
|
512
|
+
```
|
|
513
|
+
|
|
514
|
+
1. Or in the `UpdateMap`:
|
|
515
|
+
|
|
516
|
+
```ts
|
|
517
|
+
const updateMap = {
|
|
518
|
+
// ...
|
|
519
|
+
error ({ error }) {
|
|
520
|
+
return handleError(error);
|
|
521
|
+
}
|
|
522
|
+
};
|
|
523
|
+
```
|
|
524
|
+
|
|
525
|
+
Your can also use the `errorHandler` helper function:
|
|
526
|
+
|
|
527
|
+
```ts
|
|
528
|
+
const updateMap = {
|
|
529
|
+
// ...
|
|
530
|
+
...errorHandler()
|
|
531
|
+
};
|
|
532
|
+
```
|
|
512
533
|
|
|
513
534
|
The **handleError** function then calls your error handling middleware.
|
|
514
535
|
|
package/dist/Cmd.d.ts
CHANGED
|
@@ -1,38 +1,37 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* Type of the dispatch function.
|
|
3
3
|
*/
|
|
4
|
-
|
|
4
|
+
declare type Dispatch<TMsg> = (msg: TMsg) => void;
|
|
5
5
|
declare type FallbackHandler = (error?: Error) => void;
|
|
6
6
|
declare type Sub<TMsg> = (dispatch: Dispatch<TMsg>, fallback?: FallbackHandler) => void;
|
|
7
7
|
/**
|
|
8
8
|
* Type of a command.
|
|
9
9
|
*/
|
|
10
|
-
|
|
10
|
+
declare type Cmd<TMsg> = Sub<TMsg>[];
|
|
11
11
|
/**
|
|
12
|
-
*
|
|
13
|
-
* @
|
|
14
|
-
* @template TMsg Type of the Msg discriminated union.
|
|
12
|
+
* Contains functions to create commands.
|
|
13
|
+
* @template TMsg Type of the Message discriminated union.
|
|
15
14
|
*/
|
|
16
|
-
|
|
15
|
+
interface Command<TMsg> {
|
|
17
16
|
/**
|
|
18
17
|
* Represents an empty command.
|
|
19
18
|
*/
|
|
20
|
-
none:
|
|
19
|
+
none: [];
|
|
21
20
|
/**
|
|
22
21
|
* Creates a command out of a specific message.
|
|
23
22
|
* @param {TMsg} msg The specific message.
|
|
24
23
|
*/
|
|
25
|
-
ofMsg(msg: TMsg)
|
|
24
|
+
ofMsg: (msg: TMsg) => Cmd<TMsg>;
|
|
26
25
|
/**
|
|
27
26
|
* Aggregates multiple commands.
|
|
28
27
|
* @param {Cmd<TMsg> []} commands Array of commands.
|
|
29
28
|
*/
|
|
30
|
-
batch(...commands: Cmd<TMsg>[])
|
|
29
|
+
batch: (...commands: Cmd<TMsg>[]) => Cmd<TMsg>;
|
|
31
30
|
/**
|
|
32
31
|
* Command to call the subscriber.
|
|
33
32
|
* @param {Sub<TMsg>} sub The subscriber function.
|
|
34
33
|
*/
|
|
35
|
-
ofSub(sub: Sub<TMsg>)
|
|
34
|
+
ofSub: (sub: Sub<TMsg>) => Cmd<TMsg>;
|
|
36
35
|
/**
|
|
37
36
|
* Provides functionalities to create commands from simple functions.
|
|
38
37
|
*/
|
|
@@ -44,21 +43,21 @@ declare class Command<TMsg> {
|
|
|
44
43
|
* @param ofError Creates the message to dispatch when an error occurred.
|
|
45
44
|
* @param args The parameters of the task.
|
|
46
45
|
*/
|
|
47
|
-
either<TArgs extends unknown[], TReturn>(task: (...args: TArgs) => TReturn, ofSuccess: (result: TReturn) => TMsg, ofError: (error: Error) => TMsg, ...args: TArgs)
|
|
46
|
+
either: <TArgs extends unknown[], TReturn>(task: (...args: TArgs) => TReturn, ofSuccess: (result: TReturn) => TMsg, ofError: (error: Error) => TMsg, ...args: TArgs) => Cmd<TMsg>;
|
|
48
47
|
/**
|
|
49
48
|
* Creates a command out of a simple function and ignores the error case.
|
|
50
49
|
* @param task The function to call.
|
|
51
50
|
* @param ofSuccess Creates the message to dispatch after a successful call of the task.
|
|
52
51
|
* @param args The parameters of the task.
|
|
53
52
|
*/
|
|
54
|
-
perform<
|
|
53
|
+
perform: <TArgs extends unknown[], TReturn>(task: (...args: TArgs) => TReturn, ofSuccess: (result: TReturn) => TMsg, ...args: TArgs) => Cmd<TMsg>;
|
|
55
54
|
/**
|
|
56
55
|
* Creates a command out of a simple function and ignores the success case.
|
|
57
56
|
* @param task The function to call.
|
|
58
57
|
* @param ofError Creates the message to dispatch when an error occurred.
|
|
59
58
|
* @param args The parameters of the task.
|
|
60
59
|
*/
|
|
61
|
-
attempt<
|
|
60
|
+
attempt: <TArgs extends unknown[], TReturn>(task: (...args: TArgs) => TReturn, ofError: (error: Error) => TMsg, ...args: TArgs) => Cmd<TMsg>;
|
|
62
61
|
};
|
|
63
62
|
/**
|
|
64
63
|
* Provides functionalities to create commands from async functions.
|
|
@@ -71,27 +70,27 @@ declare class Command<TMsg> {
|
|
|
71
70
|
* @param ofError Creates the message to dispatch when the promise is rejected.
|
|
72
71
|
* @param args The parameters of the task.
|
|
73
72
|
*/
|
|
74
|
-
either<TArgs extends unknown[], TReturn>(task: (...args: TArgs) => Promise<TReturn>, ofSuccess: (result: TReturn) => TMsg, ofError: (error: Error) => TMsg, ...args: TArgs)
|
|
73
|
+
either: <TArgs extends unknown[], TReturn>(task: (...args: TArgs) => Promise<TReturn>, ofSuccess: (result: TReturn) => TMsg, ofError: (error: Error) => TMsg, ...args: TArgs) => Cmd<TMsg>;
|
|
75
74
|
/**
|
|
76
75
|
* Creates a command out of an async function and ignores the error case.
|
|
77
76
|
* @param task The async function to call.
|
|
78
77
|
* @param ofSuccess Creates the message to dispatch when the promise is resolved.
|
|
79
78
|
* @param args The parameters of the task.
|
|
80
79
|
*/
|
|
81
|
-
perform<
|
|
80
|
+
perform: <TArgs extends unknown[], TReturn>(task: (...args: TArgs) => Promise<TReturn>, ofSuccess: (result: TReturn) => TMsg, ...args: TArgs) => Cmd<TMsg>;
|
|
82
81
|
/**
|
|
83
82
|
* Creates a command out of an async function and ignores the success case.
|
|
84
83
|
* @param task The async function to call.
|
|
85
84
|
* @param ofError Creates the message to dispatch when the promise is rejected.
|
|
86
85
|
* @param args The parameters of the task.
|
|
87
86
|
*/
|
|
88
|
-
attempt<
|
|
87
|
+
attempt: <TArgs extends unknown[], TReturn>(task: (...args: TArgs) => Promise<TReturn>, ofError: (error: Error) => TMsg, ...args: TArgs) => Cmd<TMsg>;
|
|
89
88
|
};
|
|
90
89
|
}
|
|
91
90
|
/**
|
|
92
91
|
* Creates a typed instance of the Command class.
|
|
93
92
|
* @template TMsg The type of the Msg discriminated union.
|
|
94
|
-
* @see Command
|
|
95
93
|
*/
|
|
96
|
-
|
|
97
|
-
export {};
|
|
94
|
+
declare function createCmd<TMsg>(): Command<TMsg>;
|
|
95
|
+
export type { Dispatch, Cmd, };
|
|
96
|
+
export { createCmd, };
|
package/dist/Cmd.js
CHANGED
|
@@ -5,14 +5,6 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
5
5
|
});
|
|
6
6
|
exports.createCmd = createCmd;
|
|
7
7
|
|
|
8
|
-
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
|
9
|
-
|
|
10
|
-
function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
|
|
11
|
-
|
|
12
|
-
function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
|
13
|
-
|
|
14
|
-
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
15
|
-
|
|
16
8
|
/**
|
|
17
9
|
* Type of the dispatch function.
|
|
18
10
|
*/
|
|
@@ -22,27 +14,36 @@ function _defineProperty(obj, key, value) { if (key in obj) { Object.definePrope
|
|
|
22
14
|
*/
|
|
23
15
|
|
|
24
16
|
/**
|
|
25
|
-
*
|
|
26
|
-
* @
|
|
27
|
-
|
|
17
|
+
* Contains functions to create commands.
|
|
18
|
+
* @template TMsg Type of the Message discriminated union.
|
|
19
|
+
*/
|
|
20
|
+
|
|
21
|
+
/**
|
|
22
|
+
* Creates a typed instance of the Command class.
|
|
23
|
+
* @template TMsg The type of the Msg discriminated union.
|
|
28
24
|
*/
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
25
|
+
function createCmd() {
|
|
26
|
+
return {
|
|
27
|
+
none: [],
|
|
28
|
+
ofMsg: function ofMsg(msg) {
|
|
29
|
+
return [function (dispatch) {
|
|
30
|
+
return dispatch(msg);
|
|
31
|
+
}];
|
|
32
|
+
},
|
|
33
|
+
batch: function batch() {
|
|
34
|
+
for (var _len = arguments.length, commands = new Array(_len), _key = 0; _key < _len; _key++) {
|
|
35
|
+
commands[_key] = arguments[_key];
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
return commands.flat();
|
|
39
|
+
},
|
|
40
|
+
ofSub: function ofSub(sub) {
|
|
41
|
+
return [sub];
|
|
42
|
+
},
|
|
43
|
+
ofFunc: {
|
|
43
44
|
either: function either(task, ofSuccess, ofError) {
|
|
44
|
-
for (var
|
|
45
|
-
args[
|
|
45
|
+
for (var _len2 = arguments.length, args = new Array(_len2 > 3 ? _len2 - 3 : 0), _key2 = 3; _key2 < _len2; _key2++) {
|
|
46
|
+
args[_key2 - 3] = arguments[_key2];
|
|
46
47
|
}
|
|
47
48
|
|
|
48
49
|
var bind = function bind(dispatch) {
|
|
@@ -57,16 +58,9 @@ var Command = /*#__PURE__*/function () {
|
|
|
57
58
|
|
|
58
59
|
return [bind];
|
|
59
60
|
},
|
|
60
|
-
|
|
61
|
-
/**
|
|
62
|
-
* Creates a command out of a simple function and ignores the error case.
|
|
63
|
-
* @param task The function to call.
|
|
64
|
-
* @param ofSuccess Creates the message to dispatch after a successful call of the task.
|
|
65
|
-
* @param args The parameters of the task.
|
|
66
|
-
*/
|
|
67
61
|
perform: function perform(task, ofSuccess) {
|
|
68
|
-
for (var
|
|
69
|
-
args[
|
|
62
|
+
for (var _len3 = arguments.length, args = new Array(_len3 > 2 ? _len3 - 2 : 0), _key3 = 2; _key3 < _len3; _key3++) {
|
|
63
|
+
args[_key3 - 2] = arguments[_key3];
|
|
70
64
|
}
|
|
71
65
|
|
|
72
66
|
var bind = function bind(dispatch, fallback) {
|
|
@@ -83,16 +77,9 @@ var Command = /*#__PURE__*/function () {
|
|
|
83
77
|
|
|
84
78
|
return [bind];
|
|
85
79
|
},
|
|
86
|
-
|
|
87
|
-
/**
|
|
88
|
-
* Creates a command out of a simple function and ignores the success case.
|
|
89
|
-
* @param task The function to call.
|
|
90
|
-
* @param ofError Creates the message to dispatch when an error occurred.
|
|
91
|
-
* @param args The parameters of the task.
|
|
92
|
-
*/
|
|
93
80
|
attempt: function attempt(task, ofError) {
|
|
94
|
-
for (var
|
|
95
|
-
args[
|
|
81
|
+
for (var _len4 = arguments.length, args = new Array(_len4 > 2 ? _len4 - 2 : 0), _key4 = 2; _key4 < _len4; _key4++) {
|
|
82
|
+
args[_key4 - 2] = arguments[_key4];
|
|
96
83
|
}
|
|
97
84
|
|
|
98
85
|
var bind = function bind(dispatch, fallback) {
|
|
@@ -109,19 +96,11 @@ var Command = /*#__PURE__*/function () {
|
|
|
109
96
|
|
|
110
97
|
return [bind];
|
|
111
98
|
}
|
|
112
|
-
}
|
|
113
|
-
|
|
114
|
-
_defineProperty(this, "ofPromise", {
|
|
115
|
-
/**
|
|
116
|
-
* Creates a command out of an async function and maps the result.
|
|
117
|
-
* @param task The async function to call.
|
|
118
|
-
* @param ofSuccess Creates the message to dispatch when the promise is resolved.
|
|
119
|
-
* @param ofError Creates the message to dispatch when the promise is rejected.
|
|
120
|
-
* @param args The parameters of the task.
|
|
121
|
-
*/
|
|
99
|
+
},
|
|
100
|
+
ofPromise: {
|
|
122
101
|
either: function either(task, ofSuccess, ofError) {
|
|
123
|
-
for (var
|
|
124
|
-
args[
|
|
102
|
+
for (var _len5 = arguments.length, args = new Array(_len5 > 3 ? _len5 - 3 : 0), _key5 = 3; _key5 < _len5; _key5++) {
|
|
103
|
+
args[_key5 - 3] = arguments[_key5];
|
|
125
104
|
}
|
|
126
105
|
|
|
127
106
|
var bind = function bind(dispatch) {
|
|
@@ -134,16 +113,9 @@ var Command = /*#__PURE__*/function () {
|
|
|
134
113
|
|
|
135
114
|
return [bind];
|
|
136
115
|
},
|
|
137
|
-
|
|
138
|
-
/**
|
|
139
|
-
* Creates a command out of an async function and ignores the error case.
|
|
140
|
-
* @param task The async function to call.
|
|
141
|
-
* @param ofSuccess Creates the message to dispatch when the promise is resolved.
|
|
142
|
-
* @param args The parameters of the task.
|
|
143
|
-
*/
|
|
144
116
|
perform: function perform(task, ofSuccess) {
|
|
145
|
-
for (var
|
|
146
|
-
args[
|
|
117
|
+
for (var _len6 = arguments.length, args = new Array(_len6 > 2 ? _len6 - 2 : 0), _key6 = 2; _key6 < _len6; _key6++) {
|
|
118
|
+
args[_key6 - 2] = arguments[_key6];
|
|
147
119
|
}
|
|
148
120
|
|
|
149
121
|
var defaultFallbackHandler = function defaultFallbackHandler() {// blank
|
|
@@ -158,16 +130,9 @@ var Command = /*#__PURE__*/function () {
|
|
|
158
130
|
|
|
159
131
|
return [bind];
|
|
160
132
|
},
|
|
161
|
-
|
|
162
|
-
/**
|
|
163
|
-
* Creates a command out of an async function and ignores the success case.
|
|
164
|
-
* @param task The async function to call.
|
|
165
|
-
* @param ofError Creates the message to dispatch when the promise is rejected.
|
|
166
|
-
* @param args The parameters of the task.
|
|
167
|
-
*/
|
|
168
133
|
attempt: function attempt(task, ofError) {
|
|
169
|
-
for (var
|
|
170
|
-
args[
|
|
134
|
+
for (var _len7 = arguments.length, args = new Array(_len7 > 2 ? _len7 - 2 : 0), _key7 = 2; _key7 < _len7; _key7++) {
|
|
135
|
+
args[_key7 - 2] = arguments[_key7];
|
|
171
136
|
}
|
|
172
137
|
|
|
173
138
|
var bind = function bind(dispatch, fallback) {
|
|
@@ -182,64 +147,7 @@ var Command = /*#__PURE__*/function () {
|
|
|
182
147
|
|
|
183
148
|
return [bind];
|
|
184
149
|
}
|
|
185
|
-
});
|
|
186
|
-
}
|
|
187
|
-
|
|
188
|
-
_createClass(Command, [{
|
|
189
|
-
key: "ofMsg",
|
|
190
|
-
value:
|
|
191
|
-
/**
|
|
192
|
-
* Creates a command out of a specific message.
|
|
193
|
-
* @param {TMsg} msg The specific message.
|
|
194
|
-
*/
|
|
195
|
-
// eslint-disable-next-line class-methods-use-this
|
|
196
|
-
function ofMsg(msg) {
|
|
197
|
-
return [function (dispatch) {
|
|
198
|
-
return dispatch(msg);
|
|
199
|
-
}];
|
|
200
|
-
}
|
|
201
|
-
/**
|
|
202
|
-
* Aggregates multiple commands.
|
|
203
|
-
* @param {Cmd<TMsg> []} commands Array of commands.
|
|
204
|
-
*/
|
|
205
|
-
// eslint-disable-next-line class-methods-use-this
|
|
206
|
-
|
|
207
|
-
}, {
|
|
208
|
-
key: "batch",
|
|
209
|
-
value: function batch() {
|
|
210
|
-
for (var _len7 = arguments.length, commands = new Array(_len7), _key7 = 0; _key7 < _len7; _key7++) {
|
|
211
|
-
commands[_key7] = arguments[_key7];
|
|
212
|
-
}
|
|
213
|
-
|
|
214
|
-
return commands.flat();
|
|
215
150
|
}
|
|
216
|
-
|
|
217
|
-
* Command to call the subscriber.
|
|
218
|
-
* @param {Sub<TMsg>} sub The subscriber function.
|
|
219
|
-
*/
|
|
220
|
-
// eslint-disable-next-line class-methods-use-this
|
|
221
|
-
|
|
222
|
-
}, {
|
|
223
|
-
key: "ofSub",
|
|
224
|
-
value: function ofSub(sub) {
|
|
225
|
-
return [sub];
|
|
226
|
-
}
|
|
227
|
-
/**
|
|
228
|
-
* Provides functionalities to create commands from simple functions.
|
|
229
|
-
*/
|
|
230
|
-
|
|
231
|
-
}]);
|
|
232
|
-
|
|
233
|
-
return Command;
|
|
234
|
-
}();
|
|
235
|
-
/**
|
|
236
|
-
* Creates a typed instance of the Command class.
|
|
237
|
-
* @template TMsg The type of the Msg discriminated union.
|
|
238
|
-
* @see Command
|
|
239
|
-
*/
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
function createCmd() {
|
|
243
|
-
return new Command();
|
|
151
|
+
};
|
|
244
152
|
}
|
|
245
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/Cmd.ts"],"names":["Command","either","task","ofSuccess","ofError","args","bind","dispatch","result","ex","perform","fallback","attempt","then","defaultFallbackHandler","msg","commands","flat","sub","createCmd"],"mappings":"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","sourcesContent":["/**\n * Type of the dispatch function.\n */\nexport type Dispatch<TMsg> = (msg: TMsg) => void;\n\ntype FallbackHandler = (error?: Error) => void;\ntype Sub<TMsg> = (dispatch: Dispatch<TMsg>, fallback?: FallbackHandler) => void;\n\n/**\n * Type of a command.\n */\nexport type Cmd<TMsg> = Sub<TMsg> [];\n\n/**\n * Class to create commands.\n * @class Command\n * @template TMsg Type of the Msg discriminated union.\n */\nclass Command<TMsg> {\n    /**\n     * Represents an empty command.\n     */\n    public none = [];\n\n    /**\n     * Creates a command out of a specific message.\n     * @param {TMsg} msg The specific message.\n     */\n    // eslint-disable-next-line class-methods-use-this\n    public ofMsg (msg: TMsg): Cmd<TMsg> {\n        return [dispatch => dispatch(msg)];\n    }\n\n    /**\n     * Aggregates multiple commands.\n     * @param {Cmd<TMsg> []} commands Array of commands.\n     */\n    // eslint-disable-next-line class-methods-use-this\n    public batch (...commands: Cmd<TMsg> []): Cmd<TMsg> {\n        return commands.flat();\n    }\n\n    /**\n     * Command to call the subscriber.\n     * @param {Sub<TMsg>} sub The subscriber function.\n     */\n    // eslint-disable-next-line class-methods-use-this\n    public ofSub (sub: Sub<TMsg>): Cmd<TMsg> {\n        return [sub];\n    }\n\n    /**\n     * Provides functionalities to create commands from simple functions.\n     */\n    public ofFunc = {\n        /**\n        * Creates a command out of a simple function and maps the result.\n        * @param task The function to call.\n        * @param ofSuccess Creates the message to dispatch after a successful call of the task.\n        * @param ofError Creates the message to dispatch when an error occurred.\n        * @param args The parameters of the task.\n        */\n        either<TArgs extends unknown [], TReturn>(task: (...args: TArgs) => TReturn, ofSuccess: (result: TReturn) => TMsg, ofError: (error: Error) => TMsg, ...args: TArgs): Cmd<TMsg> {\n            const bind = (dispatch: Dispatch<TMsg>): 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<TArgs extends unknown [], TReturn>(task: (...args: TArgs) => TReturn, ofSuccess: (result: TReturn) => TMsg, ...args: TArgs): Cmd<TMsg> {\n            const bind = (dispatch: Dispatch<TMsg>, 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<TArgs extends unknown [], TReturn>(task: (...args: TArgs) => TReturn, ofError: (error: Error) => TMsg, ...args: TArgs): Cmd<TMsg> {\n            const bind = (dispatch: Dispatch<TMsg>, 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    public ofPromise = {\n        /**\n        * Creates a command out of an async function and maps the result.\n        * @param task The async function to call.\n        * @param ofSuccess Creates the message to dispatch when the promise is resolved.\n        * @param ofError Creates the message to dispatch when the promise is rejected.\n        * @param args The parameters of the task.\n        */\n        either<TArgs extends unknown [], TReturn>(task: (...args: TArgs) => Promise<TReturn>, ofSuccess: (result: TReturn) => TMsg, ofError: (error: Error) => TMsg, ...args: TArgs): Cmd<TMsg> {\n            const bind = (dispatch: Dispatch<TMsg>): void => {\n                task(...args).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<TArgs extends unknown [], TReturn>(task: (...args: TArgs) => Promise<TReturn>, ofSuccess: (result: TReturn) => TMsg, ...args: TArgs): Cmd<TMsg> {\n            const defaultFallbackHandler = (): void => {\n                // blank\n            };\n\n            const bind = (dispatch: Dispatch<TMsg>, fallback: FallbackHandler = defaultFallbackHandler): void => {\n                task(...args).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<TArgs extends unknown [], TReturn>(task: (...args: TArgs) => Promise<TReturn>, ofError: (error: Error) => TMsg, ...args: TArgs): Cmd<TMsg> {\n            const bind = (dispatch: Dispatch<TMsg>, fallback?: FallbackHandler): void => {\n                task(...args).then(() => {\n                    if (fallback) {\n                        fallback();\n                    }\n                })\n                    .catch((ex: Error) => dispatch(ofError(ex)));\n            };\n\n            return [bind];\n        },\n    };\n}\n\n/**\n * Creates a typed instance of the Command class.\n * @template TMsg The type of the Msg discriminated union.\n * @see Command\n */\nexport function createCmd<TMsg> (): Command<TMsg> {\n    return new Command<TMsg>();\n}"]}
|
|
153
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["createCmd","none","ofMsg","msg","dispatch","batch","commands","flat","ofSub","sub","ofFunc","either","task","ofSuccess","ofError","args","bind","result","ex","perform","fallback","attempt","ofPromise","then","defaultFallbackHandler"],"sources":["../src/Cmd.ts"],"sourcesContent":["/**\n * Type of the dispatch function.\n */\ntype Dispatch<TMsg> = (msg: TMsg) => void;\n\ntype FallbackHandler = (error?: Error) => void;\ntype Sub<TMsg> = (dispatch: Dispatch<TMsg>, fallback?: FallbackHandler) => void;\n\n/**\n * Type of a command.\n */\ntype Cmd<TMsg> = Sub<TMsg> [];\n\n/**\n * Contains functions to create commands.\n * @template TMsg Type of the Message discriminated union.\n */\ninterface Command<TMsg> {\n    /**\n     * Represents an empty command.\n     */\n    none: [],\n    /**\n     * Creates a command out of a specific message.\n     * @param {TMsg} msg The specific message.\n     */\n    ofMsg: (msg: TMsg) => Cmd<TMsg>,\n    /**\n     * Aggregates multiple commands.\n     * @param {Cmd<TMsg> []} commands Array of commands.\n     */\n    batch: (...commands: Cmd<TMsg> []) => Cmd<TMsg>,\n    /**\n     * Command to call the subscriber.\n     * @param {Sub<TMsg>} sub The subscriber function.\n     */\n    ofSub: (sub: Sub<TMsg>) => Cmd<TMsg>,\n    /**\n     * Provides functionalities to create commands from simple functions.\n     */\n    ofFunc: {\n        /**\n        * Creates a command out of a simple function and maps the result.\n        * @param task The function to call.\n        * @param ofSuccess Creates the message to dispatch after a successful call of the task.\n        * @param ofError Creates the message to dispatch when an error occurred.\n        * @param args The parameters of the task.\n        */\n        either: <TArgs extends unknown [], TReturn>(task: (...args: TArgs) => TReturn, ofSuccess: (result: TReturn) => TMsg, ofError: (error: Error) => TMsg, ...args: TArgs) => Cmd<TMsg>,\n        /**\n        * Creates a command out of a simple function and ignores the error case.\n        * @param task The function to call.\n        * @param ofSuccess Creates the message to dispatch after a successful call of the task.\n        * @param args The parameters of the task.\n        */\n        perform: <TArgs extends unknown [], TReturn>(task: (...args: TArgs) => TReturn, ofSuccess: (result: TReturn) => TMsg, ...args: TArgs) => Cmd<TMsg>,\n        /**\n        * Creates a command out of a simple function and ignores the success case.\n        * @param task The function to call.\n        * @param ofError Creates the message to dispatch when an error occurred.\n        * @param args The parameters of the task.\n        */\n        attempt: <TArgs extends unknown [], TReturn>(task: (...args: TArgs) => TReturn, ofError: (error: Error) => TMsg, ...args: TArgs) => Cmd<TMsg>,\n    },\n    /**\n     * Provides functionalities to create commands from async functions.\n     */\n    ofPromise: {\n        /**\n        * Creates a command out of an async function and maps the result.\n        * @param task The async function to call.\n        * @param ofSuccess Creates the message to dispatch when the promise is resolved.\n        * @param ofError Creates the message to dispatch when the promise is rejected.\n        * @param args The parameters of the task.\n        */\n        either: <TArgs extends unknown [], TReturn>(task: (...args: TArgs) => Promise<TReturn>, ofSuccess: (result: TReturn) => TMsg, ofError: (error: Error) => TMsg, ...args: TArgs) => Cmd<TMsg>,\n        /**\n        * Creates a command out of an async function and ignores the error case.\n        * @param task The async function to call.\n        * @param ofSuccess Creates the message to dispatch when the promise is resolved.\n        * @param args The parameters of the task.\n        */\n        perform: <TArgs extends unknown [], TReturn>(task: (...args: TArgs) => Promise<TReturn>, ofSuccess: (result: TReturn) => TMsg, ...args: TArgs) => Cmd<TMsg>,\n        /**\n        * Creates a command out of an async function and ignores the success case.\n        * @param task The async function to call.\n        * @param ofError Creates the message to dispatch when the promise is rejected.\n        * @param args The parameters of the task.\n        */\n        attempt: <TArgs extends unknown [], TReturn>(task: (...args: TArgs) => Promise<TReturn>, ofError: (error: Error) => TMsg, ...args: TArgs) => Cmd<TMsg>,\n    },\n}\n\n/**\n * Creates a typed instance of the Command class.\n * @template TMsg The type of the Msg discriminated union.\n */\nfunction createCmd<TMsg> (): Command<TMsg> {\n    return {\n        none: [],\n        ofMsg (msg: TMsg): Cmd<TMsg> {\n            return [dispatch => dispatch(msg)];\n        },\n        batch (...commands: Cmd<TMsg> []): Cmd<TMsg> {\n            return commands.flat();\n        },\n        ofSub (sub: Sub<TMsg>): Cmd<TMsg> {\n            return [sub];\n        },\n        ofFunc: {\n            either<TArgs extends unknown [], TReturn>(task: (...args: TArgs) => TReturn, ofSuccess: (result: TReturn) => TMsg, ofError: (error: Error) => TMsg, ...args: TArgs): Cmd<TMsg> {\n                const bind = (dispatch: Dispatch<TMsg>): void => {\n                    try {\n                        const result = task(...args);\n\n                        dispatch(ofSuccess(result));\n                    } catch (ex: unknown) {\n                        dispatch(ofError(ex as Error));\n                    }\n                };\n\n                return [bind];\n            },\n            perform<TArgs extends unknown [], TReturn>(task: (...args: TArgs) => TReturn, ofSuccess: (result: TReturn) => TMsg, ...args: TArgs): Cmd<TMsg> {\n                const bind = (dispatch: Dispatch<TMsg>, fallback?: FallbackHandler): void => {\n                    try {\n                        const result = task(...args);\n\n                        dispatch(ofSuccess(result));\n                    } catch (ex: unknown) {\n                        if (fallback) {\n                            fallback(ex as Error);\n                        }\n                    }\n                };\n\n                return [bind];\n            },\n            attempt<TArgs extends unknown [], TReturn>(task: (...args: TArgs) => TReturn, ofError: (error: Error) => TMsg, ...args: TArgs): Cmd<TMsg> {\n                const bind = (dispatch: Dispatch<TMsg>, fallback?: FallbackHandler): void => {\n                    try {\n                        task(...args);\n\n                        if (fallback) {\n                            fallback();\n                        }\n                    } catch (ex: unknown) {\n                        dispatch(ofError(ex as Error));\n                    }\n                };\n\n                return [bind];\n            },\n        },\n        ofPromise: {\n            either<TArgs extends unknown [], TReturn>(task: (...args: TArgs) => Promise<TReturn>, ofSuccess: (result: TReturn) => TMsg, ofError: (error: Error) => TMsg, ...args: TArgs): Cmd<TMsg> {\n                const bind = (dispatch: Dispatch<TMsg>): void => {\n                    task(...args).then(result => dispatch(ofSuccess(result)))\n                        .catch((ex: Error) => dispatch(ofError(ex)));\n                };\n\n                return [bind];\n            },\n            perform<TArgs extends unknown [], TReturn>(task: (...args: TArgs) => Promise<TReturn>, ofSuccess: (result: TReturn) => TMsg, ...args: TArgs): Cmd<TMsg> {\n                const defaultFallbackHandler = (): void => {\n                    // blank\n                };\n\n                const bind = (dispatch: Dispatch<TMsg>, fallback: FallbackHandler = defaultFallbackHandler): void => {\n                    task(...args).then(result => dispatch(ofSuccess(result)))\n                        .catch(fallback);\n                };\n\n                return [bind];\n            },\n            attempt<TArgs extends unknown [], TReturn>(task: (...args: TArgs) => Promise<TReturn>, ofError: (error: Error) => TMsg, ...args: TArgs): Cmd<TMsg> {\n                const bind = (dispatch: Dispatch<TMsg>, fallback?: FallbackHandler): void => {\n                    task(...args).then(() => {\n                        if (fallback) {\n                            fallback();\n                        }\n                    })\n                        .catch((ex: Error) => dispatch(ofError(ex)));\n                };\n\n                return [bind];\n            },\n        },\n    };\n}\n\nexport type {\n    Dispatch,\n    Cmd,\n};\n\nexport {\n    createCmd,\n};"],"mappings":"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"}
|
package/dist/ElmComponent.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
+
import { InitFunction, UpdateFunction } from "./Types";
|
|
1
2
|
import { Message } from "./Init";
|
|
2
|
-
import { Cmd } from "./Cmd";
|
|
3
3
|
import React from "react";
|
|
4
4
|
/**
|
|
5
5
|
* Abstract class for a react class component using the elmish pattern.
|
|
@@ -11,7 +11,7 @@ import React from "react";
|
|
|
11
11
|
* @template TMsg The type of the messages.
|
|
12
12
|
* @template TProps The type of the props.
|
|
13
13
|
*/
|
|
14
|
-
|
|
14
|
+
declare abstract class ElmComponent<TModel, TMsg extends Message, TProps> extends React.Component<TProps> {
|
|
15
15
|
private initCmd;
|
|
16
16
|
private readonly componentName;
|
|
17
17
|
private readonly buffer;
|
|
@@ -63,10 +63,4 @@ export declare abstract class ElmComponent<TModel, TMsg extends Message, TProps>
|
|
|
63
63
|
*/
|
|
64
64
|
abstract update: UpdateFunction<TProps, TModel, TMsg>;
|
|
65
65
|
}
|
|
66
|
-
export
|
|
67
|
-
export declare type InitFunction<TProps, TModel, TMessage> = (props: TProps) => InitResult<TModel, TMessage>;
|
|
68
|
-
/**
|
|
69
|
-
* Type for the return value of the update function.
|
|
70
|
-
*/
|
|
71
|
-
export declare type UpdateReturnType<TModel, TMsg> = [Partial<TModel>, Cmd<TMsg>?];
|
|
72
|
-
export declare type UpdateFunction<TProps, TModel, TMsg> = (model: TModel, msg: TMsg, props: TProps) => UpdateReturnType<TModel, TMsg>;
|
|
66
|
+
export { ElmComponent, };
|