mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-04 17:04:59 +03:00
715ee08100
refs https://github.com/TryGhost/Team/issues/1111 Extracted functionality for listing, downloading, activating, and deleting from the theme controller/template into separate components and services so that they are more composable/reusable in different situations. - moved theme activation to a new `theme-management` service that uses the `modals` service to open the theme warnings modal or limits upgrade modal as required - the activate process is a task so that consumers can store a reference to the task instance and cancel it to close any related warning/limit modals (eg, when navigating away from the route or closing the modal that kicked off the process) - created new-pattern modals for custom theme limit upgrade, theme errors, and delete confirmation so that we can treat them as promises and close where needed from parent - duplicated theme table component as `<GhThemeTableLabs>` with an actions redesign and a refactor to handle download, activation, and deletion itself making use of the new theme-management service and modals - fixed some oddities with design modal's transition/modal close handling by simplifying the async behaviour and being more explicit - added advanced design modal that contains the new theme table component and linked to it from footer of design modal's sidebar
29 lines
840 B
JavaScript
29 lines
840 B
JavaScript
import Component from '@glimmer/component';
|
|
import {action} from '@ember/object';
|
|
import {inject as service} from '@ember/service';
|
|
import {task} from 'ember-concurrency-decorators';
|
|
|
|
export default class ConfirmDeleteThemeComponent extends Component {
|
|
@service ghostPaths;
|
|
@service notifications;
|
|
@service utils;
|
|
|
|
@action
|
|
downloadTheme(event) {
|
|
event.preventDefault();
|
|
this.utils.downloadFile(`${this.ghostPaths.apiRoot}/themes/${this.args.data.theme.name}/download/`);
|
|
}
|
|
|
|
@task
|
|
*deleteThemeTask() {
|
|
try {
|
|
yield this.args.data.theme.destroyRecord();
|
|
this.args.close();
|
|
return true;
|
|
} catch (error) {
|
|
// TODO: show error in modal rather than generic message
|
|
this.notifications.showAPIError(error);
|
|
}
|
|
}
|
|
}
|