Skip to content

React Context library for controlling multiple busy indicators in an application

License

Notifications You must be signed in to change notification settings

RavenHursT/react-multi-busy

Repository files navigation

react-multi-busy

React Context library for controlling multiple busy states (spinners, progress bars, etc.) in an application

NPM JavaScript Style Guide

Examples

Install

npm install --save react-multi-busy

Usage

Wrap your component tree w/ the MultiBusyProvider:

import ReactDOM from 'react-dom'
import { MultiBusyProvider } from 'react-multi-busy'
ReactDOM.render(
  <CssBaseline>
    <MultiBusyProvider>
      <App />
    </MultiBusyProvider>
  </CssBaseline>,
  document.getElementById('root')
)

Implement the useMultiBusy custom hook in any component that you want to control the busy state for:

import { useMultiBusy } from 'react-multi-busy'

export const SomeComponent = () => {
  const {isBusy, startBusy, endBusy} = useMultiBusy()
  const busy = isBusy()
  return <Button {...{
    color: 'primary',
    variant: 'contained',
    onClick: goFetchSomething(startBusy, endBusy)
  }} >
    <span>{
      `${ busy ? 'I\'m busy' : 'Click Me' }`
    }</span>
    { busy && <CircularProgress {...{
      size: '1em',
    }} /> }
  </Button>
}

Finally, make startBusy() and endBusy() methods available to whatever it is that you want to use to control the state of:

// This could easily be a redux-thunk
const goFetchSomething = (startBusy, endBusy) => async () => {
  startBusy()
  const result = await someService()
  endBusy()
  return result
}

License

MIT © RavenHursT

About

React Context library for controlling multiple busy indicators in an application

Resources

License

Stars

Watchers

Forks

Packages

No packages published