2025-01-21 18:28:13 +08:00
|
|
|
|
<script lang="ts">
|
|
|
|
|
|
export default {
|
2025-03-19 09:17:05 +08:00
|
|
|
|
name: "testtask",//试验数据管理
|
2025-01-21 18:28:13 +08:00
|
|
|
|
};
|
|
|
|
|
|
</script>
|
|
|
|
|
|
|
|
|
|
|
|
<script setup lang="ts">
|
|
|
|
|
|
import { onMounted, ref } from "vue";
|
|
|
|
|
|
import { ElMessage, ElMessageBox } from 'element-plus'
|
|
|
|
|
|
import Page from '@/components/Pagination/page.vue'
|
2025-10-30 16:29:14 +08:00
|
|
|
|
import {
|
|
|
|
|
|
tstaskPage, addtsTask, updatetsTask, exportTaskSql, deleteTsTaskById,
|
|
|
|
|
|
deleteTsTaskByIds, confirmDeleteTask, selectTsNodesById, getMaxTaskCode,
|
|
|
|
|
|
importTaskSql
|
|
|
|
|
|
} from "@/api/testtask";
|
2025-06-18 09:22:05 +08:00
|
|
|
|
import { storagesBytype } from "@/api/storage";
|
2025-05-23 13:39:29 +08:00
|
|
|
|
import { getDict } from '@/api/dict'
|
2025-10-30 18:14:08 +08:00
|
|
|
|
import { getUserInfo } from '@/api/user';
|
2025-07-15 11:59:01 +08:00
|
|
|
|
///////
|
|
|
|
|
|
let result2 = ref([])
|
|
|
|
|
|
let result1 = ref([
|
|
|
|
|
|
{ name: '任务编号', code: 'task_code' },
|
|
|
|
|
|
{ name: '任务名称', code: 'task_name' },
|
2025-07-15 18:31:08 +08:00
|
|
|
|
{ name: '任务类型', code: 'task_type' },
|
2025-07-15 11:59:01 +08:00
|
|
|
|
{ name: '任务地点', code: 'task_place' },
|
|
|
|
|
|
{ name: '任务人员', code: 'task_person' },
|
2025-07-15 17:58:48 +08:00
|
|
|
|
{ name: '载机名称', code: 'carrier_name' },
|
|
|
|
|
|
{ name: '设备代号_编号', code: 'device_code' },
|
2025-07-15 11:59:01 +08:00
|
|
|
|
{ name: '试验描述', code: 'test_describe' },
|
|
|
|
|
|
{ name: '传感器描述', code: 'sensor_describe' },
|
|
|
|
|
|
{ name: '本地存储空间', code: 'local_storage_id' },
|
|
|
|
|
|
{ name: '备份存储空间', code: 'backup_storage_id' },
|
|
|
|
|
|
])
|
2025-01-21 18:28:13 +08:00
|
|
|
|
//定义表格数据
|
|
|
|
|
|
const tableData: any = ref([]);
|
|
|
|
|
|
// 查询数据
|
|
|
|
|
|
const dataduan = ref([])
|
|
|
|
|
|
const queryParams: any = ref({
|
|
|
|
|
|
current: 1,
|
|
|
|
|
|
size: 20,
|
2025-07-15 11:59:01 +08:00
|
|
|
|
keyword: '',
|
|
|
|
|
|
fieldName: '',
|
2025-01-21 18:28:13 +08:00
|
|
|
|
startDate: '',
|
|
|
|
|
|
endDate: ''
|
|
|
|
|
|
});
|
|
|
|
|
|
const total = ref(0);
|
2025-10-30 17:47:41 +08:00
|
|
|
|
//导入
|
2025-10-30 16:29:14 +08:00
|
|
|
|
const importDialog = ref(false)
|
|
|
|
|
|
const importForm: any = ref({})
|
|
|
|
|
|
const importRules: any = ref({
|
|
|
|
|
|
localStorageId: [{ required: true, message: "请选择本地存储空间", trigger: "change" }],
|
|
|
|
|
|
backupStorageId: [{ required: true, message: "请选择minio存储空间", trigger: "change" }],
|
|
|
|
|
|
})
|
|
|
|
|
|
const fileList = ref([])
|
|
|
|
|
|
const importFormRef = ref()
|
2025-10-30 17:47:41 +08:00
|
|
|
|
// 是否单机
|
2025-10-30 18:14:08 +08:00
|
|
|
|
const standAlone = ref(false)
|
2025-01-21 18:28:13 +08:00
|
|
|
|
//转化时间格式
|
|
|
|
|
|
function zhuandata(dateString: any) {
|
|
|
|
|
|
// 创建Date对象
|
|
|
|
|
|
const date = new Date(dateString);
|
|
|
|
|
|
// 获取年、月、日
|
|
|
|
|
|
const year = date.getFullYear();
|
|
|
|
|
|
const month = String(date.getMonth() + 1).padStart(2, '0'); // 月份从0开始,需要加1
|
|
|
|
|
|
const day = String(date.getDate()).padStart(2, '0');
|
|
|
|
|
|
// 格式化为YYYY-MM-DD
|
|
|
|
|
|
return `${year}-${month}-${day}`;
|
|
|
|
|
|
}
|
|
|
|
|
|
// 表格加载
|
|
|
|
|
|
const loading = ref(false)
|
|
|
|
|
|
//获取表格数据
|
|
|
|
|
|
function getdata() {
|
|
|
|
|
|
loading.value = true
|
2025-05-23 13:39:29 +08:00
|
|
|
|
if (dataduan.value && dataduan.value.length > 0) {
|
2025-01-21 18:28:13 +08:00
|
|
|
|
const dataArr = []
|
|
|
|
|
|
dataduan.value.forEach((item: any) => {
|
|
|
|
|
|
dataArr.push(zhuandata(item))
|
|
|
|
|
|
})
|
|
|
|
|
|
queryParams.value.startDate = dataArr[0]
|
|
|
|
|
|
queryParams.value.endDate = dataArr[1]
|
2025-05-23 13:39:29 +08:00
|
|
|
|
} else {
|
2025-01-21 18:28:13 +08:00
|
|
|
|
queryParams.value.startDate = ''
|
|
|
|
|
|
queryParams.value.endDate = ''
|
|
|
|
|
|
}
|
2025-06-20 18:05:23 +08:00
|
|
|
|
formitemarr.value.length = 0
|
|
|
|
|
|
loading.value = true
|
2025-07-15 11:59:01 +08:00
|
|
|
|
if (checkList1.value.length > 0) {
|
|
|
|
|
|
queryParams.value.fieldName = checkList1.value.join(',')
|
|
|
|
|
|
} else if (checkList2.value.length == 0 && queryParams.value.keyword) {
|
|
|
|
|
|
let result1Name = []
|
|
|
|
|
|
result1.value.forEach((item: any) => {
|
|
|
|
|
|
result1Name.push(item.code)
|
|
|
|
|
|
})
|
|
|
|
|
|
queryParams.value.fieldName = result1Name.join(',')
|
|
|
|
|
|
}
|
|
|
|
|
|
if (checkList2.value.length > 0) {
|
|
|
|
|
|
queryParams.value.attributeContentJson = checkList2.value.join(',')
|
|
|
|
|
|
} else if (checkList2.value.length == 0 && queryParams.value.keyword) {
|
|
|
|
|
|
let result1Name = []
|
2025-06-20 18:05:23 +08:00
|
|
|
|
result2.value.forEach((item: any) => {
|
2025-07-15 11:59:01 +08:00
|
|
|
|
result1Name.push(item.code)
|
|
|
|
|
|
})
|
|
|
|
|
|
queryParams.value.attributeContentJson = result1Name.join(',')
|
2025-06-20 18:05:23 +08:00
|
|
|
|
}
|
2025-07-15 11:59:01 +08:00
|
|
|
|
|
2025-01-21 18:28:13 +08:00
|
|
|
|
tstaskPage(queryParams.value).then((res: any) => {
|
2025-07-15 11:59:01 +08:00
|
|
|
|
visible.value = false
|
2025-01-21 18:28:13 +08:00
|
|
|
|
loading.value = false
|
|
|
|
|
|
tableData.value = res.data.records
|
|
|
|
|
|
queryParams.value.current = res.data.current
|
|
|
|
|
|
queryParams.value.size = res.data.size
|
|
|
|
|
|
total.value = res.data.total
|
2025-06-17 09:41:09 +08:00
|
|
|
|
let arr = []
|
2025-06-20 18:05:23 +08:00
|
|
|
|
// result2.value.length = 0
|
2025-06-17 09:41:09 +08:00
|
|
|
|
tableData.value.forEach((item: any) => {
|
|
|
|
|
|
if (item.taskProps) {
|
|
|
|
|
|
arr = JSON.parse(item.taskProps)
|
|
|
|
|
|
} else {
|
|
|
|
|
|
arr = []
|
|
|
|
|
|
}
|
|
|
|
|
|
item.taskProps = arr
|
2025-06-20 18:05:23 +08:00
|
|
|
|
result2.value = arr
|
2025-07-15 11:59:01 +08:00
|
|
|
|
// result.value = [...new Set([...result1.value, ...result2.value])];
|
2025-06-20 18:05:23 +08:00
|
|
|
|
// debugger
|
|
|
|
|
|
if (item.taskProps.length > 0) {
|
|
|
|
|
|
item.taskProps.forEach((items: any) => {
|
|
|
|
|
|
item[items.code] = items.data
|
|
|
|
|
|
})
|
|
|
|
|
|
}
|
2025-06-17 09:41:09 +08:00
|
|
|
|
});
|
2025-06-20 18:05:23 +08:00
|
|
|
|
if (tableData.value[0].taskProps && tableData.value[0].taskProps.length > 0) {
|
|
|
|
|
|
tableData.value[0].taskProps.forEach((item: any) => {
|
|
|
|
|
|
formitemarr.value.push({ name: item.name, data: '', code: item.code })
|
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
|
|
}
|
2025-01-21 18:28:13 +08:00
|
|
|
|
})
|
|
|
|
|
|
}
|
|
|
|
|
|
//弹框命名
|
|
|
|
|
|
const title = ref("")
|
|
|
|
|
|
//控制弹框显隐
|
|
|
|
|
|
const frame = ref(false)
|
|
|
|
|
|
//新增项目弹框
|
|
|
|
|
|
function addproject() {
|
|
|
|
|
|
frame.value = true
|
2025-03-19 09:17:05 +08:00
|
|
|
|
title.value = "新增试验任务"
|
2025-01-21 18:28:13 +08:00
|
|
|
|
projectForme.value = {
|
|
|
|
|
|
taskName: "",//任务名称
|
|
|
|
|
|
taskDate: "",//任务开始时间
|
|
|
|
|
|
taskPlace: "",//任务地点
|
|
|
|
|
|
taskPerson: "",//任务人员
|
|
|
|
|
|
carrierType: "",// 载体类型
|
|
|
|
|
|
carrierName: "",//载体名称
|
|
|
|
|
|
deviceName: "",//设备名称
|
|
|
|
|
|
taskCode: "",//任务编号
|
2025-05-23 13:39:29 +08:00
|
|
|
|
deviceCode: "",//设备编号
|
|
|
|
|
|
taskType: "",
|
2025-05-24 11:11:36 +08:00
|
|
|
|
testDescribe: "",// 试验描述
|
2025-05-23 13:39:29 +08:00
|
|
|
|
sensorDescribe: "",// 传感器描述
|
2025-06-17 09:41:09 +08:00
|
|
|
|
taskProps: "",//信息
|
2025-06-18 09:22:05 +08:00
|
|
|
|
localStorageId: '',
|
|
|
|
|
|
backupStorageId: ''
|
2025-01-21 18:28:13 +08:00
|
|
|
|
}
|
2025-10-30 18:14:08 +08:00
|
|
|
|
if (standAlone) {
|
|
|
|
|
|
projectForme.value.localStorageId = 1
|
|
|
|
|
|
projectForme.value.backupStorageId = -1
|
2025-10-30 17:47:41 +08:00
|
|
|
|
}
|
|
|
|
|
|
console.log(projectForme.value)
|
2025-06-20 18:05:23 +08:00
|
|
|
|
// formitemarr.value.length = 0
|
2025-06-23 17:29:34 +08:00
|
|
|
|
shidou.value = true
|
2025-01-21 18:28:13 +08:00
|
|
|
|
}
|
|
|
|
|
|
//修改项目弹框
|
|
|
|
|
|
function editproject(row: any) {
|
|
|
|
|
|
projectForme.value = JSON.parse(JSON.stringify(row))
|
2025-06-17 09:41:09 +08:00
|
|
|
|
formitemarr.value = projectForme.value.taskProps
|
2025-05-23 13:39:29 +08:00
|
|
|
|
projectForme.value.taskDate = [projectForme.value.taskStartdate, projectForme.value.taskEnddate]
|
2025-01-21 18:28:13 +08:00
|
|
|
|
title.value = "修改试验任务"
|
|
|
|
|
|
frame.value = true
|
2025-06-20 18:05:23 +08:00
|
|
|
|
formitemarr.value = projectForme.value.taskProps
|
|
|
|
|
|
selectNodes(row)
|
|
|
|
|
|
}
|
|
|
|
|
|
const shidou = ref(false)
|
|
|
|
|
|
function selectNodes(row: any) {
|
|
|
|
|
|
selectTsNodesById({ taskId: row.id }).then((res: any) => {
|
|
|
|
|
|
shidou.value = res.data
|
|
|
|
|
|
})
|
2025-01-21 18:28:13 +08:00
|
|
|
|
}
|
|
|
|
|
|
//删除项目弹框
|
|
|
|
|
|
function delproject(row: any) {
|
|
|
|
|
|
ElMessageBox.confirm(
|
2025-04-24 09:27:30 +08:00
|
|
|
|
'您确定要删除该项目及其中的节点和文件吗?',
|
2025-01-21 18:28:13 +08:00
|
|
|
|
'警告',
|
|
|
|
|
|
{
|
|
|
|
|
|
confirmButtonText: '确定',
|
|
|
|
|
|
cancelButtonText: '取消',
|
|
|
|
|
|
type: 'warning',
|
|
|
|
|
|
}
|
|
|
|
|
|
)
|
|
|
|
|
|
.then(() => {
|
2025-05-28 18:01:24 +08:00
|
|
|
|
confirmDeleteTask({ ids: row.id }).then((res: any) => {
|
|
|
|
|
|
if (res.data.data.status == 1) {
|
|
|
|
|
|
loading.value = true
|
|
|
|
|
|
deleteTsTaskById({ id: row.id }).then((res: any) => {
|
|
|
|
|
|
if (res.code == 0) {
|
|
|
|
|
|
getdata()
|
|
|
|
|
|
ElMessage({
|
|
|
|
|
|
type: 'success',
|
|
|
|
|
|
message: '删除成功',
|
|
|
|
|
|
})
|
|
|
|
|
|
}
|
2025-01-21 18:28:13 +08:00
|
|
|
|
})
|
2025-05-28 18:01:24 +08:00
|
|
|
|
} else {
|
|
|
|
|
|
ElMessage.warning("试验任务中含有已备份的文件,无法删除")
|
|
|
|
|
|
return
|
2025-01-21 18:28:13 +08:00
|
|
|
|
}
|
|
|
|
|
|
})
|
|
|
|
|
|
})
|
|
|
|
|
|
}
|
2025-10-30 16:29:14 +08:00
|
|
|
|
function expproject(row: any) {
|
|
|
|
|
|
ElMessageBox.confirm(
|
|
|
|
|
|
'您确定要导出该任务吗?',
|
|
|
|
|
|
'提示',
|
|
|
|
|
|
{
|
|
|
|
|
|
confirmButtonText: '确定',
|
|
|
|
|
|
cancelButtonText: '取消',
|
|
|
|
|
|
type: 'warning',
|
|
|
|
|
|
}
|
|
|
|
|
|
)
|
|
|
|
|
|
.then(() => {
|
|
|
|
|
|
exportTaskSql({ taskId: row.id }).then((res: any) => {
|
|
|
|
|
|
console.log(res)
|
|
|
|
|
|
console.log('响应头:', res.headers);
|
|
|
|
|
|
if (res) {
|
2025-10-30 17:47:41 +08:00
|
|
|
|
const fileName = `${row.taskCode}_exportdata.zip`; // 或从响应头中获取文件名
|
2025-10-30 16:29:14 +08:00
|
|
|
|
// 处理响应数据
|
2025-10-30 17:47:41 +08:00
|
|
|
|
const blob = new Blob([res], { type: 'application/zip' });
|
2025-10-30 16:29:14 +08:00
|
|
|
|
|
|
|
|
|
|
// 创建临时链接并触发下载
|
|
|
|
|
|
const url = window.URL.createObjectURL(blob);
|
|
|
|
|
|
const link = document.createElement('a');
|
|
|
|
|
|
link.href = url;
|
2025-10-30 17:47:41 +08:00
|
|
|
|
link.download = fileName;
|
2025-10-30 16:29:14 +08:00
|
|
|
|
link.style.display = 'none';
|
|
|
|
|
|
document.body.appendChild(link);
|
|
|
|
|
|
link.click();
|
|
|
|
|
|
document.body.removeChild(link);
|
|
|
|
|
|
window.URL.revokeObjectURL(url);
|
|
|
|
|
|
ElMessage({
|
|
|
|
|
|
type: 'success',
|
|
|
|
|
|
message: '导出成功',
|
|
|
|
|
|
})
|
|
|
|
|
|
} else {
|
|
|
|
|
|
ElMessage.error("导出失败")
|
|
|
|
|
|
return
|
|
|
|
|
|
}
|
|
|
|
|
|
})
|
|
|
|
|
|
})
|
|
|
|
|
|
}
|
2025-01-21 18:28:13 +08:00
|
|
|
|
//表格多选
|
|
|
|
|
|
const tableIdarr = ref([])
|
|
|
|
|
|
function handleSelectionChange(val: any) {
|
|
|
|
|
|
tableIdarr.value = val
|
|
|
|
|
|
}
|
|
|
|
|
|
//多选删除
|
|
|
|
|
|
function delprojectArr() {
|
|
|
|
|
|
const ids = []
|
|
|
|
|
|
tableIdarr.value.forEach((item: any) => {
|
|
|
|
|
|
ids.push(item.id)
|
|
|
|
|
|
})
|
|
|
|
|
|
ElMessageBox.confirm(
|
2025-05-23 13:39:29 +08:00
|
|
|
|
'您确定要删除这些项目及其中的节点和文件吗?',
|
2025-01-21 18:28:13 +08:00
|
|
|
|
'警告',
|
|
|
|
|
|
{
|
|
|
|
|
|
confirmButtonText: '确定',
|
|
|
|
|
|
cancelButtonText: '取消',
|
|
|
|
|
|
type: 'warning',
|
|
|
|
|
|
}
|
|
|
|
|
|
)
|
|
|
|
|
|
.then(() => {
|
2025-05-28 18:01:24 +08:00
|
|
|
|
confirmDeleteTask({ ids: ids.join(',') }).then((res: any) => {
|
|
|
|
|
|
if (res.data.data.status == 1) {
|
|
|
|
|
|
loading.value = true
|
|
|
|
|
|
deleteTsTaskByIds({ ids: ids.join(',') }).then((res: any) => {
|
|
|
|
|
|
if (res.code == 0) {
|
|
|
|
|
|
ElMessage({
|
|
|
|
|
|
type: 'success',
|
|
|
|
|
|
message: '删除成功',
|
|
|
|
|
|
})
|
|
|
|
|
|
getdata()
|
|
|
|
|
|
}
|
2025-01-21 18:28:13 +08:00
|
|
|
|
})
|
2025-05-28 18:01:24 +08:00
|
|
|
|
} else {
|
|
|
|
|
|
ElMessage.warning("试验任务中含有已备份的文件,无法删除")
|
|
|
|
|
|
return
|
2025-01-21 18:28:13 +08:00
|
|
|
|
}
|
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
|
|
})
|
|
|
|
|
|
}
|
|
|
|
|
|
//弹框关闭
|
|
|
|
|
|
function handleClose(formEl: any) {
|
|
|
|
|
|
// if (!formEl) return
|
|
|
|
|
|
// formEl.resetFields()
|
|
|
|
|
|
frame.value = false
|
|
|
|
|
|
}
|
|
|
|
|
|
//表单数据
|
|
|
|
|
|
const ruleFormRef = ref()
|
|
|
|
|
|
const projectForme: any = ref({
|
|
|
|
|
|
taskName: "",//任务名称
|
|
|
|
|
|
taskDate: "",//任务开始时间
|
|
|
|
|
|
taskPlace: "",//任务地点
|
|
|
|
|
|
taskPerson: "",//任务人员
|
|
|
|
|
|
carrierType: "",// 载体类型
|
|
|
|
|
|
carrierName: "",//载体名称
|
|
|
|
|
|
deviceName: "",//设备名称
|
|
|
|
|
|
taskCode: "",//任务编号
|
|
|
|
|
|
deviceCode: ""//设备编号
|
2025-05-23 13:39:29 +08:00
|
|
|
|
, taskType: "",
|
2025-05-24 11:11:36 +08:00
|
|
|
|
testDescribe: "",// 试验描述
|
2025-05-23 13:39:29 +08:00
|
|
|
|
sensorDescribe: "",// 传感器描述
|
2025-06-17 09:41:09 +08:00
|
|
|
|
taskProps: "",//信息
|
2025-06-18 09:22:05 +08:00
|
|
|
|
localStorageId: '',
|
|
|
|
|
|
backupStorageId: ''
|
2025-01-21 18:28:13 +08:00
|
|
|
|
})
|
|
|
|
|
|
//表单确定
|
|
|
|
|
|
async function submitForm(formEl: any) {
|
|
|
|
|
|
if (!formEl) return
|
|
|
|
|
|
await formEl.validate((valid: any, fields: any) => {
|
|
|
|
|
|
if (valid) {
|
2025-06-17 09:41:09 +08:00
|
|
|
|
if (formitemarr.value.length > 0) {
|
|
|
|
|
|
projectForme.value.taskProps = JSON.stringify(formitemarr.value)
|
|
|
|
|
|
} else {
|
|
|
|
|
|
projectForme.value.taskProps = '[]'
|
|
|
|
|
|
}
|
2025-05-23 13:39:29 +08:00
|
|
|
|
if (projectForme.value.taskDate.length > 0) {
|
|
|
|
|
|
projectForme.value.taskStartdate = projectForme.value.taskDate[0]
|
|
|
|
|
|
projectForme.value.taskEnddate = projectForme.value.taskDate[1]
|
|
|
|
|
|
} else {
|
|
|
|
|
|
projectForme.value.taskStartdate = ''
|
|
|
|
|
|
projectForme.value.taskEnddate = ''
|
|
|
|
|
|
}
|
2025-01-21 18:28:13 +08:00
|
|
|
|
if (projectForme.value.id) {
|
|
|
|
|
|
updatetsTask(projectForme.value).then((res: any) => {
|
|
|
|
|
|
if (res.code == 0) {
|
|
|
|
|
|
getdata()
|
|
|
|
|
|
ElMessage.success("修改成功")
|
|
|
|
|
|
frame.value = false
|
|
|
|
|
|
}
|
|
|
|
|
|
})
|
|
|
|
|
|
} else {
|
|
|
|
|
|
addtsTask(projectForme.value).then((res: any) => {
|
|
|
|
|
|
if (res.code == 0) {
|
|
|
|
|
|
getdata()
|
|
|
|
|
|
ElMessage.success("添加成功")
|
|
|
|
|
|
frame.value = false
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
})
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
})
|
|
|
|
|
|
}
|
|
|
|
|
|
//用户弹窗规则定义
|
|
|
|
|
|
const moderules = ref({
|
2025-05-23 13:39:29 +08:00
|
|
|
|
taskType: [{ required: true, message: "请选择任务类型", trigger: "change" }],
|
|
|
|
|
|
taskDate: [{ required: true, message: "请选择任务时间", trigger: "change" }],
|
|
|
|
|
|
taskPlace: [{ required: true, message: "请输入任务地点", trigger: "blur" }],
|
2025-06-18 09:22:05 +08:00
|
|
|
|
localStorageId: [{ required: true, message: "请选择本地存储空间", trigger: "change" }],
|
|
|
|
|
|
backupStorageId: [{ required: true, message: "请选择minio存储空间", trigger: "change" }],
|
2025-01-21 18:28:13 +08:00
|
|
|
|
});
|
|
|
|
|
|
onMounted(() => {
|
2025-10-30 18:14:08 +08:00
|
|
|
|
getUserInfo().then((res: any) => {
|
|
|
|
|
|
const roles = res.data.roles
|
|
|
|
|
|
const hasSingleMachineUser = roles.some(name => name === '单机用户');
|
|
|
|
|
|
if (hasSingleMachineUser) {
|
2025-10-31 09:05:47 +08:00
|
|
|
|
standAlone.value = true
|
2025-10-30 18:14:08 +08:00
|
|
|
|
}
|
2025-10-31 09:05:47 +08:00
|
|
|
|
})
|
2025-01-21 18:28:13 +08:00
|
|
|
|
getdata()
|
2025-05-23 13:39:29 +08:00
|
|
|
|
getDictOne()
|
2025-01-21 18:28:13 +08:00
|
|
|
|
});
|
2025-05-23 13:39:29 +08:00
|
|
|
|
//获取字典项目类型
|
|
|
|
|
|
const dictType = ref([])
|
2025-06-18 09:22:05 +08:00
|
|
|
|
const localarr = ref([])
|
|
|
|
|
|
const minioarr = ref([])
|
2025-05-23 13:39:29 +08:00
|
|
|
|
function getDictOne() {
|
|
|
|
|
|
getDict({ dictcode: 'taskType' }).then((res: any) => {
|
|
|
|
|
|
dictType.value = res.data
|
|
|
|
|
|
})
|
2025-06-18 09:22:05 +08:00
|
|
|
|
storagesBytype({ type: 'local' }).then((res: any) => {
|
|
|
|
|
|
localarr.value = res.data
|
|
|
|
|
|
})
|
|
|
|
|
|
storagesBytype({ type: 'minio' }).then((res: any) => {
|
|
|
|
|
|
minioarr.value = res.data
|
|
|
|
|
|
})
|
2025-05-23 13:39:29 +08:00
|
|
|
|
}
|
|
|
|
|
|
//项目类型转换
|
|
|
|
|
|
function typeName(arr: any, itemCode: any) {
|
|
|
|
|
|
let nameone: any
|
|
|
|
|
|
arr.forEach((item: any) => {
|
|
|
|
|
|
if (item.itemcode == itemCode) {
|
|
|
|
|
|
nameone = item.dictname
|
|
|
|
|
|
}
|
|
|
|
|
|
});
|
|
|
|
|
|
return nameone
|
|
|
|
|
|
}
|
2025-07-15 17:58:48 +08:00
|
|
|
|
function typeName1(arr: any, itemCode: any) {
|
|
|
|
|
|
let nameone: any
|
|
|
|
|
|
arr.forEach((item: any) => {
|
|
|
|
|
|
if (item.id == itemCode) {
|
|
|
|
|
|
nameone = item.name
|
|
|
|
|
|
}
|
|
|
|
|
|
});
|
|
|
|
|
|
return nameone
|
|
|
|
|
|
}
|
2025-05-28 18:01:24 +08:00
|
|
|
|
const logqing = ref(false)
|
2025-05-24 11:11:36 +08:00
|
|
|
|
const logTxt = ref('')
|
2025-05-28 18:01:24 +08:00
|
|
|
|
function Loglist(row: any, title1: any) {
|
2025-05-24 11:11:36 +08:00
|
|
|
|
title.value = title1
|
|
|
|
|
|
logqing.value = true
|
|
|
|
|
|
logTxt.value = row
|
|
|
|
|
|
}
|
2025-05-28 18:01:24 +08:00
|
|
|
|
function handleClose1() {
|
2025-05-24 11:11:36 +08:00
|
|
|
|
logqing.value = false
|
|
|
|
|
|
}
|
2025-06-17 09:41:09 +08:00
|
|
|
|
//添加属性
|
|
|
|
|
|
const formitemarr = ref([])
|
|
|
|
|
|
const dataname = ref('')
|
|
|
|
|
|
const labledone = ref(false)
|
|
|
|
|
|
function addformItem() {
|
|
|
|
|
|
labledone.value = true
|
|
|
|
|
|
dataname.value = ''
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
function labledoneclose() {
|
|
|
|
|
|
labledone.value = false
|
|
|
|
|
|
}
|
|
|
|
|
|
function labledsure() {
|
|
|
|
|
|
if (!dataname.value) {
|
|
|
|
|
|
ElMessage.warning('请输入属性名称')
|
|
|
|
|
|
return
|
|
|
|
|
|
}
|
|
|
|
|
|
generateUniqueId
|
2025-06-20 18:05:23 +08:00
|
|
|
|
formitemarr.value.push({ name: dataname.value, data: '', code: generateUniqueId(8) })
|
2025-06-17 09:41:09 +08:00
|
|
|
|
labledone.value = false
|
|
|
|
|
|
}
|
|
|
|
|
|
function generateUniqueId(length: any) {
|
|
|
|
|
|
const chars = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ';
|
|
|
|
|
|
let result = '';
|
|
|
|
|
|
|
|
|
|
|
|
// 添加时间戳部分(转换为36进制并取字母部分)
|
|
|
|
|
|
const timePart = Date.now().toString(36).toUpperCase().replace(/[0-9]/g, '');
|
|
|
|
|
|
result += timePart;
|
|
|
|
|
|
|
|
|
|
|
|
// 补充随机字符
|
|
|
|
|
|
for (let i = result.length; i < length; i++) {
|
|
|
|
|
|
result += chars.charAt(Math.floor(Math.random() * chars.length));
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
return result.substring(0, length);
|
|
|
|
|
|
}
|
|
|
|
|
|
function dellable(index: any) {
|
|
|
|
|
|
formitemarr.value.splice(index, 1)
|
|
|
|
|
|
}
|
2025-07-15 11:59:01 +08:00
|
|
|
|
const checkList1 = ref([])
|
|
|
|
|
|
const checkList2 = ref([])
|
2025-07-15 17:58:48 +08:00
|
|
|
|
const visible: any = ref(false)
|
|
|
|
|
|
function reset() {
|
|
|
|
|
|
checkList1.value.length = 0
|
|
|
|
|
|
checkList2.value.length = 0
|
|
|
|
|
|
queryParams.value.keyword = ''
|
|
|
|
|
|
dataduan.value.length = 0
|
|
|
|
|
|
visible.vlaue = false
|
|
|
|
|
|
getdata()
|
|
|
|
|
|
}
|
2025-10-30 16:29:14 +08:00
|
|
|
|
function importproject() {
|
2025-10-31 09:05:47 +08:00
|
|
|
|
fileList.value = []
|
|
|
|
|
|
importForm.value.fileName = ''
|
|
|
|
|
|
importForm.value.localStorageId = ''
|
|
|
|
|
|
importForm.value.backupStorageId = ''
|
2025-10-30 16:29:14 +08:00
|
|
|
|
getMaxTaskCode().then((res: any) => {
|
|
|
|
|
|
if (res.data) {
|
|
|
|
|
|
importForm.value.taskCode = res.data
|
|
|
|
|
|
importDialog.value = true
|
|
|
|
|
|
} else {
|
|
|
|
|
|
ElMessage.warning('查询编号失败')
|
|
|
|
|
|
return
|
|
|
|
|
|
}
|
|
|
|
|
|
})
|
|
|
|
|
|
}
|
|
|
|
|
|
function fileChange(uploadFile, uploadFiles) {
|
|
|
|
|
|
console.log(uploadFile, uploadFiles)
|
|
|
|
|
|
importForm.value.fileName = uploadFile.name
|
|
|
|
|
|
fileList.value = []
|
|
|
|
|
|
fileList.value = [uploadFile.raw]
|
|
|
|
|
|
}
|
2025-10-30 17:47:41 +08:00
|
|
|
|
const isconnect = ref(false)
|
2025-10-30 16:29:14 +08:00
|
|
|
|
function importSubmit(formEl: any) {
|
|
|
|
|
|
if (!formEl) return
|
|
|
|
|
|
formEl.validate((valid: any, fields: any) => {
|
|
|
|
|
|
if (valid) {
|
|
|
|
|
|
if (fileList.value.length == 0) {
|
2025-10-30 18:14:08 +08:00
|
|
|
|
return ElMessage.warning('请上传导入文件!')
|
|
|
|
|
|
}
|
2025-10-31 09:05:47 +08:00
|
|
|
|
if (isconnect.value) {
|
2025-10-30 18:14:08 +08:00
|
|
|
|
return
|
2025-10-30 16:29:14 +08:00
|
|
|
|
}
|
|
|
|
|
|
const formData = new FormData()
|
|
|
|
|
|
formData.append('file', fileList.value[0])
|
|
|
|
|
|
formData.append('taskCode', importForm.value.taskCode)
|
|
|
|
|
|
formData.append('localStorageId', importForm.value.localStorageId)
|
|
|
|
|
|
formData.append('backupStorageId', importForm.value.backupStorageId)
|
2025-10-30 18:14:08 +08:00
|
|
|
|
isconnect.value = true
|
2025-10-30 16:29:14 +08:00
|
|
|
|
importTaskSql(formData).then((res: any) => {
|
2025-10-30 18:14:08 +08:00
|
|
|
|
if (res.code == '0') {
|
|
|
|
|
|
isconnect.value = false
|
|
|
|
|
|
importDialog.value = false
|
2025-10-30 16:29:14 +08:00
|
|
|
|
ElMessage.success('上传成功')
|
2025-10-30 18:14:08 +08:00
|
|
|
|
getdata()
|
|
|
|
|
|
} else {
|
|
|
|
|
|
isconnect.value = false
|
|
|
|
|
|
importDialog.value = false
|
|
|
|
|
|
ElMessage.error(res.msg)
|
2025-10-30 16:29:14 +08:00
|
|
|
|
}
|
|
|
|
|
|
})
|
|
|
|
|
|
}
|
|
|
|
|
|
})
|
|
|
|
|
|
}
|
|
|
|
|
|
function importClose() {
|
|
|
|
|
|
importDialog.value = false
|
|
|
|
|
|
}
|
2025-01-21 18:28:13 +08:00
|
|
|
|
</script>
|
|
|
|
|
|
|
|
|
|
|
|
<template>
|
|
|
|
|
|
<div>
|
|
|
|
|
|
<div class="record-box">
|
|
|
|
|
|
<div class="sou_title">
|
|
|
|
|
|
<div class="sou_title_left">
|
2025-07-15 11:59:01 +08:00
|
|
|
|
<el-input style="margin-right: 10px ;width:240px;" v-model="queryParams.keyword" clearable
|
|
|
|
|
|
@change="getdata()" placeholder="全属性搜索"></el-input>
|
|
|
|
|
|
<el-button type="primary" @click="getdata()">搜索</el-button>
|
|
|
|
|
|
<el-popover placement="bottom" :width="400" trigger="click" :visible="visible">
|
|
|
|
|
|
<template #reference>
|
|
|
|
|
|
<el-button @click="visible = true" type="primary">高级</el-button>
|
|
|
|
|
|
</template>
|
2025-07-15 17:58:48 +08:00
|
|
|
|
<div style="display: flex;width: 100%;justify-content: space-between;margin: 0px 0px 10px 0px;">
|
|
|
|
|
|
<div class="shuxingtitle" style="margin: 0px;padding: 0px;font-size: 18px;">
|
|
|
|
|
|
<div class="kuai" style="height: 16px;"></div>
|
|
|
|
|
|
<div class="txt"> 高级搜索</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<div class="glose" @click="visible = false">x</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<div style="display: flex;align-items: center;">
|
2025-07-15 11:59:01 +08:00
|
|
|
|
<el-input style="margin-right: 10px;width:240px;" v-model="queryParams.keyword" clearable
|
2025-07-15 17:58:48 +08:00
|
|
|
|
placeholder="全属性搜索"></el-input>
|
2025-07-15 11:59:01 +08:00
|
|
|
|
<el-button type="primary" @click="getdata()">搜索</el-button>
|
2025-07-15 17:58:48 +08:00
|
|
|
|
<el-button type="primary" @click="reset()">重置</el-button>
|
2025-07-15 11:59:01 +08:00
|
|
|
|
</div>
|
|
|
|
|
|
<div class="shuxingtitle" v-if="result1.length > 0">
|
|
|
|
|
|
<div class="kuai"></div>
|
|
|
|
|
|
<div class="txt"> 固定属性</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<el-checkbox-group v-model="checkList1">
|
|
|
|
|
|
<el-checkbox v-for="item in result1" :key="item.code" :label="item.name"
|
|
|
|
|
|
:value="item.code" />
|
|
|
|
|
|
</el-checkbox-group>
|
|
|
|
|
|
<div class="shuxingtitle" v-if="result2.length > 0">
|
|
|
|
|
|
<div class="kuai"></div>
|
|
|
|
|
|
<div class="txt"> 自定义属性</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<el-checkbox-group v-model="checkList2">
|
|
|
|
|
|
<el-checkbox v-for="item in result2" :key="item.code" :label="item.name"
|
|
|
|
|
|
:value="item.code" />
|
|
|
|
|
|
</el-checkbox-group>
|
|
|
|
|
|
<el-date-picker v-model="dataduan" type="daterange" range-separator="至"
|
|
|
|
|
|
style="margin-right: 10px ;margin-bottom: 10px;" start-placeholder="开始时间"
|
|
|
|
|
|
end-placeholder="结束时间" />
|
|
|
|
|
|
</el-popover>
|
|
|
|
|
|
|
|
|
|
|
|
<!-- <el-button v-else type="primary" style="margin-top: 10px;" @click="getdata()">搜索</el-button> -->
|
2025-01-21 18:28:13 +08:00
|
|
|
|
</div>
|
|
|
|
|
|
<div>
|
|
|
|
|
|
<el-button type="primary" @click="addproject()">新增</el-button>
|
|
|
|
|
|
<el-button type="primary" @click="delprojectArr()" :disabled="tableIdarr.length == 0">删除</el-button>
|
2025-10-30 18:14:08 +08:00
|
|
|
|
<el-button v-if="!standAlone" type="primary" @click="importproject()">导入</el-button>
|
2025-01-21 18:28:13 +08:00
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<el-table v-loading="loading" :data="tableData" @selection-change="handleSelectionChange"
|
2025-06-17 09:41:09 +08:00
|
|
|
|
:header-cell-style="{ background: 'rgb(250 250 250)', color: '#383838', height: '50px' }"
|
2025-07-15 11:59:01 +08:00
|
|
|
|
style="width: 100%; height: calc(71vh);margin-bottom: 20px;" border>
|
2025-01-21 18:28:13 +08:00
|
|
|
|
<el-table-column type="selection" width="40" />
|
|
|
|
|
|
<el-table-column prop="taskCode" label="任务编号" width="90"></el-table-column>
|
2025-05-23 13:39:29 +08:00
|
|
|
|
<el-table-column prop="taskName" label="任务名称" width="600"></el-table-column>
|
|
|
|
|
|
<el-table-column prop="taskType" label="任务类型" width="120">
|
|
|
|
|
|
<template #default="scope">
|
|
|
|
|
|
<span>{{ typeName(dictType, scope.row.taskType) }}</span>
|
|
|
|
|
|
</template>
|
|
|
|
|
|
</el-table-column>
|
|
|
|
|
|
<el-table-column prop="taskDate" label="任务时间" width="320" align="center">
|
|
|
|
|
|
<template #default="scope">
|
|
|
|
|
|
<span>{{ scope.row.taskStartdate && scope.row.taskEnddate ? scope.row.taskStartdate + '-' +
|
|
|
|
|
|
scope.row.taskEnddate : '' }}</span>
|
|
|
|
|
|
</template>
|
|
|
|
|
|
</el-table-column>
|
|
|
|
|
|
<el-table-column prop="taskPlace" label="任务地点" width="180"></el-table-column>
|
2025-05-24 11:11:36 +08:00
|
|
|
|
<el-table-column prop="taskPerson" label="任务人员" width="280"></el-table-column>
|
2025-05-23 13:39:29 +08:00
|
|
|
|
<el-table-column prop="carrierName" label="载机名称" width="180"></el-table-column>
|
|
|
|
|
|
<el-table-column prop="deviceCode" label="设备代号_编号" width="180"></el-table-column>
|
2025-06-20 18:05:23 +08:00
|
|
|
|
|
2025-05-24 11:11:36 +08:00
|
|
|
|
<el-table-column prop="testDescribe" label="试验描述" width="320">
|
|
|
|
|
|
<template #default="scope">
|
|
|
|
|
|
<!-- <span>{{ scope.row.testDescribe }}</span> -->
|
|
|
|
|
|
<div class="ellipsis">
|
|
|
|
|
|
<span class="single-line-ellipsis">{{ scope.row.testDescribe }}</span>
|
2025-05-28 18:01:24 +08:00
|
|
|
|
<img src="@/assets/MenuIcon/xqing.png" alt="" title="详情"
|
|
|
|
|
|
@click="Loglist(scope.row.testDescribe, '试验描述详情')" style="cursor: pointer;">
|
|
|
|
|
|
</div>
|
2025-05-24 11:11:36 +08:00
|
|
|
|
</template>
|
|
|
|
|
|
</el-table-column>
|
|
|
|
|
|
<el-table-column prop="sensorDescribe" label="传感器描述" width="320">
|
|
|
|
|
|
<template #default="scope">
|
|
|
|
|
|
<!-- <span>{{ scope.row.testDescribe }}</span> -->
|
|
|
|
|
|
<div class="ellipsis">
|
|
|
|
|
|
<span class="single-line-ellipsis">{{ scope.row.sensorDescribe }}</span>
|
2025-05-28 18:01:24 +08:00
|
|
|
|
<img src="@/assets/MenuIcon/xqing.png" alt="" title="详情"
|
|
|
|
|
|
@click="Loglist(scope.row.sensorDescribe, '传感器描述详情')" style="cursor: pointer;">
|
|
|
|
|
|
</div>
|
2025-05-24 11:11:36 +08:00
|
|
|
|
</template>
|
|
|
|
|
|
</el-table-column>
|
2025-10-30 18:14:08 +08:00
|
|
|
|
<el-table-column v-if="!standAlone" prop="localStorageId" label="本地存储空间" width="180">
|
2025-07-15 17:58:48 +08:00
|
|
|
|
<template #default="scope">
|
|
|
|
|
|
<span>{{ typeName1(localarr, scope.row.localStorageId) }}</span>
|
|
|
|
|
|
</template>
|
|
|
|
|
|
</el-table-column>
|
2025-10-30 18:14:08 +08:00
|
|
|
|
<el-table-column v-if="!standAlone" prop="backupStorageId" label="备份存储空间" width="180">
|
2025-07-15 17:58:48 +08:00
|
|
|
|
<template #default="scope">
|
|
|
|
|
|
<span>{{ typeName1(minioarr, scope.row.backupStorageId) }}</span>
|
|
|
|
|
|
</template>
|
|
|
|
|
|
</el-table-column>
|
2025-10-30 16:29:14 +08:00
|
|
|
|
<el-table-column fixed="right" label="操作" width="100" align="center">
|
2025-01-21 18:28:13 +08:00
|
|
|
|
<template #default="scope">
|
|
|
|
|
|
<span
|
|
|
|
|
|
style="display: flex;display: -webkit-flex;justify-content: space-around;-webkit-justify-content: space-around; ">
|
|
|
|
|
|
<img src="@/assets/MenuIcon/lbcz_xg.png" alt="" title="修改" @click="editproject(scope.row)"
|
|
|
|
|
|
style="cursor: pointer;">
|
|
|
|
|
|
<img src="@/assets/MenuIcon/lbcz_sc.png" alt="" title="删除" @click="delproject(scope.row)"
|
|
|
|
|
|
style="cursor: pointer;">
|
2025-10-31 09:05:47 +08:00
|
|
|
|
<img v-if="standAlone" src="@/assets/MenuIcon/lbcz_dc.png" alt="" title="导出"
|
|
|
|
|
|
@click="expproject(scope.row)" style="cursor: pointer;">
|
2025-01-21 18:28:13 +08:00
|
|
|
|
</span>
|
|
|
|
|
|
</template>
|
|
|
|
|
|
</el-table-column>
|
2025-06-20 18:05:23 +08:00
|
|
|
|
<el-table-column v-for="item in result2" :prop="item.code" :label="item.name"
|
|
|
|
|
|
width="180"></el-table-column>
|
2025-01-21 18:28:13 +08:00
|
|
|
|
</el-table>
|
|
|
|
|
|
<Page :total="total" v-model:size="queryParams.size" v-model:current="queryParams.current"
|
|
|
|
|
|
@pagination="getdata()">
|
|
|
|
|
|
</Page>
|
|
|
|
|
|
</div>
|
2025-05-24 11:11:36 +08:00
|
|
|
|
<el-dialog :title="title" v-model="frame" width="60%" :before-close="handleClose" top="30px" draggable
|
|
|
|
|
|
:close-on-click-modal="false" destroy-on-close>
|
2025-05-23 13:39:29 +08:00
|
|
|
|
<el-form ref="ruleFormRef" style="max-width:100%" :model="projectForme" :rules="moderules"
|
2025-01-21 18:28:13 +08:00
|
|
|
|
label-width="auto" class="demo-ruleForm" status-icon>
|
2025-06-17 09:41:09 +08:00
|
|
|
|
<el-scrollbar height="80vh">
|
|
|
|
|
|
<div style="width: 100%;display: flex;justify-content: space-between;align-items: center;">
|
|
|
|
|
|
<el-form-item label="任务编号" style="width: 50%;">
|
|
|
|
|
|
<el-input v-model="projectForme.taskCode" maxlength="40" show-word-limit disabled
|
|
|
|
|
|
style="width: 100%;" />
|
|
|
|
|
|
</el-form-item>
|
|
|
|
|
|
<el-form-item label="任务名称" style="width: 50%;margin-left: 15px;">
|
|
|
|
|
|
<el-input v-model="projectForme.taskName" show-word-limit disabled />
|
|
|
|
|
|
</el-form-item>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<div style="width: 100%;display: flex;justify-content: space-between;align-items: center;">
|
|
|
|
|
|
<el-form-item label="任务类型" prop="taskType" style="width: 50%;">
|
2025-06-18 09:22:05 +08:00
|
|
|
|
<el-select v-model="projectForme.taskType" clearable placeholder=" ">
|
2025-06-17 09:41:09 +08:00
|
|
|
|
<el-option v-for="item in dictType" :key="item.itemcode" :label="item.dictname"
|
|
|
|
|
|
:value="item.itemcode" />
|
|
|
|
|
|
</el-select>
|
|
|
|
|
|
</el-form-item>
|
|
|
|
|
|
<el-form-item label="任务时间" prop="taskDate" style="width: 50%;margin-left: 15px;">
|
2025-07-15 11:59:01 +08:00
|
|
|
|
<el-date-picker :disabled="projectForme.id" v-model="projectForme.taskDate" type="daterange"
|
|
|
|
|
|
range-separator="-" start-placeholder="开始时间" end-placeholder="结束时间" format="YYYY-MM-DD"
|
2025-06-17 09:41:09 +08:00
|
|
|
|
value-format="YYYY-MM-DD" />
|
|
|
|
|
|
</el-form-item>
|
|
|
|
|
|
</div>
|
2025-06-20 18:05:23 +08:00
|
|
|
|
|
2025-06-17 09:41:09 +08:00
|
|
|
|
<div style="width: 100%;display: flex;justify-content: space-between;align-items: center;">
|
2025-07-15 11:59:01 +08:00
|
|
|
|
<el-form-item label="任务地点" prop="taskPlace" style="width: 50%;">
|
|
|
|
|
|
<el-input :disabled="projectForme.id" v-model="projectForme.taskPlace" maxlength="500"
|
|
|
|
|
|
show-word-limit />
|
2025-06-17 09:41:09 +08:00
|
|
|
|
</el-form-item>
|
|
|
|
|
|
<el-form-item label="任务人员" style="width: 50%;margin-left: 15px;">
|
|
|
|
|
|
<el-input v-model="projectForme.taskPerson" maxlength="500" show-word-limit />
|
|
|
|
|
|
</el-form-item>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<div style="width: 100%;display: flex;justify-content: space-between;align-items: center;">
|
2025-07-15 11:59:01 +08:00
|
|
|
|
<el-form-item label="载机名称" style="width: 50%;">
|
|
|
|
|
|
<el-input :disabled="projectForme.id" v-model="projectForme.carrierName" maxlength="40"
|
|
|
|
|
|
show-word-limit />
|
2025-06-17 09:41:09 +08:00
|
|
|
|
</el-form-item>
|
|
|
|
|
|
<el-form-item label="设备代号_编号" style="width: 50%;margin-left: 15px;">
|
2025-07-15 11:59:01 +08:00
|
|
|
|
<el-input :disabled="projectForme.id" v-model="projectForme.deviceCode" maxlength="40"
|
|
|
|
|
|
show-word-limit />
|
2025-06-17 09:41:09 +08:00
|
|
|
|
</el-form-item>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<!-- <el-form-item label="载体类型">
|
2025-03-26 09:54:02 +08:00
|
|
|
|
<el-input v-model="projectForme.carrierType" maxlength="200" show-word-limit />
|
2025-05-23 13:39:29 +08:00
|
|
|
|
</el-form-item> -->
|
2025-05-24 11:11:36 +08:00
|
|
|
|
|
2025-06-17 09:41:09 +08:00
|
|
|
|
<el-form-item label="试验描述">
|
2025-07-05 09:28:58 +08:00
|
|
|
|
<el-input v-model="projectForme.testDescribe" :rows="7" type="textarea" show-word-limit />
|
2025-06-17 09:41:09 +08:00
|
|
|
|
</el-form-item>
|
|
|
|
|
|
<el-form-item label="传感器描述">
|
2025-07-05 09:28:58 +08:00
|
|
|
|
<el-input v-model="projectForme.sensorDescribe" :rows="7" type="textarea" show-word-limit />
|
2025-06-17 09:41:09 +08:00
|
|
|
|
</el-form-item>
|
2025-07-15 11:59:01 +08:00
|
|
|
|
|
2025-06-23 17:29:34 +08:00
|
|
|
|
<!-- <el-form-item label="设备名称">
|
|
|
|
|
|
<el-input v-model="projectForme.deviceName" maxlength="40" show-word-limit />
|
|
|
|
|
|
</el-form-item> -->
|
|
|
|
|
|
<el-form-item v-for="(item, index) in formitemarr" :label="item.name">
|
|
|
|
|
|
<div style="width: 100%;display: flex;align-items: center;justify-content: space-between;">
|
|
|
|
|
|
<el-input v-model="item.data" style="width: 92%;" />
|
|
|
|
|
|
<el-button type="primary" @click="dellable(index)">删除</el-button>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</el-form-item>
|
2025-10-31 09:32:32 +08:00
|
|
|
|
<div v-if="standAlone"
|
2025-10-30 18:14:08 +08:00
|
|
|
|
style="width: 100%;display: flex;justify-content: space-between;align-items: center;">
|
2025-06-20 18:05:23 +08:00
|
|
|
|
<el-form-item label="本地存储空间" prop="localStorageId" style="width: 50%;">
|
|
|
|
|
|
<el-select v-model="projectForme.localStorageId" clearable placeholder=" "
|
2025-06-23 17:29:34 +08:00
|
|
|
|
:disabled="!shidou">
|
2025-06-20 18:05:23 +08:00
|
|
|
|
<el-option v-for="item in localarr" :key="item.id" :label="item.name"
|
|
|
|
|
|
:value="item.id" />
|
|
|
|
|
|
</el-select>
|
|
|
|
|
|
</el-form-item>
|
2025-06-23 17:29:34 +08:00
|
|
|
|
<el-form-item label="备份存储空间" prop="backupStorageId" style="width: 50%;margin-left: 15px;">
|
2025-06-20 18:05:23 +08:00
|
|
|
|
<el-select v-model="projectForme.backupStorageId" clearable placeholder=" "
|
2025-06-23 17:29:34 +08:00
|
|
|
|
:disabled="!shidou">
|
2025-06-20 18:05:23 +08:00
|
|
|
|
<el-option v-for="item in minioarr" :key="item.id" :label="item.name"
|
|
|
|
|
|
:value="item.id" />
|
|
|
|
|
|
</el-select>
|
|
|
|
|
|
</el-form-item>
|
|
|
|
|
|
</div>
|
2025-06-17 09:41:09 +08:00
|
|
|
|
</el-scrollbar>
|
|
|
|
|
|
|
2025-01-21 18:28:13 +08:00
|
|
|
|
<el-form-item>
|
2025-06-18 09:22:05 +08:00
|
|
|
|
<div style="width: 100%;display: flex;justify-content: end;">
|
|
|
|
|
|
<el-button type="primary" @click="addformItem">添加属性</el-button>
|
|
|
|
|
|
<el-button type="primary" @click="submitForm(ruleFormRef)">确定</el-button>
|
|
|
|
|
|
<el-button @click="handleClose(ruleFormRef)">取消</el-button>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</el-form-item>
|
2025-06-17 09:41:09 +08:00
|
|
|
|
|
2025-01-21 18:28:13 +08:00
|
|
|
|
</el-form>
|
|
|
|
|
|
</el-dialog>
|
2025-06-17 09:41:09 +08:00
|
|
|
|
<el-dialog :title="'添加属性'" v-model="labledone" width="20%" :before-close="labledoneclose" top="30px" draggable
|
|
|
|
|
|
:close-on-click-modal="false" destroy-on-close>
|
|
|
|
|
|
<el-input v-model="dataname" placeholder="请输入属性名称" />
|
|
|
|
|
|
<div style="width: 100%;display: flex;justify-content: end;margin-top: 10px;">
|
|
|
|
|
|
<el-button type="primary" @click="labledsure()">确定</el-button>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</el-dialog>
|
2025-06-20 18:05:23 +08:00
|
|
|
|
<!-- <el-dialog :title="'自定义属性详情'" v-model="attbute" width="1200px" :before-close="attributeclose" top="30px"
|
2025-06-17 09:41:09 +08:00
|
|
|
|
draggable :close-on-click-modal="false" destroy-on-close>
|
|
|
|
|
|
<el-table v-if="result2.length > 0" v-loading="attloading" :data="result1"
|
|
|
|
|
|
:header-cell-style="{ background: 'rgb(250 250 250)', color: '#383838', height: '50px' }"
|
|
|
|
|
|
style="width: 100%; height: calc(30vh);margin-bottom: 20px;" border>
|
|
|
|
|
|
<el-table-column v-for="item in result2" :prop="item.id" :label="item.name"></el-table-column>
|
|
|
|
|
|
</el-table>
|
|
|
|
|
|
<div v-else
|
|
|
|
|
|
style="width: 100%;height: 285px;display: flex;align-items: center;justify-content: center;border: 1px solid #ebeef5;">
|
|
|
|
|
|
<el-empty description="暂无数据" />
|
|
|
|
|
|
</div>
|
2025-06-20 18:05:23 +08:00
|
|
|
|
</el-dialog> -->
|
2025-05-24 11:11:36 +08:00
|
|
|
|
<el-dialog :title="title" v-model="logqing" width="60%" :before-close="handleClose1" top="30px" draggable
|
|
|
|
|
|
:close-on-click-modal="false" destroy-on-close>
|
2025-05-28 18:01:24 +08:00
|
|
|
|
<div class="texlog">
|
|
|
|
|
|
<el-scrollbar height="80vh">
|
|
|
|
|
|
{{ logTxt }}
|
|
|
|
|
|
</el-scrollbar>
|
|
|
|
|
|
</div>
|
2025-05-24 11:11:36 +08:00
|
|
|
|
</el-dialog>
|
2025-10-30 16:29:14 +08:00
|
|
|
|
<el-dialog title="导入试验任务参数设定" v-model="importDialog" width="30%" :before-close="importClose" top="30px"
|
|
|
|
|
|
:close-on-click-modal="false" destroy-on-close>
|
|
|
|
|
|
<!-- importForm -->
|
|
|
|
|
|
<el-form ref="importFormRef" style="max-width: 600px" :model="importForm" :rules="importRules"
|
|
|
|
|
|
label-width="auto">
|
|
|
|
|
|
<el-form-item label="新编号" prop="taskCode">
|
|
|
|
|
|
<div>{{ importForm.taskCode }}</div>
|
|
|
|
|
|
</el-form-item>
|
|
|
|
|
|
<el-form-item label="本地存储空间" prop="localStorageId" style="width: 100%;">
|
|
|
|
|
|
<el-select v-model="importForm.localStorageId" clearable placeholder="请选择本地存储空间">
|
|
|
|
|
|
<el-option v-for="item in localarr" :key="item.id" :label="item.name" :value="item.id" />
|
|
|
|
|
|
</el-select>
|
|
|
|
|
|
</el-form-item>
|
|
|
|
|
|
<el-form-item label="备份存储空间" prop="backupStorageId" style="width: 100%">
|
|
|
|
|
|
<el-select v-model="importForm.backupStorageId" clearable placeholder="请选择备份存储空间">
|
|
|
|
|
|
<el-option v-for="item in minioarr" :key="item.id" :label="item.name" :value="item.id" />
|
|
|
|
|
|
</el-select>
|
|
|
|
|
|
</el-form-item>
|
|
|
|
|
|
<el-form-item>
|
|
|
|
|
|
<div style="width: 100%;display: flex;align-items: center;">
|
2025-10-31 09:13:27 +08:00
|
|
|
|
|
2025-10-30 16:29:14 +08:00
|
|
|
|
<el-upload v-model="fileList" :auto-upload="false" :show-file-list="false" class="upload-demo"
|
|
|
|
|
|
action="" :on-change="fileChange">
|
2025-10-31 09:13:27 +08:00
|
|
|
|
<el-button type="primary" style="padding: 0px 5px;">上传导入文件</el-button>
|
2025-10-30 16:29:14 +08:00
|
|
|
|
</el-upload>
|
2025-10-31 09:13:27 +08:00
|
|
|
|
<el-input v-model="importForm.fileName" disabled style="margin-left: 10px;" />
|
2025-10-30 16:29:14 +08:00
|
|
|
|
</div>
|
|
|
|
|
|
</el-form-item>
|
|
|
|
|
|
</el-form>
|
|
|
|
|
|
<div style="width: 100%;display: flex;justify-content: end;margin-top: 10px;">
|
2025-10-30 18:14:08 +08:00
|
|
|
|
<el-button type="primary" @click="importSubmit(importFormRef)">导入</el-button>
|
2025-10-30 16:29:14 +08:00
|
|
|
|
</div>
|
|
|
|
|
|
</el-dialog>
|
2025-01-21 18:28:13 +08:00
|
|
|
|
</div>
|
|
|
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
|
|
<style lang="scss" scoped>
|
2025-05-28 18:01:24 +08:00
|
|
|
|
.texlog {
|
2025-05-24 11:11:36 +08:00
|
|
|
|
width: 100%;
|
|
|
|
|
|
padding: 10px;
|
|
|
|
|
|
border: 1px solid #ccc;
|
|
|
|
|
|
border-radius: 5px;
|
|
|
|
|
|
}
|
2025-05-28 18:01:24 +08:00
|
|
|
|
|
|
|
|
|
|
.ellipsis {
|
2025-05-24 11:11:36 +08:00
|
|
|
|
display: flex;
|
|
|
|
|
|
width: 100%;
|
|
|
|
|
|
align-items: center;
|
|
|
|
|
|
justify-content: space-between;
|
|
|
|
|
|
}
|
2025-05-28 18:01:24 +08:00
|
|
|
|
|
2025-05-24 11:11:36 +08:00
|
|
|
|
.single-line-ellipsis {
|
|
|
|
|
|
width: 270px;
|
|
|
|
|
|
/* 限制容器宽度 */
|
|
|
|
|
|
white-space: nowrap;
|
|
|
|
|
|
/* 禁止文本换行 */
|
|
|
|
|
|
overflow: hidden;
|
|
|
|
|
|
/* 隐藏超出范围的内容 */
|
|
|
|
|
|
text-overflow: ellipsis;
|
|
|
|
|
|
/* 使用省略号 */
|
|
|
|
|
|
}
|
2025-05-28 18:01:24 +08:00
|
|
|
|
|
2025-01-21 18:28:13 +08:00
|
|
|
|
.record-box {
|
|
|
|
|
|
padding: 20px;
|
|
|
|
|
|
width: 100%;
|
|
|
|
|
|
height: calc(100vh - 130px);
|
|
|
|
|
|
overflow: auto;
|
|
|
|
|
|
background-color: rgba(255, 255, 255, 1);
|
|
|
|
|
|
border: none;
|
|
|
|
|
|
border-radius: 3px;
|
|
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
|
|
|
|
|
|
|
.sou_title {
|
|
|
|
|
|
width: 100%;
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
justify-content: space-between;
|
2025-06-20 18:05:23 +08:00
|
|
|
|
// align-items: center;
|
2025-01-21 18:28:13 +08:00
|
|
|
|
margin-bottom: 20px;
|
|
|
|
|
|
|
|
|
|
|
|
.sou_title_left {
|
|
|
|
|
|
width: 80%;
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
align-items: center;
|
2025-05-23 13:39:29 +08:00
|
|
|
|
// justify-content: space-between;
|
|
|
|
|
|
flex-wrap: wrap;
|
2025-01-21 18:28:13 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
2025-07-15 11:59:01 +08:00
|
|
|
|
|
|
|
|
|
|
.shuxingtitle {
|
|
|
|
|
|
font-size: 16px;
|
|
|
|
|
|
font-weight: 600;
|
|
|
|
|
|
color: #409eff;
|
|
|
|
|
|
margin-top: 5px;
|
|
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
align-items: center;
|
|
|
|
|
|
|
|
|
|
|
|
.kuai {
|
|
|
|
|
|
width: 3px;
|
|
|
|
|
|
height: 14px;
|
|
|
|
|
|
background: #409eff;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.txt {
|
|
|
|
|
|
padding: 0px 0px 0px 5px;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
2025-07-15 17:58:48 +08:00
|
|
|
|
|
|
|
|
|
|
.glose {
|
|
|
|
|
|
cursor: pointer;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.glose:hover {
|
|
|
|
|
|
color: #409eff;
|
|
|
|
|
|
}
|
2025-01-21 18:28:13 +08:00
|
|
|
|
</style>
|