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

65 lines
1.8 KiB
Vue
Raw Normal View History

2025-10-21 16:27:49 +08:00
<template>
<Tree
ref="treRef"
:width="width"
:data="tree"
default-expand-all
@checkedNodesChange="handleCheckedNodesChange"
/>
2025-10-21 16:27:49 +08:00
</template>
<script lang="ts" setup>
import { ref } from 'vue'
2025-10-21 16:27:49 +08:00
import Tree from '../select.vue'
import { getLineTree } from '@/api/cs-device-boot/csLedger'
import { useConfig } from '@/stores/config'
import { getTemplateByDept } from '@/api/harmonic-boot/luckyexcel'
import { useDictData } from '@/stores/dictData'
import { createLineTreeDecorators, decorateLineTree } from './lineTreeUtils'
import { bootstrapWithTemplate, selectTreeNode } from './treeCommonUtils'
2025-10-21 16:27:49 +08:00
interface Props {
template?: boolean
}
const props = withDefaults(defineProps<Props>(), { template: false })
defineOptions({ name: 'govern/selectTree' })
2025-10-21 16:27:49 +08:00
const emit = defineEmits(['init', 'checkChange', 'pointTypeChange', 'Policy'])
2025-10-21 16:27:49 +08:00
const config = useConfig()
const dictData = useDictData()
const tree = ref<any[]>([])
const treRef = ref<InstanceType<typeof Tree>>()
2025-10-21 16:27:49 +08:00
const width = ref('')
const decorators = createLineTreeDecorators(() => config.getColorVal('elementUiPrimary'))
2025-10-21 16:27:49 +08:00
const handleCheckedNodesChange = (nodes: any[]) => emit('checkChange', nodes)
2025-10-21 16:27:49 +08:00
async function loadTree() {
tree.value = []
const res = await getLineTree()
const leaves = decorateLineTree(res.data, '1', decorators, { disableParents: false })
tree.value = res.data.filter((item: any) => item.name === '监测设备')
2025-10-21 16:27:49 +08:00
const node = leaves.monitor[0]
if (!node) {
emit('init')
return
}
2025-10-21 16:27:49 +08:00
await selectTreeNode(treRef.value, node, {
onSelect: selected => emit('init', { level: 2, ...selected })
})
}
2025-10-21 16:27:49 +08:00
bootstrapWithTemplate(
props.template,
loadTree,
() => getTemplateByDept({ id: dictData.state.area[0]?.id }),
data => emit('Policy', data)
)
2025-10-21 16:27:49 +08:00
</script>