vxe-pc-ui
Version:
A vue based PC component library
72 lines (71 loc) • 3.01 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = exports.VxeDrawer = exports.DrawerController = exports.Drawer = void 0;
var _core = require("@vxe-ui/core");
var _xeUtils = _interopRequireDefault(require("xe-utils"));
var _drawer = _interopRequireWildcard(require("./src/drawer"));
var _dynamics = require("../dynamics");
function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function (e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != typeof e && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (const t in e) "default" !== t && {}.hasOwnProperty.call(e, t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, t)) && (i.get || i.set) ? o(f, t, i) : f[t] = e[t]); return f; })(e, t); }
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
function handleDrawer(options) {
// 使用动态组件渲染动态弹框
(0, _dynamics.checkDynamic)();
return new Promise(resolve => {
if (options && options.id && _drawer.allActiveDrawers.some(comp => comp.props.id === options.id)) {
resolve('exist');
} else {
const _onHide = options.onHide;
const drawerOpts = Object.assign(options, {
key: _xeUtils.default.uniqueId(),
modelValue: true,
onHide(params) {
const drawerList = _dynamics.dynamicStore.drawers;
if (_onHide) {
_onHide(params);
}
_dynamics.dynamicStore.drawers = drawerList.filter(item => item.key !== drawerOpts.key);
resolve(params.type);
}
});
_dynamics.dynamicStore.drawers.push(drawerOpts);
}
});
}
function getDrawer(id) {
return _xeUtils.default.find(_drawer.allActiveDrawers, $drawer => $drawer.props.id === id);
}
/**
* 全局关闭动态的活动窗口(只能用于关闭动态的创建的活动窗口)
* 如果传 id 则关闭指定的窗口
* 如果不传则关闭所有窗口
*/
function closeDrawer(id) {
const drawers = id ? [getDrawer(id)] : _drawer.allActiveDrawers;
const restPromises = [];
drawers.forEach($drawer => {
if ($drawer) {
restPromises.push($drawer.close());
}
});
return Promise.all(restPromises);
}
function openDrawer(options) {
return handleDrawer(Object.assign({}, options));
}
const DrawerController = exports.DrawerController = {
get: getDrawer,
close: closeDrawer,
open: openDrawer
};
const VxeDrawer = exports.VxeDrawer = Object.assign(_drawer.default, {
install: function (app) {
app.component(_drawer.default.name, _drawer.default);
}
});
_core.VxeUI.drawer = DrawerController;
_dynamics.dynamicApp.use(VxeDrawer);
_core.VxeUI.component(_drawer.default);
const Drawer = exports.Drawer = VxeDrawer;
var _default = exports.default = VxeDrawer;