agent-Specialization/static/src/admin/CustomToolsGuideApp.vue

159 lines
3.6 KiB
Vue

<template>
<div class="guide-page">
<header class="guide-header">
<div class="title-block">
<p class="eyebrow">Custom Tools</p>
<h1>开发指南</h1>
<p class="desc">如何编写组织与调试自定义工具的完整说明</p>
</div>
<div class="actions">
<a class="ghost" href="/admin/custom-tools" target="_blank" rel="noopener">返回列表</a>
</div>
</header>
<section class="panel">
<div v-if="error" class="status error">{{ error }}</div>
<div v-else-if="loading" class="status">加载中...</div>
<article v-else class="markdown" v-html="html"></article>
</section>
</div>
</template>
<script setup lang="ts">
import { onMounted, ref } from 'vue';
import { renderMarkdown } from '@/composables/useMarkdownRenderer';
import guideMd from '../../../doc/custom_tools_guide.md?raw';
const html = ref('');
const loading = ref(true);
const error = ref('');
onMounted(() => {
try {
html.value = renderMarkdown(guideMd);
} catch (e: any) {
error.value = e.message || '渲染指南失败';
} finally {
loading.value = false;
}
});
</script>
<style scoped>
:global(html, body) {
min-height: 100%;
background: radial-gradient(140% 120% at 20% 20%, rgba(239, 229, 214, 0.9), transparent),
radial-gradient(120% 120% at 80% 0%, rgba(255, 255, 255, 0.9), transparent),
#f8f3e8;
}
:global(#custom-tools-guide) {
min-height: 100vh;
}
.guide-page {
--paper: #ffffff;
--border: #e3d8c8;
--ink: #1a120b;
--muted: #6f635a;
--accent: var(--claude-accent, #da7756);
--accent-strong: var(--claude-accent-strong, #bd5d3a);
--shadow: 0 16px 40px rgba(47, 32, 21, 0.12);
max-width: 1080px;
margin: 0 auto;
padding: 24px 16px 32px;
font-family: 'Space Grotesk', 'Noto Sans SC', 'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
color: var(--ink);
}
.guide-header {
display: flex;
justify-content: space-between;
gap: 12px;
align-items: flex-start;
margin-bottom: 18px;
}
.title-block h1 {
margin: 4px 0;
color: #2f2015;
}
.title-block .eyebrow {
letter-spacing: 0.12em;
text-transform: uppercase;
color: var(--muted);
font-size: 12px;
margin: 0;
}
.title-block .desc {
margin: 6px 0 0;
color: var(--muted);
}
.actions .ghost {
padding: 10px 16px;
border-radius: 12px;
border: 1px solid var(--border);
background: #fffdf8;
color: #4b3626;
text-decoration: none;
font-weight: 600;
}
.panel {
background: var(--paper);
border: 1px solid var(--border);
border-radius: 16px;
box-shadow: var(--shadow);
padding: 18px;
}
.status {
color: var(--muted);
}
.status.error {
color: #d64545;
}
.markdown :global(h1),
.markdown :global(h2),
.markdown :global(h3),
.markdown :global(h4) {
color: #2f2015;
margin: 20px 0 10px;
}
.markdown :global(p),
.markdown :global(li),
.markdown :global(code) {
color: var(--ink);
}
.markdown :global(code) {
background: #fdf8ef;
border: 1px solid var(--border);
border-radius: 6px;
padding: 2px 6px;
font-size: 13px;
}
.markdown :global(pre) {
background: #0f172a;
color: #f8fafc;
border-radius: 10px;
padding: 14px;
overflow: auto;
}
.markdown :global(a) {
color: var(--accent-strong);
}
.markdown :global(blockquote) {
border-left: 3px solid var(--border);
padding-left: 12px;
color: var(--muted);
}
.markdown :global(table) {
border-collapse: collapse;
width: 100%;
margin: 12px 0;
}
.markdown :global(th),
.markdown :global(td) {
border: 1px solid var(--border);
padding: 8px 10px;
}
.markdown :global(ul) {
padding-left: 20px;
}
</style>