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

154 lines
5.8 KiB
Vue
Raw Normal View History

2024-01-09 13:49:21 +08:00
<template>
2024-10-17 15:42:07 +08:00
<Tree ref="treRef" :width="width" :data="tree" default-expand-all @changePointType="changePointType" />
2024-01-09 13:49:21 +08:00
</template>
<script lang="ts" setup>
2024-10-17 15:42:07 +08:00
import { ref, nextTick, onMounted, defineProps } from 'vue'
2024-06-27 09:39:53 +08:00
import Tree from '../point.vue'
2024-01-11 08:54:09 +08:00
import { getLineTree } from '@/api/cs-device-boot/csLedger'
2024-01-09 13:49:21 +08:00
import { useConfig } from '@/stores/config'
2024-10-17 15:42:07 +08:00
import { getTemplateByDept } from '@/api/harmonic-boot/luckyexcel'
import { useDictData } from '@/stores/dictData'
// const props = defineProps(['template'])
interface Props {
template?: boolean
}
const props = withDefaults(defineProps<Props>(), {
template: false
2024-10-17 15:42:07 +08:00
})
2024-01-09 13:49:21 +08:00
defineOptions({
name: 'govern/deviceTree'
})
2024-10-17 15:42:07 +08:00
const emit = defineEmits(['init', 'checkChange', 'pointTypeChange', 'Policy'])
2024-01-09 13:49:21 +08:00
const config = useConfig()
const tree = ref()
2024-10-17 15:42:07 +08:00
const dictData = useDictData()
2024-01-11 08:54:09 +08:00
const treRef = ref()
const width = ref('')
2024-10-17 15:42:07 +08:00
const info = () => {
tree.value = []
let arr1: any[] = []
let arr2: any[] = []
2025-10-11 10:35:25 +08:00
let arr3: any[] = []
2024-10-17 15:42:07 +08:00
getLineTree().then(res => {
//治理设备
res.data.map((item: any) => {
if (item.name == '治理设备') {
item.children.forEach((item: any) => {
item.icon = 'el-icon-HomeFilled'
item.level = 1
2024-10-17 15:42:07 +08:00
item.color = config.getColorVal('elementUiPrimary')
item.children.forEach((item2: any) => {
item2.icon = 'el-icon-List'
item2.level = 1
2024-10-17 15:42:07 +08:00
item2.color = config.getColorVal('elementUiPrimary')
item2.children.forEach((item3: any) => {
item3.icon = 'el-icon-Platform'
2025-10-31 10:23:22 +08:00
item3.level = 2
2024-10-17 15:42:07 +08:00
item3.color =
item3.comFlag === 2 ? config.getColorVal('elementUiPrimary') : '#e26257 !important'
item3.children.forEach((item4: any) => {
item4.icon = 'el-icon-Platform'
item4.color =
item4.comFlag === 2 ? config.getColorVal('elementUiPrimary') : '#e26257 !important'
// item4.color = '#e26257 !important'
arr1.push(item4)
})
2024-06-27 09:39:53 +08:00
})
})
2024-01-11 08:54:09 +08:00
})
2024-10-17 15:42:07 +08:00
} else if (item.name == '便携式设备') {
item.children.forEach((item: any) => {
item.icon = 'el-icon-Platform'
item.color = config.getColorVal('elementUiPrimary')
item.color = item.comFlag === 2 ? config.getColorVal('elementUiPrimary') : '#e26257 !important'
item.children.forEach((item2: any) => {
item2.icon = 'el-icon-Platform'
item2.color =
item2.comFlag === 2 ? config.getColorVal('elementUiPrimary') : '#e26257 !important'
2024-10-17 15:42:07 +08:00
arr2.push(item2)
})
})
2025-10-14 09:51:42 +08:00
} else if (item.name == '在线设备') {
2025-10-11 10:35:25 +08:00
item.children.forEach((item: any) => {
item.icon = 'el-icon-HomeFilled'
item.level = 1
item.color = config.getColorVal('elementUiPrimary')
item.children.forEach((item2: any) => {
item2.icon = 'el-icon-List'
item2.level = 1
item2.color = config.getColorVal('elementUiPrimary')
item2.children.forEach((item3: any) => {
item3.icon = 'el-icon-Platform'
item3.level = 1
item3.color =
item3.comFlag === 2 ? config.getColorVal('elementUiPrimary') : '#e26257 !important'
item3.children.forEach((item4: any) => {
item4.icon = 'el-icon-Platform'
item4.color =
item4.comFlag === 2 ? config.getColorVal('elementUiPrimary') : '#e26257 !important'
// item4.color = '#e26257 !important'
arr3.push(item4)
})
})
})
})
2024-10-17 15:42:07 +08:00
}
})
tree.value = res.data
nextTick(() => {
if (arr1.length) {
//初始化选中
treRef.value.treeRef1.setCurrentKey(arr1[0].id)
// 注册父组件事件
emit('init', {
level: 2,
...arr1[0]
2024-06-27 09:39:53 +08:00
})
2025-10-11 10:35:25 +08:00
return
}
if (arr2.length) {
//初始化选中
treRef.value.treeRef2.setCurrentKey(arr2[0].id)
// 注册父组件事件
emit('init', {
level: 2,
...arr2[0]
})
return
}
if(arr3.length){
treRef.value.treeRef3.setCurrentKey(arr3[0].id)
emit('init', {
level: 2,
...arr3[0]
})
return
2024-10-17 15:42:07 +08:00
}
else {
2025-10-11 10:35:25 +08:00
emit('init')
return
2024-10-17 15:42:07 +08:00
}
})
2024-01-09 13:49:21 +08:00
})
2024-10-17 15:42:07 +08:00
}
const changePointType = (val: any, obj: any) => {
emit('pointTypeChange', val, obj)
}
if (props.template) {
getTemplateByDept({ id: dictData.state.area[0].id })
.then((res: any) => {
emit('Policy', res.data)
info()
})
.catch(err => {
info()
})
2024-10-17 15:42:07 +08:00
} else {
info()
}
onMounted(() => {})
2024-01-09 13:49:21 +08:00
</script>