2
0
Fork 0
mirror of https://github.com/discourse/discourse.git synced 2025-09-06 10:50:21 +08:00
discourse/app/assets/javascripts/discourse/components/d-editor-modal.js.es6
Joffrey JAFFEUX b3eb67976d
DEV: Upgrades to Ember 3.10 (#7871)
Co-Authored-By: majakomel <maja.komel@gmail.com>
2019-07-16 12:45:15 +02:00

61 lines
1.4 KiB
JavaScript

import { observes, on } from "ember-addons/ember-computed-decorators";
export default Ember.Component.extend({
classNameBindings: [":d-editor-modal", "hidden"],
@observes("hidden")
_hiddenChanged() {
if (!this.hidden) {
Ember.run.scheduleOnce("afterRender", () => {
const $modal = $(this.element);
const $parent = $(this.element).closest(".d-editor");
const w = $parent.width();
const h = $parent.height();
const dir = $("html").css("direction") === "rtl" ? "right" : "left";
const offset = w / 2 - $modal.outerWidth() / 2;
$modal.css(dir, offset + "px");
parent
.$(".d-editor-overlay")
.removeClass("hidden")
.css({ width: w, height: h });
this.$("input:eq(0)").focus();
});
} else {
parent.$(".d-editor-overlay").addClass("hidden");
}
},
@on("didInsertElement")
_listenKeys() {
$(this.element).on("keydown.d-modal", key => {
if (this.hidden) {
return;
}
if (key.keyCode === 27) {
this.send("cancel");
return false;
}
if (key.keyCode === 13) {
this.send("ok");
return false;
}
});
},
@on("willDestroyElement")
_stopListening() {
$(this.element).off("keydown.d-modal");
},
actions: {
ok() {
this.set("hidden", true);
this.okAction();
},
cancel() {
this.set("hidden", true);
}
}
});