react-elmish 4.2.0-beta.3 → 4.2.0-beta.4
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.
|
@@ -1,5 +1,7 @@
|
|
|
1
1
|
import { InitResult, MessageBase, Nullable } from "../Types";
|
|
2
|
+
import { Dispatch } from "../Cmd";
|
|
2
3
|
declare type FakeInitResult = Nullable<[unknown, unknown?]>;
|
|
3
|
-
declare function
|
|
4
|
+
declare function setFakes(fakeInitResult: FakeInitResult, fakeDispatch?: Nullable<Dispatch<MessageBase>>): void;
|
|
4
5
|
declare function getFakeInitResultOnce<TModel, TMessage extends MessageBase>(): Nullable<InitResult<TModel, TMessage>>;
|
|
5
|
-
|
|
6
|
+
declare function getFakeDispatchOnce<TMessage extends MessageBase>(): Nullable<Dispatch<TMessage>>;
|
|
7
|
+
export { setFakes, getFakeInitResultOnce, getFakeDispatchOnce, };
|
|
@@ -3,17 +3,26 @@
|
|
|
3
3
|
Object.defineProperty(exports, "__esModule", {
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
|
+
exports.getFakeDispatchOnce = getFakeDispatchOnce;
|
|
6
7
|
exports.getFakeInitResultOnce = getFakeInitResultOnce;
|
|
7
|
-
exports.
|
|
8
|
-
var
|
|
8
|
+
exports.setFakes = setFakes;
|
|
9
|
+
var currentFakeInitResult;
|
|
10
|
+
var currentFakeDispatch;
|
|
9
11
|
|
|
10
|
-
function
|
|
11
|
-
|
|
12
|
+
function setFakes(fakeInitResult, fakeDispatch) {
|
|
13
|
+
currentFakeInitResult = fakeInitResult;
|
|
14
|
+
currentFakeDispatch = fakeDispatch !== null && fakeDispatch !== void 0 ? fakeDispatch : null;
|
|
12
15
|
}
|
|
13
16
|
|
|
14
17
|
function getFakeInitResultOnce() {
|
|
15
|
-
var temp =
|
|
16
|
-
|
|
18
|
+
var temp = currentFakeInitResult;
|
|
19
|
+
currentFakeInitResult = null;
|
|
17
20
|
return temp;
|
|
18
21
|
}
|
|
19
|
-
|
|
22
|
+
|
|
23
|
+
function getFakeDispatchOnce() {
|
|
24
|
+
var temp = currentFakeDispatch;
|
|
25
|
+
currentFakeDispatch = null;
|
|
26
|
+
return temp;
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjdXJyZW50RmFrZUluaXRSZXN1bHQiLCJjdXJyZW50RmFrZURpc3BhdGNoIiwic2V0RmFrZXMiLCJmYWtlSW5pdFJlc3VsdCIsImZha2VEaXNwYXRjaCIsImdldEZha2VJbml0UmVzdWx0T25jZSIsInRlbXAiLCJnZXRGYWtlRGlzcGF0Y2hPbmNlIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL1Rlc3RpbmcvZmFrZUluaXRSZXN1bHQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5pdFJlc3VsdCwgTWVzc2FnZUJhc2UsIE51bGxhYmxlIH0gZnJvbSBcIi4uL1R5cGVzXCI7XG5pbXBvcnQgeyBEaXNwYXRjaCB9IGZyb20gXCIuLi9DbWRcIjtcblxudHlwZSBGYWtlSW5pdFJlc3VsdCA9IE51bGxhYmxlPFt1bmtub3duLCB1bmtub3duP10+O1xuXG5sZXQgY3VycmVudEZha2VJbml0UmVzdWx0OiBGYWtlSW5pdFJlc3VsdDtcbmxldCBjdXJyZW50RmFrZURpc3BhdGNoOiBOdWxsYWJsZTxEaXNwYXRjaDxNZXNzYWdlQmFzZT4+O1xuXG5mdW5jdGlvbiBzZXRGYWtlcyAoZmFrZUluaXRSZXN1bHQ6IEZha2VJbml0UmVzdWx0LCBmYWtlRGlzcGF0Y2g/OiBOdWxsYWJsZTxEaXNwYXRjaDxNZXNzYWdlQmFzZT4+KTogdm9pZCB7XG4gICAgY3VycmVudEZha2VJbml0UmVzdWx0ID0gZmFrZUluaXRSZXN1bHQ7XG4gICAgY3VycmVudEZha2VEaXNwYXRjaCA9IGZha2VEaXNwYXRjaCA/PyBudWxsO1xufVxuXG5mdW5jdGlvbiBnZXRGYWtlSW5pdFJlc3VsdE9uY2U8VE1vZGVsLCBUTWVzc2FnZSBleHRlbmRzIE1lc3NhZ2VCYXNlPiAoKTogTnVsbGFibGU8SW5pdFJlc3VsdDxUTW9kZWwsIFRNZXNzYWdlPj4ge1xuICAgIGNvbnN0IHRlbXAgPSBjdXJyZW50RmFrZUluaXRSZXN1bHQgYXMgTnVsbGFibGU8SW5pdFJlc3VsdDxUTW9kZWwsIFRNZXNzYWdlPj47XG5cbiAgICBjdXJyZW50RmFrZUluaXRSZXN1bHQgPSBudWxsO1xuXG4gICAgcmV0dXJuIHRlbXA7XG59XG5cbmZ1bmN0aW9uIGdldEZha2VEaXNwYXRjaE9uY2U8VE1lc3NhZ2UgZXh0ZW5kcyBNZXNzYWdlQmFzZT4gKCk6IE51bGxhYmxlPERpc3BhdGNoPFRNZXNzYWdlPj4ge1xuICAgIGNvbnN0IHRlbXAgPSBjdXJyZW50RmFrZURpc3BhdGNoO1xuXG4gICAgY3VycmVudEZha2VEaXNwYXRjaCA9IG51bGw7XG5cbiAgICByZXR1cm4gdGVtcDtcbn1cblxuZXhwb3J0IHtcbiAgICBzZXRGYWtlcyxcbiAgICBnZXRGYWtlSW5pdFJlc3VsdE9uY2UsXG4gICAgZ2V0RmFrZURpc3BhdGNoT25jZSxcbn07Il0sIm1hcHBpbmdzIjoiOzs7Ozs7OztBQUtBLElBQUlBLHFCQUFKO0FBQ0EsSUFBSUMsbUJBQUo7O0FBRUEsU0FBU0MsUUFBVCxDQUFtQkMsY0FBbkIsRUFBbURDLFlBQW5ELEVBQXlHO0VBQ3JHSixxQkFBcUIsR0FBR0csY0FBeEI7RUFDQUYsbUJBQW1CLEdBQUdHLFlBQUgsYUFBR0EsWUFBSCxjQUFHQSxZQUFILEdBQW1CLElBQXRDO0FBQ0g7O0FBRUQsU0FBU0MscUJBQVQsR0FBZ0g7RUFDNUcsSUFBTUMsSUFBSSxHQUFHTixxQkFBYjtFQUVBQSxxQkFBcUIsR0FBRyxJQUF4QjtFQUVBLE9BQU9NLElBQVA7QUFDSDs7QUFFRCxTQUFTQyxtQkFBVCxHQUE0RjtFQUN4RixJQUFNRCxJQUFJLEdBQUdMLG1CQUFiO0VBRUFBLG1CQUFtQixHQUFHLElBQXRCO0VBRUEsT0FBT0ssSUFBUDtBQUNIIn0=
|
package/dist/Testing/index.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
+
import { Cmd, Dispatch } from "../Cmd";
|
|
1
2
|
import { InitResult, MessageBase, Nullable, UpdateMap, UpdateReturnType } from "../Types";
|
|
2
|
-
import { Cmd } from "../Cmd";
|
|
3
3
|
/**
|
|
4
4
|
* Extracts the messages out of a command.
|
|
5
5
|
* @param cmd The command to process.
|
|
@@ -31,6 +31,6 @@ declare type UpdateArgsFactory<TProps, TModel, TMessage extends MessageBase> = (
|
|
|
31
31
|
* const [msg, model, props] = createUpdateArgs(Msg.myMessage(), { ... }, , { ... });
|
|
32
32
|
*/
|
|
33
33
|
declare function createUpdateArgsFactory<TProps, TModel, TMessage extends MessageBase>(initModel: () => TModel, initProps: () => TProps): UpdateArgsFactory<TProps, TModel, TMessage>;
|
|
34
|
-
declare function
|
|
34
|
+
declare function renderWithFake<TModel, TMessage extends MessageBase, TResult = unknown>(initResult: InitResult<TModel, TMessage>, render: () => TResult, fakeDispatch?: Dispatch<TMessage>): TResult;
|
|
35
35
|
export type { UpdateArgsFactory, };
|
|
36
|
-
export { getOfMsgParams, execCmd, getUpdateFn, createUpdateArgsFactory,
|
|
36
|
+
export { getOfMsgParams, execCmd, getUpdateFn, createUpdateArgsFactory, renderWithFake, };
|
package/dist/Testing/index.js
CHANGED
|
@@ -9,7 +9,7 @@ exports.createUpdateArgsFactory = createUpdateArgsFactory;
|
|
|
9
9
|
exports.execCmd = execCmd;
|
|
10
10
|
exports.getOfMsgParams = getOfMsgParams;
|
|
11
11
|
exports.getUpdateFn = getUpdateFn;
|
|
12
|
-
exports.
|
|
12
|
+
exports.renderWithFake = renderWithFake;
|
|
13
13
|
|
|
14
14
|
var _useElmish = require("../useElmish");
|
|
15
15
|
|
|
@@ -148,10 +148,10 @@ function createUpdateArgsFactory(initModel, initProps) {
|
|
|
148
148
|
};
|
|
149
149
|
}
|
|
150
150
|
|
|
151
|
-
function
|
|
152
|
-
(0, _fakeInitResult.
|
|
151
|
+
function renderWithFake(initResult, render, fakeDispatch) {
|
|
152
|
+
(0, _fakeInitResult.setFakes)(initResult, fakeDispatch !== null && fakeDispatch !== void 0 ? fakeDispatch : null);
|
|
153
153
|
var result = render();
|
|
154
|
-
(0, _fakeInitResult.
|
|
154
|
+
(0, _fakeInitResult.setFakes)(null, null);
|
|
155
155
|
return result;
|
|
156
156
|
}
|
|
157
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
157
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["getOfMsgParams","cmd","msgNames","dispatch","msg","push","map","currentCmd","execCmd","callers","Promise","resolve","reject","error","all","results","getUpdateFn","updateMap","model","props","callUpdateMap","createUpdateArgsFactory","initModel","initProps","modelTemplate","propsTemplate","renderWithFake","initResult","render","fakeDispatch","setFakes","result"],"sources":["../../src/Testing/index.ts"],"sourcesContent":["import { Cmd, Dispatch } from \"../Cmd\";\nimport { InitResult, MessageBase, Nullable, UpdateMap, UpdateReturnType } from \"../Types\";\nimport { callUpdateMap } from \"../useElmish\";\nimport { setFakes } from \"./fakeInitResult\";\n\n/**\n * Extracts the messages out of a command.\n * @param cmd The command to process.\n * @returns The array of messages.\n */\nfunction getOfMsgParams<TMsg> (cmd?: Cmd<TMsg>): TMsg [] {\n    const msgNames: TMsg [] = [];\n\n    const dispatch = (msg: TMsg): void => {\n        msgNames.push(msg);\n    };\n\n    cmd?.map(currentCmd => currentCmd(dispatch));\n\n    return msgNames;\n}\n\n/**\n * Executes all commands and resolves the messages.\n * @param cmd The command to process.\n * @returns The array of processed messages.\n */\nasync function execCmd<TMsg> (cmd?: Cmd<TMsg>): Promise<Nullable<TMsg> []> {\n    if (!cmd) {\n        return [];\n    }\n\n    const callers = cmd.map(async currentCmd => new Promise<Nullable<TMsg>>((resolve, reject) => {\n        const dispatch = (msg: TMsg): void => resolve(msg);\n\n        currentCmd(dispatch, error => {\n            if (error) {\n                reject(error);\n            } else {\n                resolve(null);\n            }\n        });\n    }));\n\n    const results = await Promise.all(callers);\n\n    return results;\n}\n\n/**\n * Creates an update function out of an UpdateMap.\n * @param {UpdateMap<TProps, TModel, TMessage>} updateMap The UpdateMap.\n * @returns {(msg: TMessage, model: TModel, props: TProps) => UpdateReturnType<TModel, TMessage>} The created update function which can be used in tests.\n */\nfunction getUpdateFn<TProps, TModel, TMessage extends MessageBase> (updateMap: UpdateMap<TProps, TModel, TMessage>): (msg: TMessage, model: TModel, props: TProps) => UpdateReturnType<TModel, TMessage> {\n    return function (msg: TMessage, model: TModel, props: TProps): UpdateReturnType<TModel, TMessage> {\n        return callUpdateMap(updateMap, msg, model, props);\n    };\n}\n\ntype UpdateArgsFactory<TProps, TModel, TMessage extends MessageBase> = (msg: TMessage, modelTemplate?: Partial<TModel>, propsTemplate?: Partial<TProps>) => [TMessage, TModel, TProps];\n\n/**\n * Creates a factory function to create a message, a model, and props which can be passed to an update function in tests.\n * @param {() => TModel} initModel A function to create an initial model.\n * @param {() => TProps} initProps A function to create initial props.\n * @returns {UpdateArgsFactory<TProps, TModel, TMessage>} A function to create a message, a model, and props.\n * @example\n * // one time\n * const createUpdateArgs = createUpdateArgsFactory(() => ({ ... }), () => ({ ... }));\n * // in tests\n * const [msg, model, props] = createUpdateArgs(Msg.myMessage(), { ... }, , { ... });\n */\nfunction createUpdateArgsFactory <TProps, TModel, TMessage extends MessageBase> (initModel: () => TModel, initProps: () => TProps): UpdateArgsFactory<TProps, TModel, TMessage> {\n    return function (msg: TMessage, modelTemplate?: Partial<TModel>, propsTemplate?: Partial<TProps>): [TMessage, TModel, TProps] {\n        return [\n            msg,\n            {\n                ...initModel(),\n                ...modelTemplate,\n            },\n            {\n                ...initProps(),\n                ...propsTemplate,\n            },\n        ];\n    };\n}\n\nfunction renderWithFake<TModel, TMessage extends MessageBase, TResult = unknown> (initResult: InitResult<TModel, TMessage>, render: () => TResult, fakeDispatch?: Dispatch<TMessage>): TResult {\n    setFakes(initResult, (fakeDispatch ?? null) as Nullable<Dispatch<unknown>>);\n\n    const result = render();\n\n    setFakes(null, null);\n\n    return result;\n}\n\nexport type {\n    UpdateArgsFactory,\n};\n\nexport {\n    getOfMsgParams,\n    execCmd,\n    getUpdateFn,\n    createUpdateArgsFactory,\n    renderWithFake,\n};"],"mappings":";;;;;;;;;;;;;AAEA;;AACA;;+CAFA,oJ;;;;;;;;;;;;AAIA;AACA;AACA;AACA;AACA;AACA,SAASA,cAAT,CAA+BC,GAA/B,EAAyD;EACrD,IAAMC,QAAiB,GAAG,EAA1B;;EAEA,IAAMC,QAAQ,GAAG,SAAXA,QAAW,CAACC,GAAD,EAAqB;IAClCF,QAAQ,CAACG,IAAT,CAAcD,GAAd;EACH,CAFD;;EAIAH,GAAG,SAAH,IAAAA,GAAG,WAAH,YAAAA,GAAG,CAAEK,GAAL,CAAS,UAAAC,UAAU;IAAA,OAAIA,UAAU,CAACJ,QAAD,CAAd;EAAA,CAAnB;EAEA,OAAOD,QAAP;AACH;AAED;AACA;AACA;AACA;AACA;;;SACeM,O;;;AAsBf;AACA;AACA;AACA;AACA;;;;wEA1BA,kBAA8BP,GAA9B;IAAA;IAAA;MAAA;QAAA;UAAA;YAAA,IACSA,GADT;cAAA;cAAA;YAAA;;YAAA,kCAEe,EAFf;;UAAA;YAKUQ,OALV,GAKoBR,GAAG,CAACK,GAAJ;cAAA,sEAAQ,iBAAMC,UAAN;gBAAA;kBAAA;oBAAA;sBAAA;wBAAA,iCAAoB,IAAIG,OAAJ,CAA4B,UAACC,OAAD,EAAUC,MAAV,EAAqB;0BACzF,IAAMT,QAAQ,GAAG,SAAXA,QAAW,CAACC,GAAD;4BAAA,OAAqBO,OAAO,CAACP,GAAD,CAA5B;0BAAA,CAAjB;;0BAEAG,UAAU,CAACJ,QAAD,EAAW,UAAAU,KAAK,EAAI;4BAC1B,IAAIA,KAAJ,EAAW;8BACPD,MAAM,CAACC,KAAD,CAAN;4BACH,CAFD,MAEO;8BACHF,OAAO,CAAC,IAAD,CAAP;4BACH;0BACJ,CANS,CAAV;wBAOH,CAV2C,CAApB;;sBAAA;sBAAA;wBAAA;oBAAA;kBAAA;gBAAA;cAAA,CAAR;;cAAA;gBAAA;cAAA;YAAA,IALpB;YAAA;YAAA,OAiB0BD,OAAO,CAACI,GAAR,CAAYL,OAAZ,CAjB1B;;UAAA;YAiBUM,OAjBV;YAAA,kCAmBWA,OAnBX;;UAAA;UAAA;YAAA;QAAA;MAAA;IAAA;EAAA,C;;;;AA2BA,SAASC,WAAT,CAAoEC,SAApE,EAAyM;EACrM,OAAO,UAAUb,GAAV,EAAyBc,KAAzB,EAAwCC,KAAxC,EAA2F;IAC9F,OAAO,IAAAC,wBAAA,EAAcH,SAAd,EAAyBb,GAAzB,EAA8Bc,KAA9B,EAAqCC,KAArC,CAAP;EACH,CAFD;AAGH;;AAID;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAASE,uBAAT,CAAiFC,SAAjF,EAA0GC,SAA1G,EAAgL;EAC5K,OAAO,UAAUnB,GAAV,EAAyBoB,aAAzB,EAA0DC,aAA1D,EAAuH;IAC1H,OAAO,CACHrB,GADG,kCAGIkB,SAAS,EAHb,GAIIE,aAJJ,mCAOID,SAAS,EAPb,GAQIE,aARJ,EAAP;EAWH,CAZD;AAaH;;AAED,SAASC,cAAT,CAAkFC,UAAlF,EAA4HC,MAA5H,EAAmJC,YAAnJ,EAA+L;EAC3L,IAAAC,wBAAA,EAASH,UAAT,EAAsBE,YAAtB,aAAsBA,YAAtB,cAAsBA,YAAtB,GAAsC,IAAtC;EAEA,IAAME,MAAM,GAAGH,MAAM,EAArB;EAEA,IAAAE,wBAAA,EAAS,IAAT,EAAe,IAAf;EAEA,OAAOC,MAAP;AACH"}
|
package/dist/useElmish.js
CHANGED
|
@@ -7,10 +7,10 @@ exports.callUpdate = callUpdate;
|
|
|
7
7
|
exports.callUpdateMap = callUpdateMap;
|
|
8
8
|
exports.useElmish = useElmish;
|
|
9
9
|
|
|
10
|
-
var _react = require("react");
|
|
11
|
-
|
|
12
10
|
var _fakeInitResult = require("./Testing/fakeInitResult");
|
|
13
11
|
|
|
12
|
+
var _react = require("react");
|
|
13
|
+
|
|
14
14
|
var _Init = require("./Init");
|
|
15
15
|
|
|
16
16
|
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; }
|
|
@@ -71,7 +71,8 @@ function useElmish(_ref) {
|
|
|
71
71
|
}
|
|
72
72
|
});
|
|
73
73
|
}, []);
|
|
74
|
-
var
|
|
74
|
+
var fakeDispatch = (0, _fakeInitResult.getFakeDispatchOnce)();
|
|
75
|
+
var dispatch = (0, _react.useCallback)(fakeDispatch !== null && fakeDispatch !== void 0 ? fakeDispatch : function (msg) {
|
|
75
76
|
if (!initializedModel) {
|
|
76
77
|
return;
|
|
77
78
|
}
|
|
@@ -182,4 +183,4 @@ function callUpdateMap(updateMap, msg, model, props) {
|
|
|
182
183
|
var updateFn = updateMap[msg.name];
|
|
183
184
|
return updateFn(msg, model, props);
|
|
184
185
|
}
|
|
185
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["useElmish","name","props","init","update","subscription","reentered","buffer","currentModel","useState","model","setModel","initializedModel","propsRef","useRef","current","execCmd","useCallback","cmd","forEach","call","dispatch","ex","Services","logger","error","msg","modelHasChanged","updatedModel","Object","getOwnPropertyNames","length","push","nextMsg","modified","info","debug","dispatchMiddleware","callUpdate","newModel","shift","prevModel","getFakeInitResultOnce","initModel","initCmd","useEffect","subCmd","destructor","callUpdateMap","updateMap","updateFn"],"sources":["../src/useElmish.ts"],"sourcesContent":["/* eslint-disable react-hooks/exhaustive-deps */\nimport { Cmd, Dispatch } from \"./Cmd\";\nimport { InitFunction, MessageBase, Nullable, UpdateFunction, UpdateMap, UpdateReturnType } from \"./Types\";\nimport { useCallback, useEffect, useRef, useState } from \"react\";\nimport { getFakeInitResultOnce } from \"./Testing/fakeInitResult\";\nimport { Services } from \"./Init\";\n\ntype SubscriptionResult<TMessage> = [Cmd<TMessage>, (() => void)?];\ntype Subscription<TProps, TModel, TMessage> = (model: TModel, props: TProps) => SubscriptionResult<TMessage>;\n\ninterface UseElmishOptions<TProps, TModel, TMessage extends MessageBase> {\n    name: string,\n    props: TProps,\n    init: InitFunction<TProps, TModel, TMessage>,\n    update: UpdateFunction<TProps, TModel, TMessage> | UpdateMap<TProps, TModel, TMessage>,\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 MessageBase> ({ 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    let initializedModel = model;\n\n    const propsRef = useRef(props);\n\n    if (propsRef.current !== props) {\n        propsRef.current = props;\n    }\n\n    const execCmd = useCallback((cmd: Cmd<TMessage>): void => {\n        cmd.forEach(call => {\n            try {\n                call(dispatch);\n            } catch (ex: unknown) {\n                Services.logger?.error(ex);\n            }\n        });\n    }, []);\n\n    const dispatch = useCallback((msg: TMessage): void => {\n        if (!initializedModel) {\n            return;\n        }\n\n        const modelHasChanged = (updatedModel: Partial<TModel>): boolean => updatedModel !== initializedModel && Object.getOwnPropertyNames(updatedModel).length > 0;\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                Services.logger?.info(\"Elm\", \"message from\", name, nextMsg.name);\n                Services.logger?.debug(\"Elm\", \"message from\", name, nextMsg);\n\n                if (Services.dispatchMiddleware) {\n                    Services.dispatchMiddleware(nextMsg);\n                }\n\n                try {\n                    const [newModel, cmd] = callUpdate(update, nextMsg, { ...initializedModel, ...currentModel }, propsRef.current);\n\n                    if (modelHasChanged(newModel)) {\n                        currentModel = { ...currentModel, ...newModel };\n\n                        modified = true;\n                    }\n\n                    if (cmd) {\n                        execCmd(cmd);\n                    }\n                } catch (ex: unknown) {\n                    Services.logger?.error(ex);\n                }\n\n                nextMsg = buffer.shift();\n            }\n            reentered = false;\n\n            if (modified) {\n                setModel(prevModel => {\n                    const updatedModel = { ...prevModel as TModel, ...currentModel };\n\n                    Services.logger?.debug(\"Elm\", \"update model for\", name, updatedModel);\n\n                    return updatedModel;\n                });\n            }\n        }\n    }, []);\n\n    if (!initializedModel) {\n        const [initModel, initCmd] = getFakeInitResultOnce<TModel, TMessage>() ?? init(props);\n\n        initializedModel = initModel;\n        setModel(initializedModel);\n\n        if (initCmd) {\n            execCmd(initCmd);\n        }\n    }\n\n    useEffect(() => {\n        if (subscription) {\n            const [subCmd, destructor] = subscription(initializedModel as TModel, props);\n\n            execCmd(subCmd);\n\n            if (destructor) {\n                return destructor;\n            }\n        }\n    }, []);\n\n    return [initializedModel, dispatch];\n}\n\nfunction callUpdate<TProps, TModel, TMessage extends MessageBase> (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 MessageBase> (updateMap: UpdateMap<TProps, TModel, TMessage>, msg: TMessage, model: TModel, props: TProps): UpdateReturnType<TModel, TMessage> {\n    // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n    // @ts-expect-error -- We know that msg fits\n    const updateFn = updateMap[msg.name as TMessage[\"name\"]] as (msg: TMessage, model: TModel, props: TProps) => UpdateReturnType<TModel, TMsg>;\n\n    return updateFn(msg, model, props);\n}\n\nexport type {\n    SubscriptionResult,\n};\n\nexport {\n    useElmish,\n    callUpdate,\n    callUpdateMap,\n};"],"mappings":"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"}
|
|
186
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["useElmish","name","props","init","update","subscription","reentered","buffer","currentModel","useState","model","setModel","initializedModel","propsRef","useRef","current","execCmd","useCallback","cmd","forEach","call","dispatch","ex","Services","logger","error","fakeDispatch","getFakeDispatchOnce","msg","modelHasChanged","updatedModel","Object","getOwnPropertyNames","length","push","nextMsg","modified","info","debug","dispatchMiddleware","callUpdate","newModel","shift","prevModel","getFakeInitResultOnce","initModel","initCmd","useEffect","subCmd","destructor","callUpdateMap","updateMap","updateFn"],"sources":["../src/useElmish.ts"],"sourcesContent":["/* eslint-disable react-hooks/exhaustive-deps */\nimport { Cmd, Dispatch } from \"./Cmd\";\nimport { getFakeDispatchOnce, getFakeInitResultOnce } from \"./Testing/fakeInitResult\";\nimport { InitFunction, MessageBase, Nullable, UpdateFunction, UpdateMap, UpdateReturnType } from \"./Types\";\nimport { useCallback, useEffect, useRef, useState } from \"react\";\nimport { Services } from \"./Init\";\n\ntype SubscriptionResult<TMessage> = [Cmd<TMessage>, (() => void)?];\ntype Subscription<TProps, TModel, TMessage> = (model: TModel, props: TProps) => SubscriptionResult<TMessage>;\n\ninterface UseElmishOptions<TProps, TModel, TMessage extends MessageBase> {\n    name: string,\n    props: TProps,\n    init: InitFunction<TProps, TModel, TMessage>,\n    update: UpdateFunction<TProps, TModel, TMessage> | UpdateMap<TProps, TModel, TMessage>,\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 MessageBase> ({ 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    let initializedModel = model;\n\n    const propsRef = useRef(props);\n\n    if (propsRef.current !== props) {\n        propsRef.current = props;\n    }\n\n    const execCmd = useCallback((cmd: Cmd<TMessage>): void => {\n        cmd.forEach(call => {\n            try {\n                call(dispatch);\n            } catch (ex: unknown) {\n                Services.logger?.error(ex);\n            }\n        });\n    }, []);\n\n    const fakeDispatch = getFakeDispatchOnce();\n    const dispatch = useCallback(fakeDispatch ?? ((msg: TMessage): void => {\n        if (!initializedModel) {\n            return;\n        }\n\n        const modelHasChanged = (updatedModel: Partial<TModel>): boolean => updatedModel !== initializedModel && Object.getOwnPropertyNames(updatedModel).length > 0;\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                Services.logger?.info(\"Elm\", \"message from\", name, nextMsg.name);\n                Services.logger?.debug(\"Elm\", \"message from\", name, nextMsg);\n\n                if (Services.dispatchMiddleware) {\n                    Services.dispatchMiddleware(nextMsg);\n                }\n\n                try {\n                    const [newModel, cmd] = callUpdate(update, nextMsg, { ...initializedModel, ...currentModel }, propsRef.current);\n\n                    if (modelHasChanged(newModel)) {\n                        currentModel = { ...currentModel, ...newModel };\n\n                        modified = true;\n                    }\n\n                    if (cmd) {\n                        execCmd(cmd);\n                    }\n                } catch (ex: unknown) {\n                    Services.logger?.error(ex);\n                }\n\n                nextMsg = buffer.shift();\n            }\n            reentered = false;\n\n            if (modified) {\n                setModel(prevModel => {\n                    const updatedModel = { ...prevModel as TModel, ...currentModel };\n\n                    Services.logger?.debug(\"Elm\", \"update model for\", name, updatedModel);\n\n                    return updatedModel;\n                });\n            }\n        }\n    }), []);\n\n    if (!initializedModel) {\n        const [initModel, initCmd] = getFakeInitResultOnce<TModel, TMessage>() ?? init(props);\n\n        initializedModel = initModel;\n        setModel(initializedModel);\n\n        if (initCmd) {\n            execCmd(initCmd);\n        }\n    }\n\n    useEffect(() => {\n        if (subscription) {\n            const [subCmd, destructor] = subscription(initializedModel as TModel, props);\n\n            execCmd(subCmd);\n\n            if (destructor) {\n                return destructor;\n            }\n        }\n    }, []);\n\n    return [initializedModel, dispatch];\n}\n\nfunction callUpdate<TProps, TModel, TMessage extends MessageBase> (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 MessageBase> (updateMap: UpdateMap<TProps, TModel, TMessage>, msg: TMessage, model: TModel, props: TProps): UpdateReturnType<TModel, TMessage> {\n    // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n    // @ts-expect-error -- We know that msg fits\n    const updateFn = updateMap[msg.name as TMessage[\"name\"]] as (msg: TMessage, model: TModel, props: TProps) => UpdateReturnType<TModel, TMsg>;\n\n    return updateFn(msg, model, props);\n}\n\nexport type {\n    SubscriptionResult,\n};\n\nexport {\n    useElmish,\n    callUpdate,\n    callUpdateMap,\n};"],"mappings":"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"}
|