discourse/app/assets/javascripts/discourse/widgets/post-edits-indicator.js.es6

41 lines
1.3 KiB
JavaScript

import { createWidget } from 'discourse/widgets/widget';
import { iconNode } from 'discourse/helpers/fa-icon';
import { longDate } from 'discourse/lib/formatter';
import { h } from 'virtual-dom';
const FIFTY_HOURS = 60 * 50 * 1000;
export default createWidget('post-edits-indicator', {
tagName: 'div.post-info.edits',
historyHeat(updatedAt) {
if (!updatedAt) { return; }
// Show heat on age
const rightNow = new Date().getTime();
const updatedAtTime = updatedAt.getTime();
const siteSettings = this.siteSettings;
if (updatedAtTime > (rightNow - FIFTY_HOURS * siteSettings.history_hours_low)) return 'heatmap-high';
if (updatedAtTime > (rightNow - FIFTY_HOURS * siteSettings.history_hours_medium)) return 'heatmap-med';
if (updatedAtTime > (rightNow - FIFTY_HOURS * siteSettings.history_hours_high)) return 'heatmap-low';
},
html(attrs) {
const contents = [attrs.version - 1, ' ', iconNode('pencil')];
const updatedAt = new Date(attrs.updated_at);
const title = `${I18n.t('post.last_edited_on')} ${longDate(updatedAt)}`;
return h('a', {
className: this.historyHeat(updatedAt),
attributes: { title }
}, contents);
},
click() {
if (this.attrs.canViewEditHistory) {
this.sendWidgetAction('showHistory');
}
}
});