@vue-interface/btn-dropdown 2.0.0-beta.22 → 2.0.0-beta.24
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/btn-dropdown.js +104 -97
- package/dist/btn-dropdown.js.map +1 -1
- package/dist/btn-dropdown.umd.cjs +1 -1
- package/dist/btn-dropdown.umd.cjs.map +1 -1
- package/dist/src/BtnDropdown.vue.d.ts +28 -29
- package/dist/src/BtnDropdownAction.vue.d.ts +4 -4
- package/dist/src/BtnDropdownSingle.vue.d.ts +216 -31
- package/dist/src/BtnDropdownSplit.vue.d.ts +166 -28
- package/dist/src/dropdown.d.ts +5 -5
- package/package.json +21 -21
package/dist/btn-dropdown.js
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import { defineComponent as
|
|
2
|
-
import { BtnGroup as
|
|
3
|
-
import { DropdownMenu as
|
|
1
|
+
import { defineComponent as M, openBlock as N, createBlock as V, resolveDynamicComponent as R, mergeProps as I, withCtx as p, renderSlot as s, ref as h, computed as k, onBeforeMount as x, unref as e, normalizeClass as $, normalizeProps as T, guardReactiveProps as q, createVNode as K, createTextVNode as P, toDisplayString as A, withKeys as U, withModifiers as H, createCommentVNode as G, createElementVNode as ee, useSlots as te, createSlots as oe } from "vue";
|
|
2
|
+
import { BtnGroup as F } from "@vue-interface/btn-group";
|
|
3
|
+
import { DropdownMenu as J } from "@vue-interface/dropdown-menu";
|
|
4
4
|
import { createPopper as ne } from "@popperjs/core";
|
|
5
|
-
const le =
|
|
5
|
+
const le = M({
|
|
6
6
|
props: {
|
|
7
7
|
expanded: {
|
|
8
8
|
type: Boolean,
|
|
@@ -33,7 +33,7 @@ const le = A({
|
|
|
33
33
|
return i;
|
|
34
34
|
};
|
|
35
35
|
function se(t, g, i, f, r, c) {
|
|
36
|
-
return
|
|
36
|
+
return N(), V(R(t.is), I({ id: t.id }, t.to ? { to: t.to } : { href: t.href }, {
|
|
37
37
|
"aria-haspopup": "true",
|
|
38
38
|
"aria-expanded": t.expanded,
|
|
39
39
|
type: t.is === "button" ? "button" : void 0
|
|
@@ -44,19 +44,25 @@ function se(t, g, i, f, r, c) {
|
|
|
44
44
|
_: 3
|
|
45
45
|
}, 16, ["id", "aria-expanded", "type"]);
|
|
46
46
|
}
|
|
47
|
-
const
|
|
48
|
-
function
|
|
49
|
-
const i =
|
|
50
|
-
c.value =
|
|
51
|
-
},
|
|
47
|
+
const j = /* @__PURE__ */ ae(le, [["render", se]]);
|
|
48
|
+
function L(t, g) {
|
|
49
|
+
const i = h(!1), f = h(!1), r = h(), c = h(), n = h(), b = h(), m = (o) => {
|
|
50
|
+
c.value = o;
|
|
51
|
+
}, S = k(
|
|
52
52
|
() => {
|
|
53
|
-
var
|
|
54
|
-
return c.value instanceof Element ? c.value : (
|
|
53
|
+
var o;
|
|
54
|
+
return c.value instanceof Element ? c.value : (o = c.value) == null ? void 0 : o.$el;
|
|
55
|
+
}
|
|
56
|
+
), w = k(
|
|
57
|
+
() => {
|
|
58
|
+
var o;
|
|
59
|
+
return n.value instanceof Element ? n.value : (o = n.value) == null ? void 0 : o.$el;
|
|
55
60
|
}
|
|
56
|
-
), $ = k(
|
|
57
|
-
() => o.value instanceof Element ? o.value : o.value.$el
|
|
58
61
|
), d = k(
|
|
59
|
-
() =>
|
|
62
|
+
() => {
|
|
63
|
+
var o;
|
|
64
|
+
return b.value instanceof Element ? b.value : (o = b.value) == null ? void 0 : o.$el;
|
|
65
|
+
}
|
|
60
66
|
), C = k(() => ({
|
|
61
67
|
[t.size]: !!t.size,
|
|
62
68
|
dropdown: t.dropdown || !(t.dropright || t.dropleft || t.dropup),
|
|
@@ -77,9 +83,9 @@ function J(t, g) {
|
|
|
77
83
|
[t.variant]: !!t.variant,
|
|
78
84
|
...y.value
|
|
79
85
|
})), u = k(() => t.dropup ? "top" : t.dropleft ? "left" : t.dropright ? "right" : "bottom"), a = k(() => t.align && t.align === "right" ? "end" : "start");
|
|
80
|
-
function
|
|
81
|
-
var
|
|
82
|
-
(
|
|
86
|
+
function D() {
|
|
87
|
+
var o;
|
|
88
|
+
(o = S.value) == null || o.focus(), i.value = !0, r.value ? r.value.update() : r.value = ne(w.value, d.value.querySelector(".dropdown-menu"), {
|
|
83
89
|
placement: `${u.value}-${a.value}`,
|
|
84
90
|
onFirstUpdate: () => {
|
|
85
91
|
f.value = !0;
|
|
@@ -94,36 +100,37 @@ function J(t, g) {
|
|
|
94
100
|
]
|
|
95
101
|
});
|
|
96
102
|
}
|
|
97
|
-
function
|
|
103
|
+
function E() {
|
|
98
104
|
i.value = !1;
|
|
99
105
|
}
|
|
100
|
-
function
|
|
101
|
-
i.value ?
|
|
106
|
+
function O() {
|
|
107
|
+
i.value ? E() : D();
|
|
102
108
|
}
|
|
103
|
-
function
|
|
109
|
+
function Q() {
|
|
104
110
|
return d.value && d.value.querySelectorAll(
|
|
105
111
|
'label, input, select, textarea, [tabindex]:not([tabindex="-1"])'
|
|
106
112
|
);
|
|
107
113
|
}
|
|
108
|
-
function
|
|
109
|
-
const
|
|
110
|
-
for (const
|
|
111
|
-
if (
|
|
114
|
+
function W(o) {
|
|
115
|
+
const B = Q();
|
|
116
|
+
for (const z in B)
|
|
117
|
+
if (o === B[z])
|
|
112
118
|
return !0;
|
|
113
119
|
return !1;
|
|
114
120
|
}
|
|
115
|
-
function
|
|
116
|
-
|
|
121
|
+
function X(o) {
|
|
122
|
+
var B, z;
|
|
123
|
+
g("blur", o), !o.defaultPrevented && (d.value && !((B = d.value) != null && B.contains(o.relatedTarget)) || !((z = d.value) != null && z.contains(o.relatedTarget))) && E();
|
|
117
124
|
}
|
|
118
|
-
function
|
|
119
|
-
|
|
125
|
+
function Y(o) {
|
|
126
|
+
W(o.target) || E();
|
|
120
127
|
}
|
|
121
|
-
function
|
|
122
|
-
g("click-toggle",
|
|
128
|
+
function Z(o) {
|
|
129
|
+
g("click-toggle", o), o.defaultPrevented || O();
|
|
123
130
|
}
|
|
124
|
-
function
|
|
125
|
-
var
|
|
126
|
-
((
|
|
131
|
+
function _(o) {
|
|
132
|
+
var B;
|
|
133
|
+
((B = w.value.parentElement) == null ? void 0 : B.lastElementChild) === o.target && E();
|
|
127
134
|
}
|
|
128
135
|
return x(() => {
|
|
129
136
|
r.value && r.value.destroy();
|
|
@@ -134,19 +141,19 @@ function J(t, g) {
|
|
|
134
141
|
classes: C,
|
|
135
142
|
expanded: i,
|
|
136
143
|
menu: b,
|
|
137
|
-
target:
|
|
144
|
+
target: n,
|
|
138
145
|
toggleClasses: l,
|
|
139
146
|
triggerAnimation: f,
|
|
140
|
-
hide:
|
|
141
|
-
show:
|
|
142
|
-
toggle:
|
|
143
|
-
onBlur:
|
|
144
|
-
onClickItem:
|
|
145
|
-
onClickToggle:
|
|
146
|
-
onKeydown:
|
|
147
|
+
hide: E,
|
|
148
|
+
show: D,
|
|
149
|
+
toggle: O,
|
|
150
|
+
onBlur: X,
|
|
151
|
+
onClickItem: Y,
|
|
152
|
+
onClickToggle: Z,
|
|
153
|
+
onKeydown: _
|
|
147
154
|
};
|
|
148
155
|
}
|
|
149
|
-
const re = /* @__PURE__ */
|
|
156
|
+
const re = /* @__PURE__ */ M({
|
|
150
157
|
__name: "BtnDropdownSingle",
|
|
151
158
|
props: {
|
|
152
159
|
active: { type: Boolean },
|
|
@@ -167,54 +174,54 @@ const re = /* @__PURE__ */ A({
|
|
|
167
174
|
const i = t, f = g, {
|
|
168
175
|
button: r,
|
|
169
176
|
$button: c,
|
|
170
|
-
target:
|
|
177
|
+
target: n,
|
|
171
178
|
classes: b,
|
|
172
179
|
expanded: m,
|
|
173
|
-
menu:
|
|
174
|
-
toggleClasses:
|
|
180
|
+
menu: S,
|
|
181
|
+
toggleClasses: w,
|
|
175
182
|
triggerAnimation: d,
|
|
176
183
|
toggle: C,
|
|
177
184
|
onBlur: v,
|
|
178
185
|
onClickToggle: y,
|
|
179
186
|
onClickItem: l,
|
|
180
187
|
onKeydown: u
|
|
181
|
-
} =
|
|
182
|
-
return (a,
|
|
188
|
+
} = L(i, f);
|
|
189
|
+
return (a, D) => (N(), V(e(F), {
|
|
183
190
|
ref_key: "target",
|
|
184
|
-
ref:
|
|
185
|
-
class:
|
|
191
|
+
ref: n,
|
|
192
|
+
class: $(e(b))
|
|
186
193
|
}, {
|
|
187
194
|
default: p(() => [
|
|
188
|
-
s(a.$slots, "button", T(
|
|
189
|
-
|
|
195
|
+
s(a.$slots, "button", T(q({ button: e(r), $button: e(c), expanded: e(m), target: e(n), toggle: e(C), onBlur: e(v), onClickToggle: e(y), onClickItem: e(l), onKeydown: e(u) })), () => [
|
|
196
|
+
K(j, {
|
|
190
197
|
id: a.$attrs.id,
|
|
191
198
|
ref_key: "button",
|
|
192
199
|
ref: r,
|
|
193
200
|
expanded: e(m),
|
|
194
|
-
class:
|
|
201
|
+
class: $(e(w)),
|
|
195
202
|
onBlur: e(v),
|
|
196
203
|
onClick: e(y)
|
|
197
204
|
}, {
|
|
198
205
|
default: p(() => [
|
|
199
206
|
s(a.$slots, "icon"),
|
|
200
207
|
s(a.$slots, "label", {}, () => [
|
|
201
|
-
|
|
208
|
+
P(A(a.label), 1)
|
|
202
209
|
])
|
|
203
210
|
]),
|
|
204
211
|
_: 3
|
|
205
212
|
}, 8, ["id", "expanded", "class", "onBlur", "onClick"])
|
|
206
213
|
]),
|
|
207
|
-
|
|
214
|
+
K(e(J), {
|
|
208
215
|
id: a.$attrs.id,
|
|
209
216
|
ref_key: "menu",
|
|
210
|
-
ref:
|
|
217
|
+
ref: S,
|
|
211
218
|
align: a.align,
|
|
212
219
|
show: e(m),
|
|
213
|
-
class:
|
|
220
|
+
class: $({ animated: e(d) }),
|
|
214
221
|
onBlur: e(v),
|
|
215
222
|
onClick: e(l),
|
|
216
|
-
onKeydown:
|
|
217
|
-
onMousedown:
|
|
223
|
+
onKeydown: U(e(u), ["tab"]),
|
|
224
|
+
onMousedown: D[0] || (D[0] = H(() => {
|
|
218
225
|
}, ["prevent"]))
|
|
219
226
|
}, {
|
|
220
227
|
default: p(() => [
|
|
@@ -226,7 +233,7 @@ const re = /* @__PURE__ */ A({
|
|
|
226
233
|
_: 3
|
|
227
234
|
}, 8, ["class"]));
|
|
228
235
|
}
|
|
229
|
-
}), ie = ["id", "aria-expanded"], ue = /* @__PURE__ */
|
|
236
|
+
}), ie = ["id", "aria-expanded"], ue = /* @__PURE__ */ M({
|
|
230
237
|
__name: "BtnDropdownSplit",
|
|
231
238
|
props: {
|
|
232
239
|
active: { type: Boolean },
|
|
@@ -247,37 +254,37 @@ const re = /* @__PURE__ */ A({
|
|
|
247
254
|
const i = t, f = g, {
|
|
248
255
|
actionClasses: r,
|
|
249
256
|
classes: c,
|
|
250
|
-
expanded:
|
|
257
|
+
expanded: n,
|
|
251
258
|
menu: b,
|
|
252
259
|
target: m,
|
|
253
|
-
toggleClasses:
|
|
254
|
-
triggerAnimation:
|
|
260
|
+
toggleClasses: S,
|
|
261
|
+
triggerAnimation: w,
|
|
255
262
|
onBlur: d,
|
|
256
263
|
onClickToggle: C,
|
|
257
264
|
onClickItem: v,
|
|
258
265
|
onKeydown: y
|
|
259
|
-
} =
|
|
260
|
-
return (l, u) => (
|
|
261
|
-
class:
|
|
266
|
+
} = L(i, f);
|
|
267
|
+
return (l, u) => (N(), V(e(F), {
|
|
268
|
+
class: $([e(c), "btn-dropdown-split"])
|
|
262
269
|
}, {
|
|
263
270
|
default: p(() => [
|
|
264
|
-
l.dropleft ?
|
|
265
|
-
|
|
271
|
+
l.dropleft ? G("", !0) : s(l.$slots, "button", T(I({ key: 0 }, { expanded: e(n), onBlur: e(d), onClickToggle: e(C), onClickItem: e(v), onKeydown: e(y) })), () => [
|
|
272
|
+
K(j, {
|
|
266
273
|
id: l.$attrs.id,
|
|
267
|
-
expanded: e(
|
|
268
|
-
class:
|
|
274
|
+
expanded: e(n),
|
|
275
|
+
class: $(e(r)),
|
|
269
276
|
onClick: u[0] || (u[0] = (a) => f("click", a))
|
|
270
277
|
}, {
|
|
271
278
|
default: p(() => [
|
|
272
279
|
s(l.$slots, "icon"),
|
|
273
280
|
s(l.$slots, "label", {}, () => [
|
|
274
|
-
|
|
281
|
+
P(A(l.label), 1)
|
|
275
282
|
])
|
|
276
283
|
]),
|
|
277
284
|
_: 3
|
|
278
285
|
}, 8, ["id", "expanded", "class"])
|
|
279
286
|
]),
|
|
280
|
-
|
|
287
|
+
K(e(F), {
|
|
281
288
|
ref_key: "target",
|
|
282
289
|
ref: m
|
|
283
290
|
}, {
|
|
@@ -287,24 +294,24 @@ const re = /* @__PURE__ */ A({
|
|
|
287
294
|
id: l.$attrs.id,
|
|
288
295
|
type: "button",
|
|
289
296
|
"aria-haspopup": "true",
|
|
290
|
-
"aria-expanded": e(
|
|
291
|
-
class:
|
|
297
|
+
"aria-expanded": e(n),
|
|
298
|
+
class: $(e(S)),
|
|
292
299
|
onBlur: u[1] || (u[1] = //@ts-ignore
|
|
293
300
|
(...a) => e(d) && e(d)(...a)),
|
|
294
301
|
onClick: u[2] || (u[2] = //@ts-ignore
|
|
295
302
|
(...a) => e(C) && e(C)(...a))
|
|
296
303
|
}, null, 42, ie)
|
|
297
304
|
]),
|
|
298
|
-
|
|
305
|
+
K(e(J), {
|
|
299
306
|
ref_key: "menu",
|
|
300
307
|
ref: b,
|
|
301
308
|
align: l.align,
|
|
302
|
-
show: e(
|
|
303
|
-
class:
|
|
309
|
+
show: e(n),
|
|
310
|
+
class: $({ animated: e(w) }),
|
|
304
311
|
onBlur: e(d),
|
|
305
312
|
onClick: e(v),
|
|
306
|
-
onKeydown:
|
|
307
|
-
onMousedown: u[3] || (u[3] =
|
|
313
|
+
onKeydown: U(e(y), ["tab"]),
|
|
314
|
+
onMousedown: u[3] || (u[3] = H(() => {
|
|
308
315
|
}, ["prevent"]))
|
|
309
316
|
}, {
|
|
310
317
|
default: p(() => [
|
|
@@ -315,27 +322,27 @@ const re = /* @__PURE__ */ A({
|
|
|
315
322
|
]),
|
|
316
323
|
_: 3
|
|
317
324
|
}, 512),
|
|
318
|
-
l.dropleft ? s(l.$slots, "button", T(
|
|
319
|
-
|
|
325
|
+
l.dropleft ? s(l.$slots, "button", T(I({ key: 1 }, { expanded: e(n), onBlur: e(d), onClickToggle: e(C), onClickItem: e(v), onKeydown: e(y) })), () => [
|
|
326
|
+
K(j, {
|
|
320
327
|
id: l.$attrs.id,
|
|
321
|
-
expanded: e(
|
|
322
|
-
class:
|
|
328
|
+
expanded: e(n),
|
|
329
|
+
class: $(e(r)),
|
|
323
330
|
onClick: u[4] || (u[4] = (a) => f("click", a))
|
|
324
331
|
}, {
|
|
325
332
|
default: p(() => [
|
|
326
333
|
s(l.$slots, "icon"),
|
|
327
334
|
s(l.$slots, "label", {}, () => [
|
|
328
|
-
|
|
335
|
+
P(A(l.label), 1)
|
|
329
336
|
])
|
|
330
337
|
]),
|
|
331
338
|
_: 3
|
|
332
339
|
}, 8, ["id", "expanded", "class"])
|
|
333
|
-
]) :
|
|
340
|
+
]) : G("", !0)
|
|
334
341
|
]),
|
|
335
342
|
_: 3
|
|
336
343
|
}, 8, ["class"]));
|
|
337
344
|
}
|
|
338
|
-
}), ge = /* @__PURE__ */
|
|
345
|
+
}), ge = /* @__PURE__ */ M({
|
|
339
346
|
__name: "BtnDropdown",
|
|
340
347
|
props: {
|
|
341
348
|
active: { type: Boolean },
|
|
@@ -354,33 +361,33 @@ const re = /* @__PURE__ */ A({
|
|
|
354
361
|
emits: ["click"],
|
|
355
362
|
setup(t, { emit: g }) {
|
|
356
363
|
const i = t, f = g;
|
|
357
|
-
function r(
|
|
358
|
-
return f("click",
|
|
364
|
+
function r(n) {
|
|
365
|
+
return f("click", n);
|
|
359
366
|
}
|
|
360
367
|
const c = te();
|
|
361
|
-
return (
|
|
368
|
+
return (n, b) => (N(), V(R(n.split ? ue : re), I(i, {
|
|
362
369
|
class: "btn-dropdown",
|
|
363
370
|
onClick: r
|
|
364
371
|
}), oe({
|
|
365
372
|
icon: p(() => [
|
|
366
|
-
s(
|
|
373
|
+
s(n.$slots, "icon")
|
|
367
374
|
]),
|
|
368
375
|
button: p((m) => [
|
|
369
|
-
s(
|
|
376
|
+
s(n.$slots, "button", T(q(m)))
|
|
370
377
|
]),
|
|
371
378
|
split: p((m) => [
|
|
372
|
-
s(
|
|
379
|
+
s(n.$slots, "split", T(q(m)))
|
|
373
380
|
]),
|
|
374
381
|
default: p(() => [
|
|
375
|
-
s(
|
|
382
|
+
s(n.$slots, "default")
|
|
376
383
|
]),
|
|
377
384
|
_: 2
|
|
378
385
|
}, [
|
|
379
|
-
|
|
386
|
+
n.label || e(c).label ? {
|
|
380
387
|
name: "label",
|
|
381
388
|
fn: p(() => [
|
|
382
|
-
s(
|
|
383
|
-
|
|
389
|
+
s(n.$slots, "label", {}, () => [
|
|
390
|
+
P(A(n.label), 1)
|
|
384
391
|
])
|
|
385
392
|
]),
|
|
386
393
|
key: "0"
|
package/dist/btn-dropdown.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"btn-dropdown.js","sources":["../src/BtnDropdownAction.vue","../src/dropdown.ts","../src/BtnDropdownSingle.vue","../src/BtnDropdownSplit.vue","../src/BtnDropdown.vue"],"sourcesContent":["<script lang=\"ts\">\nimport { defineComponent } from 'vue';\n\nexport default defineComponent({\n props: {\n expanded: {\n type: Boolean,\n default: false\n },\n id: {\n type: String,\n default: undefined\n },\n href: {\n type: String,\n default: undefined\n },\n to: {\n type: [String, Object],\n default: undefined\n }\n },\n computed: {\n is() {\n if(this.to) {\n return 'router-link';\n }\n\n if(this.href) {\n return 'a';\n }\n\n return 'button';\n },\n }\n});\n</script>\n\n<template>\n <Component\n :is=\"is\"\n :id=\"id\"\n v-bind=\"to ? { to } : { href }\"\n aria-haspopup=\"true\"\n :aria-expanded=\"expanded\"\n :type=\"is === 'button' ? 'button': undefined\">\n <slot />\n </Component>\n</template>","import { Instance, Placement, createPopper } from '@popperjs/core';\nimport { ComponentPublicInstance, ComputedRef, computed, onBeforeMount, ref } from 'vue';\n\nexport type BtnDropdownProps = {\n active?: boolean,\n align?: 'left' | 'right',\n buttonClass?: string|Record<string|undefined,boolean>,\n dropdown?: boolean,\n dropup?: boolean,\n dropleft?: boolean,\n dropright?: boolean,\n label?: string,\n offset?: number,\n size?: string,\n split?: boolean,\n variant?: string,\n}\n\nexport type BtnDropdownEmits = {\n (name: 'click', e: PointerEvent): void,\n (name: 'click-toggle', e: MouseEvent): void,\n (name: 'blur', e: FocusEvent): void\n}\n\nexport function useBtnDropdown<Props extends BtnDropdownProps, Emits extends BtnDropdownEmits>(props: Props, emit: Emits) {\n const expanded = ref(false);\n const triggerAnimation = ref(false);\n const popper = ref<Instance>();\n const button = ref<Element|ComponentPublicInstance>();\n const target = ref<Element|ComponentPublicInstance>();\n const menu = ref<Element|ComponentPublicInstance>();\n\n const $button: any = (ref) => {\n button.value = ref;\n }\n\n const buttonEl = computed(() => \n button.value instanceof Element\n ? button.value\n : button.value?.$el\n );\n\n const targetEl = computed(() => \n target.value instanceof Element\n ? target.value\n : target.value.$el\n );\n\n const menuEl = computed(() => \n menu.value instanceof Element\n ? menu.value\n : menu.value.$el\n );\n\n const classes = computed(() => ({\n [props.size]: !!props.size, \n 'dropdown': props.dropdown || !(props.dropright || props.dropleft || props.dropup),\n 'dropup': props.dropup,\n 'dropright': props.dropright,\n 'dropleft': props.dropleft,\n 'expanded': expanded.value,\n }));\n\n const actionClasses = computed(() => ({\n [props.variant]: !!props.variant,\n ...buttonsClasses.value,\n }));\n\n const buttonsClasses: ComputedRef<{\n btn: true,\n [x: string]: boolean\n }> = computed(() => {\n const buttonClass = typeof props.buttonClass === 'object'\n ? props.buttonClass\n : {[props.buttonClass]: !!props.buttonClass};\n \n return {\n btn: true,\n ...buttonClass\n };\n });\n\n const toggleClasses = computed(() => ({\n 'active': props.active,\n 'dropdown-toggle': true,\n 'dropdown-toggle-split': props.split,\n [props.variant]: !!props.variant,\n ...buttonsClasses.value,\n }));\n\n const placement = computed(() => {\n if(props.dropup) {\n return 'top';\n }\n\n if(props.dropleft) {\n return 'left';\n }\n\n if(props.dropright) {\n return 'right';\n }\n\n return 'bottom';\n });\n \n const align = computed(() => {\n if(props.align) {\n return props.align === 'right' ? 'end' : 'start';\n }\n\n return 'start';\n });\n \n function show() {\n buttonEl.value?.focus();\n \n expanded.value = true;\n\n if(!popper.value) {\n popper.value = createPopper(targetEl.value, menuEl.value.querySelector('.dropdown-menu'), {\n placement: `${placement.value}-${align.value}` as Placement,\n onFirstUpdate: () => {\n triggerAnimation.value = true;\n },\n modifiers: [\n {\n name: 'offset',\n options: {\n offset: [0, props.offset ?? 5]\n },\n },\n ]\n });\n }\n else {\n popper.value.update();\n }\n }\n\n function hide() {\n expanded.value = false;\n }\n\n function toggle() {\n !expanded.value ? show() : hide();\n }\n \n function queryFocusable() {\n return menuEl.value && menuEl.value.querySelectorAll(\n 'label, input, select, textarea, [tabindex]:not([tabindex=\"-1\"])'\n );\n }\n\n function isFocusable(element: HTMLElement) {\n const nodes = queryFocusable();\n\n for(const i in nodes) {\n if(element === nodes[i]) {\n return true;\n }\n }\n\n return false;\n }\n\n function onBlur(e: FocusEvent) {\n emit('blur', e);\n\n if(e.defaultPrevented) {\n return;\n }\n\n if(menuEl.value && !menuEl.value.contains(e.relatedTarget) || !menuEl.value.contains(e.relatedTarget)) {\n hide();\n }\n }\n\n function onClickItem(e: any) {\n if(!isFocusable(e.target)) {\n hide();\n }\n }\n\n function onClickToggle(e: MouseEvent) {\n emit('click-toggle', e);\n\n if(!e.defaultPrevented) {\n toggle();\n }\n }\n\n function onKeydown(e: KeyboardEvent) {\n if(targetEl.value.parentElement?.lastElementChild === e.target) {\n hide();\n }\n }\n\n onBeforeMount(() => {\n popper.value && popper.value.destroy();\n });\n\n return {\n actionClasses,\n button,\n $button,\n classes,\n expanded,\n menu,\n target,\n toggleClasses,\n triggerAnimation,\n hide,\n show,\n toggle,\n onBlur,\n onClickItem,\n onClickToggle,\n onKeydown\n };\n}","<script setup lang=\"ts\">\nimport { BtnGroup } from '@vue-interface/btn-group';\nimport { DropdownMenu } from '@vue-interface/dropdown-menu';\nimport BtnDropdownAction from './BtnDropdownAction.vue';\nimport { BtnDropdownEmits, BtnDropdownProps, useBtnDropdown } from './dropdown.js';\n\nconst props = defineProps<BtnDropdownProps>();\nconst emit = defineEmits<BtnDropdownEmits>();\n\nconst {\n button,\n $button,\n target,\n classes,\n expanded,\n menu,\n toggleClasses,\n triggerAnimation,\n toggle,\n onBlur,\n onClickToggle,\n onClickItem,\n onKeydown\n} = useBtnDropdown(props, emit);\n</script>\n\n<template>\n <BtnGroup\n ref=\"target\"\n :class=\"classes\">\n <slot\n name=\"button\"\n v-bind=\"{ button, $button, expanded, target, toggle, onBlur, onClickToggle, onClickItem, onKeydown }\">\n <BtnDropdownAction\n :id=\"($attrs.id as string)\"\n ref=\"button\"\n :expanded=\"expanded\"\n :class=\"toggleClasses\"\n @blur=\"onBlur\"\n @click=\"onClickToggle\">\n <slot name=\"icon\" />\n <slot name=\"label\">\n {{ label }}\n </slot>\n </BtnDropdownAction>\n </slot>\n <DropdownMenu\n :id=\"$attrs.id\"\n ref=\"menu\"\n :align=\"align\"\n :show=\"expanded\"\n :class=\"{animated: triggerAnimation}\"\n @blur=\"onBlur\"\n @click=\"onClickItem\"\n @keydown.tab=\"onKeydown\"\n @mousedown.prevent=\"\">\n <slot />\n </DropdownMenu>\n </BtnGroup>\n</template>","<script setup lang=\"ts\">\nimport { BtnGroup } from '@vue-interface/btn-group';\nimport { DropdownMenu } from '@vue-interface/dropdown-menu';\nimport BtnDropdownAction from './BtnDropdownAction.vue';\nimport { BtnDropdownEmits, BtnDropdownProps, useBtnDropdown } from './dropdown.js';\n\nconst props = defineProps<BtnDropdownProps>();\nconst emit = defineEmits<BtnDropdownEmits>();\n\nconst {\n actionClasses,\n classes,\n expanded,\n menu,\n target,\n toggleClasses,\n triggerAnimation,\n onBlur,\n onClickToggle,\n onClickItem,\n onKeydown\n} = useBtnDropdown(props, emit);\n</script>\n\n<template>\n <BtnGroup\n :class=\"classes\"\n class=\"btn-dropdown-split\">\n <slot\n v-if=\"!dropleft\"\n v-bind=\"{ expanded, onBlur, onClickToggle, onClickItem, onKeydown }\"\n name=\"button\">\n <BtnDropdownAction\n :id=\"($attrs.id as string)\"\n :expanded=\"expanded\"\n :class=\"actionClasses\"\n @click=\"emit('click', $event)\">\n <slot name=\"icon\" />\n <slot name=\"label\">\n {{ label }}\n </slot>\n </BtnDropdownAction>\n </slot>\n \n <BtnGroup ref=\"target\">\n <slot\n name=\"split\">\n <button\n :id=\"($attrs.id as string)\"\n type=\"button\"\n aria-haspopup=\"true\"\n :aria-expanded=\"expanded\"\n :class=\"toggleClasses\"\n @blur=\"onBlur\"\n @click=\"onClickToggle\" />\n </slot>\n \n <DropdownMenu\n ref=\"menu\"\n :align=\"align\"\n :show=\"expanded\"\n :class=\"{animated: triggerAnimation}\"\n @blur=\"onBlur\"\n @click=\"onClickItem\"\n @keydown.tab=\"onKeydown\"\n @mousedown.prevent=\"\">\n <slot />\n </DropdownMenu>\n </BtnGroup>\n\n <slot\n v-if=\"dropleft\"\n v-bind=\"{ expanded, onBlur, onClickToggle, onClickItem, onKeydown }\"\n name=\"button\">\n <BtnDropdownAction\n :id=\"($attrs.id as string)\"\n :expanded=\"expanded\"\n :class=\"actionClasses\"\n @click=\"emit('click', $event)\">\n <slot name=\"icon\" />\n <slot name=\"label\">\n {{ label }}\n </slot>\n </BtnDropdownAction>\n </slot>\n </BtnGroup>\n</template>","<script setup lang=\"ts\">\nimport { useSlots } from 'vue';\nimport BtnDropdownSingle from './BtnDropdownSingle.vue';\nimport BtnDropdownSplit from './BtnDropdownSplit.vue';\nimport { BtnDropdownProps } from './dropdown.js';\n\nconst props = defineProps<BtnDropdownProps>();\n\nconst emit = defineEmits<{\n click: [e: Event]\n}>();\n\nfunction onClick(e: Event) {\n return emit('click', e);\n}\n\nconst slots = useSlots();\n</script>\n\n<template>\n <Component\n :is=\"split ? BtnDropdownSplit : BtnDropdownSingle\"\n v-bind=\"props\"\n class=\"btn-dropdown\"\n @click=\"onClick\">\n <!-- @click-toggle=\"(...args: any[]) => $emit('click-toggle', ...args)\"\n @dropdown=\"(...args: any[]) => $emit('dropdown', ...args)\"\n @show=\"(...args: any[]) => $emit('show', ...args)\"\n @hide=\"(...args: any[]) => $emit('hide', ...args)\"\n @toggle=\"(...args: any[]) => $emit('toggle', ...args)\" -->\n <template #icon>\n <slot name=\"icon\" />\n </template>\n <template\n v-if=\"label || slots.label\"\n #label>\n <slot name=\"label\">\n {{ label }}\n </slot>\n </template>\n <template #button=\"slot\">\n <slot\n name=\"button\"\n v-bind=\"slot\" />\n </template>\n <template #split=\"slot\">\n <slot\n name=\"split\"\n v-bind=\"slot\" />\n </template>\n <slot />\n </Component>\n</template>"],"names":["_sfc_main$3","defineComponent","_sfc_render","_ctx","_cache","$props","$setup","$data","$options","_openBlock","_createBlock","_resolveDynamicComponent","_mergeProps","_withCtx","_renderSlot","useBtnDropdown","props","emit","expanded","ref","triggerAnimation","popper","button","target","menu","$button","buttonEl","computed","_a","targetEl","menuEl","classes","actionClasses","buttonsClasses","toggleClasses","placement","align","show","createPopper","hide","toggle","queryFocusable","isFocusable","element","nodes","i","onBlur","e","onClickItem","onClickToggle","onKeydown","onBeforeMount","__props","__emit","onClick","slots","useSlots"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"btn-dropdown.js","sources":["../src/BtnDropdownAction.vue","../src/dropdown.ts","../src/BtnDropdownSingle.vue","../src/BtnDropdownSplit.vue","../src/BtnDropdown.vue"],"sourcesContent":["<script lang=\"ts\">\nimport { defineComponent } from 'vue';\n\nexport default defineComponent({\n props: {\n expanded: {\n type: Boolean,\n default: false\n },\n id: {\n type: String,\n default: undefined\n },\n href: {\n type: String,\n default: undefined\n },\n to: {\n type: [String, Object],\n default: undefined\n }\n },\n computed: {\n is() {\n if(this.to) {\n return 'router-link';\n }\n\n if(this.href) {\n return 'a';\n }\n\n return 'button';\n },\n }\n});\n</script>\n\n<template>\n <Component\n :is=\"is\"\n :id=\"id\"\n v-bind=\"to ? { to } : { href }\"\n aria-haspopup=\"true\"\n :aria-expanded=\"expanded\"\n :type=\"is === 'button' ? 'button': undefined\">\n <slot />\n </Component>\n</template>","import { Instance, Placement, createPopper } from '@popperjs/core';\nimport { ComponentPublicInstance, ComputedRef, computed, onBeforeMount, ref } from 'vue';\n\nexport type BtnDropdownProps = {\n active?: boolean,\n align?: 'left' | 'right',\n buttonClass?: string|Record<string|undefined,boolean>,\n dropdown?: boolean,\n dropup?: boolean,\n dropleft?: boolean,\n dropright?: boolean,\n label?: string,\n offset?: number,\n size?: string,\n split?: boolean,\n variant?: string,\n}\n\nexport type BtnDropdownEmits = {\n (name: 'click', e: PointerEvent): void,\n (name: 'click-toggle', e: MouseEvent): void,\n (name: 'blur', e: FocusEvent): void\n}\n\nexport function useBtnDropdown<Props extends BtnDropdownProps, Emits extends BtnDropdownEmits>(props: Props, emit: Emits) {\n const expanded = ref(false);\n const triggerAnimation = ref(false);\n const popper = ref<Instance>();\n const button = ref<Element|ComponentPublicInstance>();\n const target = ref<Element|ComponentPublicInstance>();\n const menu = ref<Element|ComponentPublicInstance>();\n\n const $button: any = (ref) => {\n button.value = ref;\n }\n\n const buttonEl = computed<HTMLButtonElement|undefined>(() => \n button.value instanceof Element\n ? button.value\n : button.value?.$el\n );\n\n const targetEl = computed<Element|undefined>(() => \n target.value instanceof Element\n ? target.value\n : target.value?.$el\n );\n\n const menuEl = computed<Element|undefined>(() => \n menu.value instanceof Element\n ? menu.value\n : menu.value?.$el\n );\n\n const classes = computed(() => ({\n [props.size]: !!props.size, \n 'dropdown': props.dropdown || !(props.dropright || props.dropleft || props.dropup),\n 'dropup': props.dropup,\n 'dropright': props.dropright,\n 'dropleft': props.dropleft,\n 'expanded': expanded.value,\n }));\n\n const actionClasses = computed(() => ({\n [props.variant]: !!props.variant,\n ...buttonsClasses.value,\n }));\n\n const buttonsClasses: ComputedRef<{\n btn: true,\n [x: string]: boolean\n }> = computed(() => {\n const buttonClass = typeof props.buttonClass === 'object'\n ? props.buttonClass\n : {[props.buttonClass]: !!props.buttonClass};\n \n return {\n btn: true,\n ...buttonClass\n };\n });\n\n const toggleClasses = computed(() => ({\n 'active': props.active,\n 'dropdown-toggle': true,\n 'dropdown-toggle-split': props.split,\n [props.variant]: !!props.variant,\n ...buttonsClasses.value,\n }));\n\n const placement = computed(() => {\n if(props.dropup) {\n return 'top';\n }\n\n if(props.dropleft) {\n return 'left';\n }\n\n if(props.dropright) {\n return 'right';\n }\n\n return 'bottom';\n });\n \n const align = computed(() => {\n if(props.align) {\n return props.align === 'right' ? 'end' : 'start';\n }\n\n return 'start';\n });\n \n function show() {\n buttonEl.value?.focus();\n \n expanded.value = true;\n\n if(!popper.value) {\n popper.value = createPopper(targetEl.value, menuEl.value.querySelector('.dropdown-menu'), {\n placement: `${placement.value}-${align.value}` as Placement,\n onFirstUpdate: () => {\n triggerAnimation.value = true;\n },\n modifiers: [\n {\n name: 'offset',\n options: {\n offset: [0, props.offset ?? 5]\n },\n },\n ]\n });\n }\n else {\n popper.value.update();\n }\n }\n\n function hide() {\n expanded.value = false;\n }\n\n function toggle() {\n !expanded.value ? show() : hide();\n }\n \n function queryFocusable() {\n return menuEl.value && menuEl.value.querySelectorAll(\n 'label, input, select, textarea, [tabindex]:not([tabindex=\"-1\"])'\n );\n }\n\n function isFocusable(element: HTMLElement) {\n const nodes = queryFocusable();\n\n for(const i in nodes) {\n if(element === nodes[i]) {\n return true;\n }\n }\n\n return false;\n }\n\n function onBlur(e: FocusEvent) {\n emit('blur', e);\n\n if(e.defaultPrevented) {\n return;\n }\n\n if(menuEl.value && !menuEl.value?.contains((e as any).relatedTarget) || !menuEl.value?.contains((e as any).relatedTarget)) {\n hide();\n }\n }\n\n function onClickItem(e: any) {\n if(!isFocusable(e.target)) {\n hide();\n }\n }\n\n function onClickToggle(e: MouseEvent) {\n emit('click-toggle', e);\n\n if(!e.defaultPrevented) {\n toggle();\n }\n }\n\n function onKeydown(e: KeyboardEvent) {\n if(targetEl.value.parentElement?.lastElementChild === e.target) {\n hide();\n }\n }\n\n onBeforeMount(() => {\n popper.value && popper.value.destroy();\n });\n\n return {\n actionClasses,\n button,\n $button,\n classes,\n expanded,\n menu,\n target,\n toggleClasses,\n triggerAnimation,\n hide,\n show,\n toggle,\n onBlur,\n onClickItem,\n onClickToggle,\n onKeydown\n };\n}","<script setup lang=\"ts\">\nimport { BtnGroup } from '@vue-interface/btn-group';\nimport { DropdownMenu } from '@vue-interface/dropdown-menu';\nimport BtnDropdownAction from './BtnDropdownAction.vue';\nimport { BtnDropdownEmits, BtnDropdownProps, useBtnDropdown } from './dropdown.js';\n\nconst props = defineProps<BtnDropdownProps>();\nconst emit = defineEmits<BtnDropdownEmits>();\n\nconst {\n button,\n $button,\n target,\n classes,\n expanded,\n menu,\n toggleClasses,\n triggerAnimation,\n toggle,\n onBlur,\n onClickToggle,\n onClickItem,\n onKeydown\n} = useBtnDropdown(props, emit);\n</script>\n\n<template>\n <BtnGroup\n ref=\"target\"\n :class=\"classes\">\n <slot\n name=\"button\"\n v-bind=\"{ button, $button, expanded, target, toggle, onBlur, onClickToggle, onClickItem, onKeydown }\">\n <BtnDropdownAction\n :id=\"($attrs.id as string)\"\n ref=\"button\"\n :expanded=\"expanded\"\n :class=\"toggleClasses\"\n @blur=\"onBlur\"\n @click=\"onClickToggle\">\n <slot name=\"icon\" />\n <slot name=\"label\">\n {{ label }}\n </slot>\n </BtnDropdownAction>\n </slot>\n <DropdownMenu\n :id=\"$attrs.id\"\n ref=\"menu\"\n :align=\"align\"\n :show=\"expanded\"\n :class=\"{animated: triggerAnimation}\"\n @blur=\"onBlur\"\n @click=\"onClickItem\"\n @keydown.tab=\"onKeydown\"\n @mousedown.prevent=\"\">\n <slot />\n </DropdownMenu>\n </BtnGroup>\n</template>","<script setup lang=\"ts\">\nimport { BtnGroup } from '@vue-interface/btn-group';\nimport { DropdownMenu } from '@vue-interface/dropdown-menu';\nimport BtnDropdownAction from './BtnDropdownAction.vue';\nimport { BtnDropdownEmits, BtnDropdownProps, useBtnDropdown } from './dropdown.js';\n\nconst props = defineProps<BtnDropdownProps>();\nconst emit = defineEmits<BtnDropdownEmits>();\n\nconst {\n actionClasses,\n classes,\n expanded,\n menu,\n target,\n toggleClasses,\n triggerAnimation,\n onBlur,\n onClickToggle,\n onClickItem,\n onKeydown\n} = useBtnDropdown(props, emit);\n</script>\n\n<template>\n <BtnGroup\n :class=\"classes\"\n class=\"btn-dropdown-split\">\n <slot\n v-if=\"!dropleft\"\n v-bind=\"{ expanded, onBlur, onClickToggle, onClickItem, onKeydown }\"\n name=\"button\">\n <BtnDropdownAction\n :id=\"($attrs.id as string)\"\n :expanded=\"expanded\"\n :class=\"actionClasses\"\n @click=\"emit('click', $event)\">\n <slot name=\"icon\" />\n <slot name=\"label\">\n {{ label }}\n </slot>\n </BtnDropdownAction>\n </slot>\n \n <BtnGroup ref=\"target\">\n <slot\n name=\"split\">\n <button\n :id=\"($attrs.id as string)\"\n type=\"button\"\n aria-haspopup=\"true\"\n :aria-expanded=\"expanded\"\n :class=\"toggleClasses\"\n @blur=\"onBlur\"\n @click=\"onClickToggle\" />\n </slot>\n \n <DropdownMenu\n ref=\"menu\"\n :align=\"align\"\n :show=\"expanded\"\n :class=\"{animated: triggerAnimation}\"\n @blur=\"onBlur\"\n @click=\"onClickItem\"\n @keydown.tab=\"onKeydown\"\n @mousedown.prevent=\"\">\n <slot />\n </DropdownMenu>\n </BtnGroup>\n\n <slot\n v-if=\"dropleft\"\n v-bind=\"{ expanded, onBlur, onClickToggle, onClickItem, onKeydown }\"\n name=\"button\">\n <BtnDropdownAction\n :id=\"($attrs.id as string)\"\n :expanded=\"expanded\"\n :class=\"actionClasses\"\n @click=\"emit('click', $event)\">\n <slot name=\"icon\" />\n <slot name=\"label\">\n {{ label }}\n </slot>\n </BtnDropdownAction>\n </slot>\n </BtnGroup>\n</template>","<script setup lang=\"ts\">\nimport { useSlots } from 'vue';\nimport BtnDropdownSingle from './BtnDropdownSingle.vue';\nimport BtnDropdownSplit from './BtnDropdownSplit.vue';\nimport { BtnDropdownProps } from './dropdown.js';\n\nconst props = defineProps<BtnDropdownProps>();\n\nconst emit = defineEmits<{\n click: [e: Event]\n}>();\n\nfunction onClick(e: Event) {\n return emit('click', e);\n}\n\nconst slots = useSlots();\n</script>\n\n<template>\n <Component\n :is=\"split ? BtnDropdownSplit : BtnDropdownSingle\"\n v-bind=\"props\"\n class=\"btn-dropdown\"\n @click=\"onClick\">\n <!-- @click-toggle=\"(...args: any[]) => $emit('click-toggle', ...args)\"\n @dropdown=\"(...args: any[]) => $emit('dropdown', ...args)\"\n @show=\"(...args: any[]) => $emit('show', ...args)\"\n @hide=\"(...args: any[]) => $emit('hide', ...args)\"\n @toggle=\"(...args: any[]) => $emit('toggle', ...args)\" -->\n <template #icon>\n <slot name=\"icon\" />\n </template>\n <template\n v-if=\"label || slots.label\"\n #label>\n <slot name=\"label\">\n {{ label }}\n </slot>\n </template>\n <template #button=\"slot\">\n <slot\n name=\"button\"\n v-bind=\"slot\" />\n </template>\n <template #split=\"slot\">\n <slot\n name=\"split\"\n v-bind=\"slot\" />\n </template>\n <slot />\n </Component>\n</template>"],"names":["_sfc_main$3","defineComponent","_sfc_render","_ctx","_cache","$props","$setup","$data","$options","_openBlock","_createBlock","_resolveDynamicComponent","_mergeProps","_withCtx","_renderSlot","useBtnDropdown","props","emit","expanded","ref","triggerAnimation","popper","button","target","menu","$button","buttonEl","computed","_a","targetEl","menuEl","classes","actionClasses","buttonsClasses","toggleClasses","placement","align","show","createPopper","hide","toggle","queryFocusable","isFocusable","element","nodes","i","onBlur","e","_b","onClickItem","onClickToggle","onKeydown","onBeforeMount","__props","__emit","onClick","slots","useSlots"],"mappings":"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"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
(function(m,e){typeof exports=="object"&&typeof module<"u"?e(exports,require("vue"),require("@vue-interface/btn-group"),require("@vue-interface/dropdown-menu"),require("@popperjs/core")):typeof define=="function"&&define.amd?define(["exports","vue","@vue-interface/btn-group","@vue-interface/dropdown-menu","@popperjs/core"],e):(m=typeof globalThis<"u"?globalThis:m||self,e(m.BtnDropdown={},m.Vue,m.VueInterfaceBtnGroup,m.VueInterfaceDropdownMenu,m.PopperjsCore))})(this,function(m,e,
|
|
1
|
+
(function(m,e){typeof exports=="object"&&typeof module<"u"?e(exports,require("vue"),require("@vue-interface/btn-group"),require("@vue-interface/dropdown-menu"),require("@popperjs/core")):typeof define=="function"&&define.amd?define(["exports","vue","@vue-interface/btn-group","@vue-interface/dropdown-menu","@popperjs/core"],e):(m=typeof globalThis<"u"?globalThis:m||self,e(m.BtnDropdown={},m.Vue,m.VueInterfaceBtnGroup,m.VueInterfaceDropdownMenu,m.PopperjsCore))})(this,function(m,e,z,D,N){"use strict";const K=e.defineComponent({props:{expanded:{type:Boolean,default:!1},id:{type:String,default:void 0},href:{type:String,default:void 0},to:{type:[String,Object],default:void 0}},computed:{is(){return this.to?"router-link":this.href?"a":"button"}}}),E=(t,c)=>{const i=t.__vccOpts||t;for(const[f,a]of c)i[f]=a;return i};function I(t,c,i,f,a,p){return e.openBlock(),e.createBlock(e.resolveDynamicComponent(t.is),e.mergeProps({id:t.id},t.to?{to:t.to}:{href:t.href},{"aria-haspopup":"true","aria-expanded":t.expanded,type:t.is==="button"?"button":void 0}),{default:e.withCtx(()=>[e.renderSlot(t.$slots,"default")]),_:3},16,["id","aria-expanded","type"])}const P=E(K,[["render",I]]);function V(t,c){const i=e.ref(!1),f=e.ref(!1),a=e.ref(),p=e.ref(),o=e.ref(),g=e.ref(),u=n=>{p.value=n},k=e.computed(()=>{var n;return p.value instanceof Element?p.value:(n=p.value)==null?void 0:n.$el}),B=e.computed(()=>{var n;return o.value instanceof Element?o.value:(n=o.value)==null?void 0:n.$el}),d=e.computed(()=>{var n;return g.value instanceof Element?g.value:(n=g.value)==null?void 0:n.$el}),b=e.computed(()=>({[t.size]:!!t.size,dropdown:t.dropdown||!(t.dropright||t.dropleft||t.dropup),dropup:t.dropup,dropright:t.dropright,dropleft:t.dropleft,expanded:i.value})),C=e.computed(()=>({[t.variant]:!!t.variant,...y.value})),y=e.computed(()=>({btn:!0,...typeof t.buttonClass=="object"?t.buttonClass:{[t.buttonClass]:!!t.buttonClass}})),r=e.computed(()=>({active:t.active,"dropdown-toggle":!0,"dropdown-toggle-split":t.split,[t.variant]:!!t.variant,...y.value})),s=e.computed(()=>t.dropup?"top":t.dropleft?"left":t.dropright?"right":"bottom"),l=e.computed(()=>t.align&&t.align==="right"?"end":"start");function h(){var n;(n=k.value)==null||n.focus(),i.value=!0,a.value?a.value.update():a.value=N.createPopper(B.value,d.value.querySelector(".dropdown-menu"),{placement:`${s.value}-${l.value}`,onFirstUpdate:()=>{f.value=!0},modifiers:[{name:"offset",options:{offset:[0,t.offset??5]}}]})}function $(){i.value=!1}function T(){i.value?$():h()}function A(){return d.value&&d.value.querySelectorAll('label, input, select, textarea, [tabindex]:not([tabindex="-1"])')}function F(n){const w=A();for(const S in w)if(n===w[S])return!0;return!1}function O(n){var w,S;c("blur",n),!n.defaultPrevented&&(d.value&&!((w=d.value)!=null&&w.contains(n.relatedTarget))||!((S=d.value)!=null&&S.contains(n.relatedTarget)))&&$()}function R(n){F(n.target)||$()}function G(n){c("click-toggle",n),n.defaultPrevented||T()}function U(n){var w;((w=B.value.parentElement)==null?void 0:w.lastElementChild)===n.target&&$()}return e.onBeforeMount(()=>{a.value&&a.value.destroy()}),{actionClasses:C,button:p,$button:u,classes:b,expanded:i,menu:g,target:o,toggleClasses:r,triggerAnimation:f,hide:$,show:h,toggle:T,onBlur:O,onClickItem:R,onClickToggle:G,onKeydown:U}}const M=e.defineComponent({__name:"BtnDropdownSingle",props:{active:{type:Boolean},align:{},buttonClass:{},dropdown:{type:Boolean},dropup:{type:Boolean},dropleft:{type:Boolean},dropright:{type:Boolean},label:{},offset:{},size:{},split:{type:Boolean},variant:{}},emits:["click","click-toggle","blur"],setup(t,{emit:c}){const i=t,f=c,{button:a,$button:p,target:o,classes:g,expanded:u,menu:k,toggleClasses:B,triggerAnimation:d,toggle:b,onBlur:C,onClickToggle:y,onClickItem:r,onKeydown:s}=V(i,f);return(l,h)=>(e.openBlock(),e.createBlock(e.unref(z.BtnGroup),{ref_key:"target",ref:o,class:e.normalizeClass(e.unref(g))},{default:e.withCtx(()=>[e.renderSlot(l.$slots,"button",e.normalizeProps(e.guardReactiveProps({button:e.unref(a),$button:e.unref(p),expanded:e.unref(u),target:e.unref(o),toggle:e.unref(b),onBlur:e.unref(C),onClickToggle:e.unref(y),onClickItem:e.unref(r),onKeydown:e.unref(s)})),()=>[e.createVNode(P,{id:l.$attrs.id,ref_key:"button",ref:a,expanded:e.unref(u),class:e.normalizeClass(e.unref(B)),onBlur:e.unref(C),onClick:e.unref(y)},{default:e.withCtx(()=>[e.renderSlot(l.$slots,"icon"),e.renderSlot(l.$slots,"label",{},()=>[e.createTextVNode(e.toDisplayString(l.label),1)])]),_:3},8,["id","expanded","class","onBlur","onClick"])]),e.createVNode(e.unref(D.DropdownMenu),{id:l.$attrs.id,ref_key:"menu",ref:k,align:l.align,show:e.unref(u),class:e.normalizeClass({animated:e.unref(d)}),onBlur:e.unref(C),onClick:e.unref(r),onKeydown:e.withKeys(e.unref(s),["tab"]),onMousedown:h[0]||(h[0]=e.withModifiers(()=>{},["prevent"]))},{default:e.withCtx(()=>[e.renderSlot(l.$slots,"default")]),_:3},8,["id","align","show","class","onBlur","onClick","onKeydown"])]),_:3},8,["class"]))}}),j=["id","aria-expanded"],q=e.defineComponent({__name:"BtnDropdownSplit",props:{active:{type:Boolean},align:{},buttonClass:{},dropdown:{type:Boolean},dropup:{type:Boolean},dropleft:{type:Boolean},dropright:{type:Boolean},label:{},offset:{},size:{},split:{type:Boolean},variant:{}},emits:["click","click-toggle","blur"],setup(t,{emit:c}){const i=t,f=c,{actionClasses:a,classes:p,expanded:o,menu:g,target:u,toggleClasses:k,triggerAnimation:B,onBlur:d,onClickToggle:b,onClickItem:C,onKeydown:y}=V(i,f);return(r,s)=>(e.openBlock(),e.createBlock(e.unref(z.BtnGroup),{class:e.normalizeClass([e.unref(p),"btn-dropdown-split"])},{default:e.withCtx(()=>[r.dropleft?e.createCommentVNode("",!0):e.renderSlot(r.$slots,"button",e.normalizeProps(e.mergeProps({key:0},{expanded:e.unref(o),onBlur:e.unref(d),onClickToggle:e.unref(b),onClickItem:e.unref(C),onKeydown:e.unref(y)})),()=>[e.createVNode(P,{id:r.$attrs.id,expanded:e.unref(o),class:e.normalizeClass(e.unref(a)),onClick:s[0]||(s[0]=l=>f("click",l))},{default:e.withCtx(()=>[e.renderSlot(r.$slots,"icon"),e.renderSlot(r.$slots,"label",{},()=>[e.createTextVNode(e.toDisplayString(r.label),1)])]),_:3},8,["id","expanded","class"])]),e.createVNode(e.unref(z.BtnGroup),{ref_key:"target",ref:u},{default:e.withCtx(()=>[e.renderSlot(r.$slots,"split",{},()=>[e.createElementVNode("button",{id:r.$attrs.id,type:"button","aria-haspopup":"true","aria-expanded":e.unref(o),class:e.normalizeClass(e.unref(k)),onBlur:s[1]||(s[1]=(...l)=>e.unref(d)&&e.unref(d)(...l)),onClick:s[2]||(s[2]=(...l)=>e.unref(b)&&e.unref(b)(...l))},null,42,j)]),e.createVNode(e.unref(D.DropdownMenu),{ref_key:"menu",ref:g,align:r.align,show:e.unref(o),class:e.normalizeClass({animated:e.unref(B)}),onBlur:e.unref(d),onClick:e.unref(C),onKeydown:e.withKeys(e.unref(y),["tab"]),onMousedown:s[3]||(s[3]=e.withModifiers(()=>{},["prevent"]))},{default:e.withCtx(()=>[e.renderSlot(r.$slots,"default")]),_:3},8,["align","show","class","onBlur","onClick","onKeydown"])]),_:3},512),r.dropleft?e.renderSlot(r.$slots,"button",e.normalizeProps(e.mergeProps({key:1},{expanded:e.unref(o),onBlur:e.unref(d),onClickToggle:e.unref(b),onClickItem:e.unref(C),onKeydown:e.unref(y)})),()=>[e.createVNode(P,{id:r.$attrs.id,expanded:e.unref(o),class:e.normalizeClass(e.unref(a)),onClick:s[4]||(s[4]=l=>f("click",l))},{default:e.withCtx(()=>[e.renderSlot(r.$slots,"icon"),e.renderSlot(r.$slots,"label",{},()=>[e.createTextVNode(e.toDisplayString(r.label),1)])]),_:3},8,["id","expanded","class"])]):e.createCommentVNode("",!0)]),_:3},8,["class"]))}}),x=e.defineComponent({__name:"BtnDropdown",props:{active:{type:Boolean},align:{},buttonClass:{},dropdown:{type:Boolean},dropup:{type:Boolean},dropleft:{type:Boolean},dropright:{type:Boolean},label:{},offset:{},size:{},split:{type:Boolean},variant:{}},emits:["click"],setup(t,{emit:c}){const i=t,f=c;function a(o){return f("click",o)}const p=e.useSlots();return(o,g)=>(e.openBlock(),e.createBlock(e.resolveDynamicComponent(o.split?q:M),e.mergeProps(i,{class:"btn-dropdown",onClick:a}),e.createSlots({icon:e.withCtx(()=>[e.renderSlot(o.$slots,"icon")]),button:e.withCtx(u=>[e.renderSlot(o.$slots,"button",e.normalizeProps(e.guardReactiveProps(u)))]),split:e.withCtx(u=>[e.renderSlot(o.$slots,"split",e.normalizeProps(e.guardReactiveProps(u)))]),default:e.withCtx(()=>[e.renderSlot(o.$slots,"default")]),_:2},[o.label||e.unref(p).label?{name:"label",fn:e.withCtx(()=>[e.renderSlot(o.$slots,"label",{},()=>[e.createTextVNode(e.toDisplayString(o.label),1)])]),key:"0"}:void 0]),1040))}});m.BtnDropdown=x,Object.defineProperty(m,Symbol.toStringTag,{value:"Module"})});
|
|
2
2
|
//# sourceMappingURL=btn-dropdown.umd.cjs.map
|