2019-12-23 14:13:27 +08:00
|
|
|
import { WHITE } from '../common/color';
|
|
|
|
const defaultOptions = {
|
|
|
|
selector: '#van-notify',
|
|
|
|
type: 'danger',
|
|
|
|
message: '',
|
|
|
|
background: '',
|
|
|
|
duration: 3000,
|
|
|
|
zIndex: 110,
|
|
|
|
color: WHITE,
|
|
|
|
onClick: () => { },
|
|
|
|
onOpened: () => { },
|
|
|
|
onClose: () => { }
|
|
|
|
};
|
|
|
|
function parseOptions(message) {
|
|
|
|
return typeof message === 'string' ? { message } : message;
|
|
|
|
}
|
|
|
|
function getContext() {
|
|
|
|
const pages = getCurrentPages();
|
|
|
|
return pages[pages.length - 1];
|
|
|
|
}
|
|
|
|
export default function Notify(options) {
|
|
|
|
options = Object.assign({}, defaultOptions, parseOptions(options));
|
|
|
|
const context = options.context || getContext();
|
|
|
|
const notify = context.selectComponent(options.selector);
|
|
|
|
delete options.context;
|
|
|
|
delete options.selector;
|
|
|
|
if (notify) {
|
|
|
|
notify.set(options);
|
|
|
|
notify.show();
|
|
|
|
return notify;
|
|
|
|
}
|
|
|
|
console.warn('未找到 van-notify 节点,请确认 selector 及 context 是否正确');
|
|
|
|
}
|
|
|
|
Notify.clear = function (options) {
|
|
|
|
options = Object.assign({}, defaultOptions, parseOptions(options));
|
|
|
|
const context = options.context || getContext();
|
|
|
|
const notify = context.selectComponent(options.selector);
|
|
|
|
if (notify) {
|
|
|
|
notify.hide();
|
|
|
|
}
|
|
|
|
};
|