Ver código fonte

Merge remote-tracking branch 'origin/feature/iot' into feature/iot

安浩浩 7 meses atrás
pai
commit
b08aae63ed

+ 6 - 6
src/api/iot/thingmodel/index.ts

@@ -42,34 +42,34 @@ export interface ThingModelService {
 export const ThingModelApi = {
   // 查询产品物模型分页
   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) => {
     return await request.get({
-      url: `/iot/product-thing-model/list-by-product-id`,
+      url: `/iot/thing-model/list-by-product-id`,
       params
     })
   },
 
   // 查询产品物模型详情
   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) => {
-    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) => {
-    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) => {
-    return await request.delete({ url: `/iot/product-thing-model/delete?id=` + id })
+    return await request.delete({ url: `/iot/thing-model/delete?id=` + id })
   }
 }

+ 2 - 2
src/utils/dict.ts

@@ -236,9 +236,9 @@ export enum DICT_TYPE {
   IOT_DATA_FORMAT = 'iot_data_format', // IOT 数据格式
   IOT_PROTOCOL_TYPE = 'iot_protocol_type', // 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_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_PLUGIN_DEPLOY_TYPE = 'iot_plugin_deploy_type', // IOT 插件部署类型
   IOT_PLUGIN_STATUS = 'iot_plugin_status', // IOT 插件状态

+ 20 - 2
src/views/iot/thingmodel/ThingModelForm.vue

@@ -10,7 +10,7 @@
       <el-form-item label="功能类型" prop="type">
         <el-radio-group v-model="formData.type">
           <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"
             :value="dict.value"
           >
@@ -67,7 +67,7 @@ import { DICT_TYPE, getIntDictOptions } from '@/utils/dict'
 import { isEmpty } from '@/utils/is'
 
 /** IoT 物模型数据表单 */
-defineOptions({ name: 'IoTProductThingModelForm' })
+defineOptions({ name: 'IoTThingModelForm' })
 
 const product = inject<Ref<ProductVO>>(IOT_PROVIDE_KEY.PRODUCT) // 注入产品信息
 
@@ -103,6 +103,24 @@ const open = async (type: string, id?: number) => {
     formLoading.value = true
     try {
       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 {
       formLoading.value = false
     }

+ 1 - 1
src/views/iot/thingmodel/dataSpecs/ThingModelNumberDataSpecs.vue

@@ -47,7 +47,7 @@
       @change="unitChange"
     >
       <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"
         :label="item.label + '-' + item.value"
         :value="item.label + '-' + item.value"

+ 6 - 7
src/views/iot/thingmodel/index.vue

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