mango-v4-ui/components/settings/RpcSettings.tsx

205 lines
6.5 KiB
TypeScript
Raw Normal View History

2022-12-15 04:28:17 -08:00
import ButtonGroup from '@components/forms/ButtonGroup'
import Input from '@components/forms/Input'
import Button from '@components/shared/Button'
import Switch from '@components/forms/Switch'
2023-01-19 12:31:45 -08:00
import { useWallet } from '@solana/wallet-adapter-react'
2022-12-15 18:19:11 -08:00
import mangoStore from '@store/mangoStore'
2022-12-15 04:28:17 -08:00
import useLocalStorageState from 'hooks/useLocalStorageState'
import { useTranslation } from 'next-i18next'
2023-01-19 12:31:45 -08:00
import { ChangeEvent, useCallback, useEffect, useMemo, useState } from 'react'
import {
PRIORITY_FEE_KEY,
RPC_PROVIDER_KEY,
USE_ORDERBOOK_FEED_KEY,
} from 'utils/constants'
import Tooltip from '@components/shared/Tooltip'
2022-12-15 04:28:17 -08:00
2023-07-16 20:41:13 -07:00
export const TRITON_DEDICATED_URL = process.env.NEXT_PUBLIC_TRITON_TOKEN
? `https://mango.rpcpool.com/${process.env.NEXT_PUBLIC_TRITON_TOKEN}`
: 'https://mango.rpcpool.com/946ef7337da3f5b8d3e4a34e7f88'
2022-12-15 04:28:17 -08:00
const RPC_URLS = [
2022-12-15 18:19:11 -08:00
{
2023-06-27 16:30:50 -07:00
label: 'Triton Shared',
2023-07-16 20:41:13 -07:00
value: process.env.NEXT_PUBLIC_ENDPOINT || TRITON_DEDICATED_URL,
2022-12-15 18:19:11 -08:00
},
2023-06-27 16:30:50 -07:00
{
label: 'Triton Dedicated',
2023-07-16 20:41:13 -07:00
value: TRITON_DEDICATED_URL,
2023-06-27 16:30:50 -07:00
},
2022-12-27 13:35:26 -08:00
// {
// label: 'Genesys Go',
// value: 'https://mango.genesysgo.net',
// },
2022-12-15 04:28:17 -08:00
{ label: 'Custom', value: '' },
]
2023-08-29 12:34:40 -07:00
export const PRIORITY_FEE_LEVELS = [
2023-01-19 12:31:45 -08:00
{ label: 'None', value: 0 },
2023-08-29 12:34:40 -07:00
{ label: 'Low', value: 1.2 }, // +20%
{ label: 'High', value: 2 }, // +100%
2023-01-19 12:31:45 -08:00
]
2023-08-29 12:34:40 -07:00
export const DEFAULT_PRIORITY_FEE = 1
export const DEFAULT_PRIORITY_FEE_LEVEL = PRIORITY_FEE_LEVELS[1]
2023-02-03 13:23:36 -08:00
2022-12-15 04:28:17 -08:00
const RpcSettings = () => {
const { t } = useTranslation('settings')
2023-01-03 14:20:00 -08:00
const actions = mangoStore.getState().actions
2023-01-19 12:31:45 -08:00
const { wallet } = useWallet()
2022-12-15 04:28:17 -08:00
const [customUrl, setCustomUrl] = useState('')
const [showCustomForm, setShowCustomForm] = useState(false)
const [rpcEndpointProvider, setRpcEndpointProvider] = useLocalStorageState(
RPC_PROVIDER_KEY,
2023-07-21 11:47:53 -07:00
RPC_URLS[0].value,
2022-12-15 04:28:17 -08:00
)
2023-08-29 12:34:40 -07:00
const [storedPriorityFeeLevel, setStoredPriorityFeeLevel] =
useLocalStorageState(PRIORITY_FEE_KEY, DEFAULT_PRIORITY_FEE_LEVEL)
const [storedUseOrderbookFeed, setStoredUseOrderbookFeed] =
useLocalStorageState(USE_ORDERBOOK_FEED_KEY, true)
2022-12-27 13:34:05 -08:00
const rpcEndpoint = useMemo(() => {
return (
RPC_URLS.find((node) => node.value === rpcEndpointProvider) || {
label: 'Custom',
value: rpcEndpointProvider,
}
)
}, [rpcEndpointProvider])
2022-12-15 04:28:17 -08:00
2023-01-19 12:31:45 -08:00
const priorityFee = useMemo(() => {
return (
2023-08-29 12:34:40 -07:00
PRIORITY_FEE_LEVELS.find(
(node) => node.value === storedPriorityFeeLevel,
) || DEFAULT_PRIORITY_FEE_LEVEL
2023-01-19 12:31:45 -08:00
)
2023-08-29 12:34:40 -07:00
}, [storedPriorityFeeLevel])
2023-01-19 12:31:45 -08:00
2022-12-15 04:28:17 -08:00
const handleSetEndpointProvider = (provider: string) => {
2022-12-27 13:34:05 -08:00
const endpointProvider = RPC_URLS.find(
2023-07-21 11:47:53 -07:00
(node) => node.label === provider,
2022-12-27 13:34:05 -08:00
) || { label: 'Custom', value: rpcEndpointProvider }
2022-12-27 13:13:15 -08:00
setRpcEndpointProvider(endpointProvider.value)
2022-12-15 04:28:17 -08:00
if (provider !== 'Custom') {
setShowCustomForm(false)
2022-12-27 13:13:15 -08:00
actions.updateConnection(endpointProvider.value)
2022-12-15 04:28:17 -08:00
}
}
2023-01-19 12:31:45 -08:00
const handlePriorityFee = useCallback(
(label: string) => {
2023-08-29 12:34:40 -07:00
const fee = PRIORITY_FEE_LEVELS.find((fee) => fee.label === label)
if (fee) {
2023-08-29 12:34:40 -07:00
setStoredPriorityFeeLevel(fee?.value)
if (wallet) {
actions.connectMangoClientWithWallet(wallet)
}
2023-01-19 12:31:45 -08:00
}
},
2023-08-29 12:34:40 -07:00
[setStoredPriorityFeeLevel, actions, wallet],
2023-01-19 12:31:45 -08:00
)
2022-12-15 04:28:17 -08:00
useEffect(() => {
2022-12-27 13:34:05 -08:00
if (rpcEndpoint.label === 'Custom') {
2022-12-15 04:28:17 -08:00
setShowCustomForm(true)
2022-12-27 13:34:05 -08:00
setCustomUrl(rpcEndpoint.value)
2022-12-15 04:28:17 -08:00
}
2022-12-27 13:34:05 -08:00
}, [rpcEndpoint])
2022-12-15 04:28:17 -08:00
const handleSaveCustomEndpoint = () => {
if (!customUrl) return
2022-12-27 13:34:05 -08:00
setRpcEndpointProvider(customUrl)
2022-12-15 18:19:11 -08:00
actions.updateConnection(customUrl)
2022-12-15 04:28:17 -08:00
}
return (
<div className="border-b border-th-bkg-3">
2022-12-15 04:28:17 -08:00
<div className="flex flex-col border-t border-th-bkg-3 py-4 md:flex-row md:items-center md:justify-between md:px-4">
<p className="mb-2 md:mb-0">{t('rpc-provider')}</p>
2023-07-02 18:57:20 -07:00
<div className="w-full min-w-[400px] md:w-auto">
2022-12-15 04:28:17 -08:00
<ButtonGroup
2022-12-27 13:13:15 -08:00
activeValue={rpcEndpoint.label}
2022-12-15 04:28:17 -08:00
onChange={(v) => handleSetEndpointProvider(v)}
values={RPC_URLS.map((val) => val.label)}
/>
{showCustomForm ? (
<div className="mt-2">
<div className="flex space-x-2">
<Input
type="text"
name="url"
id="url"
2022-12-27 13:13:15 -08:00
className="!h-10"
2022-12-15 04:28:17 -08:00
placeholder={t('rpc-url')}
value={customUrl}
onChange={(e: ChangeEvent<HTMLInputElement>) =>
setCustomUrl(e.target.value)
}
/>
<Button
disabled={!customUrl}
onClick={handleSaveCustomEndpoint}
>
{t('save')}
</Button>
</div>
</div>
) : null}
</div>
</div>
2023-01-19 12:31:45 -08:00
<div className="flex flex-col border-t border-th-bkg-3 py-4 md:flex-row md:items-center md:justify-between md:px-4">
<p className="mb-2 md:mb-0">Priority Fee</p>
<div className="w-full min-w-[220px] md:w-auto md:pl-4">
2023-01-19 12:31:45 -08:00
<ButtonGroup
activeValue={priorityFee.label}
onChange={(v) => handlePriorityFee(v)}
2023-08-29 12:34:40 -07:00
values={PRIORITY_FEE_LEVELS.map((val) => val.label)}
2023-01-19 12:31:45 -08:00
/>
{/* {showCustomForm ? (
<div className="mt-2">
<div className="flex space-x-2">
<Input
type="text"
name="url"
id="url"
className="!h-10"
placeholder={t('rpc-url')}
value={customUrl}
onChange={(e: ChangeEvent<HTMLInputElement>) =>
setCustomUrl(e.target.value)
}
/>
<Button
className="h-12"
disabled={!customUrl}
onClick={handleSaveCustomEndpoint}
>
{t('save')}
</Button>
</div>
</div>
) : null} */}
</div>
</div>
<div className="flex items-center justify-between border-t border-th-bkg-3 p-4">
<Tooltip
content={t('settings:tooltip-orderbook-bandwidth-saving')}
maxWidth="25rem"
placement="top-start"
delay={100}
>
<p className="tooltip-underline">
{t('settings:orderbook-bandwidth-saving')}
</p>
</Tooltip>
<Switch
checked={storedUseOrderbookFeed}
onChange={() => setStoredUseOrderbookFeed(!storedUseOrderbookFeed)}
/>
</div>
</div>
2022-12-15 04:28:17 -08:00
)
}
export default RpcSettings