Files
abot/plugins/robot_menu/templates/menu_cards.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>