diff --git a/app/assets/javascripts/discourse/app/components/d-modal.js b/app/assets/javascripts/discourse/app/components/d-modal.js index c94633fe26f..8bb6568242a 100644 --- a/app/assets/javascripts/discourse/app/components/d-modal.js +++ b/app/assets/javascripts/discourse/app/components/d-modal.js @@ -51,7 +51,7 @@ export default Component.extend({ //only respond to events when the modal is visible if (!this.element.classList.contains("hidden")) { if (e.which === 27 && this.dismissable) { - next(() => $(".modal-header button.modal-close").click()); + next(() => this.attrs.closeModal("initiatedByESC")); } if (e.which === 13 && this.triggerClickOnEnter(e)) { @@ -130,9 +130,7 @@ export default Component.extend({ this.set("dismissable", true); } - if (data.headerClass) { - this.set("headerClass", data.headerClass); - } + this.set("headerClass", data.headerClass || null); if (this.element) { const autofocusInputs = this.element.querySelectorAll( diff --git a/app/assets/javascripts/discourse/app/mixins/key-enter-escape.js b/app/assets/javascripts/discourse/app/mixins/key-enter-escape.js index dfa120a5a78..5c80b74b7d9 100644 --- a/app/assets/javascripts/discourse/app/mixins/key-enter-escape.js +++ b/app/assets/javascripts/discourse/app/mixins/key-enter-escape.js @@ -3,6 +3,10 @@ import { isiPad } from "discourse/lib/utilities"; // A mixin where hitting ESC calls `cancelled` and ctrl+enter calls `save. export default { keyDown(e) { + if (document.body.classList.contains("modal-open")) { + return; + } + if (e.which === 27) { this.cancelled(); return false; diff --git a/app/assets/javascripts/discourse/app/templates/modal/discard-draft.hbs b/app/assets/javascripts/discourse/app/templates/modal/discard-draft.hbs index d3dd3eb8fcf..46c706cbc48 100644 --- a/app/assets/javascripts/discourse/app/templates/modal/discard-draft.hbs +++ b/app/assets/javascripts/discourse/app/templates/modal/discard-draft.hbs @@ -1,4 +1,4 @@ -{{#d-modal-body dismissable=false headerClass="empty"}} +{{#d-modal-body headerClass="hidden"}}