You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
116 lines
2.5 KiB
116 lines
2.5 KiB
"use strict";
|
|
|
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
|
|
exports.__esModule = true;
|
|
exports.default = void 0;
|
|
|
|
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
|
|
|
|
var _vue = _interopRequireDefault(require("vue"));
|
|
|
|
var _Dialog = _interopRequireDefault(require("./Dialog"));
|
|
|
|
var _utils = require("../utils");
|
|
|
|
var instance;
|
|
|
|
function isInDocument(element) {
|
|
return document.body.contains(element);
|
|
}
|
|
|
|
function initInstance() {
|
|
if (instance) {
|
|
instance.$destroy();
|
|
}
|
|
|
|
instance = new (_vue.default.extend(_Dialog.default))({
|
|
el: document.createElement('div'),
|
|
// avoid missing animation when first rendered
|
|
propsData: {
|
|
lazyRender: false
|
|
}
|
|
});
|
|
instance.$on('input', function (value) {
|
|
instance.value = value;
|
|
});
|
|
}
|
|
|
|
function Dialog(options) {
|
|
/* istanbul ignore if */
|
|
if (_utils.isServer) {
|
|
return Promise.resolve();
|
|
}
|
|
|
|
return new Promise(function (resolve, reject) {
|
|
if (!instance || !isInDocument(instance.$el)) {
|
|
initInstance();
|
|
}
|
|
|
|
(0, _extends2.default)(instance, Dialog.currentOptions, options, {
|
|
resolve: resolve,
|
|
reject: reject
|
|
});
|
|
});
|
|
}
|
|
|
|
Dialog.defaultOptions = {
|
|
value: true,
|
|
title: '',
|
|
width: '',
|
|
theme: null,
|
|
message: '',
|
|
overlay: true,
|
|
className: '',
|
|
allowHtml: true,
|
|
lockScroll: true,
|
|
transition: 'van-dialog-bounce',
|
|
beforeClose: null,
|
|
overlayClass: '',
|
|
overlayStyle: null,
|
|
messageAlign: '',
|
|
getContainer: 'body',
|
|
cancelButtonText: '',
|
|
cancelButtonColor: null,
|
|
confirmButtonText: '',
|
|
confirmButtonColor: null,
|
|
showConfirmButton: true,
|
|
showCancelButton: false,
|
|
closeOnPopstate: true,
|
|
closeOnClickOverlay: false,
|
|
callback: function callback(action) {
|
|
instance[action === 'confirm' ? 'resolve' : 'reject'](action);
|
|
}
|
|
};
|
|
Dialog.alert = Dialog;
|
|
|
|
Dialog.confirm = function (options) {
|
|
return Dialog((0, _extends2.default)({
|
|
showCancelButton: true
|
|
}, options));
|
|
};
|
|
|
|
Dialog.close = function () {
|
|
if (instance) {
|
|
instance.value = false;
|
|
}
|
|
};
|
|
|
|
Dialog.setDefaultOptions = function (options) {
|
|
(0, _extends2.default)(Dialog.currentOptions, options);
|
|
};
|
|
|
|
Dialog.resetDefaultOptions = function () {
|
|
Dialog.currentOptions = (0, _extends2.default)({}, Dialog.defaultOptions);
|
|
};
|
|
|
|
Dialog.resetDefaultOptions();
|
|
|
|
Dialog.install = function () {
|
|
_vue.default.use(_Dialog.default);
|
|
};
|
|
|
|
Dialog.Component = _Dialog.default;
|
|
_vue.default.prototype.$dialog = Dialog;
|
|
var _default = Dialog;
|
|
exports.default = _default; |