]> Untitled Git - lemmy-ui.git/blob - src/shared/components/common/moment-time.tsx
f216adf0a6dadf0d0a747ed1f0e160b31af7f030
[lemmy-ui.git] / src / shared / components / common / moment-time.tsx
1 import { capitalizeFirstLetter, formatPastDate } from "@utils/helpers";
2 import format from "date-fns/format";
3 import parseISO from "date-fns/parseISO";
4 import { Component } from "inferno";
5 import { I18NextService } from "../../services";
6 import { Icon } from "./icon";
7
8 interface MomentTimeProps {
9   published: string;
10   updated?: string;
11   showAgo?: boolean;
12   ignoreUpdated?: boolean;
13 }
14
15 function formatDate(input: string) {
16   return format(parseISO(input), "PPPPpppp");
17 }
18
19 export class MomentTime extends Component<MomentTimeProps, any> {
20   constructor(props: any, context: any) {
21     super(props, context);
22   }
23
24   createdAndModifiedTimes() {
25     const updated = this.props.updated;
26     let line = `${capitalizeFirstLetter(
27       I18NextService.i18n.t("created")
28     )}: ${formatDate(this.props.published)}`;
29     if (updated) {
30       line += `\n\n\n${capitalizeFirstLetter(
31         I18NextService.i18n.t("modified")
32       )} ${formatDate(updated)}`;
33     }
34     return line;
35   }
36
37   render() {
38     if (!this.props.ignoreUpdated && this.props.updated) {
39       return (
40         <span
41           data-tippy-content={this.createdAndModifiedTimes()}
42           className="moment-time fst-italics pointer unselectable"
43         >
44           <Icon icon="edit-2" classes="icon-inline me-1" />
45           {formatPastDate(this.props.updated)}
46         </span>
47       );
48     } else {
49       const published = this.props.published;
50       return (
51         <span
52           className="moment-time pointer unselectable"
53           data-tippy-content={formatDate(published)}
54         >
55           {formatPastDate(published)}
56         </span>
57       );
58     }
59   }
60 }