@silver-formily/element-plus 2.0.1 → 2.2.0
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/README.en-US.md +32 -0
- package/README.md +32 -35
- package/esm/__builtins__/index.mjs +15 -16
- package/esm/__builtins__/shared/index.mjs +11 -12
- package/esm/__builtins__/shared/transform-component.d.ts +2 -6
- package/esm/__builtins__/shared/transform-component.mjs +16 -33
- package/esm/__builtins__/shared/transform-component.mjs.map +1 -1
- package/esm/__builtins__/shared/utils.mjs +10 -10
- package/esm/__builtins__/shared/utils.mjs.map +1 -1
- package/esm/array-base/index.mjs +58 -58
- package/esm/array-base/index.mjs.map +1 -1
- package/esm/array-cards/index.mjs +44 -44
- package/esm/array-cards/index.mjs.map +1 -1
- package/esm/array-collapse/index.mjs +59 -58
- package/esm/array-collapse/index.mjs.map +1 -1
- package/esm/array-items/index.mjs +46 -43
- package/esm/array-items/index.mjs.map +1 -1
- package/esm/array-list-tabs/index.mjs +15 -14
- package/esm/array-list-tabs/index.mjs.map +1 -1
- package/esm/array-table/array-table.d.ts +28 -0
- package/esm/array-table/index.d.ts +28 -0
- package/esm/array-table/index.mjs +113 -111
- package/esm/array-table/index.mjs.map +1 -1
- package/esm/array-table/types.d.ts +1 -0
- package/esm/cascader/index.mjs +19 -20
- package/esm/cascader/index.mjs.map +1 -1
- package/esm/checkbox/checkbox-group.d.ts +1 -4
- package/esm/checkbox/index.d.ts +442 -379
- package/esm/checkbox/index.mjs.map +1 -1
- package/esm/editable/editable.d.ts +16 -12
- package/esm/editable/index.d.ts +8 -6
- package/esm/editable/index.mjs +110 -112
- package/esm/editable/index.mjs.map +1 -1
- package/esm/form-button-group/index.mjs +29 -28
- package/esm/form-button-group/index.mjs.map +1 -1
- package/esm/form-collapse/index.mjs +42 -43
- package/esm/form-collapse/index.mjs.map +1 -1
- package/esm/form-dialog/index.d.ts +1 -1
- package/esm/form-dialog/index.mjs +4 -4
- package/esm/form-dialog/index.mjs.map +1 -1
- package/esm/form-dialog/types.d.ts +6 -6
- package/esm/form-drawer/index.d.ts +1 -1
- package/esm/form-drawer/index.mjs +4 -4
- package/esm/form-drawer/index.mjs.map +1 -1
- package/esm/form-drawer/types.d.ts +6 -6
- package/esm/form-grid/index.d.ts +1 -183
- package/esm/form-grid/index.mjs +1 -1
- package/esm/form-grid/index.mjs.map +1 -1
- package/esm/form-item/form-item.d.ts +2 -1
- package/esm/form-item/index.d.ts +12 -6
- package/esm/form-item/index.mjs +163 -155
- package/esm/form-item/index.mjs.map +1 -1
- package/esm/form-item/types.d.ts +0 -1
- package/esm/form-layout/form-layout.d.ts +0 -1
- package/esm/form-layout/form-layout.mjs +53 -52
- package/esm/form-layout/form-layout.mjs.map +1 -1
- package/esm/form-layout/types.d.ts +0 -2
- package/esm/form-layout/utils.d.ts +3 -3
- package/esm/form-layout/utils.mjs +48 -43
- package/esm/form-layout/utils.mjs.map +1 -1
- package/esm/form-step/index.mjs +27 -25
- package/esm/form-step/index.mjs.map +1 -1
- package/esm/form-tab/index.d.ts +1 -26
- package/esm/form-tab/index.mjs +30 -30
- package/esm/form-tab/index.mjs.map +1 -1
- package/esm/index.d.ts +3 -0
- package/esm/index.mjs +44 -38
- package/esm/index.mjs.map +1 -1
- package/esm/input/index.mjs.map +1 -1
- package/esm/input-number/index.d.ts +258 -147
- package/esm/pagination/pagination.mjs +109 -110
- package/esm/pagination/pagination.mjs.map +1 -1
- package/esm/password/index.mjs.map +1 -1
- package/esm/preview-text/index.d.ts +5 -0
- package/esm/preview-text/index.mjs +165 -141
- package/esm/preview-text/index.mjs.map +1 -1
- package/esm/preview-text/rate.d.ts +5 -0
- package/esm/preview-text/utils.d.ts +5 -5
- package/esm/preview-text/utils.mjs.map +1 -1
- package/esm/radio/index.d.ts +344 -194
- package/esm/radio/index.mjs.map +1 -1
- package/esm/rate/index.d.ts +187 -0
- package/esm/rate/index.mjs +14 -0
- package/esm/rate/index.mjs.map +1 -0
- package/esm/reset/index.d.ts +1 -62
- package/esm/reset/index.mjs +1 -1
- package/esm/reset/index.mjs.map +1 -1
- package/esm/segmented/index.d.ts +26 -0
- package/esm/segmented/index.mjs +37 -0
- package/esm/segmented/index.mjs.map +1 -0
- package/esm/segmented/segmented.d.ts +25 -0
- package/esm/select/index.mjs +8 -8
- package/esm/select/index.mjs.map +1 -1
- package/esm/select-table/index.d.ts +28 -0
- package/esm/select-table/index.mjs +48 -47
- package/esm/select-table/index.mjs.map +1 -1
- package/esm/select-table/select-table.d.ts +56 -0
- package/esm/slider/index.d.ts +177 -0
- package/esm/slider/index.mjs +14 -0
- package/esm/slider/index.mjs.map +1 -0
- package/esm/submit/index.d.ts +1 -47
- package/esm/submit/index.mjs +1 -1
- package/esm/submit/index.mjs.map +1 -1
- package/esm/switch/index.d.ts +225 -189
- package/esm/time-select/index.d.ts +163 -103
- package/esm/transfer/index.d.ts +196 -115
- package/esm/transfer/index.mjs.map +1 -1
- package/esm/tree/index.mjs +26 -26
- package/esm/tree/index.mjs.map +1 -1
- package/esm/tree-select/index.mjs.map +1 -1
- package/esm/upload/index.d.ts +404 -399
- package/esm/upload/index.mjs.map +1 -1
- package/esm/upload/upload.d.ts +800 -790
- package/esm/vendor/icon.mjs.map +1 -1
- package/esm/vendor/lodash.mjs +12 -20
- package/esm/vendor/lodash.mjs.map +1 -1
- package/esm/vendor/runtime.mjs +29 -24
- package/esm/vendor/runtime.mjs.map +1 -1
- package/esm/vendor/shared.esm-bundler.mjs +2 -2
- package/esm/vendor/sizes.mjs.map +1 -1
- package/esm/vendor/types.mjs +5 -5
- package/esm/vendor/types.mjs.map +1 -1
- package/package.json +8 -9
package/esm/form-item/index.mjs
CHANGED
|
@@ -1,189 +1,197 @@
|
|
|
1
|
-
import { isVoidField as
|
|
2
|
-
import { useField as
|
|
3
|
-
import { defineComponent as
|
|
4
|
-
import { InfoFilled as
|
|
5
|
-
import { isValid as v, isArr as
|
|
6
|
-
import { useNamespace as
|
|
7
|
-
import { FORM_LAYOUT_PROPS_KEYS as
|
|
8
|
-
import { p as
|
|
9
|
-
import { i as
|
|
10
|
-
import {
|
|
11
|
-
import { stylePrefix as
|
|
12
|
-
import { useResizeObserver as
|
|
13
|
-
import { getFeedbackMessage as
|
|
14
|
-
import { composeExport as
|
|
15
|
-
import '../styles/form-item/index.css';const
|
|
1
|
+
import { isVoidField as de } from "@formily/core";
|
|
2
|
+
import { useField as ce, connect as fe, mapProps as ve } from "@silver-formily/vue";
|
|
3
|
+
import { defineComponent as pe, useSlots as me, computed as i, ref as b, reactive as be, watch as ye, provide as D, createElementBlock as n, openBlock as a, unref as l, normalizeClass as u, createBlock as f, createCommentVNode as c, createElementVNode as h, resolveDynamicComponent as g, normalizeStyle as W, withCtx as m, isVNode as x, createVNode as _, toDisplayString as y, Fragment as C, createTextVNode as R, renderSlot as G, TransitionGroup as ke } from "vue";
|
|
4
|
+
import { InfoFilled as ge, CircleClose as Se, CircleCheck as he, Warning as xe } from "@element-plus/icons-vue";
|
|
5
|
+
import { isValid as v, isArr as _e } from "@formily/shared";
|
|
6
|
+
import { useNamespace as Ce, useFormSize as Ie, useId as $e, formItemContextKey as we, ElTooltip as E, ElIcon as K } from "element-plus";
|
|
7
|
+
import { FORM_LAYOUT_PROPS_KEYS as We, useFormLayout as Fe, formLayoutShallowContext as Ae } from "../form-layout/utils.mjs";
|
|
8
|
+
import { p as Le } from "../vendor/lodash.mjs";
|
|
9
|
+
import { i as ze, a as Be, d as Te } from "../vendor/types.mjs";
|
|
10
|
+
import { i as Re } from "../vendor/shared.esm-bundler.mjs";
|
|
11
|
+
import { stylePrefix as Ee } from "../__builtins__/configs/index.mjs";
|
|
12
|
+
import { useResizeObserver as Ve } from "../__builtins__/shared/hooks.mjs";
|
|
13
|
+
import { getFeedbackMessage as Pe, determineFeedbackStatus as Ne } from "./utils.mjs";
|
|
14
|
+
import { composeExport as Oe } from "../__builtins__/shared/utils.mjs";
|
|
15
|
+
import '../styles/form-item/index.css';const qe = "utils/dom/style";
|
|
16
16
|
function U(s, p = "px") {
|
|
17
|
-
if (!s && s !== 0)
|
|
18
|
-
|
|
19
|
-
if (Ae(s) || Be(s))
|
|
17
|
+
if (!s && s !== 0) return "";
|
|
18
|
+
if (ze(s) || Be(s))
|
|
20
19
|
return `${s}${p}`;
|
|
21
|
-
if (
|
|
20
|
+
if (Re(s))
|
|
22
21
|
return s;
|
|
23
|
-
|
|
22
|
+
Te(qe, "binding value must be a string or number");
|
|
24
23
|
}
|
|
25
|
-
const
|
|
24
|
+
const Me = ["role", "aria-labelledby"], Y = /* @__PURE__ */ pe({
|
|
26
25
|
name: "FFormItem",
|
|
27
26
|
__name: "form-item",
|
|
28
27
|
props: {
|
|
29
|
-
label:
|
|
30
|
-
for:
|
|
31
|
-
tooltip:
|
|
32
|
-
addonBefore:
|
|
33
|
-
addonAfter:
|
|
34
|
-
extra:
|
|
35
|
-
feedbackText:
|
|
36
|
-
feedbackStatus:
|
|
37
|
-
asterisk: { type: Boolean },
|
|
38
|
-
colon: { type: Boolean, default:
|
|
39
|
-
labelAlign:
|
|
40
|
-
wrapperAlign:
|
|
41
|
-
labelWrap: { type: Boolean },
|
|
42
|
-
labelWidth:
|
|
43
|
-
wrapperWidth:
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
tooltipLayout: null
|
|
28
|
+
label: {},
|
|
29
|
+
for: {},
|
|
30
|
+
tooltip: {},
|
|
31
|
+
addonBefore: {},
|
|
32
|
+
addonAfter: {},
|
|
33
|
+
extra: {},
|
|
34
|
+
feedbackText: {},
|
|
35
|
+
feedbackStatus: {},
|
|
36
|
+
asterisk: { type: Boolean, default: void 0 },
|
|
37
|
+
colon: { type: Boolean, default: void 0 },
|
|
38
|
+
labelAlign: {},
|
|
39
|
+
wrapperAlign: {},
|
|
40
|
+
labelWrap: { type: Boolean, default: void 0 },
|
|
41
|
+
labelWidth: {},
|
|
42
|
+
wrapperWidth: {},
|
|
43
|
+
labelCol: {},
|
|
44
|
+
wrapperCol: {},
|
|
45
|
+
fullness: { type: Boolean, default: void 0 },
|
|
46
|
+
size: {},
|
|
47
|
+
layout: {},
|
|
48
|
+
feedbackLayout: {},
|
|
49
|
+
tooltipLayout: {}
|
|
52
50
|
},
|
|
53
51
|
setup(s, { expose: p }) {
|
|
54
|
-
const e = s, F =
|
|
55
|
-
|
|
56
|
-
|
|
52
|
+
const e = s, F = me(), o = Ce("form-item"), d = `${Ee}-form-item`, H = i(
|
|
53
|
+
() => Object.fromEntries(
|
|
54
|
+
Object.entries(Le(e, We)).filter(([r, w]) => v(w))
|
|
55
|
+
)
|
|
56
|
+
), J = Fe(), t = i(() => Object.assign({
|
|
57
|
+
colon: !0,
|
|
58
|
+
feedbackLayout: "loose",
|
|
59
|
+
fullness: !1,
|
|
60
|
+
labelWrap: !1
|
|
61
|
+
}, J.value, H.value)), V = ce(), Q = Ie(void 0, { formItem: !1 }), P = i(() => v(t.value.size) ? t.value.size : Q.value), A = $e().value, k = b([]), N = b(""), O = b(), S = b(), q = b();
|
|
57
62
|
p({
|
|
58
63
|
feedbackTooltipRef: q
|
|
59
64
|
});
|
|
60
|
-
const
|
|
61
|
-
() =>
|
|
62
|
-
),
|
|
63
|
-
if (
|
|
65
|
+
const I = i(
|
|
66
|
+
() => t.value.layout === "vertical" || _e(t.value.layout) && t.value.layout.includes("vertical") ? "top" : t.value.labelAlign ?? "right"
|
|
67
|
+
), X = i(() => {
|
|
68
|
+
if (I.value === "top")
|
|
64
69
|
return {};
|
|
65
|
-
const r = U(
|
|
70
|
+
const r = U(t.value.labelWidth || "");
|
|
66
71
|
return r ? { width: r } : {};
|
|
67
|
-
}),
|
|
68
|
-
const r = U(
|
|
72
|
+
}), Z = i(() => {
|
|
73
|
+
const r = U(t.value?.wrapperWidth || "");
|
|
69
74
|
return r ? { width: r, flex: "unset" } : {};
|
|
70
|
-
}),
|
|
71
|
-
justifyContent:
|
|
72
|
-
})),
|
|
73
|
-
() => e.asterisk &&
|
|
74
|
-
),
|
|
75
|
+
}), ee = i(() => ({
|
|
76
|
+
justifyContent: t.value?.wrapperAlign === "right" && "flex-end"
|
|
77
|
+
})), te = i(
|
|
78
|
+
() => e.asterisk && V.value?.pattern !== "readPretty"
|
|
79
|
+
), ae = i(() => [
|
|
75
80
|
o.b(),
|
|
76
|
-
|
|
77
|
-
o.m(e.size || V.value || "default"),
|
|
81
|
+
o.m(P.value || "default"),
|
|
78
82
|
o.is(e.feedbackStatus),
|
|
79
83
|
o.is("validating", N.value === "validating"),
|
|
80
84
|
o.is("success", N.value === "success"),
|
|
81
|
-
o.is("required",
|
|
82
|
-
o.is("no-asterisk",
|
|
83
|
-
o.is(
|
|
84
|
-
|
|
85
|
+
o.is("required", te.value || e.asterisk),
|
|
86
|
+
o.is("no-asterisk", t.value?.hideRequiredAsterisk),
|
|
87
|
+
o.is(t.value.feedbackLayout),
|
|
88
|
+
t.value?.requireAsteriskPosition === "right" ? "asterisk-right" : "asterisk-left",
|
|
85
89
|
{
|
|
86
|
-
[o.m("feedback")]:
|
|
87
|
-
[o.m(`label-${
|
|
90
|
+
[o.m("feedback")]: t.value?.statusIcon,
|
|
91
|
+
[o.m(`label-${I.value}`)]: I.value
|
|
88
92
|
}
|
|
89
|
-
]), M =
|
|
90
|
-
`${
|
|
93
|
+
]), M = i(() => [
|
|
94
|
+
`${d}-feedback`,
|
|
91
95
|
o.is(e.feedbackStatus),
|
|
92
|
-
o.is("loose",
|
|
93
|
-
]),
|
|
94
|
-
async function
|
|
96
|
+
o.is("loose", t.value.feedbackLayout === "loose")
|
|
97
|
+
]), L = i(() => e.label !== "" && v(e.label) || v(F.label)), z = i(() => e.for || (k.value.length === 1 ? k.value[0] : void 0)), B = i(() => !z.value && L.value);
|
|
98
|
+
async function le() {
|
|
95
99
|
return !0;
|
|
96
100
|
}
|
|
97
101
|
/* istanbul ignore next -- @preserve */
|
|
98
|
-
const
|
|
102
|
+
const oe = () => {
|
|
99
103
|
};
|
|
100
104
|
/* istanbul ignore next -- @preserve */
|
|
101
|
-
const
|
|
102
|
-
}
|
|
105
|
+
const re = async () => {
|
|
106
|
+
};
|
|
107
|
+
/* istanbul ignore next -- @preserve */
|
|
108
|
+
const se = () => {
|
|
109
|
+
}, ie = (r) => {
|
|
103
110
|
/* istanbul ignore else -- @preserve */
|
|
104
111
|
k.value.includes(r) || k.value.push(r);
|
|
105
|
-
},
|
|
112
|
+
}, ne = (r) => {
|
|
106
113
|
k.value = k.value.filter((w) => w !== r);
|
|
107
114
|
}, j = b(!1);
|
|
108
|
-
|
|
115
|
+
Ve(S, () => {
|
|
109
116
|
j.value = S.value?.scrollWidth > S.value?.clientWidth;
|
|
110
117
|
});
|
|
111
|
-
const T =
|
|
118
|
+
const T = i(() => j.value && !t.value.labelWrap), ue = b(""), $ = be({
|
|
112
119
|
$el: O,
|
|
113
|
-
labelWidth:
|
|
114
|
-
size:
|
|
115
|
-
validateState:
|
|
120
|
+
labelWidth: t.value?.labelWidth,
|
|
121
|
+
size: P,
|
|
122
|
+
validateState: ue.value,
|
|
116
123
|
labelId: A,
|
|
117
124
|
inputIds: k,
|
|
118
|
-
isGroup:
|
|
119
|
-
hasLabel:
|
|
120
|
-
addInputId:
|
|
121
|
-
removeInputId:
|
|
122
|
-
resetField:
|
|
123
|
-
clearValidate:
|
|
124
|
-
validate:
|
|
125
|
-
labelPosition:
|
|
125
|
+
isGroup: B,
|
|
126
|
+
hasLabel: L,
|
|
127
|
+
addInputId: ie,
|
|
128
|
+
removeInputId: ne,
|
|
129
|
+
resetField: re,
|
|
130
|
+
clearValidate: oe,
|
|
131
|
+
validate: le,
|
|
132
|
+
labelPosition: I,
|
|
126
133
|
inlineMessage: !0,
|
|
127
134
|
showMessage: !0,
|
|
128
|
-
fieldValue:
|
|
135
|
+
fieldValue: V.value?.value,
|
|
129
136
|
validateMessage: "",
|
|
130
|
-
propString: ""
|
|
137
|
+
propString: "",
|
|
138
|
+
setInitialValue: se
|
|
131
139
|
});
|
|
132
|
-
return
|
|
140
|
+
return ye(() => e.feedbackStatus, (r) => {
|
|
133
141
|
if (r === "pending") {
|
|
134
|
-
|
|
142
|
+
$.validateState = "validating";
|
|
135
143
|
return;
|
|
136
144
|
}
|
|
137
145
|
if (r === "warning") {
|
|
138
|
-
|
|
146
|
+
$.validateState = "";
|
|
139
147
|
return;
|
|
140
148
|
}
|
|
141
|
-
|
|
149
|
+
$.validateState = r;
|
|
142
150
|
}, {
|
|
143
151
|
immediate: !0
|
|
144
|
-
}), D(
|
|
145
|
-
...v(
|
|
146
|
-
...v(
|
|
147
|
-
})), D(
|
|
152
|
+
}), D(Ae, b({
|
|
153
|
+
...v(t.value.size) && { size: t.value.size },
|
|
154
|
+
...v(t.value.colon) && { colon: t.value.colon }
|
|
155
|
+
})), D(we, $), (r, w) => (a(), n("div", {
|
|
148
156
|
ref_key: "formItemRef",
|
|
149
157
|
ref: O,
|
|
150
|
-
class:
|
|
151
|
-
role:
|
|
152
|
-
"aria-labelledby":
|
|
158
|
+
class: u([d, t.value.labelWrap && "is-warp", ...ae.value]),
|
|
159
|
+
role: B.value ? "group" : void 0,
|
|
160
|
+
"aria-labelledby": B.value ? l(A) : void 0
|
|
153
161
|
}, [
|
|
154
|
-
|
|
162
|
+
L.value ? (a(), f(g(z.value ? "label" : "div"), {
|
|
155
163
|
key: 0,
|
|
156
164
|
id: l(A),
|
|
157
|
-
for:
|
|
158
|
-
class:
|
|
159
|
-
style: W(
|
|
165
|
+
for: z.value,
|
|
166
|
+
class: u([l(o).e("label"), l(v)(t.value.labelCol) && `${d}-col-${t.value.labelCol}`]),
|
|
167
|
+
style: W(X.value)
|
|
160
168
|
}, {
|
|
161
169
|
default: m(() => [
|
|
162
|
-
x(e.label) ? (
|
|
170
|
+
x(e.label) ? (a(), f(g(e.label), { key: 0 })) : (a(), n("div", {
|
|
163
171
|
key: 1,
|
|
164
|
-
class:
|
|
172
|
+
class: u(`${d}-label__wrapper`)
|
|
165
173
|
}, [
|
|
166
174
|
_(l(E), {
|
|
167
|
-
disabled: !T.value &&
|
|
175
|
+
disabled: !T.value && t.value.tooltipLayout !== "text"
|
|
168
176
|
}, {
|
|
169
177
|
content: m(() => [
|
|
170
|
-
x(e.tooltip) ? (
|
|
178
|
+
x(e.tooltip) ? (a(), f(g(e.tooltip), { key: 0 })) : (a(), n("div", {
|
|
171
179
|
key: 1,
|
|
172
180
|
style: W(`width: ${S.value?.clientWidth ?? 0}px;`)
|
|
173
181
|
}, [
|
|
174
|
-
T.value ? (
|
|
182
|
+
T.value ? (a(), n(C, { key: 0 }, [
|
|
175
183
|
R(y(e.label), 1)
|
|
176
184
|
], 64)) : c("", !0),
|
|
177
|
-
|
|
185
|
+
t.value.tooltipLayout === "text" ? (a(), n(C, { key: 1 }, [
|
|
178
186
|
R(y(e.tooltip), 1)
|
|
179
187
|
], 64)) : c("", !0)
|
|
180
188
|
], 4))
|
|
181
189
|
]),
|
|
182
190
|
default: m(() => [
|
|
183
191
|
h("span", {
|
|
184
|
-
class:
|
|
185
|
-
[`${
|
|
186
|
-
"is-tooltip": T.value || e.tooltip &&
|
|
192
|
+
class: u({
|
|
193
|
+
[`${d}-label-content`]: !0,
|
|
194
|
+
"is-tooltip": T.value || e.tooltip && t.value.tooltipLayout === "text"
|
|
187
195
|
})
|
|
188
196
|
}, [
|
|
189
197
|
h("span", {
|
|
@@ -194,52 +202,52 @@ const Oe = ["role", "aria-labelledby"], Y = /* @__PURE__ */ fe({
|
|
|
194
202
|
]),
|
|
195
203
|
_: 1
|
|
196
204
|
}, 8, ["disabled"]),
|
|
197
|
-
e.tooltip &&
|
|
205
|
+
e.tooltip && t.value.tooltipLayout !== "text" ? (a(), f(l(E), {
|
|
198
206
|
key: 0,
|
|
199
207
|
content: e.tooltip
|
|
200
208
|
}, {
|
|
201
209
|
default: m(() => [
|
|
202
210
|
_(l(K), {
|
|
203
|
-
class:
|
|
211
|
+
class: u(`${d}-label-tooltip`)
|
|
204
212
|
}, {
|
|
205
213
|
default: m(() => [
|
|
206
|
-
_(l(
|
|
214
|
+
_(l(ge))
|
|
207
215
|
]),
|
|
208
216
|
_: 1
|
|
209
217
|
}, 8, ["class"])
|
|
210
218
|
]),
|
|
211
219
|
_: 1
|
|
212
220
|
}, 8, ["content"])) : c("", !0),
|
|
213
|
-
|
|
221
|
+
t.value.colon ? (a(), n("span", {
|
|
214
222
|
key: 1,
|
|
215
|
-
class:
|
|
223
|
+
class: u(`${d}-colon`)
|
|
216
224
|
}, ":", 2)) : c("", !0)
|
|
217
225
|
], 2))
|
|
218
226
|
]),
|
|
219
227
|
_: 1
|
|
220
228
|
}, 8, ["id", "for", "class", "style"])) : c("", !0),
|
|
221
229
|
h("div", {
|
|
222
|
-
class:
|
|
223
|
-
`${
|
|
224
|
-
l(v)(
|
|
230
|
+
class: u([
|
|
231
|
+
`${d}-content__wrapper`,
|
|
232
|
+
l(v)(t.value.wrapperCol) && `${d}-col-${t.value.wrapperCol}`
|
|
225
233
|
]),
|
|
226
|
-
style: W(
|
|
234
|
+
style: W(ee.value)
|
|
227
235
|
}, [
|
|
228
|
-
l(v)(e.addonBefore) ? (
|
|
229
|
-
x(e.addonBefore) ? (
|
|
236
|
+
l(v)(e.addonBefore) ? (a(), n(C, { key: 0 }, [
|
|
237
|
+
x(e.addonBefore) ? (a(), f(g(e.addonBefore), { key: 0 })) : (a(), n("div", {
|
|
230
238
|
key: 1,
|
|
231
|
-
class:
|
|
239
|
+
class: u(`${d}-addon-before`)
|
|
232
240
|
}, y(e.addonBefore), 3))
|
|
233
241
|
], 64)) : c("", !0),
|
|
234
242
|
h("div", {
|
|
235
|
-
class:
|
|
243
|
+
class: u([
|
|
236
244
|
l(o).e("content"),
|
|
237
|
-
|
|
245
|
+
t.value.fullness && "is-fullness",
|
|
238
246
|
l(o).is("addon-after", !!e.addonAfter)
|
|
239
247
|
]),
|
|
240
|
-
style: W(
|
|
248
|
+
style: W(Z.value)
|
|
241
249
|
}, [
|
|
242
|
-
|
|
250
|
+
t.value.feedbackLayout === "popover" ? (a(), f(l(E), {
|
|
243
251
|
key: 0,
|
|
244
252
|
ref_key: "feedbackTooltipRef",
|
|
245
253
|
ref: q,
|
|
@@ -252,13 +260,13 @@ const Oe = ["role", "aria-labelledby"], Y = /* @__PURE__ */ fe({
|
|
|
252
260
|
]),
|
|
253
261
|
content: m(() => [
|
|
254
262
|
h("div", {
|
|
255
|
-
class:
|
|
263
|
+
class: u([...M.value, l(o).is("tooltip")])
|
|
256
264
|
}, [
|
|
257
265
|
_(l(K), null, {
|
|
258
266
|
default: m(() => [
|
|
259
|
-
e.feedbackStatus === "error" ? (
|
|
260
|
-
e.feedbackStatus === "success" ? (
|
|
261
|
-
e.feedbackStatus === "warning" ? (
|
|
267
|
+
e.feedbackStatus === "error" ? (a(), f(l(Se), { key: 0 })) : c("", !0),
|
|
268
|
+
e.feedbackStatus === "success" ? (a(), f(l(he), { key: 1 })) : c("", !0),
|
|
269
|
+
e.feedbackStatus === "warning" ? (a(), f(l(xe), { key: 2 })) : c("", !0)
|
|
262
270
|
]),
|
|
263
271
|
_: 1
|
|
264
272
|
}),
|
|
@@ -267,38 +275,38 @@ const Oe = ["role", "aria-labelledby"], Y = /* @__PURE__ */ fe({
|
|
|
267
275
|
]),
|
|
268
276
|
_: 3
|
|
269
277
|
}, 8, ["visible"])) : G(r.$slots, "default", { key: 1 }),
|
|
270
|
-
_(
|
|
278
|
+
_(ke, {
|
|
271
279
|
name: `${l(o).namespace.value}-zoom-in-top`
|
|
272
280
|
}, {
|
|
273
281
|
default: m(() => [
|
|
274
|
-
e.feedbackText &&
|
|
282
|
+
e.feedbackText && t.value.feedbackLayout !== "popover" ? (a(), n("div", {
|
|
275
283
|
key: 0,
|
|
276
|
-
class:
|
|
284
|
+
class: u(M.value)
|
|
277
285
|
}, y(e.feedbackText), 3)) : c("", !0),
|
|
278
|
-
l(v)(e.extra) ? (
|
|
279
|
-
x(e.extra) ? (
|
|
286
|
+
l(v)(e.extra) ? (a(), n(C, { key: 1 }, [
|
|
287
|
+
x(e.extra) ? (a(), f(g(e.extra), { key: 0 })) : (a(), n("div", {
|
|
280
288
|
key: 1,
|
|
281
|
-
class:
|
|
289
|
+
class: u(`${d}-extra`)
|
|
282
290
|
}, y(e.extra), 3))
|
|
283
291
|
], 64)) : c("", !0)
|
|
284
292
|
]),
|
|
285
293
|
_: 1
|
|
286
294
|
}, 8, ["name"])
|
|
287
295
|
], 6),
|
|
288
|
-
l(v)(e.addonAfter) ? (
|
|
289
|
-
x(e.addonAfter) ? (
|
|
296
|
+
l(v)(e.addonAfter) ? (a(), n(C, { key: 1 }, [
|
|
297
|
+
x(e.addonAfter) ? (a(), f(g(e.addonAfter), { key: 0 })) : (a(), n("div", {
|
|
290
298
|
key: 1,
|
|
291
|
-
class:
|
|
299
|
+
class: u(`${d}-addon-after`)
|
|
292
300
|
}, y(e.addonAfter), 3))
|
|
293
301
|
], 64)) : c("", !0)
|
|
294
302
|
], 6)
|
|
295
|
-
], 10,
|
|
303
|
+
], 10, Me));
|
|
296
304
|
}
|
|
297
305
|
});
|
|
298
|
-
function
|
|
299
|
-
if (
|
|
306
|
+
function je(s, p) {
|
|
307
|
+
if (de(p) || !p)
|
|
300
308
|
return s;
|
|
301
|
-
const e =
|
|
309
|
+
const e = Pe(p), F = Ne(p), o = "asterisk" in s ? s.asterisk : p.required && p.pattern !== "readPretty";
|
|
302
310
|
return {
|
|
303
311
|
...s,
|
|
304
312
|
feedbackText: e,
|
|
@@ -306,24 +314,24 @@ function qe(s, p) {
|
|
|
306
314
|
asterisk: o
|
|
307
315
|
};
|
|
308
316
|
}
|
|
309
|
-
const
|
|
317
|
+
const De = fe(
|
|
310
318
|
Y,
|
|
311
|
-
|
|
319
|
+
ve(
|
|
312
320
|
{
|
|
313
321
|
validateStatus: !0,
|
|
314
322
|
title: "label",
|
|
315
323
|
required: !0,
|
|
316
324
|
description: "extra"
|
|
317
325
|
},
|
|
318
|
-
|
|
326
|
+
je
|
|
319
327
|
)
|
|
320
|
-
),
|
|
328
|
+
), rt = Oe(De, {
|
|
321
329
|
BaseItem: Y
|
|
322
330
|
});
|
|
323
331
|
export {
|
|
324
332
|
Y as FormBaseItem,
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
333
|
+
rt as FormItem,
|
|
334
|
+
rt as default,
|
|
335
|
+
je as fieldFeedbackMapper
|
|
328
336
|
};
|
|
329
337
|
//# sourceMappingURL=index.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.mjs","sources":["../../node_modules/.pnpm/element-plus@2.13.0_vue@3.5.22_typescript@5.9.3_/node_modules/element-plus/es/utils/dom/style.mjs","../../src/form-item/form-item.vue","../../src/form-item/index.ts"],"sourcesContent":["import { isNumber, isStringNumber } from '../types.mjs';\nimport { isClient } from '@vueuse/core';\nimport { camelize, isObject, isString } from '@vue/shared';\nimport { entriesOf, keysOf } from '../objects.mjs';\nimport { debugWarn } from '../error.mjs';\n\nconst SCOPE = \"utils/dom/style\";\nconst classNameToArray = (cls = \"\") => cls.split(\" \").filter((item) => !!item.trim());\nconst hasClass = (el, cls) => {\n if (!el || !cls)\n return false;\n if (cls.includes(\" \"))\n throw new Error(\"className should not contain space.\");\n return el.classList.contains(cls);\n};\nconst addClass = (el, cls) => {\n if (!el || !cls.trim())\n return;\n el.classList.add(...classNameToArray(cls));\n};\nconst removeClass = (el, cls) => {\n if (!el || !cls.trim())\n return;\n el.classList.remove(...classNameToArray(cls));\n};\nconst getStyle = (element, styleName) => {\n var _a;\n if (!isClient || !element || !styleName)\n return \"\";\n let key = camelize(styleName);\n if (key === \"float\")\n key = \"cssFloat\";\n try {\n const style = element.style[key];\n if (style)\n return style;\n const computed = (_a = document.defaultView) == null ? void 0 : _a.getComputedStyle(element, \"\");\n return computed ? computed[key] : \"\";\n } catch (e) {\n return element.style[key];\n }\n};\nconst setStyle = (element, styleName, value) => {\n if (!element || !styleName)\n return;\n if (isObject(styleName)) {\n entriesOf(styleName).forEach(\n ([prop, value2]) => setStyle(element, prop, value2)\n );\n } else {\n const key = camelize(styleName);\n element.style[key] = value;\n }\n};\nconst removeStyle = (element, style) => {\n if (!element || !style)\n return;\n if (isObject(style)) {\n keysOf(style).forEach((prop) => removeStyle(element, prop));\n } else {\n setStyle(element, style, \"\");\n }\n};\nfunction addUnit(value, defaultUnit = \"px\") {\n if (!value && value !== 0)\n return \"\";\n if (isNumber(value) || isStringNumber(value)) {\n return `${value}${defaultUnit}`;\n } else if (isString(value)) {\n return value;\n }\n debugWarn(SCOPE, \"binding value must be a string or number\");\n}\n\nexport { addClass, addUnit, classNameToArray, getStyle, hasClass, removeClass, removeStyle, setStyle };\n//# sourceMappingURL=style.mjs.map\n","<script lang=\"ts\" setup>\r\nimport type { Field } from '@formily/core'\r\nimport type {\r\n FormItemContext,\r\n FormItemValidateState,\r\n FormValidationResult,\r\n TooltipInstance,\r\n} from 'element-plus'\r\nimport type { ICalculatedFormLayoutProps } from 'src/form-layout/types'\r\nimport type { CSSProperties } from 'vue'\r\nimport type { IFormItemProps } from './types'\r\nimport { CircleCheck, CircleClose, InfoFilled, Warning } from '@element-plus/icons-vue'\r\nimport { isArr, isValid } from '@formily/shared'\r\nimport { useField } from '@silver-formily/vue'\r\nimport { ElIcon, ElTooltip, formItemContextKey, useFormSize, useId, useNamespace } from 'element-plus'\r\nimport { addUnit } from 'element-plus/es/utils/index'\r\nimport { pick } from 'lodash-es'\r\nimport { computed, isVNode, provide, reactive, ref, useSlots, watch } from 'vue'\r\nimport { stylePrefix, useResizeObserver } from '../__builtins__'\r\nimport { FORM_LAYOUT_PROPS_KEYS, formLayoutShallowContext, useFormLayout } from '../form-layout/utils'\r\n\r\ndefineOptions({\r\n name: 'FFormItem',\r\n})\r\nconst props = defineProps({\n label: null,\n for: null,\n tooltip: null,\n addonBefore: null,\n addonAfter: null,\n extra: null,\n feedbackText: null,\n feedbackStatus: null,\n asterisk: { type: Boolean },\n colon: { type: Boolean, default: true },\n labelAlign: null,\n wrapperAlign: null,\n labelWrap: { type: Boolean },\n labelWidth: null,\n wrapperWidth: null,\n wrapperWrap: { type: Boolean },\n labelCol: null,\n wrapperCol: null,\n fullness: { type: Boolean, default: false },\n size: null,\n layout: null,\n feedbackLayout: { default: 'loose' },\n tooltipLayout: null\n})\r\nconst slots = useSlots()\r\nconst ns = useNamespace('form-item')\r\nconst prefixCls = `${stylePrefix}-form-item`\r\nconst formItemConfig: Partial<ICalculatedFormLayoutProps> = Object.fromEntries(\r\n Object.entries(pick(props, FORM_LAYOUT_PROPS_KEYS))\r\n .filter(([_, value]) => isValid(value)),\r\n)\r\nconst formlayoutConfig = useFormLayout()\r\nconst formlayout = computed(() => Object.assign({}, formlayoutConfig.value, formItemConfig))\r\n\r\nconst field = useField<Field>()\r\n\r\nconst _size = useFormSize(undefined, { formItem: false })\r\n\r\nconst labelId = useId().value\r\nconst inputIds = ref<string[]>([])\r\n\r\nconst validateState = ref<FormItemValidateState>('')\r\nconst formItemRef = ref<HTMLDivElement>()\r\nconst labelRef = ref<HTMLElement>()\r\nconst feedbackTooltipRef = ref<TooltipInstance>()\r\ndefineExpose({\r\n feedbackTooltipRef,\r\n})\r\n\r\nconst labelPosition = computed(\r\n () => {\r\n if (formlayout.value.layout === 'vertical' || (isArr(formlayout.value.layout) && formlayout.value.layout.includes('vertical' as any))) {\r\n return 'top'\r\n }\r\n return formlayout.value.labelAlign ?? 'right'\r\n },\r\n)\r\n\r\nconst labelStyle = computed<CSSProperties>(() => {\r\n if (labelPosition.value === 'top') {\r\n return {}\r\n }\r\n\r\n const labelWidth = addUnit(formlayout.value.labelWidth || '')\r\n if (labelWidth)\r\n return { width: labelWidth }\r\n return {}\r\n})\r\n\r\nconst contentStyle = computed<CSSProperties>(() => {\r\n const contentWidth = addUnit(formlayout.value?.wrapperWidth || '')\r\n if (contentWidth)\r\n return { width: contentWidth, flex: 'unset' }\r\n return {}\r\n})\r\n\r\nconst contentWrapperStyle = computed<CSSProperties>(() => {\r\n return {\r\n justifyContent: formlayout.value?.wrapperAlign === 'right' && 'flex-end',\r\n }\r\n})\r\n\r\nconst isRequired = computed(() =>\r\n props.asterisk && field.value?.pattern !== 'readPretty',\r\n)\r\n\r\nconst formItemClasses = computed(() => [\r\n ns.b(),\r\n // eslint-disable-next-line unicorn/explicit-length-check\r\n ns.m(props.size || _size.value || 'default'),\r\n ns.is(props.feedbackStatus),\r\n ns.is('validating', validateState.value === 'validating'),\r\n ns.is('success', validateState.value === 'success'),\r\n ns.is('required', isRequired.value || props.asterisk),\r\n ns.is('no-asterisk', formlayout.value?.hideRequiredAsterisk),\r\n ns.is(formlayout.value.feedbackLayout),\r\n formlayout.value?.requireAsteriskPosition === 'right'\r\n ? 'asterisk-right'\r\n : 'asterisk-left',\r\n {\r\n [ns.m('feedback')]: formlayout.value?.statusIcon,\r\n [ns.m(`label-${labelPosition.value}`)]: labelPosition.value,\r\n },\r\n])\r\n\r\nconst validateClasses = computed(() => [\r\n `${prefixCls}-feedback`,\r\n ns.is(props.feedbackStatus),\r\n ns.is('loose', props.feedbackLayout === 'loose'),\r\n])\r\n\r\nconst hasLabel = computed<boolean>(() => {\r\n return (props.label !== '' && isValid(props.label)) || isValid(slots.label)\r\n})\r\n\r\nconst labelFor = computed<string | undefined>(() => {\r\n return (\r\n props.for || (inputIds.value.length === 1 ? inputIds.value[0] : undefined)\r\n )\r\n})\r\n\r\nconst isGroup = computed<boolean>(() => {\r\n return !labelFor.value && hasLabel.value\r\n})\r\n\r\nasync function validate(): FormValidationResult {\r\n return true\r\n}\r\n/* istanbul ignore next -- @preserve */\r\nconst clearValidate: FormItemContext['clearValidate'] = () => {}\r\n/* istanbul ignore next -- @preserve */\r\nconst resetField: FormItemContext['resetField'] = async () => {}\r\n\r\nconst addInputId: FormItemContext['addInputId'] = (id: string) => {\r\n /* istanbul ignore else -- @preserve */\r\n if (!inputIds.value.includes(id)) {\r\n inputIds.value.push(id)\r\n }\r\n}\r\n\r\nconst removeInputId: FormItemContext['removeInputId'] = (id: string) => {\r\n inputIds.value = inputIds.value.filter(listId => listId !== id)\r\n}\r\n\r\nconst isEllipsisActive = ref(false)\r\nuseResizeObserver(labelRef, () => {\r\n isEllipsisActive.value = labelRef.value?.scrollWidth > labelRef.value?.clientWidth\r\n})\r\nconst isEllipsis = computed(() => {\r\n return isEllipsisActive.value && !formlayout.value.labelWrap\r\n})\r\n\r\n// HACK computed无法监听到props.feedbackStatus的变化\r\nconst _validateState = ref<FormItemValidateState>('')\r\nconst context: FormItemContext = reactive({\r\n $el: formItemRef,\r\n labelWidth: formlayout.value?.labelWidth,\r\n size: _size,\r\n validateState: _validateState.value,\r\n labelId,\r\n inputIds,\r\n isGroup,\r\n hasLabel,\r\n addInputId,\r\n removeInputId,\r\n resetField,\r\n clearValidate,\r\n validate,\r\n labelPosition,\r\n inlineMessage: true,\r\n showMessage: true,\r\n fieldValue: field.value?.value,\r\n validateMessage: '',\r\n propString: '',\r\n})\r\nwatch(() => props.feedbackStatus, (val) => {\r\n if (val === 'pending') {\r\n context.validateState = 'validating'\r\n return\r\n }\r\n if (val === 'warning') {\r\n context.validateState = ''\r\n return\r\n }\r\n context.validateState = val\r\n}, {\r\n immediate: true,\r\n})\r\n\r\nprovide(formLayoutShallowContext, ref({\r\n ...(isValid(props.size) && { size: props.size }),\r\n ...(isValid(props.colon) && { colon: props.colon }),\r\n}))\r\nprovide(formItemContextKey, context)\r\n</script>\r\n\r\n<template>\r\n <div\r\n ref=\"formItemRef\" :class=\"[prefixCls, formlayout.labelWrap && 'is-warp', ...formItemClasses]\"\r\n :role=\"isGroup ? 'group' : undefined\" :aria-labelledby=\"isGroup ? labelId : undefined\"\r\n >\r\n <component\r\n :is=\"labelFor ? 'label' : 'div'\" v-if=\"hasLabel\" :id=\"labelId\" :for=\"labelFor\"\r\n :class=\"[ns.e('label'), isValid(formlayout.labelCol) && `${prefixCls}-col-${formlayout.labelCol}`]\"\r\n :style=\"labelStyle\"\r\n >\r\n <!-- label -->\r\n <template v-if=\"isVNode(props.label)\">\r\n <component :is=\"props.label\" />\r\n </template>\r\n <div v-else :class=\"`${prefixCls}-label__wrapper`\">\r\n <ElTooltip :disabled=\"!isEllipsis && formlayout.tooltipLayout !== 'text'\">\r\n <span\r\n :class=\"{\r\n [`${prefixCls}-label-content`]: true,\r\n ['is-tooltip']: isEllipsis || (props.tooltip && formlayout.tooltipLayout === 'text'),\r\n }\"\r\n >\r\n <span ref=\"labelRef\">{{ props.label }}</span>\r\n </span>\r\n <template #content>\r\n <template v-if=\"isVNode(props.tooltip)\">\r\n <component :is=\"props.tooltip\" />\r\n </template>\r\n <div v-else :style=\"`width: ${labelRef?.clientWidth ?? 0}px;`\">\r\n <template v-if=\"isEllipsis\">\r\n {{ props.label }}\r\n </template>\r\n <template v-if=\"formlayout.tooltipLayout === 'text'\">\r\n {{ props.tooltip }}\r\n </template>\r\n </div>\r\n </template>\r\n </ElTooltip>\r\n <ElTooltip v-if=\"props.tooltip && formlayout.tooltipLayout !== 'text'\" :content=\"props.tooltip\">\r\n <ElIcon :class=\"`${prefixCls}-label-tooltip`\">\r\n <InfoFilled />\r\n </ElIcon>\r\n </ElTooltip>\r\n <span v-if=\"props.colon\" :class=\"`${prefixCls}-colon`\">:</span>\r\n </div>\r\n </component>\r\n <!-- content -->\r\n <div\r\n :class=\"[\r\n `${prefixCls}-content__wrapper`,\r\n isValid(formlayout.wrapperCol) && `${prefixCls}-col-${formlayout.wrapperCol}`,\r\n ]\"\r\n :style=\"contentWrapperStyle\"\r\n >\r\n <template v-if=\"isValid(props.addonBefore)\">\r\n <template v-if=\"isVNode(props.addonBefore)\">\r\n <component :is=\"props.addonBefore\" />\r\n </template>\r\n <div v-else :class=\"`${prefixCls}-addon-before`\">\r\n {{ props.addonBefore }}\r\n </div>\r\n </template>\r\n <div\r\n :class=\"[\r\n ns.e('content'),\r\n formlayout.fullness && 'is-fullness',\r\n ns.is('addon-after', !!props.addonAfter),\r\n ]\" :style=\"contentStyle\"\r\n >\r\n <ElTooltip\r\n v-if=\"props.feedbackLayout === 'popover'\"\r\n ref=\"feedbackTooltipRef\"\r\n :visible=\"!!props.feedbackText\"\r\n effect=\"light\"\r\n :offset=\"6\"\r\n >\r\n <template #default>\r\n <slot />\r\n </template>\r\n <template #content>\r\n <div :class=\"[...validateClasses, ns.is('tooltip')]\">\r\n <ElIcon>\r\n <CircleClose v-if=\"props.feedbackStatus === 'error'\" />\r\n <CircleCheck v-if=\"props.feedbackStatus === 'success'\" />\r\n <Warning v-if=\"props.feedbackStatus === 'warning'\" />\r\n </ElIcon>\r\n {{ props.feedbackText }}\r\n </div>\r\n </template>\r\n </ElTooltip>\r\n <slot v-else />\r\n <TransitionGroup :name=\"`${ns.namespace.value}-zoom-in-top`\">\r\n <div v-if=\"props.feedbackText && props.feedbackLayout !== 'popover'\" :class=\"validateClasses\">\r\n {{ props.feedbackText }}\r\n </div>\r\n <template v-if=\"isValid(props.extra)\">\r\n <template v-if=\"isVNode(props.extra)\">\r\n <component :is=\"props.extra\" />\r\n </template>\r\n <div v-else :class=\"`${prefixCls}-extra`\">\r\n {{ props.extra }}\r\n </div>\r\n </template>\r\n </TransitionGroup>\r\n </div>\r\n <template v-if=\"isValid(props.addonAfter)\">\r\n <template v-if=\"isVNode(props.addonAfter)\">\r\n <component :is=\"props.addonAfter\" />\r\n </template>\r\n <div v-else :class=\"`${prefixCls}-addon-after`\">\r\n {{ props.addonAfter }}\r\n </div>\r\n </template>\r\n </div>\r\n </div>\r\n</template>\r\n","import { isVoidField } from '@formily/core'\r\nimport { connect, mapProps } from '@silver-formily/vue'\r\nimport { composeExport } from '../__builtins__'\r\nimport FormBaseItem from './form-item.vue'\r\nimport { determineFeedbackStatus, getFeedbackMessage } from './utils'\r\nimport './style.scss'\r\n\r\nexport function fieldFeedbackMapper(props, field) {\r\n if (isVoidField(field) || !field) {\r\n return props\r\n }\r\n\r\n const feedbackText = getFeedbackMessage(field)\r\n const feedbackStatus = determineFeedbackStatus(field)\r\n const asterisk = 'asterisk' in props\r\n ? props.asterisk\r\n : field.required && field.pattern !== 'readPretty'\r\n\r\n return {\r\n ...props,\r\n feedbackText,\r\n feedbackStatus,\r\n asterisk,\r\n }\r\n}\r\n\r\nconst Item = connect(\r\n FormBaseItem,\r\n mapProps(\r\n {\r\n validateStatus: true,\r\n title: 'label',\r\n required: true,\r\n description: 'extra',\r\n },\r\n fieldFeedbackMapper,\r\n ),\r\n)\r\n\r\nexport const FormItem = composeExport(Item, {\r\n BaseItem: FormBaseItem,\r\n})\r\n\r\nexport default FormItem\r\n\r\nexport { default as FormBaseItem } from './form-item.vue'\r\n"],"names":["SCOPE","addUnit","value","defaultUnit","isNumber","isStringNumber","isString","debugWarn","props","__props","slots","useSlots","ns","useNamespace","prefixCls","stylePrefix","formItemConfig","pick","FORM_LAYOUT_PROPS_KEYS","_","isValid","formlayoutConfig","useFormLayout","formlayout","computed","field","useField","_size","useFormSize","labelId","useId","inputIds","ref","validateState","formItemRef","labelRef","feedbackTooltipRef","__expose","labelPosition","isArr","labelStyle","labelWidth","contentStyle","contentWidth","contentWrapperStyle","isRequired","formItemClasses","validateClasses","hasLabel","labelFor","isGroup","validate","clearValidate","resetField","addInputId","id","removeInputId","listId","isEllipsisActive","useResizeObserver","isEllipsis","_validateState","context","reactive","watch","val","provide","formLayoutShallowContext","formItemContextKey","_createElementBlock","_unref","_openBlock","_createBlock","_resolveDynamicComponent","_normalizeClass","isVNode","_createVNode","ElTooltip","_normalizeStyle","_Fragment","_createTextVNode","_toDisplayString","_createElementVNode","ElIcon","InfoFilled","_renderSlot","_ctx","CircleClose","CircleCheck","Warning","_TransitionGroup","fieldFeedbackMapper","isVoidField","feedbackText","getFeedbackMessage","feedbackStatus","determineFeedbackStatus","asterisk","Item","connect","FormBaseItem","mapProps","FormItem","composeExport"],"mappings":";;;;;;;;;;;;;;AAMA,MAAMA,KAAQ;AAyDd,SAASC,EAAQC,GAAOC,IAAc,MAAM;AAC1C,MAAI,CAACD,KAASA,MAAU;AACtB,WAAO;AACT,MAAIE,GAASF,CAAK,KAAKG,GAAeH,CAAK;AACzC,WAAO,GAAGA,CAAK,GAAGC,CAAW;AACxB,MAAIG,GAASJ,CAAK;AACvB,WAAOA;AAET,EAAAK,GAAUP,IAAO,0CAA0C;AAC7D;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AChDA,UAAMQ,IAAQC,GAyBRC,IAAQC,GAAA,GACRC,IAAKC,GAAa,WAAW,GAC7BC,IAAY,GAAGC,EAAW,cAC1BC,IAAsD,OAAO;AAAA,MACjE,OAAO,QAAQC,GAAKT,GAAOU,EAAsB,CAAC,EAC/C,OAAO,CAAC,CAACC,GAAGjB,CAAK,MAAMkB,EAAQlB,CAAK,CAAC;AAAA,IAAA,GAEpCmB,IAAmBC,GAAA,GACnBC,IAAaC,EAAS,MAAM,OAAO,OAAO,CAAA,GAAIH,EAAiB,OAAOL,CAAc,CAAC,GAErFS,IAAQC,GAAA,GAERC,IAAQC,GAAY,QAAW,EAAE,UAAU,IAAO,GAElDC,IAAUC,KAAQ,OAClBC,IAAWC,EAAc,EAAE,GAE3BC,IAAgBD,EAA2B,EAAE,GAC7CE,IAAcF,EAAA,GACdG,IAAWH,EAAA,GACXI,IAAqBJ,EAAA;AAC3B,IAAAK,EAAa;AAAA,MACX,oBAAAD;AAAA,IAAA,CACD;AAED,UAAME,IAAgBd;AAAA,MACpB,MACMD,EAAW,MAAM,WAAW,cAAegB,GAAMhB,EAAW,MAAM,MAAM,KAAKA,EAAW,MAAM,OAAO,SAAS,UAAiB,IAC1H,QAEFA,EAAW,MAAM,cAAc;AAAA,IACxC,GAGIiB,IAAahB,EAAwB,MAAM;AAC/C,UAAIc,EAAc,UAAU;AAC1B,eAAO,CAAA;AAGT,YAAMG,IAAaxC,EAAQsB,EAAW,MAAM,cAAc,EAAE;AAC5D,aAAIkB,IACK,EAAE,OAAOA,EAAA,IACX,CAAA;AAAA,IACT,CAAC,GAEKC,IAAelB,EAAwB,MAAM;AACjD,YAAMmB,IAAe1C,EAAQsB,EAAW,OAAO,gBAAgB,EAAE;AACjE,aAAIoB,IACK,EAAE,OAAOA,GAAc,MAAM,QAAA,IAC/B,CAAA;AAAA,IACT,CAAC,GAEKC,IAAsBpB,EAAwB,OAC3C;AAAA,MACL,gBAAgBD,EAAW,OAAO,iBAAiB,WAAW;AAAA,IAAA,EAEjE,GAEKsB,KAAarB;AAAA,MAAS,MAC1BhB,EAAM,YAAYiB,EAAM,OAAO,YAAY;AAAA,IAAA,GAGvCqB,KAAkBtB,EAAS,MAAM;AAAA,MACrCZ,EAAG,EAAA;AAAA;AAAA,MAEHA,EAAG,EAAEJ,EAAM,QAAQmB,EAAM,SAAS,SAAS;AAAA,MAC3Cf,EAAG,GAAGJ,EAAM,cAAc;AAAA,MAC1BI,EAAG,GAAG,cAAcqB,EAAc,UAAU,YAAY;AAAA,MACxDrB,EAAG,GAAG,WAAWqB,EAAc,UAAU,SAAS;AAAA,MAClDrB,EAAG,GAAG,YAAYiC,GAAW,SAASrC,EAAM,QAAQ;AAAA,MACpDI,EAAG,GAAG,eAAeW,EAAW,OAAO,oBAAoB;AAAA,MAC3DX,EAAG,GAAGW,EAAW,MAAM,cAAc;AAAA,MACrCA,EAAW,OAAO,4BAA4B,UAC1C,mBACA;AAAA,MACJ;AAAA,QACE,CAACX,EAAG,EAAE,UAAU,CAAC,GAAGW,EAAW,OAAO;AAAA,QACtC,CAACX,EAAG,EAAE,SAAS0B,EAAc,KAAK,EAAE,CAAC,GAAGA,EAAc;AAAA,MAAA;AAAA,IACxD,CACD,GAEKS,IAAkBvB,EAAS,MAAM;AAAA,MACrC,GAAGV,CAAS;AAAA,MACZF,EAAG,GAAGJ,EAAM,cAAc;AAAA,MAC1BI,EAAG,GAAG,SAASJ,EAAM,mBAAmB,OAAO;AAAA,IAAA,CAChD,GAEKwC,IAAWxB,EAAkB,MACzBhB,EAAM,UAAU,MAAMY,EAAQZ,EAAM,KAAK,KAAMY,EAAQV,EAAM,KAAK,CAC3E,GAEKuC,IAAWzB,EAA6B,MAE1ChB,EAAM,QAAQuB,EAAS,MAAM,WAAW,IAAIA,EAAS,MAAM,CAAC,IAAI,OAEnE,GAEKmB,IAAU1B,EAAkB,MACzB,CAACyB,EAAS,SAASD,EAAS,KACpC;AAED,mBAAeG,KAAiC;AAC9C,aAAO;AAAA,IACT;AAAA,IAAA;AAEA,UAAMC,KAAkD,MAAM;AAAA,IAAC;AAAA,IAAA;AAE/D,UAAMC,KAA4C,YAAY;AAAA,IAAC,GAEzDC,KAA4C,CAACC,MAAe;AAAA,MAAA;AAEhE,MAAKxB,EAAS,MAAM,SAASwB,CAAE,KAC7BxB,EAAS,MAAM,KAAKwB,CAAE;AAAA,IAE1B,GAEMC,KAAkD,CAACD,MAAe;AACtE,MAAAxB,EAAS,QAAQA,EAAS,MAAM,OAAO,CAAA0B,MAAUA,MAAWF,CAAE;AAAA,IAChE,GAEMG,IAAmB1B,EAAI,EAAK;AAClC,IAAA2B,GAAkBxB,GAAU,MAAM;AAChC,MAAAuB,EAAiB,QAAQvB,EAAS,OAAO,cAAcA,EAAS,OAAO;AAAA,IACzE,CAAC;AACD,UAAMyB,IAAapC,EAAS,MACnBkC,EAAiB,SAAS,CAACnC,EAAW,MAAM,SACpD,GAGKsC,KAAiB7B,EAA2B,EAAE,GAC9C8B,IAA2BC,GAAS;AAAA,MACxC,KAAK7B;AAAA,MACL,YAAYX,EAAW,OAAO;AAAA,MAC9B,MAAMI;AAAA,MACN,eAAekC,GAAe;AAAA,MAC9B,SAAAhC;AAAA,MACA,UAAAE;AAAA,MACA,SAAAmB;AAAA,MACA,UAAAF;AAAA,MACA,YAAAM;AAAA,MACA,eAAAE;AAAA,MACA,YAAAH;AAAA,MACA,eAAAD;AAAA,MACA,UAAAD;AAAA,MACA,eAAAb;AAAA,MACA,eAAe;AAAA,MACf,aAAa;AAAA,MACb,YAAYb,EAAM,OAAO;AAAA,MACzB,iBAAiB;AAAA,MACjB,YAAY;AAAA,IAAA,CACb;AACD,WAAAuC,GAAM,MAAMxD,EAAM,gBAAgB,CAACyD,MAAQ;AACzC,UAAIA,MAAQ,WAAW;AACrB,QAAAH,EAAQ,gBAAgB;AACxB;AAAA,MACF;AACA,UAAIG,MAAQ,WAAW;AACrB,QAAAH,EAAQ,gBAAgB;AACxB;AAAA,MACF;AACA,MAAAA,EAAQ,gBAAgBG;AAAA,IAC1B,GAAG;AAAA,MACD,WAAW;AAAA,IAAA,CACZ,GAEDC,EAAQC,IAA0BnC,EAAI;AAAA,MACpC,GAAIZ,EAAQZ,EAAM,IAAI,KAAK,EAAE,MAAMA,EAAM,KAAA;AAAA,MACzC,GAAIY,EAAQZ,EAAM,KAAK,KAAK,EAAE,OAAOA,EAAM,MAAA;AAAA,IAAM,CAClD,CAAC,GACF0D,EAAQE,IAAoBN,CAAO,mBAIjCO,EAiHM,OAAA;AAAA,eAhHA;AAAA,MAAJ,KAAInC;AAAA,MAAe,UAAQpB,GAAWS,QAAW,2BAA2BuB,GAAA,KAAe,CAAA;AAAA,MAC1F,MAAMI,EAAA,QAAO,UAAa;AAAA,MAAY,mBAAiBA,EAAA,QAAUoB,EAAAzC,CAAA,IAAU;AAAA,IAAA;MAGnCmB,EAAA,SADzCuB,EAAA,GAAAC,EAwCYC,EAvCLxB,EAAA,QAAQ,UAAA,KAAA,GAAA;AAAA;QAAqC,IAAIqB,EAAAzC,CAAA;AAAA,QAAU,KAAKoB,EAAA;AAAA,QACpE,OAAKyB,EAAA,CAAGJ,EAAA1D,CAAA,EAAG,YAAY0D,EAAAlD,CAAA,EAAQG,EAAA,MAAW,QAAQ,KAAA,GAAQT,CAAS,QAAQS,EAAA,MAAW,QAAQ,EAAA,CAAA;AAAA,QAC9F,SAAOiB,EAAA,KAAU;AAAA,MAAA;mBARV,MAIT;AAAA,UAOiBmC,EAAQnE,EAAM,KAAK,UACjCgE,EAA+BC,EAAfjE,EAAM,KAAK,GAAA,EAAA,KAAA,EAAA,CAAA,WAE7B6D,EA8BM,OAAA;AAAA;YA9BO,YAAUvD,CAAS,iBAAA;AAAA,UAAA;YAC9B8D,EAsBYN,EAAAO,CAAA,GAAA;AAAA,cAtBA,UAAQ,CAAGjB,EAAA,SAAcrC,EAAA,MAAW,kBAAa;AAAA,YAAA;cAShD,WATF,MAGiD;AAAA,gBAOxCoD,EAAQnE,EAAM,OAAO,UACnCgE,EAAiCC,EAAjBjE,EAAM,OAAO,GAAA,EAAA,KAAA,EAAA,CAAA,WAE/B6D,EAOM,OAAA;AAAA;kBAPO,OAAKS,EAAA,UAAY3C,EAAA,OAAU,eAAW,CAAA,KAAA;AAAA,gBAAA;kBACjCyB,EAAA,cAAhBS,EAEWU,GAAA,EAAA,KAAA,KAAA;AAAA,oBADNC,EAAAC,EAAAzE,EAAM,KAAK,GAAA,CAAA;AAAA,kBAAA;kBAEAe,EAAA,MAAW,kBAAa,eAAxC8C,EAEWU,GAAA,EAAA,KAAA,KAAA;AAAA,oBADNC,EAAAC,EAAAzE,EAAM,OAAO,GAAA,CAAA;AAAA,kBAAA;;;yBAjBtB,MAOO;AAAA,gBAPP0E,EAOO,QAAA;AAAA,kBANJ,OAAKR,EAAA;AAAA,wBAAuB5D,CAAS,gBAAA,GAAA;AAAA,oBAAwD,cAAA8C,EAAA,SAAepD,EAAM,WAAWe,EAAA,MAAW,kBAAa;AAAA,kBAAA;;kBAKtJ2D,EAA6C,QAAA;AAAA,6BAAnC;AAAA,oBAAJ,KAAI/C;AAAA,kBAAA,GAAc8C,EAAAzE,EAAM,KAAK,GAAA,GAAA;AAAA,gBAAA;;;;YAgBtBA,EAAM,WAAWe,EAAA,MAAW,kBAAa,eAA1DiD,EAIYF,EAAAO,CAAA,GAAA;AAAA;cAJ4D,SAASrE,EAAM;AAAA,YAAA;yBACrF,MAES;AAAA,gBAFToE,EAESN,EAAAa,CAAA,GAAA;AAAA,kBAFA,YAAUrE,CAAS,gBAAA;AAAA,gBAAA;6BAC1B,MAAc;AAAA,oBAAd8D,EAAcN,EAAAc,EAAA,CAAA;AAAA,kBAAA;;;;;;YAGN5E,EAAM,cAAlB6D,EAA+D,QAAA;AAAA;cAArC,YAAUvD,CAAS,QAAA;AAAA,YAAA,GAAU,KAAC,CAAA;;;;;MAI5DoE,EAkEM,OAAA;AAAA,QAjEH,OAAKR,EAAA;AAAA,aAAgB5D,CAAS;AAAA,UAA8BwD,EAAAlD,CAAA,EAAQG,QAAW,UAAU,QAAQT,CAAS,QAAQS,EAAA,MAAW,UAAU;AAAA,QAAA;QAIvI,SAAOqB,EAAA,KAAmB;AAAA,MAAA;QAEX0B,EAAAlD,CAAA,EAAQZ,EAAM,WAAW,UAAzC6D,EAOWU,GAAA,EAAA,KAAA,KAAA;AAAA,UANOJ,EAAQnE,EAAM,WAAW,UACvCgE,EAAqCC,EAArBjE,EAAM,WAAW,GAAA,EAAA,KAAA,EAAA,CAAA,WAEnC6D,EAEM,OAAA;AAAA;YAFO,YAAUvD,CAAS,eAAA;AAAA,UAAA,GAC3BmE,EAAAzE,EAAM,WAAW,GAAA,CAAA;AAAA,QAAA;QAGxB0E,EA0CM,OAAA;AAAA,UAzCH,OAAKR,EAAA;AAAA,YAAeJ,EAAA1D,CAAA,EAAG,EAAC,SAAA;AAAA,YAAwBW,EAAA,MAAW,YAAQ;AAAA,YAA8B+C,EAAA1D,CAAA,EAAG,GAAE,eAAA,CAAA,CAAkBJ,EAAM,UAAU;AAAA,UAAA;UAIrI,SAAOkC,EAAA,KAAY;AAAA,QAAA;UAGflC,EAAM,mBAAc,kBAD5BgE,EAoBYF,EAAAO,CAAA,GAAA;AAAA;qBAlBN;AAAA,YAAJ,KAAIzC;AAAA,YACH,SAAO,CAAA,CAAI5B,EAAM;AAAA,YAClB,QAAO;AAAA,YACN,QAAQ;AAAA,UAAA;YAEE,WACT,MAAQ;AAAA,cAAR6E,EAAQC,EAAA,QAAA,SAAA;AAAA,YAAA;YAEC,WACT,MAOM;AAAA,cAPNJ,EAOM,OAAA;AAAA,gBAPA,OAAKR,EAAA,CAAA,GAAM3B,EAAA,OAAiBuB,EAAA1D,CAAA,EAAG,GAAE,SAAA,CAAA,CAAA;AAAA,cAAA;gBACrCgE,EAISN,EAAAa,CAAA,GAAA,MAAA;AAAA,6BAbD,MAAuD;AAAA,oBAU1C3E,EAAM,mBAAc,gBAAvCgE,EAAuDF,EAAAiB,EAAA,GAAA,EAAA,KAAA,EAAA,CAAA;oBACpC/E,EAAM,mBAAc,kBAAvCgE,EAAyDF,EAAAkB,EAAA,GAAA,EAAA,KAAA,EAAA,CAAA;oBAC1ChF,EAAM,mBAAc,kBAAnCgE,EAAqDF,EAAAmB,EAAA,GAAA,EAAA,KAAA,EAAA,CAAA;;;;kBAC9C,MACTR,EAAGzE,EAAM,YAAY,GAAA,CAAA;AAAA,cAAA;;;gCAI3B6E,EAAeC,EAAA,QAAA,WAAA,EAAA,KAAA,GAAA;AAAA,UACfV,EAYkBc,IAAA;AAAA,YAZA,MAAI,GAAKpB,EAAA1D,CAAA,EAAG,UAAU,KAAK;AAAA,UAAA;uBATrC,MAIkC;AAAA,cAM7BJ,EAAM,gBAAgBA,EAAM,mBAAc,kBAArD6D,EAEM,OAAA;AAAA;gBAFgE,SAAOtB,EAAA,KAAe;AAAA,cAAA,GACvFkC,EAAAzE,EAAM,YAAY,GAAA,CAAA;cAEP8D,EAAAlD,CAAA,EAAQZ,EAAM,KAAK,UAAnC6D,EAOWU,GAAA,EAAA,KAAA,KAAA;AAAA,gBANOJ,EAAQnE,EAAM,KAAK,UACjCgE,EAA+BC,EAAfjE,EAAM,KAAK,GAAA,EAAA,KAAA,EAAA,CAAA,WAE7B6D,EAEM,OAAA;AAAA;kBAFO,YAAUvD,CAAS,QAAA;AAAA,gBAAA,GAC3BmE,EAAAzE,EAAM,KAAK,GAAA,CAAA;AAAA,cAAA;;;;;QAKN8D,EAAAlD,CAAA,EAAQZ,EAAM,UAAU,UAAxC6D,EAOWU,GAAA,EAAA,KAAA,KAAA;AAAA,UANOJ,EAAQnE,EAAM,UAAU,UACtCgE,EAAoCC,EAApBjE,EAAM,UAAU,GAAA,EAAA,KAAA,EAAA,CAAA,WAElC6D,EAEM,OAAA;AAAA;YAFO,YAAUvD,CAAS,cAAA;AAAA,UAAA,GAC3BmE,EAAAzE,EAAM,UAAU,GAAA,CAAA;AAAA,QAAA;;;;;ACpUtB,SAASmF,GAAoBnF,GAAOiB,GAAO;AAChD,MAAImE,GAAYnE,CAAK,KAAK,CAACA;AACzB,WAAOjB;AAGT,QAAMqF,IAAeC,GAAmBrE,CAAK,GACvCsE,IAAiBC,GAAwBvE,CAAK,GAC9CwE,IAAW,cAAczF,IAC3BA,EAAM,WACNiB,EAAM,YAAYA,EAAM,YAAY;AAExC,SAAO;AAAA,IACL,GAAGjB;AAAA,IACH,cAAAqF;AAAA,IACA,gBAAAE;AAAA,IACA,UAAAE;AAAA,EAAA;AAEJ;AAEA,MAAMC,KAAOC;AAAA,EACXC;AAAAA,EACAC;AAAA,IACE;AAAA,MACE,gBAAgB;AAAA,MAChB,OAAO;AAAA,MACP,UAAU;AAAA,MACV,aAAa;AAAA,IAAA;AAAA,IAEfV;AAAA,EAAA;AAEJ,GAEaW,KAAWC,GAAcL,IAAM;AAAA,EAC1C,UAAUE;AACZ,CAAC;","x_google_ignoreList":[0]}
|
|
1
|
+
{"version":3,"file":"index.mjs","sources":["../../node_modules/.pnpm/element-plus@2.13.2_vue@3.5.22_typescript@5.9.3_/node_modules/element-plus/es/utils/dom/style.mjs","../../src/form-item/form-item.vue","../../src/form-item/index.ts"],"sourcesContent":["import { isNumber, isStringNumber } from '../types.mjs';\nimport { isClient } from '@vueuse/core';\nimport { isString, camelize, isObject } from '@vue/shared';\nimport { entriesOf, keysOf } from '../objects.mjs';\nimport { debugWarn } from '../error.mjs';\n\nconst SCOPE = \"utils/dom/style\";\nconst classNameToArray = (cls = \"\") => cls.split(\" \").filter((item) => !!item.trim());\nconst hasClass = (el, cls) => {\n if (!el || !cls) return false;\n if (cls.includes(\" \")) throw new Error(\"className should not contain space.\");\n return el.classList.contains(cls);\n};\nconst addClass = (el, cls) => {\n if (!el || !cls.trim()) return;\n el.classList.add(...classNameToArray(cls));\n};\nconst removeClass = (el, cls) => {\n if (!el || !cls.trim()) return;\n el.classList.remove(...classNameToArray(cls));\n};\nconst getStyle = (element, styleName) => {\n var _a;\n if (!isClient || !element || !styleName) return \"\";\n let key = camelize(styleName);\n if (key === \"float\") key = \"cssFloat\";\n try {\n const style = element.style[key];\n if (style) return style;\n const computed = (_a = document.defaultView) == null ? void 0 : _a.getComputedStyle(element, \"\");\n return computed ? computed[key] : \"\";\n } catch (e) {\n return element.style[key];\n }\n};\nconst setStyle = (element, styleName, value) => {\n if (!element || !styleName) return;\n if (isObject(styleName)) {\n entriesOf(styleName).forEach(\n ([prop, value2]) => setStyle(element, prop, value2)\n );\n } else {\n const key = camelize(styleName);\n element.style[key] = value;\n }\n};\nconst removeStyle = (element, style) => {\n if (!element || !style) return;\n if (isObject(style)) {\n keysOf(style).forEach((prop) => removeStyle(element, prop));\n } else {\n setStyle(element, style, \"\");\n }\n};\nfunction addUnit(value, defaultUnit = \"px\") {\n if (!value && value !== 0) return \"\";\n if (isNumber(value) || isStringNumber(value)) {\n return `${value}${defaultUnit}`;\n } else if (isString(value)) {\n return value;\n }\n debugWarn(SCOPE, \"binding value must be a string or number\");\n}\n\nexport { addClass, addUnit, classNameToArray, getStyle, hasClass, removeClass, removeStyle, setStyle };\n//# sourceMappingURL=style.mjs.map\n","<script lang=\"ts\" setup>\r\nimport type { Field } from '@formily/core'\r\nimport type {\r\n FormItemContext,\r\n FormItemValidateState,\r\n FormValidationResult,\r\n TooltipInstance,\r\n} from 'element-plus'\r\nimport type { ICalculatedFormLayoutProps } from 'src/form-layout/types'\r\nimport type { CSSProperties } from 'vue'\r\nimport type { IFormItemProps } from './types'\r\nimport { CircleCheck, CircleClose, InfoFilled, Warning } from '@element-plus/icons-vue'\r\nimport { isArr, isValid } from '@formily/shared'\r\nimport { useField } from '@silver-formily/vue'\r\nimport { ElIcon, ElTooltip, formItemContextKey, useFormSize, useId, useNamespace } from 'element-plus'\r\nimport { addUnit } from 'element-plus/es/utils/index'\r\nimport { pick } from 'lodash-es'\r\nimport { computed, isVNode, provide, reactive, ref, useSlots, watch } from 'vue'\r\nimport { stylePrefix, useResizeObserver } from '../__builtins__'\r\nimport { FORM_LAYOUT_PROPS_KEYS, formLayoutShallowContext, useFormLayout } from '../form-layout/utils'\r\n\r\ndefineOptions({\r\n name: 'FFormItem',\r\n})\r\nconst props = withDefaults(defineProps<IFormItemProps>(), {\r\n asterisk: undefined,\r\n colon: undefined,\r\n labelWrap: undefined,\r\n fullness: undefined,\r\n})\r\nconst slots = useSlots()\r\nconst ns = useNamespace('form-item')\r\nconst prefixCls = `${stylePrefix}-form-item`\r\nconst formItemConfig = computed<Partial<ICalculatedFormLayoutProps>>(() =>\r\n Object.fromEntries(\r\n Object.entries(pick(props, FORM_LAYOUT_PROPS_KEYS))\r\n .filter(([_, value]) => isValid(value)),\r\n ),\r\n)\r\nconst formlayoutConfig = useFormLayout()\r\nconst formlayout = computed(() => Object.assign({\r\n colon: true,\r\n feedbackLayout: 'loose',\r\n fullness: false,\r\n labelWrap: false,\r\n}, formlayoutConfig.value, formItemConfig.value))\r\nconst field = useField<Field>()\r\n\r\nconst inheritedSize = useFormSize(undefined, { formItem: false })\r\nconst formItemSize = computed(() => {\r\n if (isValid(formlayout.value.size)) {\r\n return formlayout.value.size\r\n }\r\n return inheritedSize.value\r\n})\r\n\r\nconst labelId = useId().value\r\nconst inputIds = ref<string[]>([])\r\n\r\nconst validateState = ref<FormItemValidateState>('')\r\nconst formItemRef = ref<HTMLDivElement>()\r\nconst labelRef = ref<HTMLElement>()\r\nconst feedbackTooltipRef = ref<TooltipInstance>()\r\ndefineExpose({\r\n feedbackTooltipRef,\r\n})\r\n\r\nconst labelPosition = computed(\r\n () => {\r\n if (formlayout.value.layout === 'vertical' || (isArr(formlayout.value.layout) && formlayout.value.layout.includes('vertical' as any))) {\r\n return 'top'\r\n }\r\n return formlayout.value.labelAlign ?? 'right'\r\n },\r\n)\r\n\r\nconst labelStyle = computed<CSSProperties>(() => {\r\n if (labelPosition.value === 'top') {\r\n return {}\r\n }\r\n\r\n const labelWidth = addUnit(formlayout.value.labelWidth || '')\r\n if (labelWidth)\r\n return { width: labelWidth }\r\n return {}\r\n})\r\n\r\nconst contentStyle = computed<CSSProperties>(() => {\r\n const contentWidth = addUnit(formlayout.value?.wrapperWidth || '')\r\n if (contentWidth)\r\n return { width: contentWidth, flex: 'unset' }\r\n return {}\r\n})\r\n\r\nconst contentWrapperStyle = computed<CSSProperties>(() => {\r\n return {\r\n justifyContent: formlayout.value?.wrapperAlign === 'right' && 'flex-end',\r\n }\r\n})\r\n\r\nconst isRequired = computed(() =>\r\n props.asterisk && field.value?.pattern !== 'readPretty',\r\n)\r\n\r\nconst formItemClasses = computed(() => [\r\n ns.b(),\r\n ns.m(formItemSize.value || 'default'),\r\n ns.is(props.feedbackStatus),\r\n ns.is('validating', validateState.value === 'validating'),\r\n ns.is('success', validateState.value === 'success'),\r\n ns.is('required', isRequired.value || props.asterisk),\r\n ns.is('no-asterisk', formlayout.value?.hideRequiredAsterisk),\r\n ns.is(formlayout.value.feedbackLayout),\r\n formlayout.value?.requireAsteriskPosition === 'right'\r\n ? 'asterisk-right'\r\n : 'asterisk-left',\r\n {\r\n [ns.m('feedback')]: formlayout.value?.statusIcon,\r\n [ns.m(`label-${labelPosition.value}`)]: labelPosition.value,\r\n },\r\n])\r\n\r\nconst validateClasses = computed(() => [\r\n `${prefixCls}-feedback`,\r\n ns.is(props.feedbackStatus),\r\n ns.is('loose', formlayout.value.feedbackLayout === 'loose'),\r\n])\r\n\r\nconst hasLabel = computed<boolean>(() => {\r\n return (props.label !== '' && isValid(props.label)) || isValid(slots.label)\r\n})\r\n\r\nconst labelFor = computed<string | undefined>(() => {\r\n return (\r\n props.for || (inputIds.value.length === 1 ? inputIds.value[0] : undefined)\r\n )\r\n})\r\n\r\nconst isGroup = computed<boolean>(() => {\r\n return !labelFor.value && hasLabel.value\r\n})\r\n\r\nasync function validate(): FormValidationResult {\r\n return true\r\n}\r\n/* istanbul ignore next -- @preserve */\r\nconst clearValidate: FormItemContext['clearValidate'] = () => {}\r\n/* istanbul ignore next -- @preserve */\r\nconst resetField: FormItemContext['resetField'] = async () => {}\r\n/* istanbul ignore next -- @preserve */\r\nconst setInitialValue: FormItemContext['setInitialValue'] = () => {}\r\n\r\nconst addInputId: FormItemContext['addInputId'] = (id: string) => {\r\n /* istanbul ignore else -- @preserve */\r\n if (!inputIds.value.includes(id)) {\r\n inputIds.value.push(id)\r\n }\r\n}\r\n\r\nconst removeInputId: FormItemContext['removeInputId'] = (id: string) => {\r\n inputIds.value = inputIds.value.filter(listId => listId !== id)\r\n}\r\n\r\nconst isEllipsisActive = ref(false)\r\nuseResizeObserver(labelRef, () => {\r\n isEllipsisActive.value = labelRef.value?.scrollWidth > labelRef.value?.clientWidth\r\n})\r\nconst isEllipsis = computed(() => {\r\n return isEllipsisActive.value && !formlayout.value.labelWrap\r\n})\r\n\r\n// HACK computed无法监听到props.feedbackStatus的变化\r\nconst _validateState = ref<FormItemValidateState>('')\r\nconst context: FormItemContext = reactive({\r\n $el: formItemRef,\r\n labelWidth: formlayout.value?.labelWidth,\r\n size: formItemSize,\r\n validateState: _validateState.value,\r\n labelId,\r\n inputIds,\r\n isGroup,\r\n hasLabel,\r\n addInputId,\r\n removeInputId,\r\n resetField,\r\n clearValidate,\r\n validate,\r\n labelPosition,\r\n inlineMessage: true,\r\n showMessage: true,\r\n fieldValue: field.value?.value,\r\n validateMessage: '',\r\n propString: '',\r\n setInitialValue,\r\n})\r\nwatch(() => props.feedbackStatus, (val) => {\r\n if (val === 'pending') {\r\n context.validateState = 'validating'\r\n return\r\n }\r\n if (val === 'warning') {\r\n context.validateState = ''\r\n return\r\n }\r\n context.validateState = val\r\n}, {\r\n immediate: true,\r\n})\r\n\r\nprovide(formLayoutShallowContext, ref({\r\n ...(isValid(formlayout.value.size) && { size: formlayout.value.size }),\r\n ...(isValid(formlayout.value.colon) && { colon: formlayout.value.colon }),\r\n}))\r\nprovide(formItemContextKey, context)\r\n</script>\r\n\r\n<template>\r\n <div\r\n ref=\"formItemRef\" :class=\"[prefixCls, formlayout.labelWrap && 'is-warp', ...formItemClasses]\"\r\n :role=\"isGroup ? 'group' : undefined\" :aria-labelledby=\"isGroup ? labelId : undefined\"\r\n >\r\n <component\r\n :is=\"labelFor ? 'label' : 'div'\" v-if=\"hasLabel\" :id=\"labelId\" :for=\"labelFor\"\r\n :class=\"[ns.e('label'), isValid(formlayout.labelCol) && `${prefixCls}-col-${formlayout.labelCol}`]\"\r\n :style=\"labelStyle\"\r\n >\r\n <!-- label -->\r\n <template v-if=\"isVNode(props.label)\">\r\n <component :is=\"props.label\" />\r\n </template>\r\n <div v-else :class=\"`${prefixCls}-label__wrapper`\">\r\n <ElTooltip :disabled=\"!isEllipsis && formlayout.tooltipLayout !== 'text'\">\r\n <span\r\n :class=\"{\r\n [`${prefixCls}-label-content`]: true,\r\n ['is-tooltip']: isEllipsis || (props.tooltip && formlayout.tooltipLayout === 'text'),\r\n }\"\r\n >\r\n <span ref=\"labelRef\">{{ props.label }}</span>\r\n </span>\r\n <template #content>\r\n <template v-if=\"isVNode(props.tooltip)\">\r\n <component :is=\"props.tooltip\" />\r\n </template>\r\n <div v-else :style=\"`width: ${labelRef?.clientWidth ?? 0}px;`\">\r\n <template v-if=\"isEllipsis\">\r\n {{ props.label }}\r\n </template>\r\n <template v-if=\"formlayout.tooltipLayout === 'text'\">\r\n {{ props.tooltip }}\r\n </template>\r\n </div>\r\n </template>\r\n </ElTooltip>\r\n <ElTooltip v-if=\"props.tooltip && formlayout.tooltipLayout !== 'text'\" :content=\"props.tooltip\">\r\n <ElIcon :class=\"`${prefixCls}-label-tooltip`\">\r\n <InfoFilled />\r\n </ElIcon>\r\n </ElTooltip>\r\n <span v-if=\"formlayout.colon\" :class=\"`${prefixCls}-colon`\">:</span>\r\n </div>\r\n </component>\r\n <!-- content -->\r\n <div\r\n :class=\"[\r\n `${prefixCls}-content__wrapper`,\r\n isValid(formlayout.wrapperCol) && `${prefixCls}-col-${formlayout.wrapperCol}`,\r\n ]\"\r\n :style=\"contentWrapperStyle\"\r\n >\r\n <template v-if=\"isValid(props.addonBefore)\">\r\n <template v-if=\"isVNode(props.addonBefore)\">\r\n <component :is=\"props.addonBefore\" />\r\n </template>\r\n <div v-else :class=\"`${prefixCls}-addon-before`\">\r\n {{ props.addonBefore }}\r\n </div>\r\n </template>\r\n <div\r\n :class=\"[\r\n ns.e('content'),\r\n formlayout.fullness && 'is-fullness',\r\n ns.is('addon-after', !!props.addonAfter),\r\n ]\" :style=\"contentStyle\"\r\n >\r\n <ElTooltip\r\n v-if=\"formlayout.feedbackLayout === 'popover'\"\r\n ref=\"feedbackTooltipRef\"\r\n :visible=\"!!props.feedbackText\"\r\n effect=\"light\"\r\n :offset=\"6\"\r\n >\r\n <template #default>\r\n <slot />\r\n </template>\r\n <template #content>\r\n <div :class=\"[...validateClasses, ns.is('tooltip')]\">\r\n <ElIcon>\r\n <CircleClose v-if=\"props.feedbackStatus === 'error'\" />\r\n <CircleCheck v-if=\"props.feedbackStatus === 'success'\" />\r\n <Warning v-if=\"props.feedbackStatus === 'warning'\" />\r\n </ElIcon>\r\n {{ props.feedbackText }}\r\n </div>\r\n </template>\r\n </ElTooltip>\r\n <slot v-else />\r\n <TransitionGroup :name=\"`${ns.namespace.value}-zoom-in-top`\">\r\n <div v-if=\"props.feedbackText && formlayout.feedbackLayout !== 'popover'\" :class=\"validateClasses\">\r\n {{ props.feedbackText }}\r\n </div>\r\n <template v-if=\"isValid(props.extra)\">\r\n <template v-if=\"isVNode(props.extra)\">\r\n <component :is=\"props.extra\" />\r\n </template>\r\n <div v-else :class=\"`${prefixCls}-extra`\">\r\n {{ props.extra }}\r\n </div>\r\n </template>\r\n </TransitionGroup>\r\n </div>\r\n <template v-if=\"isValid(props.addonAfter)\">\r\n <template v-if=\"isVNode(props.addonAfter)\">\r\n <component :is=\"props.addonAfter\" />\r\n </template>\r\n <div v-else :class=\"`${prefixCls}-addon-after`\">\r\n {{ props.addonAfter }}\r\n </div>\r\n </template>\r\n </div>\r\n </div>\r\n</template>\r\n","import { isVoidField } from '@formily/core'\r\nimport { connect, mapProps } from '@silver-formily/vue'\r\nimport { composeExport } from '../__builtins__'\r\nimport FormBaseItem from './form-item.vue'\r\nimport { determineFeedbackStatus, getFeedbackMessage } from './utils'\r\nimport './style.scss'\r\n\r\nexport function fieldFeedbackMapper(props, field) {\r\n if (isVoidField(field) || !field) {\r\n return props\r\n }\r\n\r\n const feedbackText = getFeedbackMessage(field)\r\n const feedbackStatus = determineFeedbackStatus(field)\r\n const asterisk = 'asterisk' in props\r\n ? props.asterisk\r\n : field.required && field.pattern !== 'readPretty'\r\n\r\n return {\r\n ...props,\r\n feedbackText,\r\n feedbackStatus,\r\n asterisk,\r\n }\r\n}\r\n\r\nconst Item = connect<typeof FormBaseItem>(\r\n FormBaseItem,\r\n mapProps(\r\n {\r\n validateStatus: true,\r\n title: 'label',\r\n required: true,\r\n description: 'extra',\r\n },\r\n fieldFeedbackMapper,\r\n ),\r\n)\r\n\r\nexport const FormItem = composeExport(Item, {\r\n BaseItem: FormBaseItem,\r\n})\r\n\r\nexport default FormItem\r\n\r\nexport { default as FormBaseItem } from './form-item.vue'\r\n"],"names":["SCOPE","addUnit","value","defaultUnit","isNumber","isStringNumber","isString","debugWarn","props","__props","slots","useSlots","ns","useNamespace","prefixCls","stylePrefix","formItemConfig","computed","pick","FORM_LAYOUT_PROPS_KEYS","_","isValid","formlayoutConfig","useFormLayout","formlayout","field","useField","inheritedSize","useFormSize","formItemSize","labelId","useId","inputIds","ref","validateState","formItemRef","labelRef","feedbackTooltipRef","__expose","labelPosition","isArr","labelStyle","labelWidth","contentStyle","contentWidth","contentWrapperStyle","isRequired","formItemClasses","validateClasses","hasLabel","labelFor","isGroup","validate","clearValidate","resetField","setInitialValue","addInputId","id","removeInputId","listId","isEllipsisActive","useResizeObserver","isEllipsis","_validateState","context","reactive","watch","val","provide","formLayoutShallowContext","formItemContextKey","_createElementBlock","_unref","_openBlock","_createBlock","_resolveDynamicComponent","_normalizeClass","isVNode","_createVNode","ElTooltip","_normalizeStyle","_Fragment","_createTextVNode","_toDisplayString","_createElementVNode","ElIcon","InfoFilled","_renderSlot","_ctx","CircleClose","CircleCheck","Warning","_TransitionGroup","fieldFeedbackMapper","isVoidField","feedbackText","getFeedbackMessage","feedbackStatus","determineFeedbackStatus","asterisk","Item","connect","FormBaseItem","mapProps","FormItem","composeExport"],"mappings":"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","x_google_ignoreList":[0]}
|