2024-12-11 13:14:47 +08:00
|
|
|
|
<template>
|
2024-12-17 15:03:57 +08:00
|
|
|
|
<el-form-item
|
|
|
|
|
:rules="[{ required: true, message: '请选择数据类型', trigger: 'change' }]"
|
|
|
|
|
label="数据类型"
|
|
|
|
|
prop="property.dataType"
|
|
|
|
|
>
|
2024-12-15 23:15:51 +08:00
|
|
|
|
<el-select v-model="property.dataType" placeholder="请选择数据类型" @change="handleChange">
|
2024-12-23 17:29:14 +08:00
|
|
|
|
<!-- ARRAY 和 STRUCT 类型数据相互嵌套时,最多支持递归嵌套2层(父和子) -->
|
2024-12-14 23:27:27 +08:00
|
|
|
|
<el-option
|
2024-12-23 17:29:14 +08:00
|
|
|
|
v-for="option in getDataTypeOptions"
|
2024-12-14 23:27:27 +08:00
|
|
|
|
:key="option.value"
|
|
|
|
|
:label="option.label"
|
|
|
|
|
:value="option.value"
|
|
|
|
|
/>
|
|
|
|
|
</el-select>
|
2024-12-13 17:36:20 +08:00
|
|
|
|
</el-form-item>
|
|
|
|
|
<!-- 数值型配置 -->
|
2024-12-23 17:29:14 +08:00
|
|
|
|
<ThingModelNumberDataSpecs
|
2024-12-13 17:36:20 +08:00
|
|
|
|
v-if="
|
|
|
|
|
[DataSpecsDataType.INT, DataSpecsDataType.DOUBLE, DataSpecsDataType.FLOAT].includes(
|
2024-12-15 23:15:51 +08:00
|
|
|
|
property.dataType || ''
|
2024-12-13 17:36:20 +08:00
|
|
|
|
)
|
|
|
|
|
"
|
2024-12-15 23:15:51 +08:00
|
|
|
|
v-model="property.dataSpecs"
|
2024-12-13 17:36:20 +08:00
|
|
|
|
/>
|
|
|
|
|
<!-- 枚举型配置 -->
|
2024-12-23 17:29:14 +08:00
|
|
|
|
<ThingModelEnumDataSpecs
|
2024-12-15 23:15:51 +08:00
|
|
|
|
v-if="property.dataType === DataSpecsDataType.ENUM"
|
|
|
|
|
v-model="property.dataSpecsList"
|
2024-12-13 17:36:20 +08:00
|
|
|
|
/>
|
2024-12-14 23:09:14 +08:00
|
|
|
|
<!-- 布尔型配置 -->
|
2024-12-23 18:06:42 +08:00
|
|
|
|
<el-form-item v-if="property.dataType === DataSpecsDataType.BOOL" label="布尔值">
|
2024-12-17 15:03:57 +08:00
|
|
|
|
<template v-for="(item, index) in property.dataSpecsList" :key="item.value">
|
2024-12-14 23:09:14 +08:00
|
|
|
|
<div class="flex items-center justify-start w-1/1 mb-5px">
|
|
|
|
|
<span>{{ item.value }}</span>
|
|
|
|
|
<span class="mx-2">-</span>
|
2024-12-17 15:03:57 +08:00
|
|
|
|
<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>
|
2024-12-14 23:09:14 +08:00
|
|
|
|
</div>
|
|
|
|
|
</template>
|
|
|
|
|
</el-form-item>
|
2024-12-14 23:15:00 +08:00
|
|
|
|
<!-- 文本型配置 -->
|
2024-12-17 15:03:57 +08:00
|
|
|
|
<el-form-item
|
|
|
|
|
v-if="property.dataType === DataSpecsDataType.TEXT"
|
|
|
|
|
label="数据长度"
|
|
|
|
|
prop="property.dataSpecs.length"
|
|
|
|
|
>
|
2024-12-16 17:47:02 +08:00
|
|
|
|
<el-input v-model="property.dataSpecs.length" class="w-255px!" placeholder="请输入文本字节长度">
|
2024-12-14 23:15:00 +08:00
|
|
|
|
<template #append>字节</template>
|
|
|
|
|
</el-input>
|
|
|
|
|
</el-form-item>
|
2024-12-14 23:27:27 +08:00
|
|
|
|
<!-- 时间型配置 -->
|
2024-12-16 17:47:02 +08:00
|
|
|
|
<el-form-item v-if="property.dataType === DataSpecsDataType.DATE" label="时间格式" prop="date">
|
|
|
|
|
<el-input class="w-255px!" disabled placeholder="String类型的UTC时间戳(毫秒)" />
|
2024-12-14 23:27:27 +08:00
|
|
|
|
</el-form-item>
|
2024-12-15 00:21:40 +08:00
|
|
|
|
<!-- 数组型配置-->
|
2024-12-23 17:29:14 +08:00
|
|
|
|
<ThingModelArrayDataSpecs
|
2024-12-15 23:15:51 +08:00
|
|
|
|
v-if="property.dataType === DataSpecsDataType.ARRAY"
|
2024-12-16 17:47:02 +08:00
|
|
|
|
v-model="property.dataSpecs"
|
2024-12-15 00:21:40 +08:00
|
|
|
|
/>
|
2024-12-23 17:29:14 +08:00
|
|
|
|
<!-- Struct 型配置-->
|
|
|
|
|
<ThingModelStructDataSpecs
|
|
|
|
|
v-if="property.dataType === DataSpecsDataType.STRUCT"
|
|
|
|
|
v-model="property.dataSpecsList"
|
|
|
|
|
/>
|
2024-12-23 18:06:42 +08:00
|
|
|
|
<el-form-item v-if="!isStructDataSpecs" label="读写类型" prop="property.accessMode">
|
2024-12-15 23:15:51 +08:00
|
|
|
|
<el-radio-group v-model="property.accessMode">
|
|
|
|
|
<el-radio label="rw">读写</el-radio>
|
|
|
|
|
<el-radio label="r">只读</el-radio>
|
|
|
|
|
</el-radio-group>
|
|
|
|
|
</el-form-item>
|
|
|
|
|
<el-form-item label="属性描述" prop="description">
|
2024-12-17 15:03:57 +08:00
|
|
|
|
<el-input
|
|
|
|
|
v-model="property.description"
|
|
|
|
|
:maxlength="200"
|
|
|
|
|
:rows="3"
|
|
|
|
|
placeholder="请输入属性描述"
|
|
|
|
|
type="textarea"
|
|
|
|
|
/>
|
2024-12-15 23:15:51 +08:00
|
|
|
|
</el-form-item>
|
2024-12-11 13:14:47 +08:00
|
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
<script lang="ts" setup>
|
|
|
|
|
import { useVModel } from '@vueuse/core'
|
2024-12-23 18:06:42 +08:00
|
|
|
|
import { DataSpecsDataType, dataTypeOptions, validateBoolName } from './config'
|
2024-12-15 00:21:40 +08:00
|
|
|
|
import {
|
2024-12-23 17:29:14 +08:00
|
|
|
|
ThingModelArrayDataSpecs,
|
|
|
|
|
ThingModelEnumDataSpecs,
|
2024-12-23 18:06:42 +08:00
|
|
|
|
ThingModelNumberDataSpecs,
|
|
|
|
|
ThingModelStructDataSpecs
|
2024-12-15 00:21:40 +08:00
|
|
|
|
} from './dataSpecs'
|
2024-12-23 17:29:14 +08:00
|
|
|
|
import { ThingModelProperty } from '@/api/iot/thingmodel'
|
2024-12-11 13:14:47 +08:00
|
|
|
|
|
2024-12-17 16:20:09 +08:00
|
|
|
|
/** IoT 物模型数据 */
|
2024-12-23 10:13:14 +08:00
|
|
|
|
defineOptions({ name: 'ThingModelDataSpecs' })
|
2024-12-17 16:20:09 +08:00
|
|
|
|
|
2024-12-23 17:29:14 +08:00
|
|
|
|
const props = defineProps<{ modelValue: any; isStructDataSpecs?: boolean }>()
|
2024-12-11 13:14:47 +08:00
|
|
|
|
const emits = defineEmits(['update:modelValue'])
|
2024-12-23 10:13:14 +08:00
|
|
|
|
const property = useVModel(props, 'modelValue', emits) as Ref<ThingModelProperty>
|
2024-12-23 17:29:14 +08:00
|
|
|
|
const getDataTypeOptions = computed(() => {
|
|
|
|
|
return !props.isStructDataSpecs
|
|
|
|
|
? dataTypeOptions
|
|
|
|
|
: dataTypeOptions.filter(
|
|
|
|
|
(item) =>
|
|
|
|
|
!([DataSpecsDataType.STRUCT, DataSpecsDataType.ARRAY] as any[]).includes(item.value)
|
|
|
|
|
)
|
|
|
|
|
}) // 获得数据类型列表
|
2024-12-13 18:08:11 +08:00
|
|
|
|
/** 属性值的数据类型切换时初始化相关数据 */
|
|
|
|
|
const handleChange = (dataType: any) => {
|
2024-12-15 23:15:51 +08:00
|
|
|
|
property.value.dataSpecsList = []
|
|
|
|
|
property.value.dataSpecs = {}
|
2024-12-25 17:12:16 +08:00
|
|
|
|
// 不是列表型数据才设置 dataSpecs.dataType
|
|
|
|
|
![DataSpecsDataType.ENUM, DataSpecsDataType.BOOL, DataSpecsDataType.STRUCT].includes(dataType) &&
|
|
|
|
|
(property.value.dataSpecs.dataType = dataType)
|
2024-12-13 18:08:11 +08:00
|
|
|
|
switch (dataType) {
|
|
|
|
|
case DataSpecsDataType.ENUM:
|
2024-12-15 23:15:51 +08:00
|
|
|
|
property.value.dataSpecsList.push({
|
2024-12-14 23:09:14 +08:00
|
|
|
|
dataType: DataSpecsDataType.ENUM,
|
2024-12-13 18:08:11 +08:00
|
|
|
|
name: '', // 枚举项的名称
|
|
|
|
|
value: undefined // 枚举值
|
|
|
|
|
})
|
2024-12-14 23:09:14 +08:00
|
|
|
|
break
|
|
|
|
|
case DataSpecsDataType.BOOL:
|
|
|
|
|
for (let i = 0; i < 2; i++) {
|
2024-12-15 23:15:51 +08:00
|
|
|
|
property.value.dataSpecsList.push({
|
2024-12-14 23:09:14 +08:00
|
|
|
|
dataType: DataSpecsDataType.BOOL,
|
|
|
|
|
name: '', // 布尔值的名称
|
|
|
|
|
value: i // 布尔值
|
|
|
|
|
})
|
|
|
|
|
}
|
2024-12-14 23:27:27 +08:00
|
|
|
|
break
|
2024-12-13 18:08:11 +08:00
|
|
|
|
}
|
2024-12-13 17:36:20 +08:00
|
|
|
|
}
|
2024-12-11 13:14:47 +08:00
|
|
|
|
</script>
|
|
|
|
|
|
2024-12-17 15:03:57 +08:00
|
|
|
|
<style lang="scss" scoped>
|
|
|
|
|
:deep(.el-form-item) {
|
|
|
|
|
.el-form-item {
|
|
|
|
|
margin-bottom: 0;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
</style>
|