]> Untitled Git - lemmy-ui.git/blob - src/shared/components/common/moment-time.tsx
Merge branch 'fix/notif_new_fetch_bug' of https://github.com/ernestwisniewski/lemmy...
[lemmy-ui.git] / src / shared / components / common / moment-time.tsx
1 import { Option } from "@sniptt/monads";
2 import { Component } from "inferno";
3 import moment from "moment";
4 import { i18n } from "../../i18next";
5 import { capitalizeFirstLetter, getLanguages } from "../../utils";
6 import { Icon } from "./icon";
7
8 interface MomentTimeProps {
9   published: string;
10   updated: Option<string>;
11   showAgo?: boolean;
12   ignoreUpdated?: boolean;
13 }
14
15 export class MomentTime extends Component<MomentTimeProps, any> {
16   constructor(props: any, context: any) {
17     super(props, context);
18
19     let lang = getLanguages();
20
21     moment.locale(lang);
22   }
23
24   createdAndModifiedTimes() {
25     return `${capitalizeFirstLetter(i18n.t("created"))}: ${this.format(
26       this.props.published
27     )}\n\n\n${
28       this.props.updated.isSome() && capitalizeFirstLetter(i18n.t("modified"))
29     } ${this.format(this.props.updated.unwrap())}`;
30   }
31
32   render() {
33     if (!this.props.ignoreUpdated && this.props.updated.isSome()) {
34       return (
35         <span
36           data-tippy-content={this.createdAndModifiedTimes()}
37           className="font-italics pointer unselectable"
38         >
39           <Icon icon="edit-2" classes="icon-inline mr-1" />
40           {moment.utc(this.props.updated.unwrap()).fromNow(!this.props.showAgo)}
41         </span>
42       );
43     } else {
44       let published = this.props.published;
45       return (
46         <span
47           className="pointer unselectable"
48           data-tippy-content={this.format(published)}
49         >
50           {moment.utc(published).fromNow(!this.props.showAgo)}
51         </span>
52       );
53     }
54   }
55
56   format(input: string): string {
57     return moment.utc(input).local().format("LLLL");
58   }
59 }