mirror of
https://github.com/codeninjasllc/discourse.git
synced 2024-12-11 08:11:15 -05:00
41 lines
1.3 KiB
JavaScript
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');
|
|
}
|
|
}
|
|
});
|
|
|