refactor(intelligent-agent): 重构智能体日志与概览页面

- 重写 API 接口,使用 echartsAllData替代 dailyConversations
-优化 overview 组件,添加时间范围选择功能
- 修改 lineEcharts 组件,动态加载数据
- 调整 index 组件布局和样式
- 优化智能体列表展示和跳转逻辑
This commit is contained in:
陈昱达
2025-05-08 14:14:15 +08:00
parent b565c90150
commit fb5bcc16b9
5 changed files with 273 additions and 219 deletions

View File

@@ -1,13 +1,11 @@
import request from '@/assets/js/utils/request' import request from '@/assets/js/utils/request'
import getUrl from '@/assets/js/utils/get-url' import getUrl from '@/assets/js/utils/get-url'
export function dailyConversations(data) { export function echartsAllData(data) {
return request({ return request({
url: getUrl( url: getUrl(`/intelligent/ex/stat/all`),
`http://192.168.3.229:5001/console/api/apps/${ method: 'get',
data.id params: data,
}/statistics/daily-conversations` noLoading: true
),
method: 'get'
}) })
} }

View File

@@ -93,7 +93,6 @@ export default {
// 画图 // 画图
drawEcharts() { drawEcharts() {
let myChart = this.$echarts.init(document.getElementById(this.echartsId)) let myChart = this.$echarts.init(document.getElementById(this.echartsId))
console.log(this.options)
let option = { let option = {
...this.options, ...this.options,
title: { title: {

View File

@@ -17,9 +17,9 @@
style="flex-wrap: wrap" style="flex-wrap: wrap"
> >
<line-echarts <line-echarts
:key="item.options.title.subtext + index"
v-for="(item, index) in list" v-for="(item, index) in list"
:options="item.options" :options="item.options"
:key="item.options.title.subtext + index"
style="width: calc(50% - 10px);height: 300px" style="width: calc(50% - 10px);height: 300px"
></line-echarts> ></line-echarts>
</div> </div>
@@ -27,176 +27,14 @@
</template> </template>
<script> <script>
import LineEcharts from '@/views/intelligent-agent/children/Logs&overview/components/lineEcharts.vue' import LineEcharts from '@/views/intelligent-agent/children/Logs&overview/components/lineEcharts.vue'
import { dailyConversations } from './API' import { echartsAllData } from './API'
import '@/assets/js/business-common'
export default { export default {
name: 'overveiw', name: 'overveiw',
data() { data() {
return { return {
times: '9', times: '9',
list: [ list: [],
{
options: {
title: {
seriesName: '全部会话数', // 系列名称
text: '全部会话数',
subtext: '所有时间'
},
xAxis: {
data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
},
series: [
{
name: '会话数',
data: [820, 932, 901, 934, 1290, 1330, 1320],
itemStyle: {
color: '#0694A2'
},
areaStyle: {
color: [
{ offset: 0, color: '#0694A2' },
{
offset: 1,
color: '#F3F9FA'
}
]
}
}
]
}
},
{
options: {
title: {
text: '活跃用户数',
subtext: '所有时间'
},
xAxis: {
data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
},
series: [
{
name: '活跃用户',
data: [820, 932, 901, 934, 1290, 430, 9000],
itemStyle: {
color: '#FF8A4C'
},
areaStyle: {
color: [
{ offset: 0, color: '#FF8A4C' },
{ offset: 1, color: '#FFF6F1' }
]
}
}
]
}
},
{
options: {
title: {
text: '平均会话互动数',
subtext: '所有时间'
},
xAxis: {
data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
},
series: [
{
name: '平均会话互动数',
data: [20, 52, 1, 55, 666, 1330, 55],
itemStyle: {
color: '#FF8A4C'
},
areaStyle: {
color: [
{ offset: 0, color: '#FF8A4C' },
{ offset: 1, color: '#FFF6F1' }
]
}
}
]
}
},
{
options: {
title: {
text: 'Token 输出速度',
subtext: '所有时间'
},
xAxis: {
data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
},
series: [
{
name: 'Token 输出速度',
data: [300, 555, 444, 22, 11, 333, 1],
itemStyle: {
color: '#FF8A4C'
},
areaStyle: {
color: [
{ offset: 0, color: '#FF8A4C' },
{ offset: 1, color: '#FFF6F1' }
]
}
}
]
}
},
{
options: {
title: {
text: '用户满意度',
subtext: '所有时间'
},
xAxis: {
data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
},
series: [
{
name: '用户满意度',
data: [200, 300, 400, 444, 500, 555, 521],
itemStyle: {
color: '#1C64F1'
},
areaStyle: {
color: [
{ offset: 0, color: '#1C64F1' },
{ offset: 1, color: '#E3ECFD' }
]
}
}
]
}
},
{
options: {
title: {
text: '费用消耗',
subtext: '所有时间'
},
xAxis: {
data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
},
series: [
{
name: '费用消耗',
data: [820, 932, 901, 934, 1290, 200, 500],
itemStyle: {
color: '#FF8A4C'
},
areaStyle: {
color: [
{ offset: 0, color: '#FF8A4C' },
{ offset: 1, color: '#FFF6F1' }
]
}
}
]
}
}
],
options: [ options: [
{ {
label: '今天', label: '今天',
@@ -244,35 +82,80 @@ export default {
}, },
filters: {}, filters: {},
methods: { methods: {
changeTime(value) { /**
let label = this.findLabel(value) * 根据 value 返回对应的时间范围
this.list = this.list.map(item => { * @param {string} value - 选项值,如 '2', '3', ..., '8'
return { * @returns {{startDate: string, endDate: string}}
options: { */
tooltip: { getDateRangeByValue(value) {
trigger: 'axis', const today = new Date()
backgroundColor: 'rgba(255,255,255,0.9)',
borderColor: '#ccc',
textStyle: {
color: '#333'
},
formatter: params => { // 辅助函数:格式化日期为 yyyy-MM-dd
console.log(params) function formatDate(date) {
return ( const y = date.getFullYear()
`${params[0].axisValue} ${params[0].marker}<br/>` + const m = String(date.getMonth() + 1).padStart(2, '0')
params.map(p => `${p.seriesName}${p.value}`).join('<br/>') const d = String(date.getDate()).padStart(2, '0')
) return `${y}-${m}-${d}`
} }
},
...item.options, let startDate = ''
title: { let endDate = ''
...item.options.title,
subtext: label switch (value) {
} case '1': // 今天
} endDate = startDate = formatDate(today)
} break
}) case '2': // 过去7天
startDate = formatDate(
new Date(today.getTime() - 6 * 24 * 60 * 60 * 1000)
)
endDate = formatDate(today)
break
case '3': // 过去4周28天
startDate = formatDate(
new Date(today.getTime() - 27 * 24 * 60 * 60 * 1000)
)
endDate = formatDate(today)
break
case '4': // 过去3个月约90天
startDate = formatDate(
new Date(today.getTime() - 89 * 24 * 60 * 60 * 1000)
)
endDate = formatDate(today)
break
case '5': // 过去12个月约365天
startDate = formatDate(
new Date(today.getTime() - 364 * 24 * 60 * 60 * 1000)
)
endDate = formatDate(today)
break
case '6': // 本月至今
startDate = formatDate(
new Date(today.getFullYear(), today.getMonth(), 1)
)
endDate = formatDate(today)
break
case '7': // 本季度至今
const quarterStartMonth = Math.floor(today.getMonth() / 3) * 3
startDate = formatDate(
new Date(today.getFullYear(), quarterStartMonth, 1)
)
endDate = formatDate(today)
break
case '8': // 本年至今
startDate = formatDate(new Date(today.getFullYear(), 0, 1))
endDate = formatDate(today)
break
default:
startDate = endDate = formatDate(today)
break
}
return { startDate, endDate }
},
changeTime(value) {
this.getEcharts()
}, },
// 查找label // 查找label
findLabel(value) { findLabel(value) {
@@ -281,10 +164,183 @@ export default {
).label ).label
}, },
async getEcharts() { async getEcharts() {
// let dailyConversationsApi = await dailyConversations({ let list = [
// id: '27f6f211-6c74-4de8-9424-c1ba28d365c2' {
// }) code: 'conversationCount',
// console.log(dailyConversationsApi) options: {
title: {
seriesName: '全部会话数', // 系列名称
text: '全部会话数',
subtext: '所有时间'
},
xAxis: {
data: []
},
series: [
{
name: '会话数',
data: [],
itemStyle: {
color: '#0694A2'
},
areaStyle: {
color: [
{ offset: 0, color: '#0694A2' },
{
offset: 1,
color: '#F3F9FA'
}
]
}
}
]
}
},
{
code: 'terminalCount',
options: {
title: {
text: '活跃用户数',
subtext: '所有时间'
},
xAxis: {
data: []
},
series: [
{
name: '活跃用户',
data: [],
itemStyle: {
color: '#FF8A4C'
},
areaStyle: {
color: [
{ offset: 0, color: '#FF8A4C' },
{ offset: 1, color: '#FFF6F1' }
]
}
}
]
}
},
{
code: 'interactions',
options: {
title: {
text: '平均会话互动数',
subtext: '所有时间'
},
xAxis: {
data: []
},
series: [
{
name: '平均会话互动数',
data: [],
itemStyle: {
color: '#FF8A4C'
},
areaStyle: {
color: [
{ offset: 0, color: '#FF8A4C' },
{ offset: 1, color: '#FFF6F1' }
]
}
}
]
}
},
{
code: 'tps',
options: {
title: {
text: 'Token 输出速度',
subtext: '所有时间'
},
xAxis: {
data: []
},
series: [
{
name: 'Token 输出速度',
data: [],
itemStyle: {
color: '#FF8A4C'
},
areaStyle: {
color: [
{ offset: 0, color: '#FF8A4C' },
{ offset: 1, color: '#FFF6F1' }
]
}
}
]
}
},
{
code: 'interactions',
options: {
title: {
text: '平均每个会话交互次数',
subtext: '所有时间'
},
xAxis: {
data: []
},
series: [
{
name: '平均每个会话交互次数',
data: [],
itemStyle: {
color: '#1C64F1'
},
areaStyle: {
color: [
{ offset: 0, color: '#1C64F1' },
{ offset: 1, color: '#E3ECFD' }
]
}
}
]
}
}
]
let query = {
appId: this.$route.query.appId
}
if (this.times !== '9') {
let times = this.getDateRangeByValue(this.times)
query.startDate = times.startDate
query.endDate = times.endDate
}
let { content } = await echartsAllData(query)
let x = []
let obj = {}
content.content.map(item => {
x.push(item.date)
for (let itemKey in item) {
obj[itemKey] = obj[itemKey] ? obj[itemKey] : []
obj[itemKey].push(item[itemKey])
}
})
let label = this.findLabel(this.times)
list.map(item => {
item.options.xAxis.data = x
for (let keys in obj) {
if (keys === item.code) {
item.options.series[0].data = obj[keys]
}
}
item.options.title = {
...item.options.title,
subtext: label
}
})
this.list = JSON.parse(JSON.stringify(list))
} }
}, },
created() {}, created() {},

View File

@@ -15,7 +15,7 @@
</div> </div>
<div class="tabs-body"> <div class="tabs-body">
<logs v-if="chooseTab === 'logs'"></logs> <logs v-if="chooseTab === 'logs'"></logs>
<overview v-if="chooseTab === 'overview'"></overview> <overview v-show="chooseTab === 'overview'"></overview>
</div> </div>
</div> </div>
</template> </template>

View File

@@ -37,8 +37,8 @@ export default {
* @type {{name: string, url: string, id: string}[]} * @type {{name: string, url: string, id: string}[]}
*/ */
list: [], list: [],
page: 0, page: 1,
pageSize: 10, pageSize: 99999999,
total: -1, total: -1,
dialog: { dialog: {
visible: false, visible: false,
@@ -91,9 +91,12 @@ export default {
this.total = content.content.total this.total = content.content.total
}, },
jumpToLogs() { jumpToLogs(id) {
this.$router.push({ this.$router.push({
path: `/intelligentAgent/logs-overview` path: `/intelligentAgent/logs-overview`,
query: {
appId: id
}
}) })
}, },
@@ -170,7 +173,7 @@ export default {
} }
}, },
created() { created() {
// this.fetchAgentList() this.fetchAgentList()
} }
} }
</script> </script>
@@ -202,7 +205,7 @@ export default {
</el-col> </el-col>
</el-row> </el-row>
<div slot="header" class="clearfix mt30 flex"> <div slot="header" class="clearfix mt30 flex mb20">
<div> <div>
<h3>智能体列表</h3> <h3>智能体列表</h3>
</div> </div>
@@ -211,12 +214,8 @@ export default {
<!-- <li v-for="i in count" class="infinite-list-item">{{ i }}</li>--> <!-- <li v-for="i in count" class="infinite-list-item">{{ i }}</li>-->
<!-- </ul>--> <!-- </ul>-->
<div <div class="card-body">
class="card-body" <div class="ledge-list ">
v-infinite-scroll="load"
style="height:85vh;overflow: auto"
>
<div class="ledge-list mt20">
<el-card <el-card
v-for="(listItem, index) in list" v-for="(listItem, index) in list"
class="item datasetList" class="item datasetList"
@@ -535,4 +534,6 @@ export default {
background: linear-gradient(to bottom, #fafbfc, #f5f7fa); background: linear-gradient(to bottom, #fafbfc, #f5f7fa);
} }
} }
.container {
}
</style> </style>