【功能完善】IOT: 产品物模型-dataSpecs 校验规则完善

pull/622/head
puhui999 2024-12-17 15:03:57 +08:00
parent 6b9aaf3c9a
commit c8ab57f726
2 changed files with 98 additions and 17 deletions

View File

@ -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"> <el-form-item
<template v-for="item in property.dataSpecsList" :key="item.value"> 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-form-item
:prop="`property.dataSpecsList[${index}].name`"
:rules="[
{ required: true, message: '枚举描述不能为空' },
{ validator: validateBoolName, trigger: 'blur' }
]"
class="flex-1 mb-0"
>
<el-input <el-input
v-model="item.name" v-model="item.name"
:placeholder="`如:${item.value === 0 ? '关' : '开'}`" :placeholder="`如:${item.value === 0 ? '关' : '开'}`"
class="w-255px!" 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>

View File

@ -67,7 +67,6 @@ const formData = ref<ThingModelData>({
} }
} }
}) })
// TODO puhui999:
const formRules = reactive({ const formRules = reactive({
name: [ name: [
{ required: true, message: '功能名称不能为空', trigger: 'blur' }, { required: true, message: '功能名称不能为空', trigger: 'blur' },
@ -87,7 +86,7 @@ const formRules = reactive({
trigger: 'blur' trigger: 'blur'
}, },
{ {
validator: (rule, value, callback) => { validator: (_: any, value: string, callback: any) => {
const reservedKeywords = ['set', 'get', 'post', 'property', 'event', 'time', 'value'] const reservedKeywords = ['set', 'get', 'post', 'property', 'event', 'time', 'value']
if (reservedKeywords.includes(value)) { if (reservedKeywords.includes(value)) {
callback( callback(
@ -103,9 +102,7 @@ const formRules = reactive({
}, },
trigger: 'blur' trigger: 'blur'
} }
], ]
'property.dataType.type': [{ required: true, message: '数据类型不能为空', trigger: 'blur' }],
'property.accessMode': [{ required: true, message: '读写类型不能为空', trigger: 'blur' }]
}) })
const formRef = ref() const formRef = ref()