mirror of
https://github.com/TryGhost/Ghost.git
synced 2024-12-01 22:02:11 +03:00
569e4576d5
closes https://github.com/TryGhost/Team/issues/1130 - migrated install theme process to new modal system and changed to install+activate - added "Use theme" button that opens the new install+activate modal - when the view theme screen opens the install modal, an `onSuccess` callback is passed which sets a property that will skip closing the install modal when the view theme modal is closed and transitions to the `settings.design` route leaving the "success" modal state on screen - added a `skipErrors` option to `themeManage.activateThemeTask` so that it can be used from processes that already handle theme errors without opening extra modals on top
102 lines
3.4 KiB
JavaScript
102 lines
3.4 KiB
JavaScript
import EPMModalsService from 'ember-promise-modals/services/modals';
|
|
import {bind} from '@ember/runloop';
|
|
import {inject as service} from '@ember/service';
|
|
|
|
export default class ModalsService extends EPMModalsService {
|
|
@service dropdown;
|
|
@service themeManagement;
|
|
|
|
DEFAULT_MODAL_OPTIONS = {
|
|
'modals/confirm-unsaved-changes': {
|
|
className: 'fullscreen-modal-action fullscreen-modal-wide'
|
|
},
|
|
'modals/design/confirm-delete-theme': {
|
|
className: 'fullscreen-modal-action fullscreen-modal-wide'
|
|
},
|
|
'modals/design/install-theme': {
|
|
className: 'fullscreen-modal-action fullscreen-modal-wide'
|
|
},
|
|
'modals/design/theme-errors': {
|
|
className: 'fullscreen-modal-action fullscreen-modal-wide'
|
|
},
|
|
'modals/design/upload-theme': {
|
|
className: 'fullscreen-modal-action fullscreen-modal-wide',
|
|
beforeClose: () => {
|
|
if (this.themeManagement.isUploading) {
|
|
return false;
|
|
}
|
|
}
|
|
},
|
|
'modals/design/view-theme': {
|
|
className: 'fullscreen-modal-total-overlay',
|
|
omitBackdrop: true
|
|
},
|
|
'modals/limits/custom-theme': {
|
|
className: 'fullscreen-modal-action fullscreen-modal-wide'
|
|
}
|
|
}
|
|
|
|
// we manually close modals on backdrop clicks and escape rather than letting focus-trap
|
|
// handle it so we can intercept/abort closing for things like unsaved change confirmations
|
|
allowOutsideClick = true;
|
|
clickOutsideDeactivates = false;
|
|
escapeDeactivates = false;
|
|
|
|
open(modal, data, options) {
|
|
const mergedOptions = Object.assign({}, this.DEFAULT_MODAL_OPTIONS[modal], options);
|
|
return super.open(modal, data, mergedOptions);
|
|
}
|
|
|
|
_onFirstModalAdded() {
|
|
super._onFirstModalAdded(...arguments);
|
|
this.addEventHandlers();
|
|
this.dropdown.closeDropdowns();
|
|
}
|
|
|
|
_onLastModalRemoved() {
|
|
super._onLastModalRemoved(...arguments);
|
|
this.removeEventHandlers();
|
|
}
|
|
|
|
addEventHandlers() {
|
|
if (!this.backdropClickHandler) {
|
|
this.backdropClickHandler = bind(this, this.handleBackdropClick);
|
|
document.body.addEventListener('click', this.backdropClickHandler, {capture: true, passive: false});
|
|
}
|
|
|
|
if (!this.escapeKeyHandler) {
|
|
this.escapeKeyHandler = bind(this, this.handleEscapeKey);
|
|
document.addEventListener('keydown', this.escapeKeyHandler, {capture: true, passive: false});
|
|
}
|
|
}
|
|
|
|
removeEventHandlers() {
|
|
document.body.removeEventListener('click', this.backdropClickHandler, {capture: true, passive: false});
|
|
this.backdropClickHandler = null;
|
|
|
|
document.removeEventListener('keydown', this.escapeKeyHandler, {capture: true, passive: false});
|
|
this.escapeKeyHandler = null;
|
|
}
|
|
|
|
handleBackdropClick(event) {
|
|
let shouldClose = true;
|
|
|
|
for (const elem of (event.path || event.composedPath())) {
|
|
if (elem.matches?.('.modal-content, .fullscreen-modal-total-overlay, .ember-basic-dropdown-content')) {
|
|
shouldClose = false;
|
|
break;
|
|
}
|
|
}
|
|
|
|
if (shouldClose) {
|
|
this.top.close();
|
|
}
|
|
}
|
|
|
|
handleEscapeKey(event) {
|
|
if (event.key === 'Escape') {
|
|
this.top.close();
|
|
}
|
|
}
|
|
}
|