2024-01-09 13:49:21 +08:00
|
|
|
<template>
|
2024-01-15 20:29:12 +08:00
|
|
|
<Tree
|
|
|
|
|
ref="treRef"
|
|
|
|
|
@check-change="handleCheckChange"
|
|
|
|
|
:default-checked-keys="defaultCheckedKeys"
|
|
|
|
|
:show-checkbox="props.showCheckbox"
|
|
|
|
|
:data="tree"
|
2026-01-04 14:55:31 +08:00
|
|
|
:height="props.height"
|
2024-09-25 16:31:45 +08:00
|
|
|
@changeDeviceType="changeDeviceType"
|
2026-06-04 09:08:37 +08:00
|
|
|
@changeTreeType="loadTree"
|
2026-04-02 09:08:57 +08:00
|
|
|
:engineering="props.engineering"
|
2026-06-04 09:08:37 +08:00
|
|
|
leaf-mode="device"
|
2024-01-15 20:29:12 +08:00
|
|
|
/>
|
2024-01-09 13:49:21 +08:00
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
<script lang="ts" setup>
|
2026-06-04 09:08:37 +08:00
|
|
|
import { ref, onMounted } from 'vue'
|
|
|
|
|
import { throttle } from 'lodash'
|
2024-06-27 09:39:53 +08:00
|
|
|
import Tree from '../device.vue'
|
2024-01-09 13:49:21 +08:00
|
|
|
import { getDeviceTree } from '@/api/cs-device-boot/csLedger'
|
|
|
|
|
import { useConfig } from '@/stores/config'
|
2026-06-04 09:08:37 +08:00
|
|
|
import { waitForTreeRef, type TreeRefKey } from './lineTreeUtils'
|
|
|
|
|
import { createLineTreeDecorators } from './lineTreeUtils'
|
|
|
|
|
import { decorateDeviceTree } from './deviceTreeUtils'
|
|
|
|
|
import type { LineTreeLeaves } from './lineTreeUtils'
|
|
|
|
|
|
|
|
|
|
defineOptions({ name: 'govern/deviceTree' })
|
2026-04-02 09:08:57 +08:00
|
|
|
|
2024-01-15 20:29:12 +08:00
|
|
|
const props = withDefaults(
|
|
|
|
|
defineProps<{
|
|
|
|
|
showCheckbox?: boolean
|
2026-06-04 09:08:37 +08:00
|
|
|
defaultCheckedKeys?: any[]
|
2026-01-04 14:55:31 +08:00
|
|
|
height?: number
|
2026-04-02 09:08:57 +08:00
|
|
|
engineering?: boolean
|
2024-01-15 20:29:12 +08:00
|
|
|
}>(),
|
|
|
|
|
{
|
|
|
|
|
showCheckbox: false,
|
2026-06-04 09:08:37 +08:00
|
|
|
defaultCheckedKeys: () => [],
|
2026-04-02 09:08:57 +08:00
|
|
|
height: 0,
|
|
|
|
|
engineering: false
|
2024-01-15 20:29:12 +08:00
|
|
|
}
|
|
|
|
|
)
|
2026-06-04 09:08:37 +08:00
|
|
|
|
2024-10-23 16:29:13 +08:00
|
|
|
const emit = defineEmits(['init', 'checkChange', 'deviceTypeChange'])
|
2026-06-04 09:08:37 +08:00
|
|
|
|
2024-01-09 13:49:21 +08:00
|
|
|
const config = useConfig()
|
2026-06-04 09:08:37 +08:00
|
|
|
const tree = ref<any[]>([])
|
|
|
|
|
const treRef = ref<InstanceType<typeof Tree>>()
|
|
|
|
|
const decorators = createLineTreeDecorators(() => config.getColorVal('elementUiPrimary'))
|
2026-03-06 09:36:42 +08:00
|
|
|
|
2026-06-04 09:08:37 +08:00
|
|
|
const changeDeviceType = (val: any, obj: any) => emit('deviceTypeChange', val, obj)
|
2025-12-20 23:44:46 +08:00
|
|
|
|
2026-06-04 09:08:37 +08:00
|
|
|
async function selectInitialNode(type: string | undefined, leaves: LineTreeLeaves) {
|
|
|
|
|
const candidates: { refKey: TreeRefKey; list: any[]; level: number }[] =
|
|
|
|
|
type === '2'
|
|
|
|
|
? [{ refKey: 'treeRef4', list: leaves.engineering, level: 2 }]
|
|
|
|
|
: [
|
|
|
|
|
{ refKey: 'treeRef1', list: leaves.govern, level: 2 },
|
|
|
|
|
{ refKey: 'treeRef2', list: leaves.portable, level: 2 },
|
|
|
|
|
{ refKey: 'treeRef3', list: leaves.monitor, level: 2 }
|
|
|
|
|
]
|
2026-01-04 14:55:31 +08:00
|
|
|
|
2026-06-04 09:08:37 +08:00
|
|
|
for (const { refKey, list, level } of candidates) {
|
|
|
|
|
const node = list[0]
|
|
|
|
|
if (!node) continue
|
|
|
|
|
const treeInstance = await waitForTreeRef(treRef.value, refKey)
|
|
|
|
|
treeInstance?.setCurrentKey(node.id)
|
|
|
|
|
emit('init', { level, ...node })
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
emit('init')
|
|
|
|
|
}
|
2026-03-06 09:36:42 +08:00
|
|
|
|
2026-06-04 09:08:37 +08:00
|
|
|
const loadTree = (type?: string) => {
|
|
|
|
|
getDeviceTree({ type: type === '2' ? 'engineering' : '' }).then(res => {
|
|
|
|
|
const leaves = decorateDeviceTree(res.data, type, decorators)
|
|
|
|
|
tree.value = res.data
|
|
|
|
|
selectInitialNode(type, leaves)
|
2024-01-11 08:54:09 +08:00
|
|
|
})
|
2026-03-06 09:36:42 +08:00
|
|
|
}
|
|
|
|
|
|
2026-06-04 09:08:37 +08:00
|
|
|
onMounted(() => loadTree(props.engineering ? '2' : '1'))
|
2026-01-07 13:14:26 +08:00
|
|
|
|
2026-06-04 09:08:37 +08:00
|
|
|
const handleCheckChange = throttle(
|
2026-01-07 13:14:26 +08:00
|
|
|
(data: any, checked: any, indeterminate: any) => {
|
2026-06-04 09:08:37 +08:00
|
|
|
emit('checkChange', { data, checked, indeterminate })
|
2026-01-07 13:14:26 +08:00
|
|
|
},
|
|
|
|
|
300,
|
2026-06-04 09:08:37 +08:00
|
|
|
{ leading: true, trailing: false }
|
2026-01-07 13:14:26 +08:00
|
|
|
)
|
|
|
|
|
|
2026-06-04 09:08:37 +08:00
|
|
|
defineExpose({ treRef })
|
2024-01-09 13:49:21 +08:00
|
|
|
</script>
|