lbry-desktop/ui/component/dateTime/view.jsx

75 lines
1.9 KiB
React
Raw Normal View History

// @flow
import React from 'react';
import moment from 'moment';
type Props = {
date?: any,
timeAgo?: boolean,
formatOptions: {},
show?: string,
2021-04-02 22:26:05 -07:00
clock24h: boolean,
};
class DateTime extends React.PureComponent<Props> {
static SHOW_DATE = 'date';
static SHOW_TIME = 'time';
static getTimeAgoStr(date: any) {
const suffixList = ['years', 'months', 'days', 'hours', 'minutes', 'seconds', ''];
var duration = 0;
for (var i = 0; i < suffixList.length; ++i) {
// moment() is very liberal with it's rounding.
// Always round down dates for better youtube parity.
duration = Math.floor(moment().diff(date, suffixList[i]));
if (duration > 0) {
break;
}
}
if (i === suffixList.length) {
// This should never happen since we are handling up to 'seconds' now,
// but display the English version just in case it does.
return moment(date).from(moment());
}
// Strip off the 's' for the singular suffix, construct the string ID,
// then load the localized version.
const suffix = duration === 1 ? suffixList[i].substr(0, suffixList[i].length - 1) : suffixList[i];
let strId = '%duration% ' + suffix + ' ago';
if (!suffix) {
strId = 'Just now';
}
return __(strId, { duration });
}
render() {
2021-04-02 22:26:05 -07:00
const { date, timeAgo, show, clock24h } = this.props;
let clockFormat = 'hh:mm A';
if (clock24h) {
clockFormat = 'HH:mm';
}
if (timeAgo) {
2019-12-10 14:09:10 -05:00
if (!date) {
return null;
}
2021-04-02 22:26:05 -07:00
return <span title={moment(date).format(`MMMM Do, YYYY ${clockFormat}`)}>{DateTime.getTimeAgoStr(date)}</span>;
}
return (
<span>
{date && show === DateTime.SHOW_DATE && moment(date).format('MMMM Do, YYYY')}
2021-04-02 22:26:05 -07:00
{date && show === DateTime.SHOW_TIME && moment(date).format(clockFormat)}
{!date && '...'}
</span>
);
}
}
export default DateTime;