import { VantComponent } from '../common/component'; import { button } from '../mixins/button'; import { openType } from '../mixins/open-type'; import { GRAY, RED } from '../common/color'; type Action = 'confirm' | 'cancel' | 'overlay'; VantComponent({ mixins: [button, openType], props: { show: { type: Boolean, observer(show: boolean) { !show && this.stopLoading(); } }, title: String, message: String, theme: { type: String, value: 'default' }, useSlot: Boolean, className: String, customStyle: String, asyncClose: Boolean, messageAlign: String, overlayStyle: String, useTitleSlot: Boolean, showCancelButton: Boolean, closeOnClickOverlay: Boolean, confirmButtonOpenType: String, width: null, zIndex: { type: Number, value: 2000 }, confirmButtonText: { type: String, value: '确认' }, cancelButtonText: { type: String, value: '取消' }, confirmButtonColor: { type: String, value: RED }, cancelButtonColor: { type: String, value: GRAY }, showConfirmButton: { type: Boolean, value: true }, overlay: { type: Boolean, value: true }, transition: { type: String, value: 'scale' } }, data: { loading: { confirm: false, cancel: false } }, methods: { onConfirm() { this.handleAction('confirm'); }, onCancel() { this.handleAction('cancel'); }, onClickOverlay() { this.onClose('overlay'); }, handleAction(action: Action) { if (this.data.asyncClose) { this.setData({ [`loading.${action}`]: true }); } this.onClose(action); }, close() { this.setData({ show: false }); }, stopLoading() { this.setData({ loading: { confirm: false, cancel: false } }); }, onClose(action: Action) { if (!this.data.asyncClose) { this.close(); } this.$emit('close', action); // 把 dialog 实例传递出去,可以通过 stopLoading() 在外部关闭按钮的 loading this.$emit(action, { dialog: this }); const callback = this.data[ action === 'confirm' ? 'onConfirm' : 'onCancel' ]; if (callback) { callback(this); } } } });