fix: vbenTree modelValue synchronization (#5825)

pull/62/head
Netfan 2025-03-31 10:18:35 +08:00 committed by YunaiV
parent a61d9003dd
commit 0f5937204f
2 changed files with 9 additions and 21 deletions

View File

@ -11,7 +11,6 @@ import { onMounted, ref, watchEffect } from 'vue';
import { ChevronRight, IconifyIcon } from '@vben-core/icons'; import { ChevronRight, IconifyIcon } from '@vben-core/icons';
import { cn, get } from '@vben-core/shared/utils'; import { cn, get } from '@vben-core/shared/utils';
import { useVModel } from '@vueuse/core';
import { TreeItem, TreeRoot } from 'radix-vue'; import { TreeItem, TreeRoot } from 'radix-vue';
import { Checkbox } from '../checkbox'; import { Checkbox } from '../checkbox';
@ -27,7 +26,6 @@ const props = withDefaults(defineProps<TreeProps>(), {
expanded: () => [], expanded: () => [],
iconField: 'icon', iconField: 'icon',
labelField: 'label', labelField: 'label',
modelValue: () => [],
multiple: false, multiple: false,
showIcon: true, showIcon: true,
transition: true, transition: true,
@ -38,7 +36,6 @@ const props = withDefaults(defineProps<TreeProps>(), {
const emits = defineEmits<{ const emits = defineEmits<{
expand: [value: FlattenedItem<Recordable<any>>]; expand: [value: FlattenedItem<Recordable<any>>];
select: [value: FlattenedItem<Recordable<any>>]; select: [value: FlattenedItem<Recordable<any>>];
'update:modelValue': [value: Arrayable<Recordable<any>>];
}>(); }>();
interface InnerFlattenItem<T = Recordable<any>, P = number | string> { interface InnerFlattenItem<T = Recordable<any>, P = number | string> {
@ -76,11 +73,7 @@ function flatten<T = Recordable<any>, P = number | string>(
} }
const flattenData = ref<Array<InnerFlattenItem>>([]); const flattenData = ref<Array<InnerFlattenItem>>([]);
const modelValue = useVModel(props, 'modelValue', emits, { const modelValue = defineModel<Arrayable<number | string>>();
deep: true,
defaultValue: props.defaultValue ?? [],
passive: (props.modelValue === undefined) as false,
});
const expanded = ref<Array<number | string>>(props.defaultExpandedKeys ?? []); const expanded = ref<Array<number | string>>(props.defaultExpandedKeys ?? []);
const treeValue = ref(); const treeValue = ref();
@ -105,10 +98,14 @@ function getItemByValue(value: number | string) {
function updateTreeValue() { function updateTreeValue() {
const val = modelValue.value; const val = modelValue.value;
if (val === undefined) {
treeValue.value = undefined;
} else {
treeValue.value = Array.isArray(val) treeValue.value = Array.isArray(val)
? val.map((v) => getItemByValue(v)) ? val.map((v) => getItemByValue(v))
: getItemByValue(val); : getItemByValue(val);
} }
}
function updateModelValue(val: Arrayable<Recordable<any>>) { function updateModelValue(val: Arrayable<Recordable<any>>) {
modelValue.value = Array.isArray(val) modelValue.value = Array.isArray(val)
@ -173,13 +170,6 @@ function onSelect(item: FlattenedItem<Recordable<any>>, isSelected: boolean) {
modelValue.value.push(p); modelValue.value.push(p);
} }
}); });
} else {
if (Array.isArray(modelValue.value)) {
const index = modelValue.value.indexOf(get(item.value, props.valueField));
if (index !== -1) {
modelValue.value.splice(index, 1);
}
}
} }
updateTreeValue(); updateTreeValue();
emits('select', item); emits('select', item);
@ -240,7 +230,7 @@ defineExpose({
@select=" @select="
(event) => { (event) => {
if (event.detail.originalEvent.type === 'click') { if (event.detail.originalEvent.type === 'click') {
// event.preventDefault(); event.preventDefault();
} }
onSelect(item, event.detail.isSelected); onSelect(item, event.detail.isSelected);
} }

View File

@ -27,8 +27,6 @@ export interface TreeProps {
iconField?: string; iconField?: string;
/** label字段 */ /** label字段 */
labelField?: string; labelField?: string;
/** 当前值 */
modelValue?: Arrayable<number | string>;
/** 是否多选 */ /** 是否多选 */
multiple?: boolean; multiple?: boolean;
/** 显示由iconField指定的图标 */ /** 显示由iconField指定的图标 */