Mp 3480 persist last trading pair (#578)
* MP-3480: remove favourite asset and prepare localStore * env: updated shuttle, keplr and version (#566) * fix: fixed dust left when trying to buy max amount without leverage (#565) * feat: added squidrouter to the bridges (#561) * feat: added squidrouter to the bridges * fix: copy update * MP-3521: updated the APR calculation (#572) * Table fixes (#563) * fix: fixed the sorting of the tables * fix: added sorting functions * fix: farm sorting for deposit cap * fix: fixed Row types * Build(deps-dev): bump prettier-plugin-tailwindcss from 0.5.5 to 0.5.6 (#567) Bumps [prettier-plugin-tailwindcss](https://github.com/tailwindlabs/prettier-plugin-tailwindcss) from 0.5.5 to 0.5.6. - [Release notes](https://github.com/tailwindlabs/prettier-plugin-tailwindcss/releases) - [Changelog](https://github.com/tailwindlabs/prettier-plugin-tailwindcss/blob/main/CHANGELOG.md) - [Commits](https://github.com/tailwindlabs/prettier-plugin-tailwindcss/compare/v0.5.5...v0.5.6) --- updated-dependencies: - dependency-name: prettier-plugin-tailwindcss dependency-type: direct:development update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> * Build(deps): bump react-router-dom from 6.16.0 to 6.17.0 (#571) Bumps [react-router-dom](https://github.com/remix-run/react-router/tree/HEAD/packages/react-router-dom) from 6.16.0 to 6.17.0. - [Release notes](https://github.com/remix-run/react-router/releases) - [Changelog](https://github.com/remix-run/react-router/blob/main/packages/react-router-dom/CHANGELOG.md) - [Commits](https://github.com/remix-run/react-router/commits/react-router-dom@6.17.0/packages/react-router-dom) --- updated-dependencies: - dependency-name: react-router-dom dependency-type: direct:production update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> * ✨ HLS: Add info modal (#573) * MP-3484: remember summaryAccount tabs and auto expand both (#574) * User feedback (#575) * feat: added debt indicator and adjusted the borrowModal * fix: wallet interaction fix * Add usdc noble (#576) * env: added USDC.n * env: updated usdc noble variables * fix: fixed the pool on USDC for devnet purposes * 🐛 Fix initial status of chart (#577) * MP-3480: persist trading pair * fix: updated according to feedback * fix: remove pair from Trading View header --------- Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Bob van der Helm <34470358+bobthebuidlr@users.noreply.github.com>
This commit is contained in:
parent
ae77e96df4
commit
abd36bc502
@ -1,5 +1,5 @@
|
|||||||
import classNames from 'classnames'
|
import classNames from 'classnames'
|
||||||
import React, { useCallback } from 'react'
|
import { useCallback } from 'react'
|
||||||
|
|
||||||
import ActionButton from 'components/Button/ActionButton'
|
import ActionButton from 'components/Button/ActionButton'
|
||||||
import { Enter } from 'components/Icons'
|
import { Enter } from 'components/Icons'
|
||||||
@ -31,7 +31,7 @@ export default function Deposit(props: Props) {
|
|||||||
openAlertDialog({
|
openAlertDialog({
|
||||||
title: 'Understanding HLS Positions',
|
title: 'Understanding HLS Positions',
|
||||||
content: (
|
content: (
|
||||||
<div className='flex flex-col gap-8 pb-8 pt-2 pr-10'>
|
<div className='flex flex-col gap-8 pt-2 pb-8 pr-10'>
|
||||||
{INFO_ITEMS.map((item) => (
|
{INFO_ITEMS.map((item) => (
|
||||||
<div key={item.title} className='grid grid-cols-[min-content,auto]'>
|
<div key={item.title} className='grid grid-cols-[min-content,auto]'>
|
||||||
<span
|
<span
|
||||||
@ -44,7 +44,7 @@ export default function Deposit(props: Props) {
|
|||||||
</span>
|
</span>
|
||||||
<span className='flex flex-col'>
|
<span className='flex flex-col'>
|
||||||
<Text>{item.title}</Text>
|
<Text>{item.title}</Text>
|
||||||
<Text className='text-white/60 text-sm'>{item.description}</Text>
|
<Text className='text-sm text-white/60'>{item.description}</Text>
|
||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
||||||
))}
|
))}
|
||||||
|
@ -18,7 +18,7 @@ import useAlertDialog from 'hooks/useAlertDialog'
|
|||||||
import useAutoLend from 'hooks/useAutoLend'
|
import useAutoLend from 'hooks/useAutoLend'
|
||||||
import useLocalStorage from 'hooks/useLocalStorage'
|
import useLocalStorage from 'hooks/useLocalStorage'
|
||||||
import useStore from 'store'
|
import useStore from 'store'
|
||||||
import { getDisplayCurrencies, getEnabledMarketAssets } from 'utils/assets'
|
import { getDisplayCurrencies } from 'utils/assets'
|
||||||
import { BN } from 'utils/helpers'
|
import { BN } from 'utils/helpers'
|
||||||
|
|
||||||
const slippages = [0.02, 0.03]
|
const slippages = [0.02, 0.03]
|
||||||
@ -27,7 +27,6 @@ export default function SettingsModal() {
|
|||||||
const modal = useStore((s) => s.settingsModal)
|
const modal = useStore((s) => s.settingsModal)
|
||||||
const { open: showResetDialog } = useAlertDialog()
|
const { open: showResetDialog } = useAlertDialog()
|
||||||
const displayCurrencies = getDisplayCurrencies()
|
const displayCurrencies = getDisplayCurrencies()
|
||||||
const assets = getEnabledMarketAssets()
|
|
||||||
const { setAutoLendOnAllAccounts } = useAutoLend()
|
const { setAutoLendOnAllAccounts } = useAutoLend()
|
||||||
const [customSlippage, setCustomSlippage] = useState<number>(0)
|
const [customSlippage, setCustomSlippage] = useState<number>(0)
|
||||||
const [inputRef, setInputRef] = useState<React.RefObject<HTMLInputElement>>()
|
const [inputRef, setInputRef] = useState<React.RefObject<HTMLInputElement>>()
|
||||||
@ -36,10 +35,6 @@ export default function SettingsModal() {
|
|||||||
LocalStorageKeys.DISPLAY_CURRENCY,
|
LocalStorageKeys.DISPLAY_CURRENCY,
|
||||||
DEFAULT_SETTINGS.displayCurrency,
|
DEFAULT_SETTINGS.displayCurrency,
|
||||||
)
|
)
|
||||||
const [preferredAsset, setPreferredAsset] = useLocalStorage<string>(
|
|
||||||
LocalStorageKeys.PREFERRED_ASSET,
|
|
||||||
DEFAULT_SETTINGS.preferredAsset,
|
|
||||||
)
|
|
||||||
const [reduceMotion, setReduceMotion] = useLocalStorage<boolean>(
|
const [reduceMotion, setReduceMotion] = useLocalStorage<boolean>(
|
||||||
LocalStorageKeys.REDUCE_MOTION,
|
LocalStorageKeys.REDUCE_MOTION,
|
||||||
DEFAULT_SETTINGS.reduceMotion,
|
DEFAULT_SETTINGS.reduceMotion,
|
||||||
@ -79,22 +74,6 @@ export default function SettingsModal() {
|
|||||||
[displayCurrencies],
|
[displayCurrencies],
|
||||||
)
|
)
|
||||||
|
|
||||||
const preferredAssetsOptions = useMemo(
|
|
||||||
() =>
|
|
||||||
assets.map((asset, index) => ({
|
|
||||||
label: [
|
|
||||||
<div className='flex w-full gap-2' key={index}>
|
|
||||||
<AssetImage asset={asset} size={16} />
|
|
||||||
<Text size='sm' className='leading-4'>
|
|
||||||
{asset.symbol}
|
|
||||||
</Text>
|
|
||||||
</div>,
|
|
||||||
],
|
|
||||||
value: asset.denom,
|
|
||||||
})),
|
|
||||||
[assets],
|
|
||||||
)
|
|
||||||
|
|
||||||
const handleReduceMotion = useCallback(
|
const handleReduceMotion = useCallback(
|
||||||
(value: boolean) => {
|
(value: boolean) => {
|
||||||
setReduceMotion(value)
|
setReduceMotion(value)
|
||||||
@ -117,13 +96,6 @@ export default function SettingsModal() {
|
|||||||
[setTutorial],
|
[setTutorial],
|
||||||
)
|
)
|
||||||
|
|
||||||
const handlePreferredAsset = useCallback(
|
|
||||||
(value: string) => {
|
|
||||||
setPreferredAsset(value)
|
|
||||||
},
|
|
||||||
[setPreferredAsset],
|
|
||||||
)
|
|
||||||
|
|
||||||
const handleDisplayCurrency = useCallback(
|
const handleDisplayCurrency = useCallback(
|
||||||
(value: string) => {
|
(value: string) => {
|
||||||
setDisplayCurrency(value)
|
setDisplayCurrency(value)
|
||||||
@ -174,17 +146,10 @@ export default function SettingsModal() {
|
|||||||
|
|
||||||
const handleResetSettings = useCallback(() => {
|
const handleResetSettings = useCallback(() => {
|
||||||
handleDisplayCurrency(DEFAULT_SETTINGS.displayCurrency)
|
handleDisplayCurrency(DEFAULT_SETTINGS.displayCurrency)
|
||||||
handlePreferredAsset(DEFAULT_SETTINGS.preferredAsset)
|
|
||||||
handleSlippage(DEFAULT_SETTINGS.slippage)
|
handleSlippage(DEFAULT_SETTINGS.slippage)
|
||||||
handleReduceMotion(DEFAULT_SETTINGS.reduceMotion)
|
handleReduceMotion(DEFAULT_SETTINGS.reduceMotion)
|
||||||
handleLendAssets(DEFAULT_SETTINGS.lendAssets)
|
handleLendAssets(DEFAULT_SETTINGS.lendAssets)
|
||||||
}, [
|
}, [handleDisplayCurrency, handleReduceMotion, handleLendAssets, handleSlippage])
|
||||||
handleDisplayCurrency,
|
|
||||||
handleReduceMotion,
|
|
||||||
handleLendAssets,
|
|
||||||
handlePreferredAsset,
|
|
||||||
handleSlippage,
|
|
||||||
])
|
|
||||||
|
|
||||||
const showResetModal = useCallback(() => {
|
const showResetModal = useCallback(() => {
|
||||||
showResetDialog({
|
showResetDialog({
|
||||||
@ -267,21 +232,11 @@ export default function SettingsModal() {
|
|||||||
withStatus
|
withStatus
|
||||||
/>
|
/>
|
||||||
<SettingsOptions
|
<SettingsOptions
|
||||||
label='Preferred asset'
|
label='Display Currency'
|
||||||
description='By selecting a different asset you always have the trading pair or asset selector
|
description='Convert all values to the selected asset/currency.'
|
||||||
pre-filled with this asset.'
|
|
||||||
className='pb-6'
|
className='pb-6'
|
||||||
>
|
>
|
||||||
<Select
|
<Select
|
||||||
label='Global'
|
|
||||||
options={preferredAssetsOptions}
|
|
||||||
defaultValue={preferredAsset}
|
|
||||||
onChange={handlePreferredAsset}
|
|
||||||
className='relative border w-60 rounded-base border-white/10'
|
|
||||||
containerClassName='justify-end mb-4'
|
|
||||||
/>
|
|
||||||
<Select
|
|
||||||
label='Display Currency'
|
|
||||||
options={displayCurrenciesOptions}
|
options={displayCurrenciesOptions}
|
||||||
defaultValue={displayCurrency}
|
defaultValue={displayCurrency}
|
||||||
onChange={handleDisplayCurrency}
|
onChange={handleDisplayCurrency}
|
||||||
|
@ -66,13 +66,13 @@ export const TVChartContainer = (props: Props) => {
|
|||||||
'mainSeriesProperties.candleStyle.wickUpColor': '#3DAE9A',
|
'mainSeriesProperties.candleStyle.wickUpColor': '#3DAE9A',
|
||||||
'mainSeriesProperties.candleStyle.wickDownColor': '#AE3D3D',
|
'mainSeriesProperties.candleStyle.wickDownColor': '#AE3D3D',
|
||||||
'mainSeriesProperties.candleStyle.barColorsOnPrevClose': false,
|
'mainSeriesProperties.candleStyle.barColorsOnPrevClose': false,
|
||||||
'scalesProperties.textColor': 'rgba(255, 255, 255, 0.3)',
|
'scalesProperties.textColor': 'rgba(255, 255, 255, 0.7)',
|
||||||
'paneProperties.legendProperties.showSeriesTitle': false,
|
'paneProperties.legendProperties.showSeriesTitle': true,
|
||||||
'paneProperties.legendProperties.showVolume': false,
|
'paneProperties.legendProperties.showVolume': false,
|
||||||
'paneProperties.legendProperties.showStudyValues': false,
|
'paneProperties.legendProperties.showStudyValues': false,
|
||||||
'paneProperties.legendProperties.showStudyTitles': false,
|
'paneProperties.legendProperties.showStudyTitles': false,
|
||||||
'scalesProperties.axisHighlightColor': '#381730',
|
'scalesProperties.axisHighlightColor': '#381730',
|
||||||
'linetooltrendline.color': 'rgba( 21, 153, 128, 1)',
|
'linetooltrendline.color': '#3DAE9A',
|
||||||
'linetooltrendline.linewidth': 10,
|
'linetooltrendline.linewidth': 10,
|
||||||
},
|
},
|
||||||
overrides,
|
overrides,
|
||||||
|
@ -1,54 +1,51 @@
|
|||||||
import { useCallback, useEffect } from 'react'
|
import { useCallback } from 'react'
|
||||||
|
|
||||||
import { SwapIcon } from 'components/Icons'
|
import { SwapIcon } from 'components/Icons'
|
||||||
import Text from 'components/Text'
|
import Text from 'components/Text'
|
||||||
import AssetButton from 'components/Trade/TradeModule/AssetSelector/AssetButton'
|
import AssetButton from 'components/Trade/TradeModule/AssetSelector/AssetButton'
|
||||||
import AssetOverlay from 'components/Trade/TradeModule/AssetSelector/AssetOverlay'
|
import AssetOverlay from 'components/Trade/TradeModule/AssetSelector/AssetOverlay'
|
||||||
|
import { DEFAULT_SETTINGS } from 'constants/defaultSettings'
|
||||||
|
import { LocalStorageKeys } from 'constants/localStorageKeys'
|
||||||
|
import useLocalStorage from 'hooks/useLocalStorage'
|
||||||
import useStore from 'store'
|
import useStore from 'store'
|
||||||
|
|
||||||
interface Props {
|
interface Props {
|
||||||
buyAsset: Asset
|
buyAsset: Asset
|
||||||
sellAsset: Asset
|
sellAsset: Asset
|
||||||
onChangeBuyAsset: (asset: Asset) => void
|
|
||||||
onChangeSellAsset: (asset: Asset) => void
|
|
||||||
}
|
}
|
||||||
|
|
||||||
export default function AssetSelector(props: Props) {
|
export default function AssetSelector(props: Props) {
|
||||||
const { buyAsset, sellAsset, onChangeBuyAsset, onChangeSellAsset } = props
|
const [tradingPair, setTradingPair] = useLocalStorage<Settings['tradingPair']>(
|
||||||
|
LocalStorageKeys.TRADING_PAIR,
|
||||||
|
DEFAULT_SETTINGS.tradingPair,
|
||||||
|
)
|
||||||
|
const { buyAsset, sellAsset } = props
|
||||||
const assetOverlayState = useStore((s) => s.assetOverlayState)
|
const assetOverlayState = useStore((s) => s.assetOverlayState)
|
||||||
|
|
||||||
const handleSwapAssets = useCallback(() => {
|
const handleSwapAssets = useCallback(() => {
|
||||||
onChangeBuyAsset(sellAsset)
|
setTradingPair({ buy: sellAsset.denom, sell: buyAsset.denom })
|
||||||
onChangeSellAsset(buyAsset)
|
}, [setTradingPair, sellAsset, buyAsset])
|
||||||
}, [onChangeBuyAsset, onChangeSellAsset, sellAsset, buyAsset])
|
|
||||||
|
|
||||||
const handleChangeBuyAsset = useCallback(
|
const handleChangeBuyAsset = useCallback(
|
||||||
(asset: Asset) => {
|
(asset: Asset) => {
|
||||||
onChangeBuyAsset(asset)
|
setTradingPair({ buy: asset.denom, sell: sellAsset.denom })
|
||||||
useStore.setState({ assetOverlayState: 'sell' })
|
useStore.setState({ assetOverlayState: 'sell' })
|
||||||
},
|
},
|
||||||
[onChangeBuyAsset],
|
[setTradingPair, sellAsset],
|
||||||
)
|
)
|
||||||
|
|
||||||
const handleChangeSellAsset = useCallback(
|
const handleChangeSellAsset = useCallback(
|
||||||
(asset: Asset) => {
|
(asset: Asset) => {
|
||||||
onChangeSellAsset(asset)
|
setTradingPair({ buy: buyAsset.denom, sell: asset.denom })
|
||||||
useStore.setState({ assetOverlayState: 'closed' })
|
useStore.setState({ assetOverlayState: 'closed' })
|
||||||
},
|
},
|
||||||
[onChangeSellAsset],
|
[setTradingPair, buyAsset],
|
||||||
)
|
)
|
||||||
|
|
||||||
const handleChangeState = useCallback((state: OverlayState) => {
|
const handleChangeState = useCallback((state: OverlayState) => {
|
||||||
useStore.setState({ assetOverlayState: state })
|
useStore.setState({ assetOverlayState: state })
|
||||||
}, [])
|
}, [])
|
||||||
|
|
||||||
useEffect(() => {
|
|
||||||
if (assetOverlayState === 'closed') {
|
|
||||||
onChangeBuyAsset(buyAsset)
|
|
||||||
onChangeSellAsset(sellAsset)
|
|
||||||
}
|
|
||||||
}, [onChangeBuyAsset, onChangeSellAsset, assetOverlayState, buyAsset, sellAsset])
|
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className='grid-rows-auto grid grid-cols-[1fr_min-content_1fr] gap-y-2 bg-white/5 p-3'>
|
<div className='grid-rows-auto grid grid-cols-[1fr_min-content_1fr] gap-y-2 bg-white/5 p-3'>
|
||||||
<Text size='sm'>Buy</Text>
|
<Text size='sm'>Buy</Text>
|
||||||
|
@ -6,12 +6,10 @@ import SwapForm from 'components/Trade/TradeModule/SwapForm'
|
|||||||
interface Props {
|
interface Props {
|
||||||
buyAsset: Asset
|
buyAsset: Asset
|
||||||
sellAsset: Asset
|
sellAsset: Asset
|
||||||
onChangeBuyAsset: (asset: Asset) => void
|
|
||||||
onChangeSellAsset: (asset: Asset) => void
|
|
||||||
}
|
}
|
||||||
|
|
||||||
export default function TradeModule(props: Props) {
|
export default function TradeModule(props: Props) {
|
||||||
const { buyAsset, sellAsset, onChangeBuyAsset, onChangeSellAsset } = props
|
const { buyAsset, sellAsset } = props
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div
|
<div
|
||||||
@ -21,13 +19,7 @@ export default function TradeModule(props: Props) {
|
|||||||
'h-full',
|
'h-full',
|
||||||
)}
|
)}
|
||||||
>
|
>
|
||||||
<AssetSelector
|
<AssetSelector buyAsset={buyAsset} sellAsset={sellAsset} />
|
||||||
buyAsset={buyAsset}
|
|
||||||
sellAsset={sellAsset}
|
|
||||||
onChangeBuyAsset={onChangeBuyAsset}
|
|
||||||
onChangeSellAsset={onChangeSellAsset}
|
|
||||||
/>
|
|
||||||
|
|
||||||
<SwapForm buyAsset={buyAsset} sellAsset={sellAsset} />
|
<SwapForm buyAsset={buyAsset} sellAsset={sellAsset} />
|
||||||
</div>
|
</div>
|
||||||
)
|
)
|
||||||
|
@ -1,11 +1,13 @@
|
|||||||
import { ASSETS } from 'constants/assets'
|
|
||||||
import { ORACLE_DENOM } from 'constants/oracle'
|
import { ORACLE_DENOM } from 'constants/oracle'
|
||||||
|
import { getEnabledMarketAssets } from 'utils/assets'
|
||||||
|
|
||||||
|
const enabledMarketAssets = getEnabledMarketAssets()
|
||||||
|
|
||||||
export const DEFAULT_SETTINGS: Settings = {
|
export const DEFAULT_SETTINGS: Settings = {
|
||||||
accountSummaryTabs: [true, true],
|
accountSummaryTabs: [true, true],
|
||||||
reduceMotion: false,
|
reduceMotion: false,
|
||||||
lendAssets: true,
|
lendAssets: true,
|
||||||
preferredAsset: ASSETS[0].denom,
|
tradingPair: { buy: enabledMarketAssets[0].denom, sell: enabledMarketAssets[1].denom },
|
||||||
displayCurrency: ORACLE_DENOM,
|
displayCurrency: ORACLE_DENOM,
|
||||||
slippage: 0.02,
|
slippage: 0.02,
|
||||||
tutorial: true,
|
tutorial: true,
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
export enum LocalStorageKeys {
|
export enum LocalStorageKeys {
|
||||||
|
TRADING_PAIR = 'tradingPair',
|
||||||
ACCOUNT_SUMMARY_TABS = 'accountSummaryTabs',
|
ACCOUNT_SUMMARY_TABS = 'accountSummaryTabs',
|
||||||
PREFERRED_ASSET = 'favouriteAsset',
|
|
||||||
DISPLAY_CURRENCY = 'displayCurrency',
|
DISPLAY_CURRENCY = 'displayCurrency',
|
||||||
REDUCE_MOTION = 'reduceMotion',
|
REDUCE_MOTION = 'reduceMotion',
|
||||||
FAVORITE_ASSETS = 'favoriteAssets',
|
FAVORITE_ASSETS = 'favoriteAssets',
|
||||||
|
@ -1,28 +1,40 @@
|
|||||||
import { useState } from 'react'
|
import { useMemo } from 'react'
|
||||||
|
|
||||||
import MigrationBanner from 'components/MigrationBanner'
|
import MigrationBanner from 'components/MigrationBanner'
|
||||||
import AccountDetailsCard from 'components/Trade/AccountDetailsCard'
|
import AccountDetailsCard from 'components/Trade/AccountDetailsCard'
|
||||||
import TradeChart from 'components/Trade/TradeChart'
|
import TradeChart from 'components/Trade/TradeChart'
|
||||||
import TradeModule from 'components/Trade/TradeModule'
|
import TradeModule from 'components/Trade/TradeModule'
|
||||||
|
import { DEFAULT_SETTINGS } from 'constants/defaultSettings'
|
||||||
|
import { LocalStorageKeys } from 'constants/localStorageKeys'
|
||||||
|
import useLocalStorage from 'hooks/useLocalStorage'
|
||||||
import useStore from 'store'
|
import useStore from 'store'
|
||||||
|
import { byDenom } from 'utils/array'
|
||||||
import { getEnabledMarketAssets } from 'utils/assets'
|
import { getEnabledMarketAssets } from 'utils/assets'
|
||||||
|
|
||||||
export default function TradePage() {
|
export default function TradePage() {
|
||||||
|
const [tradingPair] = useLocalStorage<Settings['tradingPair']>(
|
||||||
|
LocalStorageKeys.TRADING_PAIR,
|
||||||
|
DEFAULT_SETTINGS.tradingPair,
|
||||||
|
)
|
||||||
const enabledMarketAssets = getEnabledMarketAssets()
|
const enabledMarketAssets = getEnabledMarketAssets()
|
||||||
const [buyAsset, setBuyAsset] = useState(enabledMarketAssets[0])
|
|
||||||
const [sellAsset, setSellAsset] = useState(enabledMarketAssets[1])
|
|
||||||
const assetOverlayState = useStore((s) => s.assetOverlayState)
|
const assetOverlayState = useStore((s) => s.assetOverlayState)
|
||||||
|
|
||||||
|
const buyAsset = useMemo(
|
||||||
|
() => enabledMarketAssets.find(byDenom(tradingPair.buy)) ?? enabledMarketAssets[0],
|
||||||
|
[tradingPair, enabledMarketAssets],
|
||||||
|
)
|
||||||
|
const sellAsset = useMemo(
|
||||||
|
() => enabledMarketAssets.find(byDenom(tradingPair.sell)) ?? enabledMarketAssets[1],
|
||||||
|
[tradingPair, enabledMarketAssets],
|
||||||
|
)
|
||||||
|
|
||||||
|
if (!tradingPair) return null
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className='flex flex-col w-full h-full gap-4'>
|
<div className='flex flex-col w-full h-full gap-4'>
|
||||||
<MigrationBanner />
|
<MigrationBanner />
|
||||||
<div className='grid h-full w-full grid-cols-[346px_auto] gap-4'>
|
<div className='grid h-full w-full grid-cols-[346px_auto] gap-4'>
|
||||||
<TradeModule
|
<TradeModule buyAsset={buyAsset} sellAsset={sellAsset} />
|
||||||
buyAsset={buyAsset}
|
|
||||||
sellAsset={sellAsset}
|
|
||||||
onChangeBuyAsset={setBuyAsset}
|
|
||||||
onChangeSellAsset={setSellAsset}
|
|
||||||
/>
|
|
||||||
<TradeChart buyAsset={buyAsset} sellAsset={sellAsset} />
|
<TradeChart buyAsset={buyAsset} sellAsset={sellAsset} />
|
||||||
<div />
|
<div />
|
||||||
<AccountDetailsCard />
|
<AccountDetailsCard />
|
||||||
|
2
src/types/interfaces/store/settings.d.ts
vendored
2
src/types/interfaces/store/settings.d.ts
vendored
@ -2,7 +2,7 @@ interface Settings {
|
|||||||
accountSummaryTabs: boolean[]
|
accountSummaryTabs: boolean[]
|
||||||
displayCurrency: string
|
displayCurrency: string
|
||||||
reduceMotion: boolean
|
reduceMotion: boolean
|
||||||
preferredAsset: string
|
tradingPair: { buy: string; sell: string }
|
||||||
lendAssets: boolean
|
lendAssets: boolean
|
||||||
slippage: number
|
slippage: number
|
||||||
tutorial: boolean
|
tutorial: boolean
|
||||||
|
Loading…
Reference in New Issue
Block a user