fix: vbenTree modelValue synchronization (#5825)
							parent
							
								
									a61d9003dd
								
							
						
					
					
						commit
						0f5937204f
					
				|  | @ -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); | ||||||
|           } |           } | ||||||
|  |  | ||||||
|  | @ -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指定的图标 */ | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	 Netfan
						Netfan