mirror of
https://github.com/cheeaun/phanpy.git
synced 2025-01-24 09:36:42 +01:00
58 lines
1.4 KiB
React
58 lines
1.4 KiB
React
|
// Twitter-style relative time component
|
||
|
// Seconds = 1s
|
||
|
// Minutes = 1m
|
||
|
// Hours = 1h
|
||
|
// Days = 1d
|
||
|
// After 7 days, use DD/MM/YYYY or MM/DD/YYYY
|
||
|
import dayjs from 'dayjs';
|
||
|
import dayjsTwitter from 'dayjs-twitter';
|
||
|
import localizedFormat from 'dayjs/plugin/localizedFormat';
|
||
|
import relativeTime from 'dayjs/plugin/relativeTime';
|
||
|
import { useEffect, useState } from 'preact/hooks';
|
||
|
|
||
|
dayjs.extend(dayjsTwitter);
|
||
|
dayjs.extend(localizedFormat);
|
||
|
dayjs.extend(relativeTime);
|
||
|
|
||
|
const dtf = new Intl.DateTimeFormat();
|
||
|
|
||
|
export default function RelativeTime({ datetime, format }) {
|
||
|
if (!datetime) return null;
|
||
|
const date = dayjs(datetime);
|
||
|
const [dateStr, setDateStr] = useState('');
|
||
|
|
||
|
useEffect(() => {
|
||
|
let timer, raf;
|
||
|
const update = () => {
|
||
|
raf = requestAnimationFrame(() => {
|
||
|
let str;
|
||
|
if (format === 'micro') {
|
||
|
// If date <= 7 days
|
||
|
if (date.diff(dayjs(), 'day') >= -7) {
|
||
|
str = date.twitter();
|
||
|
} else {
|
||
|
// If date > 7 days
|
||
|
str = dtf.format(date.toDate());
|
||
|
}
|
||
|
} else {
|
||
|
str = date.fromNow();
|
||
|
}
|
||
|
setDateStr(str);
|
||
|
|
||
|
timer = setTimeout(update, 30_000);
|
||
|
});
|
||
|
};
|
||
|
raf = requestAnimationFrame(update);
|
||
|
return () => {
|
||
|
clearTimeout(timer);
|
||
|
cancelAnimationFrame(raf);
|
||
|
};
|
||
|
}, [date]);
|
||
|
|
||
|
return (
|
||
|
<time datetime={date.toISOString()} title={date.format('LLLL')}>
|
||
|
{dateStr}
|
||
|
</time>
|
||
|
);
|
||
|
}
|