Socket
Socket
Sign inDemoInstall

react-model

Package Overview
Dependencies
Maintainers
2
Versions
101
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

react-model - npm Package Compare versions

Comparing version 4.0.1 to 4.1.0-alpha.0

4

dist/index.d.ts

@@ -7,2 +7,4 @@ /// <reference path="../src/index.d.ts" />

import { actionMiddlewares, middlewares } from './middlewares';
declare function useModel<S>(state: S): [S, (state: S) => void];
declare function createStore<S>(useHook: CustomModelHook<S>): LaneAPI<S>;
declare function Model<E, Ctx extends {}, MT extends ModelType<any, any, {}>>(models: MT, initialState?: E): API<MT>;

@@ -70,2 +72,2 @@ declare function Model<M extends Models, E>(models: M, initialState?: Global['State']): APIs<M>;

};
export { actionMiddlewares, Model, middlewares, Provider, Consumer, connect, getState, getInitialState };
export { actionMiddlewares, createStore, useModel, Model, middlewares, Provider, Consumer, connect, getState, getInitialState };

@@ -1,1 +0,1 @@

import t,{enableES5 as e}from"immer";import{createContext as n,useState as r,useRef as o,useLayoutEffect as i,createElement as c,PureComponent as a}from"react";function s(){return(s=Object.assign||function(t){for(var e=1;e<arguments.length;e++){var n=arguments[e];for(var r in n)Object.prototype.hasOwnProperty.call(n,r)&&(t[r]=n[r])}return t}).apply(this,arguments)}function u(t,e){t.prototype=Object.create(e.prototype),t.prototype.constructor=t,t.__proto__=e}var l={Actions:{},AsyncState:{},Context:{__global:{}},Middlewares:{},Setter:{classSetter:void 0,functionSetter:{}},State:{},devTools:void 0,subscriptions:{},uid:0,withDevTools:!1},f={logger:{enable:!1},devtools:{enable:!1},tryCatch:{enable:!0}},m=function(t,e){try{var n=t.next,r=f.tryCatch.enable?Promise.resolve(n(e).catch(function(t){return console.log(t)})).then(function(){}):Promise.resolve(n(e)).then(function(){});return Promise.resolve(r&&r.then?r.then(function(){}):void 0)}catch(t){return Promise.reject(t)}},S=function(t,e){try{var n=t.modelName,r=t.next,o=t.Global;return Promise.resolve((0,t.action)(t.params,s({actions:(0,t.consumerActions)(o.Actions[n],{modelName:n}),state:o.State[n]},o.Context.__global||{},o.Context[n]||{}))).then(function(n){return t.newState=n||null,Promise.resolve(r(e)).then(function(){})})}catch(t){return Promise.reject(t)}},d=function(t,e){try{var n=t.modelName,r=t.newState,o=t.next,i=t.Global;i.Setter.functionSetter[n]&&Object.keys(i.Setter.functionSetter[n]).map(function(t){var e=i.Setter.functionSetter[n][t];e&&e.selector&&!e.selectorRef&&(e.selectorRef=e.selector(i.State[n]))});var c=function(){if(r)return A(n,r),Promise.resolve(o(e)).then(function(){})}();return Promise.resolve(c&&c.then?c.then(function(){}):void 0)}catch(t){return Promise.reject(t)}},v=function(t,e){try{var n=t.modelName,r=t.next,o=t.Global,i=t.__hash,c=o.Setter.functionSetter[n];return"function"===t.type&&i&&c&&c[i]&&c[i].setState&&c[i].setState(o.State[n]),Promise.resolve(r(e)).then(function(){})}catch(t){return Promise.reject(t)}},h=function(t,e){try{var n=t.next,r=t.Global.subscriptions[t.modelName+"_"+t.actionName];return r&&r.forEach(function(e){e(t)}),Promise.resolve(n(e)).then(function(){})}catch(t){return Promise.reject(t)}},_=function(t,e){try{var n=t.Global,r=!0===f.logger.enable||"function"==typeof f.logger.enable&&f.logger.enable(t)?(console.group("%c "+t.modelName+" State Change %c "+(new Date).toLocaleTimeString(),"color: gray; font-weight: lighter;","color: black; font-weight: bold;"),console.log("%c Previous","color: #9E9E9E; font-weight: bold",n.State[t.modelName]),console.log("%c Action","color: #03A9F4; font-weight: bold",t.actionName,"payload: "+t.params),Promise.resolve(t.next(e)).then(function(){console.log("%c Next","color: #4CAF50; font-weight: bold",n.State[t.modelName]),console.groupEnd()})):Promise.resolve(t.next(e)).then(function(){});return Promise.resolve(r&&r.then?r.then(function(){}):void 0)}catch(t){return Promise.reject(t)}},p=function(t,e){try{var n=t.Global;return Promise.resolve(t.next(e)).then(function(){n.withDevTools&&f.devtools.enable&&n.devTools.send(t.modelName+"_"+t.actionName,n.State)})}catch(t){return Promise.reject(t)}},b=function(t,e){try{var n=t.modelName,r=t.next,o=t.Global;return o.Setter.classSetter&&o.Setter.classSetter(o.State),o.Setter.functionSetter[n]&&Object.keys(o.Setter.functionSetter[n]).map(function(t){var e=o.Setter.functionSetter[n][t];if(e)if(e.selector){var r=e.selector(o.State[n]);T(r,e.selectorRef)||(e.selectorRef=r,e.setState(o.State[n]))}else e.setState(o.State[n])}),Promise.resolve(r(e)).then(function(){})}catch(t){return Promise.reject(t)}},g=[m,_,p,S,d,v,b,h],y={communicator:b,consoleDebugger:_,devToolsListener:p,getNewState:S,getNewStateWithCache:function(t){return void 0===t&&(t=5e3),function(e,n){try{var r=e.Global,o=e.modelName,i=e.next,c=e.actionName;return Promise.resolve(Promise.race([(0,e.action)(e.params,{actions:(0,e.consumerActions)(r.Actions[o],{modelName:o}),state:r.State[o]}),R(t,C(o,c))])).then(function(t){return e.newState=t||null,Promise.resolve(i(n)).then(function(){})})}catch(t){return Promise.reject(t)}}},setNewState:d,stateUpdater:v,subscription:h,tryCatch:m,config:f},P=function(t,e){try{e.next=function(t){return t.length>0&&t[0](e,t.slice(1))};var n=function(){if(t.length>0)return Promise.resolve(t[0](e,t.slice(1))).then(function(){})}();return Promise.resolve(n&&n.then?n.then(function(){}):void 0)}catch(t){return Promise.reject(t)}},w=n({}),N=w.Consumer;if(!console.group){var O=[],E="-".repeat(80);console.group=function(t){O.push(t),console.log("%c \nBEGIN GROUP: %c",E,t),console.groupEnd=function(){console.log("END GROUP: %c\n%c",O.pop(),E)}}}var j=function(t,e){var n={};return Object.keys(t).forEach(function(r){n[r]=function(t,e){return function(n,r){try{return Promise.resolve(P(g,{Global:l,action:t,actionName:t.name,consumerActions:j,middlewareConfig:r,modelName:e.modelName,newState:null,params:n,type:"outer"})).then(function(){})}catch(t){return Promise.reject(t)}}}(t[r],e)}),n},A=function(e,n){if("function"==typeof n){var r=l.State[e];r=t(r,n),l.State=t(l.State,function(t){t[e]=r})}else l.State=t(l.State,function(t){t[e]=s({},t[e],n)});return l.State},R=function(t,e){return new Promise(function(n){return setTimeout(function(){console.log(t),n(e)},t)})},x=function(e,n){try{var r={__FROM_SERVER__:!0};return Promise.resolve(Promise.all(Object.keys(l.State).map(function(o){try{var i=function(){if(!e||!e.modelName||o===e.modelName||-1!==e.modelName.indexOf(o)){var i=function(e){n&&n.isServer?r[o]=e:l.State=t(l.State,function(t){t[o]=s({},t[o],e)})},c=l.AsyncState[o];return c?Promise.resolve(c(e)).then(i):i({})}}();return Promise.resolve(i&&i.then?i.then(function(){}):void 0)}catch(t){return Promise.reject(t)}}))).then(function(){return n&&n.isServer?r:l.State})}catch(t){return Promise.reject(t)}},C=function(t,e){var n=localStorage.getItem("__REACT_MODELX__"+t+"_"+e);return n?JSON.parse(n):null},T=function(t,e){if(t===e)return!0;if("object"!=typeof t||null===t||"object"!=typeof e||null===e)return!1;var n=Object.keys(t),r=Object.keys(e);if(n.length!==r.length)return!1;for(var o=0;o<n.length;o++)if(!Object.prototype.hasOwnProperty.call(e,n[o])||t[n[o]]!==e[n[o]])return!1;return!0};function G(e,n,r){if(void 0!==e.state){l.uid+=1;var o="__"+l.uid;l.State=t(l.State,function(t){t[o]=e.state}),e.middlewares&&(l.Middlewares[o]=e.middlewares),l.Actions[o]=e.actions,l.AsyncState[o]=e.asyncState,n&&(l.Context[o]=n);var i=F(o);return{__id:o,actions:i,getState:function(){return k(o)},subscribe:function(t,e){return M(o,t,e)},unsubscribe:function(t){return D(o,t)},useStore:function(t){return I(o,t)}}}if(e.actions){console.error("invalid model(s) schema: ",e);var c=function(t){return function(){return t}};return{__ERROR__:!0,actions:c({}),getActions:c({}),getInitialState:c({}),getState:c({}),subscribe:c(),unsubscribe:c(),useStore:c([{},{}])}}n&&!n.__FROM_SERVER__&&(l.State=t(l.State,function(t){Object.assign(t,n||{})})),r&&(l.Context.__global=r),Object.keys(e).forEach(function(r){var o=e[r];if(o.__ERROR__)return console.error(r+" model's schema is invalid"),l.State=t(l.State,function(t){t[r]={}}),void(l.Actions[r]={});!function(t){return void 0!==t.useStore}(o)?(n&&n.__FROM_SERVER__?l.State=t(l.State,function(t){t[r]=s({},o.state,n[r])}):l.State[r]||(l.State=t(l.State,function(t){t[r]=o.state})),o.middlewares&&(l.Middlewares[r]=o.middlewares),l.Actions[r]=o.actions,l.AsyncState[r]=o.asyncState):(l.State[r]&&n||(l.State=t(l.State,function(t){t[r]=t[o.__id]})),n&&n.__FROM_SERVER__&&(l.State=t(l.State,function(t){t[r]=s({},t[o.__id],n[r])})),l.Actions[r]=l.Actions[o.__id],l.AsyncState[r]=l.AsyncState[o.__id],l.Middlewares[r]=l.Middlewares[o.__id],l.Context[r]=l.Context[o.__id])});var a=Object.keys(e).reduce(function(t,e){var n;return s({},t,((n={})[e]=F(e),n))},{});return l.withDevTools="undefined"!=typeof window&&window.__REDUX_DEVTOOLS_EXTENSION__,l.withDevTools&&y.config.devtools.enable&&(l.devTools=window.__REDUX_DEVTOOLS_EXTENSION__,l.devTools.connect()),{actions:a,getActions:F,getInitialState:x,getState:k,subscribe:M,unsubscribe:D,useStore:I}}e();var D=function(t,e){M(t,e,void 0)},M=function(t,e,n){Array.isArray(e)?e.forEach(function(e){l.subscriptions[t+"_"+e]||(l.subscriptions[t+"_"+e]=[]),n?l.subscriptions[t+"_"+e].push(n):l.subscriptions[t+"_"+e]=[]}):(l.subscriptions[t+"_"+e]||(l.subscriptions[t+"_"+e]=[]),n?l.subscriptions[t+"_"+e].push(n):l.subscriptions[t+"_"+e]=[])},k=function(t){return l.State[t]},F=function(t,e){void 0===e&&(e={type:"outer"});var n={};return Object.keys(l.Actions[t]).forEach(function(r){return n[r]=function(n,o){try{var i=s({action:l.Actions[t][r],actionName:r,consumerActions:j,middlewareConfig:o,modelName:t,newState:null,params:n},e,{Global:l}),c=l.Middlewares[t]?Promise.resolve(P(l.Middlewares[t],i)).then(function(){}):Promise.resolve(P(g,i)).then(function(){});return Promise.resolve(c&&c.then?c.then(function(){}):void 0)}catch(t){return Promise.reject(t)}}}),n},I=function(t,e){var n=r({})[1],c=o("");i(function(){l.uid+=1;var r=""+l.uid;return c.current=r,l.Setter.functionSetter[t]||(l.Setter.functionSetter[t]={}),l.Setter.functionSetter[t][r]={setState:n,selector:e},function(){delete l.Setter.functionSetter[t][r]}},[]);var a=F(t,{__hash:c.current,type:"function"});return[e?e(k(t)):k(t),a]},V=function(t){function e(){var e;return(e=t.apply(this,arguments)||this).state=l.State,e}return u(e,t),e.prototype.render=function(){var t=this.props.children;return l.Setter.classSetter=this.setState.bind(this),c(w.Provider,{value:s({},this.state)},t)},e}(a),L=function(t,e,n){return function(r){return function(o){function i(){return o.apply(this,arguments)||this}return u(i,o),i.prototype.render=function(){var o=this,i=this.props,a=i.state,u=void 0===a?{}:a,f=i.actions,m=void 0===f?{}:f;return c(N,null,function(i){var a=i[""+t],f=l.Actions[t];return c(r,Object.assign({},o.props,{state:s({},u,e?e(a):a),actions:s({},m,n?n(j(f,{modelName:t})):j(f,{modelName:t}))}))})},i}(a)}};export{N as Consumer,G as Model,V as Provider,g as actionMiddlewares,L as connect,x as getInitialState,k as getState,y as middlewares};
import t,{enableES5 as e}from"immer";import{createContext as r,useState as n,useRef as o,useLayoutEffect as i,createElement as c,PureComponent as a}from"react";function s(){return(s=Object.assign||function(t){for(var e=1;e<arguments.length;e++){var r=arguments[e];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(t[n]=r[n])}return t}).apply(this,arguments)}function u(t,e){t.prototype=Object.create(e.prototype),t.prototype.constructor=t,t.__proto__=e}var l={Actions:{},AsyncState:{},Context:{__global:{}},Middlewares:{},Setter:{classSetter:void 0,functionSetter:{}},State:{},devTools:void 0,subscriptions:{},mutableState:{},uid:0,storeId:0,currentStoreId:0,withDevTools:!1},f={logger:{enable:!1},devtools:{enable:!1},tryCatch:{enable:!0}},m=function(t,e){try{var r=t.next;return Promise.resolve(f.tryCatch.enable?r(e).catch(function(t){return console.log(t)}):r(e))}catch(t){return Promise.reject(t)}},S=function(t,e){try{var r=t.modelName,n=t.next,o=t.Global;return Promise.resolve((0,t.action)(t.params,s({actions:(0,t.consumerActions)(o.Actions[r],{modelName:r}),state:o.State[r]},o.Context.__global||{},o.Context[r]||{}))).then(function(r){return t.newState=r||null,Promise.resolve(n(e))})}catch(t){return Promise.reject(t)}},d=function(t,e){try{var r=t.modelName,n=t.newState,o=t.next,i=t.Global;return i.Setter.functionSetter[r]&&Object.keys(i.Setter.functionSetter[r]).map(function(t){var e=i.Setter.functionSetter[r][t];e&&e.selector&&!e.selectorRef&&(e.selectorRef=e.selector(i.State[r]))}),Promise.resolve(function(){if(n)return E(r,n),Promise.resolve(o(e))}())}catch(t){return Promise.reject(t)}},v=function(t,e){try{var r=t.modelName,n=t.next,o=t.Global,i=t.__hash,c=o.Setter.functionSetter[r];return"function"===t.type&&i&&c&&c[i]&&c[i].setState&&c[i].setState(o.State[r]),Promise.resolve(n(e))}catch(t){return Promise.reject(t)}},_=function(t,e){try{var r=t.next,n=t.Global.subscriptions[t.modelName+"_"+t.actionName];return n&&n.forEach(function(e){e(t)}),Promise.resolve(r(e))}catch(t){return Promise.reject(t)}},b=function(t,e){try{var r=t.Global;return!0===f.logger.enable||"function"==typeof f.logger.enable&&f.logger.enable(t)?(console.group("%c "+t.modelName+" State Change %c "+(new Date).toLocaleTimeString(),"color: gray; font-weight: lighter;","color: black; font-weight: bold;"),console.log("%c Previous","color: #9E9E9E; font-weight: bold",r.State[t.modelName]),console.log("%c Action","color: #03A9F4; font-weight: bold",t.actionName,"payload: "+t.params),Promise.resolve(t.next(e)).then(function(e){return console.log("%c Next","color: #4CAF50; font-weight: bold",r.State[t.modelName]),console.groupEnd(),e})):Promise.resolve(t.next(e))}catch(t){return Promise.reject(t)}},p=function(t,e){try{var r=t.Global;return Promise.resolve(t.next(e)).then(function(e){return r.withDevTools&&f.devtools.enable&&r.devTools.send(t.modelName+"_"+t.actionName,r.State),e})}catch(t){return Promise.reject(t)}},h=function(t,e){try{var r=t.modelName,n=t.next,o=t.Global;return o.Setter.classSetter&&o.Setter.classSetter(o.State),o.Setter.functionSetter[r]&&Object.keys(o.Setter.functionSetter[r]).map(function(t){var e=o.Setter.functionSetter[r][t];if(e)if(e.selector){var n=e.selector(o.State[r]);T(n,e.selectorRef)||(e.selectorRef=n,e.setState(o.State[r]))}else e.setState(o.State[r])}),Promise.resolve(n(e))}catch(t){return Promise.reject(t)}},y=[m,b,p,S,d,v,h,_],g={communicator:h,consoleDebugger:b,devToolsListener:p,getNewState:S,getNewStateWithCache:function(t){return void 0===t&&(t=5e3),function(e,r){try{var n=e.Global,o=e.modelName,i=e.next,c=e.actionName;return Promise.resolve(Promise.race([(0,e.action)(e.params,{actions:(0,e.consumerActions)(n.Actions[o],{modelName:o}),state:n.State[o]}),R(t,C(o,c))])).then(function(t){return e.newState=t||null,Promise.resolve(i(r))})}catch(t){return Promise.reject(t)}}},setNewState:d,stateUpdater:v,subscription:_,tryCatch:m,config:f},P=function(t,e){try{return e.next=function(t){return t.length>0?t[0](e,t.slice(1)):e.newState},Promise.resolve(t[0](e,t.slice(1)))}catch(t){return Promise.reject(t)}},w=r({}),N=w.Consumer;if(!console.group){var O=[],j="-".repeat(80);console.group=function(t){O.push(t),console.log("%c \nBEGIN GROUP: %c",j,t),console.groupEnd=function(){console.log("END GROUP: %c\n%c",O.pop(),j)}}}var A=function(t,e){var r={};return Object.keys(t).forEach(function(n){r[n]=function(t,e){return function(r,n){try{return Promise.resolve(P(y,{Global:l,action:t,actionName:t.name,consumerActions:A,middlewareConfig:n,modelName:e.modelName,newState:null,params:r,type:"outer"}))}catch(t){return Promise.reject(t)}}}(t[n],e)}),r},E=function(e,r){if("function"==typeof r){var n=l.State[e];n=t(n,r),l.State=t(l.State,function(t){t[e]=n})}else l.State=t(l.State,function(t){t[e]=s({},t[e],r)});return l.State},R=function(t,e){return new Promise(function(r){return setTimeout(function(){console.log(t),r(e)},t)})},x=function(e,r){try{var n={__FROM_SERVER__:!0};return Promise.resolve(Promise.all(Object.keys(l.State).map(function(o){try{var i=function(){if(!e||!e.modelName||o===e.modelName||-1!==e.modelName.indexOf(o)){var i=function(e){r&&r.isServer?n[o]=e:l.State=t(l.State,function(t){t[o]=s({},t[o],e)})},c=l.AsyncState[o];return c?Promise.resolve(c(e)).then(i):i({})}}();return Promise.resolve(i&&i.then?i.then(function(){}):void 0)}catch(t){return Promise.reject(t)}}))).then(function(){return r&&r.isServer?n:l.State})}catch(t){return Promise.reject(t)}},C=function(t,e){var r=localStorage.getItem("__REACT_MODELX__"+t+"_"+e);return r?JSON.parse(r):null},T=function(t,e){if(t===e)return!0;if("object"!=typeof t||null===t||"object"!=typeof e||null===e)return!1;var r=Object.keys(t),n=Object.keys(e);if(r.length!==n.length)return!1;for(var o=0;o<r.length;o++)if(!Object.prototype.hasOwnProperty.call(e,r[o])||t[r[o]]!==e[r[o]])return!1;return!0};function G(t){var e=l.currentStoreId,r=l.mutableState[e].count;return l.mutableState[e].count+=1,l.mutableState[e][r]||(l.mutableState[e][r]=t),[l.mutableState[e][r],function(t){try{var n={Global:l,action:function(){return t},actionName:"setter",consumerActions:A,middlewareConfig:{},modelName:"__"+e,newState:{},params:void 0,type:"outer"};return l.mutableState[e][r]=t,Promise.resolve(P(y,n))}catch(t){return Promise.reject(t)}}]}function I(t){l.storeId+=1;var e=l.storeId,r="__"+e;l.Actions[r]||(l.Actions[r]={}),l.mutableState[e]||(l.mutableState[e]={count:0});var n=function(){return l.mutableState[e].count=0,l.currentStoreId=e,t()};return{useStore:function(){return L(r,n)[0]},getState:function(){return n()}}}function D(e,r,n){if(void 0!==e.state){l.storeId+=1;var o="__"+l.storeId;l.State=t(l.State,function(t){t[o]=e.state}),e.middlewares&&(l.Middlewares[o]=e.middlewares),l.Actions[o]=e.actions,l.AsyncState[o]=e.asyncState,r&&(l.Context[o]=r);var i=V(o);return{__id:o,actions:i,getState:function(){return F(o)},subscribe:function(t,e){return k(o,t,e)},unsubscribe:function(t){return M(o,t)},useStore:function(t){return L(o,t)}}}if(e.actions){console.error("invalid model(s) schema: ",e);var c=function(t){return function(){return t}};return{__ERROR__:!0,actions:c({}),getActions:c({}),getInitialState:c({}),getState:c({}),subscribe:c(),unsubscribe:c(),useStore:c([{},{}])}}r&&!r.__FROM_SERVER__&&(l.State=t(l.State,function(t){Object.assign(t,r||{})})),n&&(l.Context.__global=n),Object.keys(e).forEach(function(n){var o=e[n];if(o.__ERROR__)return console.error(n+" model's schema is invalid"),l.State=t(l.State,function(t){t[n]={}}),void(l.Actions[n]={});!function(t){return void 0!==t.useStore}(o)?(r&&r.__FROM_SERVER__?l.State=t(l.State,function(t){t[n]=s({},o.state,r[n])}):l.State[n]||(l.State=t(l.State,function(t){t[n]=o.state})),o.middlewares&&(l.Middlewares[n]=o.middlewares),l.Actions[n]=o.actions,l.AsyncState[n]=o.asyncState):(l.State[n]&&r||(l.State=t(l.State,function(t){t[n]=t[o.__id]})),r&&r.__FROM_SERVER__&&(l.State=t(l.State,function(t){t[n]=s({},t[o.__id],r[n])})),l.Actions[n]=l.Actions[o.__id],l.AsyncState[n]=l.AsyncState[o.__id],l.Middlewares[n]=l.Middlewares[o.__id],l.Context[n]=l.Context[o.__id])});var a=Object.keys(e).reduce(function(t,e){var r;return s({},t,((r={})[e]=V(e),r))},{});return l.withDevTools="undefined"!=typeof window&&window.__REDUX_DEVTOOLS_EXTENSION__,l.withDevTools&&g.config.devtools.enable&&(l.devTools=window.__REDUX_DEVTOOLS_EXTENSION__,l.devTools.connect()),{actions:a,getActions:V,getInitialState:x,getState:F,subscribe:k,unsubscribe:M,useStore:L}}e();var M=function(t,e){k(t,e,void 0)},k=function(t,e,r){Array.isArray(e)?e.forEach(function(e){l.subscriptions[t+"_"+e]||(l.subscriptions[t+"_"+e]=[]),r?l.subscriptions[t+"_"+e].push(r):l.subscriptions[t+"_"+e]=[]}):(l.subscriptions[t+"_"+e]||(l.subscriptions[t+"_"+e]=[]),r?l.subscriptions[t+"_"+e].push(r):l.subscriptions[t+"_"+e]=[])},F=function(t){return l.State[t]},V=function(t,e){void 0===e&&(e={type:"outer"});var r={};return Object.keys(l.Actions[t]).forEach(function(n){return r[n]=function(r,o){try{var i=s({action:l.Actions[t][n],actionName:n,consumerActions:A,middlewareConfig:o,modelName:t,newState:null,params:r},e,{Global:l});return Promise.resolve(P(l.Middlewares[t]?l.Middlewares[t]:y,i))}catch(t){return Promise.reject(t)}}}),r},L=function(t,e){var r=n({})[1],c=o("");i(function(){l.uid+=1;var n=""+l.uid;return c.current=n,l.Setter.functionSetter[t]||(l.Setter.functionSetter[t]={}),l.Setter.functionSetter[t][n]={setState:r,selector:e},function(){delete l.Setter.functionSetter[t][n]}},[]);var a=V(t,{__hash:c.current,type:"function"});return[e?e(F(t)):F(t),a]},U=function(t){function e(){var e;return(e=t.apply(this,arguments)||this).state=l.State,e}return u(e,t),e.prototype.render=function(){var t=this.props.children;return l.Setter.classSetter=this.setState.bind(this),c(w.Provider,{value:s({},this.state)},t)},e}(a),X=function(t,e,r){return function(n){return function(o){function i(){return o.apply(this,arguments)||this}return u(i,o),i.prototype.render=function(){var o=this,i=this.props,a=i.state,u=void 0===a?{}:a,f=i.actions,m=void 0===f?{}:f;return c(N,null,function(i){var a=i[""+t],f=l.Actions[t];return c(n,Object.assign({},o.props,{state:s({},u,e?e(a):a),actions:s({},m,r?r(A(f,{modelName:t})):A(f,{modelName:t}))}))})},i}(a)}};export{N as Consumer,D as Model,U as Provider,y as actionMiddlewares,X as connect,I as createStore,x as getInitialState,F as getState,g as middlewares,G as useModel};

@@ -1,1 +0,1 @@

var e,t=require("immer"),n=(e=t)&&"object"==typeof e&&"default"in e?e.default:e,r=require("react");function o(){return(o=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var r in n)Object.prototype.hasOwnProperty.call(n,r)&&(e[r]=n[r])}return e}).apply(this,arguments)}function i(e,t){e.prototype=Object.create(t.prototype),e.prototype.constructor=e,e.__proto__=t}var c={Actions:{},AsyncState:{},Context:{__global:{}},Middlewares:{},Setter:{classSetter:void 0,functionSetter:{}},State:{},devTools:void 0,subscriptions:{},uid:0,withDevTools:!1},a={logger:{enable:!1},devtools:{enable:!1},tryCatch:{enable:!0}},s=function(e,t){try{var n=e.next,r=a.tryCatch.enable?Promise.resolve(n(t).catch(function(e){return console.log(e)})).then(function(){}):Promise.resolve(n(t)).then(function(){});return Promise.resolve(r&&r.then?r.then(function(){}):void 0)}catch(e){return Promise.reject(e)}},u=function(e,t){try{var n=e.modelName,r=e.next,i=e.Global;return Promise.resolve((0,e.action)(e.params,o({actions:(0,e.consumerActions)(i.Actions[n],{modelName:n}),state:i.State[n]},i.Context.__global||{},i.Context[n]||{}))).then(function(n){return e.newState=n||null,Promise.resolve(r(t)).then(function(){})})}catch(e){return Promise.reject(e)}},l=function(e,t){try{var n=e.modelName,r=e.newState,o=e.next,i=e.Global;i.Setter.functionSetter[n]&&Object.keys(i.Setter.functionSetter[n]).map(function(e){var t=i.Setter.functionSetter[n][e];t&&t.selector&&!t.selectorRef&&(t.selectorRef=t.selector(i.State[n]))});var c=function(){if(r)return E(n,r),Promise.resolve(o(t)).then(function(){})}();return Promise.resolve(c&&c.then?c.then(function(){}):void 0)}catch(e){return Promise.reject(e)}},f=function(e,t){try{var n=e.modelName,r=e.next,o=e.Global,i=e.__hash,c=o.Setter.functionSetter[n];return"function"===e.type&&i&&c&&c[i]&&c[i].setState&&c[i].setState(o.State[n]),Promise.resolve(r(t)).then(function(){})}catch(e){return Promise.reject(e)}},m=function(e,t){try{var n=e.next,r=e.Global.subscriptions[e.modelName+"_"+e.actionName];return r&&r.forEach(function(t){t(e)}),Promise.resolve(n(t)).then(function(){})}catch(e){return Promise.reject(e)}},S=function(e,t){try{var n=e.Global,r=!0===a.logger.enable||"function"==typeof a.logger.enable&&a.logger.enable(e)?(console.group("%c "+e.modelName+" State Change %c "+(new Date).toLocaleTimeString(),"color: gray; font-weight: lighter;","color: black; font-weight: bold;"),console.log("%c Previous","color: #9E9E9E; font-weight: bold",n.State[e.modelName]),console.log("%c Action","color: #03A9F4; font-weight: bold",e.actionName,"payload: "+e.params),Promise.resolve(e.next(t)).then(function(){console.log("%c Next","color: #4CAF50; font-weight: bold",n.State[e.modelName]),console.groupEnd()})):Promise.resolve(e.next(t)).then(function(){});return Promise.resolve(r&&r.then?r.then(function(){}):void 0)}catch(e){return Promise.reject(e)}},d=function(e,t){try{var n=e.Global;return Promise.resolve(e.next(t)).then(function(){n.withDevTools&&a.devtools.enable&&n.devTools.send(e.modelName+"_"+e.actionName,n.State)})}catch(e){return Promise.reject(e)}},v=function(e,t){try{var n=e.modelName,r=e.next,o=e.Global;return o.Setter.classSetter&&o.Setter.classSetter(o.State),o.Setter.functionSetter[n]&&Object.keys(o.Setter.functionSetter[n]).map(function(e){var t=o.Setter.functionSetter[n][e];if(t)if(t.selector){var r=t.selector(o.State[n]);x(r,t.selectorRef)||(t.selectorRef=r,t.setState(o.State[n]))}else t.setState(o.State[n])}),Promise.resolve(r(t)).then(function(){})}catch(e){return Promise.reject(e)}},h=[s,S,d,u,l,f,v,m],_={communicator:v,consoleDebugger:S,devToolsListener:d,getNewState:u,getNewStateWithCache:function(e){return void 0===e&&(e=5e3),function(t,n){try{var r=t.Global,o=t.modelName,i=t.next,c=t.actionName;return Promise.resolve(Promise.race([(0,t.action)(t.params,{actions:(0,t.consumerActions)(r.Actions[o],{modelName:o}),state:r.State[o]}),N(e,j(o,c))])).then(function(e){return t.newState=e||null,Promise.resolve(i(n)).then(function(){})})}catch(e){return Promise.reject(e)}}},setNewState:l,stateUpdater:f,subscription:m,tryCatch:s,config:a},p=function(e,t){try{t.next=function(e){return e.length>0&&e[0](t,e.slice(1))};var n=function(){if(e.length>0)return Promise.resolve(e[0](t,e.slice(1))).then(function(){})}();return Promise.resolve(n&&n.then?n.then(function(){}):void 0)}catch(e){return Promise.reject(e)}},b=r.createContext({}),y=b.Consumer;if(!console.group){var g=[],P="-".repeat(80);console.group=function(e){g.push(e),console.log("%c \nBEGIN GROUP: %c",P,e),console.groupEnd=function(){console.log("END GROUP: %c\n%c",g.pop(),P)}}}var w=function(e,t){var n={};return Object.keys(e).forEach(function(r){n[r]=function(e,t){return function(n,r){try{return Promise.resolve(p(h,{Global:c,action:e,actionName:e.name,consumerActions:w,middlewareConfig:r,modelName:t.modelName,newState:null,params:n,type:"outer"})).then(function(){})}catch(e){return Promise.reject(e)}}}(e[r],t)}),n},E=function(e,t){if("function"==typeof t){var r=c.State[e];r=n(r,t),c.State=n(c.State,function(t){t[e]=r})}else c.State=n(c.State,function(n){n[e]=o({},n[e],t)});return c.State},N=function(e,t){return new Promise(function(n){return setTimeout(function(){console.log(e),n(t)},e)})},O=function(e,t){try{var r={__FROM_SERVER__:!0};return Promise.resolve(Promise.all(Object.keys(c.State).map(function(i){try{var a=function(){if(!e||!e.modelName||i===e.modelName||-1!==e.modelName.indexOf(i)){var a=function(e){t&&t.isServer?r[i]=e:c.State=n(c.State,function(t){t[i]=o({},t[i],e)})},s=c.AsyncState[i];return s?Promise.resolve(s(e)).then(a):a({})}}();return Promise.resolve(a&&a.then?a.then(function(){}):void 0)}catch(e){return Promise.reject(e)}}))).then(function(){return t&&t.isServer?r:c.State})}catch(e){return Promise.reject(e)}},j=function(e,t){var n=localStorage.getItem("__REACT_MODELX__"+e+"_"+t);return n?JSON.parse(n):null},x=function(e,t){if(e===t)return!0;if("object"!=typeof e||null===e||"object"!=typeof t||null===t)return!1;var n=Object.keys(e),r=Object.keys(t);if(n.length!==r.length)return!1;for(var o=0;o<n.length;o++)if(!Object.prototype.hasOwnProperty.call(t,n[o])||e[n[o]]!==t[n[o]])return!1;return!0};t.enableES5();var A=function(e,t){R(e,t,void 0)},R=function(e,t,n){Array.isArray(t)?t.forEach(function(t){c.subscriptions[e+"_"+t]||(c.subscriptions[e+"_"+t]=[]),n?c.subscriptions[e+"_"+t].push(n):c.subscriptions[e+"_"+t]=[]}):(c.subscriptions[e+"_"+t]||(c.subscriptions[e+"_"+t]=[]),n?c.subscriptions[e+"_"+t].push(n):c.subscriptions[e+"_"+t]=[])},C=function(e){return c.State[e]},T=function(e,t){void 0===t&&(t={type:"outer"});var n={};return Object.keys(c.Actions[e]).forEach(function(r){return n[r]=function(n,i){try{var a=o({action:c.Actions[e][r],actionName:r,consumerActions:w,middlewareConfig:i,modelName:e,newState:null,params:n},t,{Global:c}),s=c.Middlewares[e]?Promise.resolve(p(c.Middlewares[e],a)).then(function(){}):Promise.resolve(p(h,a)).then(function(){});return Promise.resolve(s&&s.then?s.then(function(){}):void 0)}catch(e){return Promise.reject(e)}}}),n},M=function(e,t){var n=r.useState({})[1],o=r.useRef("");r.useLayoutEffect(function(){c.uid+=1;var r=""+c.uid;return o.current=r,c.Setter.functionSetter[e]||(c.Setter.functionSetter[e]={}),c.Setter.functionSetter[e][r]={setState:n,selector:t},function(){delete c.Setter.functionSetter[e][r]}},[]);var i=T(e,{__hash:o.current,type:"function"});return[t?t(C(e)):C(e),i]},G=function(e){function t(){var t;return(t=e.apply(this,arguments)||this).state=c.State,t}return i(t,e),t.prototype.render=function(){var e=this.props.children;return c.Setter.classSetter=this.setState.bind(this),r.createElement(b.Provider,{value:o({},this.state)},e)},t}(r.PureComponent);exports.Consumer=y,exports.Model=function(e,t,r){if(void 0!==e.state){c.uid+=1;var i="__"+c.uid;c.State=n(c.State,function(t){t[i]=e.state}),e.middlewares&&(c.Middlewares[i]=e.middlewares),c.Actions[i]=e.actions,c.AsyncState[i]=e.asyncState,t&&(c.Context[i]=t);var a=T(i);return{__id:i,actions:a,getState:function(){return C(i)},subscribe:function(e,t){return R(i,e,t)},unsubscribe:function(e){return A(i,e)},useStore:function(e){return M(i,e)}}}if(e.actions){console.error("invalid model(s) schema: ",e);var s=function(e){return function(){return e}};return{__ERROR__:!0,actions:s({}),getActions:s({}),getInitialState:s({}),getState:s({}),subscribe:s(),unsubscribe:s(),useStore:s([{},{}])}}t&&!t.__FROM_SERVER__&&(c.State=n(c.State,function(e){Object.assign(e,t||{})})),r&&(c.Context.__global=r),Object.keys(e).forEach(function(r){var i=e[r];if(i.__ERROR__)return console.error(r+" model's schema is invalid"),c.State=n(c.State,function(e){e[r]={}}),void(c.Actions[r]={});void 0===i.useStore?(t&&t.__FROM_SERVER__?c.State=n(c.State,function(e){e[r]=o({},i.state,t[r])}):c.State[r]||(c.State=n(c.State,function(e){e[r]=i.state})),i.middlewares&&(c.Middlewares[r]=i.middlewares),c.Actions[r]=i.actions,c.AsyncState[r]=i.asyncState):(c.State[r]&&t||(c.State=n(c.State,function(e){e[r]=e[i.__id]})),t&&t.__FROM_SERVER__&&(c.State=n(c.State,function(e){e[r]=o({},e[i.__id],t[r])})),c.Actions[r]=c.Actions[i.__id],c.AsyncState[r]=c.AsyncState[i.__id],c.Middlewares[r]=c.Middlewares[i.__id],c.Context[r]=c.Context[i.__id])});var u=Object.keys(e).reduce(function(e,t){var n;return o({},e,((n={})[t]=T(t),n))},{});return c.withDevTools="undefined"!=typeof window&&window.__REDUX_DEVTOOLS_EXTENSION__,c.withDevTools&&_.config.devtools.enable&&(c.devTools=window.__REDUX_DEVTOOLS_EXTENSION__,c.devTools.connect()),{actions:u,getActions:T,getInitialState:O,getState:C,subscribe:R,unsubscribe:A,useStore:M}},exports.Provider=G,exports.actionMiddlewares=h,exports.connect=function(e,t,n){return function(a){return function(s){function u(){return s.apply(this,arguments)||this}return i(u,s),u.prototype.render=function(){var i=this,s=this.props,u=s.state,l=void 0===u?{}:u,f=s.actions,m=void 0===f?{}:f;return r.createElement(y,null,function(s){var u=s[""+e],f=c.Actions[e];return r.createElement(a,Object.assign({},i.props,{state:o({},l,t?t(u):u),actions:o({},m,n?n(w(f,{modelName:e})):w(f,{modelName:e}))}))})},u}(r.PureComponent)}},exports.getInitialState=O,exports.getState=C,exports.middlewares=_;
var e,t=require("immer"),r=(e=t)&&"object"==typeof e&&"default"in e?e.default:e,n=require("react");function o(){return(o=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e}).apply(this,arguments)}function a(e,t){e.prototype=Object.create(t.prototype),e.prototype.constructor=e,e.__proto__=t}var c={Actions:{},AsyncState:{},Context:{__global:{}},Middlewares:{},Setter:{classSetter:void 0,functionSetter:{}},State:{},devTools:void 0,subscriptions:{},mutableState:{},uid:0,storeId:0,currentStoreId:0,withDevTools:!1},i={logger:{enable:!1},devtools:{enable:!1},tryCatch:{enable:!0}},s=function(e,t){try{var r=e.next;return Promise.resolve(i.tryCatch.enable?r(t).catch(function(e){return console.log(e)}):r(t))}catch(e){return Promise.reject(e)}},u=function(e,t){try{var r=e.modelName,n=e.next,a=e.Global;return Promise.resolve((0,e.action)(e.params,o({actions:(0,e.consumerActions)(a.Actions[r],{modelName:r}),state:a.State[r]},a.Context.__global||{},a.Context[r]||{}))).then(function(r){return e.newState=r||null,Promise.resolve(n(t))})}catch(e){return Promise.reject(e)}},l=function(e,t){try{var r=e.modelName,n=e.newState,o=e.next,a=e.Global;return a.Setter.functionSetter[r]&&Object.keys(a.Setter.functionSetter[r]).map(function(e){var t=a.Setter.functionSetter[r][e];t&&t.selector&&!t.selectorRef&&(t.selectorRef=t.selector(a.State[r]))}),Promise.resolve(function(){if(n)return N(r,n),Promise.resolve(o(t))}())}catch(e){return Promise.reject(e)}},f=function(e,t){try{var r=e.modelName,n=e.next,o=e.Global,a=e.__hash,c=o.Setter.functionSetter[r];return"function"===e.type&&a&&c&&c[a]&&c[a].setState&&c[a].setState(o.State[r]),Promise.resolve(n(t))}catch(e){return Promise.reject(e)}},m=function(e,t){try{var r=e.next,n=e.Global.subscriptions[e.modelName+"_"+e.actionName];return n&&n.forEach(function(t){t(e)}),Promise.resolve(r(t))}catch(e){return Promise.reject(e)}},S=function(e,t){try{var r=e.Global;return!0===i.logger.enable||"function"==typeof i.logger.enable&&i.logger.enable(e)?(console.group("%c "+e.modelName+" State Change %c "+(new Date).toLocaleTimeString(),"color: gray; font-weight: lighter;","color: black; font-weight: bold;"),console.log("%c Previous","color: #9E9E9E; font-weight: bold",r.State[e.modelName]),console.log("%c Action","color: #03A9F4; font-weight: bold",e.actionName,"payload: "+e.params),Promise.resolve(e.next(t)).then(function(t){return console.log("%c Next","color: #4CAF50; font-weight: bold",r.State[e.modelName]),console.groupEnd(),t})):Promise.resolve(e.next(t))}catch(e){return Promise.reject(e)}},d=function(e,t){try{var r=e.Global;return Promise.resolve(e.next(t)).then(function(t){return r.withDevTools&&i.devtools.enable&&r.devTools.send(e.modelName+"_"+e.actionName,r.State),t})}catch(e){return Promise.reject(e)}},v=function(e,t){try{var r=e.modelName,n=e.next,o=e.Global;return o.Setter.classSetter&&o.Setter.classSetter(o.State),o.Setter.functionSetter[r]&&Object.keys(o.Setter.functionSetter[r]).map(function(e){var t=o.Setter.functionSetter[r][e];if(t)if(t.selector){var n=t.selector(o.State[r]);A(n,t.selectorRef)||(t.selectorRef=n,t.setState(o.State[r]))}else t.setState(o.State[r])}),Promise.resolve(n(t))}catch(e){return Promise.reject(e)}},_=[s,S,d,u,l,f,v,m],p={communicator:v,consoleDebugger:S,devToolsListener:d,getNewState:u,getNewStateWithCache:function(e){return void 0===e&&(e=5e3),function(t,r){try{var n=t.Global,o=t.modelName,a=t.next,c=t.actionName;return Promise.resolve(Promise.race([(0,t.action)(t.params,{actions:(0,t.consumerActions)(n.Actions[o],{modelName:o}),state:n.State[o]}),E(e,j(o,c))])).then(function(e){return t.newState=e||null,Promise.resolve(a(r))})}catch(e){return Promise.reject(e)}}},setNewState:l,stateUpdater:f,subscription:m,tryCatch:s,config:i},b=function(e,t){try{return t.next=function(e){return e.length>0?e[0](t,e.slice(1)):t.newState},Promise.resolve(e[0](t,e.slice(1)))}catch(e){return Promise.reject(e)}},h=n.createContext({}),y=h.Consumer;if(!console.group){var g=[],P="-".repeat(80);console.group=function(e){g.push(e),console.log("%c \nBEGIN GROUP: %c",P,e),console.groupEnd=function(){console.log("END GROUP: %c\n%c",g.pop(),P)}}}var w=function(e,t){var r={};return Object.keys(e).forEach(function(n){r[n]=function(e,t){return function(r,n){try{return Promise.resolve(b(_,{Global:c,action:e,actionName:e.name,consumerActions:w,middlewareConfig:n,modelName:t.modelName,newState:null,params:r,type:"outer"}))}catch(e){return Promise.reject(e)}}}(e[n],t)}),r},N=function(e,t){if("function"==typeof t){var n=c.State[e];n=r(n,t),c.State=r(c.State,function(t){t[e]=n})}else c.State=r(c.State,function(r){r[e]=o({},r[e],t)});return c.State},E=function(e,t){return new Promise(function(r){return setTimeout(function(){console.log(e),r(t)},e)})},O=function(e,t){try{var n={__FROM_SERVER__:!0};return Promise.resolve(Promise.all(Object.keys(c.State).map(function(a){try{var i=function(){if(!e||!e.modelName||a===e.modelName||-1!==e.modelName.indexOf(a)){var i=function(e){t&&t.isServer?n[a]=e:c.State=r(c.State,function(t){t[a]=o({},t[a],e)})},s=c.AsyncState[a];return s?Promise.resolve(s(e)).then(i):i({})}}();return Promise.resolve(i&&i.then?i.then(function(){}):void 0)}catch(e){return Promise.reject(e)}}))).then(function(){return t&&t.isServer?n:c.State})}catch(e){return Promise.reject(e)}},j=function(e,t){var r=localStorage.getItem("__REACT_MODELX__"+e+"_"+t);return r?JSON.parse(r):null},A=function(e,t){if(e===t)return!0;if("object"!=typeof e||null===e||"object"!=typeof t||null===t)return!1;var r=Object.keys(e),n=Object.keys(t);if(r.length!==n.length)return!1;for(var o=0;o<r.length;o++)if(!Object.prototype.hasOwnProperty.call(t,r[o])||e[r[o]]!==t[r[o]])return!1;return!0};t.enableES5();var x=function(e,t){R(e,t,void 0)},R=function(e,t,r){Array.isArray(t)?t.forEach(function(t){c.subscriptions[e+"_"+t]||(c.subscriptions[e+"_"+t]=[]),r?c.subscriptions[e+"_"+t].push(r):c.subscriptions[e+"_"+t]=[]}):(c.subscriptions[e+"_"+t]||(c.subscriptions[e+"_"+t]=[]),r?c.subscriptions[e+"_"+t].push(r):c.subscriptions[e+"_"+t]=[])},C=function(e){return c.State[e]},T=function(e,t){void 0===t&&(t={type:"outer"});var r={};return Object.keys(c.Actions[e]).forEach(function(n){return r[n]=function(r,a){try{var i=o({action:c.Actions[e][n],actionName:n,consumerActions:w,middlewareConfig:a,modelName:e,newState:null,params:r},t,{Global:c});return Promise.resolve(b(c.Middlewares[e]?c.Middlewares[e]:_,i))}catch(e){return Promise.reject(e)}}}),r},I=function(e,t){var r=n.useState({})[1],o=n.useRef("");n.useLayoutEffect(function(){c.uid+=1;var n=""+c.uid;return o.current=n,c.Setter.functionSetter[e]||(c.Setter.functionSetter[e]={}),c.Setter.functionSetter[e][n]={setState:r,selector:t},function(){delete c.Setter.functionSetter[e][n]}},[]);var a=T(e,{__hash:o.current,type:"function"});return[t?t(C(e)):C(e),a]},M=function(e){function t(){var t;return(t=e.apply(this,arguments)||this).state=c.State,t}return a(t,e),t.prototype.render=function(){var e=this.props.children;return c.Setter.classSetter=this.setState.bind(this),n.createElement(h.Provider,{value:o({},this.state)},e)},t}(n.PureComponent);exports.Consumer=y,exports.Model=function(e,t,n){if(void 0!==e.state){c.storeId+=1;var a="__"+c.storeId;c.State=r(c.State,function(t){t[a]=e.state}),e.middlewares&&(c.Middlewares[a]=e.middlewares),c.Actions[a]=e.actions,c.AsyncState[a]=e.asyncState,t&&(c.Context[a]=t);var i=T(a);return{__id:a,actions:i,getState:function(){return C(a)},subscribe:function(e,t){return R(a,e,t)},unsubscribe:function(e){return x(a,e)},useStore:function(e){return I(a,e)}}}if(e.actions){console.error("invalid model(s) schema: ",e);var s=function(e){return function(){return e}};return{__ERROR__:!0,actions:s({}),getActions:s({}),getInitialState:s({}),getState:s({}),subscribe:s(),unsubscribe:s(),useStore:s([{},{}])}}t&&!t.__FROM_SERVER__&&(c.State=r(c.State,function(e){Object.assign(e,t||{})})),n&&(c.Context.__global=n),Object.keys(e).forEach(function(n){var a=e[n];if(a.__ERROR__)return console.error(n+" model's schema is invalid"),c.State=r(c.State,function(e){e[n]={}}),void(c.Actions[n]={});void 0===a.useStore?(t&&t.__FROM_SERVER__?c.State=r(c.State,function(e){e[n]=o({},a.state,t[n])}):c.State[n]||(c.State=r(c.State,function(e){e[n]=a.state})),a.middlewares&&(c.Middlewares[n]=a.middlewares),c.Actions[n]=a.actions,c.AsyncState[n]=a.asyncState):(c.State[n]&&t||(c.State=r(c.State,function(e){e[n]=e[a.__id]})),t&&t.__FROM_SERVER__&&(c.State=r(c.State,function(e){e[n]=o({},e[a.__id],t[n])})),c.Actions[n]=c.Actions[a.__id],c.AsyncState[n]=c.AsyncState[a.__id],c.Middlewares[n]=c.Middlewares[a.__id],c.Context[n]=c.Context[a.__id])});var u=Object.keys(e).reduce(function(e,t){var r;return o({},e,((r={})[t]=T(t),r))},{});return c.withDevTools="undefined"!=typeof window&&window.__REDUX_DEVTOOLS_EXTENSION__,c.withDevTools&&p.config.devtools.enable&&(c.devTools=window.__REDUX_DEVTOOLS_EXTENSION__,c.devTools.connect()),{actions:u,getActions:T,getInitialState:O,getState:C,subscribe:R,unsubscribe:x,useStore:I}},exports.Provider=M,exports.actionMiddlewares=_,exports.connect=function(e,t,r){return function(i){return function(s){function u(){return s.apply(this,arguments)||this}return a(u,s),u.prototype.render=function(){var a=this,s=this.props,u=s.state,l=void 0===u?{}:u,f=s.actions,m=void 0===f?{}:f;return n.createElement(y,null,function(s){var u=s[""+e],f=c.Actions[e];return n.createElement(i,Object.assign({},a.props,{state:o({},l,t?t(u):u),actions:o({},m,r?r(w(f,{modelName:e})):w(f,{modelName:e}))}))})},u}(n.PureComponent)}},exports.createStore=function(e){c.storeId+=1;var t=c.storeId,r="__"+t;c.Actions[r]||(c.Actions[r]={}),c.mutableState[t]||(c.mutableState[t]={count:0});var n=function(){return c.mutableState[t].count=0,c.currentStoreId=t,e()};return{useStore:function(){return I(r,n)[0]},getState:function(){return n()}}},exports.getInitialState=O,exports.getState=C,exports.middlewares=p,exports.useModel=function(e){var t=c.currentStoreId,r=c.mutableState[t].count;return c.mutableState[t].count+=1,c.mutableState[t][r]||(c.mutableState[t][r]=e),[c.mutableState[t][r],function(e){try{var n={Global:c,action:function(){return e},actionName:"setter",consumerActions:w,middlewareConfig:{},modelName:"__"+t,newState:{},params:void 0,type:"outer"};return c.mutableState[t][r]=e,Promise.resolve(b(_,n))}catch(e){return Promise.reject(e)}}]};

@@ -1,1 +0,1 @@

import t,{enableES5 as e}from"immer";import{createContext as o,useState as n,useRef as a,useLayoutEffect as s,PureComponent as c,createElement as i}from"react";var r={Actions:{},AsyncState:{},Context:{__global:{}},Middlewares:{},Setter:{classSetter:void 0,functionSetter:{}},State:{},devTools:void 0,subscriptions:{},uid:0,withDevTools:!1};const l={logger:{enable:!1},devtools:{enable:!1},tryCatch:{enable:!0}},S=async(t,e)=>{const{next:o}=t;l.tryCatch.enable?await o(e).catch(t=>console.log(t)):await o(e)},u=async(t,e)=>{const{action:o,modelName:n,consumerActions:a,params:s,next:c,Global:i}=t;t.newState=await o(s,{actions:a(i.Actions[n],{modelName:n}),state:i.State[n],...i.Context.__global||{},...i.Context[n]||{}})||null,await c(e)},d=async(t,e)=>{const{modelName:o,newState:n,next:a,Global:s}=t;s.Setter.functionSetter[o]&&Object.keys(s.Setter.functionSetter[o]).map(t=>{const e=s.Setter.functionSetter[o][t];e&&e.selector&&!e.selectorRef&&(e.selectorRef=e.selector(s.State[o]))}),n&&(O(o,n),await a(e))},m=async(t,e)=>{const{modelName:o,next:n,Global:a,__hash:s}=t,c=a.Setter.functionSetter[o];"function"===t.type&&s&&c&&c[s]&&c[s].setState&&c[s].setState(a.State[o]),await n(e)},_=async(t,e)=>{const{modelName:o,actionName:n,next:a,Global:s}=t,c=s.subscriptions[`${o}_${n}`];c&&c.forEach(e=>{e(t)}),await a(e)},b=async(t,e)=>{const{Global:o}=t;!0===l.logger.enable||"function"==typeof l.logger.enable&&l.logger.enable(t)?(console.group(`%c ${t.modelName} State Change %c ${(new Date).toLocaleTimeString()}`,"color: gray; font-weight: lighter;","color: black; font-weight: bold;"),console.log("%c Previous","color: #9E9E9E; font-weight: bold",o.State[t.modelName]),console.log("%c Action","color: #03A9F4; font-weight: bold",t.actionName,"payload: "+t.params),await t.next(e),console.log("%c Next","color: #4CAF50; font-weight: bold",o.State[t.modelName]),console.groupEnd()):await t.next(e)},f=async(t,e)=>{const{Global:o}=t;await t.next(e),o.withDevTools&&l.devtools.enable&&o.devTools.send(`${t.modelName}_${t.actionName}`,o.State)},w=async(t,e)=>{const{modelName:o,next:n,Global:a}=t;a.Setter.classSetter&&a.Setter.classSetter(a.State),a.Setter.functionSetter[o]&&Object.keys(a.Setter.functionSetter[o]).map(t=>{const e=a.Setter.functionSetter[o][t];if(e)if(e.selector){const t=e.selector(a.State[o]);$(t,e.selectorRef)||(e.selectorRef=t,e.setState(a.State[o]))}else e.setState(a.State[o])}),await n(e)},g=[S,b,f,u,d,m,w,_],p={communicator:w,consoleDebugger:b,devToolsListener:f,getNewState:u,getNewStateWithCache:(t=5e3)=>async(e,o)=>{const{action:n,Global:a,modelName:s,consumerActions:c,params:i,next:r,actionName:l}=e;e.newState=await Promise.race([n(i,{actions:c(a.Actions[s],{modelName:s}),state:a.State[s]}),A(t,v(s,l))])||null,await r(o)},setNewState:d,stateUpdater:m,subscription:_,tryCatch:S,config:l},y=async(t,e)=>{e.next=t=>t.length>0&&t[0](e,t.slice(1)),t.length>0&&await t[0](e,t.slice(1))},h=o({}),N=h.Consumer;if(!console.group){const t=[],e="-".repeat(80);console.group=function(o){t.push(o),console.log("%c \nBEGIN GROUP: %c",e,o),console.groupEnd=function(){console.log("END GROUP: %c\n%c",t.pop(),e)}}}const E=(t,e)=>{const o={};return Object.keys(t).forEach(n=>{o[n]=((t,e)=>async(o,n)=>{const a={Global:r,action:t,actionName:t.name,consumerActions:E,middlewareConfig:n,modelName:e.modelName,newState:null,params:o,type:"outer"};await y(g,a)})(t[n],e)}),o},O=(e,o)=>{if("function"==typeof o){let n=r.State[e];n=t(n,o),r.State=t(r.State,t=>{t[e]=n})}else r.State=t(r.State,t=>{t[e]={...t[e],...o}});return r.State},A=(t,e)=>new Promise(o=>setTimeout(()=>{console.log(t),o(e)},t)),R=async(e,o)=>{const n={__FROM_SERVER__:!0};return await Promise.all(Object.keys(r.State).map(async a=>{if(!e||!e.modelName||a===e.modelName||-1!==e.modelName.indexOf(a)){const s=r.AsyncState[a],c=s?await s(e):{};o&&o.isServer?n[a]=c:r.State=t(r.State,t=>{t[a]={...t[a],...c}})}})),o&&o.isServer?n:r.State},v=(t,e)=>{const o=localStorage.getItem(`__REACT_MODELX__${t}_${e}`);return o?JSON.parse(o):null},$=(t,e)=>{if(t===e)return!0;if("object"!=typeof t||null===t||"object"!=typeof e||null===e)return!1;const o=Object.keys(t),n=Object.keys(e);if(o.length!==n.length)return!1;for(let n=0;n<o.length;n++)if(!Object.prototype.hasOwnProperty.call(e,o[n])||t[o[n]]!==e[o[n]])return!1;return!0};function x(e,o,n){if(void 0!==e.state){r.uid+=1;const n="__"+r.uid;r.State=t(r.State,t=>{t[n]=e.state}),e.middlewares&&(r.Middlewares[n]=e.middlewares),r.Actions[n]=e.actions,r.AsyncState[n]=e.asyncState,o&&(r.Context[n]=o);const a=G(n);return{__id:n,actions:a,getState:()=>j(n),subscribe:(t,e)=>T(n,t,e),unsubscribe:t=>C(n,t),useStore:t=>D(n,t)}}{if(e.actions){console.error("invalid model(s) schema: ",e);const t=t=>(...e)=>t;return{__ERROR__:!0,actions:t({}),getActions:t({}),getInitialState:t({}),getState:t({}),subscribe:t(),unsubscribe:t(),useStore:t([{},{}])}}o&&!o.__FROM_SERVER__&&(r.State=t(r.State,t=>{Object.assign(t,o||{})})),n&&(r.Context.__global=n),Object.keys(e).forEach(n=>{const a=e[n];if(a.__ERROR__)return console.error(n+" model's schema is invalid"),r.State=t(r.State,t=>{t[n]={}}),void(r.Actions[n]={});(t=>void 0!==t.useStore)(a)?(r.State[n]&&o||(r.State=t(r.State,t=>{t[n]=t[a.__id]})),o&&o.__FROM_SERVER__&&(r.State=t(r.State,t=>{t[n]={...t[a.__id],...o[n]}})),r.Actions[n]=r.Actions[a.__id],r.AsyncState[n]=r.AsyncState[a.__id],r.Middlewares[n]=r.Middlewares[a.__id],r.Context[n]=r.Context[a.__id]):(o&&o.__FROM_SERVER__?r.State=t(r.State,t=>{t[n]={...a.state,...o[n]}}):r.State[n]||(r.State=t(r.State,t=>{t[n]=a.state})),a.middlewares&&(r.Middlewares[n]=a.middlewares),r.Actions[n]=a.actions,r.AsyncState[n]=a.asyncState)});const a=Object.keys(e).reduce((t,e)=>({...t,[e]:G(e)}),{});return r.withDevTools="undefined"!=typeof window&&window.__REDUX_DEVTOOLS_EXTENSION__,r.withDevTools&&p.config.devtools.enable&&(r.devTools=window.__REDUX_DEVTOOLS_EXTENSION__,r.devTools.connect()),{actions:a,getActions:G,getInitialState:R,getState:j,subscribe:T,unsubscribe:C,useStore:D}}}e();const C=(t,e)=>{T(t,e,void 0)},T=(t,e,o)=>{Array.isArray(e)?e.forEach(e=>{r.subscriptions[`${t}_${e}`]||(r.subscriptions[`${t}_${e}`]=[]),o?r.subscriptions[`${t}_${e}`].push(o):r.subscriptions[`${t}_${e}`]=[]}):(r.subscriptions[`${t}_${e}`]||(r.subscriptions[`${t}_${e}`]=[]),o?r.subscriptions[`${t}_${e}`].push(o):r.subscriptions[`${t}_${e}`]=[])},j=t=>r.State[t],G=(t,e={type:"outer"})=>{const o={};return Object.keys(r.Actions[t]).forEach(n=>o[n]=async(o,a)=>{const s={action:r.Actions[t][n],actionName:n,consumerActions:E,middlewareConfig:a,modelName:t,newState:null,params:o,...e,Global:r};r.Middlewares[t]?await y(r.Middlewares[t],s):await y(g,s)}),o},D=(t,e)=>{const o=n({})[1],c=a("");s(()=>{r.uid+=1;const n=""+r.uid;return c.current=n,r.Setter.functionSetter[t]||(r.Setter.functionSetter[t]={}),r.Setter.functionSetter[t][n]={setState:o,selector:e},function(){delete r.Setter.functionSetter[t][n]}},[]);const i=G(t,{__hash:c.current,type:"function"});return[e?e(j(t)):j(t),i]};class M extends c{constructor(){super(...arguments),this.state=r.State}render(){const{children:t}=this.props;return r.Setter.classSetter=this.setState.bind(this),i(h.Provider,{value:{...this.state}},t)}}const k=(t,e,o)=>n=>class extends c{render(){const{state:a={},actions:s={}}=this.props;return i(N,null,c=>{const{[""+t]:l}=c,S=r.Actions[t];return i(n,Object.assign({},this.props,{state:{...a,...e?e(l):l},actions:{...s,...o?o(E(S,{modelName:t})):E(S,{modelName:t})}}))})}};export{N as Consumer,x as Model,M as Provider,g as actionMiddlewares,k as connect,R as getInitialState,j as getState,p as middlewares};
import t,{enableES5 as e}from"immer";import{createContext as o,useState as n,useRef as a,useLayoutEffect as s,PureComponent as r,createElement as c}from"react";var i={Actions:{},AsyncState:{},Context:{__global:{}},Middlewares:{},Setter:{classSetter:void 0,functionSetter:{}},State:{},devTools:void 0,subscriptions:{},mutableState:{},uid:0,storeId:0,currentStoreId:0,withDevTools:!1};const l={logger:{enable:!1},devtools:{enable:!1},tryCatch:{enable:!0}},u=async(t,e)=>{const{next:o}=t;return l.tryCatch.enable?await o(e).catch(t=>console.log(t)):await o(e)},S=async(t,e)=>{const{action:o,modelName:n,consumerActions:a,params:s,next:r,Global:c}=t;return t.newState=await o(s,{actions:a(c.Actions[n],{modelName:n}),state:c.State[n],...c.Context.__global||{},...c.Context[n]||{}})||null,await r(e)},d=async(t,e)=>{const{modelName:o,newState:n,next:a,Global:s}=t;if(s.Setter.functionSetter[o]&&Object.keys(s.Setter.functionSetter[o]).map(t=>{const e=s.Setter.functionSetter[o][t];e&&e.selector&&!e.selectorRef&&(e.selectorRef=e.selector(s.State[o]))}),n)return E(o,n),await a(e)},m=async(t,e)=>{const{modelName:o,next:n,Global:a,__hash:s}=t,r=a.Setter.functionSetter[o];return"function"===t.type&&s&&r&&r[s]&&r[s].setState&&r[s].setState(a.State[o]),await n(e)},_=async(t,e)=>{const{modelName:o,actionName:n,next:a,Global:s}=t,r=s.subscriptions[`${o}_${n}`];return r&&r.forEach(e=>{e(t)}),await a(e)},b=async(t,e)=>{const{Global:o}=t;if(!0===l.logger.enable||"function"==typeof l.logger.enable&&l.logger.enable(t)){console.group(`%c ${t.modelName} State Change %c ${(new Date).toLocaleTimeString()}`,"color: gray; font-weight: lighter;","color: black; font-weight: bold;"),console.log("%c Previous","color: #9E9E9E; font-weight: bold",o.State[t.modelName]),console.log("%c Action","color: #03A9F4; font-weight: bold",t.actionName,"payload: "+t.params);const n=await t.next(e);return console.log("%c Next","color: #4CAF50; font-weight: bold",o.State[t.modelName]),console.groupEnd(),n}return await t.next(e)},f=async(t,e)=>{const{Global:o}=t,n=await t.next(e);return o.withDevTools&&l.devtools.enable&&o.devTools.send(`${t.modelName}_${t.actionName}`,o.State),n},w=async(t,e)=>{const{modelName:o,next:n,Global:a}=t;return a.Setter.classSetter&&a.Setter.classSetter(a.State),a.Setter.functionSetter[o]&&Object.keys(a.Setter.functionSetter[o]).map(t=>{const e=a.Setter.functionSetter[o][t];if(e)if(e.selector){const t=e.selector(a.State[o]);$(t,e.selectorRef)||(e.selectorRef=t,e.setState(a.State[o]))}else e.setState(a.State[o])}),await n(e)},g=[u,b,f,S,d,m,w,_],p={communicator:w,consoleDebugger:b,devToolsListener:f,getNewState:S,getNewStateWithCache:(t=5e3)=>async(e,o)=>{const{action:n,Global:a,modelName:s,consumerActions:r,params:c,next:i,actionName:l}=e;return e.newState=await Promise.race([n(c,{actions:r(a.Actions[s],{modelName:s}),state:a.State[s]}),O(t,R(s,l))])||null,await i(o)},setNewState:d,stateUpdater:m,subscription:_,tryCatch:u,config:l},y=async(t,e)=>(e.next=t=>t.length>0?t[0](e,t.slice(1)):e.newState,await t[0](e,t.slice(1))),h=o({}),N=h.Consumer;if(!console.group){const t=[],e="-".repeat(80);console.group=function(o){t.push(o),console.log("%c \nBEGIN GROUP: %c",e,o),console.groupEnd=function(){console.log("END GROUP: %c\n%c",t.pop(),e)}}}const A=(t,e)=>{const o={};return Object.keys(t).forEach(n=>{o[n]=((t,e)=>async(o,n)=>{const a={Global:i,action:t,actionName:t.name,consumerActions:A,middlewareConfig:n,modelName:e.modelName,newState:null,params:o,type:"outer"};return await y(g,a)})(t[n],e)}),o},E=(e,o)=>{if("function"==typeof o){let n=i.State[e];n=t(n,o),i.State=t(i.State,t=>{t[e]=n})}else i.State=t(i.State,t=>{t[e]={...t[e],...o}});return i.State},O=(t,e)=>new Promise(o=>setTimeout(()=>{console.log(t),o(e)},t)),v=async(e,o)=>{const n={__FROM_SERVER__:!0};return await Promise.all(Object.keys(i.State).map(async a=>{if(!e||!e.modelName||a===e.modelName||-1!==e.modelName.indexOf(a)){const s=i.AsyncState[a],r=s?await s(e):{};o&&o.isServer?n[a]=r:i.State=t(i.State,t=>{t[a]={...t[a],...r}})}})),o&&o.isServer?n:i.State},R=(t,e)=>{const o=localStorage.getItem(`__REACT_MODELX__${t}_${e}`);return o?JSON.parse(o):null},$=(t,e)=>{if(t===e)return!0;if("object"!=typeof t||null===t||"object"!=typeof e||null===e)return!1;const o=Object.keys(t),n=Object.keys(e);if(o.length!==n.length)return!1;for(let n=0;n<o.length;n++)if(!Object.prototype.hasOwnProperty.call(e,o[n])||t[o[n]]!==e[o[n]])return!1;return!0};function x(t){const e=i.currentStoreId,o=i.mutableState[e].count;return i.mutableState[e].count+=1,i.mutableState[e][o]||(i.mutableState[e][o]=t),[i.mutableState[e][o],async t=>{const n={Global:i,action:()=>t,actionName:"setter",consumerActions:A,middlewareConfig:{},modelName:"__"+e,newState:{},params:void 0,type:"outer"};return i.mutableState[e][o]=t,await y(g,n)}]}function C(t){i.storeId+=1;const e=i.storeId,o="__"+e;i.Actions[o]||(i.Actions[o]={}),i.mutableState[e]||(i.mutableState[e]={count:0});const n=()=>(i.mutableState[e].count=0,i.currentStoreId=e,t());return{useStore:()=>M(o,n)[0],getState:()=>n()}}function T(e,o,n){if(void 0!==e.state){i.storeId+=1;const n="__"+i.storeId;i.State=t(i.State,t=>{t[n]=e.state}),e.middlewares&&(i.Middlewares[n]=e.middlewares),i.Actions[n]=e.actions,i.AsyncState[n]=e.asyncState,o&&(i.Context[n]=o);const a=D(n);return{__id:n,actions:a,getState:()=>I(n),subscribe:(t,e)=>G(n,t,e),unsubscribe:t=>j(n,t),useStore:t=>M(n,t)}}{if(e.actions){console.error("invalid model(s) schema: ",e);const t=t=>(...e)=>t;return{__ERROR__:!0,actions:t({}),getActions:t({}),getInitialState:t({}),getState:t({}),subscribe:t(),unsubscribe:t(),useStore:t([{},{}])}}o&&!o.__FROM_SERVER__&&(i.State=t(i.State,t=>{Object.assign(t,o||{})})),n&&(i.Context.__global=n),Object.keys(e).forEach(n=>{const a=e[n];if(a.__ERROR__)return console.error(n+" model's schema is invalid"),i.State=t(i.State,t=>{t[n]={}}),void(i.Actions[n]={});(t=>void 0!==t.useStore)(a)?(i.State[n]&&o||(i.State=t(i.State,t=>{t[n]=t[a.__id]})),o&&o.__FROM_SERVER__&&(i.State=t(i.State,t=>{t[n]={...t[a.__id],...o[n]}})),i.Actions[n]=i.Actions[a.__id],i.AsyncState[n]=i.AsyncState[a.__id],i.Middlewares[n]=i.Middlewares[a.__id],i.Context[n]=i.Context[a.__id]):(o&&o.__FROM_SERVER__?i.State=t(i.State,t=>{t[n]={...a.state,...o[n]}}):i.State[n]||(i.State=t(i.State,t=>{t[n]=a.state})),a.middlewares&&(i.Middlewares[n]=a.middlewares),i.Actions[n]=a.actions,i.AsyncState[n]=a.asyncState)});const a=Object.keys(e).reduce((t,e)=>({...t,[e]:D(e)}),{});return i.withDevTools="undefined"!=typeof window&&window.__REDUX_DEVTOOLS_EXTENSION__,i.withDevTools&&p.config.devtools.enable&&(i.devTools=window.__REDUX_DEVTOOLS_EXTENSION__,i.devTools.connect()),{actions:a,getActions:D,getInitialState:v,getState:I,subscribe:G,unsubscribe:j,useStore:M}}}e();const j=(t,e)=>{G(t,e,void 0)},G=(t,e,o)=>{Array.isArray(e)?e.forEach(e=>{i.subscriptions[`${t}_${e}`]||(i.subscriptions[`${t}_${e}`]=[]),o?i.subscriptions[`${t}_${e}`].push(o):i.subscriptions[`${t}_${e}`]=[]}):(i.subscriptions[`${t}_${e}`]||(i.subscriptions[`${t}_${e}`]=[]),o?i.subscriptions[`${t}_${e}`].push(o):i.subscriptions[`${t}_${e}`]=[])},I=t=>i.State[t],D=(t,e={type:"outer"})=>{const o={};return Object.keys(i.Actions[t]).forEach(n=>o[n]=async(o,a)=>{const s={action:i.Actions[t][n],actionName:n,consumerActions:A,middlewareConfig:a,modelName:t,newState:null,params:o,...e,Global:i};return i.Middlewares[t]?await y(i.Middlewares[t],s):await y(g,s)}),o},M=(t,e)=>{const o=n({})[1],r=a("");s(()=>{i.uid+=1;const n=""+i.uid;return r.current=n,i.Setter.functionSetter[t]||(i.Setter.functionSetter[t]={}),i.Setter.functionSetter[t][n]={setState:o,selector:e},function(){delete i.Setter.functionSetter[t][n]}},[]);const c=D(t,{__hash:r.current,type:"function"});return[e?e(I(t)):I(t),c]};class k extends r{constructor(){super(...arguments),this.state=i.State}render(){const{children:t}=this.props;return i.Setter.classSetter=this.setState.bind(this),c(h.Provider,{value:{...this.state}},t)}}const P=(t,e,o)=>n=>class extends r{render(){const{state:a={},actions:s={}}=this.props;return c(N,null,r=>{const{[""+t]:l}=r,u=i.Actions[t];return c(n,Object.assign({},this.props,{state:{...a,...e?e(l):l},actions:{...s,...o?o(A(u,{modelName:t})):A(u,{modelName:t})}}))})}};export{N as Consumer,T as Model,k as Provider,g as actionMiddlewares,P as connect,C as createStore,v as getInitialState,I as getState,p as middlewares,x as useModel};

@@ -1,1 +0,1 @@

!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("immer"),require("react")):"function"==typeof define&&define.amd?define(["exports","immer","react"],t):t((e=e||self).reactModel={},e.immer,e.react)}(this,function(e,t,n){var r="default"in t?t.default:t;function o(){return(o=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var r in n)Object.prototype.hasOwnProperty.call(n,r)&&(e[r]=n[r])}return e}).apply(this,arguments)}function i(e,t){e.prototype=Object.create(t.prototype),e.prototype.constructor=e,e.__proto__=t}var c={Actions:{},AsyncState:{},Context:{__global:{}},Middlewares:{},Setter:{classSetter:void 0,functionSetter:{}},State:{},devTools:void 0,subscriptions:{},uid:0,withDevTools:!1},a={logger:{enable:!1},devtools:{enable:!1},tryCatch:{enable:!0}},s=function(e,t){try{var n=e.next,r=a.tryCatch.enable?Promise.resolve(n(t).catch(function(e){return console.log(e)})).then(function(){}):Promise.resolve(n(t)).then(function(){});return Promise.resolve(r&&r.then?r.then(function(){}):void 0)}catch(e){return Promise.reject(e)}},u=function(e,t){try{var n=e.modelName,r=e.next,i=e.Global;return Promise.resolve((0,e.action)(e.params,o({actions:(0,e.consumerActions)(i.Actions[n],{modelName:n}),state:i.State[n]},i.Context.__global||{},i.Context[n]||{}))).then(function(n){return e.newState=n||null,Promise.resolve(r(t)).then(function(){})})}catch(e){return Promise.reject(e)}},l=function(e,t){try{var n=e.modelName,r=e.newState,o=e.next,i=e.Global;i.Setter.functionSetter[n]&&Object.keys(i.Setter.functionSetter[n]).map(function(e){var t=i.Setter.functionSetter[n][e];t&&t.selector&&!t.selectorRef&&(t.selectorRef=t.selector(i.State[n]))});var c=function(){if(r)return E(n,r),Promise.resolve(o(t)).then(function(){})}();return Promise.resolve(c&&c.then?c.then(function(){}):void 0)}catch(e){return Promise.reject(e)}},f=function(e,t){try{var n=e.modelName,r=e.next,o=e.Global,i=e.__hash,c=o.Setter.functionSetter[n];return"function"===e.type&&i&&c&&c[i]&&c[i].setState&&c[i].setState(o.State[n]),Promise.resolve(r(t)).then(function(){})}catch(e){return Promise.reject(e)}},m=function(e,t){try{var n=e.next,r=e.Global.subscriptions[e.modelName+"_"+e.actionName];return r&&r.forEach(function(t){t(e)}),Promise.resolve(n(t)).then(function(){})}catch(e){return Promise.reject(e)}},d=function(e,t){try{var n=e.Global,r=!0===a.logger.enable||"function"==typeof a.logger.enable&&a.logger.enable(e)?(console.group("%c "+e.modelName+" State Change %c "+(new Date).toLocaleTimeString(),"color: gray; font-weight: lighter;","color: black; font-weight: bold;"),console.log("%c Previous","color: #9E9E9E; font-weight: bold",n.State[e.modelName]),console.log("%c Action","color: #03A9F4; font-weight: bold",e.actionName,"payload: "+e.params),Promise.resolve(e.next(t)).then(function(){console.log("%c Next","color: #4CAF50; font-weight: bold",n.State[e.modelName]),console.groupEnd()})):Promise.resolve(e.next(t)).then(function(){});return Promise.resolve(r&&r.then?r.then(function(){}):void 0)}catch(e){return Promise.reject(e)}},S=function(e,t){try{var n=e.Global;return Promise.resolve(e.next(t)).then(function(){n.withDevTools&&a.devtools.enable&&n.devTools.send(e.modelName+"_"+e.actionName,n.State)})}catch(e){return Promise.reject(e)}},v=function(e,t){try{var n=e.modelName,r=e.next,o=e.Global;return o.Setter.classSetter&&o.Setter.classSetter(o.State),o.Setter.functionSetter[n]&&Object.keys(o.Setter.functionSetter[n]).map(function(e){var t=o.Setter.functionSetter[n][e];if(t)if(t.selector){var r=t.selector(o.State[n]);A(r,t.selectorRef)||(t.selectorRef=r,t.setState(o.State[n]))}else t.setState(o.State[n])}),Promise.resolve(r(t)).then(function(){})}catch(e){return Promise.reject(e)}},h=[s,d,S,u,l,f,v,m],_={communicator:v,consoleDebugger:d,devToolsListener:S,getNewState:u,getNewStateWithCache:function(e){return void 0===e&&(e=5e3),function(t,n){try{var r=t.Global,o=t.modelName,i=t.next,c=t.actionName;return Promise.resolve(Promise.race([(0,t.action)(t.params,{actions:(0,t.consumerActions)(r.Actions[o],{modelName:o}),state:r.State[o]}),N(e,j(o,c))])).then(function(e){return t.newState=e||null,Promise.resolve(i(n)).then(function(){})})}catch(e){return Promise.reject(e)}}},setNewState:l,stateUpdater:f,subscription:m,tryCatch:s,config:a},p=function(e,t){try{t.next=function(e){return e.length>0&&e[0](t,e.slice(1))};var n=function(){if(e.length>0)return Promise.resolve(e[0](t,e.slice(1))).then(function(){})}();return Promise.resolve(n&&n.then?n.then(function(){}):void 0)}catch(e){return Promise.reject(e)}},b=n.createContext({}),y=b.Consumer;if(!console.group){var g=[],P="-".repeat(80);console.group=function(e){g.push(e),console.log("%c \nBEGIN GROUP: %c",P,e),console.groupEnd=function(){console.log("END GROUP: %c\n%c",g.pop(),P)}}}var w=function(e,t){var n={};return Object.keys(e).forEach(function(r){n[r]=function(e,t){return function(n,r){try{return Promise.resolve(p(h,{Global:c,action:e,actionName:e.name,consumerActions:w,middlewareConfig:r,modelName:t.modelName,newState:null,params:n,type:"outer"})).then(function(){})}catch(e){return Promise.reject(e)}}}(e[r],t)}),n},E=function(e,t){if("function"==typeof t){var n=c.State[e];n=r(n,t),c.State=r(c.State,function(t){t[e]=n})}else c.State=r(c.State,function(n){n[e]=o({},n[e],t)});return c.State},N=function(e,t){return new Promise(function(n){return setTimeout(function(){console.log(e),n(t)},e)})},O=function(e,t){try{var n={__FROM_SERVER__:!0};return Promise.resolve(Promise.all(Object.keys(c.State).map(function(i){try{var a=function(){if(!e||!e.modelName||i===e.modelName||-1!==e.modelName.indexOf(i)){var a=function(e){t&&t.isServer?n[i]=e:c.State=r(c.State,function(t){t[i]=o({},t[i],e)})},s=c.AsyncState[i];return s?Promise.resolve(s(e)).then(a):a({})}}();return Promise.resolve(a&&a.then?a.then(function(){}):void 0)}catch(e){return Promise.reject(e)}}))).then(function(){return t&&t.isServer?n:c.State})}catch(e){return Promise.reject(e)}},j=function(e,t){var n=localStorage.getItem("__REACT_MODELX__"+e+"_"+t);return n?JSON.parse(n):null},A=function(e,t){if(e===t)return!0;if("object"!=typeof e||null===e||"object"!=typeof t||null===t)return!1;var n=Object.keys(e),r=Object.keys(t);if(n.length!==r.length)return!1;for(var o=0;o<n.length;o++)if(!Object.prototype.hasOwnProperty.call(t,n[o])||e[n[o]]!==t[n[o]])return!1;return!0};t.enableES5();var R=function(e,t){x(e,t,void 0)},x=function(e,t,n){Array.isArray(t)?t.forEach(function(t){c.subscriptions[e+"_"+t]||(c.subscriptions[e+"_"+t]=[]),n?c.subscriptions[e+"_"+t].push(n):c.subscriptions[e+"_"+t]=[]}):(c.subscriptions[e+"_"+t]||(c.subscriptions[e+"_"+t]=[]),n?c.subscriptions[e+"_"+t].push(n):c.subscriptions[e+"_"+t]=[])},C=function(e){return c.State[e]},T=function(e,t){void 0===t&&(t={type:"outer"});var n={};return Object.keys(c.Actions[e]).forEach(function(r){return n[r]=function(n,i){try{var a=o({action:c.Actions[e][r],actionName:r,consumerActions:w,middlewareConfig:i,modelName:e,newState:null,params:n},t,{Global:c}),s=c.Middlewares[e]?Promise.resolve(p(c.Middlewares[e],a)).then(function(){}):Promise.resolve(p(h,a)).then(function(){});return Promise.resolve(s&&s.then?s.then(function(){}):void 0)}catch(e){return Promise.reject(e)}}}),n},M=function(e,t){var r=n.useState({})[1],o=n.useRef("");n.useLayoutEffect(function(){c.uid+=1;var n=""+c.uid;return o.current=n,c.Setter.functionSetter[e]||(c.Setter.functionSetter[e]={}),c.Setter.functionSetter[e][n]={setState:r,selector:t},function(){delete c.Setter.functionSetter[e][n]}},[]);var i=T(e,{__hash:o.current,type:"function"});return[t?t(C(e)):C(e),i]},G=function(e){function t(){var t;return(t=e.apply(this,arguments)||this).state=c.State,t}return i(t,e),t.prototype.render=function(){var e=this.props.children;return c.Setter.classSetter=this.setState.bind(this),n.createElement(b.Provider,{value:o({},this.state)},e)},t}(n.PureComponent);e.Consumer=y,e.Model=function(e,t,n){if(void 0!==e.state){c.uid+=1;var i="__"+c.uid;c.State=r(c.State,function(t){t[i]=e.state}),e.middlewares&&(c.Middlewares[i]=e.middlewares),c.Actions[i]=e.actions,c.AsyncState[i]=e.asyncState,t&&(c.Context[i]=t);var a=T(i);return{__id:i,actions:a,getState:function(){return C(i)},subscribe:function(e,t){return x(i,e,t)},unsubscribe:function(e){return R(i,e)},useStore:function(e){return M(i,e)}}}if(e.actions){console.error("invalid model(s) schema: ",e);var s=function(e){return function(){return e}};return{__ERROR__:!0,actions:s({}),getActions:s({}),getInitialState:s({}),getState:s({}),subscribe:s(),unsubscribe:s(),useStore:s([{},{}])}}t&&!t.__FROM_SERVER__&&(c.State=r(c.State,function(e){Object.assign(e,t||{})})),n&&(c.Context.__global=n),Object.keys(e).forEach(function(n){var i=e[n];if(i.__ERROR__)return console.error(n+" model's schema is invalid"),c.State=r(c.State,function(e){e[n]={}}),void(c.Actions[n]={});void 0===i.useStore?(t&&t.__FROM_SERVER__?c.State=r(c.State,function(e){e[n]=o({},i.state,t[n])}):c.State[n]||(c.State=r(c.State,function(e){e[n]=i.state})),i.middlewares&&(c.Middlewares[n]=i.middlewares),c.Actions[n]=i.actions,c.AsyncState[n]=i.asyncState):(c.State[n]&&t||(c.State=r(c.State,function(e){e[n]=e[i.__id]})),t&&t.__FROM_SERVER__&&(c.State=r(c.State,function(e){e[n]=o({},e[i.__id],t[n])})),c.Actions[n]=c.Actions[i.__id],c.AsyncState[n]=c.AsyncState[i.__id],c.Middlewares[n]=c.Middlewares[i.__id],c.Context[n]=c.Context[i.__id])});var u=Object.keys(e).reduce(function(e,t){var n;return o({},e,((n={})[t]=T(t),n))},{});return c.withDevTools="undefined"!=typeof window&&window.__REDUX_DEVTOOLS_EXTENSION__,c.withDevTools&&_.config.devtools.enable&&(c.devTools=window.__REDUX_DEVTOOLS_EXTENSION__,c.devTools.connect()),{actions:u,getActions:T,getInitialState:O,getState:C,subscribe:x,unsubscribe:R,useStore:M}},e.Provider=G,e.actionMiddlewares=h,e.connect=function(e,t,r){return function(a){return function(s){function u(){return s.apply(this,arguments)||this}return i(u,s),u.prototype.render=function(){var i=this,s=this.props,u=s.state,l=void 0===u?{}:u,f=s.actions,m=void 0===f?{}:f;return n.createElement(y,null,function(s){var u=s[""+e],f=c.Actions[e];return n.createElement(a,Object.assign({},i.props,{state:o({},l,t?t(u):u),actions:o({},m,r?r(w(f,{modelName:e})):w(f,{modelName:e}))}))})},u}(n.PureComponent)}},e.getInitialState=O,e.getState=C,e.middlewares=_});
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("immer"),require("react")):"function"==typeof define&&define.amd?define(["exports","immer","react"],t):t((e=e||self).reactModel={},e.immer,e.react)}(this,function(e,t,r){var n="default"in t?t.default:t;function o(){return(o=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var r=arguments[t];for(var n in r)Object.prototype.hasOwnProperty.call(r,n)&&(e[n]=r[n])}return e}).apply(this,arguments)}function a(e,t){e.prototype=Object.create(t.prototype),e.prototype.constructor=e,e.__proto__=t}var i={Actions:{},AsyncState:{},Context:{__global:{}},Middlewares:{},Setter:{classSetter:void 0,functionSetter:{}},State:{},devTools:void 0,subscriptions:{},mutableState:{},uid:0,storeId:0,currentStoreId:0,withDevTools:!1},c={logger:{enable:!1},devtools:{enable:!1},tryCatch:{enable:!0}},s=function(e,t){try{var r=e.next;return Promise.resolve(c.tryCatch.enable?r(t).catch(function(e){return console.log(e)}):r(t))}catch(e){return Promise.reject(e)}},u=function(e,t){try{var r=e.modelName,n=e.next,a=e.Global;return Promise.resolve((0,e.action)(e.params,o({actions:(0,e.consumerActions)(a.Actions[r],{modelName:r}),state:a.State[r]},a.Context.__global||{},a.Context[r]||{}))).then(function(r){return e.newState=r||null,Promise.resolve(n(t))})}catch(e){return Promise.reject(e)}},l=function(e,t){try{var r=e.modelName,n=e.newState,o=e.next,a=e.Global;return a.Setter.functionSetter[r]&&Object.keys(a.Setter.functionSetter[r]).map(function(e){var t=a.Setter.functionSetter[r][e];t&&t.selector&&!t.selectorRef&&(t.selectorRef=t.selector(a.State[r]))}),Promise.resolve(function(){if(n)return N(r,n),Promise.resolve(o(t))}())}catch(e){return Promise.reject(e)}},f=function(e,t){try{var r=e.modelName,n=e.next,o=e.Global,a=e.__hash,i=o.Setter.functionSetter[r];return"function"===e.type&&a&&i&&i[a]&&i[a].setState&&i[a].setState(o.State[r]),Promise.resolve(n(t))}catch(e){return Promise.reject(e)}},m=function(e,t){try{var r=e.next,n=e.Global.subscriptions[e.modelName+"_"+e.actionName];return n&&n.forEach(function(t){t(e)}),Promise.resolve(r(t))}catch(e){return Promise.reject(e)}},S=function(e,t){try{var r=e.Global;return!0===c.logger.enable||"function"==typeof c.logger.enable&&c.logger.enable(e)?(console.group("%c "+e.modelName+" State Change %c "+(new Date).toLocaleTimeString(),"color: gray; font-weight: lighter;","color: black; font-weight: bold;"),console.log("%c Previous","color: #9E9E9E; font-weight: bold",r.State[e.modelName]),console.log("%c Action","color: #03A9F4; font-weight: bold",e.actionName,"payload: "+e.params),Promise.resolve(e.next(t)).then(function(t){return console.log("%c Next","color: #4CAF50; font-weight: bold",r.State[e.modelName]),console.groupEnd(),t})):Promise.resolve(e.next(t))}catch(e){return Promise.reject(e)}},d=function(e,t){try{var r=e.Global;return Promise.resolve(e.next(t)).then(function(t){return r.withDevTools&&c.devtools.enable&&r.devTools.send(e.modelName+"_"+e.actionName,r.State),t})}catch(e){return Promise.reject(e)}},v=function(e,t){try{var r=e.modelName,n=e.next,o=e.Global;return o.Setter.classSetter&&o.Setter.classSetter(o.State),o.Setter.functionSetter[r]&&Object.keys(o.Setter.functionSetter[r]).map(function(e){var t=o.Setter.functionSetter[r][e];if(t)if(t.selector){var n=t.selector(o.State[r]);A(n,t.selectorRef)||(t.selectorRef=n,t.setState(o.State[r]))}else t.setState(o.State[r])}),Promise.resolve(n(t))}catch(e){return Promise.reject(e)}},_=[s,S,d,u,l,f,v,m],b={communicator:v,consoleDebugger:S,devToolsListener:d,getNewState:u,getNewStateWithCache:function(e){return void 0===e&&(e=5e3),function(t,r){try{var n=t.Global,o=t.modelName,a=t.next,i=t.actionName;return Promise.resolve(Promise.race([(0,t.action)(t.params,{actions:(0,t.consumerActions)(n.Actions[o],{modelName:o}),state:n.State[o]}),E(e,j(o,i))])).then(function(e){return t.newState=e||null,Promise.resolve(a(r))})}catch(e){return Promise.reject(e)}}},setNewState:l,stateUpdater:f,subscription:m,tryCatch:s,config:c},p=function(e,t){try{return t.next=function(e){return e.length>0?e[0](t,e.slice(1)):t.newState},Promise.resolve(e[0](t,e.slice(1)))}catch(e){return Promise.reject(e)}},h=r.createContext({}),y=h.Consumer;if(!console.group){var g=[],P="-".repeat(80);console.group=function(e){g.push(e),console.log("%c \nBEGIN GROUP: %c",P,e),console.groupEnd=function(){console.log("END GROUP: %c\n%c",g.pop(),P)}}}var w=function(e,t){var r={};return Object.keys(e).forEach(function(n){r[n]=function(e,t){return function(r,n){try{return Promise.resolve(p(_,{Global:i,action:e,actionName:e.name,consumerActions:w,middlewareConfig:n,modelName:t.modelName,newState:null,params:r,type:"outer"}))}catch(e){return Promise.reject(e)}}}(e[n],t)}),r},N=function(e,t){if("function"==typeof t){var r=i.State[e];r=n(r,t),i.State=n(i.State,function(t){t[e]=r})}else i.State=n(i.State,function(r){r[e]=o({},r[e],t)});return i.State},E=function(e,t){return new Promise(function(r){return setTimeout(function(){console.log(e),r(t)},e)})},O=function(e,t){try{var r={__FROM_SERVER__:!0};return Promise.resolve(Promise.all(Object.keys(i.State).map(function(a){try{var c=function(){if(!e||!e.modelName||a===e.modelName||-1!==e.modelName.indexOf(a)){var c=function(e){t&&t.isServer?r[a]=e:i.State=n(i.State,function(t){t[a]=o({},t[a],e)})},s=i.AsyncState[a];return s?Promise.resolve(s(e)).then(c):c({})}}();return Promise.resolve(c&&c.then?c.then(function(){}):void 0)}catch(e){return Promise.reject(e)}}))).then(function(){return t&&t.isServer?r:i.State})}catch(e){return Promise.reject(e)}},j=function(e,t){var r=localStorage.getItem("__REACT_MODELX__"+e+"_"+t);return r?JSON.parse(r):null},A=function(e,t){if(e===t)return!0;if("object"!=typeof e||null===e||"object"!=typeof t||null===t)return!1;var r=Object.keys(e),n=Object.keys(t);if(r.length!==n.length)return!1;for(var o=0;o<r.length;o++)if(!Object.prototype.hasOwnProperty.call(t,r[o])||e[r[o]]!==t[r[o]])return!1;return!0};t.enableES5();var R=function(e,t){x(e,t,void 0)},x=function(e,t,r){Array.isArray(t)?t.forEach(function(t){i.subscriptions[e+"_"+t]||(i.subscriptions[e+"_"+t]=[]),r?i.subscriptions[e+"_"+t].push(r):i.subscriptions[e+"_"+t]=[]}):(i.subscriptions[e+"_"+t]||(i.subscriptions[e+"_"+t]=[]),r?i.subscriptions[e+"_"+t].push(r):i.subscriptions[e+"_"+t]=[])},C=function(e){return i.State[e]},M=function(e,t){void 0===t&&(t={type:"outer"});var r={};return Object.keys(i.Actions[e]).forEach(function(n){return r[n]=function(r,a){try{var c=o({action:i.Actions[e][n],actionName:n,consumerActions:w,middlewareConfig:a,modelName:e,newState:null,params:r},t,{Global:i});return Promise.resolve(p(i.Middlewares[e]?i.Middlewares[e]:_,c))}catch(e){return Promise.reject(e)}}}),r},T=function(e,t){var n=r.useState({})[1],o=r.useRef("");r.useLayoutEffect(function(){i.uid+=1;var r=""+i.uid;return o.current=r,i.Setter.functionSetter[e]||(i.Setter.functionSetter[e]={}),i.Setter.functionSetter[e][r]={setState:n,selector:t},function(){delete i.Setter.functionSetter[e][r]}},[]);var a=M(e,{__hash:o.current,type:"function"});return[t?t(C(e)):C(e),a]},I=function(e){function t(){var t;return(t=e.apply(this,arguments)||this).state=i.State,t}return a(t,e),t.prototype.render=function(){var e=this.props.children;return i.Setter.classSetter=this.setState.bind(this),r.createElement(h.Provider,{value:o({},this.state)},e)},t}(r.PureComponent);e.Consumer=y,e.Model=function(e,t,r){if(void 0!==e.state){i.storeId+=1;var a="__"+i.storeId;i.State=n(i.State,function(t){t[a]=e.state}),e.middlewares&&(i.Middlewares[a]=e.middlewares),i.Actions[a]=e.actions,i.AsyncState[a]=e.asyncState,t&&(i.Context[a]=t);var c=M(a);return{__id:a,actions:c,getState:function(){return C(a)},subscribe:function(e,t){return x(a,e,t)},unsubscribe:function(e){return R(a,e)},useStore:function(e){return T(a,e)}}}if(e.actions){console.error("invalid model(s) schema: ",e);var s=function(e){return function(){return e}};return{__ERROR__:!0,actions:s({}),getActions:s({}),getInitialState:s({}),getState:s({}),subscribe:s(),unsubscribe:s(),useStore:s([{},{}])}}t&&!t.__FROM_SERVER__&&(i.State=n(i.State,function(e){Object.assign(e,t||{})})),r&&(i.Context.__global=r),Object.keys(e).forEach(function(r){var a=e[r];if(a.__ERROR__)return console.error(r+" model's schema is invalid"),i.State=n(i.State,function(e){e[r]={}}),void(i.Actions[r]={});void 0===a.useStore?(t&&t.__FROM_SERVER__?i.State=n(i.State,function(e){e[r]=o({},a.state,t[r])}):i.State[r]||(i.State=n(i.State,function(e){e[r]=a.state})),a.middlewares&&(i.Middlewares[r]=a.middlewares),i.Actions[r]=a.actions,i.AsyncState[r]=a.asyncState):(i.State[r]&&t||(i.State=n(i.State,function(e){e[r]=e[a.__id]})),t&&t.__FROM_SERVER__&&(i.State=n(i.State,function(e){e[r]=o({},e[a.__id],t[r])})),i.Actions[r]=i.Actions[a.__id],i.AsyncState[r]=i.AsyncState[a.__id],i.Middlewares[r]=i.Middlewares[a.__id],i.Context[r]=i.Context[a.__id])});var u=Object.keys(e).reduce(function(e,t){var r;return o({},e,((r={})[t]=M(t),r))},{});return i.withDevTools="undefined"!=typeof window&&window.__REDUX_DEVTOOLS_EXTENSION__,i.withDevTools&&b.config.devtools.enable&&(i.devTools=window.__REDUX_DEVTOOLS_EXTENSION__,i.devTools.connect()),{actions:u,getActions:M,getInitialState:O,getState:C,subscribe:x,unsubscribe:R,useStore:T}},e.Provider=I,e.actionMiddlewares=_,e.connect=function(e,t,n){return function(c){return function(s){function u(){return s.apply(this,arguments)||this}return a(u,s),u.prototype.render=function(){var a=this,s=this.props,u=s.state,l=void 0===u?{}:u,f=s.actions,m=void 0===f?{}:f;return r.createElement(y,null,function(s){var u=s[""+e],f=i.Actions[e];return r.createElement(c,Object.assign({},a.props,{state:o({},l,t?t(u):u),actions:o({},m,n?n(w(f,{modelName:e})):w(f,{modelName:e}))}))})},u}(r.PureComponent)}},e.createStore=function(e){i.storeId+=1;var t=i.storeId,r="__"+t;i.Actions[r]||(i.Actions[r]={}),i.mutableState[t]||(i.mutableState[t]={count:0});var n=function(){return i.mutableState[t].count=0,i.currentStoreId=t,e()};return{useStore:function(){return T(r,n)[0]},getState:function(){return n()}}},e.getInitialState=O,e.getState=C,e.middlewares=b,e.useModel=function(e){var t=i.currentStoreId,r=i.mutableState[t].count;return i.mutableState[t].count+=1,i.mutableState[t][r]||(i.mutableState[t][r]=e),[i.mutableState[t][r],function(e){try{var n={Global:i,action:function(){return e},actionName:"setter",consumerActions:w,middlewareConfig:{},modelName:"__"+t,newState:{},params:void 0,type:"outer"};return i.mutableState[t][r]=e,Promise.resolve(p(_,n))}catch(e){return Promise.reject(e)}}]}});
{
"name": "react-model",
"version": "4.0.1",
"version": "4.1.0-alpha.0",
"description": "The State management library for React",

@@ -5,0 +5,0 @@ "main": "./dist/react-model.js",

@@ -20,23 +20,12 @@ # react-model &middot; ![GitHub license](https://img.shields.io/badge/license-MIT-blue.svg) [![npm version](https://img.shields.io/npm/v/react-model.svg?style=flat)](https://www.npmjs.com/package/react-model) [![minified size](https://badgen.net/bundlephobia/min/react)](https://bundlephobia.com/result?p=react-model) [![Build Status](https://travis-ci.org/byte-fe/react-model.svg?branch=master)](https://travis-ci.org/byte-fe/react-model) [![size](http://img.badgesize.io/https://cdn.jsdelivr.net/npm/react-model/dist/react-model.js?compression=gzip)](http://img.badgesize.io/https://cdn.jsdelivr.net/npm/react-model/dist/react-model.js) [![downloads](https://img.shields.io/npm/dt/react-model.svg)](https://www.npmjs.com/package/react-model) [![Coverage Status](https://codecov.io/gh/byte-fe/react-model/branch/master/graph/badge.svg)](https://codecov.io/gh/byte-fe/react-model) [![Greenkeeper badge](https://badges.greenkeeper.io/byte-fe/react-model.svg)](https://greenkeeper.io/) ![PRs Welcome](https://img.shields.io/badge/PRs-welcome-brightgreen.svg)

```tsx
import { Model } from 'react-model'
import { useModel, createStore } from 'react-model'
// define model
const Todo = {
state: {
items: ['Install react-model', 'Read github docs', 'Build App']
},
actions: {
add: todo => {
// s is the readonly version of state
// you can also return partial state here but don't need to keep immutable manually
// state is the mutable state
return state => {
state.items.push(todo)
}
}
}
const useTodo = () => {
const [items, setItems] = useModel(['Install react-model', 'Read github docs', 'Build App'])
return { items, setItems }
}
// Model Register
const { useStore } = Model(Todo)
const { useStore } = createStore(Todo)

@@ -48,5 +37,5 @@ const App = () => {

const TodoList = () => {
const [state, actions] = useStore()
const { items, setItems } = useStore()
return <div>
<Addon handler={actions.add} />
<Addon handler={setItems} />
{state.items.map((item, index) => (<Todo key={index} item={item} />))}

@@ -53,0 +42,0 @@ </div>

const State = {}
const mutableState = {}
const Actions = {}

@@ -25,2 +26,4 @@ const AsyncState = {}

let uid = 0 // The unique id of hooks
let storeId = 0 // The unique id of stores
let currentStoreId = 0 // Used for useModel

@@ -36,4 +39,7 @@ export default {

subscriptions,
mutableState,
uid,
storeId,
currentStoreId,
withDevTools
} as Global

@@ -38,3 +38,3 @@ import produce from 'immer'

}
await applyMiddlewares(actionMiddlewares, context)
return await applyMiddlewares(actionMiddlewares, context)
}

@@ -41,0 +41,0 @@

@@ -31,2 +31,5 @@ type Setter = {

}
mutableState: {
[modelName: string]: any
}
AsyncState: {

@@ -44,2 +47,4 @@ [modelName: string]: undefined | ((context?: any) => Promise<Partial<any>>)

uid: number
storeId: number
currentStoreId: number
}

@@ -68,2 +73,5 @@

// v4.1+ Custom Hooks
type CustomModelHook<State> = () => State
type Dispatch<A> = (value: A) => void

@@ -102,3 +110,3 @@ type SetStateAction<S> = S | ((prevState: S) => S)

type Middleware<S = {}> = (C: Context<S>, M: Middleware<S>[]) => void
type Middleware<S = {}> = (C: Context<S>, M: Middleware<S>[]) => Promise<void>

@@ -150,2 +158,7 @@ type MiddlewareConfig = {

interface LaneAPI<S> {
useStore: () => S
getState: () => S
}
interface APIs<M extends Models> {

@@ -152,0 +165,0 @@ useStore: <

@@ -19,5 +19,5 @@ import { getCache, setPartialState, timeout, shallowEqual } from './helper'

if (config.tryCatch.enable) {
await next(restMiddlewares).catch((e: any) => console.log(e))
return await next(restMiddlewares).catch((e: any) => console.log(e))
} else {
await next(restMiddlewares)
return await next(restMiddlewares)
}

@@ -35,28 +35,27 @@ }

})) || null
await next(restMiddlewares)
return await next(restMiddlewares)
}
const getNewStateWithCache = (maxTime: number = 5000): Middleware => async (
context,
restMiddlewares
) => {
const {
action,
Global,
modelName,
consumerActions,
params,
next,
actionName
} = context
context.newState =
(await Promise.race([
action(params, {
actions: consumerActions(Global.Actions[modelName], { modelName }),
state: Global.State[modelName]
}),
timeout(maxTime, getCache(modelName, actionName))
])) || null
await next(restMiddlewares)
}
const getNewStateWithCache =
(maxTime: number = 5000): Middleware =>
async (context, restMiddlewares) => {
const {
action,
Global,
modelName,
consumerActions,
params,
next,
actionName
} = context
context.newState =
(await Promise.race([
action(params, {
actions: consumerActions(Global.Actions[modelName], { modelName }),
state: Global.State[modelName]
}),
timeout(maxTime, getCache(modelName, actionName))
])) || null
return await next(restMiddlewares)
}

@@ -77,3 +76,3 @@ const setNewState: Middleware = async (context, restMiddlewares) => {

setPartialState(modelName, newState)
await next(restMiddlewares)
return await next(restMiddlewares)
}

@@ -94,3 +93,3 @@ }

}
await next(restMiddlewares)
return await next(restMiddlewares)
}

@@ -106,3 +105,3 @@

}
await next(restMiddlewares)
return await next(restMiddlewares)
}

@@ -136,3 +135,3 @@

)
await context.next(restMiddlewares)
const ret = await context.next(restMiddlewares)
console.log(

@@ -144,4 +143,5 @@ '%c Next',

console.groupEnd()
return ret
} else {
await context.next(restMiddlewares)
return await context.next(restMiddlewares)
}

@@ -152,3 +152,3 @@ }

const { Global } = context
await context.next(restMiddlewares)
const ret = await context.next(restMiddlewares)
if (Global.withDevTools && config.devtools.enable) {

@@ -160,2 +160,3 @@ Global.devTools.send(

}
return ret
}

@@ -184,3 +185,3 @@

}
await next(restMiddlewares)
return await next(restMiddlewares)
}

@@ -216,10 +217,10 @@

) => {
context.next = (restMiddlewares: Middleware[]) =>
restMiddlewares.length > 0 &&
restMiddlewares[0](context as Context, restMiddlewares.slice(1))
if (middlewares.length > 0) {
await middlewares[0](context as Context, middlewares.slice(1))
context.next = (restMiddlewares: Middleware[]) => {
if (restMiddlewares.length > 0)
return restMiddlewares[0](context as Context, restMiddlewares.slice(1))
else return context.newState
}
return await middlewares[0](context as Context, middlewares.slice(1))
}
export { actionMiddlewares, applyMiddlewares, middlewares }

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc