mirror of
https://gitee.com/myxzgzs/boyue-ui-admin-vue3
synced 2025-08-09 17:02:43 +08:00
Merge remote-tracking branch 'origin/feature/iot' into feature/iot
This commit is contained in:
commit
b08aae63ed
@ -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 })
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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 插件状态
|
||||||
|
@ -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
|
||||||
}
|
}
|
||||||
|
@ -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"
|
||||||
|
@ -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() // 消息弹窗
|
||||||
|
Loading…
x
Reference in New Issue
Block a user