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.
Files changed (119) hide show
  1. package/libs/button/index.css +579 -1
  2. package/libs/button/index.mjs +111 -66
  3. package/libs/button/index.umd.js +203 -2
  4. package/libs/cell/index.css +1077 -1
  5. package/libs/cell/index.mjs +167 -104
  6. package/libs/cell/index.umd.js +300 -2
  7. package/libs/checkbox/index.css +1053 -1
  8. package/libs/checkbox/index.mjs +242 -127
  9. package/libs/checkbox/index.umd.js +369 -2
  10. package/libs/checkboxGroup/index.css +422 -1
  11. package/libs/checkboxGroup/index.mjs +173 -87
  12. package/libs/checkboxGroup/index.umd.js +265 -2
  13. package/libs/col/index.css +615 -1
  14. package/libs/col/index.mjs +246 -81
  15. package/libs/col/index.umd.js +305 -2
  16. package/libs/countdown/index.css +417 -1
  17. package/libs/countdown/index.mjs +179 -71
  18. package/libs/countdown/index.umd.js +231 -2
  19. package/libs/dialog/index.css +1405 -1
  20. package/libs/dialog/index.mjs +646 -476
  21. package/libs/dialog/index.umd.js +1128 -2
  22. package/libs/empty/index.css +457 -1
  23. package/libs/empty/index.mjs +91 -44
  24. package/libs/empty/index.umd.js +139 -2
  25. package/libs/form/index.css +477 -1
  26. package/libs/form/index.mjs +226 -126
  27. package/libs/form/index.umd.js +319 -2
  28. package/libs/formItem/index.css +477 -1
  29. package/libs/formItem/index.mjs +276 -126
  30. package/libs/formItem/index.umd.js +372 -2
  31. package/libs/icon/index.css +982 -1
  32. package/libs/icon/index.mjs +107 -58
  33. package/libs/icon/index.umd.js +186 -2
  34. package/libs/index.css +2902 -1
  35. package/libs/index.mjs +3785 -2344
  36. package/libs/index.umd.js +5509 -2
  37. package/libs/input/index.css +483 -1
  38. package/libs/input/index.mjs +183 -92
  39. package/libs/input/index.umd.js +274 -2
  40. package/libs/layout/index.css +684 -1
  41. package/libs/layout/index.mjs +230 -130
  42. package/libs/layout/index.umd.js +318 -2
  43. package/libs/list/index.css +440 -1
  44. package/libs/list/index.mjs +388 -207
  45. package/libs/list/index.umd.js +571 -2
  46. package/libs/loading/index.css +548 -1
  47. package/libs/loading/index.mjs +196 -118
  48. package/libs/loading/index.umd.js +321 -2
  49. package/libs/mask/index.css +426 -1
  50. package/libs/mask/index.mjs +131 -70
  51. package/libs/mask/index.umd.js +201 -2
  52. package/libs/popup/index.css +465 -1
  53. package/libs/popup/index.mjs +210 -134
  54. package/libs/popup/index.umd.js +358 -2
  55. package/libs/progress/index.css +488 -1
  56. package/libs/progress/index.mjs +200 -128
  57. package/libs/progress/index.umd.js +322 -2
  58. package/libs/pullrefresh/index.css +441 -1
  59. package/libs/pullrefresh/index.mjs +241 -111
  60. package/libs/pullrefresh/index.umd.js +302 -2
  61. package/libs/row/index.css +485 -1
  62. package/libs/row/index.mjs +181 -89
  63. package/libs/row/index.umd.js +237 -2
  64. package/libs/slider/index.css +558 -1
  65. package/libs/slider/index.mjs +356 -160
  66. package/libs/slider/index.umd.js +453 -2
  67. package/libs/stepper/index.css +489 -1
  68. package/libs/stepper/index.mjs +181 -101
  69. package/libs/stepper/index.umd.js +269 -2
  70. package/libs/swipe/index.css +506 -1
  71. package/libs/swipe/index.mjs +542 -259
  72. package/libs/swipe/index.umd.js +703 -2
  73. package/libs/swipeItem/index.css +424 -1
  74. package/libs/swipeItem/index.mjs +111 -52
  75. package/libs/swipeItem/index.umd.js +154 -2
  76. package/libs/switch/index.css +472 -1
  77. package/libs/switch/index.mjs +121 -62
  78. package/libs/switch/index.umd.js +200 -2
  79. package/libs/tab/index.mjs +131 -68
  80. package/libs/tab/index.umd.js +190 -1
  81. package/libs/tabs/index.css +514 -1
  82. package/libs/tabs/index.mjs +751 -410
  83. package/libs/tabs/index.umd.js +1020 -2
  84. package/libs/toast/index.css +1050 -1
  85. package/libs/toast/index.mjs +183 -114
  86. package/libs/toast/index.umd.js +306 -2
  87. package/libs/tooltip/index.css +514 -1
  88. package/libs/tooltip/index.mjs +293 -155
  89. package/libs/tooltip/index.umd.js +416 -2
  90. package/package.json +5 -4
  91. package/libs/button/package.json +0 -5
  92. package/libs/cell/package.json +0 -5
  93. package/libs/checkbox/package.json +0 -5
  94. package/libs/checkboxGroup/package.json +0 -5
  95. package/libs/col/package.json +0 -5
  96. package/libs/countdown/package.json +0 -5
  97. package/libs/dialog/package.json +0 -5
  98. package/libs/empty/package.json +0 -5
  99. package/libs/form/package.json +0 -5
  100. package/libs/formItem/package.json +0 -5
  101. package/libs/icon/package.json +0 -5
  102. package/libs/input/package.json +0 -5
  103. package/libs/layout/package.json +0 -5
  104. package/libs/list/package.json +0 -5
  105. package/libs/loading/package.json +0 -5
  106. package/libs/mask/package.json +0 -5
  107. package/libs/popup/package.json +0 -5
  108. package/libs/progress/package.json +0 -5
  109. package/libs/pullrefresh/package.json +0 -5
  110. package/libs/row/package.json +0 -5
  111. package/libs/slider/package.json +0 -5
  112. package/libs/stepper/package.json +0 -5
  113. package/libs/swipe/package.json +0 -5
  114. package/libs/swipeItem/package.json +0 -5
  115. package/libs/switch/package.json +0 -5
  116. package/libs/tab/package.json +0 -5
  117. package/libs/tabs/package.json +0 -5
  118. package/libs/toast/package.json +0 -5
  119. package/libs/tooltip/package.json +0 -5
@@ -1,11 +1,40 @@
1
- import { ref as N, reactive as P, defineComponent as j, getCurrentInstance as k, watch as W, onMounted as H, onBeforeUnmount as X, createVNode as h, Teleport as Y, withDirectives as G, vShow as R, nextTick as M, onBeforeUpdate as q, Fragment as J, mergeProps as B, isVNode as K, h as Q, render as Z } from "vue";
2
- const b = (e, t) => t ? typeof t == "string" ? ` ${e}--${t}` : Array.isArray(t) ? t.reduce((o, n) => o + b(e, n), "") : Object.keys(t).reduce(
3
- (o, n) => o + (t[n] ? b(e, n) : ""),
4
- ""
5
- ) : "", ee = (e) => (t, o) => {
6
- let n = t, r = o;
7
- return n && typeof n != "string" && (r = n, n = ""), n = n ? `${e}__${n}` : e, `${n}${b(n, r)}`;
8
- }, te = () => (e, t) => t ? `${b(`y-${e}`, t)}` : `y-${e}`, ne = {
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
- N("zh-CN");
21
- P({
22
- "zh-CN": ne
49
+ ref("zh-CN");
50
+ reactive({
51
+ "zh-CN": defaultLang
23
52
  });
24
- const F = (e) => {
25
- const t = `y-${e}`;
26
- return [t, ee(t), te()];
27
- }, _ = (e) => isNaN(Number(e)) && typeof e == "string" ? e : `${e}px`, I = {
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: !1
67
+ default: false
32
68
  },
33
69
  // 是否只能通过 v-model 控制显隐
34
70
  manual: {
35
71
  type: Boolean,
36
- default: !1
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: !0
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
- }, [oe, S] = F("popper"), U = (e) => e.parentElement ? getComputedStyle(e.parentElement).position !== "static" ? e.parentElement : U(e.parentElement) : e, C = (e, t, o) => {
83
- let n = t || e.offsetTop, r = o || e.offsetLeft;
84
- return e.parentElement ? (getComputedStyle(e.parentElement).position !== "static" && (n += e.parentElement.offsetTop, r += e.parentElement.offsetLeft), C(e.parentElement, n, r)) : {
85
- offsetLeft: r,
86
- offsetTop: n
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
- }, L = /* @__PURE__ */ j({
89
- name: oe,
141
+ };
142
+ const Popper = /* @__PURE__ */ defineComponent({
143
+ name: name$1,
90
144
  props: {
91
- ...I,
145
+ ...tooltipProps,
92
146
  reference: {
93
147
  type: Object,
94
148
  default: null
95
149
  }
96
150
  },
97
- setup(e, {
98
- slots: t
151
+ setup(props, {
152
+ slots
99
153
  }) {
100
- const o = k(), n = N(e.modelValue), r = P({
154
+ const instance = getCurrentInstance();
155
+ const visible = ref(props.modelValue);
156
+ const positionInfo = reactive({
101
157
  placement: "",
102
158
  align: ""
103
- }), i = P({
159
+ });
160
+ const offset = reactive({
104
161
  top: 0,
105
162
  left: 0
106
- }), m = () => {
107
- var V;
108
- const l = e.reference, c = (V = o == null ? void 0 : o.proxy) == null ? void 0 : V.$refs.popper;
109
- if (!l || !c)
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: f,
113
- offsetHeight: p
114
- } = l, {
115
- offsetTop: s,
116
- offsetLeft: u
117
- } = C(l), {
118
- offsetWidth: d,
119
- offsetHeight: g
120
- } = c, {
121
- placement: y,
122
- align: v
123
- } = r, {
124
- offsetLeft: E,
125
- offsetTop: z
126
- } = C(U(c)), a = {
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: y
193
+ newPlacement: placement
130
194
  };
131
- e.autoFlipping && (y === "left" && u - d < pageXOffset ? a.newPlacement = "right" : y === "right" && u + f + d > pageXOffset + innerWidth ? a.newPlacement = "left" : y === "top" && s - g < pageYOffset ? a.newPlacement = "bottom" : y === "bottom" && s + p + g > pageYOffset + innerHeight && (a.newPlacement = "top"));
132
- const A = a.newPlacement === "top" ? -g : p, D = a.newPlacement === "left" ? -d : f;
133
- switch (a.newPlacement) {
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
- a.y = s + A, v === "start" ? a.x = u : v === "end" ? a.x = u + f - d : a.x = u + f / 2 - d / 2;
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
- a.x = u + D, v === "start" ? a.y = s : v === "end" ? a.y = s + p - g : a.y = s + p / 2 - g / 2;
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
- i.left = a.x - E, i.top = a.y - z, r.placement = a.newPlacement;
144
- }, $ = (l) => {
145
- var p;
146
- const c = (p = o == null ? void 0 : o.proxy) == null ? void 0 : p.$refs.popper, f = e.reference;
147
- f && c && !f.contains(l.target) && !c.contains(l.target) && (n.value = !1);
148
- }, T = () => {
149
- n.value = !n.value;
150
- }, O = () => {
151
- const [l, c] = e.position.split("-");
152
- r.align = c, r.placement = l;
153
- }, w = () => {
154
- e.manual && (n.value = e.modelValue), e.modelValue || n.value ? M(m).catch((l) => {
155
- throw new Error(l);
156
- }) : (i.left = 0, i.top = 0);
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
- return W(() => e.position, () => {
159
- O(), w();
160
- }), W([() => n.value, () => e.modelValue, () => e.reference], w), H(() => {
161
- var l;
162
- O(), w(), e.manual || ((l = e.reference) == null || l.addEventListener("click", T), document.addEventListener("touchstart", $), document.addEventListener("mousedown", $));
163
- }), X(() => {
164
- var l;
165
- e.manual || ((l = e.reference) == null || l.removeEventListener("click", T), document.removeEventListener("touchstart", $), document.removeEventListener("mousedown", $));
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: l,
169
- top: c
170
- } = i, {
171
- width: f,
172
- color: p,
173
- bgColor: s,
174
- modelValue: u,
175
- minWidth: d,
176
- popperClass: g,
177
- popperStyle: y,
178
- text: v
179
- } = e;
180
- return h(Y, {
181
- to: e.teleport
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 E;
185
- return [G(h("div", {
186
- class: [S({
187
- [r.placement]: r.placement
188
- }), g],
189
- ref: "popper",
190
- style: {
191
- ...y,
192
- left: `${l}px`,
193
- top: `${c}px`
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
- }, [h("div", {
196
- class: S("content"),
197
- style: {
198
- color: p,
199
- width: _(f),
200
- minWidth: _(d),
201
- backgroundColor: s
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
- }, [((E = t.default) == null ? void 0 : E.call(t)) || v]), h("div", {
204
- class: S("arrow", [`${r.placement}${r.align ? `-${r.align}` : ""}`]),
205
- style: {
206
- color: s
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)]), [[R, u || n.value]])];
328
+ }, null)]), [[vShow, modelValue || visible.value]])];
209
329
  }
210
330
  });
211
331
  };
212
332
  }
213
333
  });
214
- function re(e) {
215
- return typeof e == "function" || Object.prototype.toString.call(e) === "[object Object]" && !K(e);
334
+ function _isSlot(s) {
335
+ return typeof s === "function" || Object.prototype.toString.call(s) === "[object Object]" && !isVNode(s);
216
336
  }
217
- const [le] = F("tooltip"), x = /* @__PURE__ */ j({
218
- name: le,
219
- props: I,
220
- setup(e, {
221
- slots: t
337
+ const [name] = createNamespace("tooltip");
338
+ const Tooltip = /* @__PURE__ */ defineComponent({
339
+ name,
340
+ props: tooltipProps,
341
+ setup(props, {
342
+ slots
222
343
  }) {
223
- const o = k(), n = N(), r = () => {
224
- var m;
225
- const i = (m = o == null ? void 0 : o.proxy) == null ? void 0 : m.$el;
226
- return i == null ? void 0 : i.nextElementSibling;
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
- return H(() => {
229
- n.value = r();
230
- }), q(() => {
231
- M(() => {
232
- n.value = r();
233
- }).catch((i) => {
234
- throw Error(i);
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
- var m;
238
- let i;
239
- return h(J, null, [(m = t.default) == null ? void 0 : m.call(t)[0], n.value && (t.popper ? h(L, B(e, {
240
- reference: n.value
241
- }), re(i = t.popper()) ? i : {
242
- default: () => [i]
243
- }) : h(L, B(e, {
244
- reference: n.value
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
- }), ae = {
249
- install: (e) => {
250
- e.directive("tooltip", {
251
- getSSRProps: (t) => ({ ...t }),
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: (t, o) => {
256
- const n = Q(L, { ...o.value, reference: t });
257
- t.$popper = document.createElement("div"), document.body.appendChild(t.$popper), n.appContext = e._context, Z(n, t.$popper);
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: (t) => {
260
- t.$popper && t.$popper.remove();
390
+ unmounted: (el) => {
391
+ el.$popper && el.$popper.remove();
261
392
  }
262
393
  });
263
394
  }
264
395
  };
265
- x.install = (e) => {
266
- const { name: t } = x;
267
- e.component(t, x), e.use(ae);
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
- x as default,
271
- ae as tooltipDirective
408
+ Tooltip as default,
409
+ tooltipDirective
272
410
  };