fix: alert send wrong confirm state to beforeClose (#5991)
* 修复alert在按下Esc或者点击遮罩关闭时,可能发送错误的isConfirm状态pull/78/MERGE
							parent
							
								
									14bd6dd25d
								
							
						
					
					
						commit
						79de6bcbf7
					
				|  | @ -91,14 +91,13 @@ const getIconRender = computed(() => { | |||
| }); | ||||
| 
 | ||||
| function doCancel() { | ||||
|   isConfirm.value = false; | ||||
|   handleCancel(); | ||||
|   handleOpenChange(false); | ||||
| } | ||||
| 
 | ||||
| function doConfirm() { | ||||
|   isConfirm.value = true; | ||||
|   handleConfirm(); | ||||
|   handleOpenChange(false); | ||||
|   emits('confirm'); | ||||
| } | ||||
| 
 | ||||
| provideAlertContext({ | ||||
|  | @ -117,11 +116,13 @@ function handleCancel() { | |||
| 
 | ||||
| const loading = ref(false); | ||||
| async function handleOpenChange(val: boolean) { | ||||
|   const confirmState = isConfirm.value; | ||||
|   isConfirm.value = false; | ||||
|   await nextTick(); | ||||
|   if (!val && props.beforeClose) { | ||||
|     loading.value = true; | ||||
|     try { | ||||
|       const res = await props.beforeClose({ isConfirm: isConfirm.value }); | ||||
|       const res = await props.beforeClose({ isConfirm: confirmState }); | ||||
|       if (res !== false) { | ||||
|         open.value = false; | ||||
|       } | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue
	
	 Netfan
						Netfan