1
0
mirror of https://github.com/flarum/core.git synced 2025-07-25 02:31:17 +02:00

Split up post controls into "user", "moderation", "destructive"

This commit is contained in:
Toby Zerner
2015-06-26 16:15:30 +09:30
parent 020e671c74
commit ce0bb59997

View File

@@ -29,7 +29,11 @@ export default function(app) {
}
}
Post.prototype.controls = function(context) {
Post.prototype.userControls = function(context) {
return new ItemList();
};
Post.prototype.moderationControls = function(context) {
var items = new ItemList();
if (this.contentType() === 'comment' && this.canEdit()) {
@@ -37,17 +41,37 @@ export default function(app) {
items.add('restore', ActionButton.component({ icon: 'reply', label: 'Restore', onclick: restoreAction.bind(this) }));
} else {
items.add('edit', ActionButton.component({ icon: 'pencil', label: 'Edit', onclick: editAction.bind(this) }));
if (this.number() != 1) {
items.add('hide', ActionButton.component({ icon: 'times', label: 'Delete', onclick: hideAction.bind(this) }));
}
}
}
if ((this.contentType() !== 'comment' || this.isHidden()) && this.canDelete() && this.number() != 1) {
items.add('delete', ActionButton.component({ icon: 'times', label: 'Delete', onclick: deleteAction.bind(this) }));
return items;
};
Post.prototype.destructiveControls = function(context) {
var items = new ItemList();
if (this.number() != 1) {
if (this.contentType() === 'comment' && !this.isHidden() && this.canEdit()) {
items.add('hide', ActionButton.component({ icon: 'times', label: 'Delete', onclick: hideAction.bind(this) }));
} else if ((this.contentType() !== 'comment' || this.isHidden()) && this.canDelete()) {
items.add('delete', ActionButton.component({ icon: 'times', label: 'Delete Forever', onclick: deleteAction.bind(this) }));
}
}
return items;
};
Post.prototype.controls = function(context) {
var items = new ItemList();
['user', 'moderation', 'destructive'].forEach(section => {
var controls = this[section+'Controls'](context).toArray();
if (controls.length) {
items.add(section, controls);
items.add(section+'Separator', Separator.component());
}
});
return items;
}
};