FIX: bold sidebar header when admin sidebar is disabled (#26993)

Recently a bug was introduced when the admin sidebar section was made bold.

When the admin sidebar is disabled, we display the original sidebar in the admin panel. In that case, an incorrect CSS rule is executed.
```CSS
.admin-area .sidebar-wrapper {
  background-color: var(--d-sidebar-admin-background);
  .sidebar-section-header-text {
    font-weight: bold;
  }
}
```
Bug in this PR: https://github.com/discourse/discourse/pull/26801

To solve it, a custom CSS class with a panel key was added which will allow granular customisations.
This commit is contained in:
Krzysztof Kotlarek 2024-05-13 12:36:03 +10:00 committed by GitHub
parent fc76622b56
commit 74f24d5973
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
3 changed files with 20 additions and 10 deletions

View File

@ -1,9 +1,17 @@
import Component from "@glimmer/component";
import { service } from "@ember/service";
import ApiSections from "./api-sections"; import ApiSections from "./api-sections";
const SidebarApiPanels = <template> export default class SidebarApiPanels extends Component {
<div class="sidebar-sections"> @service sidebarState;
get panelCssClass() {
return `${this.sidebarState.currentPanel.key}-panel`;
}
<template>
<div class="sidebar-sections {{this.panelCssClass}}">
<ApiSections @collapsable={{@collapsableSections}} /> <ApiSections @collapsable={{@collapsableSections}} />
</div> </div>
</template>; </template>
}
export default SidebarApiPanels;

View File

@ -921,7 +921,7 @@ acceptance("Sidebar - Plugin API", function (needs) {
api.addSidebarPanel((BaseCustomSidebarPanel) => { api.addSidebarPanel((BaseCustomSidebarPanel) => {
const AdminSidebarPanel = class extends BaseCustomSidebarPanel { const AdminSidebarPanel = class extends BaseCustomSidebarPanel {
get key() { get key() {
return "admin-panel"; return "admin";
} }
get hidden() { get hidden() {
@ -1004,9 +1004,9 @@ acceptance("Sidebar - Plugin API", function (needs) {
} }
}; };
}, },
"admin-panel" "admin"
); );
api.setSidebarPanel("admin-panel"); api.setSidebarPanel("admin");
api.setSeparatedSidebarMode(); api.setSeparatedSidebarMode();
}); });
@ -1019,12 +1019,14 @@ acceptance("Sidebar - Plugin API", function (needs) {
"test admin section", "test admin section",
"displays header with correct text" "displays header with correct text"
); );
assert.dom(".admin-panel").exists();
withPluginApi(PLUGIN_API_VERSION, (api) => { withPluginApi(PLUGIN_API_VERSION, (api) => {
api.setSidebarPanel("main-panel"); api.setSidebarPanel("main-panel");
api.setCombinedSidebarMode(); api.setCombinedSidebarMode();
}); });
await visit("/"); await visit("/");
assert.dom(".sidebar__panel-switch-button").doesNotExist(); assert.dom(".sidebar__panel-switch-button").doesNotExist();
assert.dom(".admin-panel").doesNotExist();
assert assert
.dom(".sidebar-section[data-section-name='test-admin-section']") .dom(".sidebar-section[data-section-name='test-admin-section']")
.doesNotExist(); .doesNotExist();

View File

@ -26,7 +26,7 @@
} }
} }
.admin-area .sidebar-wrapper { .admin-area .sidebar-wrapper .admin-panel {
background-color: var(--d-sidebar-admin-background); background-color: var(--d-sidebar-admin-background);
.sidebar-section-header-text { .sidebar-section-header-text {
font-weight: bold; font-weight: bold;