/** * Copyright (c) 2013-Now https://jeesite.com All rights reserved. * No deletion without permission, or be held responsible to law. * @author Vben、ThinkGem */ import type { ModalFunc, ModalFuncProps } from 'ant-design-vue/lib/modal/Modal'; import { Modal, message as Message, notification } from 'ant-design-vue'; import { InfoCircleFilled, CheckCircleFilled, CloseCircleFilled } from '@ant-design/icons-vue'; import { NotificationArgsProps, ConfigProps } from 'ant-design-vue/lib/notification'; import { useI18n } from './useI18n'; import { isString } from '@jeesite/core/utils/is'; import { Icon } from '@jeesite/core/components/Icon'; import type { ConfigOnClose, MessageType } from 'ant-design-vue/lib/message'; import type { JointContent } from 'ant-design-vue/es/message/interface'; export interface NotifyApi { info(config: NotificationArgsProps): void; success(config: NotificationArgsProps): void; error(config: NotificationArgsProps): void; warn(config: NotificationArgsProps): void; warning(config: NotificationArgsProps): void; open(args: NotificationArgsProps): void; close(key: string): void; config(options: ConfigProps): void; destroy(): void; } export declare type NotificationPlacement = 'topLeft' | 'topRight' | 'bottomLeft' | 'bottomRight'; export declare type IconType = 'success' | 'info' | 'error' | 'warning'; export interface ModalOptionsEx extends Omit { iconType: 'warning' | 'success' | 'error' | 'info'; icon?: any; title?: any; content?: any; } export type ModalOptionsPartial = Partial & Pick; interface ConfirmOptions { info: ModalFunc; success: ModalFunc; error: ModalFunc; warn: ModalFunc; warning: ModalFunc; } function getIcon(iconType: string) { if (iconType === 'warning') { return ; } else if (iconType === 'success') { return ; } else if (iconType === 'info') { return ; } else { return ; } } function renderContent({ content }: Pick) { if (isString(content)) { return
${content as string}
`}>; } else { return content; } } /** * @description: Create confirmation box */ function createConfirm(options: ModalOptionsEx) { const iconType = options.iconType || 'info'; Reflect.deleteProperty(options, 'iconType'); const opt: ModalFuncProps = { maskClosable: true, centered: true, icon: getIcon(iconType), ...options, content: renderContent(options), }; return Modal.confirm(opt); } const getBaseOptions = () => { const { t } = useI18n(); return { okText: t('common.okText'), centered: true, }; }; function createModalOptions(options: ModalOptionsPartial, icon: string): ModalOptionsPartial | any { return { ...getBaseOptions(), ...options, content: renderContent(options), icon: getIcon(icon), }; } function createSuccessModal(options: ModalOptionsPartial) { return Modal.success(createModalOptions(options, 'success')); } function createErrorModal(options: ModalOptionsPartial) { return Modal.error(createModalOptions(options, 'close')); } function createInfoModal(options: ModalOptionsPartial) { return Modal.info(createModalOptions(options, 'info')); } function createWarningModal(options: ModalOptionsPartial) { return Modal.warning(createModalOptions(options, 'warning')); } function contains(str, searchs) { if (typeof str === 'object' && str.content) { str = str.content; } if (typeof str === 'object' && str.props?.innerHTML) { str = str.props?.innerHTML; } if (typeof str === 'string' && searchs) { const ss = searchs.split(','); for (let i = 0; i < ss.length; i++) { if (str.indexOf(ss[i]) >= 0) { return true; } } } return false; } function showMessageModal(options: ModalOptionsPartial | string, type?: string) { const { t } = useI18n(); if (typeof options === 'string') options = { content: options }; if (typeof options.content === 'string' && options.content.startsWith('posfull:')) { options.content = ''; options.width = '80%'; } if (type === 'error' || contains(options.content, t('sys.message.error'))) { return Modal.error(createModalOptions(options, 'close')); } else if (type === 'warning' || contains(options.content, t('sys.message.warning'))) { return Modal.warning(createModalOptions(options, 'warning')); } else if (type === 'success' || contains(options.content, t('sys.message.success'))) { return Modal.success(createModalOptions(options, 'success')); } else { return Modal.info(createModalOptions(options, 'info')); } } function showMessage(content: JointContent, type?: string, duration?: number, onClose?: ConfigOnClose) { const { t } = useI18n(); let messageRemove = () => {}; if (typeof content === 'string' && content.startsWith('posfull:')) { content = { content: (
setTimeout(messageRemove, 1000)}>
messageRemove()}>
), duration, }; } if (type === 'error' || contains(content, t('sys.message.error'))) { messageRemove = Message.error(content, duration, onClose); } else if (type === 'warning' || contains(content, t('sys.message.warning'))) { messageRemove = Message.warning(content, duration, onClose); } else if (type === 'success' || contains(content, t('sys.message.success'))) { messageRemove = Message.success(content, duration, onClose); } else { messageRemove = Message.info(content, duration, onClose); } return messageRemove; } notification.config({ placement: 'topRight', duration: 3, }); /** * @description: message */ export function useMessage() { return { createMessage: Message, notification: notification as NotifyApi, createConfirm: createConfirm, createSuccessModal, createErrorModal, createInfoModal, createWarningModal, showMessageModal, showMessage, }; }