main
parent
dad69ea7f7
commit
2730102450
|
@ -88,6 +88,10 @@ const infoApi = {
|
||||||
importP(params,template_name) {
|
importP(params,template_name) {
|
||||||
return postPBRequest('/template', params, 53212,template_name)
|
return postPBRequest('/template', params, 53212,template_name)
|
||||||
},
|
},
|
||||||
|
// 获取模板点位类型
|
||||||
|
getPointType(params) {
|
||||||
|
return postPBRequest('/template', params, 53011)
|
||||||
|
},
|
||||||
|
|
||||||
// 点位导出
|
// 点位导出
|
||||||
exportP(params) {
|
exportP(params) {
|
||||||
|
|
|
@ -93,7 +93,7 @@ export default {
|
||||||
template_name: [
|
template_name: [
|
||||||
{ required: true, message: "请选择通讯模板", trigger: "blur" },
|
{ required: true, message: "请选择通讯模板", trigger: "blur" },
|
||||||
],
|
],
|
||||||
driver_description: [{ required: true, message: "请输入驱动描述", trigger: "blur" }],
|
driver_description: [{ required: false, message: "请输入驱动描述", trigger: "blur" }],
|
||||||
driver_type: [{ required: true, message: "请选择通讯驱动", trigger: "change" }]
|
driver_type: [{ required: true, message: "请选择通讯驱动", trigger: "change" }]
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
|
@ -49,7 +49,7 @@ export default {
|
||||||
{ required: true, validator: validName, trigger: "blur" },
|
{ required: true, validator: validName, trigger: "blur" },
|
||||||
],
|
],
|
||||||
template_description: [
|
template_description: [
|
||||||
{ required: true, message: "请输入模板描述", trigger: "blur" }
|
{ required: false, message: "请输入模板描述", trigger: "blur" }
|
||||||
],
|
],
|
||||||
template_type: [
|
template_type: [
|
||||||
{ required: true, message: "请选择类型", trigger: "blur" }
|
{ required: true, message: "请选择类型", trigger: "blur" }
|
||||||
|
|
|
@ -7,22 +7,23 @@
|
||||||
<el-form-item label="点位地址:" prop="address">
|
<el-form-item label="点位地址:" prop="address">
|
||||||
<el-input v-model="addForm.address" placeholder="请输入点位地址:0-65535" clearable type="number" />
|
<el-input v-model="addForm.address" placeholder="请输入点位地址:0-65535" clearable type="number" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="点位类型:" prop="point_type">
|
|
||||||
<el-select v-model="addForm.point_type" size="mini" placeholder="请选择点位类型">
|
|
||||||
<el-option v-for="item in datatypeArr" :key="item.value" :label="item.label" :value="item.value" />
|
|
||||||
</el-select>
|
|
||||||
</el-form-item>
|
|
||||||
<el-form-item label="寄存器:" prop="register">
|
<el-form-item label="寄存器:" prop="register">
|
||||||
<el-select v-model="addForm.register" size="mini" placeholder="请选择寄存器">
|
<el-select v-model="addForm.register" size="mini" placeholder="请选择寄存器" @change="changeRegister">
|
||||||
<el-option v-for="item in registerArr" :key="item.value" :label="item.label" :value="item.value" />
|
<el-option v-for="item in registerArr" :key="item.value" :label="item.label" :value="item.value" />
|
||||||
</el-select>
|
</el-select>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
|
<el-form-item label="点位类型:" prop="point_type">
|
||||||
|
<el-select v-model="addForm.point_type" size="mini" placeholder="请选择点位类型">
|
||||||
|
<el-option v-for="item in datatypeArr" :disabled="item.disabled || item.disabled1" :key="item.value" :label="item.label"
|
||||||
|
:value="item.value" />
|
||||||
|
</el-select>
|
||||||
|
</el-form-item>
|
||||||
<el-form-item label="点位描述:" prop="point_description">
|
<el-form-item label="点位描述:" prop="point_description">
|
||||||
<el-input v-model="addForm.point_description" placeholder="请输入点位描述(不超过50个字符)" clearable maxlength="50"/>
|
<el-input v-model="addForm.point_description" placeholder="请输入点位描述(不超过50个字符)" clearable maxlength="50" />
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="读写权限:" prop="point_permissions">
|
<el-form-item label="读写权限:" prop="point_permissions">
|
||||||
<el-select v-model="addForm.point_permissions" size="mini" placeholder="请选择读写权限">
|
<el-select v-model="addForm.point_permissions" size="mini" placeholder="请选择读写权限">
|
||||||
<el-option v-for="item in perOptions" :key="item.value" :label="item.label" :value="item.value" />
|
<el-option v-for="item in perOptions" :disabled="item.disabled" :key="item.value" :label="item.label" :value="item.value" />
|
||||||
</el-select>
|
</el-select>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="缩放系数:" prop="multiplier">
|
<el-form-item label="缩放系数:" prop="multiplier">
|
||||||
|
@ -45,7 +46,7 @@ import { onMounted, reactive, ref, toRefs, computed, nextTick } from "vue";
|
||||||
import infoApi from "@/api/infoApi.js";
|
import infoApi from "@/api/infoApi.js";
|
||||||
import { ElMessage, ElMessageBox } from "element-plus";
|
import { ElMessage, ElMessageBox } from "element-plus";
|
||||||
export default {
|
export default {
|
||||||
props: ["formData", "dialogVisible", "pointData", "type"],
|
props: ["formData", "dialogVisible", "pointData", "type", "pointTypeOptions"],
|
||||||
emits: ["dialogClose", "dialogSuccess"],
|
emits: ["dialogClose", "dialogSuccess"],
|
||||||
setup(props, ctx) {
|
setup(props, ctx) {
|
||||||
const checkAddress = (rule, value, callback) => {
|
const checkAddress = (rule, value, callback) => {
|
||||||
|
@ -68,54 +69,25 @@ export default {
|
||||||
const state = reactive({
|
const state = reactive({
|
||||||
addForm: {
|
addForm: {
|
||||||
},
|
},
|
||||||
datatypeArr: [{
|
datatypeArr: [],
|
||||||
label: 'bool',
|
|
||||||
value: 1
|
|
||||||
}, {
|
|
||||||
label: 'int16',
|
|
||||||
value: 2
|
|
||||||
}, {
|
|
||||||
label: 'int32',
|
|
||||||
value: 3
|
|
||||||
}, {
|
|
||||||
label: 'int64',
|
|
||||||
value: 4
|
|
||||||
},
|
|
||||||
{
|
|
||||||
label: 'unit16',
|
|
||||||
value: 5
|
|
||||||
}, {
|
|
||||||
label: 'unit32',
|
|
||||||
value: 6
|
|
||||||
},
|
|
||||||
{
|
|
||||||
label: 'unit64',
|
|
||||||
value: 7
|
|
||||||
}, {
|
|
||||||
label: 'float32',
|
|
||||||
value: 8
|
|
||||||
}, {
|
|
||||||
label: 'float64',
|
|
||||||
value: 9
|
|
||||||
}],
|
|
||||||
registerArr: [
|
registerArr: [
|
||||||
{
|
{
|
||||||
label: 'coil_status',
|
label: 'coil_status',
|
||||||
value: 1
|
value: 1
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
label: 'input_status',
|
label: 'input_status',
|
||||||
value: 2
|
value: 2
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
label: 'input_register',
|
label: 'input_register',
|
||||||
value: 3
|
value: 3
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
label: 'holding_register',
|
label: 'holding_register',
|
||||||
value: 4
|
value: 4
|
||||||
}],
|
}],
|
||||||
|
|
||||||
byte_orderArr: [{
|
byte_orderArr: [{
|
||||||
label: 'null',
|
label: 'null',
|
||||||
value: 1
|
value: 1
|
||||||
|
@ -165,7 +137,7 @@ export default {
|
||||||
}],
|
}],
|
||||||
perOptions: [
|
perOptions: [
|
||||||
{
|
{
|
||||||
label: '只读',
|
label: '可读',
|
||||||
value: 1
|
value: 1
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
@ -184,10 +156,10 @@ export default {
|
||||||
point_type: [{ required: true, message: "请选择点位类型", trigger: "blur" }],
|
point_type: [{ required: true, message: "请选择点位类型", trigger: "blur" }],
|
||||||
register: [{ required: true, message: "请输入寄存器", trigger: "blur" }],
|
register: [{ required: true, message: "请输入寄存器", trigger: "blur" }],
|
||||||
multiplier: [{ required: true, message: "请输入缩放系数", trigger: "blur" }],
|
multiplier: [{ required: true, message: "请输入缩放系数", trigger: "blur" }],
|
||||||
point_unit: [{ required: true, message: "请输入点位单位", trigger: "blur" }],
|
point_unit: [{ required: false, message: "请输入点位单位", trigger: "blur" }],
|
||||||
point_permissions: [{ required: true, message: "请输入读写权限", trigger: "blur" }],
|
point_permissions: [{ required: true, message: "请输入读写权限", trigger: "blur" }],
|
||||||
point_description: [
|
point_description: [
|
||||||
{ required: true, message: "请输入点位描述", trigger: "blur" }
|
{ required: false, message: "请输入点位描述", trigger: "blur" }
|
||||||
],
|
],
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
@ -196,8 +168,65 @@ export default {
|
||||||
});
|
});
|
||||||
|
|
||||||
onMounted(() => {
|
onMounted(() => {
|
||||||
state.addForm = props.pointData
|
state.addForm = props.pointData;
|
||||||
|
getPointData();
|
||||||
|
changeRegister();
|
||||||
});
|
});
|
||||||
|
|
||||||
|
const getPointData = () => {
|
||||||
|
state.datatypeArr = [];
|
||||||
|
for (let i in props.pointTypeOptions) {
|
||||||
|
let obj = {
|
||||||
|
value: Number(i),
|
||||||
|
label: props.pointTypeOptions[i],
|
||||||
|
disabled: (Number(i) === 2 || Number(i) === 6 || Number(i) === 12) && (props.formData.template_type === 1)
|
||||||
|
}
|
||||||
|
state.datatypeArr.push(obj);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
const changeRegister = () => {
|
||||||
|
if(state.addForm.register === 1) {
|
||||||
|
state.datatypeArr.forEach(ele => { // 只能选择bool
|
||||||
|
ele.disabled1 = ele.value!== 1
|
||||||
|
})
|
||||||
|
state.perOptions.forEach(ele => {// 可读可写
|
||||||
|
ele.disabled = false;
|
||||||
|
})
|
||||||
|
state.addForm.point_type = 1;
|
||||||
|
state.addForm.point_permissions = 1;
|
||||||
|
}
|
||||||
|
if(state.addForm.register === 2) {
|
||||||
|
state.datatypeArr.forEach(ele => {// 只能选择bool
|
||||||
|
ele.disabled1 = ele.value!== 1
|
||||||
|
})
|
||||||
|
state.perOptions.forEach(ele => {// 只能可读
|
||||||
|
ele.disabled = ele.value === 2;
|
||||||
|
})
|
||||||
|
state.addForm.point_type = 1;
|
||||||
|
state.addForm.point_permissions = 1;
|
||||||
|
}
|
||||||
|
if(state.addForm.register === 3) {
|
||||||
|
state.datatypeArr.forEach(ele => {// 不支持bool
|
||||||
|
ele.disabled1 = ele.value === 1
|
||||||
|
})
|
||||||
|
state.perOptions.forEach(ele => {// 只能可读
|
||||||
|
ele.disabled = ele.value === 2;
|
||||||
|
})
|
||||||
|
state.addForm.point_type = 3;
|
||||||
|
state.addForm.point_permissions = 1;
|
||||||
|
}
|
||||||
|
if(state.addForm.register === 4) {
|
||||||
|
state.datatypeArr.forEach(ele => {// 不支持bool
|
||||||
|
ele.disabled1 = ele.value === 1
|
||||||
|
})
|
||||||
|
state.perOptions.forEach(ele => {// 可读可写
|
||||||
|
ele.disabled = false;
|
||||||
|
})
|
||||||
|
state.addForm.point_type = 3;
|
||||||
|
state.addForm.point_permissions = 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
const closeDialog = () => {
|
const closeDialog = () => {
|
||||||
ctx.emit("dialogClose");
|
ctx.emit("dialogClose");
|
||||||
};
|
};
|
||||||
|
@ -230,7 +259,8 @@ export default {
|
||||||
visible,
|
visible,
|
||||||
closeDialog,
|
closeDialog,
|
||||||
saveP,
|
saveP,
|
||||||
ruleFormRef
|
ruleFormRef,
|
||||||
|
changeRegister
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
|
@ -3,8 +3,6 @@
|
||||||
v-model="visible" title="点位管理">
|
v-model="visible" title="点位管理">
|
||||||
<el-card class="top-title">
|
<el-card class="top-title">
|
||||||
<span>模板名称:{{ formData.template_name }}</span>
|
<span>模板名称:{{ formData.template_name }}</span>
|
||||||
<!-- <span>模板描述:{{ formData.template_description }}</span>
|
|
||||||
<span>模板类型:{{ templateData[formData.template_type] }}</span> -->
|
|
||||||
<span>点位数量:{{ propertiesData.length }}</span>
|
<span>点位数量:{{ propertiesData.length }}</span>
|
||||||
</el-card>
|
</el-card>
|
||||||
<div class="top-btn">
|
<div class="top-btn">
|
||||||
|
@ -25,7 +23,7 @@
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
<el-table-column prop="point_type" label="点位类型" align="center" show-overflow-tooltip>
|
<el-table-column prop="point_type" label="点位类型" align="center" show-overflow-tooltip>
|
||||||
<template #default="scope">
|
<template #default="scope">
|
||||||
<span>{{ typeData[scope.row.point_type] }}</span>
|
<span>{{ pointTypeOptions[scope.row.point_type] }}</span>
|
||||||
</template>
|
</template>
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
|
|
||||||
|
@ -42,7 +40,7 @@
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
<el-table-column prop="point_permissions" label="读写权限" align="center" show-overflow-tooltip>
|
<el-table-column prop="point_permissions" label="读写权限" align="center" show-overflow-tooltip>
|
||||||
<template #default="scope">
|
<template #default="scope">
|
||||||
<span>{{ scope.row.point_permissions == 1 ? '只读' : '可写' }}</span>
|
<span>{{ scope.row.point_permissions == 1 ? '可读' : '可写' }}</span>
|
||||||
</template>
|
</template>
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
<el-table-column label="操作" align="center" width="200" show-overflow-tooltip>
|
<el-table-column label="操作" align="center" width="200" show-overflow-tooltip>
|
||||||
|
@ -56,7 +54,7 @@
|
||||||
</template>
|
</template>
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
</el-table>
|
</el-table>
|
||||||
<AddPoint :type="type" :formData="formData1" :pointData="pointData" :dialogVisible="dialogVisible1"
|
<AddPoint :type="type" :pointTypeOptions="pointTypeOptions" :formData="formData1" :pointData="pointData" :dialogVisible="dialogVisible1"
|
||||||
v-if="dialogVisible1" @dialogClose="dialogVisible1 = false" @dialogSuccess="dialogSuccess1">
|
v-if="dialogVisible1" @dialogClose="dialogVisible1 = false" @dialogSuccess="dialogSuccess1">
|
||||||
</AddPoint>
|
</AddPoint>
|
||||||
<ExportPoint :formData="formData1" :dialogVisible="dialogVisible2" v-if="dialogVisible2"
|
<ExportPoint :formData="formData1" :dialogVisible="dialogVisible2" v-if="dialogVisible2"
|
||||||
|
@ -84,17 +82,6 @@ export default {
|
||||||
dialogVisible1: false,
|
dialogVisible1: false,
|
||||||
dialogVisible2: false,
|
dialogVisible2: false,
|
||||||
propertiesData: [],
|
propertiesData: [],
|
||||||
typeData: {
|
|
||||||
1: 'bool',
|
|
||||||
2: 'int16',
|
|
||||||
3: 'int32',
|
|
||||||
4: 'int64',
|
|
||||||
5: 'unit16',
|
|
||||||
6: 'unit32',
|
|
||||||
7: 'unit64',
|
|
||||||
8: 'float32',
|
|
||||||
9: 'float64'
|
|
||||||
},
|
|
||||||
byteData: {
|
byteData: {
|
||||||
1: 'null',
|
1: 'null',
|
||||||
2: '12',
|
2: '12',
|
||||||
|
@ -116,16 +103,27 @@ export default {
|
||||||
3: 'input_register',
|
3: 'input_register',
|
||||||
4: 'holding_register'
|
4: 'holding_register'
|
||||||
},
|
},
|
||||||
type: 'I'
|
type: 'I',
|
||||||
|
pointTypeOptions:{}
|
||||||
});
|
});
|
||||||
const visible = computed(() => {
|
const visible = computed(() => {
|
||||||
return props.dialogVisible;
|
return props.dialogVisible;
|
||||||
});
|
});
|
||||||
|
|
||||||
onMounted(() => {
|
onMounted(() => {
|
||||||
|
getPointType();
|
||||||
getPointList();
|
getPointList();
|
||||||
});
|
});
|
||||||
|
|
||||||
|
const getPointType = async () => {
|
||||||
|
const parm = {};
|
||||||
|
const res = await infoApi.getPointType(parm);
|
||||||
|
|
||||||
|
if (res.code == 0) {
|
||||||
|
state.pointTypeOptions = res.data;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
const getPointList = async () => {
|
const getPointList = async () => {
|
||||||
const parm = {
|
const parm = {
|
||||||
template_name: props.formData.template_name
|
template_name: props.formData.template_name
|
||||||
|
@ -178,12 +176,12 @@ export default {
|
||||||
state.type = 'I';
|
state.type = 'I';
|
||||||
state.pointData = {
|
state.pointData = {
|
||||||
point_name: '',
|
point_name: '',
|
||||||
address: 36,
|
address: null,
|
||||||
point_type: 1,
|
point_type: 1,
|
||||||
point_permissions: 1,
|
point_permissions: 1,
|
||||||
multiplier: 1,
|
multiplier: 1,
|
||||||
point_unit: 'on',
|
point_unit: '',
|
||||||
register: 1
|
register: 3
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -47,7 +47,8 @@
|
||||||
<fieldset class="right-div1 box2">
|
<fieldset class="right-div1 box2">
|
||||||
<legend class="box-ht">网卡信息</legend>
|
<legend class="box-ht">网卡信息</legend>
|
||||||
<div v-for="(item, index) of deviceData.running_information && deviceData.running_information.netinfo" :key="index" class="all-con">
|
<div v-for="(item, index) of deviceData.running_information && deviceData.running_information.netinfo" :key="index" class="all-con">
|
||||||
<p class="title">网卡{{ item.name }}的使用情况</p>
|
<p class="title" v-if="index===0">网卡A</p>
|
||||||
|
<p class="title" v-else>网卡B</p>
|
||||||
<div class="data">
|
<div class="data">
|
||||||
<span>
|
<span>
|
||||||
<span class="name">字节</span>
|
<span class="name">字节</span>
|
||||||
|
|
|
@ -10,7 +10,8 @@
|
||||||
size="large"
|
size="large"
|
||||||
>
|
>
|
||||||
<div v-for="(item, index) of formData.ip" :key="index" :class="formData.ip.length ==1 ? 'ipDiv' : 'moreipDiv'">
|
<div v-for="(item, index) of formData.ip" :key="index" :class="formData.ip.length ==1 ? 'ipDiv' : 'moreipDiv'">
|
||||||
<p>{{ item.name || "网卡" }}</p>
|
<p v-if="index===0">{{ "网卡A【最外侧网口】" }}</p>
|
||||||
|
<p v-else>{{ "网卡B【靠近电源侧网口】" }}</p>
|
||||||
<div class="info-div">
|
<div class="info-div">
|
||||||
<div>
|
<div>
|
||||||
<el-form-item
|
<el-form-item
|
||||||
|
|
Loading…
Reference in New Issue