import ButtonGroup from '@components/forms/ButtonGroup' import Select from '@components/forms/Select' import ChartMiddleOBLeft from '@components/icons/ChartMiddleOBLeft' import ChartMiddleOBRight from '@components/icons/ChartMiddleOBRight' import ChartOnLeft from '@components/icons/ChartOnLeft' import ChartOnRight from '@components/icons/ChartOnRight' import Tooltip from '@components/shared/Tooltip' import { TradeLayout } from '@components/trade/TradeAdvancedPage' // import dayjs from 'dayjs' import { ReactNode, useEffect, useState } from 'react' // import { useRouter } from 'next/router' // import { useCallback } from 'react' import dayjs from 'dayjs' import useLocalStorageState from 'hooks/useLocalStorageState' import { useTranslation } from 'next-i18next' import { useTheme } from 'next-themes' import { useCallback } from 'react' import { useRouter } from 'next/router' import { NOTIFICATION_POSITION_KEY, SIZE_INPUT_UI_KEY, TRADE_CHART_UI_KEY, TRADE_LAYOUT_KEY, } from 'utils/constants' import mangoStore from '@store/mangoStore' import { CUSTOM_SKINS } from 'utils/theme' const NOTIFICATION_POSITIONS = [ 'bottom-left', 'bottom-right', 'top-left', 'top-right', ] const TRADING_CHARTS = ['custom', 'trading-view'] const TRADE_FORM_UI = ['slider', 'buttons'] const LANGS = [ { locale: 'en', name: 'english', description: 'english' }, // { locale: 'ru', name: 'russian', description: 'russian' }, // { locale: 'es', name: 'spanish', description: 'spanish' }, { locale: 'zh_tw', name: 'chinese-traditional', description: 'traditional chinese', }, // { locale: 'zh', name: 'chinese', description: 'simplified chinese' }, ] const DEFAULT_THEMES = [ 'light', 'medium', 'dark', 'high-contrast', 'mango-classic', 'avocado', 'banana', 'blueberry', 'lychee', 'olive', ] const DisplaySettings = () => { const { t } = useTranslation(['common', 'settings']) const { theme, setTheme } = useTheme() const [themes, setThemes] = useState(DEFAULT_THEMES) const nfts = mangoStore((s) => s.wallet.nfts.data) const [savedLanguage, setSavedLanguage] = useLocalStorageState( 'language', 'en', ) const router = useRouter() const { pathname, asPath, query } = router const [notificationPosition, setNotificationPosition] = useLocalStorageState( NOTIFICATION_POSITION_KEY, 'bottom-left', ) const [tradeFormUi, setTradeFormUi] = useLocalStorageState( SIZE_INPUT_UI_KEY, 'slider', ) const [tradeChartUi, setTradeChartUi] = useLocalStorageState( TRADE_CHART_UI_KEY, 'trading-view', ) const [, setTradeLayout] = useLocalStorageState(TRADE_LAYOUT_KEY, 'chartLeft') // add nft skins to theme selection list useEffect(() => { if (nfts.length) { const customThemes = [] const ownedCollections = [ ...new Set(nfts.map((x) => x.collectionAddress)), ] for (const collection of ownedCollections) { for (const themeKey in CUSTOM_SKINS) { if (CUSTOM_SKINS[themeKey] === collection) { customThemes.push(themeKey) } } } setThemes( customThemes.length ? [...customThemes, ...DEFAULT_THEMES] : [...DEFAULT_THEMES], ) } else { setThemes([...DEFAULT_THEMES]) } }, [nfts]) const handleLangChange = useCallback( (l: string) => { setSavedLanguage(l) router.push({ pathname, query }, asPath, { locale: l }) dayjs.locale(l == 'zh_tw' ? 'zh-tw' : l) }, [router, pathname, query, asPath, setSavedLanguage], ) return (
{t('settings:theme')}
{t('settings:language')}
{t('settings:notification-position')}
{t('settings:trade-layout')}
{t('settings:swap-trade-size-selector')}
{t('settings:trade-chart')}