【优化功能】 IOT 产品管理,Topic 类列表展示问题

pull/542/head
安浩浩 2024-09-24 23:18:42 +08:00
parent 6aaf611291
commit 0e3ebbd2b8
2 changed files with 215 additions and 201 deletions

View File

@ -2,10 +2,24 @@
<ContentWrap> <ContentWrap>
<el-tabs> <el-tabs>
<el-tab-pane label="基础通信 Topic"> <el-tab-pane label="基础通信 Topic">
<Table :columns="columns1" :data="data1" :span-method="objectSpanMethod" /> <Table
:columns="columns1"
:data="data1"
:span-method="createSpanMethod(data1)"
align="left"
headerAlign="left"
border="true"
/>
</el-tab-pane> </el-tab-pane>
<el-tab-pane label="物模型通信 Topic"> <el-tab-pane label="物模型通信 Topic">
<Table :columns="columns2" :data="data2" :span-method="objectSpanMethod" /> <Table
:columns="columns2"
:data="data2"
:span-method="createSpanMethod(data2)"
align="left"
headerAlign="left"
border="true"
/>
</el-tab-pane> </el-tab-pane>
</el-tabs> </el-tabs>
</ContentWrap> </ContentWrap>
@ -13,209 +27,207 @@
<script setup lang="ts"> <script setup lang="ts">
import { ProductVO } from '@/api/iot/product' import { ProductVO } from '@/api/iot/product'
const { product } = defineProps<{ product: ProductVO }>() const props = defineProps<{ product: ProductVO }>()
// //
const columns1 = reactive([ const columns1 = reactive([
{ { label: '功能', field: 'function', width: 150 },
label: '功能', { label: 'Topic 类', field: 'topicClass', width: 800 },
field: 'function', { label: '操作权限', field: 'operationPermission', width: 100 },
width: 150 { label: '描述', field: 'description' }
},
{
label: 'Topic 类',
field: 'topicClass',
width: 500
},
{
label: '操作权限',
field: 'operationPermission',
width: 100
},
{
label: '描述',
field: 'description'
}
]) ])
const columns2 = reactive([ const columns2 = reactive([
{ { label: '功能', field: 'function', width: 150 },
label: '功能', { label: 'Topic 类', field: 'topicClass', width: 800 },
field: 'function', { label: '操作权限', field: 'operationPermission', width: 100 },
width: 150 { label: '描述', field: 'description' }
},
{
label: 'Topic 类',
field: 'topicClass',
width: 500
},
{
label: '操作权限',
field: 'operationPermission',
width: 150
},
{
label: '描述',
field: 'description'
}
]) ])
// const data1 = computed(() => {
const data1 = reactive([ if (!props.product || !props.product.productKey) return []
return [
{ {
function: 'OTA 升级', function: 'OTA 升级',
topicClass: '/ota/device/inform/' + product.productKey + '/${deviceName}', topicClass: `/ota/device/inform/${props.product.productKey}/\${deviceName}`,
operationPermission: '发布', operationPermission: '发布',
description: '设备上报固件升级信息' description: '设备上报固件升级信息'
}, },
{ {
function: 'OTA 升级', function: 'OTA 升级',
topicClass: '/ota/device/upgrade/' + product.productKey + '/${deviceName}', topicClass: `/ota/device/upgrade/${props.product.productKey}/\${deviceName}`,
operationPermission: '订阅', operationPermission: '订阅',
description: '固件升级信息下行' description: '固件升级信息下行'
}, },
{ {
function: 'OTA 升级', function: 'OTA 升级',
topicClass: '/sys/' + product.productKey + '/${deviceName}/thing/ota/firmware/get', topicClass: `/sys/${props.product.productKey}/\${deviceName}/thing/ota/firmware/get`,
operationPermission: '发布', operationPermission: '发布',
description: '设备上报固件升级进度' description: '设备上报固件升级进度'
}, },
{ {
function: 'OTA 升级', function: 'OTA 升级',
topicClass: '/sys/' + product.productKey + '/${deviceName}/thing/ota/firmware/get', topicClass: `/sys/${props.product.productKey}/\${deviceName}/thing/ota/firmware/get`,
operationPermission: '发布', operationPermission: '发布',
description: '设备主动拉取固件升级信息' description: '设备主动拉取固件升级信息'
}, },
{ {
function: '设备标签', function: '设备标签',
topicClass: '/sys/' + product.productKey + '/${deviceName}/thing/deviceinfo/update', topicClass: `/sys/${props.product.productKey}/\${deviceName}/thing/deviceinfo/update`,
operationPermission: '发布', operationPermission: '发布',
description: '设备上报标签数据' description: '设备上报标签数据'
}, },
{ {
function: '设备标签', function: '设备标签',
topicClass: '/sys/' + product.productKey + '/${deviceName}/thing/deviceinfo/update_reply', topicClass: `/sys/${props.product.productKey}/\${deviceName}/thing/deviceinfo/update_reply`,
operationPermission: '订阅', operationPermission: '订阅',
description: '云端响应标签上报' description: '云端响应标签上报'
}, },
{ {
function: '设备标签', function: '设备标签',
topicClass: '/sys/' + product.productKey + '/${deviceName}/thing/deviceinfo/delete', topicClass: `/sys/${props.product.productKey}/\${deviceName}/thing/deviceinfo/delete`,
operationPermission: '订阅', operationPermission: '订阅',
description: '设备删除标签信息' description: '设备删除标签信息'
}, },
{ {
function: '设备标签', function: '设备标签',
topicClass: '/sys/' + product.productKey + '/${deviceName}/thing/deviceinfo/delete_reply', topicClass: `/sys/${props.product.productKey}/\${deviceName}/thing/deviceinfo/delete_reply`,
operationPermission: '订阅', operationPermission: '订阅',
description: '云端响应标签删除' description: '云端响应标签删除'
}, },
{ {
function: '时钟同步', function: '时钟同步',
topicClass: '/ext/ntp/' + product.productKey + '/${deviceName}/request', topicClass: `/ext/ntp/${props.product.productKey}/\${deviceName}/request`,
operationPermission: '发布', operationPermission: '发布',
description: 'NTP 时钟同步请求' description: 'NTP 时钟同步请求'
}, },
{ {
function: '时钟同步', function: '时钟同步',
topicClass: '/ext/ntp/' + product.productKey + '/${deviceName}/response', topicClass: `/ext/ntp/${props.product.productKey}/\${deviceName}/response`,
operationPermission: '订阅', operationPermission: '订阅',
description: 'NTP 时钟同步响应' description: 'NTP 时钟同步响应'
}, },
{ {
function: '设备影子', function: '设备影子',
topicClass: '/shadow/update/' + product.productKey + '/${deviceName}', topicClass: `/shadow/update/${props.product.productKey}/\${deviceName}`,
operationPermission: '发布', operationPermission: '发布',
description: '设备影子发布' description: '设备影子发布'
}, },
{ {
function: '设备影子', function: '设备影子',
topicClass: '/shadow/get/' + product.productKey + '/${deviceName}', topicClass: `/shadow/get/${props.product.productKey}/\${deviceName}`,
operationPermission: '订阅', operationPermission: '订阅',
description: '设备接收影子变更' description: '设备接收影子变更'
}, },
{ {
function: '配置更新', function: '配置更新',
topicClass: '/sys/' + product.productKey + '/${deviceName}/thing/config/push', topicClass: `/sys/${props.product.productKey}/\${deviceName}/thing/config/push`,
operationPermission: '订阅', operationPermission: '订阅',
description: '云端主动下推配置信息' description: '云端主动下推配置信息'
}, },
{ {
function: '配置更新', function: '配置更新',
topicClass: '/sys/' + product.productKey + '/${deviceName}/thing/config/get', topicClass: `/sys/${props.product.productKey}/\${deviceName}/thing/config/get`,
operationPermission: '发布', operationPermission: '发布',
description: '设备端查询配置信息' description: '设备端查询配置信息'
}, },
{ {
function: '配置更新', function: '配置更新',
topicClass: '/sys/' + product.productKey + '/${deviceName}/thing/config/get_reply', topicClass: `/sys/${props.product.productKey}/\${deviceName}/thing/config/get_reply`,
operationPermission: '订阅', operationPermission: '订阅',
description: '云端响应配置信息' description: '云端响应配置信息'
}, },
{ {
function: '广播', function: '广播',
topicClass: '/broadcast/' + product.productKey + '/${identifier}', topicClass: `/broadcast/${props.product.productKey}/\${identifier}`,
operationPermission: '订阅', operationPermission: '订阅',
description: '广播 Topicidentifier 为用户自定义字符串' description: '广播 Topicidentifier 为用户自定义字符串'
} }
]) ]
})
const data2 = reactive([ const data2 = computed(() => {
if (!props.product || !props.product.productKey) return []
return [
{ {
function: '属性上报', function: '属性上报',
topicClass: '/sys/' + product.productKey + '/${deviceName}/thing/event/property/post', topicClass: `/sys/${props.product.productKey}/\${deviceName}/thing/event/property/post`,
operationPermission: '发布', operationPermission: '发布',
description: '设备属性上报' description: '设备属性上报'
}, },
{ {
function: '属性上报', function: '属性上报',
topicClass: '/sys/' + product.productKey + '/${deviceName}/thing/event/property/post_reply', topicClass: `/sys/${props.product.productKey}/\${deviceName}/thing/event/property/post_reply`,
operationPermission: '订阅', operationPermission: '订阅',
description: '云端响应属性上报' description: '云端响应属性上报'
}, },
{ {
function: '属性设置', function: '属性设置',
topicClass: '/sys/' + product.productKey + '/${deviceName}/thing/service/property/set', topicClass: `/sys/${props.product.productKey}/\${deviceName}/thing/service/property/set`,
operationPermission: '订阅', operationPermission: '订阅',
description: '设备属性设置' description: '设备属性设置'
}, },
{ {
function: '事件上报', function: '事件上报',
topicClass: topicClass: `/sys/${props.product.productKey}/\${deviceName}/thing/event/\${tsl.event.identifier}/post`,
'/sys/' + product.productKey + '/${deviceName}/thing/event/${tsl.event.identifier}/post',
operationPermission: '发布', operationPermission: '发布',
description: '设备事件上报' description: '设备事件上报'
}, },
{ {
function: '事件上报', function: '事件上报',
topicClass: topicClass: `/sys/${props.product.productKey}/\${deviceName}/thing/event/\${tsl.event.identifier}/post_reply`,
'/sys/' +
product.productKey +
'/${deviceName}/thing/event/${tsl.event.identifier}/post_reply',
operationPermission: '订阅', operationPermission: '订阅',
description: '云端响应事件上报' description: '云端响应事件上报'
}, },
{ {
function: '服务调用', function: '服务调用',
topicClass: topicClass: `/sys/${props.product.productKey}/\${deviceName}/thing/service/\${tsl.service.identifier}`,
'/sys/' + product.productKey + '/${deviceName}/thing/service/${tsl.service.identifier}',
operationPermission: '订阅', operationPermission: '订阅',
description: '设备服务调用' description: '设备服务调用'
}, },
{ {
function: '服务调用', function: '服务调用',
topicClass: topicClass: `/sys/${props.product.productKey}/\${deviceName}/thing/service/\${tsl.service.identifier}_reply`,
'/sys/' + product.productKey + '/${deviceName}/thing/service/${tsl.service.identifier}_reply',
operationPermission: '发布', operationPermission: '发布',
description: '设备端响应服务调用' description: '设备端响应服务调用'
} }
]) ]
})
// //
const objectSpanMethod = ({ row, column, rowIndex, columnIndex }: SpanMethodProps) => { const createSpanMethod = (data: any[]) => {
if (columnIndex === 0 || columnIndex === 2) { //
if (rowIndex % 2 === 0) { const rowspanMap: Record<number, number> = {}
let currentFunction = ''
let startIndex = 0
let count = 0
data.forEach((item, index) => {
if (item.function !== currentFunction) {
if (count > 0) {
rowspanMap[startIndex] = count
}
currentFunction = item.function
startIndex = index
count = 1
} else {
count++
}
})
//
if (count > 0) {
rowspanMap[startIndex] = count
}
// span
return ({ row, column, rowIndex, columnIndex }: SpanMethodProps) => {
if (columnIndex === 0) {
//
const rowspan = rowspanMap[rowIndex] || 0
if (rowspan > 0) {
return { return {
rowspan: 2, rowspan,
colspan: 1 colspan: 1
} }
} else { } else {
@ -226,4 +238,5 @@ const objectSpanMethod = ({ row, column, rowIndex, columnIndex }: SpanMethodProp
} }
} }
} }
}
</script> </script>

View File

@ -18,9 +18,10 @@
</template> </template>
<script lang="ts" setup> <script lang="ts" setup>
import { ProductApi, ProductVO } from '@/api/iot/product' import { ProductApi, ProductVO } from '@/api/iot/product'
import { DeviceApi } from '@/api/iot/device'
import ProductDetailsHeader from '@/views/iot/product/detail/ProductDetailsHeader.vue' import ProductDetailsHeader from '@/views/iot/product/detail/ProductDetailsHeader.vue'
import ProductDetailsInfo from '@/views/iot/product/detail/ProductDetailsInfo.vue' import ProductDetailsInfo from '@/views/iot/product/detail/ProductDetailsInfo.vue'
import { DeviceApi } from '@/api/iot/device' import ProductTopic from '@/views/iot/product/detail/ProductTopic.vue'
defineOptions({ name: 'IoTProductDetail' }) defineOptions({ name: 'IoTProductDetail' })