2025-07-09 05:22:28 +08:00

124 lines
5.0 KiB
HTML

<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>{% block title %}太白购物商城 - 管理后台{% endblock %}</title>
<!-- Bootstrap CSS -->
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.1.3/dist/css/bootstrap.min.css" rel="stylesheet">
<!-- Bootstrap Icons -->
<link href="https://cdn.jsdelivr.net/npm/bootstrap-icons@1.8.1/font/bootstrap-icons.css" rel="stylesheet">
<!-- Admin Base CSS -->
<link href="{{ url_for('static', filename='css/admin_base.css') }}" rel="stylesheet">
{% block extra_css %}{% endblock %}
</head>
<body>
<!-- 侧边栏 -->
<div class="admin-sidebar">
<div class="sidebar-brand">
<i class="bi bi-shop"></i>
太白购物商城
</div>
<ul class="nav flex-column">
<li class="nav-item">
<a class="nav-link {% if request.endpoint == 'admin.dashboard' %}active{% endif %}"
href="{{ url_for('admin.dashboard') }}">
<i class="bi bi-speedometer2"></i>
仪表板
</a>
</li>
<li class="nav-item">
<a class="nav-link {% if request.endpoint == 'admin.users' %}active{% endif %}"
href="{{ url_for('admin.users') }}">
<i class="bi bi-people"></i>
用户管理
</a>
</li>
<li class="nav-item">
<a class="nav-link {% if request.endpoint.startswith('product.') %}active{% endif %}"
href="{{ url_for('product.index') }}">
<i class="bi bi-box"></i>
商品管理
</a>
</li>
<li class="nav-item">
<a class="nav-link {% if request.endpoint.startswith('admin.order') %}active{% endif %}"
href="{{ url_for('admin.orders') }}">
<i class="bi bi-receipt"></i>
订单管理
</a>
</li>
<li class="nav-item">
<a class="nav-link {% if request.endpoint == 'admin.logs' %}active{% endif %}"
href="{{ url_for('admin.logs') }}">
<i class="bi bi-journal-text"></i>
操作日志
</a>
</li>
<li class="nav-item">
<a class="nav-link {% if request.endpoint == 'admin.profile' %}active{% endif %}"
href="{{ url_for('admin.profile') }}">
<i class="bi bi-person-gear"></i>
个人资料
</a>
</li>
</ul>
</div>
<!-- 主要内容区域 -->
<div class="admin-main">
<!-- 顶部导航 -->
<div class="admin-header d-flex justify-content-between align-items-center">
<div>
<h4 class="mb-0">{% block page_title %}管理后台{% endblock %}</h4>
<small class="text-muted">{% block page_description %}{% endblock %}</small>
</div>
<div class="d-flex align-items-center">
<div class="dropdown">
<a class="btn btn-link text-decoration-none dropdown-toggle" href="#" role="button"
data-bs-toggle="dropdown" aria-expanded="false">
<i class="bi bi-person-circle"></i>
{{ session.admin_username }}
</a>
<ul class="dropdown-menu">
<li><a class="dropdown-item" href="{{ url_for('admin.profile') }}">
<i class="bi bi-person-gear"></i> 个人资料
</a></li>
<li><hr class="dropdown-divider"></li>
<li><a class="dropdown-item" href="{{ url_for('admin.logout') }}">
<i class="bi bi-box-arrow-right"></i> 退出登录
</a></li>
</ul>
</div>
</div>
</div>
<!-- 内容区域 -->
<div class="admin-content">
<!-- 消息提示 -->
{% with messages = get_flashed_messages(with_categories=true) %}
{% if messages %}
{% for category, message in messages %}
<div class="alert alert-{{ 'danger' if category == 'error' else category }} alert-dismissible fade show" role="alert">
{{ message }}
<button type="button" class="btn-close" data-bs-dismiss="alert" aria-label="Close"></button>
</div>
{% endfor %}
{% endif %}
{% endwith %}
{% block content %}{% endblock %}
</div>
</div>
<!-- Bootstrap JS -->
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.1.3/dist/js/bootstrap.bundle.min.js"></script>
{% block extra_js %}{% endblock %}
</body>
</html>