2025-05-08 08:23:03 +00:00
|
|
|
<template>
|
2025-05-12 10:19:28 +00:00
|
|
|
<div>
|
|
|
|
|
<el-input
|
|
|
|
|
v-model="filterText"
|
|
|
|
|
:placeholder="$t('common.search')"
|
|
|
|
|
prefix-icon="Search"
|
|
|
|
|
clearable
|
2025-05-13 08:19:21 +00:00
|
|
|
class="p-16"
|
2025-05-12 10:19:28 +00:00
|
|
|
/>
|
|
|
|
|
<el-tree
|
|
|
|
|
ref="treeRef"
|
|
|
|
|
:data="data"
|
|
|
|
|
:props="defaultProps"
|
|
|
|
|
@node-click="handleNodeClick"
|
|
|
|
|
:filter-node-method="filterNode"
|
|
|
|
|
:default-expanded-keys="[currentNodeKey]"
|
|
|
|
|
:current-node-key="currentNodeKey"
|
|
|
|
|
highlight-current
|
|
|
|
|
node-key="id"
|
|
|
|
|
>
|
|
|
|
|
<template #default="{ node, data }">
|
|
|
|
|
<div class="custom-tree-node flex align-center">
|
|
|
|
|
<AppIcon iconName="app-folder" style="font-size: 16px"></AppIcon>
|
|
|
|
|
<span class="ml-8" >{{ node.label }}</span>
|
|
|
|
|
</div>
|
|
|
|
|
</template>
|
|
|
|
|
</el-tree>
|
|
|
|
|
</div>
|
2025-05-08 08:23:03 +00:00
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
<script lang="ts" setup>
|
2025-05-12 10:19:28 +00:00
|
|
|
import { ref, watch } from 'vue'
|
|
|
|
|
import type { TreeInstance } from 'element-plus'
|
2025-05-08 08:23:03 +00:00
|
|
|
defineOptions({ name: 'FolderTree' })
|
2025-05-09 06:42:51 +00:00
|
|
|
const props = defineProps({
|
|
|
|
|
data: {
|
|
|
|
|
type: Array,
|
|
|
|
|
default: () => [],
|
|
|
|
|
},
|
2025-05-12 10:19:28 +00:00
|
|
|
currentNodeKey: {
|
|
|
|
|
type: String,
|
|
|
|
|
default: 'root',
|
|
|
|
|
},
|
2025-05-09 06:42:51 +00:00
|
|
|
})
|
2025-05-08 08:23:03 +00:00
|
|
|
interface Tree {
|
2025-05-09 06:42:51 +00:00
|
|
|
name: string
|
2025-05-08 08:23:03 +00:00
|
|
|
children?: Tree[]
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const defaultProps = {
|
|
|
|
|
children: 'children',
|
2025-05-09 06:42:51 +00:00
|
|
|
label: 'name',
|
2025-05-08 08:23:03 +00:00
|
|
|
}
|
2025-05-12 10:19:28 +00:00
|
|
|
|
|
|
|
|
const emit = defineEmits(['handleNodeClick'])
|
|
|
|
|
|
|
|
|
|
const treeRef = ref<TreeInstance>()
|
|
|
|
|
const filterText = ref('')
|
|
|
|
|
|
|
|
|
|
watch(filterText, (val) => {
|
|
|
|
|
treeRef.value!.filter(val)
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
const filterNode = (value: string, data: Tree) => {
|
|
|
|
|
if (!value) return true
|
|
|
|
|
return data.name.includes(value)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const handleNodeClick = (data: Tree) => {
|
|
|
|
|
emit('handleNodeClick', data)
|
|
|
|
|
}
|
2025-05-08 08:23:03 +00:00
|
|
|
</script>
|