UNPKG

@gyenno/nutui-taro

Version:

京东风格的轻量级移动端 Vue2、Vue3 组件库(支持小程序开发)

83 lines (82 loc) 2.24 kB
import { computed, openBlock, createBlock, Transition, withCtx, withDirectives, createElementVNode, normalizeClass, normalizeStyle, renderSlot, vShow } from "vue"; import { c as createComponent } from "./component-25dcca32.js"; import { _ as _export_sfc } from "./_plugin-vue_export-helper-cc2b3d55.js"; import "../locale/lang"; const { componentName, create } = createComponent("overlay"); const _sfc_main = create({ props: { visible: { type: Boolean, default: false }, zIndex: { type: [Number, String], default: 2e3 }, duration: { type: [Number, String], default: 0.3 }, overlayClass: { type: String, default: "" }, lockScroll: { type: Boolean, default: true }, overlayStyle: { type: Object }, closeOnClickOverlay: { type: Boolean, default: true } }, emits: ["click", "update:visible"], setup(props, { emit }) { const classes = computed(() => { const prefixCls = componentName; return { [prefixCls]: true, [props.overlayClass]: true }; }); const style = computed(() => { return { transitionDuration: `${props.duration}s`, zIndex: props.zIndex, ...props.overlayStyle }; }); const onClick = (e) => { emit("click", e); if (props.closeOnClickOverlay) { emit("update:visible", false); } }; return { classes, style, onClick }; } }); const _hoisted_1 = ["catch-move"]; function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) { return openBlock(), createBlock(Transition, { name: "overlay-fade" }, { default: withCtx(() => [ withDirectives(createElementVNode("view", { class: normalizeClass(_ctx.classes), onClick: _cache[0] || (_cache[0] = (...args) => _ctx.onClick && _ctx.onClick(...args)), style: normalizeStyle(_ctx.style), "catch-move": _ctx.lockScroll }, [ renderSlot(_ctx.$slots, "default") ], 14, _hoisted_1), [ [vShow, _ctx.visible] ]) ]), _: 3 }); } const OverLay = /* @__PURE__ */ _export_sfc(_sfc_main, [["render", _sfc_render]]); export { OverLay as default };