UnisKB/ui/src/components/folder-tree/index.vue

73 lines
1.5 KiB
Vue
Raw Normal View History

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>