use-interval-value
v1.0.1
Published
Generate new values at intervals
Downloads
4
Readme
use-interval-value
Generate new values at intervals
Install
npm install use-interval-value
Usage
import * as React from 'react'
import useIntervalValue from 'use-interval-value'
const getCurrentTime = () => new Date().toString().slice(16, 24)
export const Time = () => {
const time = useIntervalValue(1000, getCurrentTime)
return <div>{time}</div>
}
With mutable callback
import * as React from 'react'
import useIntervalValue, { IntervalCallback } from 'use-interval-value'
const second = 1e3
const minute = second * 60
const hour = minute * 60
const formatTimeLeft = (msLeft: number) => {
const hours = Math.floor(msLeft / hour).toString().padStart(2, '0')
const minutes = Math.floor((msLeft % hour) / minute).toString().padStart(2, '0')
const seconds = Math.ceil((msLeft % minute) / second).toString().padStart(2, '0')
return `${hours}:${minutes}:${seconds}`
}
export const Countdown = ({ endTimestamp }: { endTimestamp: number }) => {
const getTimeLeft = React.useCallback<IntervalCallback<string>>(
clear => {
const timeLeft = endTimestamp - Date.now()
if (timeLeft <= 0) clear()
return formatTimeLeft(timeLeft < 0 ? 0 : timeLeft)
},
[endTimestamp]
)
const time = useIntervalValue(1000, getTimeLeft)
return <div>{time}</div>
}
Countdown.defaultProps = {
endTimestamp: Date.now() + 1e4,
}
License
MIT © termosa
This hook is created using create-react-hook.