@rokku-x/react-hook-loading-spinner 0.1.1 → 0.2.0

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.
@@ -1,2 +1,9 @@
1
- export { default } from '../mainLogic';
2
- export * from '../mainLogic';
1
+ export default function ssrLoading(): {
2
+ overrideLoading: (state: boolean | null) => void;
3
+ startLoading: () => void;
4
+ stopLoading: () => void;
5
+ readonly isLocalLoading: boolean;
6
+ asyncUseLoading: <R, _ extends any[]>(asyncFunction: Promise<R>) => Promise<R>;
7
+ readonly isLoading: boolean;
8
+ };
9
+ export * from '../store/loadingStore';
@@ -1,2 +1,9 @@
1
- export { default } from '../mainLogic';
2
- export * from '../mainLogic';
1
+ export default function useLoading(): {
2
+ overrideLoading: (state: boolean | null) => void;
3
+ startLoading: () => void;
4
+ stopLoading: () => void;
5
+ readonly isLocalLoading: boolean;
6
+ asyncUseLoading: <R, _ extends any[]>(asyncFunction: Promise<R>) => Promise<R>;
7
+ readonly isLoading: boolean;
8
+ };
9
+ export * from '../store/loadingStore';
package/dist/index.cjs.js CHANGED
@@ -1,6 +1,30 @@
1
- "use client";"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const I=require("react/jsx-runtime"),m=require("react");require("react-dom");const T=n=>{let t;const e=new Set,i=(g,r)=>{const u=typeof g=="function"?g(t):g;if(!Object.is(u,t)){const L=t;t=r??(typeof u!="object"||u===null)?u:Object.assign({},t,u),e.forEach(f=>f(t,L))}},o=()=>t,a={setState:i,getState:o,getInitialState:()=>p,subscribe:g=>(e.add(g),()=>e.delete(g))},p=t=n(i,o,a);return a},R=(n=>n?T(n):T),A=n=>n;function D(n,t=A){const e=m.useSyncExternalStore(n.subscribe,m.useCallback(()=>t(n.getState()),[n,t]),m.useCallback(()=>t(n.getInitialState()),[n,t]));return m.useDebugValue(e),e}const w=n=>{const t=R(n),e=i=>D(t,i);return Object.assign(e,t),e},k=(n=>n?w(n):w),x={BASE_URL:"/",DEV:!1,MODE:"production",PROD:!0,SSR:!1},b=new Map,C=n=>{const t=b.get(n);return t?Object.fromEntries(Object.entries(t.stores).map(([e,i])=>[e,i.getState()])):{}},N=(n,t,e)=>{if(n===void 0)return{type:"untracked",connection:t.connect(e)};const i=b.get(e.name);if(i)return{type:"tracked",store:n,...i};const o={connection:t.connect(e),stores:{}};return b.set(e.name,o),{type:"tracked",store:n,...o}},M=(n,t)=>{if(t===void 0)return;const e=b.get(n);e&&(delete e.stores[t],Object.keys(e.stores).length===0&&b.delete(n))},P=n=>{var t,e;if(!n)return;const i=n.split(`
2
- `),o=i.findIndex(S=>S.includes("api.setState"));if(o<0)return;const c=((t=i[o+1])==null?void 0:t.trim())||"";return(e=/.+ (.+) .+/.exec(c))==null?void 0:e[1]},J=(n,t={})=>(e,i,o)=>{const{enabled:c,anonymousActionType:S,store:a,...p}=t;let g;try{g=(c??(x?"production":void 0)!=="production")&&window.__REDUX_DEVTOOLS_EXTENSION__}catch{}if(!g)return n(e,i,o);const{connection:r,...u}=N(a,g,p);let L=!0;o.setState=((l,v,s)=>{const d=e(l,v);if(!L)return d;const _=s===void 0?{type:S||P(new Error().stack)||"anonymous"}:typeof s=="string"?{type:s}:s;return a===void 0?(r?.send(_,i()),d):(r?.send({..._,type:`${a}/${_.type}`},{...C(p.name),[a]:o.getState()}),d)}),o.devtools={cleanup:()=>{r&&typeof r.unsubscribe=="function"&&r.unsubscribe(),M(p.name,a)}};const f=(...l)=>{const v=L;L=!1,e(...l),L=v},h=n(o.setState,i,o);if(u.type==="untracked"?r?.init(h):(u.stores[u.store]=o,r?.init(Object.fromEntries(Object.entries(u.stores).map(([l,v])=>[l,l===u.store?h:v.getState()])))),o.dispatchFromDevtools&&typeof o.dispatch=="function"){let l=!1;const v=o.dispatch;o.dispatch=(...s)=>{(x?"production":void 0)!=="production"&&s[0].type==="__setState"&&!l&&(console.warn('[zustand devtools middleware] "__setState" action type is reserved to set state from the devtools. Avoid using it.'),l=!0),v(...s)}}return r.subscribe(l=>{var v;switch(l.type){case"ACTION":if(typeof l.payload!="string"){console.error("[zustand devtools middleware] Unsupported action format");return}return E(l.payload,s=>{if(s.type==="__setState"){if(a===void 0){f(s.state);return}Object.keys(s.state).length!==1&&console.error(`
1
+ "use client";"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const y=require("react"),N=require("crypto"),C=require("react/jsx-runtime"),F=require("react-dom"),I=e=>{let t;const n=new Set,i=(g,r)=>{const c=typeof g=="function"?g(t):g;if(!Object.is(c,t)){const L=t;t=r??(typeof c!="object"||c===null)?c:Object.assign({},t,c),n.forEach(u=>u(t,L))}},o=()=>t,a={setState:i,getState:o,getInitialState:()=>v,subscribe:g=>(n.add(g),()=>n.delete(g))},v=t=e(i,o,a);return a},M=(e=>e?I(e):I),P=e=>e;function U(e,t=P){const n=y.useSyncExternalStore(e.subscribe,y.useCallback(()=>t(e.getState()),[e,t]),y.useCallback(()=>t(e.getInitialState()),[e,t]));return y.useDebugValue(n),n}const j=e=>{const t=M(e),n=i=>U(t,i);return Object.assign(n,t),n},$=(e=>e?j(e):j),T={BASE_URL:"/",DEV:!1,MODE:"production",PROD:!0,SSR:!1},E=new Map,w=e=>{const t=E.get(e);return t?Object.fromEntries(Object.entries(t.stores).map(([n,i])=>[n,i.getState()])):{}},J=(e,t,n)=>{if(e===void 0)return{type:"untracked",connection:t.connect(n)};const i=E.get(n.name);if(i)return{type:"tracked",store:e,...i};const o={connection:t.connect(n),stores:{}};return E.set(n.name,o),{type:"tracked",store:e,...o}},z=(e,t)=>{if(t===void 0)return;const n=E.get(e);n&&(delete n.stores[t],Object.keys(n.stores).length===0&&E.delete(e))},W=e=>{var t,n;if(!e)return;const i=e.split(`
2
+ `),o=i.findIndex(f=>f.includes("api.setState"));if(o<0)return;const s=((t=i[o+1])==null?void 0:t.trim())||"";return(n=/.+ (.+) .+/.exec(s))==null?void 0:n[1]},q=(e,t={})=>(n,i,o)=>{const{enabled:s,anonymousActionType:f,store:a,...v}=t;let g;try{g=(s??(T?"production":void 0)!=="production")&&window.__REDUX_DEVTOOLS_EXTENSION__}catch{}if(!g)return e(n,i,o);const{connection:r,...c}=J(a,g,v);let L=!0;o.setState=((d,p,l)=>{const S=n(d,p);if(!L)return S;const x=l===void 0?{type:f||W(new Error().stack)||"anonymous"}:typeof l=="string"?{type:l}:l;return a===void 0?(r?.send(x,i()),S):(r?.send({...x,type:`${a}/${x.type}`},{...w(v.name),[a]:o.getState()}),S)}),o.devtools={cleanup:()=>{r&&typeof r.unsubscribe=="function"&&r.unsubscribe(),z(v.name,a)}};const u=(...d)=>{const p=L;L=!1,n(...d),L=p},b=e(o.setState,i,o);if(c.type==="untracked"?r?.init(b):(c.stores[c.store]=o,r?.init(Object.fromEntries(Object.entries(c.stores).map(([d,p])=>[d,d===c.store?b:p.getState()])))),o.dispatchFromDevtools&&typeof o.dispatch=="function"){let d=!1;const p=o.dispatch;o.dispatch=(...l)=>{(T?"production":void 0)!=="production"&&l[0].type==="__setState"&&!d&&(console.warn('[zustand devtools middleware] "__setState" action type is reserved to set state from the devtools. Avoid using it.'),d=!0),p(...l)}}return r.subscribe(d=>{var p;switch(d.type){case"ACTION":if(typeof d.payload!="string"){console.error("[zustand devtools middleware] Unsupported action format");return}return O(d.payload,l=>{if(l.type==="__setState"){if(a===void 0){u(l.state);return}Object.keys(l.state).length!==1&&console.error(`
3
3
  [zustand devtools middleware] Unsupported __setState action format.
4
4
  When using 'store' option in devtools(), the 'state' should have only one key, which is a value of 'store' that was passed in devtools(),
5
5
  and value of this only key should be a state object. Example: { "type": "__setState", "state": { "abc123Store": { "foo": "bar" } } }
6
- `);const d=s.state[a];if(d==null)return;JSON.stringify(o.getState())!==JSON.stringify(d)&&f(d);return}o.dispatchFromDevtools&&typeof o.dispatch=="function"&&o.dispatch(s)});case"DISPATCH":switch(l.payload.type){case"RESET":return f(h),a===void 0?r?.init(o.getState()):r?.init(C(p.name));case"COMMIT":if(a===void 0){r?.init(o.getState());return}return r?.init(C(p.name));case"ROLLBACK":return E(l.state,s=>{if(a===void 0){f(s),r?.init(o.getState());return}f(s[a]),r?.init(C(p.name))});case"JUMP_TO_STATE":case"JUMP_TO_ACTION":return E(l.state,s=>{if(a===void 0){f(s);return}JSON.stringify(o.getState())!==JSON.stringify(s[a])&&f(s[a])});case"IMPORT_STATE":{const{nextLiftedState:s}=l.payload,d=(v=s.computedStates.slice(-1)[0])==null?void 0:v.state;if(!d)return;f(a===void 0?d:d[a]),r?.send(null,s);return}case"PAUSE_RECORDING":return L=!L}return}}),h},U=J,E=(n,t)=>{let e;try{e=JSON.parse(n)}catch(i){console.error("[zustand devtools middleware] Could not parse the received json",i)}e!==void 0&&t(e)};class j extends EventTarget{constructor(){super(...arguments),this.controller=new AbortController}on(t,e){return this.addEventListener(t,i=>e(i.detail),{signal:this.controller.signal}),this}once(t,e){return this.addEventListener(t,i=>e(i.detail),{signal:this.controller.signal,once:!0}),this}emit(t,e){return this.dispatchEvent(new CustomEvent(t,{detail:e}))}removeAllListeners(){this.controller.abort(),this.controller=new AbortController}}const y=new j,F=k()(U((n,t)=>({loadingCount:0,overrideState:null,localCounters:{},isLoading(){return t().overrideState??t().loadingCount>0},actions:{isGlobalLoading(){return t().isLoading()},startLoading:e=>{const i=t().isLoading();n(c=>({loadingCount:c.loadingCount+1})),e&&n(c=>({localCounters:{...c.localCounters,[e]:(c.localCounters[e]??0)+1}}));const o=t().isLoading();o&&!i&&y.emit("start",null),y.emit("change",{isLoading:o,isOverrideState:t().overrideState!==null})},stopLoading:e=>{const i=t().isLoading(),o=e?t().localCounters[e]??0:0;e&&o>0&&n(S=>({loadingCount:Math.max(0,S.loadingCount-1),localCounters:{...S.localCounters,[e]:Math.max(0,S.localCounters[e]-1)}}));const c=t().isLoading();!c&&i&&y.emit("stop",null),y.emit("change",{isLoading:c,isOverrideState:t().overrideState!==null})},overrideLoading:e=>{const i=t().isLoading();n({overrideState:e});const o=t().isLoading();o&&!i?y.emit("start",null):!o&&i&&y.emit("stop",null),y.emit("change",{isLoading:o,isOverrideState:e!==null})},getLocalCounter:e=>t().localCounters[e]??0,isLocalLoading:e=>(t().localCounters[e]??0)>0}})));function O(){const n=m.useId(),{actions:t}=F(c=>c),e=()=>{t.startLoading(n)},i=()=>{t.isLocalLoading(n)&&t.stopLoading(n)},o=async c=>{e();try{return await c}finally{i()}};return{overrideLoading:t.overrideLoading,startLoading:e,stopLoading:i,get isLocalLoading(){return t.isLocalLoading(n)},asyncUseLoading:o,get isLoading(){return t.isGlobalLoading()}}}const z={Spin:"spin",FadeInOut:"fadeInOut",None:"none"},W=n=>I.jsx("div",{id:"loading-circle",style:{width:"90px",height:"90px",border:"15px solid #f3f3f3",borderTop:"15px solid #009b4bff",borderRadius:"50%",boxSizing:"border-box"},...n}),q=n=>I.jsx("div",{style:{padding:"20px",fontSize:"25px",color:"#333",fontFamily:"system-ui, sans-serif"},...n,children:"Please wait..."});function B({isLoading:n=!1}){const{startLoading:t,stopLoading:e}=O();return m.useEffect(()=>(n?t():e(),()=>{n&&e()}),[n]),null}exports.AnimationType=z;exports.EventEmitter=j;exports.Loading=B;exports.LoadingCircle=W;exports.LoadingPleaseWait=q;exports.loadingEventTarget=y;exports.ssrLoading=O;exports.useLoading=O;
6
+ `);const S=l.state[a];if(S==null)return;JSON.stringify(o.getState())!==JSON.stringify(S)&&u(S);return}o.dispatchFromDevtools&&typeof o.dispatch=="function"&&o.dispatch(l)});case"DISPATCH":switch(d.payload.type){case"RESET":return u(b),a===void 0?r?.init(o.getState()):r?.init(w(v.name));case"COMMIT":if(a===void 0){r?.init(o.getState());return}return r?.init(w(v.name));case"ROLLBACK":return O(d.state,l=>{if(a===void 0){u(l),r?.init(o.getState());return}u(l[a]),r?.init(w(v.name))});case"JUMP_TO_STATE":case"JUMP_TO_ACTION":return O(d.state,l=>{if(a===void 0){u(l);return}JSON.stringify(o.getState())!==JSON.stringify(l[a])&&u(l[a])});case"IMPORT_STATE":{const{nextLiftedState:l}=d.payload,S=(p=l.computedStates.slice(-1)[0])==null?void 0:p.state;if(!S)return;u(a===void 0?S:S[a]),r?.send(null,l);return}case"PAUSE_RECORDING":return L=!L}return}}),b},G=q,O=(e,t)=>{let n;try{n=JSON.parse(e)}catch(i){console.error("[zustand devtools middleware] Could not parse the received json",i)}n!==void 0&&t(n)};class R extends EventTarget{constructor(){super(...arguments),this.controller=new AbortController}on(t,n){return this.addEventListener(t,i=>n(i.detail),{signal:this.controller.signal}),this}once(t,n){return this.addEventListener(t,i=>n(i.detail),{signal:this.controller.signal,once:!0}),this}emit(t,n){return this.dispatchEvent(new CustomEvent(t,{detail:n}))}removeAllListeners(){this.controller.abort(),this.controller=new AbortController}}const h=new R,_=$()(G((e,t)=>({loadingCount:0,overrideState:null,localCounters:{},isLoading(){return t().overrideState??t().loadingCount>0},actions:{isGlobalLoading(){return t().isLoading()},startLoading:n=>{const i=t().isLoading();e(s=>({loadingCount:s.loadingCount+1})),n&&e(s=>({localCounters:{...s.localCounters,[n]:(s.localCounters[n]??0)+1}}));const o=t().isLoading();o&&!i&&h.emit("start",null),h.emit("change",{isLoading:o,isOverrideState:t().overrideState!==null})},stopLoading:n=>{const i=t().isLoading(),o=n?t().localCounters[n]??0:0;n&&o>0&&e(f=>({loadingCount:Math.max(0,f.loadingCount-1),localCounters:{...f.localCounters,[n]:Math.max(0,f.localCounters[n]-1)}}));const s=t().isLoading();!s&&i&&h.emit("stop",null),h.emit("change",{isLoading:s,isOverrideState:t().overrideState!==null})},overrideLoading:n=>{const i=t().isLoading();e({overrideState:n});const o=t().isLoading();o&&!i?h.emit("start",null):!o&&i&&h.emit("stop",null),h.emit("change",{isLoading:o,isOverrideState:n!==null})},getLocalCounter:n=>t().localCounters[n]??0,isLocalLoading:n=>(t().localCounters[n]??0)>0}})));function A(){const e=y.useId(),{actions:t}=_(s=>s),n=()=>{t.startLoading(e)},i=()=>{t.isLocalLoading(e)&&t.stopLoading(e)},o=async s=>{n();try{return await s}finally{i()}};return{overrideLoading:t.overrideLoading,startLoading:n,stopLoading:i,get isLocalLoading(){return t.isLocalLoading(e)},asyncUseLoading:o,get isLoading(){return t.isGlobalLoading()}}}function V(){const e=N.randomUUID(),{actions:t}=_(s=>s),n=()=>{t.startLoading(e)},i=()=>{t.isLocalLoading(e)&&t.stopLoading(e)},o=async s=>{n();try{return await s}finally{i()}};return{overrideLoading:t.overrideLoading,startLoading:n,stopLoading:i,get isLocalLoading(){return t.isLocalLoading(e)},asyncUseLoading:o,get isLoading(){return t.isGlobalLoading()}}}const m={Spin:"spin",FadeInOut:"fadeInOut",None:"none"},B=({scale:e=1,animationType:t=m.Spin,animationDuration:n,children:i,style:o,className:s,id:f,prefix:a})=>{const v=t,g=t===m.Spin?1:t===m.FadeInOut?2:0,r=n||g,c=t===m.Spin?"linear":t===m.FadeInOut?"ease-in-out":"linear",L=t===m.None?"none":`${a}-${v} ${r}s ${c} infinite`;return C.jsx("div",{style:{animation:L,...e!==1?{zoom:e}:{},...o},className:s,id:f,children:i})},k=e=>C.jsx("div",{id:"loading-circle",style:{width:"90px",height:"90px",border:"15px solid #f3f3f3",borderTop:"15px solid #009b4bff",borderRadius:"50%",boxSizing:"border-box"},...e}),D=e=>C.jsx("div",{style:{padding:"20px",fontSize:"25px",color:"#333",fontFamily:"system-ui, sans-serif"},...e,children:"Please wait..."});function X({loadingComponent:e,loadingComponentScale:t=1,animationType:n=m.Spin,animationDuration:i,wrapperStyle:o,wrapperClassName:s,wrapperId:f,animationWrapperStyle:a,animationWrapperClassName:v,animationWrapperId:g}){e=e||(n===m.Spin?k:D);const r=y.useRef(Math.random().toString(36).substring(2,6).replace(/[0-9]/g,"")),{loadingCount:c,overrideState:L}=_(p=>p),u=L??c>0,b=y.useRef(null);y.useEffect(()=>{u?(b.current?.showModal(),document.body.setAttribute("inert","")):(b.current?.close(),document.body.removeAttribute("inert"))},[u]);const d=f||"loading-wrapper-"+r.current;return u?F.createPortal(C.jsxs(C.Fragment,{children:[C.jsx("style",{children:`
7
+ dialog#${d}[open] {
8
+ display: flex !important;
9
+ justify-content: center;
10
+ align-items: center;
11
+ width: 100vw;
12
+ height: 100vh;
13
+ max-width: 100%;
14
+ max-height: 100%;
15
+ }
16
+ @keyframes ${r.current}-spin {
17
+ 0% { transform: rotate(0deg); }
18
+ 100% { transform: rotate(360deg); }
19
+ }
20
+ @keyframes ${r.current}-fadeInOut {
21
+ 0%, 100% { opacity: 0.2; }
22
+ 50% { opacity: 1; }
23
+ }
24
+ body:has(dialog#${d}[open]) {
25
+ overflow: hidden;
26
+ }
27
+ body {
28
+ scrollbar-gutter: stable;
29
+ }
30
+ `}),C.jsx("dialog",{ref:b,style:{border:"none",padding:0,backgroundColor:"rgba(0, 0, 0, 0.5)",backdropFilter:"blur(2px)",...o},className:s,id:d,children:C.jsx(B,{scale:t,animationType:n,animationDuration:i,style:a,className:v,id:g,prefix:r.current,children:y.isValidElement(e)?e:y.createElement(e)})})]}),document.body):null}function H({isLoading:e=!1}){const{startLoading:t,stopLoading:n}=A();return y.useEffect(()=>(e?t():n(),()=>{e&&n()}),[e]),null}exports.AnimationType=m;exports.EventEmitter=R;exports.Loading=H;exports.LoadingCircle=k;exports.LoadingPleaseWait=D;exports.LoadingRenderer=X;exports.loadingEventTarget=h;exports.ssrLoading=V;exports.useLoading=A;
package/dist/index.d.ts CHANGED
@@ -3,5 +3,6 @@ export { default as ssrLoading } from './hooks/ssrLoading';
3
3
  export { LoadingCircle, LoadingPleaseWait, AnimationType } from './components/LoadingRenderer';
4
4
  export type { AnimationType as AnimationTypeType } from './components/LoadingRenderer';
5
5
  export { default as Loading } from './components/Loading';
6
+ export { default as LoadingRenderer } from './components/LoadingRenderer';
6
7
  export { default as EventEmitter } from './utils/EventEmitter';
7
- export { loadingEventTarget } from './mainLogic';
8
+ export { loadingEventTarget } from './store/loadingStore';
package/dist/index.esm.js CHANGED
@@ -1,232 +1,233 @@
1
1
  "use client";
2
- import { jsx as T } from "react/jsx-runtime";
3
- import b, { useId as x, useEffect as R } from "react";
4
- import "react-dom";
5
- const E = (n) => {
2
+ import b, { useId as N, useRef as x, useEffect as A } from "react";
3
+ import { randomUUID as j } from "crypto";
4
+ import { jsx as C, jsxs as D, Fragment as F } from "react/jsx-runtime";
5
+ import { createPortal as M } from "react-dom";
6
+ const T = (e) => {
6
7
  let t;
7
- const e = /* @__PURE__ */ new Set(), i = (v, r) => {
8
- const u = typeof v == "function" ? v(t) : v;
9
- if (!Object.is(u, t)) {
10
- const L = t;
11
- t = r ?? (typeof u != "object" || u === null) ? u : Object.assign({}, t, u), e.forEach((f) => f(t, L));
8
+ const n = /* @__PURE__ */ new Set(), i = (f, r) => {
9
+ const c = typeof f == "function" ? f(t) : f;
10
+ if (!Object.is(c, t)) {
11
+ const p = t;
12
+ t = r ?? (typeof c != "object" || c === null) ? c : Object.assign({}, t, c), n.forEach((u) => u(t, p));
12
13
  }
13
- }, o = () => t, a = { setState: i, getState: o, getInitialState: () => p, subscribe: (v) => (e.add(v), () => e.delete(v)) }, p = t = n(i, o, a);
14
+ }, o = () => t, a = { setState: i, getState: o, getInitialState: () => v, subscribe: (f) => (n.add(f), () => n.delete(f)) }, v = t = e(i, o, a);
14
15
  return a;
15
- }, j = ((n) => n ? E(n) : E), A = (n) => n;
16
- function D(n, t = A) {
17
- const e = b.useSyncExternalStore(
18
- n.subscribe,
19
- b.useCallback(() => t(n.getState()), [n, t]),
20
- b.useCallback(() => t(n.getInitialState()), [n, t])
16
+ }, U = ((e) => e ? T(e) : T), $ = (e) => e;
17
+ function P(e, t = $) {
18
+ const n = b.useSyncExternalStore(
19
+ e.subscribe,
20
+ b.useCallback(() => t(e.getState()), [e, t]),
21
+ b.useCallback(() => t(e.getInitialState()), [e, t])
21
22
  );
22
- return b.useDebugValue(e), e;
23
+ return b.useDebugValue(n), n;
23
24
  }
24
- const w = (n) => {
25
- const t = j(n), e = (i) => D(t, i);
26
- return Object.assign(e, t), e;
27
- }, k = ((n) => n ? w(n) : w), I = { BASE_URL: "/", DEV: !1, MODE: "production", PROD: !0, SSR: !1 }, m = /* @__PURE__ */ new Map(), C = (n) => {
28
- const t = m.get(n);
25
+ const R = (e) => {
26
+ const t = U(e), n = (i) => P(t, i);
27
+ return Object.assign(n, t), n;
28
+ }, J = ((e) => e ? R(e) : R), k = { BASE_URL: "/", DEV: !1, MODE: "production", PROD: !0, SSR: !1 }, w = /* @__PURE__ */ new Map(), _ = (e) => {
29
+ const t = w.get(e);
29
30
  return t ? Object.fromEntries(
30
- Object.entries(t.stores).map(([e, i]) => [e, i.getState()])
31
+ Object.entries(t.stores).map(([n, i]) => [n, i.getState()])
31
32
  ) : {};
32
- }, N = (n, t, e) => {
33
- if (n === void 0)
33
+ }, z = (e, t, n) => {
34
+ if (e === void 0)
34
35
  return {
35
36
  type: "untracked",
36
- connection: t.connect(e)
37
+ connection: t.connect(n)
37
38
  };
38
- const i = m.get(e.name);
39
+ const i = w.get(n.name);
39
40
  if (i)
40
- return { type: "tracked", store: n, ...i };
41
+ return { type: "tracked", store: e, ...i };
41
42
  const o = {
42
- connection: t.connect(e),
43
+ connection: t.connect(n),
43
44
  stores: {}
44
45
  };
45
- return m.set(e.name, o), { type: "tracked", store: n, ...o };
46
- }, M = (n, t) => {
46
+ return w.set(n.name, o), { type: "tracked", store: e, ...o };
47
+ }, G = (e, t) => {
47
48
  if (t === void 0) return;
48
- const e = m.get(n);
49
- e && (delete e.stores[t], Object.keys(e.stores).length === 0 && m.delete(n));
50
- }, J = (n) => {
51
- var t, e;
52
- if (!n) return;
53
- const i = n.split(`
49
+ const n = w.get(e);
50
+ n && (delete n.stores[t], Object.keys(n.stores).length === 0 && w.delete(e));
51
+ }, V = (e) => {
52
+ var t, n;
53
+ if (!e) return;
54
+ const i = e.split(`
54
55
  `), o = i.findIndex(
55
- (S) => S.includes("api.setState")
56
+ (g) => g.includes("api.setState")
56
57
  );
57
58
  if (o < 0) return;
58
- const c = ((t = i[o + 1]) == null ? void 0 : t.trim()) || "";
59
- return (e = /.+ (.+) .+/.exec(c)) == null ? void 0 : e[1];
60
- }, P = (n, t = {}) => (e, i, o) => {
61
- const { enabled: c, anonymousActionType: S, store: a, ...p } = t;
62
- let v;
59
+ const s = ((t = i[o + 1]) == null ? void 0 : t.trim()) || "";
60
+ return (n = /.+ (.+) .+/.exec(s)) == null ? void 0 : n[1];
61
+ }, W = (e, t = {}) => (n, i, o) => {
62
+ const { enabled: s, anonymousActionType: g, store: a, ...v } = t;
63
+ let f;
63
64
  try {
64
- v = (c ?? (I ? "production" : void 0) !== "production") && window.__REDUX_DEVTOOLS_EXTENSION__;
65
+ f = (s ?? (k ? "production" : void 0) !== "production") && window.__REDUX_DEVTOOLS_EXTENSION__;
65
66
  } catch {
66
67
  }
67
- if (!v)
68
- return n(e, i, o);
69
- const { connection: r, ...u } = N(a, v, p);
70
- let L = !0;
71
- o.setState = ((l, g, s) => {
72
- const d = e(l, g);
73
- if (!L) return d;
74
- const _ = s === void 0 ? {
75
- type: S || J(new Error().stack) || "anonymous"
76
- } : typeof s == "string" ? { type: s } : s;
77
- return a === void 0 ? (r?.send(_, i()), d) : (r?.send(
68
+ if (!f)
69
+ return e(n, i, o);
70
+ const { connection: r, ...c } = z(a, f, v);
71
+ let p = !0;
72
+ o.setState = ((d, S, l) => {
73
+ const L = n(d, S);
74
+ if (!p) return L;
75
+ const O = l === void 0 ? {
76
+ type: g || V(new Error().stack) || "anonymous"
77
+ } : typeof l == "string" ? { type: l } : l;
78
+ return a === void 0 ? (r?.send(O, i()), L) : (r?.send(
78
79
  {
79
- ..._,
80
- type: `${a}/${_.type}`
80
+ ...O,
81
+ type: `${a}/${O.type}`
81
82
  },
82
83
  {
83
- ...C(p.name),
84
+ ..._(v.name),
84
85
  [a]: o.getState()
85
86
  }
86
- ), d);
87
+ ), L);
87
88
  }), o.devtools = {
88
89
  cleanup: () => {
89
- r && typeof r.unsubscribe == "function" && r.unsubscribe(), M(p.name, a);
90
+ r && typeof r.unsubscribe == "function" && r.unsubscribe(), G(v.name, a);
90
91
  }
91
92
  };
92
- const f = (...l) => {
93
- const g = L;
94
- L = !1, e(...l), L = g;
95
- }, h = n(o.setState, i, o);
96
- if (u.type === "untracked" ? r?.init(h) : (u.stores[u.store] = o, r?.init(
93
+ const u = (...d) => {
94
+ const S = p;
95
+ p = !1, n(...d), p = S;
96
+ }, m = e(o.setState, i, o);
97
+ if (c.type === "untracked" ? r?.init(m) : (c.stores[c.store] = o, r?.init(
97
98
  Object.fromEntries(
98
- Object.entries(u.stores).map(([l, g]) => [
99
- l,
100
- l === u.store ? h : g.getState()
99
+ Object.entries(c.stores).map(([d, S]) => [
100
+ d,
101
+ d === c.store ? m : S.getState()
101
102
  ])
102
103
  )
103
104
  )), o.dispatchFromDevtools && typeof o.dispatch == "function") {
104
- let l = !1;
105
- const g = o.dispatch;
106
- o.dispatch = (...s) => {
107
- (I ? "production" : void 0) !== "production" && s[0].type === "__setState" && !l && (console.warn(
105
+ let d = !1;
106
+ const S = o.dispatch;
107
+ o.dispatch = (...l) => {
108
+ (k ? "production" : void 0) !== "production" && l[0].type === "__setState" && !d && (console.warn(
108
109
  '[zustand devtools middleware] "__setState" action type is reserved to set state from the devtools. Avoid using it.'
109
- ), l = !0), g(...s);
110
+ ), d = !0), S(...l);
110
111
  };
111
112
  }
112
- return r.subscribe((l) => {
113
- var g;
114
- switch (l.type) {
113
+ return r.subscribe((d) => {
114
+ var S;
115
+ switch (d.type) {
115
116
  case "ACTION":
116
- if (typeof l.payload != "string") {
117
+ if (typeof d.payload != "string") {
117
118
  console.error(
118
119
  "[zustand devtools middleware] Unsupported action format"
119
120
  );
120
121
  return;
121
122
  }
122
- return O(
123
- l.payload,
124
- (s) => {
125
- if (s.type === "__setState") {
123
+ return E(
124
+ d.payload,
125
+ (l) => {
126
+ if (l.type === "__setState") {
126
127
  if (a === void 0) {
127
- f(s.state);
128
+ u(l.state);
128
129
  return;
129
130
  }
130
- Object.keys(s.state).length !== 1 && console.error(
131
+ Object.keys(l.state).length !== 1 && console.error(
131
132
  `
132
133
  [zustand devtools middleware] Unsupported __setState action format.
133
134
  When using 'store' option in devtools(), the 'state' should have only one key, which is a value of 'store' that was passed in devtools(),
134
135
  and value of this only key should be a state object. Example: { "type": "__setState", "state": { "abc123Store": { "foo": "bar" } } }
135
136
  `
136
137
  );
137
- const d = s.state[a];
138
- if (d == null)
138
+ const L = l.state[a];
139
+ if (L == null)
139
140
  return;
140
- JSON.stringify(o.getState()) !== JSON.stringify(d) && f(d);
141
+ JSON.stringify(o.getState()) !== JSON.stringify(L) && u(L);
141
142
  return;
142
143
  }
143
- o.dispatchFromDevtools && typeof o.dispatch == "function" && o.dispatch(s);
144
+ o.dispatchFromDevtools && typeof o.dispatch == "function" && o.dispatch(l);
144
145
  }
145
146
  );
146
147
  case "DISPATCH":
147
- switch (l.payload.type) {
148
+ switch (d.payload.type) {
148
149
  case "RESET":
149
- return f(h), a === void 0 ? r?.init(o.getState()) : r?.init(C(p.name));
150
+ return u(m), a === void 0 ? r?.init(o.getState()) : r?.init(_(v.name));
150
151
  case "COMMIT":
151
152
  if (a === void 0) {
152
153
  r?.init(o.getState());
153
154
  return;
154
155
  }
155
- return r?.init(C(p.name));
156
+ return r?.init(_(v.name));
156
157
  case "ROLLBACK":
157
- return O(l.state, (s) => {
158
+ return E(d.state, (l) => {
158
159
  if (a === void 0) {
159
- f(s), r?.init(o.getState());
160
+ u(l), r?.init(o.getState());
160
161
  return;
161
162
  }
162
- f(s[a]), r?.init(C(p.name));
163
+ u(l[a]), r?.init(_(v.name));
163
164
  });
164
165
  case "JUMP_TO_STATE":
165
166
  case "JUMP_TO_ACTION":
166
- return O(l.state, (s) => {
167
+ return E(d.state, (l) => {
167
168
  if (a === void 0) {
168
- f(s);
169
+ u(l);
169
170
  return;
170
171
  }
171
- JSON.stringify(o.getState()) !== JSON.stringify(s[a]) && f(s[a]);
172
+ JSON.stringify(o.getState()) !== JSON.stringify(l[a]) && u(l[a]);
172
173
  });
173
174
  case "IMPORT_STATE": {
174
- const { nextLiftedState: s } = l.payload, d = (g = s.computedStates.slice(-1)[0]) == null ? void 0 : g.state;
175
- if (!d) return;
176
- f(a === void 0 ? d : d[a]), r?.send(
175
+ const { nextLiftedState: l } = d.payload, L = (S = l.computedStates.slice(-1)[0]) == null ? void 0 : S.state;
176
+ if (!L) return;
177
+ u(a === void 0 ? L : L[a]), r?.send(
177
178
  null,
178
179
  // FIXME no-any
179
- s
180
+ l
180
181
  );
181
182
  return;
182
183
  }
183
184
  case "PAUSE_RECORDING":
184
- return L = !L;
185
+ return p = !p;
185
186
  }
186
187
  return;
187
188
  }
188
- }), h;
189
- }, U = P, O = (n, t) => {
190
- let e;
189
+ }), m;
190
+ }, B = W, E = (e, t) => {
191
+ let n;
191
192
  try {
192
- e = JSON.parse(n);
193
+ n = JSON.parse(e);
193
194
  } catch (i) {
194
195
  console.error(
195
196
  "[zustand devtools middleware] Could not parse the received json",
196
197
  i
197
198
  );
198
199
  }
199
- e !== void 0 && t(e);
200
+ n !== void 0 && t(n);
200
201
  };
201
- class F extends EventTarget {
202
+ class X extends EventTarget {
202
203
  constructor() {
203
204
  super(...arguments), this.controller = new AbortController();
204
205
  }
205
- on(t, e) {
206
+ on(t, n) {
206
207
  return this.addEventListener(
207
208
  t,
208
- (i) => e(i.detail),
209
+ (i) => n(i.detail),
209
210
  { signal: this.controller.signal }
210
211
  ), this;
211
212
  }
212
- once(t, e) {
213
+ once(t, n) {
213
214
  return this.addEventListener(
214
215
  t,
215
- (i) => e(i.detail),
216
+ (i) => n(i.detail),
216
217
  {
217
218
  signal: this.controller.signal,
218
219
  once: !0
219
220
  }
220
221
  ), this;
221
222
  }
222
- emit(t, e) {
223
- return this.dispatchEvent(new CustomEvent(t, { detail: e }));
223
+ emit(t, n) {
224
+ return this.dispatchEvent(new CustomEvent(t, { detail: n }));
224
225
  }
225
226
  removeAllListeners() {
226
227
  this.controller.abort(), this.controller = new AbortController();
227
228
  }
228
229
  }
229
- const y = new F(), z = k()(U((n, t) => ({
230
+ const h = new X(), I = J()(B((e, t) => ({
230
231
  loadingCount: 0,
231
232
  overrideState: null,
232
233
  localCounters: {},
@@ -237,58 +238,58 @@ const y = new F(), z = k()(U((n, t) => ({
237
238
  isGlobalLoading() {
238
239
  return t().isLoading();
239
240
  },
240
- startLoading: (e) => {
241
+ startLoading: (n) => {
241
242
  const i = t().isLoading();
242
- n((c) => ({ loadingCount: c.loadingCount + 1 })), e && n((c) => ({
243
+ e((s) => ({ loadingCount: s.loadingCount + 1 })), n && e((s) => ({
243
244
  localCounters: {
244
- ...c.localCounters,
245
- [e]: (c.localCounters[e] ?? 0) + 1
245
+ ...s.localCounters,
246
+ [n]: (s.localCounters[n] ?? 0) + 1
246
247
  }
247
248
  }));
248
249
  const o = t().isLoading();
249
- o && !i && y.emit("start", null), y.emit("change", { isLoading: o, isOverrideState: t().overrideState !== null });
250
+ o && !i && h.emit("start", null), h.emit("change", { isLoading: o, isOverrideState: t().overrideState !== null });
250
251
  },
251
- stopLoading: (e) => {
252
- const i = t().isLoading(), o = e ? t().localCounters[e] ?? 0 : 0;
253
- e && o > 0 && n((S) => ({
254
- loadingCount: Math.max(0, S.loadingCount - 1),
252
+ stopLoading: (n) => {
253
+ const i = t().isLoading(), o = n ? t().localCounters[n] ?? 0 : 0;
254
+ n && o > 0 && e((g) => ({
255
+ loadingCount: Math.max(0, g.loadingCount - 1),
255
256
  localCounters: {
256
- ...S.localCounters,
257
- [e]: Math.max(0, S.localCounters[e] - 1)
257
+ ...g.localCounters,
258
+ [n]: Math.max(0, g.localCounters[n] - 1)
258
259
  }
259
260
  }));
260
- const c = t().isLoading();
261
- !c && i && y.emit("stop", null), y.emit("change", { isLoading: c, isOverrideState: t().overrideState !== null });
261
+ const s = t().isLoading();
262
+ !s && i && h.emit("stop", null), h.emit("change", { isLoading: s, isOverrideState: t().overrideState !== null });
262
263
  },
263
- overrideLoading: (e) => {
264
+ overrideLoading: (n) => {
264
265
  const i = t().isLoading();
265
- n({ overrideState: e });
266
+ e({ overrideState: n });
266
267
  const o = t().isLoading();
267
- o && !i ? y.emit("start", null) : !o && i && y.emit("stop", null), y.emit("change", { isLoading: o, isOverrideState: e !== null });
268
+ o && !i ? h.emit("start", null) : !o && i && h.emit("stop", null), h.emit("change", { isLoading: o, isOverrideState: n !== null });
268
269
  },
269
- getLocalCounter: (e) => t().localCounters[e] ?? 0,
270
- isLocalLoading: (e) => (t().localCounters[e] ?? 0) > 0
270
+ getLocalCounter: (n) => t().localCounters[n] ?? 0,
271
+ isLocalLoading: (n) => (t().localCounters[n] ?? 0) > 0
271
272
  }
272
273
  })));
273
- function B() {
274
- const n = x(), { actions: t } = z((c) => c), e = () => {
275
- t.startLoading(n);
274
+ function H() {
275
+ const e = N(), { actions: t } = I((s) => s), n = () => {
276
+ t.startLoading(e);
276
277
  }, i = () => {
277
- t.isLocalLoading(n) && t.stopLoading(n);
278
- }, o = async (c) => {
279
- e();
278
+ t.isLocalLoading(e) && t.stopLoading(e);
279
+ }, o = async (s) => {
280
+ n();
280
281
  try {
281
- return await c;
282
+ return await s;
282
283
  } finally {
283
284
  i();
284
285
  }
285
286
  };
286
287
  return {
287
288
  overrideLoading: t.overrideLoading,
288
- startLoading: e,
289
+ startLoading: n,
289
290
  stopLoading: i,
290
291
  get isLocalLoading() {
291
- return t.isLocalLoading(n);
292
+ return t.isLocalLoading(e);
292
293
  },
293
294
  asyncUseLoading: o,
294
295
  get isLoading() {
@@ -296,24 +297,119 @@ function B() {
296
297
  }
297
298
  };
298
299
  }
299
- const X = {
300
+ function nt() {
301
+ const e = j(), { actions: t } = I((s) => s), n = () => {
302
+ t.startLoading(e);
303
+ }, i = () => {
304
+ t.isLocalLoading(e) && t.stopLoading(e);
305
+ }, o = async (s) => {
306
+ n();
307
+ try {
308
+ return await s;
309
+ } finally {
310
+ i();
311
+ }
312
+ };
313
+ return {
314
+ overrideLoading: t.overrideLoading,
315
+ startLoading: n,
316
+ stopLoading: i,
317
+ get isLocalLoading() {
318
+ return t.isLocalLoading(e);
319
+ },
320
+ asyncUseLoading: o,
321
+ get isLoading() {
322
+ return t.isGlobalLoading();
323
+ }
324
+ };
325
+ }
326
+ const y = {
300
327
  Spin: "spin",
301
328
  FadeInOut: "fadeInOut",
302
329
  None: "none"
303
- }, $ = (n) => /* @__PURE__ */ T("div", { id: "loading-circle", style: { width: "90px", height: "90px", border: "15px solid #f3f3f3", borderTop: "15px solid #009b4bff", borderRadius: "50%", boxSizing: "border-box" }, ...n }), H = (n) => /* @__PURE__ */ T("div", { style: { padding: "20px", fontSize: "25px", color: "#333", fontFamily: "system-ui, sans-serif" }, ...n, children: "Please wait..." });
304
- function K({ isLoading: n = !1 }) {
305
- const { startLoading: t, stopLoading: e } = B();
306
- return R(() => (n ? t() : e(), () => {
307
- n && e();
308
- }), [n]), null;
330
+ }, K = ({ scale: e = 1, animationType: t = y.Spin, animationDuration: n, children: i, style: o, className: s, id: g, prefix: a }) => {
331
+ const v = t, f = t === y.Spin ? 1 : t === y.FadeInOut ? 2 : 0, r = n || f, c = t === y.Spin ? "linear" : t === y.FadeInOut ? "ease-in-out" : "linear", p = t === y.None ? "none" : `${a}-${v} ${r}s ${c} infinite`;
332
+ return /* @__PURE__ */ C("div", { style: { animation: p, ...e !== 1 ? { zoom: e } : {}, ...o }, className: s, id: g, children: i });
333
+ }, q = (e) => /* @__PURE__ */ C("div", { id: "loading-circle", style: { width: "90px", height: "90px", border: "15px solid #f3f3f3", borderTop: "15px solid #009b4bff", borderRadius: "50%", boxSizing: "border-box" }, ...e }), Q = (e) => /* @__PURE__ */ C("div", { style: { padding: "20px", fontSize: "25px", color: "#333", fontFamily: "system-ui, sans-serif" }, ...e, children: "Please wait..." });
334
+ function ot({
335
+ loadingComponent: e,
336
+ loadingComponentScale: t = 1,
337
+ animationType: n = y.Spin,
338
+ animationDuration: i,
339
+ wrapperStyle: o,
340
+ wrapperClassName: s,
341
+ wrapperId: g,
342
+ animationWrapperStyle: a,
343
+ animationWrapperClassName: v,
344
+ animationWrapperId: f
345
+ }) {
346
+ e = e || (n === y.Spin ? q : Q);
347
+ const r = x(Math.random().toString(36).substring(2, 6).replace(/[0-9]/g, "")), { loadingCount: c, overrideState: p } = I((S) => S), u = p ?? c > 0, m = x(null);
348
+ A(() => {
349
+ u ? (m.current?.showModal(), document.body.setAttribute("inert", "")) : (m.current?.close(), document.body.removeAttribute("inert"));
350
+ }, [u]);
351
+ const d = g || "loading-wrapper-" + r.current;
352
+ return u ? M(
353
+ /* @__PURE__ */ D(F, { children: [
354
+ /* @__PURE__ */ C("style", { children: `
355
+ dialog#${d}[open] {
356
+ display: flex !important;
357
+ justify-content: center;
358
+ align-items: center;
359
+ width: 100vw;
360
+ height: 100vh;
361
+ max-width: 100%;
362
+ max-height: 100%;
363
+ }
364
+ @keyframes ${r.current}-spin {
365
+ 0% { transform: rotate(0deg); }
366
+ 100% { transform: rotate(360deg); }
367
+ }
368
+ @keyframes ${r.current}-fadeInOut {
369
+ 0%, 100% { opacity: 0.2; }
370
+ 50% { opacity: 1; }
371
+ }
372
+ body:has(dialog#${d}[open]) {
373
+ overflow: hidden;
374
+ }
375
+ body {
376
+ scrollbar-gutter: stable;
377
+ }
378
+ ` }),
379
+ /* @__PURE__ */ C(
380
+ "dialog",
381
+ {
382
+ ref: m,
383
+ style: {
384
+ border: "none",
385
+ padding: 0,
386
+ backgroundColor: "rgba(0, 0, 0, 0.5)",
387
+ backdropFilter: "blur(2px)",
388
+ ...o
389
+ },
390
+ className: s,
391
+ id: d,
392
+ children: /* @__PURE__ */ C(K, { scale: t, animationType: n, animationDuration: i, style: a, className: v, id: f, prefix: r.current, children: b.isValidElement(e) ? e : b.createElement(e) })
393
+ }
394
+ )
395
+ ] }),
396
+ document.body
397
+ ) : null;
398
+ }
399
+ function it({ isLoading: e = !1 }) {
400
+ const { startLoading: t, stopLoading: n } = H();
401
+ return A(() => (e ? t() : n(), () => {
402
+ e && n();
403
+ }), [e]), null;
309
404
  }
310
405
  export {
311
- X as AnimationType,
312
- F as EventEmitter,
313
- K as Loading,
314
- $ as LoadingCircle,
315
- H as LoadingPleaseWait,
316
- y as loadingEventTarget,
317
- B as ssrLoading,
318
- B as useLoading
406
+ y as AnimationType,
407
+ X as EventEmitter,
408
+ it as Loading,
409
+ q as LoadingCircle,
410
+ Q as LoadingPleaseWait,
411
+ ot as LoadingRenderer,
412
+ h as loadingEventTarget,
413
+ nt as ssrLoading,
414
+ H as useLoading
319
415
  };
@@ -0,0 +1,42 @@
1
+ import { default as EventEmitter } from '../utils/EventEmitter';
2
+ type LoadingEvents = {
3
+ change: {
4
+ isLoading: boolean;
5
+ isOverrideState: boolean;
6
+ } | null;
7
+ start: null;
8
+ stop: null;
9
+ };
10
+ export declare const loadingEventTarget: EventEmitter<LoadingEvents>;
11
+ interface Store {
12
+ loadingCount: number;
13
+ overrideState: boolean | null;
14
+ localCounters: Record<string, number>;
15
+ isLoading: () => boolean;
16
+ actions: {
17
+ isGlobalLoading: () => boolean;
18
+ startLoading: (instanceId?: string) => void;
19
+ stopLoading: (instanceId?: string) => void;
20
+ overrideLoading: (state: boolean | null) => void;
21
+ getLocalCounter: (instanceId: string) => number;
22
+ isLocalLoading: (instanceId: string) => boolean;
23
+ };
24
+ }
25
+ export declare const loadingStore: import('zustand').UseBoundStore<Omit<import('zustand').StoreApi<Store>, "setState" | "devtools"> & {
26
+ setState(partial: Store | Partial<Store> | ((state: Store) => Store | Partial<Store>), replace?: false | undefined, action?: (string | {
27
+ [x: string]: unknown;
28
+ [x: number]: unknown;
29
+ [x: symbol]: unknown;
30
+ type: string;
31
+ }) | undefined): void;
32
+ setState(state: Store | ((state: Store) => Store), replace: true, action?: (string | {
33
+ [x: string]: unknown;
34
+ [x: number]: unknown;
35
+ [x: symbol]: unknown;
36
+ type: string;
37
+ }) | undefined): void;
38
+ devtools: {
39
+ cleanup: () => void;
40
+ };
41
+ }>;
42
+ export {};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@rokku-x/react-hook-loading-spinner",
3
- "version": "0.1.1",
3
+ "version": "0.2.0",
4
4
  "description": "A lightweight and flexible React loading state hook library with built-in spinner components, global state management, and zero dependencies (except React and Zustand).",
5
5
  "main": "dist/index.cjs.js",
6
6
  "module": "dist/index.esm.js",
@@ -78,4 +78,4 @@
78
78
  "dependencies": {
79
79
  "zustand": "^5.0.10"
80
80
  }
81
- }
81
+ }
@@ -1,19 +0,0 @@
1
- import { default as EventEmitter } from './utils/EventEmitter';
2
- type LoadingEvents = {
3
- change: {
4
- isLoading: boolean;
5
- isOverrideState: boolean;
6
- } | null;
7
- start: null;
8
- stop: null;
9
- };
10
- export declare const loadingEventTarget: EventEmitter<LoadingEvents>;
11
- export default function (): {
12
- overrideLoading: (state: boolean | null) => void;
13
- startLoading: () => void;
14
- stopLoading: () => void;
15
- readonly isLocalLoading: boolean;
16
- asyncUseLoading: <R, _ extends any[]>(asyncFunction: Promise<R>) => Promise<R>;
17
- readonly isLoading: boolean;
18
- };
19
- export {};