DEV: Move sidebar utility class to body tag (#17259)
This commit is contained in:
parent
4821d44c3c
commit
836b5300fc
|
@ -8,11 +8,6 @@ export default Controller.extend({
|
|||
router: service(),
|
||||
showSidebar: true,
|
||||
|
||||
@discourseComputed("showSidebar", "currentUser.experimental_sidebar_enabled")
|
||||
mainOutletWrapperClasses(showSidebar, experimentalSidebarEnabled) {
|
||||
return showSidebar && experimentalSidebarEnabled ? "has-sidebar" : "";
|
||||
},
|
||||
|
||||
@discourseComputed
|
||||
canSignUp() {
|
||||
return (
|
||||
|
|
|
@ -15,9 +15,9 @@
|
|||
|
||||
{{plugin-outlet name="below-site-header" connectorTagName="div" args=(hash currentPath=router._router.currentPath)}}
|
||||
|
||||
<div id="main-outlet-wrapper" class="wrap {{mainOutletWrapperClasses}}" role="main">
|
||||
{{#if currentUser.experimental_sidebar_enabled}}
|
||||
<Sidebar @shouldDisplay={{showSidebar}} />
|
||||
<div id="main-outlet-wrapper" class="wrap" role="main">
|
||||
{{#if (and currentUser.experimental_sidebar_enabled showSidebar)}}
|
||||
<Sidebar />
|
||||
{{/if}}
|
||||
|
||||
<div id="main-outlet">
|
||||
|
|
|
@ -1,5 +1,4 @@
|
|||
{{#if @shouldDisplay}}
|
||||
<div class="sidebar-wrapper">
|
||||
{{#d-section pageClass="has-sidebar" class="sidebar-wrapper"}}
|
||||
<div class="sidebar-container">
|
||||
<Sidebar::TopicsSection />
|
||||
<Sidebar::CategoriesSection />
|
||||
|
@ -12,5 +11,4 @@
|
|||
<Sidebar::MessagesSection />
|
||||
{{/if}}
|
||||
</div>
|
||||
</div>
|
||||
{{/if}}
|
||||
{{/d-section}}
|
||||
|
|
|
@ -8,7 +8,12 @@ acceptance("Sidebar - Anon User", function () {
|
|||
test("sidebar is not displayed", async function (assert) {
|
||||
await visit("/");
|
||||
|
||||
assert.ok(!exists("#main-outlet-wrapper.has-sidebar"));
|
||||
assert.strictEqual(
|
||||
document.querySelectorAll("body.has-sidebar-page").length,
|
||||
0,
|
||||
"does not add sidebar utility class to body"
|
||||
);
|
||||
|
||||
assert.ok(!exists(".sidebar-wrapper"));
|
||||
});
|
||||
});
|
||||
|
@ -19,7 +24,12 @@ acceptance("Sidebar - User with sidebar disabled", function (needs) {
|
|||
test("sidebar is not displayed", async function (assert) {
|
||||
await visit("/");
|
||||
|
||||
assert.ok(!exists("#main-outlet-wrapper.has-sidebar"));
|
||||
assert.strictEqual(
|
||||
document.querySelectorAll("body.has-sidebar-page").length,
|
||||
0,
|
||||
"does not add sidebar utility class to body"
|
||||
);
|
||||
|
||||
assert.ok(!exists(".sidebar-wrapper"));
|
||||
});
|
||||
});
|
||||
|
@ -30,18 +40,20 @@ acceptance("Sidebar - User with sidebar enabled", function (needs) {
|
|||
test("hiding and displaying sidebar", async function (assert) {
|
||||
await visit("/");
|
||||
|
||||
assert.ok(
|
||||
exists("#main-outlet-wrapper.has-sidebar"),
|
||||
"adds sidebar utility class on main outlet wrapper"
|
||||
assert.strictEqual(
|
||||
document.querySelectorAll("body.has-sidebar-page").length,
|
||||
1,
|
||||
"adds sidebar utility class to body"
|
||||
);
|
||||
|
||||
assert.ok(exists(".sidebar-wrapper"), "displays the sidebar by default");
|
||||
|
||||
await click(".header-sidebar-toggle .btn");
|
||||
|
||||
assert.ok(
|
||||
!exists("#main-outlet-wrapper.has-sidebar"),
|
||||
"removes sidebar utility class from main outlet wrapper"
|
||||
assert.strictEqual(
|
||||
document.querySelectorAll("body.has-sidebar-page").length,
|
||||
0,
|
||||
"removes sidebar utility class to body"
|
||||
);
|
||||
|
||||
assert.ok(!exists(".sidebar-wrapper"), "hides the sidebar");
|
||||
|
|
|
@ -191,13 +191,13 @@ input {
|
|||
grid-template-columns: minmax(0, 1fr);
|
||||
gap: 0;
|
||||
|
||||
&.has-sidebar {
|
||||
grid-template-areas: "sidebar content";
|
||||
grid-template-columns: 240px 1fr;
|
||||
gap: 0 2em;
|
||||
}
|
||||
|
||||
#main-outlet {
|
||||
grid-area: content;
|
||||
}
|
||||
}
|
||||
|
||||
body.has-sidebar-page #main-outlet-wrapper {
|
||||
grid-template-areas: "sidebar content";
|
||||
grid-template-columns: 240px 1fr;
|
||||
gap: 0 2em;
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue