y-design-ssr 0.2.0 → 0.2.2
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/libs/button/index.css +579 -1
- package/libs/button/index.mjs +111 -66
- package/libs/button/index.umd.js +203 -2
- package/libs/cell/index.css +1077 -1
- package/libs/cell/index.mjs +167 -104
- package/libs/cell/index.umd.js +300 -2
- package/libs/checkbox/index.css +1053 -1
- package/libs/checkbox/index.mjs +242 -127
- package/libs/checkbox/index.umd.js +369 -2
- package/libs/checkboxGroup/index.css +422 -1
- package/libs/checkboxGroup/index.mjs +173 -87
- package/libs/checkboxGroup/index.umd.js +265 -2
- package/libs/col/index.css +615 -1
- package/libs/col/index.mjs +246 -81
- package/libs/col/index.umd.js +305 -2
- package/libs/countdown/index.css +417 -1
- package/libs/countdown/index.mjs +179 -71
- package/libs/countdown/index.umd.js +231 -2
- package/libs/dialog/index.css +1405 -1
- package/libs/dialog/index.mjs +646 -476
- package/libs/dialog/index.umd.js +1128 -2
- package/libs/empty/index.css +457 -1
- package/libs/empty/index.mjs +91 -44
- package/libs/empty/index.umd.js +139 -2
- package/libs/form/index.css +477 -1
- package/libs/form/index.mjs +226 -126
- package/libs/form/index.umd.js +319 -2
- package/libs/formItem/index.css +477 -1
- package/libs/formItem/index.mjs +276 -126
- package/libs/formItem/index.umd.js +372 -2
- package/libs/icon/index.css +982 -1
- package/libs/icon/index.mjs +107 -58
- package/libs/icon/index.umd.js +186 -2
- package/libs/index.css +2902 -1
- package/libs/index.mjs +3785 -2344
- package/libs/index.umd.js +5509 -2
- package/libs/input/index.css +483 -1
- package/libs/input/index.mjs +183 -92
- package/libs/input/index.umd.js +274 -2
- package/libs/layout/index.css +684 -1
- package/libs/layout/index.mjs +230 -130
- package/libs/layout/index.umd.js +318 -2
- package/libs/list/index.css +440 -1
- package/libs/list/index.mjs +388 -207
- package/libs/list/index.umd.js +571 -2
- package/libs/loading/index.css +548 -1
- package/libs/loading/index.mjs +196 -118
- package/libs/loading/index.umd.js +321 -2
- package/libs/mask/index.css +426 -1
- package/libs/mask/index.mjs +131 -70
- package/libs/mask/index.umd.js +201 -2
- package/libs/popup/index.css +465 -1
- package/libs/popup/index.mjs +210 -134
- package/libs/popup/index.umd.js +358 -2
- package/libs/progress/index.css +488 -1
- package/libs/progress/index.mjs +200 -128
- package/libs/progress/index.umd.js +322 -2
- package/libs/pullrefresh/index.css +441 -1
- package/libs/pullrefresh/index.mjs +241 -111
- package/libs/pullrefresh/index.umd.js +302 -2
- package/libs/row/index.css +485 -1
- package/libs/row/index.mjs +181 -89
- package/libs/row/index.umd.js +237 -2
- package/libs/slider/index.css +558 -1
- package/libs/slider/index.mjs +356 -160
- package/libs/slider/index.umd.js +453 -2
- package/libs/stepper/index.css +489 -1
- package/libs/stepper/index.mjs +181 -101
- package/libs/stepper/index.umd.js +269 -2
- package/libs/swipe/index.css +506 -1
- package/libs/swipe/index.mjs +542 -259
- package/libs/swipe/index.umd.js +703 -2
- package/libs/swipeItem/index.css +424 -1
- package/libs/swipeItem/index.mjs +111 -52
- package/libs/swipeItem/index.umd.js +154 -2
- package/libs/switch/index.css +472 -1
- package/libs/switch/index.mjs +121 -62
- package/libs/switch/index.umd.js +200 -2
- package/libs/tab/index.mjs +131 -68
- package/libs/tab/index.umd.js +190 -1
- package/libs/tabs/index.css +514 -1
- package/libs/tabs/index.mjs +751 -410
- package/libs/tabs/index.umd.js +1020 -2
- package/libs/toast/index.css +1050 -1
- package/libs/toast/index.mjs +183 -114
- package/libs/toast/index.umd.js +306 -2
- package/libs/tooltip/index.css +514 -1
- package/libs/tooltip/index.mjs +293 -155
- package/libs/tooltip/index.umd.js +416 -2
- package/package.json +5 -4
- package/libs/button/package.json +0 -5
- package/libs/cell/package.json +0 -5
- package/libs/checkbox/package.json +0 -5
- package/libs/checkboxGroup/package.json +0 -5
- package/libs/col/package.json +0 -5
- package/libs/countdown/package.json +0 -5
- package/libs/dialog/package.json +0 -5
- package/libs/empty/package.json +0 -5
- package/libs/form/package.json +0 -5
- package/libs/formItem/package.json +0 -5
- package/libs/icon/package.json +0 -5
- package/libs/input/package.json +0 -5
- package/libs/layout/package.json +0 -5
- package/libs/list/package.json +0 -5
- package/libs/loading/package.json +0 -5
- package/libs/mask/package.json +0 -5
- package/libs/popup/package.json +0 -5
- package/libs/progress/package.json +0 -5
- package/libs/pullrefresh/package.json +0 -5
- package/libs/row/package.json +0 -5
- package/libs/slider/package.json +0 -5
- package/libs/stepper/package.json +0 -5
- package/libs/swipe/package.json +0 -5
- package/libs/swipeItem/package.json +0 -5
- package/libs/switch/package.json +0 -5
- package/libs/tab/package.json +0 -5
- package/libs/tabs/package.json +0 -5
- package/libs/toast/package.json +0 -5
- package/libs/tooltip/package.json +0 -5
package/libs/tooltip/index.mjs
CHANGED
|
@@ -1,11 +1,40 @@
|
|
|
1
|
-
import { ref
|
|
2
|
-
const
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
}
|
|
1
|
+
import { ref, reactive, defineComponent, getCurrentInstance, watch, onMounted, onBeforeUnmount, createVNode, Teleport, withDirectives, vShow, nextTick, onBeforeUpdate, Fragment, mergeProps, isVNode, h, render } from "vue";
|
|
2
|
+
const getMods = (el, mods) => {
|
|
3
|
+
if (!mods) {
|
|
4
|
+
return "";
|
|
5
|
+
}
|
|
6
|
+
if (typeof mods === "string") {
|
|
7
|
+
return ` ${el}--${mods}`;
|
|
8
|
+
}
|
|
9
|
+
if (Array.isArray(mods)) {
|
|
10
|
+
return mods.reduce((acc, cur) => acc + getMods(el, cur), "");
|
|
11
|
+
}
|
|
12
|
+
return Object.keys(mods).reduce(
|
|
13
|
+
(acc, cur) => acc + (mods[cur] ? getMods(el, cur) : ""),
|
|
14
|
+
""
|
|
15
|
+
);
|
|
16
|
+
};
|
|
17
|
+
const createBEM = (block) => {
|
|
18
|
+
return (el, mods) => {
|
|
19
|
+
let _el = el;
|
|
20
|
+
let _mods = mods;
|
|
21
|
+
if (_el && typeof _el !== "string") {
|
|
22
|
+
_mods = _el;
|
|
23
|
+
_el = "";
|
|
24
|
+
}
|
|
25
|
+
_el = _el ? `${block}__${_el}` : block;
|
|
26
|
+
return `${_el}${getMods(_el, _mods)}`;
|
|
27
|
+
};
|
|
28
|
+
};
|
|
29
|
+
const createGlobalBem = () => {
|
|
30
|
+
return (el, mods) => {
|
|
31
|
+
if (!mods) {
|
|
32
|
+
return `y-${el}`;
|
|
33
|
+
}
|
|
34
|
+
return `${getMods(`y-${el}`, mods)}`;
|
|
35
|
+
};
|
|
36
|
+
};
|
|
37
|
+
const defaultLang = {
|
|
9
38
|
"pull-refresh": {
|
|
10
39
|
pulling: "下拉刷新...",
|
|
11
40
|
loosing: "释放刷新...",
|
|
@@ -17,23 +46,30 @@ const b = (e, t) => t ? typeof t == "string" ? ` ${e}--${t}` : Array.isArray(t)
|
|
|
17
46
|
validateMessage: "请输入正确内容"
|
|
18
47
|
}
|
|
19
48
|
};
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
"zh-CN":
|
|
49
|
+
ref("zh-CN");
|
|
50
|
+
reactive({
|
|
51
|
+
"zh-CN": defaultLang
|
|
23
52
|
});
|
|
24
|
-
const
|
|
25
|
-
const
|
|
26
|
-
return [
|
|
27
|
-
}
|
|
53
|
+
const createNamespace = (name2) => {
|
|
54
|
+
const prefixedName = `y-${name2}`;
|
|
55
|
+
return [prefixedName, createBEM(prefixedName), createGlobalBem()];
|
|
56
|
+
};
|
|
57
|
+
const parseUnit = (val) => {
|
|
58
|
+
if (isNaN(Number(val)) && typeof val === "string") {
|
|
59
|
+
return val;
|
|
60
|
+
}
|
|
61
|
+
return `${val}px`;
|
|
62
|
+
};
|
|
63
|
+
const tooltipProps = {
|
|
28
64
|
// 是否显示
|
|
29
65
|
modelValue: {
|
|
30
66
|
type: Boolean,
|
|
31
|
-
default:
|
|
67
|
+
default: false
|
|
32
68
|
},
|
|
33
69
|
// 是否只能通过 v-model 控制显隐
|
|
34
70
|
manual: {
|
|
35
71
|
type: Boolean,
|
|
36
|
-
default:
|
|
72
|
+
default: false
|
|
37
73
|
},
|
|
38
74
|
text: {
|
|
39
75
|
type: String,
|
|
@@ -71,7 +107,7 @@ const F = (e) => {
|
|
|
71
107
|
// 当tooltip显示超出视窗时会自动在另一侧渲染
|
|
72
108
|
autoFlipping: {
|
|
73
109
|
type: Boolean,
|
|
74
|
-
default:
|
|
110
|
+
default: true
|
|
75
111
|
},
|
|
76
112
|
// 展示位置
|
|
77
113
|
position: {
|
|
@@ -79,194 +115,296 @@ const F = (e) => {
|
|
|
79
115
|
default: "top"
|
|
80
116
|
/* Top */
|
|
81
117
|
}
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
118
|
+
};
|
|
119
|
+
const [name$1, bem] = createNamespace("popper");
|
|
120
|
+
const getNoStaticParent = (el) => {
|
|
121
|
+
if (!el.parentElement)
|
|
122
|
+
return el;
|
|
123
|
+
if (getComputedStyle(el.parentElement).position !== "static")
|
|
124
|
+
return el.parentElement;
|
|
125
|
+
return getNoStaticParent(el.parentElement);
|
|
126
|
+
};
|
|
127
|
+
const getElementToPageTop = (el, offsetTop, offsetLeft) => {
|
|
128
|
+
let top = offsetTop || el.offsetTop;
|
|
129
|
+
let left = offsetLeft || el.offsetLeft;
|
|
130
|
+
if (el.parentElement) {
|
|
131
|
+
if (getComputedStyle(el.parentElement).position !== "static") {
|
|
132
|
+
top += el.parentElement.offsetTop;
|
|
133
|
+
left += el.parentElement.offsetLeft;
|
|
134
|
+
}
|
|
135
|
+
return getElementToPageTop(el.parentElement, top, left);
|
|
136
|
+
}
|
|
137
|
+
return {
|
|
138
|
+
offsetLeft: left,
|
|
139
|
+
offsetTop: top
|
|
87
140
|
};
|
|
88
|
-
}
|
|
89
|
-
|
|
141
|
+
};
|
|
142
|
+
const Popper = /* @__PURE__ */ defineComponent({
|
|
143
|
+
name: name$1,
|
|
90
144
|
props: {
|
|
91
|
-
...
|
|
145
|
+
...tooltipProps,
|
|
92
146
|
reference: {
|
|
93
147
|
type: Object,
|
|
94
148
|
default: null
|
|
95
149
|
}
|
|
96
150
|
},
|
|
97
|
-
setup(
|
|
98
|
-
slots
|
|
151
|
+
setup(props, {
|
|
152
|
+
slots
|
|
99
153
|
}) {
|
|
100
|
-
const
|
|
154
|
+
const instance = getCurrentInstance();
|
|
155
|
+
const visible = ref(props.modelValue);
|
|
156
|
+
const positionInfo = reactive({
|
|
101
157
|
placement: "",
|
|
102
158
|
align: ""
|
|
103
|
-
})
|
|
159
|
+
});
|
|
160
|
+
const offset = reactive({
|
|
104
161
|
top: 0,
|
|
105
162
|
left: 0
|
|
106
|
-
})
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
163
|
+
});
|
|
164
|
+
const setPosition = () => {
|
|
165
|
+
var _a;
|
|
166
|
+
const $el = props.reference;
|
|
167
|
+
const $popper = (_a = instance == null ? void 0 : instance.proxy) == null ? void 0 : _a.$refs.popper;
|
|
168
|
+
if (!$el || !$popper)
|
|
110
169
|
return;
|
|
111
170
|
const {
|
|
112
|
-
offsetWidth
|
|
113
|
-
offsetHeight
|
|
114
|
-
} =
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
} =
|
|
171
|
+
offsetWidth,
|
|
172
|
+
offsetHeight
|
|
173
|
+
} = $el;
|
|
174
|
+
const {
|
|
175
|
+
offsetTop,
|
|
176
|
+
offsetLeft
|
|
177
|
+
} = getElementToPageTop($el);
|
|
178
|
+
const {
|
|
179
|
+
offsetWidth: tipWidth,
|
|
180
|
+
offsetHeight: tipHeight
|
|
181
|
+
} = $popper;
|
|
182
|
+
const {
|
|
183
|
+
placement,
|
|
184
|
+
align
|
|
185
|
+
} = positionInfo;
|
|
186
|
+
const {
|
|
187
|
+
offsetLeft: noStaticEleLeft,
|
|
188
|
+
offsetTop: noStaticEleTop
|
|
189
|
+
} = getElementToPageTop(getNoStaticParent($popper));
|
|
190
|
+
const p = {
|
|
127
191
|
x: 0,
|
|
128
192
|
y: 0,
|
|
129
|
-
newPlacement:
|
|
193
|
+
newPlacement: placement
|
|
130
194
|
};
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
195
|
+
if (props.autoFlipping) {
|
|
196
|
+
if (placement === "left" && offsetLeft - tipWidth < pageXOffset) {
|
|
197
|
+
p.newPlacement = "right";
|
|
198
|
+
} else if (placement === "right" && offsetLeft + offsetWidth + tipWidth > pageXOffset + innerWidth) {
|
|
199
|
+
p.newPlacement = "left";
|
|
200
|
+
} else if (placement === "top" && offsetTop - tipHeight < pageYOffset) {
|
|
201
|
+
p.newPlacement = "bottom";
|
|
202
|
+
} else if (placement === "bottom" && offsetTop + offsetHeight + tipHeight > pageYOffset + innerHeight)
|
|
203
|
+
p.newPlacement = "top";
|
|
204
|
+
}
|
|
205
|
+
const realHeight = p.newPlacement === "top" ? -tipHeight : offsetHeight;
|
|
206
|
+
const realWidth = p.newPlacement === "left" ? -tipWidth : offsetWidth;
|
|
207
|
+
switch (p.newPlacement) {
|
|
134
208
|
case "top":
|
|
135
209
|
case "bottom":
|
|
136
|
-
|
|
210
|
+
p.y = offsetTop + realHeight;
|
|
211
|
+
if (align === "start")
|
|
212
|
+
p.x = offsetLeft;
|
|
213
|
+
else if (align === "end")
|
|
214
|
+
p.x = offsetLeft + offsetWidth - tipWidth;
|
|
215
|
+
else
|
|
216
|
+
p.x = offsetLeft + offsetWidth / 2 - tipWidth / 2;
|
|
137
217
|
break;
|
|
138
218
|
case "left":
|
|
139
219
|
case "right":
|
|
140
|
-
|
|
220
|
+
p.x = offsetLeft + realWidth;
|
|
221
|
+
if (align === "start")
|
|
222
|
+
p.y = offsetTop;
|
|
223
|
+
else if (align === "end")
|
|
224
|
+
p.y = offsetTop + offsetHeight - tipHeight;
|
|
225
|
+
else
|
|
226
|
+
p.y = offsetTop + offsetHeight / 2 - tipHeight / 2;
|
|
141
227
|
break;
|
|
142
228
|
}
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
229
|
+
offset.left = p.x - noStaticEleLeft;
|
|
230
|
+
offset.top = p.y - noStaticEleTop;
|
|
231
|
+
positionInfo.placement = p.newPlacement;
|
|
232
|
+
};
|
|
233
|
+
const handleHide = (e) => {
|
|
234
|
+
var _a;
|
|
235
|
+
const $popper = (_a = instance == null ? void 0 : instance.proxy) == null ? void 0 : _a.$refs.popper;
|
|
236
|
+
const $el = props.reference;
|
|
237
|
+
if ($el && $popper && !$el.contains(e.target) && !$popper.contains(e.target)) {
|
|
238
|
+
visible.value = false;
|
|
239
|
+
}
|
|
240
|
+
};
|
|
241
|
+
const toggle = () => {
|
|
242
|
+
visible.value = !visible.value;
|
|
243
|
+
};
|
|
244
|
+
const setPositionInfo = () => {
|
|
245
|
+
const [placement, align] = props.position.split("-");
|
|
246
|
+
positionInfo.align = align;
|
|
247
|
+
positionInfo.placement = placement;
|
|
248
|
+
};
|
|
249
|
+
const showPopper = () => {
|
|
250
|
+
if (props.manual) {
|
|
251
|
+
visible.value = props.modelValue;
|
|
252
|
+
}
|
|
253
|
+
if (props.modelValue || visible.value) {
|
|
254
|
+
nextTick(setPosition).catch((error) => {
|
|
255
|
+
throw new Error(error);
|
|
256
|
+
});
|
|
257
|
+
} else {
|
|
258
|
+
offset.left = 0;
|
|
259
|
+
offset.top = 0;
|
|
260
|
+
}
|
|
157
261
|
};
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
var
|
|
165
|
-
|
|
166
|
-
|
|
262
|
+
watch(() => props.position, () => {
|
|
263
|
+
setPositionInfo();
|
|
264
|
+
showPopper();
|
|
265
|
+
});
|
|
266
|
+
watch([() => visible.value, () => props.modelValue, () => props.reference], showPopper);
|
|
267
|
+
onMounted(() => {
|
|
268
|
+
var _a;
|
|
269
|
+
setPositionInfo();
|
|
270
|
+
showPopper();
|
|
271
|
+
if (!props.manual) {
|
|
272
|
+
(_a = props.reference) == null ? void 0 : _a.addEventListener("click", toggle);
|
|
273
|
+
document.addEventListener("touchstart", handleHide);
|
|
274
|
+
document.addEventListener("mousedown", handleHide);
|
|
275
|
+
}
|
|
276
|
+
});
|
|
277
|
+
onBeforeUnmount(() => {
|
|
278
|
+
var _a;
|
|
279
|
+
if (!props.manual) {
|
|
280
|
+
(_a = props.reference) == null ? void 0 : _a.removeEventListener("click", toggle);
|
|
281
|
+
document.removeEventListener("touchstart", handleHide);
|
|
282
|
+
document.removeEventListener("mousedown", handleHide);
|
|
283
|
+
}
|
|
284
|
+
});
|
|
285
|
+
return () => {
|
|
167
286
|
const {
|
|
168
|
-
left
|
|
169
|
-
top
|
|
170
|
-
} =
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
287
|
+
left,
|
|
288
|
+
top
|
|
289
|
+
} = offset;
|
|
290
|
+
const {
|
|
291
|
+
width,
|
|
292
|
+
color,
|
|
293
|
+
bgColor,
|
|
294
|
+
modelValue,
|
|
295
|
+
minWidth,
|
|
296
|
+
popperClass,
|
|
297
|
+
popperStyle,
|
|
298
|
+
text
|
|
299
|
+
} = props;
|
|
300
|
+
return createVNode(Teleport, {
|
|
301
|
+
"to": props.teleport
|
|
182
302
|
}, {
|
|
183
303
|
default: () => {
|
|
184
|
-
var
|
|
185
|
-
return [
|
|
186
|
-
class: [
|
|
187
|
-
[
|
|
188
|
-
}),
|
|
189
|
-
ref: "popper",
|
|
190
|
-
style: {
|
|
191
|
-
...
|
|
192
|
-
left: `${
|
|
193
|
-
top: `${
|
|
304
|
+
var _a;
|
|
305
|
+
return [withDirectives(createVNode("div", {
|
|
306
|
+
"class": [bem({
|
|
307
|
+
[positionInfo.placement]: positionInfo.placement
|
|
308
|
+
}), popperClass],
|
|
309
|
+
"ref": "popper",
|
|
310
|
+
"style": {
|
|
311
|
+
...popperStyle,
|
|
312
|
+
left: `${left}px`,
|
|
313
|
+
top: `${top}px`
|
|
194
314
|
}
|
|
195
|
-
}, [
|
|
196
|
-
class:
|
|
197
|
-
style: {
|
|
198
|
-
color
|
|
199
|
-
width:
|
|
200
|
-
minWidth:
|
|
201
|
-
backgroundColor:
|
|
315
|
+
}, [createVNode("div", {
|
|
316
|
+
"class": bem("content"),
|
|
317
|
+
"style": {
|
|
318
|
+
color,
|
|
319
|
+
width: parseUnit(width),
|
|
320
|
+
minWidth: parseUnit(minWidth),
|
|
321
|
+
backgroundColor: bgColor
|
|
202
322
|
}
|
|
203
|
-
}, [((
|
|
204
|
-
class:
|
|
205
|
-
style: {
|
|
206
|
-
color:
|
|
323
|
+
}, [((_a = slots.default) == null ? void 0 : _a.call(slots)) || text]), createVNode("div", {
|
|
324
|
+
"class": bem("arrow", [`${positionInfo.placement}${positionInfo.align ? `-${positionInfo.align}` : ""}`]),
|
|
325
|
+
"style": {
|
|
326
|
+
color: bgColor
|
|
207
327
|
}
|
|
208
|
-
}, null)]), [[
|
|
328
|
+
}, null)]), [[vShow, modelValue || visible.value]])];
|
|
209
329
|
}
|
|
210
330
|
});
|
|
211
331
|
};
|
|
212
332
|
}
|
|
213
333
|
});
|
|
214
|
-
function
|
|
215
|
-
return typeof
|
|
334
|
+
function _isSlot(s) {
|
|
335
|
+
return typeof s === "function" || Object.prototype.toString.call(s) === "[object Object]" && !isVNode(s);
|
|
216
336
|
}
|
|
217
|
-
const [
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
337
|
+
const [name] = createNamespace("tooltip");
|
|
338
|
+
const Tooltip = /* @__PURE__ */ defineComponent({
|
|
339
|
+
name,
|
|
340
|
+
props: tooltipProps,
|
|
341
|
+
setup(props, {
|
|
342
|
+
slots
|
|
222
343
|
}) {
|
|
223
|
-
const
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
344
|
+
const instance = getCurrentInstance();
|
|
345
|
+
const $dom = ref();
|
|
346
|
+
const getEl = () => {
|
|
347
|
+
var _a;
|
|
348
|
+
const $root = (_a = instance == null ? void 0 : instance.proxy) == null ? void 0 : _a.$el;
|
|
349
|
+
return $root == null ? void 0 : $root.nextElementSibling;
|
|
227
350
|
};
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
})
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
351
|
+
onMounted(() => {
|
|
352
|
+
$dom.value = getEl();
|
|
353
|
+
});
|
|
354
|
+
onBeforeUpdate(() => {
|
|
355
|
+
nextTick(() => {
|
|
356
|
+
$dom.value = getEl();
|
|
357
|
+
}).catch((e) => {
|
|
358
|
+
throw Error(e);
|
|
235
359
|
});
|
|
236
|
-
})
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
360
|
+
});
|
|
361
|
+
return () => {
|
|
362
|
+
var _a;
|
|
363
|
+
let _slot;
|
|
364
|
+
return createVNode(Fragment, null, [(_a = slots.default) == null ? void 0 : _a.call(slots)[0], $dom.value && (slots.popper ? createVNode(Popper, mergeProps(props, {
|
|
365
|
+
"reference": $dom.value
|
|
366
|
+
}), _isSlot(_slot = slots.popper()) ? _slot : {
|
|
367
|
+
default: () => [_slot]
|
|
368
|
+
}) : createVNode(Popper, mergeProps(props, {
|
|
369
|
+
"reference": $dom.value
|
|
245
370
|
}), null))]);
|
|
246
371
|
};
|
|
247
372
|
}
|
|
248
|
-
})
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
373
|
+
});
|
|
374
|
+
const tooltipDirective = {
|
|
375
|
+
install: (app) => {
|
|
376
|
+
app.directive("tooltip", {
|
|
377
|
+
getSSRProps: (binding) => {
|
|
378
|
+
return { ...binding };
|
|
379
|
+
},
|
|
252
380
|
// 指令是具有一组生命周期的钩子:
|
|
253
381
|
// 在绑定元素的 attribute 或事件监听器被应用之前调用
|
|
254
382
|
// 在绑定元素的父组件挂载之前调用
|
|
255
|
-
mounted: (
|
|
256
|
-
const
|
|
257
|
-
|
|
383
|
+
mounted: (el, binding) => {
|
|
384
|
+
const tooltipComponent = h(Popper, { ...binding.value, reference: el });
|
|
385
|
+
el.$popper = document.createElement("div");
|
|
386
|
+
document.body.appendChild(el.$popper);
|
|
387
|
+
tooltipComponent.appContext = app._context;
|
|
388
|
+
render(tooltipComponent, el.$popper);
|
|
258
389
|
},
|
|
259
|
-
unmounted: (
|
|
260
|
-
|
|
390
|
+
unmounted: (el) => {
|
|
391
|
+
el.$popper && el.$popper.remove();
|
|
261
392
|
}
|
|
262
393
|
});
|
|
263
394
|
}
|
|
264
395
|
};
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
396
|
+
const reset = "";
|
|
397
|
+
const libs = "";
|
|
398
|
+
const font = "";
|
|
399
|
+
const animation = "";
|
|
400
|
+
const theme = "";
|
|
401
|
+
const style = "";
|
|
402
|
+
Tooltip.install = (app) => {
|
|
403
|
+
const { name: name2 } = Tooltip;
|
|
404
|
+
app.component(name2, Tooltip);
|
|
405
|
+
app.use(tooltipDirective);
|
|
268
406
|
};
|
|
269
407
|
export {
|
|
270
|
-
|
|
271
|
-
|
|
408
|
+
Tooltip as default,
|
|
409
|
+
tooltipDirective
|
|
272
410
|
};
|