comic-plus
Version:
<p align="center"> <img width="200px" src="./logo.png"/> </p>
88 lines (87 loc) • 3.73 kB
JavaScript
;
Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: "Module" } });
const vue = require("vue");
require("../style/drawer.css");
const index = require("../../mode/index.js");
const popup = require("../../../hooks/popup.js");
require("../../../utils/config.js");
require("@vueuse/core");
const main_props = require("./main.props.js");
require("../../../icons/index.js");
const components = require("../../../icons/components/components.js");
const _hoisted_1 = { class: "cu-drawer__header" };
const _hoisted_2 = { class: "cu-drawer__content" };
const _hoisted_3 = {
key: 0,
class: "cu-drawer__footer"
};
const _sfc_main = /* @__PURE__ */ vue.defineComponent({
...{
name: "CuDrawer"
},
__name: "main",
props: main_props.drawerProps,
emits: main_props.drawerEmits,
setup(__props, { emit: __emit }) {
const props = __props;
const emit = __emit;
const { visible, showMode, onAfterEnter, modeHandleClick, close, onAfterLeave } = popup.usePopup(props, emit);
const drawerStyle = vue.computed(() => {
const key = ["left", "right"].includes(props.direction) ? "width" : "height";
return {
[key]: props.dimension,
backgroundColor: props.color
};
});
return (_ctx, _cache) => {
return vue.openBlock(), vue.createBlock(vue.unref(index.CuMode), {
show: vue.unref(showMode),
"lock-scroll": !_ctx.appendToBody || !_ctx.lockScroll ? false : _ctx.lockScroll,
"append-to-body": _ctx.appendToBody,
"append-to": _ctx.appendTo,
"custom-class": ["cu-mode__drawer", _ctx.modeClass],
onClose: _cache[2] || (_cache[2] = ($event) => emit("close")),
onOpen: vue.unref(onAfterEnter),
onModeClick: vue.unref(modeHandleClick)
}, {
default: vue.withCtx(() => [
vue.createVNode(vue.Transition, {
name: "cu-drawer-" + _ctx.direction,
onAfterLeave: _cache[0] || (_cache[0] = ($event) => vue.unref(onAfterLeave)()),
onAfterEnter: _cache[1] || (_cache[1] = ($event) => emit("open"))
}, {
default: vue.withCtx(() => [
vue.unref(visible) ? (vue.openBlock(), vue.createElementBlock("div", {
key: 0,
class: vue.normalizeClass(["cu-drawer", ["cu-drawer--" + _ctx.direction, _ctx.customClass]]),
style: vue.normalizeStyle(drawerStyle.value)
}, [
vue.createElementVNode("div", _hoisted_1, [
vue.createElementVNode("div", null, [
vue.renderSlot(_ctx.$slots, "header", {}, () => [
vue.createTextVNode(vue.toDisplayString(_ctx.header), 1)
])
]),
_ctx.showClose ? (vue.openBlock(), vue.createBlock(vue.unref(components.Close), {
key: 0,
class: "close",
onClick: vue.unref(close)
}, null, 8, ["onClick"])) : vue.createCommentVNode("", true)
]),
vue.createElementVNode("div", _hoisted_2, [
vue.renderSlot(_ctx.$slots, "default")
]),
_ctx.$slots.footer ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_3, [
vue.renderSlot(_ctx.$slots, "footer")
])) : vue.createCommentVNode("", true)
], 6)) : vue.createCommentVNode("", true)
]),
_: 3
}, 8, ["name"])
]),
_: 3
}, 8, ["show", "lock-scroll", "append-to-body", "append-to", "custom-class", "onOpen", "onModeClick"]);
};
}
});
exports.default = _sfc_main;