import { useState, useEffect, useCallback } from 'react' import { ArrowRightLeft, RefreshCw } from 'lucide-react' import { useTranslation } from '../../i18n' import CustomSelect from '../shared/CustomSelect' const CURRENCIES = [ 'AED', 'AFN', 'ALL', 'AMD', 'ANG', 'AOA', 'ARS', 'AUD', 'AWG', 'AZN', 'BAM', 'BBD', 'BDT', 'BGN', 'BHD', 'BIF', 'BMD', 'BND', 'BOB', 'BRL', 'BSD', 'BTN', 'BWP', 'BYN', 'BZD', 'CAD', 'CDF', 'CHF', 'CLF', 'CLP', 'CNH', 'CNY', 'COP', 'CRC', 'CUP', 'CVE', 'CZK', 'DJF', 'DKK', 'DOP', 'DZD', 'EGP', 'ERN', 'ETB', 'EUR', 'FJD', 'FKP', 'FOK', 'GBP', 'GEL', 'GGP', 'GHS', 'GIP', 'GMD', 'GNF', 'GTQ', 'GYD', 'HKD', 'HNL', 'HRK', 'HTG', 'HUF', 'IDR', 'ILS', 'IMP', 'INR', 'IQD', 'ISK', 'JEP', 'JMD', 'JOD', 'JPY', 'KES', 'KGS', 'KHR', 'KID', 'KMF', 'KRW', 'KWD', 'KYD', 'KZT', 'LAK', 'LBP', 'LKR', 'LRD', 'LSL', 'LYD', 'MAD', 'MDL', 'MGA', 'MKD', 'MMK', 'MNT', 'MOP', 'MRU', 'MUR', 'MVR', 'MWK', 'MXN', 'MYR', 'MZN', 'NAD', 'NGN', 'NIO', 'NOK', 'NPR', 'NZD', 'OMR', 'PAB', 'PEN', 'PGK', 'PHP', 'PKR', 'PLN', 'PYG', 'QAR', 'RON', 'RSD', 'RUB', 'RWF', 'SAR', 'SBD', 'SCR', 'SDG', 'SEK', 'SGD', 'SHP', 'SLE', 'SOS', 'SRD', 'SSP', 'STN', 'SYP', 'SZL', 'THB', 'TJS', 'TMT', 'TND', 'TOP', 'TRY', 'TTD', 'TVD', 'TWD', 'TZS', 'UAH', 'UGX', 'USD', 'UYU', 'UZS', 'VES', 'VND', 'VUV', 'WST', 'XAF', 'XCD', 'XDR', 'XOF', 'XPF', 'YER', 'ZAR', 'ZMW', 'ZWL' ] const CURRENCY_OPTIONS = CURRENCIES.map(c => ({ value: c, label: c })) export default function CurrencyWidget() { const { t, locale } = useTranslation() const [from, setFrom] = useState(() => localStorage.getItem('currency_from') || 'EUR') const [to, setTo] = useState(() => localStorage.getItem('currency_to') || 'USD') const [amount, setAmount] = useState('100') const [rate, setRate] = useState(null) const [loading, setLoading] = useState(false) const fetchRate = useCallback(async () => { if (from === to) { setRate(1); return } setLoading(true) try { const resp = await fetch(`https://api.exchangerate-api.com/v4/latest/${from}`) const data = await resp.json() setRate(data.rates?.[to] || null) } catch { setRate(null) } finally { setLoading(false) } }, [from, to]) useEffect(() => { fetchRate() }, [fetchRate]) useEffect(() => { localStorage.setItem('currency_from', from) }, [from]) useEffect(() => { localStorage.setItem('currency_to', to) }, [to]) const swap = () => { setFrom(to); setTo(from) } const rawResult = rate && amount ? (parseFloat(amount) * rate).toFixed(2) : null const formatNumber = (num) => { if (!num || num === '—') return '—' return parseFloat(num).toLocaleString(locale, { minimumFractionDigits: 2, maximumFractionDigits: 2 }) } const result = rawResult return (
{t('dashboard.currency')}
{/* Amount */}
setAmount(e.target.value)} className="w-full text-2xl font-black tabular-nums outline-none [appearance:textfield] [&::-webkit-inner-spin-button]:appearance-none" style={{ color: 'var(--text-primary)', background: 'transparent', border: 'none' }} />
{/* From / Swap / To */}
{/* Result */}

{formatNumber(result)} {to}

{rate &&

1 {from} = {rate.toFixed(4)} {to}

}
) }