182 lines
5.0 KiB
HTML
182 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>MobileModels 文档查看</title>
|
|
<style>
|
|
:root {
|
|
--bg: #f5f7fb;
|
|
--card: #ffffff;
|
|
--text: #1c2430;
|
|
--sub: #566173;
|
|
--line: #d9e0ea;
|
|
--brand: #0f6fff;
|
|
}
|
|
* { box-sizing: border-box; }
|
|
body {
|
|
margin: 0;
|
|
font-family: "PingFang SC", "Noto Sans SC", "Microsoft YaHei", sans-serif;
|
|
background: radial-gradient(circle at 0 0, #eef4ff 0, var(--bg) 40%), var(--bg);
|
|
color: var(--text);
|
|
}
|
|
.top-nav {
|
|
background: linear-gradient(180deg, #1f2a3a, #1a2431);
|
|
border-bottom: 1px solid rgba(255, 255, 255, 0.08);
|
|
}
|
|
.top-nav-inner {
|
|
max-width: 1200px;
|
|
margin: 0 auto;
|
|
padding: 0 16px;
|
|
height: 52px;
|
|
display: flex;
|
|
align-items: center;
|
|
gap: 8px;
|
|
}
|
|
.top-nav .brand,
|
|
.top-nav .item {
|
|
color: #d6e3f7;
|
|
text-decoration: none;
|
|
font-size: 14px;
|
|
padding: 6px 10px;
|
|
border-radius: 6px;
|
|
}
|
|
.top-nav .brand {
|
|
font-weight: 700;
|
|
margin-right: 8px;
|
|
color: #f4f8ff;
|
|
}
|
|
.top-nav .item.active {
|
|
background: rgba(255, 255, 255, 0.16);
|
|
color: #ffffff;
|
|
font-weight: 600;
|
|
}
|
|
.wrap {
|
|
max-width: 1200px;
|
|
margin: 24px auto;
|
|
padding: 0 16px 32px;
|
|
display: grid;
|
|
gap: 16px;
|
|
}
|
|
.card {
|
|
background: var(--card);
|
|
border: 1px solid var(--line);
|
|
border-radius: 14px;
|
|
padding: 14px;
|
|
box-shadow: 0 6px 18px rgba(36, 56, 89, 0.06);
|
|
}
|
|
.title {
|
|
margin: 0 0 8px;
|
|
font-size: 18px;
|
|
font-weight: 700;
|
|
}
|
|
.sub {
|
|
margin: 0 0 14px;
|
|
color: var(--sub);
|
|
font-size: 13px;
|
|
line-height: 1.5;
|
|
}
|
|
.btns {
|
|
display: flex;
|
|
gap: 8px;
|
|
flex-wrap: wrap;
|
|
margin-top: 12px;
|
|
}
|
|
.btn {
|
|
display: inline-flex;
|
|
align-items: center;
|
|
padding: 9px 14px;
|
|
border-radius: 10px;
|
|
border: 1px solid #c8d6ee;
|
|
background: #f7faff;
|
|
color: #244775;
|
|
text-decoration: none;
|
|
font-size: 13px;
|
|
font-weight: 700;
|
|
}
|
|
.btn:hover {
|
|
background: #eef5ff;
|
|
}
|
|
pre {
|
|
margin: 0;
|
|
white-space: pre-wrap;
|
|
word-break: break-word;
|
|
font-size: 13px;
|
|
line-height: 1.65;
|
|
background: #f6f8fb;
|
|
border: 1px solid var(--line);
|
|
border-radius: 10px;
|
|
padding: 14px;
|
|
overflow: auto;
|
|
}
|
|
</style>
|
|
</head>
|
|
<body>
|
|
<nav class="top-nav">
|
|
<div class="top-nav-inner">
|
|
<a href="/web/device_query.html" class="brand">MobileModels</a>
|
|
<a href="/web/device_query.html" class="item">设备查询</a>
|
|
<a href="/web/brand_management.html" class="item">数据管理</a>
|
|
<a href="/web/device_query.html?view=docs" class="item active">相关文档</a>
|
|
</div>
|
|
</nav>
|
|
|
|
<div class="wrap">
|
|
<section class="card">
|
|
<h1 class="title" id="docTitle">文档查看</h1>
|
|
<p class="sub" id="docPath">正在加载文档...</p>
|
|
<div class="btns">
|
|
<a class="btn" href="/web/doc_viewer.html?path=/docs/mysql-query-design.md&title=MySQL%20%E8%AE%BE%E8%AE%A1%E8%AF%B4%E6%98%8E">MySQL 设计说明</a>
|
|
<a class="btn" href="/web/doc_viewer.html?path=/docs/web-ui.md&title=Web%20%E4%BD%BF%E7%94%A8%E8%AF%B4%E6%98%8E">Web 使用说明</a>
|
|
<a class="btn" href="/web/doc_viewer.html?path=/README.md&title=%E9%A1%B9%E7%9B%AE%20README">项目 README</a>
|
|
</div>
|
|
</section>
|
|
|
|
<section class="card">
|
|
<pre id="docContent">加载中...</pre>
|
|
</section>
|
|
</div>
|
|
|
|
<script>
|
|
const ALLOWED_DOCS = new Map([
|
|
["/docs/mysql-query-design.md", "MySQL 设计说明"],
|
|
["/docs/web-ui.md", "Web 使用说明"],
|
|
["/README.md", "项目 README"],
|
|
]);
|
|
|
|
async function main() {
|
|
const params = new URLSearchParams(window.location.search);
|
|
const path = params.get("path") || "/docs/mysql-query-design.md";
|
|
const title = params.get("title") || ALLOWED_DOCS.get(path) || "文档查看";
|
|
const docTitleEl = document.getElementById("docTitle");
|
|
const docPathEl = document.getElementById("docPath");
|
|
const docContentEl = document.getElementById("docContent");
|
|
|
|
if (!ALLOWED_DOCS.has(path)) {
|
|
docTitleEl.textContent = "文档不存在";
|
|
docPathEl.textContent = path;
|
|
docContentEl.textContent = "当前只允许查看预设文档。";
|
|
return;
|
|
}
|
|
|
|
document.title = `${title} - MobileModels`;
|
|
docTitleEl.textContent = title;
|
|
docPathEl.textContent = path;
|
|
|
|
try {
|
|
const resp = await fetch(path, { cache: "no-store" });
|
|
if (!resp.ok) {
|
|
throw new Error(`HTTP ${resp.status}`);
|
|
}
|
|
const text = await resp.text();
|
|
docContentEl.textContent = text;
|
|
} catch (err) {
|
|
docContentEl.textContent = `加载失败\n${err.message || err}`;
|
|
}
|
|
}
|
|
|
|
main();
|
|
</script>
|
|
</body>
|
|
</html>
|