react-better-model 0.1.3 → 0.1.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.
package/lib/index.d.ts CHANGED
@@ -17,6 +17,7 @@ export declare class Model<S, E = {}> {
17
17
  dispatch: <K extends keyof E>(key: K, data?: (E[K] extends undefined ? never : E[K]) | undefined) => void;
18
18
  reset: () => void;
19
19
  }
20
+ export declare function useModelCtx<M extends Model<M['state'], M['events']>>(ctx: Context<M>): M;
20
21
  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
22
  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
23
  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;
package/lib/index.js CHANGED
@@ -11,7 +11,7 @@ var __assign = (this && this.__assign) || function () {
11
11
  return __assign.apply(this, arguments);
12
12
  };
13
13
  Object.defineProperty(exports, "__esModule", { value: true });
14
- exports.useModelCtxEvent = exports.useModelInstanceEvent = exports.useModelCtxState = exports.useModelInstanceState = exports.Model = void 0;
14
+ exports.useModelCtxEvent = exports.useModelInstanceEvent = exports.useModelCtxState = exports.useModelInstanceState = exports.useModelCtx = exports.Model = void 0;
15
15
  var react_1 = require("react");
16
16
  var Model = /** @class */ (function () {
17
17
  function Model(state, events) {
@@ -86,6 +86,10 @@ var Model = /** @class */ (function () {
86
86
  return Model;
87
87
  }());
88
88
  exports.Model = Model;
89
+ function useModelCtx(ctx) {
90
+ return (0, react_1.useContext)(ctx);
91
+ }
92
+ exports.useModelCtx = useModelCtx;
89
93
  function useModelInstanceState(viewModel, key) {
90
94
  var _a = (0, react_1.useState)(viewModel.state[key]), value = _a[0], setValue = _a[1];
91
95
  (0, react_1.useEffect)(function () { return viewModel.onStateChange(key, setValue); }, []);
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "react-better-model",
3
- "version": "0.1.3",
3
+ "version": "0.1.4",
4
4
  "description": "",
5
5
  "main": "lib/index.js",
6
6
  "types": "lib/index.d.ts",