92 lines
2.7 KiB
TypeScript
92 lines
2.7 KiB
TypeScript
import { useEffect, useState } from 'react'
|
|
import styled from '@emotion/styled'
|
|
import useMangoGroupConfig from '../hooks/useMangoGroupConfig'
|
|
import MarketMenuItem from './MarketMenuItem'
|
|
import { LinkButton } from './Button'
|
|
import MarketsModal from './MarketsModal'
|
|
import useLocalStorageState from '../hooks/useLocalStorageState'
|
|
|
|
const StyledMarketSelectWrapper = styled.div`
|
|
-ms-overflow-style: none;
|
|
scrollbar-width: none;
|
|
|
|
::-webkit-scrollbar {
|
|
display: none;
|
|
}
|
|
`
|
|
|
|
const StyledMarketTypeToggleWrapper = styled.div`
|
|
background: rgba(255, 255, 255, 0.12);
|
|
`
|
|
|
|
const StyledArrow = styled.div`
|
|
width: 0;
|
|
height: 0;
|
|
border-top: 20px solid transparent;
|
|
border-bottom: 20px solid transparent;
|
|
border-left: 20px solid rgba(255, 255, 255, 0.12);
|
|
padding-right: 0.5rem;
|
|
`
|
|
|
|
const MarketSelect = () => {
|
|
const [showMarketsModal, setShowMarketsModal] = useState(false)
|
|
const [hiddenMarkets] = useLocalStorageState('hiddenMarkets', [])
|
|
const [sortedMarkets, setSortedMarkets] = useState([])
|
|
const groupConfig = useMangoGroupConfig()
|
|
|
|
useEffect(() => {
|
|
const markets = []
|
|
const allMarkets = [...groupConfig.perpMarkets, ...groupConfig.spotMarkets]
|
|
allMarkets.forEach((market) => {
|
|
const base = market.name.slice(0, -5)
|
|
const found = markets.find((b) => b.baseAsset === base)
|
|
if (!found) {
|
|
markets.push({ baseAsset: base, markets: [market] })
|
|
} else {
|
|
found.markets.push(market)
|
|
}
|
|
})
|
|
setSortedMarkets(
|
|
markets.sort((a, b) => a.baseAsset.localeCompare(b.baseAsset))
|
|
)
|
|
}, [])
|
|
|
|
return (
|
|
<>
|
|
<StyledMarketSelectWrapper className="bg-th-bkg-3 flex h-10">
|
|
<StyledMarketTypeToggleWrapper className="flex items-center pl-6 md:pl-9 pr-1">
|
|
<LinkButton
|
|
className="font-normal text-th-fgd-2 text-xs"
|
|
onClick={() => setShowMarketsModal(true)}
|
|
>
|
|
MARKETS
|
|
</LinkButton>
|
|
</StyledMarketTypeToggleWrapper>
|
|
<StyledArrow />
|
|
<div className="flex items-center justify-between w-full">
|
|
<div className="flex items-center">
|
|
{sortedMarkets
|
|
.filter((m) => !hiddenMarkets.includes(m.baseAsset))
|
|
.map((s) => (
|
|
<MarketMenuItem
|
|
key={s.baseAsset}
|
|
linksArray={s.markets}
|
|
menuTitle={s.baseAsset}
|
|
/>
|
|
))}
|
|
</div>
|
|
</div>
|
|
</StyledMarketSelectWrapper>
|
|
{showMarketsModal ? (
|
|
<MarketsModal
|
|
isOpen={showMarketsModal}
|
|
onClose={() => setShowMarketsModal(false)}
|
|
markets={sortedMarkets}
|
|
/>
|
|
) : null}
|
|
</>
|
|
)
|
|
}
|
|
|
|
export default MarketSelect
|