Umsetzung Aufgabenverwaltung

This commit is contained in:
2026-03-02 15:33:35 +01:00
parent c922ef6668
commit abf85f66e4
43 changed files with 6617 additions and 2103 deletions

View File

@@ -6,19 +6,274 @@
<title>XXX The Game</title>
<link rel="stylesheet" href="/css/variables.css">
<link rel="stylesheet" href="/css/style.css">
<style>
body {
display: block;
min-height: 100vh;
}
/* ── Layout ── */
.layout {
display: flex;
min-height: 100vh;
}
/* ── Sidebar ── */
.sidebar {
width: 240px;
background: var(--color-card);
border-right: 1px solid var(--color-secondary);
display: flex;
flex-direction: column;
position: fixed;
top: 0;
left: 0;
height: 100vh;
overflow-y: auto;
z-index: 100;
transition: transform 0.25s ease;
}
.sidebar-brand {
color: var(--color-primary);
font-size: 1.1rem;
font-weight: 700;
padding: 1.25rem 1.25rem 1rem;
border-bottom: 1px solid var(--color-secondary);
flex-shrink: 0;
}
.sidebar ul {
list-style: none;
padding: 0.5rem 0;
}
.sidebar ul li a {
display: flex;
align-items: center;
gap: 0.75rem;
padding: 0.7rem 1.25rem;
color: var(--color-text);
text-decoration: none;
font-size: 0.95rem;
border-left: 3px solid transparent;
transition: background 0.15s, color 0.15s, border-color 0.15s;
}
.sidebar ul li a:hover,
.sidebar ul li a.active {
background: var(--color-secondary);
color: var(--color-primary);
border-left-color: var(--color-primary);
}
.sidebar ul li a .icon {
font-size: 1rem;
width: 1.2rem;
text-align: center;
flex-shrink: 0;
}
/* ── Main ── */
.main {
margin-left: 240px;
flex: 1;
display: flex;
flex-direction: column;
min-height: 100vh;
}
/* ── Topbar ── */
.topbar {
display: flex;
align-items: center;
gap: 1rem;
padding: 0.9rem 1.5rem;
background: var(--color-card);
border-bottom: 1px solid var(--color-secondary);
position: sticky;
top: 0;
z-index: 50;
}
.topbar h1 {
font-size: 1.2rem;
font-weight: 600;
}
.burger {
display: none;
background: none;
border: none;
cursor: pointer;
color: var(--color-text);
padding: 0.25rem 0.4rem;
border-radius: 4px;
transition: background 0.15s;
flex-shrink: 0;
}
.burger:hover {
background: var(--color-secondary);
}
.burger-icon {
display: flex;
flex-direction: column;
gap: 5px;
width: 22px;
}
.burger-icon span {
display: block;
height: 2px;
background: var(--color-text);
border-radius: 2px;
transition: transform 0.25s, opacity 0.25s;
}
.burger.open .burger-icon span:nth-child(1) {
transform: translateY(7px) rotate(45deg);
}
.burger.open .burger-icon span:nth-child(2) {
opacity: 0;
}
.burger.open .burger-icon span:nth-child(3) {
transform: translateY(-7px) rotate(-45deg);
}
/* ── Content ── */
.content {
padding: 2rem 1.5rem;
flex: 1;
}
/* ── Overlay ── */
.overlay {
display: none;
position: fixed;
inset: 0;
background: rgba(0, 0, 0, 0.55);
z-index: 90;
}
/* ── Mobile ── */
@media (max-width: 768px) {
.sidebar {
transform: translateX(-100%);
}
.sidebar.open {
transform: translateX(0);
box-shadow: 4px 0 20px rgba(0, 0, 0, 0.5);
}
.main {
margin-left: 0;
}
.burger {
display: flex;
}
.overlay.visible {
display: block;
}
}
</style>
</head>
<body>
<h1>XXX The Game</h1>
<p id="greeting"></p>
<div class="overlay" id="overlay"></div>
<div class="layout">
<aside class="sidebar" id="sidebar">
<div class="sidebar-brand">XXX The Game</div>
<ul>
<li><a href="#" class="active"><span class="icon"></span> Dashboard</a></li>
<li><a href="#"><span class="icon"></span> Meine Session</a></li>
<li><a href="/aufgaben.html"><span class="icon"></span> Aufgaben</a></li>
<li><a href="/entdecken.html"><span class="icon"></span> Entdecken</a></li>
<li><a href="#"><span class="icon"></span> Strafen</a></li>
<li><a href="/toys.html"><span class="icon"></span> Toys</a></li>
<li><a href="#"><span class="icon"></span> Favoriten</a></li>
<li><a href="#"><span class="icon"></span> Rangliste</a></li>
<li><a href="#"><span class="icon"></span> Nachrichten</a></li>
<li><a href="#"><span class="icon"></span> Einstellungen</a></li>
<li><a href="#" id="logoutLink"><span class="icon"></span> Abmelden</a></li>
</ul>
</aside>
<div class="main">
<header class="topbar">
<button class="burger" id="burgerBtn" aria-label="Menü öffnen">
<span class="burger-icon">
<span></span>
<span></span>
<span></span>
</span>
</button>
<h1>XXX The Game</h1>
</header>
<div class="content">
<p id="greeting"></p>
</div>
</div>
</div>
<script>
const userJson = sessionStorage.getItem('user');
if (!userJson) {
window.location.href = '/login.html';
} else {
const user = JSON.parse(userJson);
document.getElementById('greeting').textContent = 'Willkommen, ' + user.name + '!';
// ── Auth check ──
fetch('/login/me')
.then(response => {
if (response.status === 401) {
window.location.href = '/login.html';
return null;
}
return response.json();
})
.then(user => {
if (user) {
document.getElementById('greeting').textContent = 'Willkommen, ' + user.name + '!';
}
})
.catch(() => {
window.location.href = '/login.html';
});
// ── Burger menu ──
const sidebar = document.getElementById('sidebar');
const burgerBtn = document.getElementById('burgerBtn');
const overlay = document.getElementById('overlay');
function openMenu() {
sidebar.classList.add('open');
overlay.classList.add('visible');
burgerBtn.classList.add('open');
burgerBtn.setAttribute('aria-label', 'Menü schließen');
}
function closeMenu() {
sidebar.classList.remove('open');
overlay.classList.remove('visible');
burgerBtn.classList.remove('open');
burgerBtn.setAttribute('aria-label', 'Menü öffnen');
}
burgerBtn.addEventListener('click', () => {
sidebar.classList.contains('open') ? closeMenu() : openMenu();
});
overlay.addEventListener('click', closeMenu);
// Close on nav link click (mobile)
sidebar.querySelectorAll('a').forEach(link => {
link.addEventListener('click', () => {
if (window.innerWidth <= 768) closeMenu();
});
});
</script>
</body>
</html>