]> Untitled Git - lemmy.git/blob - ui/src/components/moment-time.tsx
Merge branch 'digitalkiller-master'
[lemmy.git] / ui / src / components / moment-time.tsx
1 import { Component } from 'inferno';
2 import * as moment from 'moment';
3 import 'moment/locale/de';
4 import 'moment/locale/zh-cn';
5 import 'moment/locale/fr';
6 import 'moment/locale/sv';
7 import 'moment/locale/ru';
8 import { getMomentLanguage } from '../utils';
9 import { i18n } from '../i18next';
10
11 interface MomentTimeProps {
12   data: {
13     published?: string;
14     when_?: string;
15     updated?: string;
16   }
17 }
18
19 export class MomentTime extends Component<MomentTimeProps, any> {
20
21   constructor(props: any, context: any) {
22     super(props, context);
23
24     let lang = getMomentLanguage();
25
26     moment.locale(lang);
27   }
28
29   render() {
30     if (this.props.data.updated) {
31       return (
32         <span title={this.props.data.updated} className="font-italics">{i18n.t('modified')} {moment.utc(this.props.data.updated).fromNow()}</span>
33       )
34     } else {
35       let str = this.props.data.published || this.props.data.when_;
36       return (
37         <span title={str}>{moment.utc(str).fromNow()}</span>
38       )
39     }
40   }
41 }