2026-02-24 06:54:14 +00:00
|
|
|
<template>
|
|
|
|
|
<div class="app-container">
|
|
|
|
|
<el-menu
|
|
|
|
|
:default-active="activeIndex"
|
|
|
|
|
class="el-menu-demo"
|
|
|
|
|
mode="horizontal"
|
|
|
|
|
router
|
|
|
|
|
>
|
|
|
|
|
<el-menu-item index="/dashboard">控制台</el-menu-item>
|
|
|
|
|
<el-menu-item index="/kb">知识库管理</el-menu-item>
|
|
|
|
|
<el-menu-item index="/rag-lab">RAG 实验室</el-menu-item>
|
|
|
|
|
<el-menu-item index="/monitoring">会话监控</el-menu-item>
|
feat(AISVC-T8): LLM配置管理与RAG调试输出支持 [AC-AISVC-42, AC-AISVC-43, AC-AISVC-44, AC-AISVC-45, AC-AISVC-46, AC-AISVC-47, AC-AISVC-48, AC-AISVC-49, AC-AISVC-50]
- 新增 LLMProviderFactory 工厂类支持 OpenAI/Ollama/Azure [AC-AISVC-42]
- 新增 LLMConfigManager 支持配置热更新 [AC-AISVC-43, AC-AISVC-44]
- 新增 LLM 管理 API 端点 [AC-AISVC-42~AC-AISVC-46]
- 更新 RAG 实验接口支持 AI 回复生成 [AC-AISVC-47, AC-AISVC-49]
- 新增 RAG 实验流式输出 SSE [AC-AISVC-48]
- 支持指定 LLM 提供者 [AC-AISVC-50]
- 更新 OpenAPI 契约添加 LLM 管理接口
- 更新前后端规范文档 v0.4.0 迭代
2026-02-24 17:25:53 +00:00
|
|
|
<el-menu-item index="/admin/embedding">嵌入模型配置</el-menu-item>
|
2026-02-24 06:54:14 +00:00
|
|
|
<div class="flex-grow" />
|
|
|
|
|
<div class="tenant-selector">
|
|
|
|
|
<el-select v-model="currentTenantId" placeholder="选择租户" @change="handleTenantChange">
|
|
|
|
|
<el-option label="默认租户" value="default" />
|
|
|
|
|
<el-option label="租户 A" value="tenant_a" />
|
|
|
|
|
<el-option label="租户 B" value="tenant_b" />
|
|
|
|
|
</el-select>
|
|
|
|
|
</div>
|
|
|
|
|
</el-menu>
|
|
|
|
|
<router-view />
|
|
|
|
|
</div>
|
|
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
<script setup lang="ts">
|
|
|
|
|
import { ref, computed } from 'vue'
|
|
|
|
|
import { useRoute } from 'vue-router'
|
|
|
|
|
import { useTenantStore } from '@/stores/tenant'
|
|
|
|
|
|
|
|
|
|
const route = useRoute()
|
|
|
|
|
const tenantStore = useTenantStore()
|
|
|
|
|
|
|
|
|
|
const activeIndex = computed(() => route.path)
|
|
|
|
|
const currentTenantId = ref(tenantStore.currentTenantId)
|
|
|
|
|
|
|
|
|
|
const handleTenantChange = (val: string) => {
|
|
|
|
|
tenantStore.setTenant(val)
|
|
|
|
|
}
|
|
|
|
|
</script>
|
|
|
|
|
|
|
|
|
|
<style scoped>
|
|
|
|
|
.flex-grow {
|
|
|
|
|
flex-grow: 1;
|
|
|
|
|
}
|
|
|
|
|
.tenant-selector {
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
padding: 0 20px;
|
|
|
|
|
}
|
|
|
|
|
.app-container {
|
|
|
|
|
padding: 20px;
|
|
|
|
|
}
|
|
|
|
|
</style>
|