组件修改
This commit is contained in:
@@ -33,29 +33,12 @@
|
||||
<!-- 主内容区 -->
|
||||
<main class="main-content">
|
||||
<!-- iframe 模式 -->
|
||||
<div v-if="currentIframeUrl" class="iframe-container">
|
||||
<div class="iframe-header">
|
||||
<span class="iframe-title">{{ currentMenuItem?.label }}</span>
|
||||
<el-button
|
||||
text
|
||||
@click="handleRefreshIframe"
|
||||
:icon="Refresh"
|
||||
>
|
||||
刷新
|
||||
</el-button>
|
||||
</div>
|
||||
<iframe
|
||||
ref="iframeRef"
|
||||
:src="currentIframeUrl"
|
||||
class="content-iframe"
|
||||
frameborder="0"
|
||||
@load="handleIframeLoad"
|
||||
/>
|
||||
<div v-if="iframeLoading" class="iframe-loading">
|
||||
<Loader :size="20" class="is-loading" />
|
||||
<span>加载中...</span>
|
||||
</div>
|
||||
</div>
|
||||
<IframeView
|
||||
v-if="currentIframeUrl"
|
||||
:url="currentIframeUrl"
|
||||
:title="currentMenuItem?.label"
|
||||
:show-header="true"
|
||||
/>
|
||||
|
||||
<!-- 路由模式 -->
|
||||
<router-view v-else />
|
||||
@@ -76,13 +59,9 @@ import {
|
||||
ChevronRight,
|
||||
User,
|
||||
Settings,
|
||||
LogOut,
|
||||
RefreshCw,
|
||||
Loader
|
||||
LogOut
|
||||
} from 'lucide-vue-next'
|
||||
|
||||
// el-button 图标需要传入组件
|
||||
const Refresh = RefreshCw
|
||||
import { IframeView } from 'shared/components'
|
||||
import { ElMessage } from 'element-plus'
|
||||
import type { MenuItem } from 'shared/types'
|
||||
|
||||
@@ -92,8 +71,6 @@ const route = useRoute()
|
||||
// 状态管理
|
||||
const collapsed = ref(false)
|
||||
const activeMenu = ref('home')
|
||||
const iframeLoading = ref(false)
|
||||
const iframeRef = ref<HTMLIFrameElement>()
|
||||
|
||||
// 从 LocalStorage 获取用户名
|
||||
function getUserName(): string {
|
||||
@@ -175,7 +152,7 @@ const menuItems = ref<MenuItem[]>(loadMenuFromStorage())
|
||||
|
||||
// 当前菜单项
|
||||
const currentMenuItem = computed(() => {
|
||||
return menuItems.value.find(item => item.key === activeMenu.value)
|
||||
return menuItems.value.find((item: MenuItem) => item.key === activeMenu.value)
|
||||
})
|
||||
|
||||
// 当前 iframe URL(从路由 meta 读取)
|
||||
@@ -196,30 +173,9 @@ const handleMenuClick = (item: MenuItem) => {
|
||||
// 所有菜单都通过路由跳转
|
||||
if (item.url) {
|
||||
router.push(item.url)
|
||||
if (item.viewType === 'iframe') {
|
||||
iframeLoading.value = true
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// iframe 加载完成
|
||||
const handleIframeLoad = () => {
|
||||
iframeLoading.value = false
|
||||
}
|
||||
|
||||
// 刷新 iframe
|
||||
const handleRefreshIframe = () => {
|
||||
if (iframeRef.value) {
|
||||
iframeLoading.value = true
|
||||
iframeRef.value.src = iframeRef.value.src
|
||||
}
|
||||
}
|
||||
|
||||
// 用户头像加载错误
|
||||
const handleAvatarError = () => {
|
||||
return true
|
||||
}
|
||||
|
||||
// 用户操作
|
||||
const handleUserCommand = (command: string) => {
|
||||
switch (command) {
|
||||
|
||||
@@ -33,7 +33,7 @@
|
||||
</el-form-item>
|
||||
|
||||
<el-form-item label="系统提示词">
|
||||
<el-input v-model="agentConfig.systemPrompt" type="textarea" rows="4" placeholder="输入系统提示词,用于指导AI的行为" />
|
||||
<el-input v-model="agentConfig.systemPrompt" type="textarea" :rows="4" placeholder="输入系统提示词,用于指导AI的行为" />
|
||||
</el-form-item>
|
||||
|
||||
<el-form-item label="启用知识库">
|
||||
@@ -73,7 +73,7 @@
|
||||
</template>
|
||||
|
||||
<div class="test-section">
|
||||
<el-input v-model="testMessage" type="textarea" rows="3" placeholder="输入测试消息..." style="margin-bottom: 12px;" />
|
||||
<el-input v-model="testMessage" type="textarea" :rows="3" placeholder="输入测试消息..." style="margin-bottom: 12px;" />
|
||||
<el-button type="primary" @click="testAgent">发送测试</el-button>
|
||||
|
||||
<div v-if="testResponse" class="test-response">
|
||||
|
||||
@@ -140,7 +140,7 @@
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="故障描述">
|
||||
<el-input v-model="formData.remark" type="textarea" rows="4" placeholder="请输入故障描述" />
|
||||
<el-input v-model="formData.remark" type="textarea" :rows="4" placeholder="请输入故障描述" />
|
||||
</el-form-item>
|
||||
</el-form>
|
||||
<template #footer>
|
||||
|
||||
@@ -156,7 +156,7 @@
|
||||
@input="adjustHeight"
|
||||
@keydown="handleKeyDown"
|
||||
placeholder="请输入您的问题,例如:电源模块过热报警怎么处理..."
|
||||
rows="1"
|
||||
:rows="1"
|
||||
class="chat-textarea"
|
||||
/>
|
||||
</div>
|
||||
|
||||
Reference in New Issue
Block a user