Files
admin-govern/src/components/tree/govern/cloudDeviceEntryTreeZL.vue

71 lines
1.9 KiB
Vue
Raw Normal View History

2026-01-04 14:55:31 +08:00
<template>
<Tree ref="treRef" :width="width" :height="height" :showPush="props.showPush" :data="tree" default-expand-all
@changePointType="changePointType" @onAdd="onAdd" />
2026-01-04 14:55:31 +08:00
</template>
<script lang="ts" setup>
import { ref } from 'vue'
2026-01-04 14:55:31 +08:00
import Tree from '../index.vue'
import { objTree } from '@/api/cs-device-boot/csLedger'
2026-01-04 14:55:31 +08:00
import { useConfig } from '@/stores/config'
2026-01-27 16:32:33 +08:00
import { querySysExcel } from '@/api/harmonic-boot/luckyexcel'
2026-01-04 14:55:31 +08:00
import { useDictData } from '@/stores/dictData'
import { createLineTreeDecorators } from './lineTreeUtils'
import { decorateObjTree } from './deviceTreeUtils'
import { bootstrapWithTemplate, selectTreeNode } from './treeCommonUtils'
2026-01-04 14:55:31 +08:00
interface Props {
template?: boolean
showPush?: boolean
height?: number
2026-01-04 14:55:31 +08:00
}
2026-01-04 14:55:31 +08:00
const props = withDefaults(defineProps<Props>(), {
template: false,
showPush: false,
height: 0
2026-01-04 14:55:31 +08:00
})
defineOptions({ name: 'govern/cloudDeviceEntryTreeZL' })
2026-01-04 14:55:31 +08:00
const emit = defineEmits(['init', 'checkChange', 'pointTypeChange', 'Policy', 'onAdd'])
2026-01-04 14:55:31 +08:00
const config = useConfig()
const dictData = useDictData()
const tree = ref<any[]>([])
const treRef = ref<InstanceType<typeof Tree>>()
2026-01-04 14:55:31 +08:00
const width = ref('')
const decorators = createLineTreeDecorators(() => config.getColorVal('elementUiPrimary'))
const changePointType = (val: any, obj: any) => emit('pointTypeChange', val, obj)
const onAdd = () => emit('onAdd')
async function loadTree() {
2026-01-04 14:55:31 +08:00
tree.value = []
const res = await objTree()
const leaves = decorateObjTree(res.data, decorators)
tree.value = res.data
2026-01-04 14:55:31 +08:00
const node = leaves[0]
if (!node) {
emit('init')
return
}
2026-01-04 14:55:31 +08:00
await selectTreeNode(treRef.value, node, {
onSelect: selected => emit('init', selected)
})
2026-01-04 14:55:31 +08:00
}
bootstrapWithTemplate(
props.template,
loadTree,
() => querySysExcel({ id: dictData.state.area[0]?.id }),
data => emit('Policy', data)
)
2026-01-04 14:55:31 +08:00
defineExpose({ info: loadTree })
2026-01-04 14:55:31 +08:00
</script>