react-better-model 0.1.0 → 0.1.1
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/lib/index.d.ts +19 -12
- package/lib/index.js +36 -23
- package/package.json +1 -1
- package/readme.md +0 -0
package/lib/index.d.ts
CHANGED
|
@@ -1,17 +1,24 @@
|
|
|
1
1
|
import { Context } from 'react';
|
|
2
|
-
|
|
2
|
+
declare type Sub<S, K extends keyof S = keyof S> = (v: S[K]) => void;
|
|
3
|
+
export declare class Model<S, E = {}> {
|
|
3
4
|
state: S;
|
|
5
|
+
events: E;
|
|
4
6
|
private subs;
|
|
7
|
+
private listeners;
|
|
8
|
+
private updateSingleSubscriber;
|
|
5
9
|
private updateSubscribers;
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
onStateChange: (k:
|
|
10
|
-
setState(delta: Partial<S>)
|
|
11
|
-
|
|
12
|
-
|
|
10
|
+
private updateEventListeners;
|
|
11
|
+
private initialState;
|
|
12
|
+
constructor(state?: S, events?: E);
|
|
13
|
+
onStateChange: <K extends keyof S>(k: K, cb: Sub<S>) => () => void;
|
|
14
|
+
setState: (delta: Partial<S>) => void;
|
|
15
|
+
setValue: <K extends keyof S>(key: K, value: S[K]) => void;
|
|
16
|
+
onEvent: <K extends keyof E>(k: K, cb: Sub<E>) => () => void;
|
|
17
|
+
dispatch: <K extends keyof E>(key: K, data?: (E[K] extends undefined ? never : E[K]) | undefined) => void;
|
|
18
|
+
reset: () => void;
|
|
13
19
|
}
|
|
14
|
-
export declare function useModelInstanceState<M extends Model<M['state'], M['
|
|
15
|
-
export declare function useModelCtxState<M extends Model<M['state'], M['
|
|
16
|
-
export declare function useModelInstanceEvent<
|
|
17
|
-
export declare function useModelCtxEvent<
|
|
20
|
+
export declare function useModelInstanceState<K extends keyof M['state'], M extends Model<M['state'], M['events']>>(viewModel: M, key: K): [M['state'][K], (data: M['state'][K]) => void];
|
|
21
|
+
export declare function useModelCtxState<K extends keyof M['state'], M extends Model<M['state'], M['events']>>(ctx: Context<M>, key: K): [M["state"][K], (data: M["state"][K]) => void];
|
|
22
|
+
export declare function useModelInstanceEvent<K extends keyof M['events'], D extends M['events'], M extends Model<M['state'], M['events']>>(viewModel: M, ns: K, cb?: Sub<D, K>): (data?: (D[K] extends undefined ? never : D[K]) | undefined) => void;
|
|
23
|
+
export declare function useModelCtxEvent<K extends keyof M['events'], D extends M['events'], M extends Model<M['state'], M['events']>>(ctx: Context<M>, ns: K, cb?: (eventData: D[K]) => void): (data?: (D[K] extends undefined ? never : D[K]) | undefined) => void;
|
|
24
|
+
export {};
|
package/lib/index.js
CHANGED
|
@@ -14,11 +14,18 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
14
14
|
exports.useModelCtxEvent = exports.useModelInstanceEvent = exports.useModelCtxState = exports.useModelInstanceState = exports.Model = void 0;
|
|
15
15
|
var react_1 = require("react");
|
|
16
16
|
var Model = /** @class */ (function () {
|
|
17
|
-
function Model(state) {
|
|
17
|
+
function Model(state, events) {
|
|
18
18
|
var _this = this;
|
|
19
19
|
if (state === void 0) { state = {}; }
|
|
20
|
+
if (events === void 0) { events = {}; }
|
|
20
21
|
this.state = state;
|
|
22
|
+
this.events = events;
|
|
21
23
|
this.subs = new Map();
|
|
24
|
+
this.listeners = new Map();
|
|
25
|
+
this.updateSingleSubscriber = function (k, v) {
|
|
26
|
+
var _a;
|
|
27
|
+
(_a = _this.subs.get(k)) === null || _a === void 0 ? void 0 : _a.forEach(function (cb) { return cb(v); });
|
|
28
|
+
};
|
|
22
29
|
this.updateSubscribers = function (delta) {
|
|
23
30
|
var keyVals = Object.entries(delta);
|
|
24
31
|
var _loop_1 = function (key, val) {
|
|
@@ -33,8 +40,11 @@ var Model = /** @class */ (function () {
|
|
|
33
40
|
_loop_1(key, val);
|
|
34
41
|
}
|
|
35
42
|
};
|
|
36
|
-
this.
|
|
37
|
-
|
|
43
|
+
this.updateEventListeners = function (k, data) {
|
|
44
|
+
var _a;
|
|
45
|
+
(_a = _this.listeners.get(k)) === null || _a === void 0 ? void 0 : _a.forEach(function (cb) { return cb(data); });
|
|
46
|
+
};
|
|
47
|
+
this.initialState = {};
|
|
38
48
|
this.onStateChange = function (k, cb) {
|
|
39
49
|
var keySubs = _this.subs.get(k);
|
|
40
50
|
if (!keySubs) {
|
|
@@ -46,29 +56,33 @@ var Model = /** @class */ (function () {
|
|
|
46
56
|
keySubs.delete(cb);
|
|
47
57
|
};
|
|
48
58
|
};
|
|
49
|
-
this.
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
59
|
+
this.setState = function (delta) {
|
|
60
|
+
_this.state = __assign(__assign({}, _this.state), delta);
|
|
61
|
+
_this.updateSubscribers(delta);
|
|
62
|
+
};
|
|
63
|
+
this.setValue = function (key, value) {
|
|
64
|
+
_this.state[key] = value;
|
|
65
|
+
_this.updateSingleSubscriber(key, value);
|
|
66
|
+
};
|
|
67
|
+
this.onEvent = function (k, cb) {
|
|
68
|
+
var nsListeners = _this.listeners.get(k);
|
|
69
|
+
if (!nsListeners) {
|
|
70
|
+
nsListeners = new Set();
|
|
71
|
+
_this.listeners.set(k, nsListeners);
|
|
54
72
|
}
|
|
55
|
-
|
|
73
|
+
nsListeners.add(cb);
|
|
56
74
|
return function () {
|
|
57
|
-
|
|
75
|
+
nsListeners.delete(cb);
|
|
58
76
|
};
|
|
59
77
|
};
|
|
60
|
-
this.
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
}
|
|
78
|
+
this.dispatch = function (key, data) {
|
|
79
|
+
_this.updateEventListeners(key, data);
|
|
80
|
+
};
|
|
81
|
+
this.reset = function () {
|
|
82
|
+
_this.setState(_this.initialState);
|
|
66
83
|
};
|
|
84
|
+
this.initialState = state;
|
|
67
85
|
}
|
|
68
|
-
Model.prototype.setState = function (delta) {
|
|
69
|
-
this.state = __assign(__assign({}, this.state), delta);
|
|
70
|
-
this.updateSubscribers(delta);
|
|
71
|
-
};
|
|
72
86
|
return Model;
|
|
73
87
|
}());
|
|
74
88
|
exports.Model = Model;
|
|
@@ -76,8 +90,7 @@ function useModelInstanceState(viewModel, key) {
|
|
|
76
90
|
var _a = (0, react_1.useState)(viewModel.state[key]), value = _a[0], setValue = _a[1];
|
|
77
91
|
(0, react_1.useEffect)(function () { return viewModel.onStateChange(key, setValue); }, []);
|
|
78
92
|
var setter = (0, react_1.useCallback)(function (v) {
|
|
79
|
-
|
|
80
|
-
viewModel.setState((_a = {}, _a[key] = v, _a));
|
|
93
|
+
viewModel.setValue(key, v);
|
|
81
94
|
}, [key]);
|
|
82
95
|
return [value, setter];
|
|
83
96
|
}
|
|
@@ -93,7 +106,7 @@ function useModelInstanceEvent(viewModel, ns, cb) {
|
|
|
93
106
|
return viewModel.onEvent(ns, cb);
|
|
94
107
|
}
|
|
95
108
|
}, [cb]);
|
|
96
|
-
return function (data) { return viewModel.
|
|
109
|
+
return function (data) { return viewModel.dispatch(ns, data); };
|
|
97
110
|
}
|
|
98
111
|
exports.useModelInstanceEvent = useModelInstanceEvent;
|
|
99
112
|
function useModelCtxEvent(ctx, ns, cb) {
|
package/package.json
CHANGED
package/readme.md
ADDED
|
File without changes
|