2025-06-10 12:56:31 +08:00

345 lines
10 KiB
HTML

<!DOCTYPE html>
<html lang="zh-Hant">
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1" />
<title>功能列</title>
<style>
html, body {
height: 100%;
margin: 0;
padding: 0;
font-family: Arial, sans-serif;
background-color: #ffffff;
}
* {
box-sizing: border-box;
}
.sidebar {
width: 100%;
height: 100%;
background-color: #f8f9fa;
border-right: 1px solid #ddd;
overflow-y: auto;
overflow-x: hidden;
}
.sidebar img {
display: block;
margin: 20px auto;
width: 60px;
height: 60px;
border-radius: 50%;
}
.sidebar ul {
list-style: none;
padding: 0;
margin: 0;
}
.sidebar ul li {
color: #333;
cursor: pointer;
padding: 12px 20px;
transition: background 0.2s ease;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
max-width: 100%;
}
.sidebar ul li:hover,
.sidebar ul li.active {
background-color: #e6f0f8;
color: #007bff;
}
.has-submenu > .submenu-toggle,
.li-content {
display: flex;
justify-content: space-between;
align-items: center;
gap: 6px;
}
.submenu-toggle > span:first-child,
.li-content > span:first-child {
flex-grow: 1;
min-width: 0;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
}
.parent-badge,
.badge {
display: inline-flex;
justify-content: center;
align-items: center;
min-width: 20px;
height: 20px;
padding: 2px 6px;
font-size: 12px;
font-weight: bold;
color: white;
background-color: red;
border-radius: 10px;
text-align: center;
white-space: nowrap;
line-height: 1;
flex-shrink: 0;
}
.parent-badge {
display: none;
}
.submenu-arrow {
font-size: 12px;
user-select: none;
}
.has-submenu ul {
list-style: none;
padding-left: 15px;
margin: 0;
max-height: 0;
overflow: hidden;
transition: max-height 0.3s ease, padding 0.3s ease;
}
.has-submenu.open ul {
padding-top: 5px;
max-height: 200px;
}
.has-submenu ul li {
padding: 10px 20px;
font-size: 16px;
color: #444;
}
.has-submenu ul li:hover {
background-color: #deeaf6;
}
</style>
</head>
<body>
<div class="sidebar">
<img src="https://cdn-icons-png.freepik.com/512/4873/4873262.png" alt="Logo" />
<ul>
<li class="active" onclick="requestNavigation('dashboard.html', this)">首頁</li>
<li class="has-submenu">
<div class="submenu-toggle" onclick="toggleSubmenu(this)">
<span>住戶居民</span>
<span class="parent-badge"></span>
<span class="submenu-arrow"></span>
</div>
<ul>
<li onclick="requestNavigation('resident_activation.html', this)">
<div class="li-content">
<span>未開通居民</span>
<span class="badge" data-count="8">8</span>
</div>
</li>
<li onclick="requestNavigation('resident_list.html', this)">居民列表</li>
</ul>
</li>
<li class="has-submenu">
<div class="submenu-toggle" onclick="toggleSubmenu(this)">
<span>警急通報</span>
<span class="parent-badge"></span>
<span class="submenu-arrow"></span>
</div>
<ul>
<li onclick="requestNavigation('notification.html', this)">發送通報</li>
<li onclick="requestNavigation('notice_list.html', this)">
<div class="li-content">
<span>居民通報</span>
<span class="badge" data-count="99">99</span>
</div>
</li>
</ul>
</li>
<li class="has-submenu">
<div class="submenu-toggle" onclick="toggleSubmenu(this)">
<span>廣告</span>
<span class="parent-badge"></span>
<span class="submenu-arrow"></span>
</div>
<ul>
<li onclick="requestNavigation('carousel_ads_list.html', this)">首頁輪播廣告</li>
<li onclick="requestNavigation('marquee_ads_list.html', this)">跑馬登廣告</li>
</ul>
</li>
<li onclick="requestNavigation('resident_log_list.html', this)">出入管理</li>
<li class="has-submenu">
<div class="submenu-toggle" onclick="toggleSubmenu(this)">
<span>居民訊息</span>
<span class="parent-badge"></span>
<span class="submenu-arrow"></span>
</div>
<ul>
<li onclick="requestNavigation('message_list.html', this)">
<div class="li-content">
<span>居民訊息</span>
<span class="badge" data-count="99">99</span>
</div>
</li>
<li onclick="requestNavigation('quick_message_list.html', this)">快速訊息</li>
</ul>
</li>
<li class="has-submenu">
<div class="submenu-toggle" onclick="toggleSubmenu(this)">
<span>水電報修</span>
<span class="parent-badge"></span>
<span class="submenu-arrow"></span>
</div>
<ul>
<li onclick="requestNavigation('repair_list.html', this)">
<div class="li-content">
<span>報修申請</span>
<span class="badge" data-count="99">99</span>
</div>
</li>
<li onclick="requestNavigation('repair_firm_list.html', this)">報修廠商</li>
</ul>
</li>
<li onclick="requestNavigation('feedback_list.html', this)">
<div class="li-content">
<span>意見回饋</span>
<span class="badge" data-count="99">99</span>
<span class="submenu-arrow">&emsp;</span>
</div>
</li>
<li onclick="requestNavigation('activity_list.html', this)">
<div class="li-content">
<span>社區活動</span>
<span class="badge" data-count="99">99</span>
<span class="submenu-arrow">&emsp;</span>
</div>
</li>
<li class="has-submenu">
<div class="submenu-toggle" onclick="toggleSubmenu(this)">
<span>郵件管理</span>
<span class="parent-badge"></span>
<span class="submenu-arrow"></span>
</div>
<ul>
<li onclick="requestNavigation('parcel_list.html', this)">郵件管理</li>
<li onclick="requestNavigation('mailing_firm_list.html', this)">郵寄廠商</li>
</ul>
</li>
<li class="has-submenu">
<div class="submenu-toggle" onclick="toggleSubmenu(this)">
<span>訪客管理</span>
<span class="parent-badge"></span>
<span class="submenu-arrow"></span>
</div>
<ul>
<li onclick="requestNavigation('visitor_list.html', this)">訪客管理</li>
<li onclick="requestNavigation('visitor_role_list.html', this)">訪客身分</li>
<li onclick="requestNavigation('purpose_list.html', this)">訪客事由</li>
</ul>
</li>
<li class="has-submenu">
<div class="submenu-toggle" onclick="toggleSubmenu(this)">
<span>公告管理</span>
<span class="parent-badge"></span>
<span class="submenu-arrow"></span>
</div>
<ul>
<li onclick="requestNavigation('announcement_list.html', this)">公告管理</li>
<li onclick="requestNavigation('announcement_title_list.html', this)">公告標題</li>
</ul>
</li>
<li class="has-submenu">
<div class="submenu-toggle" onclick="toggleSubmenu(this)">
<span>繳費通知</span>
<span class="parent-badge"></span>
<span class="submenu-arrow"></span>
</div>
<ul>
<li onclick="requestNavigation('fee_list.html', this)">繳費通知</li>
<li onclick="requestNavigation('payment_item_list.html', this)">繳費項目</li>
</ul>
</li>
<li onclick="requestNavigation('admin_list.html', this)">管理員設定</li>
<li onclick="requestNavigation('community_edit.html', this)">設定</li>
<li onclick="window.top.location.href='login.html';" style="cursor:pointer;">登出</li>
</ul>
</div>
<script>
function requestNavigation(url, clickedElement) {
console.log('Sidebar: 發送導航請求 ->', url);
parent.postMessage({ type: 'navigate', url: url }, '*');
const allItems = document.querySelectorAll('.sidebar ul li, .sidebar ul ul li');
allItems.forEach(item => item.classList.remove('active'));
clickedElement.classList.add('active');
if (clickedElement.closest('.has-submenu ul')) {
const parentLi = clickedElement.closest('.has-submenu');
if (parentLi) {
document.querySelectorAll('.sidebar > ul > li').forEach(li => li.classList.remove('active'));
parentLi.classList.add('active');
}
} else {
document.querySelectorAll('.sidebar > ul > li').forEach(li => li.classList.remove('active'));
clickedElement.classList.add('active');
}
}
function toggleSubmenu(toggleElement) {
const parentLi = toggleElement.closest('.has-submenu');
parentLi.classList.toggle('open');
const arrow = toggleElement.querySelector('.submenu-arrow');
if (arrow) {
arrow.textContent = parentLi.classList.contains('open') ? '▲' : '▼';
}
updateParentBadges();
}
function updateParentBadges() {
const submenuParents = document.querySelectorAll('.has-submenu');
submenuParents.forEach(parent => {
const isOpen = parent.classList.contains('open');
const badgeContainer = parent.querySelector('.parent-badge');
const subBadges = parent.querySelectorAll('ul .badge');
let total = 0;
subBadges.forEach(badge => {
const raw = badge.getAttribute('data-count');
const val = parseInt(raw, 10);
if (!isNaN(val)) total += val;
});
if (!isOpen && total > 0) {
badgeContainer.textContent = total;
badgeContainer.style.display = 'inline-flex';
} else {
badgeContainer.style.display = 'none';
badgeContainer.textContent = '';
}
});
}
document.addEventListener('DOMContentLoaded', () => {
updateParentBadges();
});
</script>
</body>
</html>