UNPKG

song-ui-u

Version:

vue3 + js的PC前端组件库

189 lines (178 loc) 8.52 kB
import { mergeModels, useModel, computed, isVNode, onMounted, openBlock, createBlock, Transition, withCtx, withDirectives, createVNode, mergeProps, createElementVNode, normalizeClass, resolveDynamicComponent, toDisplayString, createElementBlock, Fragment, createTextVNode, createCommentVNode, renderSlot, vShow } from 'vue'; import { useNamespace } from '../../../hook/use-namespace/index.mjs'; import { types } from '../../../utils/types.mjs'; import { typeIcon } from '../../../utils/componentsType.mjs'; import { themeType } from '../../../utils/themeType.mjs'; import '../../../hook/use-zindex/index.mjs'; import { XButton } from '../../button/index.mjs'; import '../../buttonGroup/index.mjs'; import { XIcon } from '../../icon/index.mjs'; import '../../input/index.mjs'; import '../../textarea/index.mjs'; import '../../row/index.mjs'; import '../../col/index.mjs'; import '../../container/index.mjs'; import '../../checkbox/index.mjs'; import '../../switch/index.mjs'; import '../../form/index.mjs'; import '../../message/index.mjs'; import { XMask } from '../../mask/index.mjs'; import '../../modal/index.mjs'; import '../index.mjs'; import '../../drawer/index.mjs'; import '../../badge/index.mjs'; import '../../space/index.mjs'; import '../../image/index.mjs'; import '../../radio/index.mjs'; import '../../divider/index.mjs'; import '../../chat/index.mjs'; import '../../progress/index.mjs'; import '../../upload/index.mjs'; import '../../vTree/index.mjs'; import '../../table/index.mjs'; import '../../tabs/index.mjs'; import '../../menu/index.mjs'; import '../../steps/index.mjs'; import '../../header/index.mjs'; import '../../breadcrumble/index.mjs'; import '../../datePicker/index.mjs'; import '../../tooltip/index.mjs'; import '../../popover/index.mjs'; import '../../timePicker/index.mjs'; import '../../select/index.mjs'; import '../../collapse/index.mjs'; import '../../card/index.mjs'; import '../../timeline/index.mjs'; import '../../tag/index.mjs'; import '../../result/index.mjs'; import '../../sender/index.mjs'; import { useMessageBox } from './composables/use-message-box.mjs'; import { messageBoxProps } from './message-box.mjs'; import _export_sfc from '../../../_virtual/_plugin-vue_export-helper.mjs'; const __default__ = { name: "x-message-box" }; const _sfc_main = /*#__PURE__*/Object.assign(__default__, { props: /*#__PURE__*/mergeModels(messageBoxProps, { "modelValue": {}, "modelModifiers": {}, }), emits: /*#__PURE__*/mergeModels(["ok", "cancel", "open", "opened", "close", "closed"], ["update:modelValue"]), setup(__props, { expose: __expose, emit: __emit }) { __expose(); const props = __props; const emit = __emit; const ns = useNamespace("message-box"); const visible = useModel(__props, "modelValue"); const { useBeforeCancel, useBeforeChange, useClose, isLoading } = useMessageBox( { props, visible } ); // icon const icon = computed(() => typeIcon[props.icon]); const theme = computed(() => themeType?.[props.icon] || props.icon); // isString const isString = computed(() => types().isString(props.content)); const isVNodeDom = computed(() => isVNode(props.content)); onMounted(() => { visible.value = true; }); const __returned__ = { props, emit, ns, visible, useBeforeCancel, useBeforeChange, useClose, isLoading, icon, theme, isString, isVNodeDom, onMounted, computed, isVNode, get useNamespace() { return useNamespace }, get typeIcon() { return typeIcon }, get themeType() { return themeType }, get types() { return types }, get XMask() { return XMask }, get XButton() { return XButton }, get XIcon() { return XIcon }, get useMessageBox() { return useMessageBox }, get messageBoxProps() { return messageBoxProps } }; Object.defineProperty(__returned__, '__isScriptSetup', { enumerable: false, value: true }); return __returned__ } }); function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) { return (openBlock(), createBlock(Transition, { name: $setup.ns.b(), persisted: "" }, { default: withCtx(() => [ withDirectives(createVNode($setup["XMask"], mergeProps(_ctx.$attrs, { onClose: $setup.useClose }), { default: withCtx(() => [ createElementVNode("div", { class: normalizeClass([$setup.ns.b()]) }, [ createElementVNode("div", { class: normalizeClass([$setup.ns.e('wrap')]) }, [ createElementVNode("div", { class: normalizeClass([$setup.ns.e('body')]) }, [ createElementVNode("div", { class: normalizeClass([$setup.ns.e('header')]) }, [ createVNode($setup["XIcon"], { class: normalizeClass([$setup.ns.m($setup.theme)]) }, { default: withCtx(() => [ (openBlock(), createBlock(resolveDynamicComponent($setup.icon))) ]), _: 1 /* STABLE */ }, 8 /* PROPS */, ["class"]), createElementVNode("div", { class: normalizeClass([$setup.ns.e('title')]) }, toDisplayString(_ctx.title), 3 /* TEXT, CLASS */) ], 2 /* CLASS */), createElementVNode("div", { class: normalizeClass([$setup.ns.e('content')]) }, [ ($setup.isString) ? (openBlock(), createElementBlock(Fragment, { key: 0 }, [ createTextVNode(toDisplayString(_ctx.content), 1 /* TEXT */) ], 64 /* STABLE_FRAGMENT */)) : createCommentVNode("v-if", true), ($setup.isVNodeDom) ? (openBlock(), createBlock(resolveDynamicComponent(_ctx.content), { key: 1 })) : createCommentVNode("v-if", true) ], 2 /* CLASS */) ], 2 /* CLASS */), (_ctx.footer) ? (openBlock(), createElementBlock("div", { key: 0, class: normalizeClass([$setup.ns.e('footer')]) }, [ (_ctx.$slots.footer) ? renderSlot(_ctx.$slots, "footer", { key: 0 }) : (openBlock(), createElementBlock(Fragment, { key: 1 }, [ (_ctx.cancelButtonShow) ? (openBlock(), createBlock($setup["XButton"], { key: 0, text: "", size: "large", onClick: $setup.useBeforeCancel }, { default: withCtx(() => [ createTextVNode(toDisplayString(_ctx.cancelButtonText), 1 /* TEXT */) ]), _: 1 /* STABLE */ }, 8 /* PROPS */, ["onClick"])) : createCommentVNode("v-if", true), (_ctx.confirmButtonShow) ? (openBlock(), createBlock($setup["XButton"], { key: 1, type: "primary", size: "large", loading: $setup.isLoading, onClick: $setup.useBeforeChange }, { default: withCtx(() => [ createTextVNode(toDisplayString(_ctx.confirmButtonText), 1 /* TEXT */) ]), _: 1 /* STABLE */ }, 8 /* PROPS */, ["loading", "onClick"])) : createCommentVNode("v-if", true) ], 64 /* STABLE_FRAGMENT */)) ], 2 /* CLASS */)) : createCommentVNode("v-if", true) ], 2 /* CLASS */) ], 2 /* CLASS */) ]), _: 3 /* FORWARDED */ }, 16 /* FULL_PROPS */, ["onClose"]), [ [vShow, $setup.visible] ]) ]), _: 3 /* FORWARDED */ }, 8 /* PROPS */, ["name"])) } var MessageBoxNode = /*#__PURE__*/_export_sfc(_sfc_main, [['render',_sfc_render],['__file',"E:\\code\\my-code\\song-ui-ultra\\packages\\components\\messageBox\\src\\message-box.vue"]]); export { MessageBoxNode as default }; //# sourceMappingURL=message-box.vue.mjs.map