This commit is contained in:
2026-03-04 02:41:43 +01:00
parent 282832050f
commit b04a404654
4 changed files with 57 additions and 41 deletions

View File

@@ -1,8 +1,9 @@
</main> </main>
<footer class="site-footer"> <footer class="site-footer">
<div class="footer-left">© <?= date('Y') ?> Nexus</div> <div class="footer-left">© <?= date('Y') ?> Nexus</div>
<div class="footer-right">Security first · Internal only</div> <div class="footer-right">Security first · Internal only</div>
</footer> </footer>
</div>
</div> </div>
</div> </div>
<?php asset_scripts('footer'); ?> <?php asset_scripts('footer'); ?>

View File

@@ -61,7 +61,8 @@ if ($currentModule) {
</div> </div>
</div> </div>
</header> </header>
<aside class="app-sidebar"> <div class="layout-body">
<aside class="app-sidebar">
<div class="brand-text"></div> <div class="brand-text"></div>
<button class="sidebar-toggle" data-sidebar-toggle aria-label="Menü ein-/ausklappen"> <button class="sidebar-toggle" data-sidebar-toggle aria-label="Menü ein-/ausklappen">
@@ -82,22 +83,22 @@ if ($currentModule) {
<a href="/users" class="nav-link <?= $path === '/users' ? 'is-active' : '' ?>">User</a> <a href="/users" class="nav-link <?= $path === '/users' ? 'is-active' : '' ?>">User</a>
<a href="/settings" class="nav-link <?= $path === '/settings' ? 'is-active' : '' ?>">Einstellungen</a> <a href="/settings" class="nav-link <?= $path === '/settings' ? 'is-active' : '' ?>">Einstellungen</a>
</nav> </nav>
</aside> </aside>
<div class="app-content"> <div class="app-content">
<button class="floating-toggle" data-sidebar-toggle aria-label="Menü einblenden">»»</button> <button class="floating-toggle" data-sidebar-toggle aria-label="Menü einblenden">»»</button>
<?php if ($moduleMenu): ?> <?php if ($moduleMenu): ?>
<div class="module-subnav"> <div class="module-subnav">
<?php foreach ($moduleMenu as $entry): ?> <?php foreach ($moduleMenu as $entry): ?>
<a class="nav-link" href="<?= e($entry['href'] ?? '#') ?>"> <a class="nav-link" href="<?= e($entry['href'] ?? '#') ?>">
<?= e($entry['label'] ?? 'Link') ?> <?= e($entry['label'] ?? 'Link') ?>
</a> </a>
<?php endforeach; ?> <?php endforeach; ?>
</div> </div>
<?php endif; ?> <?php endif; ?>
<main class="site-main"> <main class="site-main">
<?php if (defined('APP_DEBUG_TOOL') && APP_DEBUG_TOOL): ?> <?php if (defined('APP_DEBUG_TOOL') && APP_DEBUG_TOOL): ?>
<a class="debug-fab" href="/debug" title="Debug"> <a class="debug-fab" href="/debug" title="Debug">
🐞 🐞

View File

@@ -77,9 +77,9 @@ body {
z-index: 1; z-index: 1;
min-height: 100vh; min-height: 100vh;
display: grid; display: grid;
grid-template-columns: 260px 1fr; grid-template-columns: 1fr;
gap: 24px; gap: 14px;
padding: 24px; padding: 18px 24px 24px;
} }
.app-sidebar { .app-sidebar {
@@ -92,8 +92,12 @@ body {
flex-direction: column; flex-direction: column;
gap: 18px; gap: 18px;
position: sticky; position: sticky;
top: 24px; top: 110px;
height: fit-content; height: fit-content;
transform: translateX(-12px);
opacity: 0;
pointer-events: none;
transition: transform 260ms ease, opacity 260ms ease;
} }
.sidebar-toggle { .sidebar-toggle {
@@ -124,22 +128,15 @@ body {
z-index: 60; z-index: 60;
} }
.sidebar-collapsed .app-shell { .layout-body.sidebar-open .app-sidebar {
grid-template-columns: 1fr; transform: translateX(0);
opacity: 1;
pointer-events: auto;
} }
.sidebar-collapsed .app-sidebar { .layout-body.sidebar-open .app-content {
width: 0; transition: transform 260ms ease;
padding: 0;
border: none;
box-shadow: none;
background: transparent;
}
.sidebar-collapsed .app-sidebar * {
display: none;
}
.sidebar-collapsed .sidebar-toggle {
display: none;
} }
.sidebar-collapsed .floating-toggle { .sidebar-collapsed .floating-toggle {
display: inline-flex; display: inline-flex;
} }
@@ -218,6 +215,16 @@ body {
gap: 16px; gap: 16px;
} }
.layout-body {
display: grid;
grid-template-columns: 1fr;
gap: 16px;
transition: grid-template-columns 260ms ease;
}
.layout-body.sidebar-open {
grid-template-columns: 260px 1fr;
}
.topbar { .topbar {
position: sticky; position: sticky;
top: 0; top: 0;
@@ -227,13 +234,13 @@ body {
background: var(--panel); background: var(--panel);
border: 1px solid var(--line); border: 1px solid var(--line);
border-radius: 18px; border-radius: 18px;
padding: 10px 18px; padding: 6px 14px;
display: flex; display: flex;
align-items: center; align-items: center;
justify-content: space-between; justify-content: space-between;
gap: 16px; gap: 16px;
box-shadow: var(--shadow); box-shadow: var(--shadow);
min-height: 96px; min-height: 88px;
} }
.topbar { position: relative; } .topbar { position: relative; }
.topbar::after { .topbar::after {

View File

@@ -1,14 +1,21 @@
(() => { (() => {
const toggles = document.querySelectorAll('[data-sidebar-toggle]'); const toggles = document.querySelectorAll('[data-sidebar-toggle]');
const layout = document.querySelector('.layout-body');
toggles.forEach((toggle) => { toggles.forEach((toggle) => {
toggle.addEventListener('click', () => { toggle.addEventListener('click', () => {
document.body.classList.toggle('sidebar-collapsed'); document.body.classList.toggle('sidebar-collapsed');
localStorage.setItem('sidebar-collapsed', document.body.classList.contains('sidebar-collapsed') ? '1' : '0'); layout?.classList.toggle('sidebar-open');
const collapsed = document.body.classList.contains('sidebar-collapsed');
localStorage.setItem('sidebar-collapsed', collapsed ? '1' : '0');
}); });
}); });
const saved = localStorage.getItem('sidebar-collapsed'); const saved = localStorage.getItem('sidebar-collapsed');
if (saved === null || saved === '1') { const collapsed = (saved === null || saved === '1');
if (collapsed) {
document.body.classList.add('sidebar-collapsed'); document.body.classList.add('sidebar-collapsed');
layout?.classList.remove('sidebar-open');
} else {
layout?.classList.add('sidebar-open');
} }
})(); })();