UX: Sections not collapsable in "header dropdown" navigation menu (#21604)

What is the problem?

This is a follow up to 4cca7de22d. In the
commit, CSS was used to disable the collapsing of sections in the header
dropdown navigation menu when the `navigation_menu` site setting is set
to `header dropdown`. However, using CSS is not the correct approach as
the underlying code is still marking the section as collapsable which
means that the sections will still be displayed as collapsed with no way
to "uncollapse" if the local store has already marked the section as
collapsed.

What is the fix?

This commit removes the usage of CSS to hide the collapsabe button and
instead correctly marks the section as not collapsable in the code.
This commit is contained in:
Alan Guo Xiang Tan 2023-05-17 15:28:09 +09:00 committed by GitHub
parent 5878535606
commit c991b8f6a0
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
8 changed files with 55 additions and 15 deletions

View File

@ -1,5 +1,5 @@
<div class="sidebar-sections sidebar-sections-anonymous"> <div class="sidebar-sections sidebar-sections-anonymous">
<Sidebar::Anonymous::CustomSections /> <Sidebar::Anonymous::CustomSections @collapsable={{@collapsableSections}} />
<Sidebar::Anonymous::CategoriesSection <Sidebar::Anonymous::CategoriesSection
@collapsable={{@collapsableSections}} @collapsable={{@collapsableSections}}
/> />

View File

@ -1,7 +1,7 @@
<Sidebar::Section <Sidebar::Section
@sectionName={{this.section.slug}} @sectionName={{this.section.slug}}
@headerLinkText={{this.section.decoratedTitle}} @headerLinkText={{this.section.decoratedTitle}}
@collapsable={{true}} @collapsable={{@collapsable}}
@headerActions={{this.section.headerActions}} @headerActions={{this.section.headerActions}}
@headerActionsIcon={{this.section.headerActionIcon}} @headerActionsIcon={{this.section.headerActionIcon}}
@class={{this.section.dragCss}} @class={{this.section.dragCss}}

View File

@ -1,5 +1,8 @@
<div class="sidebar-custom-sections"> <div class="sidebar-custom-sections">
{{#each this.sections as |section|}} {{#each this.sections as |section|}}
<Sidebar::Common::CustomSection @sectionData={{section}} /> <Sidebar::Common::CustomSection
@sectionData={{section}}
@collapsable={{@collapsable}}
/>
{{/each}} {{/each}}
</div> </div>

View File

@ -9,7 +9,7 @@
<div class="sidebar-hamburger-dropdown"> <div class="sidebar-hamburger-dropdown">
<Sidebar::Sections <Sidebar::Sections
@currentUser={{this.currentUser}} @currentUser={{this.currentUser}}
@collapsableSections={{true}} @collapsableSections={{this.collapsableSections}}
/> />
<Sidebar::Footer @tagName="" /> <Sidebar::Footer @tagName="" />
</div> </div>

View File

@ -5,9 +5,22 @@ import { inject as service } from "@ember/service";
export default class SidebarHamburgerDropdown extends Component { export default class SidebarHamburgerDropdown extends Component {
@service appEvents; @service appEvents;
@service currentUser; @service currentUser;
@service site;
@service siteSettings;
@action @action
triggerRenderedAppEvent() { triggerRenderedAppEvent() {
this.appEvents.trigger("sidebar-hamburger-dropdown:rendered"); this.appEvents.trigger("sidebar-hamburger-dropdown:rendered");
} }
get collapsableSections() {
if (
this.siteSettings.navigation_menu === "header dropdown" &&
!this.args.collapsableSections
) {
return this.site.mobileView || this.site.narrowDesktopView;
} else {
this.args.collapsableSections;
}
}
} }

View File

@ -1,5 +1,5 @@
<div class="sidebar-sections"> <div class="sidebar-sections">
<Sidebar::User::CustomSections /> <Sidebar::User::CustomSections @collapsable={{@collapsableSections}} />
<Sidebar::User::CategoriesSection @collapsable={{@collapsableSections}} /> <Sidebar::User::CategoriesSection @collapsable={{@collapsableSections}} />
{{#if this.currentUser.display_sidebar_tags}} {{#if this.currentUser.display_sidebar_tags}}

View File

@ -9,7 +9,7 @@ import {
} from "discourse/tests/helpers/qunit-helpers"; } from "discourse/tests/helpers/qunit-helpers";
acceptance( acceptance(
"Sidebar - Logged on user - Experimental sidebar and hamburger setting disabled", "Sidebar - Logged on user - Legacy navigation menu enabled",
function (needs) { function (needs) {
needs.user(); needs.user();
@ -27,7 +27,29 @@ acceptance(
); );
acceptance( acceptance(
"Sidebar - Logged on user - header dropdown navigation menu enabled", "Sidebar - Logged on user - Mobile view - Header dropdown navigation menu enabled",
function (needs) {
needs.user();
needs.mobileView();
needs.settings({
navigation_menu: "header dropdown",
});
test("sections are collapsable", async function (assert) {
await visit("/");
await click(".hamburger-dropdown");
assert.ok(
exists(".sidebar-section-header.sidebar-section-header-collapsable"),
"sections are collapsable"
);
});
}
);
acceptance(
"Sidebar - Logged on user - Desktop view - Header dropdown navigation menu enabled",
function (needs) { function (needs) {
needs.user(); needs.user();
@ -52,6 +74,16 @@ acceptance(
); );
}); });
test("sections are not collapsable", async function (assert) {
await visit("/");
await click(".hamburger-dropdown");
assert.notOk(
exists(".sidebar-section-header.sidebar-section-header-collapsable"),
"sections are not collapsable"
);
});
test("'more' dropdown should display as regular list items in header dropdown mode", async function (assert) { test("'more' dropdown should display as regular list items in header dropdown mode", async function (assert) {
await visit("/"); await visit("/");
await click(".hamburger-dropdown"); await click(".hamburger-dropdown");

View File

@ -54,14 +54,6 @@
} }
} }
.sidebar-section-wrapper .sidebar-section-header-caret {
display: none;
}
.sidebar-section-header-collapsable {
pointer-events: none; // disabling collapsible sections
}
.sidebar-custom-sections .d-icon-globe { .sidebar-custom-sections .d-icon-globe {
left: -0.9em; left: -0.9em;
top: 0.35em; top: 0.35em;