mirror of
http://112.124.100.131/ebiz-ai/ebiz-ai-knowledge-manage.git
synced 2025-12-18 23:36:53 +08:00
refactor(intelligent-agent): 重构智能体日志与概览页面
- 重写 API 接口,使用 echartsAllData替代 dailyConversations -优化 overview 组件,添加时间范围选择功能 - 修改 lineEcharts 组件,动态加载数据 - 调整 index 组件布局和样式 - 优化智能体列表展示和跳转逻辑
This commit is contained in:
@@ -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'
|
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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: {
|
||||||
|
|||||||
@@ -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() {},
|
||||||
|
|||||||
@@ -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>
|
||||||
|
|||||||
@@ -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>
|
||||||
|
|||||||
Reference in New Issue
Block a user