2024-08-23 13:19:20 +08:00
|
|
|
<template>
|
2024-10-11 08:49:31 +08:00
|
|
|
<div class='plan_tree'>
|
|
|
|
|
<div class='search_view'>
|
2024-08-27 18:37:46 +08:00
|
|
|
<el-input
|
2024-10-11 08:49:31 +08:00
|
|
|
placeholder='请输入计划名称'
|
|
|
|
|
v-model='searchForm.planName'
|
2024-08-27 18:37:46 +08:00
|
|
|
></el-input>
|
2024-10-11 08:49:31 +08:00
|
|
|
<Menu style='width: 26px;height: 26px; margin-left: 8px;cursor: pointer;color:var(--el-color-primary)'
|
|
|
|
|
@click.stop='detail()' />
|
2024-08-27 18:37:46 +08:00
|
|
|
</div>
|
2024-10-11 08:49:31 +08:00
|
|
|
<div class='tree_container'>
|
2024-08-27 18:37:46 +08:00
|
|
|
<el-tree
|
2024-10-11 08:49:31 +08:00
|
|
|
:data='data'
|
|
|
|
|
ref='treeRef'
|
|
|
|
|
:filter-node-method='filterNode'
|
|
|
|
|
:props='defaultProps'
|
|
|
|
|
node-key='id'
|
2024-08-27 18:37:46 +08:00
|
|
|
default-expand-all
|
2024-10-11 08:49:31 +08:00
|
|
|
:default-checked-keys='defaultChecked'
|
|
|
|
|
@node-click='handleNodeClick'
|
2024-08-27 18:37:46 +08:00
|
|
|
>
|
2024-10-11 08:49:31 +08:00
|
|
|
<template #default='{ node, data }'>
|
|
|
|
|
<span class='custom-tree-node' style='display: flex;align-items: center;'>
|
|
|
|
|
<Platform v-if='!data.pid' style='width:18px;height: 18px;margin-right:8px;'
|
|
|
|
|
:style="{color:node.label=='未检测'?'#F56C6C':node.label=='检测中'?'#E6A23C':'#67C23A'}" />
|
2024-08-27 15:40:58 +08:00
|
|
|
<span>{{ node.label }}</span>
|
2024-08-27 18:37:46 +08:00
|
|
|
<!-- <Menu v-if="data.pid" @click.stop="detail(data)" style="width: 12px;margin-left: 8px;"/> -->
|
2024-08-27 15:40:58 +08:00
|
|
|
</span>
|
|
|
|
|
</template>
|
|
|
|
|
</el-tree>
|
2024-08-23 16:51:49 +08:00
|
|
|
</div>
|
2024-08-23 13:19:20 +08:00
|
|
|
</div>
|
|
|
|
|
</template>
|
2024-10-11 08:49:31 +08:00
|
|
|
<script lang='ts' setup>
|
|
|
|
|
import { Menu, Platform } from '@element-plus/icons-vue'
|
|
|
|
|
import { useRouter } from 'vue-router'
|
|
|
|
|
|
|
|
|
|
const router = useRouter()
|
|
|
|
|
const data: any = ref([])
|
2024-08-23 13:19:20 +08:00
|
|
|
const defaultProps = {
|
2024-10-11 08:49:31 +08:00
|
|
|
children: 'children',
|
|
|
|
|
label: 'name',
|
|
|
|
|
pid: 'pid',
|
|
|
|
|
}
|
2024-08-23 13:19:20 +08:00
|
|
|
const searchForm = ref({
|
2024-10-11 08:49:31 +08:00
|
|
|
planName: '',
|
|
|
|
|
})
|
|
|
|
|
const defaultChecked = ref([])
|
2024-08-23 13:19:20 +08:00
|
|
|
const getTreeData = (val: any) => {
|
2024-10-11 08:49:31 +08:00
|
|
|
defaultChecked.value = []
|
|
|
|
|
data.value = val
|
|
|
|
|
defaultChecked.value.push(data.value[0].children[0].id)
|
|
|
|
|
}
|
|
|
|
|
const filterText = ref('')
|
|
|
|
|
const treeRef = ref()
|
2024-11-12 20:35:12 +08:00
|
|
|
const {updateSelectedTreeNode} = defineProps<{
|
|
|
|
|
updateSelectedTreeNode:Function;
|
|
|
|
|
}>();
|
2024-08-23 13:19:20 +08:00
|
|
|
watch(
|
|
|
|
|
() => searchForm.value.planName,
|
|
|
|
|
(val) => {
|
2024-10-11 08:49:31 +08:00
|
|
|
treeRef.value!.filter(val)
|
2024-08-23 13:19:20 +08:00
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
deep: true,
|
2024-10-11 08:49:31 +08:00
|
|
|
},
|
|
|
|
|
)
|
2024-08-23 13:19:20 +08:00
|
|
|
const handleNodeClick = (data) => {
|
2024-10-11 08:49:31 +08:00
|
|
|
console.log(data)
|
2024-11-12 20:35:12 +08:00
|
|
|
updateSelectedTreeNode()
|
2024-10-11 08:49:31 +08:00
|
|
|
}
|
2024-08-23 13:19:20 +08:00
|
|
|
const filterNode = (value: string, data) => {
|
2024-10-11 08:49:31 +08:00
|
|
|
if (!value) return true
|
|
|
|
|
return data.name.includes(value)
|
|
|
|
|
}
|
2024-08-27 15:40:58 +08:00
|
|
|
// 点击详情
|
2024-10-11 08:49:31 +08:00
|
|
|
const detail = () => {
|
|
|
|
|
router.push('/plan')
|
|
|
|
|
}
|
2024-08-23 13:19:20 +08:00
|
|
|
onMounted(() => {
|
2024-10-11 08:49:31 +08:00
|
|
|
console.log()
|
|
|
|
|
})
|
|
|
|
|
defineExpose({ getTreeData })
|
2024-08-23 13:19:20 +08:00
|
|
|
</script>
|
2024-10-11 08:49:31 +08:00
|
|
|
<style lang='scss' scoped>
|
2024-08-23 13:19:20 +08:00
|
|
|
.plan_tree {
|
2024-09-02 16:10:33 +08:00
|
|
|
// width: 200px;
|
|
|
|
|
// height: 100%;
|
2024-08-23 16:51:49 +08:00
|
|
|
display: flex;
|
|
|
|
|
flex-direction: column;
|
2024-08-23 13:19:20 +08:00
|
|
|
padding: 5px;
|
2024-09-02 16:10:33 +08:00
|
|
|
// height: calc(100% - 70px);
|
2024-08-27 14:01:26 +08:00
|
|
|
background-color: #fff;
|
2024-10-11 08:49:31 +08:00
|
|
|
|
2024-08-27 18:37:46 +08:00
|
|
|
.search_view {
|
|
|
|
|
width: 100%;
|
|
|
|
|
height: auto;
|
|
|
|
|
display: flex;
|
|
|
|
|
justify-content: space-between;
|
|
|
|
|
padding: 0 5px;
|
|
|
|
|
box-sizing: border-box;
|
|
|
|
|
align-items: center;
|
2024-10-11 08:49:31 +08:00
|
|
|
|
|
|
|
|
.el-input {
|
2024-08-27 18:37:46 +08:00
|
|
|
margin-top: 6px;
|
|
|
|
|
}
|
|
|
|
|
}
|
2024-10-11 08:49:31 +08:00
|
|
|
|
2024-08-23 13:19:20 +08:00
|
|
|
.el-input {
|
|
|
|
|
width: 100%;
|
2024-08-23 16:51:49 +08:00
|
|
|
margin: 0 10px 10px 0;
|
2024-08-23 13:19:20 +08:00
|
|
|
}
|
2024-08-27 15:40:58 +08:00
|
|
|
|
2024-08-23 16:51:49 +08:00
|
|
|
.tree_container {
|
|
|
|
|
flex: 1;
|
|
|
|
|
overflow-y: auto;
|
2024-08-27 15:40:58 +08:00
|
|
|
|
2024-08-23 16:51:49 +08:00
|
|
|
.el-tree {
|
|
|
|
|
height: 100%;
|
2024-11-12 20:35:12 +08:00
|
|
|
width: 100%;
|
2024-08-23 16:51:49 +08:00
|
|
|
}
|
2024-08-23 13:19:20 +08:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
</style>
|