235 lines
6.6 KiB
HTML
235 lines
6.6 KiB
HTML
<html>
|
|
<head>
|
|
<meta charset="UTF-8">
|
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
<style>
|
|
:root {
|
|
--ps-blue: #0070cc;
|
|
--ps-cyan: #1eaedb;
|
|
--ps-white: #ffffff;
|
|
--ink: #1f1f1f;
|
|
--muted: #6b6b6b;
|
|
--line: #f3f3f3;
|
|
--ok: #0f7a4f;
|
|
--ok-bg: #e9f9f1;
|
|
--off: #9f2f2f;
|
|
--off-bg: #feefef;
|
|
}
|
|
* { box-sizing: border-box; }
|
|
body {
|
|
margin: 0;
|
|
padding: 16px;
|
|
font-family: "PlayStation SST", "SST", "PingFang SC", "Noto Sans CJK SC", sans-serif;
|
|
background: linear-gradient(180deg, #f5f7fa 0%, #ffffff 100%);
|
|
color: var(--ink);
|
|
}
|
|
.page {
|
|
width: 980px;
|
|
margin: 0 auto;
|
|
background: #fff;
|
|
border: 1px solid #dfe6ef;
|
|
border-radius: 24px;
|
|
overflow: hidden;
|
|
box-shadow: rgba(0, 0, 0, 0.08) 0 5px 9px 0;
|
|
}
|
|
.hero {
|
|
padding: 28px 30px 24px 30px;
|
|
background: linear-gradient(180deg, #121314 0%, #000000 100%);
|
|
color: var(--ps-white);
|
|
}
|
|
.hero h1 {
|
|
margin: 0 0 8px 0;
|
|
font-size: 44px;
|
|
font-weight: 300;
|
|
line-height: 1.25;
|
|
letter-spacing: .1px;
|
|
}
|
|
.hero-sub {
|
|
margin: 0;
|
|
font-size: 18px;
|
|
line-height: 1.5;
|
|
color: rgba(255,255,255,.86);
|
|
}
|
|
.hero-meta {
|
|
margin-top: 14px;
|
|
display: flex;
|
|
gap: 10px;
|
|
flex-wrap: wrap;
|
|
}
|
|
.meta-pill {
|
|
padding: 6px 12px;
|
|
border-radius: 999px;
|
|
font-size: 14px;
|
|
background: rgba(255,255,255,0.10);
|
|
border: 1px solid rgba(255,255,255,0.16);
|
|
}
|
|
.meta-pill strong { font-weight: 700; }
|
|
.content {
|
|
padding: 22px 24px 20px 24px;
|
|
background: linear-gradient(180deg, #ffffff 0%, #f5f7fa 100%);
|
|
}
|
|
.block {
|
|
border: 1px solid var(--line);
|
|
border-radius: 20px;
|
|
padding: 16px 18px;
|
|
margin-bottom: 14px;
|
|
background: #fff;
|
|
box-shadow: rgba(0, 0, 0, 0.06) 0 5px 9px 0;
|
|
}
|
|
.block h2 {
|
|
margin: 0;
|
|
font-size: 22px;
|
|
font-weight: 300;
|
|
line-height: 1.25;
|
|
letter-spacing: .1px;
|
|
color: #000;
|
|
}
|
|
.feature-list {
|
|
margin-top: 14px;
|
|
display: grid;
|
|
grid-template-columns: repeat(3, minmax(0, 1fr));
|
|
gap: 10px;
|
|
}
|
|
.feature-card {
|
|
border: 1px solid #e6edf5;
|
|
border-radius: 19px;
|
|
padding: 12px 13px;
|
|
background: #fff;
|
|
box-shadow: rgba(0, 0, 0, 0.08) 0 5px 9px 0;
|
|
transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
|
|
}
|
|
.feature-card:hover {
|
|
transform: scale(1.02);
|
|
border-color: var(--ps-cyan);
|
|
box-shadow: rgba(0, 0, 0, 0.16) 0 5px 9px 0;
|
|
}
|
|
.feature-top { display: flex; align-items: center; gap: 8px; }
|
|
.feature-index {
|
|
min-width: 38px;
|
|
text-align: center;
|
|
font-weight: 700;
|
|
color: var(--ps-blue);
|
|
background: #eef6ff;
|
|
border: 1px solid #d3e8ff;
|
|
border-radius: 12px;
|
|
padding: 4px 6px;
|
|
font-size: 9px;
|
|
}
|
|
.feature-meta { flex: 1; }
|
|
.feature-meta h3 {
|
|
margin: 0 0 2px 0;
|
|
font-size: 12px;
|
|
font-weight: 300;
|
|
line-height: 1.25;
|
|
letter-spacing: .1px;
|
|
color: #000;
|
|
}
|
|
.feature-key { margin: 0; font-size: 12px; color: var(--muted); }
|
|
.status-badge {
|
|
font-size: 9px;
|
|
font-weight: 700;
|
|
padding: 4px 10px;
|
|
border-radius: 999px;
|
|
border: 1px solid transparent;
|
|
white-space: nowrap;
|
|
}
|
|
.status-on {
|
|
color: var(--ok);
|
|
background: var(--ok-bg);
|
|
border-color: #bde8d2;
|
|
}
|
|
.status-off {
|
|
color: var(--off);
|
|
background: var(--off-bg);
|
|
border-color: #f3c7c7;
|
|
}
|
|
.feature-body {
|
|
margin-top: 10px;
|
|
padding: 10px 12px;
|
|
border-radius: 12px;
|
|
background: #f8fbff;
|
|
border: 1px dashed #d6e6f7;
|
|
}
|
|
.feature-body p { margin: 0; font-size: 11px; color: #1f1f1f; line-height: 1.5; }
|
|
.line-main { color: #1f1f1f; }
|
|
.line-sub { color: #6b6b6b; display: inline-block; margin-top: 5px; }
|
|
code {
|
|
background: #eef6ff;
|
|
border: 1px solid #d2e6ff;
|
|
color: #0068bd;
|
|
padding: 1px 7px;
|
|
border-radius: 999px;
|
|
font-size: 9px;
|
|
}
|
|
.footer {
|
|
background: var(--ps-blue);
|
|
color: #fff;
|
|
padding: 14px 20px;
|
|
display: flex;
|
|
justify-content: space-between;
|
|
align-items: center;
|
|
font-size: 14px;
|
|
}
|
|
.footer a {
|
|
color: #fff;
|
|
text-decoration: none;
|
|
border-bottom: 1px dashed rgba(255,255,255,.55);
|
|
}
|
|
</style>
|
|
</head>
|
|
<body>
|
|
<div class="page">
|
|
<header class="hero">
|
|
<h1>机器人功能菜单</h1>
|
|
<p class="hero-sub">用户功能查看中心 · 直达命令与状态一屏可见</p>
|
|
<div class="hero-meta">
|
|
<span class="meta-pill">目标:<strong>{{ group_id }}</strong></span>
|
|
<span class="meta-pill">功能总数:<strong>{{ feature_total }}</strong></span>
|
|
<span class="meta-pill">已开启:<strong>{{ enabled_count }}</strong></span>
|
|
<span class="meta-pill">生成时间:<strong>{{ now_text }}</strong></span>
|
|
</div>
|
|
</header>
|
|
<main class="content">
|
|
<section class="block">
|
|
<h2>功能卡片</h2>
|
|
<div class="feature-list">
|
|
{% for item in feature_cards %}
|
|
<section class="feature-card">
|
|
<div class="feature-top">
|
|
<div class="feature-index">{{ "%02d"|format(item.index) }}</div>
|
|
<div class="feature-meta">
|
|
<h3>{{ item.title }}</h3>
|
|
<p class="feature-key">功能键:<code>{{ item.feature_key }}</code></p>
|
|
</div>
|
|
<span class="status-badge {{ item.status_class }}">{{ item.status_text }}</span>
|
|
</div>
|
|
<div class="feature-body">
|
|
{% if item.command.is_auto %}
|
|
<p><span class="line-main">{{ item.command.tip }}</span></p>
|
|
{% else %}
|
|
<p>
|
|
<span class="line-main">指令:<code>{{ item.command.primary }}</code></span>
|
|
{% if item.command.aliases %}
|
|
<span class="line-sub">
|
|
别名:
|
|
{% for alias in item.command.aliases %}
|
|
<code>{{ alias }}</code>{% if not loop.last %} / {% endif %}
|
|
{% endfor %}
|
|
</span>
|
|
{% endif %}
|
|
</p>
|
|
{% endif %}
|
|
</div>
|
|
</section>
|
|
{% endfor %}
|
|
</div>
|
|
</section>
|
|
</main>
|
|
<footer class="footer">
|
|
<span>ABOT 功能菜单</span>
|
|
<a href="javascript:void(0)">菜单</a>
|
|
</footer>
|
|
</div>
|
|
</body>
|
|
</html>
|