2023-06-09 13:46:11 +08:00
|
|
|
|
import { Modal } from '@arco-design/web-vue';
|
|
|
|
|
import type { ModalConfig } from '@arco-design/web-vue';
|
|
|
|
|
|
|
|
|
|
export type ModalType = 'info' | 'success' | 'warning' | 'error';
|
|
|
|
|
|
|
|
|
|
export type ModalSize = 'small' | 'medium' | 'large' | 'full';
|
|
|
|
|
|
|
|
|
|
export type ModalMode = 'default' | 'weak';
|
|
|
|
|
|
|
|
|
|
export interface ModalOptions extends ModalConfig {
|
|
|
|
|
mode?: ModalMode;
|
|
|
|
|
type: ModalType;
|
|
|
|
|
size?: ModalSize;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export default function useModal() {
|
|
|
|
|
return {
|
|
|
|
|
openModal: (options: ModalOptions) =>
|
2023-06-16 15:37:34 +08:00
|
|
|
|
// error 使用 warning的感叹号图标
|
|
|
|
|
Modal[options.type === 'error' ? 'warning' : options.type]({
|
|
|
|
|
// 默认设置按钮属性,也可通过options传入覆盖
|
2023-06-12 18:29:21 +08:00
|
|
|
|
okButtonProps: {
|
|
|
|
|
type: options.mode === 'weak' ? 'text' : 'primary',
|
|
|
|
|
},
|
|
|
|
|
cancelButtonProps: {
|
|
|
|
|
type: options.mode === 'weak' ? 'text' : 'secondary',
|
|
|
|
|
},
|
2023-08-09 10:07:00 +08:00
|
|
|
|
simple: false,
|
2023-06-16 15:37:34 +08:00
|
|
|
|
...options,
|
|
|
|
|
titleAlign: 'start',
|
2023-08-09 13:57:29 +08:00
|
|
|
|
modalClass: `ms-usemodal ms-usemodal-${options.mode || 'default'} ms-usemodal-${
|
|
|
|
|
options.size || 'small'
|
|
|
|
|
} ms-usemodal-${options.type}`,
|
2023-06-09 13:46:11 +08:00
|
|
|
|
}),
|
|
|
|
|
};
|
|
|
|
|
}
|