Commit e1496a9c authored by 胡占生's avatar 胡占生 🇨🇳

fix: 修复我的算法编辑功能

parent 4dcefc1b
...@@ -57,6 +57,13 @@ export function detailAlg(id) { ...@@ -57,6 +57,13 @@ export function detailAlg(id) {
}) })
} }
// 查询我的算法列表详情
export function detailMyAlg(id) {
return request({
url: `/yunshou/userAlgorithm/${id}`,
method: 'get',
})
}
// 新增算法列表 // 新增算法列表
export function addAlg(data) { export function addAlg(data) {
......
...@@ -61,7 +61,12 @@ ...@@ -61,7 +61,12 @@
:key="disc.id" :key="disc.id"
:label="disc.alarmName" :label="disc.alarmName"
:value="disc.id" :value="disc.id"
/> >
<span>
<el-tag type="success" :style="{backgroundColor: disc.alarmColor,width:'40px'}">{{ }}</el-tag>
</span>
{{ disc.alarmName }}
</el-option>
</el-select> </el-select>
</el-form-item> </el-form-item>
</el-col> </el-col>
...@@ -174,7 +179,12 @@ ...@@ -174,7 +179,12 @@
:key="disc.id" :key="disc.id"
:label="disc.alarmName" :label="disc.alarmName"
:value="disc.id" :value="disc.id"
/> > <span>
<el-tag type="success" :style="{backgroundColor: disc.alarmColor,width:'40px'}">{{ }}</el-tag>
</span>
{{ disc.alarmName }}
</el-option>
</el-select> </el-select>
</el-form-item> </el-form-item>
</el-col> </el-col>
......
...@@ -7,38 +7,33 @@ ...@@ -7,38 +7,33 @@
> >
<el-form ref="algRef" :model="form" :rules="rules" label-width="80px"> <el-form ref="algRef" :model="form" :rules="rules" label-width="80px">
<el-row> <el-row>
<el-col :span="12"> <el-col :span="24">
<el-form-item label="算法名称" prop="algorithmName"> <el-form-item label="算法名称" prop="algorithmName">
<el-input v-model="form.algorithmName" placeholder="请输入岗位名称" /> <el-input v-model="form.algorithmName" placeholder="请输入岗位名称" disabled/>
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="12"> <el-col :span="24">
<el-form-item label="算法英文" prop="algorithmEnglish"> <el-form-item label="算法英文" prop="algorithmEnglish">
<el-input v-model="form.algorithmEnglish" placeholder="请输入编码名称" /> <el-input v-model="form.algorithmEnglish" placeholder="请输入编码名称" disabled/>
</el-form-item> </el-form-item>
</el-col> </el-col>
</el-row> </el-row>
<el-row> <el-row>
<el-col :span="12"> <el-col :span="24">
<el-form-item label="硬件平台" prop="algorithmPlat"> <el-form-item label="预警等级" prop="alarmLevel">
<el-input v-model="form.algorithmPlat" placeholder="请输入编码名称" /> <el-select v-model="form.alarmLevel" placeholder="请选择预警等级" clearable >
</el-form-item> <el-option
</el-col> v-for="disc in levelList"
<el-col :span="12"> :key="disc.id"
<el-form-item label="告警等级" prop="alarmLevel"> :label="disc.alarmName"
<el-input v-model="form.alarmLevel" placeholder="请输入告警等级" /> :value="disc.id"
</el-form-item> >
</el-col> <span>
</el-row> <el-tag type="success" :style="{backgroundColor: disc.alarmColor,width:'40px'}">{{ }}</el-tag>
<el-row> </span>
<el-col :span="12"> {{ disc.alarmName }}
<el-form-item label="卡片文案" prop="cardCopywriting"> </el-option>
<el-input v-model="form.cardCopywriting" type="textarea" :rows="8" placeholder="请输入内容" /> </el-select>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="卡片图片" prop="status">
<ImageUpload :modelValue="form.cardImg" :limit='1' :fileSize="5" @update:modelValue="getImageUrl"/>
</el-form-item> </el-form-item>
</el-col> </el-col>
</el-row> </el-row>
...@@ -53,20 +48,29 @@ ...@@ -53,20 +48,29 @@
</template> </template>
<script setup> <script setup>
import { addAlg, updateAlg , detailAlg} from "@/api/algorithmList/index.js"; import { addAlg, updateMyAlg , detailAlg,detailMyAlg} from "@/api/algorithmList/index.js";
import { listAlgLevel} from "@/api/algorithmList/algorithmDown.js";
const { proxy } = getCurrentInstance(); const { proxy } = getCurrentInstance();
const emit = defineEmits(); const emit = defineEmits();
const open = ref(false); const open = ref(false);
const title = ref(""); const title = ref("");
const levelList = ref([]);
const ids = ref([]); const ids = ref([]);
const data = reactive({ const data = reactive({
form: {}, form: {
id: '',
algorithmEnglish: '',
algorithmName: '',
algorithmPlat: 0,
status: "0",
remark: ''
},
queryParams: { queryParams: {
pageNum: 1, pageNum: 1,
pageSize: 10, pageSize: 10,
algorithmEnglish: undefined, algorithmEnglish: '',
algorithmName: undefined, algorithmName: '',
status: undefined status: ''
}, },
rules: { rules: {
algorithmName: [{ required: true, message: "算法名称不能为空", trigger: "blur" }], algorithmName: [{ required: true, message: "算法名称不能为空", trigger: "blur" }],
...@@ -78,23 +82,30 @@ const data = reactive({ ...@@ -78,23 +82,30 @@ const data = reactive({
const { queryParams, form, rules } = toRefs(data); const { queryParams, form, rules } = toRefs(data);
function getImageUrl(url){ function getImageUrl(url){
form.value.cardImg=url form.value.cardImg=url
console.log("🚀 ~ getImageUrl ~ orm.cardImg:", form) console.log("🚀 ~ getImageUrl ~ orm.cardImg:", form)
} }
/** 表单重置 */ /** 表单重置 */
function reset() { function reset() {
form.value = { form.value = {
id: undefined, id: '',
algorithmEnglish: undefined, algorithmEnglish: '',
algorithmName: undefined, algorithmName: '',
algorithmPlat: 0, algorithmPlat: 0,
status: "0", status: "0",
remark: undefined remark: ''
}; };
proxy.resetForm("algRef"); proxy.resetForm("algRef");
} }
/** 查询预警等级列表 */
function getLevelList() {
listAlgLevel().then(response => {
levelList.value = response.rows;
});
}
getLevelList()
/** 新增按钮操作 */ /** 新增按钮操作 */
function handleAdd() { function handleAdd() {
...@@ -105,12 +116,14 @@ function handleAdd() { ...@@ -105,12 +116,14 @@ function handleAdd() {
/** 修改按钮操作 */ /** 修改按钮操作 */
function handleUpdate(row) { function handleUpdate(row) {
reset(); console.log("🚀 ~ handleUpdate ~ row:", row)
const id = row.id || ids.value; const id = row.userAlgorithmId || ids.value;
detailAlg(id).then(response => { detailMyAlg(id).then(response => {
form.value = response.data; form.value = response.data;
form.value.algorithmName = row.algorithmName;
form.value.algorithmEnglish = row.algorithmEnglish;
open.value = true; open.value = true;
title.value = "修改算法"; title.value = "修改我的算法";
}); });
} }
...@@ -119,7 +132,7 @@ function submitForm() { ...@@ -119,7 +132,7 @@ function submitForm() {
proxy.$refs["algRef"].validate(valid => { proxy.$refs["algRef"].validate(valid => {
if (valid) { if (valid) {
if (form.value.id != undefined) { if (form.value.id != undefined) {
updateAlg(form.value).then(response => { updateMyAlg(form.value).then(response => {
proxy.$modal.msgSuccess("修改成功"); proxy.$modal.msgSuccess("修改成功");
open.value = false; open.value = false;
emit("getList"); emit("getList");
......
...@@ -27,12 +27,12 @@ ...@@ -27,12 +27,12 @@
default-active="2" default-active="2"
class="el-menu-vertical-demo" class="el-menu-vertical-demo"
> >
<el-menu-item :index="'我的算法'" @click="getMyList"> <el-menu-item :index="'我的算法'" @click="handMyMenuClick">
<span><el-icon style="color: #7F8184;"><component :is="'HomeFilled'" /></el-icon>我的算法</span> <span><el-icon style="color: #7F8184;"><component :is="'HomeFilled'" /></el-icon>我的算法</span>
</el-menu-item> </el-menu-item>
<el-divider style="margin: 5px 0;"/> <el-divider style="margin: 5px 0;"/>
<el-menu-item :index="''" @click="handMenuClick"> <el-menu-item :index="''" @click="handMenuClick">
<span> <el-icon style="color: #7F8184;"><component :is="'DeleteFilled'" /></el-icon>全部</span> <span> <el-icon style="color: #7F8184;"><component :is="'Menu'" /></el-icon>全部算法</span>
</el-menu-item> </el-menu-item>
<el-menu-item v-for="item in algorithm_scen" :key="item.value" :index="item.value" @click="handMenuClick"> <el-menu-item v-for="item in algorithm_scen" :key="item.value" :index="item.value" @click="handMenuClick">
<span style="display: flex;align-items: center;"> <span style="display: flex;align-items: center;">
...@@ -116,9 +116,10 @@ ...@@ -116,9 +116,10 @@
> >
{{ item.cardCopywriting }} {{ item.cardCopywriting }}
</div> </div>
<div style="display: flex;justify-content: flex-end;position: absolute;right: 15px;bottom: 10px;" > <div style="display: flex;justify-content: flex-end;position: absolute;right: 15px;bottom: 5px;" >
<el-button link type="primary" icon="Bottom" @click.stop="handleUpdate(item)" v-if="!listState">添加</el-button> <el-button link type="primary" :icon="item.status=='0'?'Bottom':'Check'" @click.stop="handleUpdate(item)" v-if="!listState">{{item.status=='0'?'添加':'已添加'}}</el-button>
<el-button link type="primary" icon="Edit" @click.stop="handleEnable(item)" v-if="listState">{{item.algorithmStatus=='0'?'停用':'启用' }}</el-button> <el-button link type="primary" icon="Open" @click.stop="handleEnable(item)" v-if="listState">{{item.algorithmStatus=='0'?'停用':'启用' }}</el-button>
<el-button link type="primary" icon="Edit" @click.stop="handlUpdateMyAlg(item)" v-if="listState">{{'编辑'}}</el-button>
<el-button link type="primary" icon="Delete" @click.stop="handleDelete(item)" v-if="listState">删除</el-button> <el-button link type="primary" icon="Delete" @click.stop="handleDelete(item)" v-if="listState">删除</el-button>
<!-- <el-dropdown trigger="click" @command.stop="handleSetSize"> <!-- <el-dropdown trigger="click" @command.stop="handleSetSize">
<el-button link type="primary"> <el-button link type="primary">
...@@ -148,13 +149,14 @@ ...@@ -148,13 +149,14 @@
</el-col> </el-col>
</el-row> </el-row>
<algorithmDown ref="algorithmDownRef" /> <algorithmDown ref="algorithmDownRef" />
<algForm ref="algFormRef" />
</div> </div>
</template> </template>
<script setup name="Index"> <script setup name="Index">
import { listAlg, listMyAlg ,detailAlg, addMyAlg, updateMyAlgState,deleteMyAlg, deleteAlg,updateAlgState } from "@/api/algorithmList/index.js"; import { listAlg, listMyAlg ,detailAlg, addMyAlg, updateMyAlgState,deleteMyAlg, deleteAlg,updateAlgState } from "@/api/algorithmList/index.js";
import algorithmDown from './components/algorithmDown.vue' import algorithmDown from './components/algorithmDown.vue'
// import algForm from './components/algorithmDown.vue' import algForm from './components/form.vue'
const { proxy } = getCurrentInstance(); const { proxy } = getCurrentInstance();
const { algorithm_scen, sys_job_status } = proxy.useDict("algorithm_scen", "sys_job_status"); const { algorithm_scen, sys_job_status } = proxy.useDict("algorithm_scen", "sys_job_status");
import { ArrowDown } from '@element-plus/icons-vue' import { ArrowDown } from '@element-plus/icons-vue'
...@@ -162,6 +164,7 @@ ...@@ -162,6 +164,7 @@
const globalScreenHeight = inject('globalScreenHeight'); const globalScreenHeight = inject('globalScreenHeight');
const router = useRouter(); const router = useRouter();
const algorithmDownRef = ref(null) const algorithmDownRef = ref(null)
const algFormRef = ref(null)
const nowText=ref('算法管理') const nowText=ref('算法管理')
const nowTopTitle=ref('算法管理') const nowTopTitle=ref('算法管理')
const listState=ref(false) const listState=ref(false)
...@@ -217,8 +220,9 @@ ...@@ -217,8 +220,9 @@
getList() getList()
} }
function handleUpdate(row) { function handleUpdate(row) {
addMyAlg({algorithmId:row.id}).then((res) => { if(row.status=='0') addMyAlg({algorithmId:row.id}).then((res) => {
proxy.$modal.msgSuccess("添加成功"); proxy.$modal.msgSuccess("添加成功");
getList()
console.log("🚀 ~ addMyAlg ~ res:", res) console.log("🚀 ~ addMyAlg ~ res:", res)
}) })
// algorithmDownRef.value.handleUpdate(row) // algorithmDownRef.value.handleUpdate(row)
...@@ -230,13 +234,19 @@ ...@@ -230,13 +234,19 @@
getList() getList()
} }
function handMyMenuClick(row) {
queryParams.value.applicationScenarios=''
nowTopTitle.value=row.index
getMyList()
}
function iconComponent(row){ function iconComponent(row){
if(row){ if(row){
return row return row
}else{ }else{
return 'CirclePlusFilled' return 'CirclePlusFilled'
} }
} }
function handleEnable(row){ function handleEnable(row){
...@@ -251,6 +261,10 @@ ...@@ -251,6 +261,10 @@
} }
function handlUpdateMyAlg(row){
algFormRef.value.handleUpdate(row)
}
/** 删除按钮操作 */ /** 删除按钮操作 */
function handleDelete(row) { function handleDelete(row) {
const id = row.userAlgorithmId || ids.value; const id = row.userAlgorithmId || ids.value;
...@@ -282,7 +296,7 @@ ...@@ -282,7 +296,7 @@
-webkit-line-clamp: 3; -webkit-line-clamp: 3;
-webkit-box-orient: vertical; -webkit-box-orient: vertical;
overflow: hidden; overflow: hidden;
margin: 5px 0; margin: 10px 0;
} }
.ellipsis { .ellipsis {
overflow: hidden; /* 隐藏超出的内容 */ overflow: hidden; /* 隐藏超出的内容 */
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment