oceanprotocol/react

View on GitHub
example/src/NetworkMonitor.tsx

Summary

Maintainability
A
0 mins
Test Coverage
import React, { useCallback } from 'react'
import { useOcean } from '@oceanprotocol/react'
import { ConfigHelper } from '@oceanprotocol/lib'
import { useEffect } from 'react'

export const NetworkMonitor = () => {
  const { connect, web3Provider } = useOcean()

  const handleNetworkChanged = useCallback(
    (chainId: number) => {
      const config = new ConfigHelper().getConfig(chainId)
      connect(config)
    },
    [connect]
  )

  useEffect(() => {
    if (!web3Provider) return

    web3Provider.on('chainChanged', handleNetworkChanged)

    return () => {
      web3Provider.removeListener('chainChanged', handleNetworkChanged)
    }
  }, [web3Provider, handleNetworkChanged])

  return <></>
}