Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/oieduardorabelo/use-navigator-online

⚛️ React Hooks to detect when your browser is online/offline.
https://github.com/oieduardorabelo/use-navigator-online

browser navigator-online offline online react react-hooks reactjs

Last synced: 10 days ago
JSON representation

⚛️ React Hooks to detect when your browser is online/offline.

Awesome Lists containing this project

README

        

# @oieduardorabelo/use-navigator-online

React Hooks to detect when your browser is online/offline using [`window.navigator.onLine` API](https://developer.mozilla.org/en-US/docs/Web/API/NavigatorOnLine).

To install it:

```
yarn add @oieduardorabelo/use-navigator-online
```

## Example

An online demo is available at CodeSandbox:

- **Live demo:** https://codesandbox.io/s/live-demo-use-navigator-online-1xy56

If you've any issues, **open an issue with a CodeSandbox link** with your issue

## API Explained

In your app, you can add:

```javascript
import { useNavigatorOnline } from '@oieduardorabelo/use-navigator-online';

function App() {
let details = useNavigatorOnline(options)
...
}
```

### `details` object is composed of:

- `details.isOnline`: It is a `Boolean` value, `true` when online
- `details.isOffline`: It is a `Boolean` value, `true` when offline
- `details.status`: Returns a default `String`, when online it is `"online"` and when offline it is `"offline"`. You can customize it using `options` param

### `options` object is composed of:

- `options.whenOnline`: Can be any valid React children. It will replace the `String` returned in `details.status` when online.
- `options.whenOffline`: Can be any valid React children. It will replace the `String` returned in `details.status` when offline.
- `options.startOnline`: To support SSR, you can control the initial rendering mode using this option. It is a boolean value to determine which state your application should use first: `true` for "online-first" or `false` for "offline-first". Defaults to `true`/online-first. The value will be synced with `window.navigator.onLine` inside an `useEffect` when your application is rendered in the browser.

## Examples

Using `isOnline` and `isOffline` flags:

```javascript
import { useNavigatorOnline } from '@oieduardorabelo/use-navigator-online';

function App() {
let { isOnline, isOffline } = useNavigatorOnline();

return (


{isOnline && We are online!}
{isOffline && We are offline!}

);
}
```

Using default `status`:

```javascript
import { useNavigatorOnline } from '@oieduardorabelo/use-navigator-online';

function App() {
// will toggle between "online" and "offline"
let { status } = useNavigatorOnline();

return

Browser now is {status}!
;
}
```

Custom values for `status` with `whenOnline` and `whenOffline`:

```javascript
import { useNavigatorOnline } from '@oieduardorabelo/use-navigator-online';

function App() {
// you can pass any React children in "whenOnline" and "whenOffline"
let { status } = useNavigatorOnline({
whenOnline:

WE ARE ONLINE!

,
whenOffline:

Damn, offline :(

,
});

return

{status}
;
}
```

No extra configuration is needed to use it on SSR:

```javascript
import { useNavigatorOnline } from '@oieduardorabelo/use-navigator-online';

function App() {
let { status } = useNavigatorOnline();

return

{status}
;
}
```

You can initialize your application offline-first. This **will sync** with `window.navigator.onLine` when your application starts, using a `useEffect`. Trigerring a re-render of your application.

```javascript
import { useNavigatorOnline } from '@oieduardorabelo/use-navigator-online';

function App() {
let { status } = useNavigatorOnline({
startOnline: false
});

return

{status}
;
}
```

### License

[MIT License](https://oss.ninja/mit/oieduardorabelo/) © [Eduardo Rabelo](https://eduardorabelo.me)