1
0
mirror of https://github.com/tooot-app/app synced 2025-06-05 22:19:13 +02:00
Files
tooot/src/components/RelativeTime.tsx
Zhiyuan Zheng 7c0bcbeb06 Fixed #337
2022-06-14 23:43:11 +02:00

30 lines
671 B
TypeScript

import { useEffect, useState } from 'react'
import { FormattedRelativeTime } from 'react-intl'
import { AppState } from 'react-native'
export interface Props {
time: string | number
}
const RelativeTime: React.FC<Props> = ({ time }) => {
const [now, setNow] = useState(new Date().getTime())
useEffect(() => {
const appStateListener = AppState.addEventListener('change', state => {
setNow(new Date().getTime())
})
return () => {
appStateListener.remove()
}
}, [])
return (
<FormattedRelativeTime
value={(new Date(time).getTime() - now) / 1000}
updateIntervalInSeconds={1}
/>
)
}
export default RelativeTime