Files
qihuo/templates/base.html
T

119 lines
8.3 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>
<style>
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;background:#0a0a10;color:#eaeaea;min-height:100vh}
.page-wrap{max-width:1800px;margin:0 auto;min-height:100vh}
.topbar{background:#12121a;border-bottom:1px solid #242435;padding:0 1.5rem}
.topbar-inner{display:flex;align-items:center;gap:1.5rem;height:56px}
.logo{font-size:1.05rem;font-weight:600;background:linear-gradient(90deg,#4cc2ff,#7b42ff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;white-space:nowrap}
.nav{display:flex;gap:.25rem;flex:1;flex-wrap:wrap}
.nav a{padding:.5rem 1rem;color:#a9a9c4;text-decoration:none;font-size:.9rem;border-radius:8px;transition:.2s}
.nav a:hover{color:#fff;background:#1a1a29}
.nav a.active{color:#4cc2ff;background:#1a1a29}
.user-bar{font-size:.85rem;color:#888;white-space:nowrap}
.user-bar a{color:#ff6666;text-decoration:none;margin-left:.5rem}
.main{padding:1.5rem}
.page-title{font-size:1.5rem;margin-bottom:1.5rem;color:#fff}
.flash{padding:1rem;background:#1e2533;color:#4cc2ff;border-radius:10px;margin-bottom:1.5rem;text-align:center}
.card{background:#12121a;border-radius:16px;padding:1.5rem;border:1px solid #242435;margin-bottom:1.5rem}
.card h2{font-size:1.15rem;margin-bottom:1rem;color:#c4c4ff;display:flex;align-items:center;gap:.5rem}
.card h2:before{content:"";width:4px;height:16px;background:#4cc2ff;border-radius:2px}
.form-row{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:1rem;align-items:flex-start}
.form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem;margin-bottom:1rem}
.form-grid .full{grid-column:1/-1}
.field label{display:block;font-size:.8rem;color:#a9a9ff;margin-bottom:.35rem}
input,select,textarea,button{padding:.7rem 1rem;border-radius:10px;border:1px solid #2e2e45;background:#1a1a29;color:#fff;font-size:.9rem;outline:none;width:100%}
textarea{min-height:80px;resize:vertical}
input:focus,select:focus,textarea:focus{border-color:#4cc2ff}
button.btn-primary{background:linear-gradient(90deg,#4285f4,#7b42ff);border:none;cursor:pointer;color:#fff;width:auto}
button.btn-primary:hover{opacity:.9}
.list{display:flex;flex-direction:column;gap:.75rem}
.list-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#161625;border-radius:10px;gap:1rem;flex-wrap:wrap}
.btn-del{padding:.4rem .8rem;background:#291d2f;color:#ff6666;border-radius:8px;text-decoration:none;font-size:.85rem}
table{width:100%;border-collapse:collapse}
th,td{padding:.85rem;text-align:left;border-bottom:1px solid #242435;font-size:.9rem}
th{color:#a9a9ff;white-space:nowrap}
.badge{padding:.25rem .5rem;border-radius:6px;font-size:.75rem}
.badge.profit{background:#1e332f;color:#4cd97f}
.badge.loss{background:#331e24;color:#ff6666}
.badge.dir{background:#1e2533;color:#4cc2ff}
.badge.planned{background:#29241e;color:#eac147}
.badge.active{background:#1e332f;color:#4cd97f}
.badge.expired{background:#2a2a35;color:#999}
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem;margin-bottom:1.5rem}
.stat-item{background:#161625;padding:1rem;border-radius:12px;text-align:center}
.stat-item .label{font-size:.8rem;color:#999}
.stat-item .value{font-size:1.4rem;font-weight:600;color:#fff;margin-top:.25rem}
.symbol-wrap{position:relative}
.symbol-dropdown{position:absolute;top:100%;left:0;right:0;background:#1a1a29;border:1px solid #2e2e45;border-radius:10px;margin-top:4px;z-index:100;max-height:240px;overflow-y:auto;display:none}
.symbol-dropdown.show{display:block}
.symbol-option{padding:.65rem 1rem;cursor:pointer;font-size:.85rem;border-bottom:1px solid #242435}
.symbol-option:hover{background:#242435}
.symbol-option .sub{font-size:.75rem;color:#888;margin-top:2px}
.symbol-selected{font-size:.75rem;color:#4cc2ff;margin-top:4px}
.check-row{display:flex;flex-wrap:wrap;gap:1rem;margin:.75rem 0}
.check-row label{display:flex;align-items:center;gap:.4rem;font-size:.85rem;color:#ccc;cursor:pointer}
.check-row input{width:auto}
.hint{font-size:.78rem;color:#888;line-height:1.5;margin-top:.5rem}
.filter-row{display:flex;gap:.75rem;flex-wrap:wrap;align-items:flex-end;margin-bottom:1rem}
.filter-row .field{width:auto;min-width:140px}
.filter-row button{width:auto}
.split-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;align-items:stretch;margin-bottom:1.5rem}
.split-grid .card{margin-bottom:0;height:100%;min-height:560px;display:flex;flex-direction:column}
.split-grid .card-body{flex:1;overflow:auto}
.card-scroll{max-height:420px;overflow-y:auto}
.preset-tabs{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1rem}
.preset-tabs a{padding:.45rem .85rem;border-radius:8px;border:1px solid #2e2e45;color:#a9a9c4;text-decoration:none;font-size:.85rem}
.preset-tabs a.active,.preset-tabs a:hover{background:#1e2533;color:#4cc2ff;border-color:#4cc2ff}
.btn-link{color:#4cc2ff;cursor:pointer;font-size:.85rem;background:none;border:none;padding:0}
.btn-link:hover{text-decoration:underline}
.modal-mask{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:1000;display:none;align-items:center;justify-content:center;padding:1rem}
.modal-mask.show{display:flex}
.modal-box{background:#12121a;border:1px solid #242435;border-radius:16px;max-width:900px;width:100%;max-height:90vh;overflow:auto;padding:1.5rem}
.modal-box h3{margin-bottom:1rem;color:#c4c4ff}
.modal-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.75rem;font-size:.9rem}
.modal-grid .item label{color:#888;font-size:.75rem;display:block}
.modal-grid .item div{margin-top:.2rem}
.modal-close{float:right;color:#888;cursor:pointer;font-size:1.2rem}
.calc-readonly{background:#161625;color:#4cc2ff}
@media(max-width:1100px){
.split-grid{grid-template-columns:1fr}
.split-grid .card{min-height:auto}
}
@media(max-width:768px){
.topbar-inner{flex-wrap:wrap;height:auto;padding:.75rem 0}
.nav{order:3;width:100%}
}
</style>
{% block extra_css %}{% endblock %}
</head>
<body>
<div class="page-wrap">
<header class="topbar">
<div class="topbar-inner">
<div class="logo">期货监控复盘</div>
<nav class="nav">
<a href="{{ url_for('plans') }}" class="{% if request.endpoint == 'plans' %}active{% endif %}">开单计划</a>
<a href="{{ url_for('keys') }}" class="{% if request.endpoint == 'keys' %}active{% endif %}">关键位监控</a>
<a href="{{ url_for('records') }}" class="{% if request.endpoint == 'records' %}active{% endif %}">交易记录与复盘</a>
<a href="{{ url_for('stats') }}" class="{% if request.endpoint == 'stats' %}active{% endif %}">统计分析</a>
<a href="{{ url_for('settings') }}" class="{% if request.endpoint == 'settings' %}active{% endif %}">系统设置</a>
</nav>
<div class="user-bar">{{ session.username or '用户' }}<a href="{{ url_for('logout') }}">退出</a></div>
</div>
</header>
<main class="main">
{% with msg=get_flashed_messages() %}{% if msg %}<div class="flash">{{ msg[0] }}</div>{% endif %}{% endwith %}
{% block content %}{% endblock %}
</main>
</div>
<script src="{{ url_for('static', filename='js/symbol.js') }}"></script>
{% block extra_js %}{% endblock %}
</body>
</html>