song-ui-u
Version:
vue3 + js的PC前端组件库
189 lines (178 loc) • 8.52 kB
JavaScript
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