Merge branch 'dev' of https://github.com/Fairy-Oracle-Sanctuary/NeoBot into dev
This commit is contained in:
@@ -19,7 +19,7 @@ token = ""
|
|||||||
# Bot 基础配置
|
# Bot 基础配置
|
||||||
[bot]
|
[bot]
|
||||||
# 命令前缀列表
|
# 命令前缀列表
|
||||||
command = ["/"]
|
command = ["。"]
|
||||||
# 是否忽略自己的消息
|
# 是否忽略自己的消息
|
||||||
ignore_self_message = true
|
ignore_self_message = true
|
||||||
# 权限不足时的消息
|
# 权限不足时的消息
|
||||||
|
|||||||
71
web_static/changelog_generator/generate.py
Normal file
71
web_static/changelog_generator/generate.py
Normal file
@@ -0,0 +1,71 @@
|
|||||||
|
import os
|
||||||
|
import sys
|
||||||
|
from datetime import datetime
|
||||||
|
from jinja2 import Environment, FileSystemLoader
|
||||||
|
|
||||||
|
# ==========================================
|
||||||
|
# 配置区域
|
||||||
|
# ==========================================
|
||||||
|
|
||||||
|
# 输出文件路径 (相对于当前脚本或绝对路径)
|
||||||
|
OUTPUT_FILE = "../changelog.html"
|
||||||
|
|
||||||
|
# 更新日志数据
|
||||||
|
# 格式说明:
|
||||||
|
# version: 版本号
|
||||||
|
# date: 日期 (YYYY-MM-DD)
|
||||||
|
# description: 版本描述 (可选)
|
||||||
|
# changes: 变更列表
|
||||||
|
# - type: 类型 (add, update, fix)
|
||||||
|
# - content: 变更内容
|
||||||
|
changelogs = [
|
||||||
|
{
|
||||||
|
"version": "v1.0.0",
|
||||||
|
"date": "2026-3-1",
|
||||||
|
"description": "引入了更多有趣的互动功能,并优化了系统稳定性。",
|
||||||
|
"changes": [
|
||||||
|
{"type": "add", "content": "新增了天气查询功能,支持全国主要城市"},
|
||||||
|
{"type": "update", "content": "优化了 Web Parser 的解析速度,不过b站的视频解析等待重做中"},
|
||||||
|
{"type": "fix", "content": "修复了在某些特定网络环境下图片加载失败的问题"},
|
||||||
|
{"type": "update", "content": "支持多实现端连接(反向WS),此功能并不完善,等待重做"}
|
||||||
|
|
||||||
|
|
||||||
|
]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
|
||||||
|
# ==========================================
|
||||||
|
# 生成逻辑 (通常不需要修改)
|
||||||
|
# ==========================================
|
||||||
|
|
||||||
|
def generate_changelog():
|
||||||
|
# 获取当前脚本所在目录
|
||||||
|
base_dir = os.path.dirname(os.path.abspath(__file__))
|
||||||
|
|
||||||
|
# 设置 Jinja2 环境
|
||||||
|
env = Environment(loader=FileSystemLoader(base_dir))
|
||||||
|
template = env.get_template("template.html")
|
||||||
|
|
||||||
|
# 获取最新版本号
|
||||||
|
latest_version = changelogs[0]["version"] if changelogs else "v0.0.0"
|
||||||
|
|
||||||
|
# 渲染模板
|
||||||
|
html_content = template.render(
|
||||||
|
log=changelogs[0] if changelogs else None,
|
||||||
|
latest_version=latest_version,
|
||||||
|
generated_at=datetime.now().strftime("%Y-%m-%d %H:%M:%S")
|
||||||
|
)
|
||||||
|
|
||||||
|
# 确定输出路径
|
||||||
|
output_path = os.path.join(base_dir, OUTPUT_FILE)
|
||||||
|
|
||||||
|
# 写入文件
|
||||||
|
try:
|
||||||
|
with open(output_path, "w", encoding="utf-8") as f:
|
||||||
|
f.write(html_content)
|
||||||
|
print(f"✅ 成功生成更新日志: {os.path.abspath(output_path)}")
|
||||||
|
except Exception as e:
|
||||||
|
print(f"❌ 生成失败: {e}")
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
generate_changelog()
|
||||||
187
web_static/changelog_generator/template.html
Normal file
187
web_static/changelog_generator/template.html
Normal file
@@ -0,0 +1,187 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
<html lang="zh-CN" class="scroll-smooth">
|
||||||
|
<head>
|
||||||
|
<meta charset="UTF-8">
|
||||||
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||||
|
<title>NEOBOT | Changelog</title>
|
||||||
|
<script src="https://cdn.tailwindcss.com"></script>
|
||||||
|
<link rel="preconnect" href="https://fonts.googleapis.com">
|
||||||
|
<link href="https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;500;700&family=Inter:wght@300;400;600&family=Noto+Serif+SC:wght@300;400;700&family=Cormorant+Garamond:ital,wght@0,400;1,400&display=swap" rel="stylesheet">
|
||||||
|
<script src="https://code.iconify.design/iconify-icon/1.0.7/iconify-icon.min.js"></script>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
tailwind.config = {
|
||||||
|
theme: {
|
||||||
|
extend: {
|
||||||
|
fontFamily: {
|
||||||
|
sans: ['"Inter"', 'sans-serif'],
|
||||||
|
display: ['"Space Grotesk"', 'sans-serif'],
|
||||||
|
serif: ['"Noto Serif SC"', 'serif'],
|
||||||
|
lyric: ['"Cormorant Garamond"', 'serif'],
|
||||||
|
},
|
||||||
|
colors: {
|
||||||
|
brand: {
|
||||||
|
bg: '#050505',
|
||||||
|
surface: '#121212',
|
||||||
|
border: '#27272a',
|
||||||
|
text: '#e4e4e7',
|
||||||
|
muted: '#a1a1aa',
|
||||||
|
}
|
||||||
|
},
|
||||||
|
animation: {
|
||||||
|
'fade-in-up': 'fadeInUp 1s cubic-bezier(0.16, 1, 0.3, 1) forwards',
|
||||||
|
'pulse-slow': 'pulse 4s cubic-bezier(0.4, 0, 0.6, 1) infinite',
|
||||||
|
},
|
||||||
|
keyframes: {
|
||||||
|
fadeInUp: {
|
||||||
|
'0%': { opacity: '0', transform: 'translateY(20px)' },
|
||||||
|
'100%': { opacity: '1', transform: 'translateY(0)' },
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
<style>
|
||||||
|
body {
|
||||||
|
background-color: #050505;
|
||||||
|
color: #e4e4e7;
|
||||||
|
background-image: radial-gradient(circle at 50% 0%, #1a1a1a 0%, #050505 60%);
|
||||||
|
background-attachment: fixed;
|
||||||
|
}
|
||||||
|
|
||||||
|
.changelog-card {
|
||||||
|
background: rgba(18, 18, 18, 0.6);
|
||||||
|
backdrop-filter: blur(12px);
|
||||||
|
border: 1px solid rgba(255, 255, 255, 0.08);
|
||||||
|
border-radius: 8px;
|
||||||
|
transition: all 0.3s ease;
|
||||||
|
}
|
||||||
|
.changelog-card:hover {
|
||||||
|
border-color: rgba(255, 255, 255, 0.2);
|
||||||
|
background: rgba(30, 30, 30, 0.8);
|
||||||
|
transform: translateY(-2px);
|
||||||
|
}
|
||||||
|
|
||||||
|
.lyric-text {
|
||||||
|
font-family: "Cormorant Garamond", serif;
|
||||||
|
font-style: italic;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Timeline line */
|
||||||
|
.timeline-line {
|
||||||
|
position: absolute;
|
||||||
|
left: 24px;
|
||||||
|
top: 0;
|
||||||
|
bottom: 0;
|
||||||
|
width: 1px;
|
||||||
|
background: linear-gradient(to bottom, rgba(255,255,255,0.1), rgba(255,255,255,0.05));
|
||||||
|
}
|
||||||
|
|
||||||
|
::-webkit-scrollbar { width: 6px; }
|
||||||
|
::-webkit-scrollbar-track { background: #050505; }
|
||||||
|
::-webkit-scrollbar-thumb { background: #333; border-radius: 3px; }
|
||||||
|
</style>
|
||||||
|
</head>
|
||||||
|
<body class="antialiased selection:bg-white/20 selection:text-white">
|
||||||
|
|
||||||
|
<!-- 导航 -->
|
||||||
|
<nav class="fixed top-0 w-full z-50 border-b border-white/5 bg-black/80 backdrop-blur-md">
|
||||||
|
<div class="max-w-6xl mx-auto px-6 h-20 flex items-center justify-between">
|
||||||
|
<div class="flex items-center gap-3">
|
||||||
|
<a href="../index.html" class="flex items-center gap-3 hover:opacity-80 transition-opacity">
|
||||||
|
<div class="w-2 h-2 bg-white rounded-full animate-pulse-slow"></div>
|
||||||
|
<span class="font-display font-bold text-sm tracking-widest text-white">NEO<span class="text-white/40 font-light">BOT</span></span>
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="flex items-center gap-4 text-[10px] font-mono text-gray-400 uppercase tracking-widest">
|
||||||
|
<span class="px-2 py-1 rounded border border-white/10 bg-white/5">Changelog</span>
|
||||||
|
<span>Latest: {{ latest_version }}</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</nav>
|
||||||
|
|
||||||
|
<main class="pt-40 pb-32 px-6">
|
||||||
|
<div class="max-w-4xl mx-auto space-y-16">
|
||||||
|
|
||||||
|
<!-- Header -->
|
||||||
|
<section class="text-center space-y-4 animate-fade-in-up">
|
||||||
|
<div class="font-mono text-xs text-gray-500 mb-2">PROJECT HISTORY</div>
|
||||||
|
<h1 class="text-4xl md:text-6xl font-display font-bold text-white leading-tight">
|
||||||
|
System<br>
|
||||||
|
<span class="text-white/30">Evolution</span>
|
||||||
|
</h1>
|
||||||
|
<p class="font-serif text-lg text-gray-400 max-w-2xl mx-auto">
|
||||||
|
记录每一次微小的改变,见证成长的轨迹。
|
||||||
|
</p>
|
||||||
|
</section>
|
||||||
|
|
||||||
|
<!-- Changelog Card -->
|
||||||
|
<section class="max-w-2xl mx-auto">
|
||||||
|
<div class="changelog-card p-8 md:p-10 relative overflow-hidden group">
|
||||||
|
<!-- Decorative background glow -->
|
||||||
|
<div class="absolute top-0 right-0 -mr-16 -mt-16 w-64 h-64 bg-white/5 rounded-full blur-3xl group-hover:bg-white/10 transition-colors duration-500"></div>
|
||||||
|
|
||||||
|
<!-- Version & Date -->
|
||||||
|
<div class="relative z-10 flex flex-col md:flex-row md:items-end justify-between gap-4 mb-8 border-b border-white/10 pb-6">
|
||||||
|
<div>
|
||||||
|
<div class="flex items-center gap-3 mb-2">
|
||||||
|
<h2 class="font-display text-4xl text-white font-bold">{{ log.version }}</h2>
|
||||||
|
<span class="px-2 py-0.5 rounded text-[10px] font-mono font-bold bg-white/10 text-white/60 border border-white/10">LATEST</span>
|
||||||
|
</div>
|
||||||
|
<div class="font-mono text-xs text-gray-500">{{ log.date }}</div>
|
||||||
|
</div>
|
||||||
|
{% if log.description %}
|
||||||
|
<div class="md:text-right max-w-xs">
|
||||||
|
<p class="font-serif text-sm text-gray-400 italic leading-relaxed">
|
||||||
|
"{{ log.description }}"
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
{% endif %}
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<!-- Changes List -->
|
||||||
|
<div class="relative z-10">
|
||||||
|
<ul class="space-y-4">
|
||||||
|
{% for change in log.changes %}
|
||||||
|
<li class="flex items-start gap-4 group/item">
|
||||||
|
{% if change.type == 'add' %}
|
||||||
|
<span class="flex-shrink-0 mt-1 px-2 py-1 rounded text-[10px] font-mono font-bold bg-green-500/10 text-green-400 border border-green-500/20 group-hover/item:bg-green-500/20 transition-colors">ADD</span>
|
||||||
|
{% elif change.type == 'update' %}
|
||||||
|
<span class="flex-shrink-0 mt-1 px-2 py-1 rounded text-[10px] font-mono font-bold bg-blue-500/10 text-blue-400 border border-blue-500/20 group-hover/item:bg-blue-500/20 transition-colors">UPD</span>
|
||||||
|
{% elif change.type == 'fix' %}
|
||||||
|
<span class="flex-shrink-0 mt-1 px-2 py-1 rounded text-[10px] font-mono font-bold bg-red-500/10 text-red-400 border border-red-500/20 group-hover/item:bg-red-500/20 transition-colors">FIX</span>
|
||||||
|
{% else %}
|
||||||
|
<span class="flex-shrink-0 mt-1 px-2 py-1 rounded text-[10px] font-mono font-bold bg-gray-500/10 text-gray-400 border border-gray-500/20 group-hover/item:bg-gray-500/20 transition-colors">MSC</span>
|
||||||
|
{% endif %}
|
||||||
|
|
||||||
|
<span class="text-base text-gray-300 leading-relaxed group-hover/item:text-white transition-colors">{{ change.content }}</span>
|
||||||
|
</li>
|
||||||
|
{% endfor %}
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</section>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</main>
|
||||||
|
|
||||||
|
<footer class="py-12 border-t border-white/5 bg-black/20">
|
||||||
|
<div class="max-w-6xl mx-auto px-6 flex flex-col md:flex-row justify-between items-center gap-6">
|
||||||
|
<div class="text-center md:text-left">
|
||||||
|
<div class="font-display font-bold text-white mb-1">NEOBOT</div>
|
||||||
|
<p class="font-mono text-[10px] text-gray-600">
|
||||||
|
PRIVATE PERSONAL PROJECT<br>
|
||||||
|
GENERATED BY CHANGELOG TOOL
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
<div class="font-mono text-[10px] text-gray-600 text-center md:text-right">
|
||||||
|
TO ASTEROID B-612<br>
|
||||||
|
SASAKURE.UK
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</footer>
|
||||||
|
|
||||||
|
</body>
|
||||||
|
</html>
|
||||||
Reference in New Issue
Block a user