Provides links&functions based on @capacitor/network
.
The NetworkStatus
link serves as a container for link structure representing network status inside deep.
You need only one container link per deep instance.
- Install this package in your deep by using npm-packager
- Provide permissions to this package
- Import the library into your TypeScript project:
import Network from "@deep-foundation/capacitor-network";
- Create container link of type
NetworkStatus
to store Network state:
const containerLinkId = await Network.createContainer(deep:DeepClient)
You can also create it manually inside your deepcase client. Open Insert menu, search for and then insert "NetworkStatus" type link.
- Save&Upload network status:
Call saveNetworkStatus function and pass an empty array as connectionStatuses to automatically get current network state and upload data as links to your deep instance.
await Network.saveNetworkStatus({ deep, containerLinkId, connectionStatuses: [] })
- Get current status of the network as
NetworkStatusType
from your deep instance:
Call getCurrentStatus function and pass your deep instance with container link ID.
await Network.getCurrentStatus({ deep, containerLinkId })
- Import NetworkStatus react component or hooks:
import { WithNetworkStatus, NetworkStatus, useNetworkStatus, useCurrentStatus, useContainer } from "@deep-foundation/capacitor-network";
- Create NetworkStatus component instance inside your deep app and pass a DeepClient instance.
function Page() {
return <NetworkStatus deep={useDeep()} />
}
You will see basic ui with all package functionality.
Or use WithNetworkStatus Component like that:
<WithNetworkStatus deep={yourDeepInstance} containerLinkId={yourContainerLinkId}>
<NetworkStatus />
</WithNetworkStatus>
- Custom hooks can be used anywhere in your deep app:
useNetworkStatus() hook for managing network event listeners from @capacitor/network
and store event data when device is offline.
const { connectionStatuses, subscribeToNetworkStatusChanges } = useNetworkStatus({ deep, containerLinkId });
useCurrentStatus() hook to get current status of the network from your deep instance and handler function to refetch current state when needed.
const { currentStatus, loadCurrentStatus } = useCurrentStatus({ deep, containerLinkId });
useContainer() hook to get existing or create a new container link ID.
const containerLinkId = useContainer(deep);
Feel free to contribute. Please fork the repository and submit a pull request for any bugs, improvements, or features.