!630 【代码优化】IOT: ThingModel

Merge pull request !630 from puhui999/feature/iot
This commit is contained in:
芋道源码 2024-12-28 13:01:46 +00:00 committed by Gitee
commit afaea19726
No known key found for this signature in database
GPG Key ID: 173E9B9CA92EEF8F
5 changed files with 35 additions and 18 deletions

View File

@ -42,34 +42,34 @@ export interface ThingModelService {
export const ThingModelApi = { export const ThingModelApi = {
// 查询产品物模型分页 // 查询产品物模型分页
getThingModelPage: async (params: any) => { getThingModelPage: async (params: any) => {
return await request.get({ url: `/iot/product-thing-model/page`, params }) return await request.get({ url: `/iot/thing-model/page`, params })
}, },
// 获得产品物模型 // 获得产品物模型
getThingModelListByProductId: async (params: any) => { getThingModelListByProductId: async (params: any) => {
return await request.get({ return await request.get({
url: `/iot/product-thing-model/list-by-product-id`, url: `/iot/thing-model/list-by-product-id`,
params params
}) })
}, },
// 查询产品物模型详情 // 查询产品物模型详情
getThingModel: async (id: number) => { getThingModel: async (id: number) => {
return await request.get({ url: `/iot/product-thing-model/get?id=` + id }) return await request.get({ url: `/iot/thing-model/get?id=` + id })
}, },
// 新增产品物模型 // 新增产品物模型
createThingModel: async (data: ThingModelData) => { createThingModel: async (data: ThingModelData) => {
return await request.post({ url: `/iot/product-thing-model/create`, data }) return await request.post({ url: `/iot/thing-model/create`, data })
}, },
// 修改产品物模型 // 修改产品物模型
updateThingModel: async (data: ThingModelData) => { updateThingModel: async (data: ThingModelData) => {
return await request.put({ url: `/iot/product-thing-model/update`, data }) return await request.put({ url: `/iot/thing-model/update`, data })
}, },
// 删除产品物模型 // 删除产品物模型
deleteThingModel: async (id: number) => { deleteThingModel: async (id: number) => {
return await request.delete({ url: `/iot/product-thing-model/delete?id=` + id }) return await request.delete({ url: `/iot/thing-model/delete?id=` + id })
} }
} }

View File

@ -236,9 +236,9 @@ export enum DICT_TYPE {
IOT_DATA_FORMAT = 'iot_data_format', // IOT 数据格式 IOT_DATA_FORMAT = 'iot_data_format', // IOT 数据格式
IOT_PROTOCOL_TYPE = 'iot_protocol_type', // IOT 接入网关协议 IOT_PROTOCOL_TYPE = 'iot_protocol_type', // IOT 接入网关协议
IOT_DEVICE_STATUS = 'iot_device_status', // IOT 设备状态 IOT_DEVICE_STATUS = 'iot_device_status', // IOT 设备状态
IOT_PRODUCT_THING_MODEL_TYPE = 'iot_product_thing_model_type', // IOT 产品功能类型 IOT_THING_MODEL_TYPE = 'iot_thing_model_type', // IOT 产品功能类型
IOT_DATA_TYPE = 'iot_data_type', // IOT 数据类型 IOT_DATA_TYPE = 'iot_data_type', // IOT 数据类型
IOT_PRODUCT_THING_MODEL_UNIT = 'iot_product_thing_model_unit', // IOT 物模型单位 IOT_THING_MODEL_UNIT = 'iot_thing_model_unit', // IOT 物模型单位
IOT_RW_TYPE = 'iot_rw_type', // IOT 读写类型 IOT_RW_TYPE = 'iot_rw_type', // IOT 读写类型
IOT_PLUGIN_DEPLOY_TYPE = 'iot_plugin_deploy_type', // IOT 插件部署类型 IOT_PLUGIN_DEPLOY_TYPE = 'iot_plugin_deploy_type', // IOT 插件部署类型
IOT_PLUGIN_STATUS = 'iot_plugin_status', // IOT 插件状态 IOT_PLUGIN_STATUS = 'iot_plugin_status', // IOT 插件状态

View File

@ -10,7 +10,7 @@
<el-form-item label="功能类型" prop="type"> <el-form-item label="功能类型" prop="type">
<el-radio-group v-model="formData.type"> <el-radio-group v-model="formData.type">
<el-radio-button <el-radio-button
v-for="dict in getIntDictOptions(DICT_TYPE.IOT_PRODUCT_THING_MODEL_TYPE)" v-for="dict in getIntDictOptions(DICT_TYPE.IOT_THING_MODEL_TYPE)"
:key="dict.value" :key="dict.value"
:value="dict.value" :value="dict.value"
> >
@ -67,7 +67,7 @@ import { DICT_TYPE, getIntDictOptions } from '@/utils/dict'
import { isEmpty } from '@/utils/is' import { isEmpty } from '@/utils/is'
/** IoT 物模型数据表单 */ /** IoT 物模型数据表单 */
defineOptions({ name: 'IoTProductThingModelForm' }) defineOptions({ name: 'IoTThingModelForm' })
const product = inject<Ref<ProductVO>>(IOT_PROVIDE_KEY.PRODUCT) // const product = inject<Ref<ProductVO>>(IOT_PROVIDE_KEY.PRODUCT) //
@ -103,6 +103,24 @@ const open = async (type: string, id?: number) => {
formLoading.value = true formLoading.value = true
try { try {
formData.value = await ThingModelApi.getThingModel(id) formData.value = await ThingModelApi.getThingModel(id)
//
if (isEmpty(formData.value.property)) {
formData.value.dataType = DataSpecsDataType.INT
formData.value.property = {
dataType: DataSpecsDataType.INT,
dataSpecs: {
dataType: DataSpecsDataType.INT
}
}
}
//
if (isEmpty(formData.value.service)) {
formData.value.service = {}
}
//
if (isEmpty(formData.value.event)) {
formData.value.event = {}
}
} finally { } finally {
formLoading.value = false formLoading.value = false
} }

View File

@ -47,7 +47,7 @@
@change="unitChange" @change="unitChange"
> >
<el-option <el-option
v-for="(item, index) in getStrDictOptions(DICT_TYPE.IOT_PRODUCT_THING_MODEL_UNIT)" v-for="(item, index) in getStrDictOptions(DICT_TYPE.IOT_THING_MODEL_UNIT)"
:key="index" :key="index"
:label="item.label + '-' + item.value" :label="item.label + '-' + item.value"
:value="item.label + '-' + item.value" :value="item.label + '-' + item.value"

View File

@ -16,7 +16,7 @@
placeholder="请选择功能类型" placeholder="请选择功能类型"
> >
<el-option <el-option
v-for="dict in getIntDictOptions(DICT_TYPE.IOT_PRODUCT_THING_MODEL_TYPE)" v-for="dict in getIntDictOptions(DICT_TYPE.IOT_THING_MODEL_TYPE)"
:key="dict.value" :key="dict.value"
:label="dict.label" :label="dict.label"
:value="dict.value" :value="dict.value"
@ -33,7 +33,7 @@
重置 重置
</el-button> </el-button>
<el-button <el-button
v-hasPermi="[`iot:product-thing-model:create`]" v-hasPermi="[`iot:thing-model:create`]"
plain plain
type="primary" type="primary"
@click="openForm('create')" @click="openForm('create')"
@ -49,7 +49,7 @@
<el-table v-loading="loading" :data="list" :show-overflow-tooltip="true" :stripe="true"> <el-table v-loading="loading" :data="list" :show-overflow-tooltip="true" :stripe="true">
<el-table-column align="center" label="功能类型" prop="type"> <el-table-column align="center" label="功能类型" prop="type">
<template #default="scope"> <template #default="scope">
<dict-tag :type="DICT_TYPE.IOT_PRODUCT_THING_MODEL_TYPE" :value="scope.row.type" /> <dict-tag :type="DICT_TYPE.IOT_THING_MODEL_TYPE" :value="scope.row.type" />
</template> </template>
</el-table-column> </el-table-column>
<el-table-column align="center" label="功能名称" prop="name" /> <el-table-column align="center" label="功能名称" prop="name" />
@ -118,7 +118,7 @@
<el-table-column align="center" label="操作"> <el-table-column align="center" label="操作">
<template #default="scope"> <template #default="scope">
<el-button <el-button
v-hasPermi="[`iot:product-thing-model:update`]" v-hasPermi="[`iot:thing-model:update`]"
link link
type="primary" type="primary"
@click="openForm('update', scope.row.id)" @click="openForm('update', scope.row.id)"
@ -126,7 +126,7 @@
编辑 编辑
</el-button> </el-button>
<el-button <el-button
v-hasPermi="['iot:product-thing-model:delete']" v-hasPermi="['iot:thing-model:delete']"
link link
type="danger" type="danger"
@click="handleDelete(scope.row.id)" @click="handleDelete(scope.row.id)"
@ -161,9 +161,8 @@ import {
getEventTypeByValue, getEventTypeByValue,
ThingModelType ThingModelType
} from './config' } from './config'
import { ThingModelNumberDataSpecs } from '@/views/iot/thingmodel/dataSpecs'
defineOptions({ name: 'IoTProductThingModel' }) defineOptions({ name: 'IoTThingModel' })
const { t } = useI18n() // const { t } = useI18n() //
const message = useMessage() // const message = useMessage() //