@e7w/easy-model 0.1.7 → 0.1.8

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/dist/index.umd.js CHANGED
@@ -1,4 +1,4 @@
1
- (function(f,m){typeof exports=="object"&&typeof module<"u"?m(exports,require("react")):typeof define=="function"&&define.amd?define(["exports","react"],m):(f=typeof globalThis<"u"?globalThis:f||self,m(f["@e7w/easy-model"]={},f.React))})(this,function(f,m){"use strict";var Xe=Object.defineProperty;var Be=(f,m,w)=>m in f?Xe(f,m,{enumerable:!0,configurable:!0,writable:!0,value:w}):f[m]=w;var O=(f,m,w)=>Be(f,typeof m!="symbol"?m+"":m,w);const w=new WeakMap,W=new WeakMap,Q=Symbol("origin");let p=null;const z=["includes","indexOf","lastIndexOf"],ye=[Promise,RegExp,Date,WeakMap,WeakSet,Map,Set];function M(e){if(e=_(e),!e||ye.some(i=>e instanceof i))return e;if(w.has(e))return w.get(e);const n={},r={},a=new Proxy(e,{get(i,o,c){if(o===Q)return i;let s=ee(i,o);return s||(s=Reflect.get(i,o,c),typeof s=="function"?(r[o]||(r[o]=s.bind(M(i))),s=r[o]):typeof s=="object"&&s!==null&&(n[o]||(n[o]=Y(s,K(e,o))),s=M(s)),s)},set(i,o,c,s){let d=Reflect.get(i,o,s);if(d=_(d),c=_(c),d===c)return!0;const l=Reflect.set(i,o,c,s);if(l){n[o]&&(n[o](),delete n[o]),typeof c=="object"&&c!==null&&(n[o]=Y(c,K(e,o))),r[o]&&delete r[o];const R=p;p=new WeakSet,G(i,[o],d,c),p=R}return l},deleteProperty(i,o){let c=Reflect.get(i,o);c=_(c);const s=Reflect.deleteProperty(i,o);return s&&(n[o]&&(n[o](),delete n[o]),r[o]&&delete r[o],G(i,[o],c,void 0)),s}});return w.set(e,a),a}function Y(e,n){e=_(e),W.has(e)||W.set(e,new Map);const r=W.get(e),a=Symbol();return r.set(a,n),function(){r.delete(a)}}function K(e,n){return function(...r){const[a,...i]=r;G(e,[n,...a],...i)}}function G(e,...n){if(e=_(e),p!=null&&p.has(e))return;p==null||p.add(e);const r=W.get(e);if(!r)return;[...r.values()].forEach(i=>{const o=new EventTarget,c=new Event("__trigger__");o.addEventListener(c.type,s),o.dispatchEvent(c);function s(){o.removeEventListener(c.type,s),i(...n)}})}function _(e){return typeof e!="object"||e===null?e:e[Q]??e}function ee(e,n){if(e=_(e),["constructor","__proto__"].includes(n))return Reflect.get(e,n);if(n==="hasOwnProperty")return function(r){return Object.prototype.hasOwnProperty.call(_(this),r)};if(Array.isArray(e)&&z.includes(n))return function(...r){const a=z[n].apply(_(this),r);return a===-1||a===!1?z[n].apply(_(this),r.map(_)):a}}const P=Symbol("instance"),F=new WeakMap,te=new WeakSet,U=new WeakMap,J=new WeakMap;function N(e){if(te.has(e))return e;if(F.has(e))return F.get(e);const n={};o.prototype=new Proxy({constructor:e,__proto__:e.prototype},{get(c,s,d){let l=ee(c,s);return l||(l=Reflect.get(c,s,d),typeof s=="symbol"||["constructor","__proto__"].includes(s)||typeof l!="function")?l:(n[s]||(n[s]=function(...R){return l.apply(M(this),R)}),n[s])}});const r=new Map,a=new FinalizationRegistry(({args:c,token:s})=>{var d;ne(r,c),(d=J.get(s))==null||d(),a.unregister(s)}),i=new Proxy(e,{apply(c,s,d){var R,g,v,j;let l=r;for(let h=0;h<d.length;h++)l.has(d[h])||l.set(d[h],new Map),l=l.get(d[h]);if(!l.has(P)||l.get(P)!==void 0&&!((g=(R=l.get(P))==null?void 0:R.deref)!=null&&g.call(R))){l.set(P,void 0);const h=M(Reflect.construct(c,d,o));l.set(P,new WeakRef(h));const C=re(h);a.register(h,{args:d,token:C},C)}return(j=(v=l.get(P))==null?void 0:v.deref)==null?void 0:j.call(v)}});return F.set(e,i),te.add(i),F.get(e);function o(){}}function ne(e,n){if(n.length===0)return e.delete(P);const[r,...a]=n,i=e.get(r);if(!(i instanceof Map&&(ne(i,a),i.size>0)))return e.delete(r)}function Ee(e){const n=M(e),r=re(n);return{register(a){r&&J.set(r,a)},unregister(){r&&J.delete(r)}}}function re(e){return U.has(e)||U.set(e,{}),U.get(e)}const he=Object.create(null);function _e(e,n){const r=N(e),a=n?r(...n):he;return V(a)}function V(e){const[,n]=m.useReducer(r=>(r+1)%100,0);return m.useEffect(()=>(n(),Y(e,()=>n())),[e]),e}class ve{constructor(n,...r){O(this,"symbol",Symbol());O(this,"args");this.target=n,this.args=r}}const ke=N(ve);class pe{constructor(){O(this,"loading",{});O(this,"globalLoading",0);O(this,"onceTokens",new WeakMap);O(this,"oncePool",{})}addGlobalLoading(){this.globalLoading++}subGlobalLoading(){this.globalLoading--}load(n=!1){return(r,{name:a})=>{const{loading:i,addGlobalLoading:o,subGlobalLoading:c}=this;return async function(...s){const d=Reflect.get(this,a),l=ke(d,...s);if(!!i[l.symbol])return i[l.symbol][1];const{promise:g,resolve:v,reject:j}=Promise.withResolvers();i[l.symbol]=[d,g],n&&o();try{const h=await r.apply(this,s);v(h)}catch(h){j(h)}return Reflect.deleteProperty(i,l.symbol),n&&c(),g}}}once(n,{name:r}){const{oncePool:a,onceTokens:i}=this;return function(...o){const c=Reflect.get(this,r);i.has(c)||i.set(c,Symbol());const s=i.get(c);return!!a[s]||(a[s]=n.apply(this,o).catch(l=>(Reflect.deleteProperty(a,s),Promise.reject(l)))),a[s]}}isLoading(n){return Object.getOwnPropertySymbols(this.loading).some(r=>this.loading[r][0]===n)}get isGlobalLoading(){return this.globalLoading>0}}const oe=N(pe)(),we=()=>{const{isGlobalLoading:e,isLoading:n}=V(oe);return{isGlobalLoading:e,isLoading:n}};var D={exports:{}},L={};/**
1
+ (function(d,v){typeof exports=="object"&&typeof module<"u"?v(exports,require("react")):typeof define=="function"&&define.amd?define(["exports","react"],v):(d=typeof globalThis<"u"?globalThis:d||self,v(d["@e7w/easy-model"]={},d.React))})(this,(function(d,v){"use strict";var Ze=Object.defineProperty;var Qe=(d,v,w)=>v in d?Ze(d,v,{enumerable:!0,configurable:!0,writable:!0,value:w}):d[v]=w;var j=(d,v,w)=>Qe(d,typeof v!="symbol"?v+"":v,w);const w=new WeakMap,F=new WeakMap,te=Symbol("origin");let p=null;const G=["includes","indexOf","lastIndexOf"],ge=[Promise,RegExp,Date,WeakMap,WeakSet,Map,Set];function N(e){if(e=k(e),!e||ge.some(i=>e instanceof i))return e;if(w.has(e))return w.get(e);const n={},r={},a=new Proxy(e,{get(i,o,c){if(o===te)return i;let s=re(i,o);return s||(s=Reflect.get(i,o,c),typeof s=="function"?(r[o]||(r[o]=s.bind(N(i))),s=r[o]):typeof s=="object"&&s!==null&&(n[o]||(n[o]=x(s,ne(e,o))),s=N(s)),s)},set(i,o,c,s){let f=Reflect.get(i,o,s);if(f=k(f),c=k(c),f===c)return!0;const u=Reflect.set(i,o,c,s);if(u){n[o]&&(n[o](),delete n[o]),typeof c=="object"&&c!==null&&(n[o]=x(c,ne(e,o))),r[o]&&delete r[o];const y=p;p=new WeakSet,U(i,[o],f,c),p=y}return u},deleteProperty(i,o){let c=Reflect.get(i,o);c=k(c);const s=Reflect.deleteProperty(i,o);return s&&(n[o]&&(n[o](),delete n[o]),r[o]&&delete r[o],U(i,[o],c,void 0)),s}});return w.set(e,a),a}function x(e,n){e=k(e),F.has(e)||F.set(e,new Map);const r=F.get(e),a=Symbol();return r.set(a,n),function(){r.delete(a)}}function ne(e,n){return function(...r){const[a,...i]=r;U(e,[n,...a],...i)}}function U(e,...n){if(e=k(e),p!=null&&p.has(e))return;p==null||p.add(e);const r=F.get(e);if(!r)return;[...r.values()].forEach(i=>{const o=new EventTarget,c=new Event("__trigger__");o.addEventListener(c.type,s),o.dispatchEvent(c);function s(){o.removeEventListener(c.type,s),i(...n)}})}function k(e){return typeof e!="object"||e===null?e:e[te]??e}function re(e,n){if(e=k(e),["constructor","__proto__"].includes(n))return Reflect.get(e,n);if(n==="hasOwnProperty")return function(r){return Object.prototype.hasOwnProperty.call(k(this),r)};if(Array.isArray(e)&&G.includes(n))return function(...r){const a=G[n].apply(k(this),r);return a===-1||a===!1?G[n].apply(k(this),r.map(k)):a}}const P=Symbol("instance"),Y=new WeakMap,oe=new WeakSet,V=new WeakMap,$=new WeakMap;function L(e){if(oe.has(e))return e;if(Y.has(e))return Y.get(e);const n={};o.prototype=new Proxy({constructor:e,__proto__:e.prototype},{get(c,s,f){let u=re(c,s);return u||(u=Reflect.get(c,s,f),typeof s=="symbol"||["constructor","__proto__"].includes(s)||typeof u!="function")?u:(n[s]||(n[s]=function(...y){return u.apply(N(this),y)}),n[s])}});const r=new Map,a=new FinalizationRegistry(({args:c,token:s})=>{var f;se(r,c),(f=$.get(s))==null||f(),a.unregister(s)}),i=new Proxy(e,{apply(c,s,f){var y,g,m,R;let u=r;for(let E=0;E<f.length;E++)u.has(f[E])||u.set(f[E],new Map),u=u.get(f[E]);if(!u.has(P)||u.get(P)!==void 0&&!((g=(y=u.get(P))==null?void 0:y.deref)!=null&&g.call(y))){u.set(P,void 0);const E=N(Reflect.construct(c,f,o));u.set(P,new WeakRef(E));const T=ie(E);a.register(E,{args:f,token:T},T)}return(R=(m=u.get(P))==null?void 0:m.deref)==null?void 0:R.call(m)}});return Y.set(e,i),oe.add(i),Y.get(e);function o(){}}function se(e,n){if(n.length===0)return e.delete(P);const[r,...a]=n,i=e.get(r);if(!(i instanceof Map&&(se(i,a),i.size>0)))return e.delete(r)}function we(e){const n=N(e),r=ie(n);return{register(a){r&&$.set(r,a)},unregister(){r&&$.delete(r)}}}function ie(e){return V.has(e)||V.set(e,{}),V.get(e)}const Te=Object.create(null);function je(e,n){const r=L(e),a=n?r(...n):Te;return J(a)}function J(e){const[,n]=v.useReducer(r=>(r+1)%100,0);return v.useEffect(()=>(n(),x(e,()=>n())),[e]),e}function Pe(...e){v.useEffect(()=>x(...e),e)}const Oe=Promise.withResolvers?()=>Promise.withResolvers():()=>{let e,n;return{promise:new Promise((a,i)=>{e=a,n=i}),resolve:e,reject:n}};class Se{constructor(n,...r){j(this,"symbol",Symbol());j(this,"args");this.target=n,this.args=r}}const Ce=L(Se);class Ae{constructor(){j(this,"loading",{});j(this,"globalLoading",0);j(this,"onceTokens",new WeakMap);j(this,"oncePool",{});j(this,"loadingTokens",new WeakMap)}addGlobalLoading(){this.globalLoading++}subGlobalLoading(){this.globalLoading--}load(n=!1){return(r,{name:a})=>{const{loading:i,addGlobalLoading:o,subGlobalLoading:c,loadingTokens:s}=this;return async function(...f){const u=Reflect.get(this,a),y=Ce(u,...f);if(s.set(u,y.symbol),!!i[y.symbol])return i[y.symbol];const{promise:m,resolve:R,reject:E}=Oe();i[y.symbol]=m,n&&o();try{const T=await r.apply(this,f);R(T)}catch(T){E(T)}return Reflect.deleteProperty(i,y.symbol),n&&c(),s.delete(u),m}}}once(n,{name:r}){const{oncePool:a,onceTokens:i}=this;return function(...o){const c=Reflect.get(this,r);i.has(c)||i.set(c,Symbol());const s=i.get(c);return!!a[s]||(a[s]=n.apply(this,o).catch(u=>(Reflect.deleteProperty(a,s),Promise.reject(u)))),a[s]}}isLoading(n){const r=this.loadingTokens.get(n);return r?!!this.loading[r]:!1}get isGlobalLoading(){return this.globalLoading>0}}const ae=L(Ae)(),Me=()=>{const{isGlobalLoading:e,isLoading:n}=J(ae);return{isGlobalLoading:e,isLoading:n}};var z={exports:{}},W={};/**
2
2
  * @license React
3
3
  * react-jsx-runtime.production.js
4
4
  *
@@ -6,7 +6,7 @@
6
6
  *
7
7
  * This source code is licensed under the MIT license found in the
8
8
  * LICENSE file in the root directory of this source tree.
9
- */var se;function ge(){if(se)return L;se=1;var e=Symbol.for("react.transitional.element"),n=Symbol.for("react.fragment");function r(a,i,o){var c=null;if(o!==void 0&&(c=""+o),i.key!==void 0&&(c=""+i.key),"key"in i){o={};for(var s in i)s!=="key"&&(o[s]=i[s])}else o=i;return i=o.ref,{$$typeof:e,type:a,key:c,ref:i!==void 0?i:null,props:o}}return L.Fragment=n,L.jsx=r,L.jsxs=r,L}var I={};/**
9
+ */var ce;function Ne(){if(ce)return W;ce=1;var e=Symbol.for("react.transitional.element"),n=Symbol.for("react.fragment");function r(a,i,o){var c=null;if(o!==void 0&&(c=""+o),i.key!==void 0&&(c=""+i.key),"key"in i){o={};for(var s in i)s!=="key"&&(o[s]=i[s])}else o=i;return i=o.ref,{$$typeof:e,type:a,key:c,ref:i!==void 0?i:null,props:o}}return W.Fragment=n,W.jsx=r,W.jsxs=r,W}var I={};/**
10
10
  * @license React
11
11
  * react-jsx-runtime.development.js
12
12
  *
@@ -14,9 +14,9 @@
14
14
  *
15
15
  * This source code is licensed under the MIT license found in the
16
16
  * LICENSE file in the root directory of this source tree.
17
- */var ie;function Te(){return ie||(ie=1,process.env.NODE_ENV!=="production"&&function(){function e(t){if(t==null)return null;if(typeof t=="function")return t.$$typeof===Je?null:t.displayName||t.name||null;if(typeof t=="string")return t;switch(t){case C:return"Fragment";case Ie:return"Profiler";case Le:return"StrictMode";case De:return"Suspense";case ze:return"SuspenseList";case Ue:return"Activity"}if(typeof t=="object")switch(typeof t.tag=="number"&&console.error("Received an unexpected object in getComponentNameFromType(). This is likely a bug in React. Please file an issue."),t.$$typeof){case h:return"Portal";case Ye:return(t.displayName||"Context")+".Provider";case We:return(t._context.displayName||"Context")+".Consumer";case Fe:var u=t.render;return t=t.displayName,t||(t=u.displayName||u.name||"",t=t!==""?"ForwardRef("+t+")":"ForwardRef"),t;case Ge:return u=t.displayName||null,u!==null?u:e(t.type)||"Memo";case ue:u=t._payload,t=t._init;try{return e(t(u))}catch{}}return null}function n(t){return""+t}function r(t){try{n(t);var u=!1}catch{u=!0}if(u){u=console;var b=u.error,y=typeof Symbol=="function"&&Symbol.toStringTag&&t[Symbol.toStringTag]||t.constructor.name||"Object";return b.call(u,"The provided key is an unsupported type %s. This value must be coerced to a string before using it here.",y),n(t)}}function a(t){if(t===C)return"<>";if(typeof t=="object"&&t!==null&&t.$$typeof===ue)return"<...>";try{var u=e(t);return u?"<"+u+">":"<...>"}catch{return"<...>"}}function i(){var t=X.A;return t===null?null:t.getOwner()}function o(){return Error("react-stack-top-frame")}function c(t){if(le.call(t,"key")){var u=Object.getOwnPropertyDescriptor(t,"key").get;if(u&&u.isReactWarning)return!1}return t.key!==void 0}function s(t,u){function b(){fe||(fe=!0,console.error("%s: `key` is not a prop. Trying to access it will result in `undefined` being returned. If you need to access the same value within the child component, you should pass it as a different prop. (https://react.dev/link/special-props)",u))}b.isReactWarning=!0,Object.defineProperty(t,"key",{get:b,configurable:!0})}function d(){var t=e(this.type);return de[t]||(de[t]=!0,console.error("Accessing element.ref was removed in React 19. ref is now a regular prop. It will be removed from the JSX Element type in a future release.")),t=this.props.ref,t!==void 0?t:null}function l(t,u,b,y,T,k,q,H){return b=k.ref,t={$$typeof:j,type:t,key:u,props:k,_owner:T},(b!==void 0?b:null)!==null?Object.defineProperty(t,"ref",{enumerable:!1,get:d}):Object.defineProperty(t,"ref",{enumerable:!1,value:null}),t._store={},Object.defineProperty(t._store,"validated",{configurable:!1,enumerable:!1,writable:!0,value:0}),Object.defineProperty(t,"_debugInfo",{configurable:!1,enumerable:!1,writable:!0,value:null}),Object.defineProperty(t,"_debugStack",{configurable:!1,enumerable:!1,writable:!0,value:q}),Object.defineProperty(t,"_debugTask",{configurable:!1,enumerable:!1,writable:!0,value:H}),Object.freeze&&(Object.freeze(t.props),Object.freeze(t)),t}function R(t,u,b,y,T,k,q,H){var E=u.children;if(E!==void 0)if(y)if(Ve(E)){for(y=0;y<E.length;y++)g(E[y]);Object.freeze&&Object.freeze(E)}else console.error("React.jsx: Static children should always be an array. You are likely explicitly calling React.jsxs or React.jsxDEV. Use the Babel transform instead.");else g(E);if(le.call(u,"key")){E=e(t);var x=Object.keys(u).filter(function($e){return $e!=="key"});y=0<x.length?"{key: someKey, "+x.join(": ..., ")+": ...}":"{key: someKey}",Re[E+y]||(x=0<x.length?"{"+x.join(": ..., ")+": ...}":"{}",console.error(`A props object containing a "key" prop is being spread into JSX:
17
+ */var le;function xe(){return le||(le=1,process.env.NODE_ENV!=="production"&&(function(){function e(t){if(t==null)return null;if(typeof t=="function")return t.$$typeof===Xe?null:t.displayName||t.name||null;if(typeof t=="string")return t;switch(t){case q:return"Fragment";case ze:return"Profiler";case Ye:return"StrictMode";case Ve:return"Suspense";case $e:return"SuspenseList";case Be:return"Activity"}if(typeof t=="object")switch(typeof t.tag=="number"&&console.error("Received an unexpected object in getComponentNameFromType(). This is likely a bug in React. Please file an issue."),t.$$typeof){case T:return"Portal";case Ge:return t.displayName||"Context";case De:return(t._context.displayName||"Context")+".Consumer";case Ue:var l=t.render;return t=t.displayName,t||(t=l.displayName||l.name||"",t=t!==""?"ForwardRef("+t+")":"ForwardRef"),t;case Je:return l=t.displayName||null,l!==null?l:e(t.type)||"Memo";case H:l=t._payload,t=t._init;try{return e(t(l))}catch{}}return null}function n(t){return""+t}function r(t){try{n(t);var l=!1}catch{l=!0}if(l){l=console;var b=l.error,h=typeof Symbol=="function"&&Symbol.toStringTag&&t[Symbol.toStringTag]||t.constructor.name||"Object";return b.call(l,"The provided key is an unsupported type %s. This value must be coerced to a string before using it here.",h),n(t)}}function a(t){if(t===q)return"<>";if(typeof t=="object"&&t!==null&&t.$$typeof===H)return"<...>";try{var l=e(t);return l?"<"+l+">":"<...>"}catch{return"<...>"}}function i(){var t=Z.A;return t===null?null:t.getOwner()}function o(){return Error("react-stack-top-frame")}function c(t){if(ve.call(t,"key")){var l=Object.getOwnPropertyDescriptor(t,"key").get;if(l&&l.isReactWarning)return!1}return t.key!==void 0}function s(t,l){function b(){Re||(Re=!0,console.error("%s: `key` is not a prop. Trying to access it will result in `undefined` being returned. If you need to access the same value within the child component, you should pass it as a different prop. (https://react.dev/link/special-props)",l))}b.isReactWarning=!0,Object.defineProperty(t,"key",{get:b,configurable:!0})}function f(){var t=e(this.type);return Ee[t]||(Ee[t]=!0,console.error("Accessing element.ref was removed in React 19. ref is now a regular prop. It will be removed from the JSX Element type in a future release.")),t=this.props.ref,t!==void 0?t:null}function u(t,l,b,h,D,K){var _=b.ref;return t={$$typeof:E,type:t,key:l,props:b,_owner:h},(_!==void 0?_:null)!==null?Object.defineProperty(t,"ref",{enumerable:!1,get:f}):Object.defineProperty(t,"ref",{enumerable:!1,value:null}),t._store={},Object.defineProperty(t._store,"validated",{configurable:!1,enumerable:!1,writable:!0,value:0}),Object.defineProperty(t,"_debugInfo",{configurable:!1,enumerable:!1,writable:!0,value:null}),Object.defineProperty(t,"_debugStack",{configurable:!1,enumerable:!1,writable:!0,value:D}),Object.defineProperty(t,"_debugTask",{configurable:!1,enumerable:!1,writable:!0,value:K}),Object.freeze&&(Object.freeze(t.props),Object.freeze(t)),t}function y(t,l,b,h,D,K){var _=l.children;if(_!==void 0)if(h)if(qe(_)){for(h=0;h<_.length;h++)g(_[h]);Object.freeze&&Object.freeze(_)}else console.error("React.jsx: Static children should always be an array. You are likely explicitly calling React.jsxs or React.jsxDEV. Use the Babel transform instead.");else g(_);if(ve.call(l,"key")){_=e(t);var M=Object.keys(l).filter(function(He){return He!=="key"});h=0<M.length?"{key: someKey, "+M.join(": ..., ")+": ...}":"{key: someKey}",pe[_+h]||(M=0<M.length?"{"+M.join(": ..., ")+": ...}":"{}",console.error(`A props object containing a "key" prop is being spread into JSX:
18
18
  let props = %s;
19
19
  <%s {...props} />
20
20
  React keys must be passed directly to JSX without using spread:
21
21
  let props = %s;
22
- <%s key={someKey} {...props} />`,y,E,x,E),Re[E+y]=!0)}if(E=null,b!==void 0&&(r(b),E=""+b),c(u)&&(r(u.key),E=""+u.key),"key"in u){b={};for(var Z in u)Z!=="key"&&(b[Z]=u[Z])}else b=u;return E&&s(b,typeof t=="function"?t.displayName||t.name||"Unknown":t),l(t,E,k,T,i(),b,q,H)}function g(t){typeof t=="object"&&t!==null&&t.$$typeof===j&&t._store&&(t._store.validated=1)}var v=m,j=Symbol.for("react.transitional.element"),h=Symbol.for("react.portal"),C=Symbol.for("react.fragment"),Le=Symbol.for("react.strict_mode"),Ie=Symbol.for("react.profiler"),We=Symbol.for("react.consumer"),Ye=Symbol.for("react.context"),Fe=Symbol.for("react.forward_ref"),De=Symbol.for("react.suspense"),ze=Symbol.for("react.suspense_list"),Ge=Symbol.for("react.memo"),ue=Symbol.for("react.lazy"),Ue=Symbol.for("react.activity"),Je=Symbol.for("react.client.reference"),X=v.__CLIENT_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE,le=Object.prototype.hasOwnProperty,Ve=Array.isArray,B=console.createTask?console.createTask:function(){return null};v={"react-stack-bottom-frame":function(t){return t()}};var fe,de={},be=v["react-stack-bottom-frame"].bind(v,o)(),me=B(a(o)),Re={};I.Fragment=C,I.jsx=function(t,u,b,y,T){var k=1e4>X.recentlyCreatedOwnerStacks++;return R(t,u,b,!1,y,T,k?Error("react-stack-top-frame"):be,k?B(a(t)):me)},I.jsxs=function(t,u,b,y,T){var k=1e4>X.recentlyCreatedOwnerStacks++;return R(t,u,b,!0,y,T,k?Error("react-stack-top-frame"):be,k?B(a(t)):me)}}()),I}var ae;function Pe(){return ae||(ae=1,process.env.NODE_ENV==="production"?D.exports=ge():D.exports=Te()),D.exports}var je=Pe();const S={},A={},$=m.createContext({namespace:""});function Oe(e){return S[e]||(S[e]=new Map),S[e]}function Se(e){return A[e]||(A[e]=new Map),A[e]}const Ae=({children:e,namespace:n=""})=>je.jsx($.Provider,{value:{namespace:n},children:e});function Ce({schema:e,ctor:n}){const{namespace:r}=m.useContext($);return Oe(r).set(e,n),null}function xe({schema:e,val:n}){const{namespace:r}=m.useContext($);return Se(r).set(e,n),null}function Me(e,n=""){return(r,{static:a,kind:i})=>{if(i!=="field")throw new Error("inject 装饰器只能用于类的属性字段");if(a)throw new Error("inject 装饰器不能用于静态属性");return function(o){var l;if(!ce(e,n))return console.error(`[IoC] 依赖注入失败 - namespace: "${n}", schema: ${e.description||"unknown"}`,"未注册"),o;let c=o;const s=(l=S[n])==null?void 0:l.get(e);if(s)c=N(s)();else{const R=A[n];R!=null&&R.has(e)&&(c=R.get(e))}const d=e.safeParse(c);return d.success?c:(console.error(`[IoC] 依赖注入失败 - namespace: "${n}", schema: ${e.description||"unknown"}`,d.error.issues),o)}}}function Ne(e){delete S[e],delete A[e]}function ce(e,n=""){const r=S[n],a=A[n];return(r==null?void 0:r.has(e))||(a==null?void 0:a.has(e))}f.CInjection=Ce,f.Container=Ae,f.VInjection=xe,f.clearNamespace=Ne,f.finalizationRegistry=Ee,f.inject=Me,f.isRegistered=ce,f.loader=oe,f.provide=N,f.useInstance=V,f.useLoader=we,f.useModel=_e,f.watch=Y,Object.defineProperty(f,Symbol.toStringTag,{value:"Module"})});
22
+ <%s key={someKey} {...props} />`,h,_,M,_),pe[_+h]=!0)}if(_=null,b!==void 0&&(r(b),_=""+b),c(l)&&(r(l.key),_=""+l.key),"key"in l){b={};for(var ee in l)ee!=="key"&&(b[ee]=l[ee])}else b=l;return _&&s(b,typeof t=="function"?t.displayName||t.name||"Unknown":t),u(t,_,b,i(),D,K)}function g(t){m(t)?t._store&&(t._store.validated=1):typeof t=="object"&&t!==null&&t.$$typeof===H&&(t._payload.status==="fulfilled"?m(t._payload.value)&&t._payload.value._store&&(t._payload.value._store.validated=1):t._store&&(t._store.validated=1))}function m(t){return typeof t=="object"&&t!==null&&t.$$typeof===E}var R=v,E=Symbol.for("react.transitional.element"),T=Symbol.for("react.portal"),q=Symbol.for("react.fragment"),Ye=Symbol.for("react.strict_mode"),ze=Symbol.for("react.profiler"),De=Symbol.for("react.consumer"),Ge=Symbol.for("react.context"),Ue=Symbol.for("react.forward_ref"),Ve=Symbol.for("react.suspense"),$e=Symbol.for("react.suspense_list"),Je=Symbol.for("react.memo"),H=Symbol.for("react.lazy"),Be=Symbol.for("react.activity"),Xe=Symbol.for("react.client.reference"),Z=R.__CLIENT_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE,ve=Object.prototype.hasOwnProperty,qe=Array.isArray,Q=console.createTask?console.createTask:function(){return null};R={react_stack_bottom_frame:function(t){return t()}};var Re,Ee={},me=R.react_stack_bottom_frame.bind(R,o)(),ke=Q(a(o)),pe={};I.Fragment=q,I.jsx=function(t,l,b){var h=1e4>Z.recentlyCreatedOwnerStacks++;return y(t,l,b,!1,h?Error("react-stack-top-frame"):me,h?Q(a(t)):ke)},I.jsxs=function(t,l,b){var h=1e4>Z.recentlyCreatedOwnerStacks++;return y(t,l,b,!0,h?Error("react-stack-top-frame"):me,h?Q(a(t)):ke)}})()),I}var ue;function Le(){return ue||(ue=1,process.env.NODE_ENV==="production"?z.exports=Ne():z.exports=xe()),z.exports}var fe=Le();const S={},C={},A=new WeakMap;let O="";function de(e){return S[e]||(S[e]=new Map),S[e]}function be(e){return C[e]||(C[e]=new Map),C[e]}const B=({children:e})=>fe.jsx(fe.Fragment,{children:e});function ye({schema:e,ctor:n}){return be(O).delete(e),de(O).set(e,n),null}function he({schema:e,val:n}){return de(O).delete(e),be(O).set(e,n),null}function We(e,n=""){return(r,{static:a,kind:i,name:o,addInitializer:c})=>{if(i!=="field")throw new Error("[IoC] - inject 装饰器只能用于类的属性字段");if(a)throw new Error("[IoC] - inject 装饰器不能用于静态属性");return c(function(){Object.defineProperty(this,o,{get(){var m;A.has(this)||A.set(this,{});const s=A.get(this);s[o]||(s[o]={initialized:!1,val:void 0});const f=s[o];if(f.initialized)return f.val;if(!_e(e,n))return console.error(`[IoC] 依赖注入失败 - namespace: ${n||"默认"}, schema: ${e.description||e.type||"unknown"}`,"未注册"),f.val;let u;const y=(m=S[n])==null?void 0:m.get(e);if(y)u=L(y)();else{const R=C[n];R!=null&&R.has(e)&&(u=R.get(e))}const g=e.safeParse(u);return g.success?(f.initialized=!0,f.val=u,u):(console.error(`[IoC] 依赖注入失败 - namespace: "${n}", schema: ${e.description||"unknown"}`,g.error.issues),u)}})}),function(s){A.has(this)||A.set(this,{});const f=A.get(this);return f[o]||(f[o]={initialized:!1,val:s}),s}}}function Ie(e){delete S[e],delete C[e]}function _e(e,n=""){const r=S[n],a=C[n];return!!(r!=null&&r.has(e)||a!=null&&a.has(e))}const Fe=[he,ye];function X(e){if(!e||typeof e!="object"||!("type"in e))return;const{type:n,props:r}=e;if(!Fe.includes(n)){const i=O;n===B&&(O=r.namespace||""),v.Children.toArray(r==null?void 0:r.children).forEach(c=>X(c)),n===B&&(O=i);return}const a=n(r);X(a)}d.CInjection=ye,d.Container=B,d.VInjection=he,d.clearNamespace=Ie,d.config=X,d.finalizationRegistry=we,d.inject=We,d.isRegistered=_e,d.loader=ae,d.provide=L,d.useInstance=J,d.useLoader=Me,d.useModel=je,d.useWatcher=Pe,d.watch=x,Object.defineProperty(d,Symbol.toStringTag,{value:"Module"})}));
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@e7w/easy-model",
3
- "version": "0.1.7",
3
+ "version": "0.1.8",
4
4
  "module": "./dist/index.es.js",
5
5
  "publishConfig": {
6
6
  "access": "public",
@@ -20,39 +20,49 @@
20
20
  "zod": "^4.1.5"
21
21
  },
22
22
  "devDependencies": {
23
- "@eslint/js": "^9.24.0",
24
- "@testing-library/jest-dom": "^6.6.3",
25
- "@testing-library/react": "^16.3.0",
23
+ "@babel/plugin-proposal-decorators": "^7.29.0",
24
+ "@eslint/js": "^9.39.3",
25
+ "@reduxjs/toolkit": "^2.11.2",
26
+ "@testing-library/jest-dom": "^6.9.1",
27
+ "@testing-library/react": "^16.3.2",
26
28
  "@types/jsdom": "^21.1.7",
27
- "@types/node": "^22.13.5",
29
+ "@types/node": "^22.19.11",
28
30
  "@types/react": ">=17.0.0",
29
- "@vitejs/plugin-react-swc": "^3.8.1",
30
- "@vitest/coverage-v8": "^3.0.7",
31
+ "@types/react-dom": ">=17.0.0",
32
+ "@types/react-redux": "^7.1.34",
33
+ "@vitejs/plugin-react": "^5.1.4",
34
+ "@vitest/coverage-v8": "^3.2.4",
31
35
  "copyfiles": "^2.4.1",
32
36
  "dts-bundle-generator": "^9.5.1",
33
- "eslint": "^9.24.0",
34
- "eslint-config-prettier": "^10.0.1",
37
+ "eslint": "^9.39.3",
38
+ "eslint-config-prettier": "^10.1.8",
35
39
  "eslint-plugin-autofix": "^2.2.0",
36
- "eslint-plugin-prettier": "^5.2.3",
37
- "globals": "^16.0.0",
40
+ "eslint-plugin-prettier": "^5.5.5",
41
+ "globals": "^16.5.0",
38
42
  "husky": "^9.1.7",
39
- "jiti": "^2.4.2",
40
- "jsdom": "^26.0.0",
41
- "lint-staged": "^15.4.3",
42
- "postcss": "^8.5.3",
43
+ "jiti": "^2.6.1",
44
+ "jsdom": "^26.1.0",
45
+ "lint-staged": "^15.5.2",
46
+ "mobx": "^6.15.0",
47
+ "mobx-react-lite": "^4.1.1",
48
+ "postcss": "^8.5.6",
43
49
  "postcss-scss": "^4.0.9",
44
- "prettier": "^3.5.2",
45
- "rimraf": "^6.0.1",
46
- "stylelint": "^16.14.1",
50
+ "prettier": "^3.8.1",
51
+ "react-dom": ">=17.0.0",
52
+ "react-redux": "^9.2.0",
53
+ "redux": "^5.0.1",
54
+ "rimraf": "^6.1.3",
55
+ "stylelint": "^16.26.1",
47
56
  "stylelint-config-recommended": "^15.0.0",
48
57
  "stylelint-config-sass-guidelines": "^12.1.0",
49
58
  "stylelint-order": "^6.0.4",
50
59
  "stylelint-prettier": "^5.0.3",
51
60
  "ts-node": "^10.9.2",
52
- "typescript": "^5.7.3",
53
- "typescript-eslint": "^8.29.1",
54
- "vite": "^6.2.0",
55
- "vitest": "^3.0.7"
61
+ "typescript": "^5.9.3",
62
+ "typescript-eslint": "^8.56.1",
63
+ "vite": "^6.4.1",
64
+ "vitest": "^3.2.4",
65
+ "zustand": "^5.0.11"
56
66
  },
57
67
  "files": [
58
68
  "dist",