fix(DynamicDialog): delay instance removal until after hide animation

pull/6977/head
严浩 2024-12-19 16:01:45 +08:00
parent d177ba5ff7
commit 3b0739684a
1 changed files with 3 additions and 3 deletions

View File

@ -1,6 +1,6 @@
<template> <template>
<template v-for="(instance, key) in instanceMap" :key="key"> <template v-for="(instance, key) in instanceMap" :key="key">
<DDialog v-model:visible="instance.visible" :_instance="instance" v-bind="instance.options.props" @hide="onDialogHide(instance)" @after-hide="onDialogAfterHide"> <DDialog v-model:visible="instance.visible" :_instance="instance" v-bind="instance.options.props" @hide="onDialogHide(instance)" @after-hide="onDialogAfterHide(instance)">
<template v-if="instance.options.templates && instance.options.templates.header" #header> <template v-if="instance.options.templates && instance.options.templates.header" #header>
<component v-for="(header, index) in getTemplateItems(instance.options.templates.header)" :is="header" :key="index + '_header'" v-bind="instance.options.emits"></component> <component v-for="(header, index) in getTemplateItems(instance.options.templates.header)" :is="header" :key="index + '_header'" v-bind="instance.options.emits"></component>
</template> </template>
@ -61,11 +61,11 @@ export default {
methods: { methods: {
onDialogHide(instance) { onDialogHide(instance) {
!this.currentInstance && instance.options.onClose && instance.options.onClose({ type: 'dialog-close' }); !this.currentInstance && instance.options.onClose && instance.options.onClose({ type: 'dialog-close' });
delete this.instanceMap[instance.key];
}, },
onDialogAfterHide() { onDialogAfterHide(instance) {
this.currentInstance && delete this.currentInstance; this.currentInstance && delete this.currentInstance;
this.currentInstance = null; this.currentInstance = null;
delete this.instanceMap[instance.key];
}, },
getTemplateItems(template) { getTemplateItems(template) {
return Array.isArray(template) ? template : [template]; return Array.isArray(template) ? template : [template];