stacker.news/components/nav/carousel.js

47 lines
1.1 KiB
JavaScript

import { createContext, useCallback, useContext, useEffect, useState } from 'react'
const STORAGE_KEY = 'asSats'
const DEFAULT_SELECTION = 'fiat'
const carousel = [
'fiat',
'yep',
'1btc',
'blockHeight',
'chainFee',
'halving'
]
export const CarouselContext = createContext({
selection: undefined,
handleClick: () => {}
})
export function CarouselProvider ({ children }) {
const [selection, setSelection] = useState(undefined)
const [pos, setPos] = useState(0)
useEffect(() => {
const selection = window.localStorage.getItem(STORAGE_KEY) ?? DEFAULT_SELECTION
setSelection(selection)
setPos(carousel.findIndex((item) => item === selection))
}, [])
const handleClick = useCallback(() => {
const nextPos = (pos + 1) % carousel.length
window.localStorage.setItem(STORAGE_KEY, carousel[nextPos])
setSelection(carousel[nextPos])
setPos(nextPos)
}, [pos])
return (
<CarouselContext.Provider value={[selection, handleClick]}>
{children}
</CarouselContext.Provider>
)
}
export function useCarousel () {
return useContext(CarouselContext)
}