Skip to content

Latest commit

 

History

History
93 lines (76 loc) · 2.04 KB

README.md

File metadata and controls

93 lines (76 loc) · 2.04 KB

react-camouflage

react-camouflage components help to change view as per various status

Usage

FetchView

Get rid of the below lengthy conditions for your API (service) status.

if (!status) {
  return <div>Partial Loader goes here</div>
} else if (status === 'loading') {
  return <div>Spinner goes here</div>
} else if (status === 'success') {
  return <div>Service Data List here</div>
} else {
   return (
     <span>Error Occurred: Please click to try again.</div>
   );
}

Example for FetchView with status Props.

const status = 'success';
/**
 * `FetchView.Initial` will render when status is undefined or null.
 * `FetchView.Fetching` will render when status is 'loading`.
 * `FetchView.Fetched` will render when status is 'success`.
 * `FetchView.Error` will render when status is 'error`.
 */

<FetchView status={status}>
  <FetchView.Initial>
    <div>Partial Loader goes here</div>
  </FetchView.Initial>
  <FetchView.Fetching>
    <div>Spinner goes here</div>
  </FetchView.Fetching>
  <FetchView.Fetched>
    <div>Service Data List here</div>
  </FetchView.Fetched>
  <FetchView.Error>
    <span>Error Occurred: Please click to try again.</div>
  </FetchView.Error>
</FetchView>

Example for FetchView with status Props.

const statusMapping = {
  [Statuses.Success]: (status === 'success'),
  [Statuses.Error]: (status === 'error'),
  [Statuses.Loading]: (status === 'loading'),
}

<FetchView statusMapping={statusMapping}>
  <FetchView.Initial>
    <div>Partial Loader goes here</div>
  </FetchView.Initial>
  <FetchView.Fetching>
    <div>Spinner goes here</div>
  </FetchView.Fetching>
  <FetchView.Fetched>
    <div>Service Data List here</div>
  </FetchView.Fetched>
  <FetchView.Error>
    <span>Error Occurred: Please click to try again.</div>
  </FetchView.Error>
</FetchView>
Using NPM:
$ npm install react-camouflage --save
Using yarn
$ yarn add react-camouflage

Demo

Code Sandbox Working Demo

License

MIT