import React, { useContext, useEffect, useState } from 'react' import { Button } from 'react-bootstrap' import useSWR from 'swr' import { fixedDecimal } from '../lib/format' import { useMe } from './me' const fetcher = url => fetch(url).then(res => res.json()).catch() export const PriceContext = React.createContext({ price: null }) export const CURRENCY_SYMBOLS = { 'USD': '$', 'EUR': '€' } const endpoint = (fiat) => `https://api.coinbase.com/v2/prices/BTC-${fiat}/spot` export async function getPrice (fiat) { const data = await fetcher(endpoint(fiat)) return data?.data?.amount } export function PriceProvider ({ price, children }) { const { fiatCurrency } = useMe() const { data } = useSWR( endpoint(fiatCurrency), fetcher, { refreshInterval: 30000 }) const contextValue = { price: data?.data?.amount || price } return ( {children} ) } export function usePrice () { const { price } = useContext(PriceContext) return price } export default function Price () { const [asSats, setAsSats] = useState(undefined) useEffect(() => { setAsSats(localStorage.getItem('asSats')) }, []) const price = usePrice() const { fiatCurrency } = useMe() const fiatSymbol = CURRENCY_SYMBOLS[fiatCurrency]; if (!price) return null const handleClick = () => { if (asSats === 'yep') { localStorage.setItem('asSats', '1btc') setAsSats('1btc') } else if (asSats === '1btc') { localStorage.removeItem('asSats') setAsSats(undefined) } else { localStorage.setItem('asSats', 'yep') setAsSats('yep') } } if (asSats === 'yep') { return ( ) } if (asSats === '1btc') { return ( ) } return ( ) }