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

65 lines
1.8 KiB
Vue

<template>
<Tree
ref="treRef"
:width="width"
:data="tree"
default-expand-all
@checkedNodesChange="handleCheckedNodesChange"
/>
</template>
<script lang="ts" setup>
import { ref } from 'vue'
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'
interface Props {
template?: boolean
}
const props = withDefaults(defineProps<Props>(), { template: false })
defineOptions({ name: 'govern/selectTree' })
const emit = defineEmits(['init', 'checkChange', 'pointTypeChange', 'Policy'])
const config = useConfig()
const dictData = useDictData()
const tree = ref<any[]>([])
const treRef = ref<InstanceType<typeof Tree>>()
const width = ref('')
const decorators = createLineTreeDecorators(() => config.getColorVal('elementUiPrimary'))
const handleCheckedNodesChange = (nodes: any[]) => emit('checkChange', nodes)
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 === '监测设备')
const node = leaves.monitor[0]
if (!node) {
emit('init')
return
}
await selectTreeNode(treRef.value, node, {
onSelect: selected => emit('init', { level: 2, ...selected })
})
}
bootstrapWithTemplate(
props.template,
loadTree,
() => getTemplateByDept({ id: dictData.state.area[0]?.id }),
data => emit('Policy', data)
)
</script>