import Component from "@glimmer/component"; import { action } from "@ember/object"; import { service } from "@ember/service"; import I18n from "discourse-i18n"; import AdminPageSubheader from "admin/components/admin-page-subheader"; import InstallThemeModal from "admin/components/modal/install-theme"; import ThemesGrid from "admin/components/themes-grid"; export default class AdminConfigAreasLookAndFeelThemes extends Component { @service modal; @service router; @service toasts; @action installModal() { this.modal.show(InstallThemeModal, { model: { ...this.installThemeOptions() }, }); } // TODO (martin) These install methods may not belong here and they // are incomplete or have stubbed or omitted properties. We may want // to move this to the new config route or a dedicated component // that sits in the route. installThemeOptions() { return { selectedType: "theme", userId: null, content: [], installedThemes: this.args.themes, addTheme: this.addTheme, updateSelectedType: () => {}, }; } @action addTheme(theme) { this.toasts.success({ data: { message: I18n.t("admin.customize.theme.install_success", { theme: theme.name, }), }, duration: 2000, }); this.router.refresh(); } }