|
@@ -1,5 +1,9 @@
|
|
<template>
|
|
<template>
|
|
- <el-form-item label="数据类型" prop="dataType">
|
|
|
|
|
|
+ <el-form-item
|
|
|
|
+ :rules="[{ required: true, message: '请选择数据类型', trigger: 'change' }]"
|
|
|
|
+ label="数据类型"
|
|
|
|
+ prop="property.dataType"
|
|
|
|
+ >
|
|
<el-select v-model="property.dataType" placeholder="请选择数据类型" @change="handleChange">
|
|
<el-select v-model="property.dataType" placeholder="请选择数据类型" @change="handleChange">
|
|
<el-option
|
|
<el-option
|
|
v-for="option in dataTypeOptions"
|
|
v-for="option in dataTypeOptions"
|
|
@@ -24,21 +28,43 @@
|
|
v-model="property.dataSpecsList"
|
|
v-model="property.dataSpecsList"
|
|
/>
|
|
/>
|
|
<!-- 布尔型配置 -->
|
|
<!-- 布尔型配置 -->
|
|
- <el-form-item v-if="property.dataType === DataSpecsDataType.BOOL" label="布尔值" prop="bool">
|
|
|
|
- <template v-for="item in property.dataSpecsList" :key="item.value">
|
|
|
|
|
|
+ <el-form-item
|
|
|
|
+ v-if="property.dataType === DataSpecsDataType.BOOL"
|
|
|
|
+ :rules="[{ required: true, message: '请输入布尔值名称', trigger: 'blur' }]"
|
|
|
|
+ label="布尔值"
|
|
|
|
+ prop="property.dataSpecsList"
|
|
|
|
+ >
|
|
|
|
+ <template v-for="(item, index) in property.dataSpecsList" :key="item.value">
|
|
<div class="flex items-center justify-start w-1/1 mb-5px">
|
|
<div class="flex items-center justify-start w-1/1 mb-5px">
|
|
<span>{{ item.value }}</span>
|
|
<span>{{ item.value }}</span>
|
|
<span class="mx-2">-</span>
|
|
<span class="mx-2">-</span>
|
|
- <el-input
|
|
|
|
- v-model="item.name"
|
|
|
|
- :placeholder="`如:${item.value === 0 ? '关' : '开'}`"
|
|
|
|
- class="w-255px!"
|
|
|
|
- />
|
|
|
|
|
|
+ <el-form-item
|
|
|
|
+ :prop="`property.dataSpecsList[${index}].name`"
|
|
|
|
+ :rules="[
|
|
|
|
+ { required: true, message: '枚举描述不能为空' },
|
|
|
|
+ { validator: validateBoolName, trigger: 'blur' }
|
|
|
|
+ ]"
|
|
|
|
+ class="flex-1 mb-0"
|
|
|
|
+ >
|
|
|
|
+ <el-input
|
|
|
|
+ v-model="item.name"
|
|
|
|
+ :placeholder="`如:${item.value === 0 ? '关' : '开'}`"
|
|
|
|
+ class="w-255px!"
|
|
|
|
+ />
|
|
|
|
+ </el-form-item>
|
|
</div>
|
|
</div>
|
|
</template>
|
|
</template>
|
|
</el-form-item>
|
|
</el-form-item>
|
|
<!-- 文本型配置 -->
|
|
<!-- 文本型配置 -->
|
|
- <el-form-item v-if="property.dataType === DataSpecsDataType.TEXT" label="数据长度" prop="text">
|
|
|
|
|
|
+ <el-form-item
|
|
|
|
+ v-if="property.dataType === DataSpecsDataType.TEXT"
|
|
|
|
+ :rules="[
|
|
|
|
+ { required: true, message: '请输入文本字节长度', trigger: 'blur' },
|
|
|
|
+ { validator: validateTextLength, trigger: 'blur' }
|
|
|
|
+ ]"
|
|
|
|
+ label="数据长度"
|
|
|
|
+ prop="property.dataSpecs.length"
|
|
|
|
+ >
|
|
<el-input v-model="property.dataSpecs.length" class="w-255px!" placeholder="请输入文本字节长度">
|
|
<el-input v-model="property.dataSpecs.length" class="w-255px!" placeholder="请输入文本字节长度">
|
|
<template #append>字节</template>
|
|
<template #append>字节</template>
|
|
</el-input>
|
|
</el-input>
|
|
@@ -53,14 +79,24 @@
|
|
v-model="property.dataSpecs"
|
|
v-model="property.dataSpecs"
|
|
/>
|
|
/>
|
|
<!-- TODO puhui999: Struct 属性待完善 -->
|
|
<!-- TODO puhui999: Struct 属性待完善 -->
|
|
- <el-form-item label="读写类型" prop="accessMode">
|
|
|
|
|
|
+ <el-form-item
|
|
|
|
+ :rules="[{ required: true, message: '请选择读写类型', trigger: 'change' }]"
|
|
|
|
+ label="读写类型"
|
|
|
|
+ prop="property.accessMode"
|
|
|
|
+ >
|
|
<el-radio-group v-model="property.accessMode">
|
|
<el-radio-group v-model="property.accessMode">
|
|
<el-radio label="rw">读写</el-radio>
|
|
<el-radio label="rw">读写</el-radio>
|
|
<el-radio label="r">只读</el-radio>
|
|
<el-radio label="r">只读</el-radio>
|
|
</el-radio-group>
|
|
</el-radio-group>
|
|
</el-form-item>
|
|
</el-form-item>
|
|
<el-form-item label="属性描述" prop="description">
|
|
<el-form-item label="属性描述" prop="description">
|
|
- <el-input v-model="property.description" placeholder="请输入属性描述" type="textarea" />
|
|
|
|
|
|
+ <el-input
|
|
|
|
+ v-model="property.description"
|
|
|
|
+ :maxlength="200"
|
|
|
|
+ :rows="3"
|
|
|
|
+ placeholder="请输入属性描述"
|
|
|
|
+ type="textarea"
|
|
|
|
+ />
|
|
</el-form-item>
|
|
</el-form-item>
|
|
</template>
|
|
</template>
|
|
|
|
|
|
@@ -73,6 +109,7 @@ import {
|
|
ThingModelNumberTypeDataSpecs
|
|
ThingModelNumberTypeDataSpecs
|
|
} from './dataSpecs'
|
|
} from './dataSpecs'
|
|
import { ThingModelProperty } from '@/api/iot/thinkmodelfunction'
|
|
import { ThingModelProperty } from '@/api/iot/thinkmodelfunction'
|
|
|
|
+import { isEmpty } from '@/utils/is'
|
|
|
|
|
|
/** 物模型数据 */
|
|
/** 物模型数据 */
|
|
defineOptions({ name: 'ThingModelDataSpecs' })
|
|
defineOptions({ name: 'ThingModelDataSpecs' })
|
|
@@ -105,6 +142,53 @@ const handleChange = (dataType: any) => {
|
|
break
|
|
break
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
+
|
|
|
|
+/** 校验布尔值名称 */
|
|
|
|
+const validateBoolName = (_: any, value: string, callback: any) => {
|
|
|
|
+ if (isEmpty(value)) {
|
|
|
|
+ callback(new Error('布尔值名称不能为空'))
|
|
|
|
+ return
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ // 检查开头字符
|
|
|
|
+ if (!/^[\u4e00-\u9fa5a-zA-Z0-9]/.test(value)) {
|
|
|
|
+ callback(new Error('布尔值名称必须以中文、英文字母或数字开头'))
|
|
|
|
+ return
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ // 检查整体格式
|
|
|
|
+ if (!/^[\u4e00-\u9fa5a-zA-Z0-9][a-zA-Z0-9\u4e00-\u9fa5_-]*$/.test(value)) {
|
|
|
|
+ callback(new Error('布尔值名称只能包含中文、英文字母、数字、下划线和短划线'))
|
|
|
|
+ return
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ // 检查长度(一个中文算一个字符)
|
|
|
|
+ if (value.length > 20) {
|
|
|
|
+ callback(new Error('布尔值名称长度不能超过20个字符'))
|
|
|
|
+ return
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ callback()
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+/** 校验文本长度 */
|
|
|
|
+const validateTextLength = (_: any, value: any, callback: any) => {
|
|
|
|
+ if (isEmpty(value)) {
|
|
|
|
+ callback(new Error('文本长度不能为空'))
|
|
|
|
+ return
|
|
|
|
+ }
|
|
|
|
+ if (isNaN(Number(value))) {
|
|
|
|
+ callback(new Error('文本长度必须是数字'))
|
|
|
|
+ return
|
|
|
|
+ }
|
|
|
|
+ callback()
|
|
|
|
+}
|
|
</script>
|
|
</script>
|
|
|
|
|
|
-<style lang="scss" scoped></style>
|
|
|
|
|
|
+<style lang="scss" scoped>
|
|
|
|
+:deep(.el-form-item) {
|
|
|
|
+ .el-form-item {
|
|
|
|
+ margin-bottom: 0;
|
|
|
|
+ }
|
|
|
|
+}
|
|
|
|
+</style>
|