52 lines
1.5 KiB
TypeScript
52 lines
1.5 KiB
TypeScript
import { useEffect, useMemo } from 'react'
|
|
import { Account, Connection } from '@solana/web3.js'
|
|
import { IDS } from '@blockworks-foundation/mango-client'
|
|
import useMangoStore from '../stores/useMangoStore'
|
|
|
|
const useConnection = () => {
|
|
const setMangoStore = useMangoStore((s) => s.set)
|
|
const {
|
|
cluster,
|
|
current: connection,
|
|
endpoint,
|
|
} = useMangoStore((s) => s.connection)
|
|
|
|
const sendConnection = useMemo(
|
|
() => new Connection(endpoint, 'recent'),
|
|
[endpoint]
|
|
)
|
|
|
|
useEffect(() => {
|
|
if (connection && endpoint === connection['_rpcEndpoint']) return
|
|
console.log('setting new connection')
|
|
|
|
const newConnection = new Connection(endpoint, 'recent')
|
|
setMangoStore((state) => {
|
|
state.connection.current = newConnection
|
|
})
|
|
}, [endpoint])
|
|
|
|
useEffect(() => {
|
|
if (connection && endpoint === connection['_rpcEndpoint']) return
|
|
const id = connection.onAccountChange(new Account().publicKey, () => {})
|
|
return () => {
|
|
connection.removeAccountChangeListener(id)
|
|
}
|
|
}, [endpoint])
|
|
|
|
useEffect(() => {
|
|
if (connection && endpoint === connection['_rpcEndpoint']) return
|
|
const id = connection.onSlotChange(() => null)
|
|
return () => {
|
|
connection.removeSlotChangeListener(id)
|
|
}
|
|
}, [endpoint])
|
|
|
|
const programId = useMemo(() => IDS[cluster].mango_program_id, [cluster])
|
|
const dexProgramId = useMemo(() => IDS[cluster]?.dex_program_id, [cluster])
|
|
|
|
return { connection, dexProgramId, cluster, programId, sendConnection }
|
|
}
|
|
|
|
export default useConnection
|