- This is a React Js library that provides network status (online/offline) with polling.
npm i react-network-status
or yarn add react-network-status
Hook that updates component with the network status offline/online state.
This gives user a flexibility to programmatically render UI components.
import { useNetworkStatus } from "react-network-status";
const App = () => {
const [networkStatus, setNetworkStatus] = useState(true);
const config = {
timeout: 5000,
interval: 1000,
};
useNetworkStatus((networkStatusUpdate) => {
setNetworkStatus(networkStatusUpdate);
}, config);
return <div>You are: {networkStatus ? "online" : "offline"}</div>;
};
NetworkDetector
- Component that can be used in State based Components.
It has no UI but just accepts config and onChange event.
import { NetworkDetector } from "react-network-status";
class App extends Component {
state = {
networkStatus: true,
};
config = {
timeout: 5000,
interval: 1000,
};
onNetworkStatusChange = (networkStatus: boolean) => {
this.setState({ networkStatus });
};
render() {
const { networkStatus } = this.state;
return (
<div>
You are: {networkStatus ? "online" : "offline"}
<NetworkDetector
config={this.config}
onChange={this.onNetworkStatusChange}
/>
</div>
);
}
}
<NetworkDetector/>
, and useNetworkStatus
accept the following props:
const config = {
url: // YOUR_POLLING URL,
interval: // YOUR POLLING INTERVAL,
timeout: // YOUR POLLING TIMEOUT
};
onChange: Event that provides status (true or false) as online value of the network.
Prop | Type | Description | Default |
---|---|---|---|
config |
Obj or Bool | Config for polling fallback [1] | [see below] |
config.enabled |
Boolean | Force polling on or off | Depends on the browser [1] |
config.url |
String | URL to pool for connection status | "https://ipv4.icanhazip.com" |
config.interval |
Number | How often (in ms) to poll | 5000 |
config.timeout |
Number | How long (in ms) before timeout | 5000 |
onChange |
Function | Called when connection changes | none |
[1] Polling is only used as a fallback for browsers that don't support the "online"
event. Currently these are Chrome on Windows, Firefox on Windows, and Chrome on Linux.
[2] <NetworkDetector/>
will not render children
.
- For web development and related services visit us at: https://developershive.com
- Mail us at: [email protected]
- Name: Tofiq Quadri
- Email: [email protected]
- This package is maintained by tofiqquadri.