AIManage/src/views/connection/detail.vue

215 lines
6.9 KiB
Vue
Raw Normal View History

2024-06-20 23:49:38 +08:00
<template>
2024-07-07 19:15:46 +08:00
<div class="app-container connection-detail">
2024-06-20 23:49:38 +08:00
<el-card>
<template #header>
<svg-icon icon-class="pause" style="width:20px;height:20px;" />
互联协议信息</template>
<table style="width:100%" class="tb-base-info">
<tr>
<td style="width: 50%;">
<span class="sp-title">模型名称:</span>
2024-07-07 19:15:46 +08:00
<span class="sp-text">{{ info.data.model_name }}</span>
2024-06-20 23:49:38 +08:00
</td>
<td style="width: 50%;">
<span class="sp-title">模型版本:</span>
2024-07-07 19:15:46 +08:00
<span class="sp-text">{{ info.data.connection_version}}</span>
2024-06-20 23:49:38 +08:00
</td>
</tr>
<tr>
<td style="width: 50%;">
<span class="sp-title">互联名称:</span>
2024-07-07 19:15:46 +08:00
<span class="sp-text">{{ info.data.connection_name }}</span>
2024-06-20 23:49:38 +08:00
</td>
<td style="width: 50%;">
<span class="sp-title">标签:</span>
2024-07-07 19:15:46 +08:00
<span class="sp-text">{{ info.data.connection_label }}</span>
2024-06-20 23:49:38 +08:00
</td>
</tr>
<tr>
<td style="width: 50%;">
<span class="sp-title">创建用户:</span>
2024-07-07 19:15:46 +08:00
<span class="sp-text">{{ info.data.user_name }}</span>
2024-06-20 23:49:38 +08:00
</td>
<td style="width: 50%;">
<span class="sp-title">创建时间:</span>
2024-07-07 19:15:46 +08:00
<span class="sp-text">{{ info.data.create_time }}</span>
2024-06-20 23:49:38 +08:00
</td>
</tr>
<tr>
<td style="width: 100%;" colspan="2">
<span class="sp-title">互联说明:</span>
2024-07-07 19:15:46 +08:00
<span class="sp-text">{{ info.data.connection_desc }}</span>
2024-06-20 23:49:38 +08:00
</td>
</tr>
</table>
</el-card>
<el-card style="margin-top: 12px;">
<template #header>
<svg-icon icon-class="pause" style="width:20px;height:20px;" />
算子互联信息</template>
<div class="detail-content">
<div class="item">
<div class="div-title">
<i-ep-setting/><span>互联设置</span>
</div>
<div class="div-chart">
2024-07-07 19:15:46 +08:00
<detailFlow ref="operFlow" @nodeClick="doNodeClick"/>
2024-06-20 23:49:38 +08:00
</div>
</div>
<div class="item" style="margin-left: 100px;">
<div class="div-title">
<i-ep-document/><span>算子基本信息</span>
</div>
<div class="div-info">
2024-07-07 19:15:46 +08:00
<template v-if="info.selNode">
2024-06-20 23:49:38 +08:00
<div class="row">
<span class="sp-label">算子名称:</span>
2024-07-07 19:15:46 +08:00
<span class="sp-text">{{ info.selNode.operator_name }}</span>
2024-06-20 23:49:38 +08:00
</div>
<div class="row">
<span class="sp-label">算子版本:</span>
2024-07-07 19:15:46 +08:00
<span class="sp-text">{{ info.selNode.operator_version }}</span>
2024-06-20 23:49:38 +08:00
</div>
<div class="row">
<span class="sp-label">算子说明:</span>
2024-07-07 19:15:46 +08:00
<span class="sp-text">{{ info.selNode.operator_desc }}</span>
2024-06-20 23:49:38 +08:00
</div>
2024-07-07 19:15:46 +08:00
<!--
2024-06-20 23:49:38 +08:00
<div class="row">
<span class="sp-label">输入参数:</span>
<span class="sp-text">
size(1024,1080)
</span>
</div>
<div class="row">
<span class="sp-label">输出参数:</span>
<span class="sp-text">
<div>size:(1024,1080)</div>
<div>type:nearest</div>
</span>
</div>
2024-07-07 19:15:46 +08:00
-->
<div class="row">
<span class="sp-label">参数:</span>
<span class="sp-text">
<span :key="it.key" style="display: block;" v-for="it in mapToArray(info.selNode.parameters)">{{ it.key }}:{{it.value }}</span>
</span>
</div>
</template>
2024-06-20 23:49:38 +08:00
</div>
</div>
</div>
</el-card>
<el-card class="card-footer">
<el-button type="primary" @click="doBack"></el-button>
</el-card>
</div>
</template>
<script lang='ts' setup>
import detailFlow from './detailFlow.vue';
2024-07-07 19:15:46 +08:00
import ConnApi from '@/api/connection'
2024-06-20 23:49:38 +08:00
const router = useRouter();
2024-07-07 19:15:46 +08:00
const route =useRoute()
const info=reactive({
data:{},
selNode:null
})
const operFlow=ref();
2024-06-20 23:49:38 +08:00
const doBack=()=>{
2024-07-07 19:15:46 +08:00
router.replace({path:"/connection/index"})
2024-06-20 23:49:38 +08:00
}
2024-07-07 19:15:46 +08:00
const mapToArray=obj=>{
let arr=[];
for(let k in obj){
arr.push({
key:k,value:obj[k]
})
};
return arr;
}
const loadData=()=>{
let id=route.query.id;
ConnApi.detail(id).then(d=>{
info.data=d.data?.data||{};
operFlow.value.showFlow(info.data)
});
};
const doNodeClick=(node)=>{
info.selNode=node;
}
onMounted(() => {
loadData();
});
2024-06-20 23:49:38 +08:00
</script>
<style scoped lang='scss'>
2024-07-07 19:15:46 +08:00
.connection-detail {
2024-06-20 23:49:38 +08:00
:deep(.el-card__header) {
padding: 8px 4px;
display: flex;
align-items: center
}
.detail-content{
display: flex;
justify-content: center;
.item{
width:300px;
.div-title{
color:#409EFF;
display: flex;
align-items: center;
font-size: 12px;
}
.div-chart{
border:solid 1px #409EFF;
min-height: 400px;
height: 400px;
}
.div-info{
border:dotted 1px #409EFF;
min-height: 400px;
padding:10px;
font-size: 12px;
.row{
display: flex;
.sp-label{
color:#888;
display: block;
white-space: nowrap;
}
.sp-text{
flex-grow: 1;
display: block;
}
}
}
}
}
}
2024-07-07 19:15:46 +08:00
.tb-base-info {
line-height: 30px;
:deep(span){
font-size: 14px;
}
2024-06-20 23:49:38 +08:00
}
:deep(.svg-icon) {
margin-right: 8px;
}
.card-footer{
position: fixed;
width: calc(100% - 215px);
bottom: 0px;
:deep(.el-card__body){
padding:10px;
.el-pagination{
justify-content: end;
}
}
}
</style>