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 CHANGED
@@ -1,17 +1,24 @@
1
1
  import { Context } from 'react';
2
- export declare class Model<S, E> {
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
- constructor(state?: S);
7
- eventListeners: Map<keyof E, Set<(eventData: E[keyof E]) => void>>;
8
- evtDataTypes: E;
9
- onStateChange: (k: keyof S, cb: (v: S[keyof S]) => void) => () => void;
10
- setState(delta: Partial<S>): void;
11
- onEvent: (evt: keyof typeof this.evtDataTypes, cb: (eventData: E[keyof E]) => void) => () => void;
12
- emitEvent: (evt: keyof E, data: E[keyof E]) => void;
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['evtDataTypes']>>(viewModel: M, key: keyof M['state']): (M["state"][keyof M["state"]] | ((v: any) => void))[];
15
- export declare function useModelCtxState<M extends Model<M['state'], M['evtDataTypes']>>(ctx: Context<M>, key: keyof M['state']): (M["state"][keyof M["state"]] | ((v: any) => void))[];
16
- export declare function useModelInstanceEvent<M extends Model<M['state'], M['evtDataTypes']>, NS extends keyof M['evtDataTypes']>(viewModel: M, ns: NS, cb?: (eventData: M['evtDataTypes'][NS]) => void): (data: M['evtDataTypes'][NS]) => void;
17
- export declare function useModelCtxEvent<M extends Model<M['state'], M['evtDataTypes']>, NS extends keyof M['evtDataTypes']>(ctx: Context<M>, ns: NS, cb?: (eventData: M['evtDataTypes'][NS]) => void): (data: M["evtDataTypes"][NS]) => void;
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.eventListeners = new Map();
37
- this.evtDataTypes = {};
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.onEvent = function (evt, cb) {
50
- var listeners = _this.eventListeners.get(evt);
51
- if (!listeners) {
52
- listeners = new Set();
53
- _this.eventListeners.set(evt, listeners);
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
- listeners.add(cb);
73
+ nsListeners.add(cb);
56
74
  return function () {
57
- listeners.delete(cb);
75
+ nsListeners.delete(cb);
58
76
  };
59
77
  };
60
- this.emitEvent = function (evt, data) {
61
- if (_this.eventListeners.has(evt)) {
62
- _this.eventListeners.get(evt).forEach(function (cb) {
63
- cb(data);
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
- var _a;
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.emitEvent(ns, data); };
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
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "react-better-model",
3
- "version": "0.1.0",
3
+ "version": "0.1.1",
4
4
  "description": "",
5
5
  "main": "lib/index.js",
6
6
  "types": "lib/index.d.ts",
package/readme.md ADDED
File without changes