webscopeio / react-health-check

Lightweight React hook for checking health of API services.

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

React Health Check πŸ₯

Lightweight React hook for checking health of API services.

stable tslib checks license


Installation πŸ§‘β€πŸ”§

npm i @webscopeio/react-health-check

or

yarn add @webscopeio/react-health-check

Examples 😲

Usage ❓

const { available, refresh } = useHealthCheck({
  service: {
    name: 'auth',
    url: 'https://example.com/auth/health',
  },
  onSuccess: ({ service, timestamp }) => {
    console.log(`Service "${service.name}" is available since "${timestamp}" πŸŽ‰`);
  },
  onError: ({ service, timestamp }) => {
    console.log(`Service "${service.name}" is not available since "${timestamp}" πŸ˜”`);
  },
});

You can also create a global configuration so you don't have to define services and callbacks every time:

// App wrapper
<HealthCheckConfig
  value={{
    services: [
      {
        name: 'auth',
        url: 'https://example.com/auth/health',
      },
      {
        name: 'payment',
        url: 'https://example.com/payment/health',
      },
    ],
    onSuccess: ({ service, timestamp }) => {
      console.log(`Service "${service.name}" is available since "${timestamp}" πŸŽ‰`);
    },
    onError: ({ service, timestamp }) => {
      console.log(`Service "${service.name}" is not available since "${timestamp}" πŸ˜”`);
    },
  }}
>
  <App />
</HealthCheckConfig>;

// Later in some child component
const { available } = useHealthCheck('auth');

Configuration πŸ› 

useHealthCheck() hook accepts a configuration object with keys:

Key Type Description
service Service<S = string> Object defining an API service to be checked.
onSuccess (state: ServiceState<S>) => void; Callback which should be called when API service becomes available again.
onError (state: ServiceState<S>) => void; Callback which should be called when API service becomes unavailable.
refreshInterval number Polling interval for health checks in milliseconds.
Default value: 5000
refreshWhileHidden boolean Determines whether polling should be paused while browser window isn't visible.
Default value: false

Global configuration accepts the same keys as useHealthCheck() hook with the exception of "service". You need to specify array of "services" when using global configuration.

License πŸ’Ό

MIT | Developed by Webscope.io

About

Lightweight React hook for checking health of API services.

License:MIT License


Languages

Language:TypeScript 92.1%Language:JavaScript 7.9%