@element-plus/nightly 0.0.20231223 → 0.0.20231225
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.css +1 -1
- package/dist/index.full.js +2 -2
- package/dist/index.full.min.js +2 -2
- package/dist/index.full.min.js.map +1 -1
- package/dist/index.full.min.mjs +2 -2
- package/dist/index.full.min.mjs.map +1 -1
- package/dist/index.full.mjs +2 -2
- package/dist/locale/af.js +1 -1
- package/dist/locale/af.min.js +1 -1
- package/dist/locale/af.min.mjs +1 -1
- package/dist/locale/af.mjs +1 -1
- package/dist/locale/ar-eg.js +1 -1
- package/dist/locale/ar-eg.min.js +1 -1
- package/dist/locale/ar-eg.min.mjs +1 -1
- package/dist/locale/ar-eg.mjs +1 -1
- package/dist/locale/ar.js +1 -1
- package/dist/locale/ar.min.js +1 -1
- package/dist/locale/ar.min.mjs +1 -1
- package/dist/locale/ar.mjs +1 -1
- package/dist/locale/az.js +1 -1
- package/dist/locale/az.min.js +1 -1
- package/dist/locale/az.min.mjs +1 -1
- package/dist/locale/az.mjs +1 -1
- package/dist/locale/bg.js +1 -1
- package/dist/locale/bg.min.js +1 -1
- package/dist/locale/bg.min.mjs +1 -1
- package/dist/locale/bg.mjs +1 -1
- package/dist/locale/bn.js +1 -1
- package/dist/locale/bn.min.js +1 -1
- package/dist/locale/bn.min.mjs +1 -1
- package/dist/locale/bn.mjs +1 -1
- package/dist/locale/ca.js +1 -1
- package/dist/locale/ca.min.js +1 -1
- package/dist/locale/ca.min.mjs +1 -1
- package/dist/locale/ca.mjs +1 -1
- package/dist/locale/ckb.js +1 -1
- package/dist/locale/ckb.min.js +1 -1
- package/dist/locale/ckb.min.mjs +1 -1
- package/dist/locale/ckb.mjs +1 -1
- package/dist/locale/cs.js +1 -1
- package/dist/locale/cs.min.js +1 -1
- package/dist/locale/cs.min.mjs +1 -1
- package/dist/locale/cs.mjs +1 -1
- package/dist/locale/da.js +1 -1
- package/dist/locale/da.min.js +1 -1
- package/dist/locale/da.min.mjs +1 -1
- package/dist/locale/da.mjs +1 -1
- package/dist/locale/de.js +1 -1
- package/dist/locale/de.min.js +1 -1
- package/dist/locale/de.min.mjs +1 -1
- package/dist/locale/de.mjs +1 -1
- package/dist/locale/el.js +1 -1
- package/dist/locale/el.min.js +1 -1
- package/dist/locale/el.min.mjs +1 -1
- package/dist/locale/el.mjs +1 -1
- package/dist/locale/en.js +1 -1
- package/dist/locale/en.min.js +1 -1
- package/dist/locale/en.min.mjs +1 -1
- package/dist/locale/en.mjs +1 -1
- package/dist/locale/eo.js +1 -1
- package/dist/locale/eo.min.js +1 -1
- package/dist/locale/eo.min.mjs +1 -1
- package/dist/locale/eo.mjs +1 -1
- package/dist/locale/es.js +1 -1
- package/dist/locale/es.min.js +1 -1
- package/dist/locale/es.min.mjs +1 -1
- package/dist/locale/es.mjs +1 -1
- package/dist/locale/et.js +1 -1
- package/dist/locale/et.min.js +1 -1
- package/dist/locale/et.min.mjs +1 -1
- package/dist/locale/et.mjs +1 -1
- package/dist/locale/eu.js +1 -1
- package/dist/locale/eu.min.js +1 -1
- package/dist/locale/eu.min.mjs +1 -1
- package/dist/locale/eu.mjs +1 -1
- package/dist/locale/fa.js +1 -1
- package/dist/locale/fa.min.js +1 -1
- package/dist/locale/fa.min.mjs +1 -1
- package/dist/locale/fa.mjs +1 -1
- package/dist/locale/fi.js +1 -1
- package/dist/locale/fi.min.js +1 -1
- package/dist/locale/fi.min.mjs +1 -1
- package/dist/locale/fi.mjs +1 -1
- package/dist/locale/fr.js +1 -1
- package/dist/locale/fr.min.js +1 -1
- package/dist/locale/fr.min.mjs +1 -1
- package/dist/locale/fr.mjs +1 -1
- package/dist/locale/he.js +1 -1
- package/dist/locale/he.min.js +1 -1
- package/dist/locale/he.min.mjs +1 -1
- package/dist/locale/he.mjs +1 -1
- package/dist/locale/hr.js +1 -1
- package/dist/locale/hr.min.js +1 -1
- package/dist/locale/hr.min.mjs +1 -1
- package/dist/locale/hr.mjs +1 -1
- package/dist/locale/hu.js +1 -1
- package/dist/locale/hu.min.js +1 -1
- package/dist/locale/hu.min.mjs +1 -1
- package/dist/locale/hu.mjs +1 -1
- package/dist/locale/hy-am.js +1 -1
- package/dist/locale/hy-am.min.js +1 -1
- package/dist/locale/hy-am.min.mjs +1 -1
- package/dist/locale/hy-am.mjs +1 -1
- package/dist/locale/id.js +1 -1
- package/dist/locale/id.min.js +1 -1
- package/dist/locale/id.min.mjs +1 -1
- package/dist/locale/id.mjs +1 -1
- package/dist/locale/it.js +1 -1
- package/dist/locale/it.min.js +1 -1
- package/dist/locale/it.min.mjs +1 -1
- package/dist/locale/it.mjs +1 -1
- package/dist/locale/ja.js +1 -1
- package/dist/locale/ja.min.js +1 -1
- package/dist/locale/ja.min.mjs +1 -1
- package/dist/locale/ja.mjs +1 -1
- package/dist/locale/kk.js +1 -1
- package/dist/locale/kk.min.js +1 -1
- package/dist/locale/kk.min.mjs +1 -1
- package/dist/locale/kk.mjs +1 -1
- package/dist/locale/km.js +1 -1
- package/dist/locale/km.min.js +1 -1
- package/dist/locale/km.min.mjs +1 -1
- package/dist/locale/km.mjs +1 -1
- package/dist/locale/ko.js +1 -1
- package/dist/locale/ko.min.js +1 -1
- package/dist/locale/ko.min.mjs +1 -1
- package/dist/locale/ko.mjs +1 -1
- package/dist/locale/ku.js +1 -1
- package/dist/locale/ku.min.js +1 -1
- package/dist/locale/ku.min.mjs +1 -1
- package/dist/locale/ku.mjs +1 -1
- package/dist/locale/ky.js +1 -1
- package/dist/locale/ky.min.js +1 -1
- package/dist/locale/ky.min.mjs +1 -1
- package/dist/locale/ky.mjs +1 -1
- package/dist/locale/lt.js +1 -1
- package/dist/locale/lt.min.js +1 -1
- package/dist/locale/lt.min.mjs +1 -1
- package/dist/locale/lt.mjs +1 -1
- package/dist/locale/lv.js +1 -1
- package/dist/locale/lv.min.js +1 -1
- package/dist/locale/lv.min.mjs +1 -1
- package/dist/locale/lv.mjs +1 -1
- package/dist/locale/mg.js +1 -1
- package/dist/locale/mg.min.js +1 -1
- package/dist/locale/mg.min.mjs +1 -1
- package/dist/locale/mg.mjs +1 -1
- package/dist/locale/mn.js +1 -1
- package/dist/locale/mn.min.js +1 -1
- package/dist/locale/mn.min.mjs +1 -1
- package/dist/locale/mn.mjs +1 -1
- package/dist/locale/nb-no.js +1 -1
- package/dist/locale/nb-no.min.js +1 -1
- package/dist/locale/nb-no.min.mjs +1 -1
- package/dist/locale/nb-no.mjs +1 -1
- package/dist/locale/nl.js +1 -1
- package/dist/locale/nl.min.js +1 -1
- package/dist/locale/nl.min.mjs +1 -1
- package/dist/locale/nl.mjs +1 -1
- package/dist/locale/pa.js +1 -1
- package/dist/locale/pa.min.js +1 -1
- package/dist/locale/pa.min.mjs +1 -1
- package/dist/locale/pa.mjs +1 -1
- package/dist/locale/pl.js +1 -1
- package/dist/locale/pl.min.js +1 -1
- package/dist/locale/pl.min.mjs +1 -1
- package/dist/locale/pl.mjs +1 -1
- package/dist/locale/pt-br.js +1 -1
- package/dist/locale/pt-br.min.js +1 -1
- package/dist/locale/pt-br.min.mjs +1 -1
- package/dist/locale/pt-br.mjs +1 -1
- package/dist/locale/pt.js +1 -1
- package/dist/locale/pt.min.js +1 -1
- package/dist/locale/pt.min.mjs +1 -1
- package/dist/locale/pt.mjs +1 -1
- package/dist/locale/ro.js +1 -1
- package/dist/locale/ro.min.js +1 -1
- package/dist/locale/ro.min.mjs +1 -1
- package/dist/locale/ro.mjs +1 -1
- package/dist/locale/ru.js +1 -1
- package/dist/locale/ru.min.js +1 -1
- package/dist/locale/ru.min.mjs +1 -1
- package/dist/locale/ru.mjs +1 -1
- package/dist/locale/sk.js +1 -1
- package/dist/locale/sk.min.js +1 -1
- package/dist/locale/sk.min.mjs +1 -1
- package/dist/locale/sk.mjs +1 -1
- package/dist/locale/sl.js +1 -1
- package/dist/locale/sl.min.js +1 -1
- package/dist/locale/sl.min.mjs +1 -1
- package/dist/locale/sl.mjs +1 -1
- package/dist/locale/sr.js +1 -1
- package/dist/locale/sr.min.js +1 -1
- package/dist/locale/sr.min.mjs +1 -1
- package/dist/locale/sr.mjs +1 -1
- package/dist/locale/sv.js +1 -1
- package/dist/locale/sv.min.js +1 -1
- package/dist/locale/sv.min.mjs +1 -1
- package/dist/locale/sv.mjs +1 -1
- package/dist/locale/sw.js +1 -1
- package/dist/locale/sw.min.js +1 -1
- package/dist/locale/sw.min.mjs +1 -1
- package/dist/locale/sw.mjs +1 -1
- package/dist/locale/ta.js +1 -1
- package/dist/locale/ta.min.js +1 -1
- package/dist/locale/ta.min.mjs +1 -1
- package/dist/locale/ta.mjs +1 -1
- package/dist/locale/th.js +1 -1
- package/dist/locale/th.min.js +1 -1
- package/dist/locale/th.min.mjs +1 -1
- package/dist/locale/th.mjs +1 -1
- package/dist/locale/tk.js +1 -1
- package/dist/locale/tk.min.js +1 -1
- package/dist/locale/tk.min.mjs +1 -1
- package/dist/locale/tk.mjs +1 -1
- package/dist/locale/tr.js +1 -1
- package/dist/locale/tr.min.js +1 -1
- package/dist/locale/tr.min.mjs +1 -1
- package/dist/locale/tr.mjs +1 -1
- package/dist/locale/ug-cn.js +1 -1
- package/dist/locale/ug-cn.min.js +1 -1
- package/dist/locale/ug-cn.min.mjs +1 -1
- package/dist/locale/ug-cn.mjs +1 -1
- package/dist/locale/uk.js +1 -1
- package/dist/locale/uk.min.js +1 -1
- package/dist/locale/uk.min.mjs +1 -1
- package/dist/locale/uk.mjs +1 -1
- package/dist/locale/uz-uz.js +1 -1
- package/dist/locale/uz-uz.min.js +1 -1
- package/dist/locale/uz-uz.min.mjs +1 -1
- package/dist/locale/uz-uz.mjs +1 -1
- package/dist/locale/vi.js +1 -1
- package/dist/locale/vi.min.js +1 -1
- package/dist/locale/vi.min.mjs +1 -1
- package/dist/locale/vi.mjs +1 -1
- package/dist/locale/zh-cn.js +1 -1
- package/dist/locale/zh-cn.min.js +1 -1
- package/dist/locale/zh-cn.min.mjs +1 -1
- package/dist/locale/zh-cn.mjs +1 -1
- package/dist/locale/zh-tw.js +1 -1
- package/dist/locale/zh-tw.min.js +1 -1
- package/dist/locale/zh-tw.min.mjs +1 -1
- package/dist/locale/zh-tw.mjs +1 -1
- package/es/components/alert/index.mjs +2 -2
- package/es/components/alert/src/alert.mjs +36 -96
- package/es/components/alert/src/alert.mjs.map +1 -1
- package/es/components/alert/src/alert2.mjs +96 -36
- package/es/components/alert/src/alert2.mjs.map +1 -1
- package/es/components/index.mjs +3 -3
- package/es/components/radio/index.mjs +2 -2
- package/es/components/radio/src/radio-button.mjs +66 -9
- package/es/components/radio/src/radio-button.mjs.map +1 -1
- package/es/components/radio/src/radio-button2.mjs +9 -66
- package/es/components/radio/src/radio-button2.mjs.map +1 -1
- package/es/components/upload/index.mjs +1 -1
- package/es/components/upload/src/upload-content.mjs +194 -33
- package/es/components/upload/src/upload-content.mjs.map +1 -1
- package/es/components/upload/src/upload-content2.mjs +33 -194
- package/es/components/upload/src/upload-content2.mjs.map +1 -1
- package/es/components/upload/src/upload2.mjs +1 -1
- package/es/index.mjs +3 -3
- package/es/version.d.ts +1 -1
- package/es/version.mjs +1 -1
- package/es/version.mjs.map +1 -1
- package/lib/components/alert/index.js +2 -2
- package/lib/components/alert/src/alert.js +37 -95
- package/lib/components/alert/src/alert.js.map +1 -1
- package/lib/components/alert/src/alert2.js +95 -37
- package/lib/components/alert/src/alert2.js.map +1 -1
- package/lib/components/index.js +3 -3
- package/lib/components/radio/index.js +2 -2
- package/lib/components/radio/src/radio-button.js +66 -9
- package/lib/components/radio/src/radio-button.js.map +1 -1
- package/lib/components/radio/src/radio-button2.js +9 -66
- package/lib/components/radio/src/radio-button2.js.map +1 -1
- package/lib/components/upload/index.js +1 -1
- package/lib/components/upload/src/upload-content.js +192 -31
- package/lib/components/upload/src/upload-content.js.map +1 -1
- package/lib/components/upload/src/upload-content2.js +31 -192
- package/lib/components/upload/src/upload-content2.js.map +1 -1
- package/lib/components/upload/src/upload2.js +1 -1
- package/lib/index.js +3 -3
- package/lib/version.d.ts +1 -1
- package/lib/version.js +1 -1
- package/lib/version.js.map +1 -1
- package/package.json +2 -2
- package/theme-chalk/el-col.css +1 -1
- package/theme-chalk/index.css +1 -1
- package/theme-chalk/src/common/var.scss +1 -1
- package/web-types.json +1 -1
|
@@ -1,42 +1,102 @@
|
|
|
1
|
+
import { defineComponent, useSlots, ref, computed, openBlock, createBlock, Transition, unref, withCtx, withDirectives, createElementVNode, normalizeClass, resolveDynamicComponent, createCommentVNode, createElementBlock, renderSlot, createTextVNode, toDisplayString, Fragment, createVNode, vShow } from 'vue';
|
|
2
|
+
import { ElIcon } from '../../icon/index.mjs';
|
|
1
3
|
import '../../../utils/index.mjs';
|
|
2
|
-
import
|
|
3
|
-
import {
|
|
4
|
-
import
|
|
4
|
+
import '../../../hooks/index.mjs';
|
|
5
|
+
import { alertProps, alertEmits } from './alert.mjs';
|
|
6
|
+
import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
|
|
7
|
+
import { TypeComponents, TypeComponentsMap } from '../../../utils/vue/icon.mjs';
|
|
8
|
+
import { useNamespace } from '../../../hooks/use-namespace/index.mjs';
|
|
5
9
|
|
|
6
|
-
const
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
10
|
+
const __default__ = defineComponent({
|
|
11
|
+
name: "ElAlert"
|
|
12
|
+
});
|
|
13
|
+
const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
14
|
+
...__default__,
|
|
15
|
+
props: alertProps,
|
|
16
|
+
emits: alertEmits,
|
|
17
|
+
setup(__props, { emit }) {
|
|
18
|
+
const props = __props;
|
|
19
|
+
const { Close } = TypeComponents;
|
|
20
|
+
const slots = useSlots();
|
|
21
|
+
const ns = useNamespace("alert");
|
|
22
|
+
const visible = ref(true);
|
|
23
|
+
const iconComponent = computed(() => TypeComponentsMap[props.type]);
|
|
24
|
+
const iconClass = computed(() => [
|
|
25
|
+
ns.e("icon"),
|
|
26
|
+
{ [ns.is("big")]: !!props.description || !!slots.default }
|
|
27
|
+
]);
|
|
28
|
+
const isBoldTitle = computed(() => {
|
|
29
|
+
return { [ns.is("bold")]: props.description || slots.default };
|
|
30
|
+
});
|
|
31
|
+
const close = (evt) => {
|
|
32
|
+
visible.value = false;
|
|
33
|
+
emit("close", evt);
|
|
34
|
+
};
|
|
35
|
+
return (_ctx, _cache) => {
|
|
36
|
+
return openBlock(), createBlock(Transition, {
|
|
37
|
+
name: unref(ns).b("fade"),
|
|
38
|
+
persisted: ""
|
|
39
|
+
}, {
|
|
40
|
+
default: withCtx(() => [
|
|
41
|
+
withDirectives(createElementVNode("div", {
|
|
42
|
+
class: normalizeClass([unref(ns).b(), unref(ns).m(_ctx.type), unref(ns).is("center", _ctx.center), unref(ns).is(_ctx.effect)]),
|
|
43
|
+
role: "alert"
|
|
44
|
+
}, [
|
|
45
|
+
_ctx.showIcon && unref(iconComponent) ? (openBlock(), createBlock(unref(ElIcon), {
|
|
46
|
+
key: 0,
|
|
47
|
+
class: normalizeClass(unref(iconClass))
|
|
48
|
+
}, {
|
|
49
|
+
default: withCtx(() => [
|
|
50
|
+
(openBlock(), createBlock(resolveDynamicComponent(unref(iconComponent))))
|
|
51
|
+
]),
|
|
52
|
+
_: 1
|
|
53
|
+
}, 8, ["class"])) : createCommentVNode("v-if", true),
|
|
54
|
+
createElementVNode("div", {
|
|
55
|
+
class: normalizeClass(unref(ns).e("content"))
|
|
56
|
+
}, [
|
|
57
|
+
_ctx.title || _ctx.$slots.title ? (openBlock(), createElementBlock("span", {
|
|
58
|
+
key: 0,
|
|
59
|
+
class: normalizeClass([unref(ns).e("title"), unref(isBoldTitle)])
|
|
60
|
+
}, [
|
|
61
|
+
renderSlot(_ctx.$slots, "title", {}, () => [
|
|
62
|
+
createTextVNode(toDisplayString(_ctx.title), 1)
|
|
63
|
+
])
|
|
64
|
+
], 2)) : createCommentVNode("v-if", true),
|
|
65
|
+
_ctx.$slots.default || _ctx.description ? (openBlock(), createElementBlock("p", {
|
|
66
|
+
key: 1,
|
|
67
|
+
class: normalizeClass(unref(ns).e("description"))
|
|
68
|
+
}, [
|
|
69
|
+
renderSlot(_ctx.$slots, "default", {}, () => [
|
|
70
|
+
createTextVNode(toDisplayString(_ctx.description), 1)
|
|
71
|
+
])
|
|
72
|
+
], 2)) : createCommentVNode("v-if", true),
|
|
73
|
+
_ctx.closable ? (openBlock(), createElementBlock(Fragment, { key: 2 }, [
|
|
74
|
+
_ctx.closeText ? (openBlock(), createElementBlock("div", {
|
|
75
|
+
key: 0,
|
|
76
|
+
class: normalizeClass([unref(ns).e("close-btn"), unref(ns).is("customed")]),
|
|
77
|
+
onClick: close
|
|
78
|
+
}, toDisplayString(_ctx.closeText), 3)) : (openBlock(), createBlock(unref(ElIcon), {
|
|
79
|
+
key: 1,
|
|
80
|
+
class: normalizeClass(unref(ns).e("close-btn")),
|
|
81
|
+
onClick: close
|
|
82
|
+
}, {
|
|
83
|
+
default: withCtx(() => [
|
|
84
|
+
createVNode(unref(Close))
|
|
85
|
+
]),
|
|
86
|
+
_: 1
|
|
87
|
+
}, 8, ["class"]))
|
|
88
|
+
], 64)) : createCommentVNode("v-if", true)
|
|
89
|
+
], 2)
|
|
90
|
+
], 2), [
|
|
91
|
+
[vShow, visible.value]
|
|
92
|
+
])
|
|
93
|
+
]),
|
|
94
|
+
_: 3
|
|
95
|
+
}, 8, ["name"]);
|
|
96
|
+
};
|
|
35
97
|
}
|
|
36
98
|
});
|
|
37
|
-
|
|
38
|
-
close: (evt) => evt instanceof MouseEvent
|
|
39
|
-
};
|
|
99
|
+
var Alert = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "alert.vue"]]);
|
|
40
100
|
|
|
41
|
-
export {
|
|
101
|
+
export { Alert as default };
|
|
42
102
|
//# sourceMappingURL=alert2.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"alert2.mjs","sources":["../../../../../../packages/components/alert/src/alert.
|
|
1
|
+
{"version":3,"file":"alert2.mjs","sources":["../../../../../../packages/components/alert/src/alert.vue"],"sourcesContent":["<template>\n <transition :name=\"ns.b('fade')\">\n <div\n v-show=\"visible\"\n :class=\"[ns.b(), ns.m(type), ns.is('center', center), ns.is(effect)]\"\n role=\"alert\"\n >\n <el-icon v-if=\"showIcon && iconComponent\" :class=\"iconClass\">\n <component :is=\"iconComponent\" />\n </el-icon>\n\n <div :class=\"ns.e('content')\">\n <span\n v-if=\"title || $slots.title\"\n :class=\"[ns.e('title'), isBoldTitle]\"\n >\n <slot name=\"title\">{{ title }}</slot>\n </span>\n <p v-if=\"$slots.default || description\" :class=\"ns.e('description')\">\n <slot>\n {{ description }}\n </slot>\n </p>\n <template v-if=\"closable\">\n <div\n v-if=\"closeText\"\n :class=\"[ns.e('close-btn'), ns.is('customed')]\"\n @click=\"close\"\n >\n {{ closeText }}\n </div>\n <el-icon v-else :class=\"ns.e('close-btn')\" @click=\"close\">\n <Close />\n </el-icon>\n </template>\n </div>\n </div>\n </transition>\n</template>\n<script lang=\"ts\" setup>\nimport { computed, ref, useSlots } from 'vue'\nimport { ElIcon } from '@element-plus/components/icon'\nimport { TypeComponents, TypeComponentsMap } from '@element-plus/utils'\nimport { useNamespace } from '@element-plus/hooks'\nimport { alertEmits, alertProps } from './alert'\n\nconst { Close } = TypeComponents\n\ndefineOptions({\n name: 'ElAlert',\n})\n\nconst props = defineProps(alertProps)\nconst emit = defineEmits(alertEmits)\nconst slots = useSlots()\n\nconst ns = useNamespace('alert')\n\nconst visible = ref(true)\n\nconst iconComponent = computed(() => TypeComponentsMap[props.type])\n\nconst iconClass = computed(() => [\n ns.e('icon'),\n { [ns.is('big')]: !!props.description || !!slots.default },\n])\n\nconst isBoldTitle = computed(() => {\n return { [ns.is('bold')]: props.description || slots.default }\n})\n\nconst close = (evt: MouseEvent) => {\n visible.value = false\n emit('close', evt)\n}\n</script>\n"],"names":[],"mappings":";;;;;;;;;mCAgDc,CAAA;AAAA,EACZ,IAAM,EAAA,SAAA;AACR,CAAA,CAAA,CAAA;;;;;;;AAJA,IAAA,MAAM,EAAE,KAAU,EAAA,GAAA,cAAA,CAAA;AAQlB,IAAA,MAAM,QAAQ,QAAS,EAAA,CAAA;AAEvB,IAAM,MAAA,EAAA,GAAK,aAAa,OAAO,CAAA,CAAA;AAE/B,IAAM,MAAA,OAAA,GAAU,IAAI,IAAI,CAAA,CAAA;AAExB,IAAA,MAAM,aAAgB,GAAA,QAAA,CAAS,MAAM,iBAAA,CAAkB,MAAM,IAAK,CAAA,CAAA,CAAA;AAElE,IAAM,MAAA,SAAA,GAAY,SAAS,MAAM;AAAA,MAC/B,EAAA,CAAG,EAAE,MAAM,CAAA;AAAA,MACX,EAAE,CAAC,EAAG,CAAA,EAAA,CAAG,KAAK,CAAA,GAAI,CAAC,CAAC,KAAM,CAAA,WAAA,IAAe,CAAC,CAAC,MAAM,OAAQ,EAAA;AAAA,KAC1D,CAAA,CAAA;AAED,IAAM,MAAA,WAAA,GAAc,SAAS,MAAM;AACjC,MAAO,OAAA,EAAE,CAAC,EAAG,CAAA,EAAA,CAAG,MAAM,CAAI,GAAA,KAAA,CAAM,WAAe,IAAA,KAAA,CAAM,OAAQ,EAAA,CAAA;AAAA,KAC9D,CAAA,CAAA;AAED,IAAM,MAAA,KAAA,GAAQ,CAAC,GAAoB,KAAA;AACjC,MAAA,OAAA,CAAQ,KAAQ,GAAA,KAAA,CAAA;AAChB,MAAA,IAAA,CAAK,SAAS,GAAG,CAAA,CAAA;AAAA,KACnB,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|
package/es/components/index.mjs
CHANGED
|
@@ -77,7 +77,7 @@ export { ElMessageBox } from './message-box/index.mjs';
|
|
|
77
77
|
export { ElNotification } from './notification/index.mjs';
|
|
78
78
|
export { ElPopover, ElPopoverDirective } from './popover/index.mjs';
|
|
79
79
|
export { affixEmits, affixProps } from './affix/src/affix.mjs';
|
|
80
|
-
export { alertEffects, alertEmits, alertProps } from './alert/src/
|
|
80
|
+
export { alertEffects, alertEmits, alertProps } from './alert/src/alert.mjs';
|
|
81
81
|
export { autocompleteEmits, autocompleteProps } from './autocomplete/src/autocomplete.mjs';
|
|
82
82
|
export { avatarEmits, avatarProps } from './avatar/src/avatar.mjs';
|
|
83
83
|
export { backtopEmits, backtopProps } from './backtop/src/backtop.mjs';
|
|
@@ -151,7 +151,7 @@ export { default as ElPopperContent } from './popper/src/content2.mjs';
|
|
|
151
151
|
export { progressProps } from './progress/src/progress.mjs';
|
|
152
152
|
export { radioEmits, radioProps, radioPropsBase } from './radio/src/radio.mjs';
|
|
153
153
|
export { radioGroupEmits, radioGroupProps } from './radio/src/radio-group.mjs';
|
|
154
|
-
export { radioButtonProps } from './radio/src/radio-
|
|
154
|
+
export { radioButtonProps } from './radio/src/radio-button2.mjs';
|
|
155
155
|
export { radioGroupKey } from './radio/src/constants.mjs';
|
|
156
156
|
export { rateEmits, rateProps } from './rate/src/rate.mjs';
|
|
157
157
|
export { IconComponentMap, IconMap, resultProps } from './result/src/result.mjs';
|
|
@@ -198,7 +198,7 @@ export { useTooltipContentProps } from './tooltip/src/content.mjs';
|
|
|
198
198
|
export { TOOLTIP_INJECTION_KEY } from './tooltip/src/constants.mjs';
|
|
199
199
|
export { LEFT_CHECK_CHANGE_EVENT, RIGHT_CHECK_CHANGE_EVENT, transferCheckedChangeFn, transferEmits, transferProps } from './transfer/src/transfer.mjs';
|
|
200
200
|
export { genFileId, uploadBaseProps, uploadListTypes, uploadProps } from './upload/src/upload.mjs';
|
|
201
|
-
export { uploadContentProps } from './upload/src/upload-
|
|
201
|
+
export { uploadContentProps } from './upload/src/upload-content2.mjs';
|
|
202
202
|
export { uploadListEmits, uploadListProps } from './upload/src/upload-list.mjs';
|
|
203
203
|
export { uploadDraggerEmits, uploadDraggerProps } from './upload/src/upload-dragger.mjs';
|
|
204
204
|
export { uploadContextKey } from './upload/src/constants.mjs';
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import '../../utils/index.mjs';
|
|
2
2
|
import Radio from './src/radio2.mjs';
|
|
3
|
-
import RadioButton from './src/radio-
|
|
3
|
+
import RadioButton from './src/radio-button.mjs';
|
|
4
4
|
import RadioGroup from './src/radio-group2.mjs';
|
|
5
5
|
export { radioEmits, radioProps, radioPropsBase } from './src/radio.mjs';
|
|
6
6
|
export { radioGroupEmits, radioGroupProps } from './src/radio-group.mjs';
|
|
7
|
-
export { radioButtonProps } from './src/radio-
|
|
7
|
+
export { radioButtonProps } from './src/radio-button2.mjs';
|
|
8
8
|
export { radioGroupKey } from './src/constants.mjs';
|
|
9
9
|
import { withInstall, withNoopInstall } from '../../utils/vue/install.mjs';
|
|
10
10
|
|
|
@@ -1,14 +1,71 @@
|
|
|
1
|
-
import '
|
|
2
|
-
import
|
|
3
|
-
import {
|
|
1
|
+
import { defineComponent, computed, openBlock, createElementBlock, normalizeClass, unref, withDirectives, createElementVNode, isRef, withModifiers, vModelRadio, normalizeStyle, renderSlot, createTextVNode, toDisplayString } from 'vue';
|
|
2
|
+
import '../../../hooks/index.mjs';
|
|
3
|
+
import { useRadio } from './use-radio.mjs';
|
|
4
|
+
import { radioButtonProps } from './radio-button2.mjs';
|
|
5
|
+
import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
|
|
6
|
+
import { useNamespace } from '../../../hooks/use-namespace/index.mjs';
|
|
4
7
|
|
|
5
|
-
const
|
|
6
|
-
|
|
7
|
-
name:
|
|
8
|
-
|
|
9
|
-
|
|
8
|
+
const _hoisted_1 = ["value", "name", "disabled"];
|
|
9
|
+
const __default__ = defineComponent({
|
|
10
|
+
name: "ElRadioButton"
|
|
11
|
+
});
|
|
12
|
+
const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
13
|
+
...__default__,
|
|
14
|
+
props: radioButtonProps,
|
|
15
|
+
setup(__props) {
|
|
16
|
+
const props = __props;
|
|
17
|
+
const ns = useNamespace("radio");
|
|
18
|
+
const { radioRef, focus, size, disabled, modelValue, radioGroup } = useRadio(props);
|
|
19
|
+
const activeStyle = computed(() => {
|
|
20
|
+
return {
|
|
21
|
+
backgroundColor: (radioGroup == null ? void 0 : radioGroup.fill) || "",
|
|
22
|
+
borderColor: (radioGroup == null ? void 0 : radioGroup.fill) || "",
|
|
23
|
+
boxShadow: (radioGroup == null ? void 0 : radioGroup.fill) ? `-1px 0 0 0 ${radioGroup.fill}` : "",
|
|
24
|
+
color: (radioGroup == null ? void 0 : radioGroup.textColor) || ""
|
|
25
|
+
};
|
|
26
|
+
});
|
|
27
|
+
return (_ctx, _cache) => {
|
|
28
|
+
var _a;
|
|
29
|
+
return openBlock(), createElementBlock("label", {
|
|
30
|
+
class: normalizeClass([
|
|
31
|
+
unref(ns).b("button"),
|
|
32
|
+
unref(ns).is("active", unref(modelValue) === _ctx.label),
|
|
33
|
+
unref(ns).is("disabled", unref(disabled)),
|
|
34
|
+
unref(ns).is("focus", unref(focus)),
|
|
35
|
+
unref(ns).bm("button", unref(size))
|
|
36
|
+
])
|
|
37
|
+
}, [
|
|
38
|
+
withDirectives(createElementVNode("input", {
|
|
39
|
+
ref_key: "radioRef",
|
|
40
|
+
ref: radioRef,
|
|
41
|
+
"onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => isRef(modelValue) ? modelValue.value = $event : null),
|
|
42
|
+
class: normalizeClass(unref(ns).be("button", "original-radio")),
|
|
43
|
+
value: _ctx.label,
|
|
44
|
+
type: "radio",
|
|
45
|
+
name: _ctx.name || ((_a = unref(radioGroup)) == null ? void 0 : _a.name),
|
|
46
|
+
disabled: unref(disabled),
|
|
47
|
+
onFocus: _cache[1] || (_cache[1] = ($event) => focus.value = true),
|
|
48
|
+
onBlur: _cache[2] || (_cache[2] = ($event) => focus.value = false),
|
|
49
|
+
onClick: _cache[3] || (_cache[3] = withModifiers(() => {
|
|
50
|
+
}, ["stop"]))
|
|
51
|
+
}, null, 42, _hoisted_1), [
|
|
52
|
+
[vModelRadio, unref(modelValue)]
|
|
53
|
+
]),
|
|
54
|
+
createElementVNode("span", {
|
|
55
|
+
class: normalizeClass(unref(ns).be("button", "inner")),
|
|
56
|
+
style: normalizeStyle(unref(modelValue) === _ctx.label ? unref(activeStyle) : {}),
|
|
57
|
+
onKeydown: _cache[4] || (_cache[4] = withModifiers(() => {
|
|
58
|
+
}, ["stop"]))
|
|
59
|
+
}, [
|
|
60
|
+
renderSlot(_ctx.$slots, "default", {}, () => [
|
|
61
|
+
createTextVNode(toDisplayString(_ctx.label), 1)
|
|
62
|
+
])
|
|
63
|
+
], 38)
|
|
64
|
+
], 2);
|
|
65
|
+
};
|
|
10
66
|
}
|
|
11
67
|
});
|
|
68
|
+
var RadioButton = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "radio-button.vue"]]);
|
|
12
69
|
|
|
13
|
-
export {
|
|
70
|
+
export { RadioButton as default };
|
|
14
71
|
//# sourceMappingURL=radio-button.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"radio-button.mjs","sources":["../../../../../../packages/components/radio/src/radio-button.
|
|
1
|
+
{"version":3,"file":"radio-button.mjs","sources":["../../../../../../packages/components/radio/src/radio-button.vue"],"sourcesContent":["<template>\n <label\n :class=\"[\n ns.b('button'),\n ns.is('active', modelValue === label),\n ns.is('disabled', disabled),\n ns.is('focus', focus),\n ns.bm('button', size),\n ]\"\n >\n <input\n ref=\"radioRef\"\n v-model=\"modelValue\"\n :class=\"ns.be('button', 'original-radio')\"\n :value=\"label\"\n type=\"radio\"\n :name=\"name || radioGroup?.name\"\n :disabled=\"disabled\"\n @focus=\"focus = true\"\n @blur=\"focus = false\"\n @click.stop\n />\n <span\n :class=\"ns.be('button', 'inner')\"\n :style=\"modelValue === label ? activeStyle : {}\"\n @keydown.stop\n >\n <slot>\n {{ label }}\n </slot>\n </span>\n </label>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed } from 'vue'\nimport { useNamespace } from '@element-plus/hooks'\nimport { useRadio } from './use-radio'\nimport { radioButtonProps } from './radio-button'\nimport type { CSSProperties } from 'vue'\n\ndefineOptions({\n name: 'ElRadioButton',\n})\n\nconst props = defineProps(radioButtonProps)\n\nconst ns = useNamespace('radio')\nconst { radioRef, focus, size, disabled, modelValue, radioGroup } =\n useRadio(props)\n\nconst activeStyle = computed<CSSProperties>(() => {\n return {\n backgroundColor: radioGroup?.fill || '',\n borderColor: radioGroup?.fill || '',\n boxShadow: radioGroup?.fill ? `-1px 0 0 0 ${radioGroup.fill}` : '',\n color: radioGroup?.textColor || '',\n }\n})\n</script>\n"],"names":[],"mappings":";;;;;;;;mCAyCc,CAAA;AAAA,EACZ,IAAM,EAAA,eAAA;AACR,CAAA,CAAA,CAAA;;;;;;AAIA,IAAM,MAAA,EAAA,GAAK,aAAa,OAAO,CAAA,CAAA;AAC/B,IAAM,MAAA,EAAE,UAAU,KAAO,EAAA,IAAA,EAAM,UAAU,UAAY,EAAA,UAAA,EAAA,GACnD,SAAS,KAAK,CAAA,CAAA;AAEhB,IAAM,MAAA,WAAA,GAAc,SAAwB,MAAM;AAChD,MAAO,OAAA;AAAA,QACL,eAAA,EAAiB,eAAoB,IAAA,GAAA,KAAA,CAAA,GAAA,UAAA,CAAA,IAAA,KAAA,EAAA;AAAA,QACrC,WAAA,EAAa,eAAoB,IAAA,GAAA,KAAA,CAAA,GAAA,UAAA,CAAA,IAAA,KAAA,EAAA;AAAA,QACjC,SAAW,EAAA,CAAA,UAAA,IAAmB,IAAA,GAAA,KAAA,CAAA,GAAA,eAAkC,IAAA,CAAA,WAAA,EAAA,UAAA,CAAA,IAAA,CAAA,CAAA,GAAA,EAAA;AAAA,QAChE,KAAA,EAAO,eAAyB,IAAA,GAAA,KAAA,CAAA,GAAA,UAAA,CAAA,SAAA,KAAA,EAAA;AAAA,OAClC,CAAA;AAAA,KACD,CAAA,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|
|
@@ -1,71 +1,14 @@
|
|
|
1
|
-
import
|
|
2
|
-
import '
|
|
3
|
-
import {
|
|
4
|
-
import { radioButtonProps } from './radio-button.mjs';
|
|
5
|
-
import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
|
|
6
|
-
import { useNamespace } from '../../../hooks/use-namespace/index.mjs';
|
|
1
|
+
import '../../../utils/index.mjs';
|
|
2
|
+
import { radioPropsBase } from './radio.mjs';
|
|
3
|
+
import { buildProps } from '../../../utils/vue/props/runtime.mjs';
|
|
7
4
|
|
|
8
|
-
const
|
|
9
|
-
|
|
10
|
-
name:
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
...__default__,
|
|
14
|
-
props: radioButtonProps,
|
|
15
|
-
setup(__props) {
|
|
16
|
-
const props = __props;
|
|
17
|
-
const ns = useNamespace("radio");
|
|
18
|
-
const { radioRef, focus, size, disabled, modelValue, radioGroup } = useRadio(props);
|
|
19
|
-
const activeStyle = computed(() => {
|
|
20
|
-
return {
|
|
21
|
-
backgroundColor: (radioGroup == null ? void 0 : radioGroup.fill) || "",
|
|
22
|
-
borderColor: (radioGroup == null ? void 0 : radioGroup.fill) || "",
|
|
23
|
-
boxShadow: (radioGroup == null ? void 0 : radioGroup.fill) ? `-1px 0 0 0 ${radioGroup.fill}` : "",
|
|
24
|
-
color: (radioGroup == null ? void 0 : radioGroup.textColor) || ""
|
|
25
|
-
};
|
|
26
|
-
});
|
|
27
|
-
return (_ctx, _cache) => {
|
|
28
|
-
var _a;
|
|
29
|
-
return openBlock(), createElementBlock("label", {
|
|
30
|
-
class: normalizeClass([
|
|
31
|
-
unref(ns).b("button"),
|
|
32
|
-
unref(ns).is("active", unref(modelValue) === _ctx.label),
|
|
33
|
-
unref(ns).is("disabled", unref(disabled)),
|
|
34
|
-
unref(ns).is("focus", unref(focus)),
|
|
35
|
-
unref(ns).bm("button", unref(size))
|
|
36
|
-
])
|
|
37
|
-
}, [
|
|
38
|
-
withDirectives(createElementVNode("input", {
|
|
39
|
-
ref_key: "radioRef",
|
|
40
|
-
ref: radioRef,
|
|
41
|
-
"onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => isRef(modelValue) ? modelValue.value = $event : null),
|
|
42
|
-
class: normalizeClass(unref(ns).be("button", "original-radio")),
|
|
43
|
-
value: _ctx.label,
|
|
44
|
-
type: "radio",
|
|
45
|
-
name: _ctx.name || ((_a = unref(radioGroup)) == null ? void 0 : _a.name),
|
|
46
|
-
disabled: unref(disabled),
|
|
47
|
-
onFocus: _cache[1] || (_cache[1] = ($event) => focus.value = true),
|
|
48
|
-
onBlur: _cache[2] || (_cache[2] = ($event) => focus.value = false),
|
|
49
|
-
onClick: _cache[3] || (_cache[3] = withModifiers(() => {
|
|
50
|
-
}, ["stop"]))
|
|
51
|
-
}, null, 42, _hoisted_1), [
|
|
52
|
-
[vModelRadio, unref(modelValue)]
|
|
53
|
-
]),
|
|
54
|
-
createElementVNode("span", {
|
|
55
|
-
class: normalizeClass(unref(ns).be("button", "inner")),
|
|
56
|
-
style: normalizeStyle(unref(modelValue) === _ctx.label ? unref(activeStyle) : {}),
|
|
57
|
-
onKeydown: _cache[4] || (_cache[4] = withModifiers(() => {
|
|
58
|
-
}, ["stop"]))
|
|
59
|
-
}, [
|
|
60
|
-
renderSlot(_ctx.$slots, "default", {}, () => [
|
|
61
|
-
createTextVNode(toDisplayString(_ctx.label), 1)
|
|
62
|
-
])
|
|
63
|
-
], 38)
|
|
64
|
-
], 2);
|
|
65
|
-
};
|
|
5
|
+
const radioButtonProps = buildProps({
|
|
6
|
+
...radioPropsBase,
|
|
7
|
+
name: {
|
|
8
|
+
type: String,
|
|
9
|
+
default: ""
|
|
66
10
|
}
|
|
67
11
|
});
|
|
68
|
-
var RadioButton = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "radio-button.vue"]]);
|
|
69
12
|
|
|
70
|
-
export {
|
|
13
|
+
export { radioButtonProps };
|
|
71
14
|
//# sourceMappingURL=radio-button2.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"radio-button2.mjs","sources":["../../../../../../packages/components/radio/src/radio-button.
|
|
1
|
+
{"version":3,"file":"radio-button2.mjs","sources":["../../../../../../packages/components/radio/src/radio-button.ts"],"sourcesContent":["import { buildProps } from '@element-plus/utils'\nimport { radioPropsBase } from './radio'\nimport type { ExtractPropTypes } from 'vue'\nimport type RadioButton from './radio-button.vue'\n\nexport const radioButtonProps = buildProps({\n ...radioPropsBase,\n /**\n * @description native 'name' attribute\n */\n name: {\n type: String,\n default: '',\n },\n} as const)\n\nexport type RadioButtonProps = ExtractPropTypes<typeof radioButtonProps>\nexport type RadioButtonInstance = InstanceType<typeof RadioButton>\n"],"names":[],"mappings":";;;;AAEY,MAAC,gBAAgB,GAAG,UAAU,CAAC;AAC3C,EAAE,GAAG,cAAc;AACnB,EAAE,IAAI,EAAE;AACR,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,CAAC;;;;"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import '../../utils/index.mjs';
|
|
2
2
|
import Upload from './src/upload2.mjs';
|
|
3
3
|
export { genFileId, uploadBaseProps, uploadListTypes, uploadProps } from './src/upload.mjs';
|
|
4
|
-
export { uploadContentProps } from './src/upload-
|
|
4
|
+
export { uploadContentProps } from './src/upload-content2.mjs';
|
|
5
5
|
export { uploadListEmits, uploadListProps } from './src/upload-list.mjs';
|
|
6
6
|
export { uploadDraggerEmits, uploadDraggerProps } from './src/upload-dragger.mjs';
|
|
7
7
|
export { uploadContextKey } from './src/constants.mjs';
|
|
@@ -1,39 +1,200 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { defineComponent, shallowRef, openBlock, createElementBlock, normalizeClass, unref, withKeys, withModifiers, createBlock, withCtx, renderSlot, createElementVNode } from 'vue';
|
|
2
|
+
import { isPlainObject, isFunction } from '@vue/shared';
|
|
3
|
+
import { cloneDeep, isEqual } from 'lodash-unified';
|
|
4
|
+
import '../../../hooks/index.mjs';
|
|
2
5
|
import '../../../utils/index.mjs';
|
|
3
|
-
import
|
|
4
|
-
import
|
|
6
|
+
import '../../form/index.mjs';
|
|
7
|
+
import UploadDragger from './upload-dragger2.mjs';
|
|
8
|
+
import { uploadContentProps } from './upload-content2.mjs';
|
|
9
|
+
import { genFileId } from './upload.mjs';
|
|
10
|
+
import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
|
|
11
|
+
import { useNamespace } from '../../../hooks/use-namespace/index.mjs';
|
|
12
|
+
import { useFormDisabled } from '../../form/src/hooks/use-form-common-props.mjs';
|
|
13
|
+
import { entriesOf } from '../../../utils/objects.mjs';
|
|
5
14
|
|
|
6
|
-
const
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
15
|
+
const _hoisted_1 = ["onKeydown"];
|
|
16
|
+
const _hoisted_2 = ["name", "multiple", "accept"];
|
|
17
|
+
const __default__ = defineComponent({
|
|
18
|
+
name: "ElUploadContent",
|
|
19
|
+
inheritAttrs: false
|
|
20
|
+
});
|
|
21
|
+
const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
22
|
+
...__default__,
|
|
23
|
+
props: uploadContentProps,
|
|
24
|
+
setup(__props, { expose }) {
|
|
25
|
+
const props = __props;
|
|
26
|
+
const ns = useNamespace("upload");
|
|
27
|
+
const disabled = useFormDisabled();
|
|
28
|
+
const requests = shallowRef({});
|
|
29
|
+
const inputRef = shallowRef();
|
|
30
|
+
const uploadFiles = (files) => {
|
|
31
|
+
if (files.length === 0)
|
|
32
|
+
return;
|
|
33
|
+
const { autoUpload, limit, fileList, multiple, onStart, onExceed } = props;
|
|
34
|
+
if (limit && fileList.length + files.length > limit) {
|
|
35
|
+
onExceed(files, fileList);
|
|
36
|
+
return;
|
|
37
|
+
}
|
|
38
|
+
if (!multiple) {
|
|
39
|
+
files = files.slice(0, 1);
|
|
40
|
+
}
|
|
41
|
+
for (const file of files) {
|
|
42
|
+
const rawFile = file;
|
|
43
|
+
rawFile.uid = genFileId();
|
|
44
|
+
onStart(rawFile);
|
|
45
|
+
if (autoUpload)
|
|
46
|
+
upload(rawFile);
|
|
47
|
+
}
|
|
48
|
+
};
|
|
49
|
+
const upload = async (rawFile) => {
|
|
50
|
+
inputRef.value.value = "";
|
|
51
|
+
if (!props.beforeUpload) {
|
|
52
|
+
return doUpload(rawFile);
|
|
53
|
+
}
|
|
54
|
+
let hookResult;
|
|
55
|
+
let beforeData = {};
|
|
56
|
+
try {
|
|
57
|
+
const originData = props.data;
|
|
58
|
+
const beforeUploadPromise = props.beforeUpload(rawFile);
|
|
59
|
+
beforeData = isPlainObject(props.data) ? cloneDeep(props.data) : props.data;
|
|
60
|
+
hookResult = await beforeUploadPromise;
|
|
61
|
+
if (isPlainObject(props.data) && isEqual(originData, beforeData)) {
|
|
62
|
+
beforeData = cloneDeep(props.data);
|
|
63
|
+
}
|
|
64
|
+
} catch (e) {
|
|
65
|
+
hookResult = false;
|
|
66
|
+
}
|
|
67
|
+
if (hookResult === false) {
|
|
68
|
+
props.onRemove(rawFile);
|
|
69
|
+
return;
|
|
70
|
+
}
|
|
71
|
+
let file = rawFile;
|
|
72
|
+
if (hookResult instanceof Blob) {
|
|
73
|
+
if (hookResult instanceof File) {
|
|
74
|
+
file = hookResult;
|
|
75
|
+
} else {
|
|
76
|
+
file = new File([hookResult], rawFile.name, {
|
|
77
|
+
type: rawFile.type
|
|
78
|
+
});
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
doUpload(Object.assign(file, {
|
|
82
|
+
uid: rawFile.uid
|
|
83
|
+
}), beforeData);
|
|
84
|
+
};
|
|
85
|
+
const resolveData = async (data, rawFile) => {
|
|
86
|
+
if (isFunction(data)) {
|
|
87
|
+
return data(rawFile);
|
|
88
|
+
}
|
|
89
|
+
return data;
|
|
90
|
+
};
|
|
91
|
+
const doUpload = async (rawFile, beforeData) => {
|
|
92
|
+
const {
|
|
93
|
+
headers,
|
|
94
|
+
data,
|
|
95
|
+
method,
|
|
96
|
+
withCredentials,
|
|
97
|
+
name: filename,
|
|
98
|
+
action,
|
|
99
|
+
onProgress,
|
|
100
|
+
onSuccess,
|
|
101
|
+
onError,
|
|
102
|
+
httpRequest
|
|
103
|
+
} = props;
|
|
104
|
+
try {
|
|
105
|
+
beforeData = await resolveData(beforeData != null ? beforeData : data, rawFile);
|
|
106
|
+
} catch (e) {
|
|
107
|
+
props.onRemove(rawFile);
|
|
108
|
+
return;
|
|
109
|
+
}
|
|
110
|
+
const { uid } = rawFile;
|
|
111
|
+
const options = {
|
|
112
|
+
headers: headers || {},
|
|
113
|
+
withCredentials,
|
|
114
|
+
file: rawFile,
|
|
115
|
+
data: beforeData,
|
|
116
|
+
method,
|
|
117
|
+
filename,
|
|
118
|
+
action,
|
|
119
|
+
onProgress: (evt) => {
|
|
120
|
+
onProgress(evt, rawFile);
|
|
121
|
+
},
|
|
122
|
+
onSuccess: (res) => {
|
|
123
|
+
onSuccess(res, rawFile);
|
|
124
|
+
delete requests.value[uid];
|
|
125
|
+
},
|
|
126
|
+
onError: (err) => {
|
|
127
|
+
onError(err, rawFile);
|
|
128
|
+
delete requests.value[uid];
|
|
129
|
+
}
|
|
130
|
+
};
|
|
131
|
+
const request = httpRequest(options);
|
|
132
|
+
requests.value[uid] = request;
|
|
133
|
+
if (request instanceof Promise) {
|
|
134
|
+
request.then(options.onSuccess, options.onError);
|
|
135
|
+
}
|
|
136
|
+
};
|
|
137
|
+
const handleChange = (e) => {
|
|
138
|
+
const files = e.target.files;
|
|
139
|
+
if (!files)
|
|
140
|
+
return;
|
|
141
|
+
uploadFiles(Array.from(files));
|
|
142
|
+
};
|
|
143
|
+
const handleClick = () => {
|
|
144
|
+
if (!disabled.value) {
|
|
145
|
+
inputRef.value.value = "";
|
|
146
|
+
inputRef.value.click();
|
|
147
|
+
}
|
|
148
|
+
};
|
|
149
|
+
const handleKeydown = () => {
|
|
150
|
+
handleClick();
|
|
151
|
+
};
|
|
152
|
+
const abort = (file) => {
|
|
153
|
+
const _reqs = entriesOf(requests.value).filter(file ? ([uid]) => String(file.uid) === uid : () => true);
|
|
154
|
+
_reqs.forEach(([uid, req]) => {
|
|
155
|
+
if (req instanceof XMLHttpRequest)
|
|
156
|
+
req.abort();
|
|
157
|
+
delete requests.value[uid];
|
|
158
|
+
});
|
|
159
|
+
};
|
|
160
|
+
expose({
|
|
161
|
+
abort,
|
|
162
|
+
upload
|
|
163
|
+
});
|
|
164
|
+
return (_ctx, _cache) => {
|
|
165
|
+
return openBlock(), createElementBlock("div", {
|
|
166
|
+
class: normalizeClass([unref(ns).b(), unref(ns).m(_ctx.listType), unref(ns).is("drag", _ctx.drag)]),
|
|
167
|
+
tabindex: "0",
|
|
168
|
+
onClick: handleClick,
|
|
169
|
+
onKeydown: withKeys(withModifiers(handleKeydown, ["self"]), ["enter", "space"])
|
|
170
|
+
}, [
|
|
171
|
+
_ctx.drag ? (openBlock(), createBlock(UploadDragger, {
|
|
172
|
+
key: 0,
|
|
173
|
+
disabled: unref(disabled),
|
|
174
|
+
onFile: uploadFiles
|
|
175
|
+
}, {
|
|
176
|
+
default: withCtx(() => [
|
|
177
|
+
renderSlot(_ctx.$slots, "default")
|
|
178
|
+
]),
|
|
179
|
+
_: 3
|
|
180
|
+
}, 8, ["disabled"])) : renderSlot(_ctx.$slots, "default", { key: 1 }),
|
|
181
|
+
createElementVNode("input", {
|
|
182
|
+
ref_key: "inputRef",
|
|
183
|
+
ref: inputRef,
|
|
184
|
+
class: normalizeClass(unref(ns).e("input")),
|
|
185
|
+
name: _ctx.name,
|
|
186
|
+
multiple: _ctx.multiple,
|
|
187
|
+
accept: _ctx.accept,
|
|
188
|
+
type: "file",
|
|
189
|
+
onChange: handleChange,
|
|
190
|
+
onClick: _cache[0] || (_cache[0] = withModifiers(() => {
|
|
191
|
+
}, ["stop"]))
|
|
192
|
+
}, null, 42, _hoisted_2)
|
|
193
|
+
], 42, _hoisted_1);
|
|
194
|
+
};
|
|
35
195
|
}
|
|
36
196
|
});
|
|
197
|
+
var UploadContent = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "upload-content.vue"]]);
|
|
37
198
|
|
|
38
|
-
export {
|
|
199
|
+
export { UploadContent as default };
|
|
39
200
|
//# sourceMappingURL=upload-content.mjs.map
|