mirror of
https://github.com/discourse/discourse.git
synced 2025-02-22 04:48:39 +08:00
data:image/s3,"s3://crabby-images/94cbb/94cbb57df0d84bd1cbee25a6ba37820bb33959e9" alt="Martin Brennan"
We have separated and combined modes for sidebar panels. Separated means the panels show only their own sections, combined means sections from all panels are shown. The admin sidebar only shows its own panels, so it must set the mode to separated; however when we navigate to chat or home we must revert to the initial mode setttings.
61 lines
1.6 KiB
JavaScript
61 lines
1.6 KiB
JavaScript
import { tracked } from "@glimmer/tracking";
|
|
import { inject as service } from "@ember/service";
|
|
import {
|
|
ADMIN_PANEL,
|
|
COMBINED_MODE,
|
|
MAIN_PANEL,
|
|
SEPARATED_MODE,
|
|
} from "discourse/lib/sidebar/panels";
|
|
import DiscourseRoute from "discourse/routes/discourse";
|
|
import I18n from "discourse-i18n";
|
|
|
|
export default class AdminRoute extends DiscourseRoute {
|
|
@service sidebarState;
|
|
@service siteSettings;
|
|
@service currentUser;
|
|
@tracked initialSidebarState;
|
|
|
|
titleToken() {
|
|
return I18n.t("admin_title");
|
|
}
|
|
|
|
activate() {
|
|
if (this.currentUser.use_admin_sidebar) {
|
|
this.initialSidebarState = {
|
|
mode: this.sidebarState.mode,
|
|
displaySwitchPanelButtons: this.sidebarState.displaySwitchPanelButtons,
|
|
};
|
|
|
|
this.sidebarState.setPanel(ADMIN_PANEL);
|
|
this.sidebarState.setSeparatedMode();
|
|
this.sidebarState.hideSwitchPanelButtons();
|
|
}
|
|
|
|
this.controllerFor("application").setProperties({
|
|
showTop: false,
|
|
});
|
|
}
|
|
|
|
deactivate(transition) {
|
|
this.controllerFor("application").set("showTop", true);
|
|
|
|
if (this.currentUser.use_admin_sidebar) {
|
|
if (!transition?.to.name.startsWith("admin")) {
|
|
if (this.initialSidebarState.mode === SEPARATED_MODE) {
|
|
this.sidebarState.setSeparatedMode();
|
|
} else if (this.initialSidebarState.mode === COMBINED_MODE) {
|
|
this.sidebarState.setCombinedMode();
|
|
}
|
|
|
|
if (this.initialSidebarState.displaySwitchPanelButtons) {
|
|
this.sidebarState.showSwitchPanelButtons();
|
|
} else {
|
|
this.sidebarState.hideSwitchPanelButtons();
|
|
}
|
|
|
|
this.sidebarState.setPanel(MAIN_PANEL);
|
|
}
|
|
}
|
|
}
|
|
}
|