2019-11-08 05:38:28 +08:00
|
|
|
import discourseComputed from "discourse-common/utils/decorators";
|
2019-10-31 04:28:29 +08:00
|
|
|
import { equal } from "@ember/object/computed";
|
2019-10-30 21:48:24 +08:00
|
|
|
import { scheduleOnce } from "@ember/runloop";
|
2019-10-24 00:30:52 +08:00
|
|
|
import Component from "@ember/component";
|
2018-01-31 05:31:29 +08:00
|
|
|
|
2019-05-28 00:27:16 +08:00
|
|
|
const ACTIONS = ["delete", "delete_replies", "edit", "none"];
|
|
|
|
|
2019-10-24 00:30:52 +08:00
|
|
|
export default Component.extend({
|
2019-01-04 01:03:01 +08:00
|
|
|
postId: null,
|
2018-01-31 05:31:29 +08:00
|
|
|
postAction: null,
|
|
|
|
postEdit: null,
|
|
|
|
|
2019-11-08 05:38:28 +08:00
|
|
|
@discourseComputed
|
2018-01-31 05:31:29 +08:00
|
|
|
penaltyActions() {
|
|
|
|
return ACTIONS.map(id => {
|
|
|
|
return { id, name: I18n.t(`admin.user.penalty_post_${id}`) };
|
|
|
|
});
|
|
|
|
},
|
|
|
|
|
2019-10-31 04:28:29 +08:00
|
|
|
editing: equal("postAction", "edit"),
|
2018-01-31 05:31:29 +08:00
|
|
|
|
|
|
|
actions: {
|
|
|
|
penaltyChanged() {
|
2019-05-27 16:15:39 +08:00
|
|
|
let postAction = this.postAction;
|
2018-01-31 05:31:29 +08:00
|
|
|
|
|
|
|
// If we switch to edit mode, jump to the edit textarea
|
2018-06-15 23:03:24 +08:00
|
|
|
if (postAction === "edit") {
|
2019-10-30 21:48:24 +08:00
|
|
|
scheduleOnce("afterRender", () => {
|
2019-07-16 18:45:15 +08:00
|
|
|
let elem = this.element;
|
|
|
|
let body = elem.closest(".modal-body");
|
2018-01-31 05:31:29 +08:00
|
|
|
body.scrollTop(body.height());
|
2019-07-16 18:45:15 +08:00
|
|
|
elem.querySelector(".post-editor").focus();
|
2018-01-31 05:31:29 +08:00
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|