@vue-interface/btn-dropdown 4.1.1 → 4.1.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.
@@ -1,14 +1,14 @@
1
- import { ref as D, computed as x, watchEffect as R, defineComponent as A, createElementBlock as I, openBlock as H, normalizeClass as y, unref as e, renderSlot as b, createVNode as N, normalizeProps as B, guardReactiveProps as S, createElementVNode as z, toDisplayString as M, withModifiers as V, normalizeStyle as F, withCtx as v, createCommentVNode as L, mergeProps as P, createBlock as G, resolveDynamicComponent as J } from "vue";
2
- import { DropdownMenu as j } from "@vue-interface/dropdown-menu";
3
- import { offset as K, flip as Q } from "@floating-ui/dom";
4
- import { useFloating as U } from "@floating-ui/vue";
5
- function q(t, c) {
6
- const p = D(), i = D(), u = D(!1), a = x(() => t.align ?? "start"), s = x(() => t.dropup ? "top" : t.dropleft ? "left" : t.dropright ? "right" : "bottom"), k = x(() => `${s.value}-${a.value}`), T = x(() => ({
1
+ import { ref as D, computed as x, watchEffect as O, defineComponent as A, createElementBlock as I, openBlock as H, normalizeClass as C, unref as e, renderSlot as y, createVNode as N, normalizeProps as v, guardReactiveProps as S, createElementVNode as z, toDisplayString as M, withModifiers as V, normalizeStyle as F, withCtx as h, createCommentVNode as L, mergeProps as P, useTemplateRef as G, createBlock as J, resolveDynamicComponent as K } from "vue";
2
+ import { DropdownMenu as R } from "@vue-interface/dropdown-menu";
3
+ import { offset as Q, flip as U } from "@floating-ui/dom";
4
+ import { useFloating as W } from "@floating-ui/vue";
5
+ function j(t, k) {
6
+ const p = D(), g = D(), s = D(!1), u = x(() => t.align ?? "start"), c = x(() => t.dropup ? "top" : t.dropleft ? "left" : t.dropright ? "right" : "bottom"), a = x(() => `${c.value}-${u.value}`), i = x(() => ({
7
7
  dropdown: t.dropup && t.dropright && t.dropleft,
8
8
  dropup: t.dropup,
9
9
  dropright: t.dropright,
10
10
  dropleft: t.dropleft,
11
- expanded: u.value,
11
+ expanded: s.value,
12
12
  [t.size ?? ""]: !!t.size
13
13
  })), d = x(() => {
14
14
  const l = {
@@ -24,71 +24,71 @@ function q(t, c) {
24
24
  l[E] = !0;
25
25
  else t.buttonClass && Object.assign(l, t.buttonClass);
26
26
  return l;
27
- }), { floatingStyles: $, update: C } = U(p, i, {
28
- placement: k,
27
+ }), { floatingStyles: T, update: B } = W(p, g, {
28
+ placement: a,
29
29
  middleware: t.middleware ?? [
30
- K(t.offset ?? 5),
31
- Q()
30
+ Q(t.offset ?? 5),
31
+ U()
32
32
  ]
33
33
  });
34
34
  function w() {
35
- u.value = !0, !(!p.value || !i.value) && (C(), c("show"));
35
+ s.value = !0, !(!p.value || !g.value) && (B(), k("show"));
36
36
  }
37
- function m() {
38
- u.value = !1, p.value?.blur(), c("hide");
37
+ function b() {
38
+ s.value = !1, p.value?.blur(), k("hide");
39
39
  }
40
40
  function r() {
41
- u.value ? m() : w();
41
+ s.value ? b() : w();
42
42
  }
43
- function g(l) {
44
- const E = Array.from(i.value?.$el.querySelectorAll("label, input, select, textarea") ?? []);
45
- for (const O in E)
46
- if (l === E[O])
43
+ function m(l) {
44
+ const E = Array.from(g.value?.$el.querySelectorAll("label, input, select, textarea") ?? []);
45
+ for (const q in E)
46
+ if (l === E[q])
47
47
  return !0;
48
48
  return !1;
49
49
  }
50
- function h(l) {
50
+ function $(l) {
51
51
  if (!(l.relatedTarget instanceof HTMLElement)) {
52
- m();
52
+ b();
53
53
  return;
54
54
  }
55
- (i.value && !i.value?.$el.contains(l.relatedTarget) || !p.value?.contains(l.relatedTarget)) && m();
55
+ (g.value && !g.value?.$el.contains(l.relatedTarget) || !p.value?.contains(l.relatedTarget)) && b();
56
56
  }
57
57
  function f(l) {
58
- c("click", l);
58
+ k("click", l);
59
59
  }
60
60
  function o(l) {
61
- l.target?.dispatchEvent(new Event("focus", l)), c("clickToggle", l), l.defaultPrevented || r();
61
+ l.target?.dispatchEvent(new Event("focus", l)), k("clickToggle", l), l.defaultPrevented || r();
62
62
  }
63
63
  function n(l) {
64
64
  if (!(l.target instanceof HTMLElement)) {
65
- m();
65
+ b();
66
66
  return;
67
67
  }
68
- !g(l.target) && !l.defaultPrevented && m();
68
+ !m(l.target) && !l.defaultPrevented && b();
69
69
  }
70
- return R(() => {
71
- u.value ? window.addEventListener("resize", C) : window.removeEventListener("resize", C);
70
+ return O(() => {
71
+ s.value ? window.addEventListener("resize", B) : window.removeEventListener("resize", B);
72
72
  }), {
73
73
  target: p,
74
- menu: i,
75
- alignment: a,
76
- expanded: u,
77
- floatingStyles: $,
78
- placement: k,
79
- side: s,
80
- classes: T,
74
+ menu: g,
75
+ alignment: u,
76
+ expanded: s,
77
+ floatingStyles: T,
78
+ placement: a,
79
+ side: c,
80
+ classes: i,
81
81
  buttonClasses: d,
82
82
  show: w,
83
- hide: m,
83
+ hide: b,
84
84
  toggle: r,
85
- onBlur: h,
85
+ onBlur: $,
86
86
  onClick: f,
87
87
  onClickToggle: o,
88
88
  onClickItem: n
89
89
  };
90
90
  }
91
- const W = ["aria-expanded"], X = /* @__PURE__ */ A({
91
+ const X = ["aria-expanded"], Y = /* @__PURE__ */ A({
92
92
  __name: "BtnDropdownSingle",
93
93
  props: {
94
94
  align: {},
@@ -107,62 +107,62 @@ const W = ["aria-expanded"], X = /* @__PURE__ */ A({
107
107
  variant: { default: "btn-primary" }
108
108
  },
109
109
  emits: ["click", "clickToggle", "show", "hide"],
110
- setup(t, { expose: c, emit: p }) {
111
- const i = t, u = p, {
112
- target: a,
113
- menu: s,
114
- buttonClasses: k,
115
- classes: T,
110
+ setup(t, { expose: k, emit: p }) {
111
+ const g = t, s = p, {
112
+ target: u,
113
+ menu: c,
114
+ buttonClasses: a,
115
+ classes: i,
116
116
  expanded: d,
117
- floatingStyles: $,
118
- show: C,
117
+ floatingStyles: T,
118
+ show: B,
119
119
  hide: w,
120
- toggle: m,
120
+ toggle: b,
121
121
  onBlur: r,
122
- onClickToggle: g,
123
- onClickItem: h
124
- } = q(i, u);
125
- return c({
126
- show: C,
122
+ onClickToggle: m,
123
+ onClickItem: $
124
+ } = j(g, s);
125
+ return k({
126
+ show: B,
127
127
  hide: w,
128
- toggle: m
128
+ toggle: b
129
129
  }), (f, o) => (H(), I("div", {
130
- class: y(["btn-group", e(T)])
130
+ class: C(["btn-group", e(i)])
131
131
  }, [
132
- b(f.$slots, "button", B(S({ target: (n) => a.value = n, expanded: e(d), onBlur: e(r), onClickToggle: e(g) })), () => [
132
+ y(f.$slots, "button", v(S({ target: (n) => u.value = n, expanded: e(d), onBlur: e(r), onClickToggle: e(m) })), () => [
133
133
  z("button", {
134
134
  ref_key: "target",
135
- ref: a,
135
+ ref: u,
136
136
  type: "button",
137
- class: y({ ...e(k), "dropdown-toggle": !0 }),
137
+ class: C({ ...e(a), "dropdown-toggle": !0 }),
138
138
  "aria-haspopup": "true",
139
139
  "aria-expanded": e(d),
140
140
  onBlur: o[0] || (o[0] = //@ts-ignore
141
141
  (...n) => e(r) && e(r)(...n)),
142
142
  onClick: o[1] || (o[1] = //@ts-ignore
143
- (...n) => e(g) && e(g)(...n))
144
- }, M(t.label), 43, W)
143
+ (...n) => e(m) && e(m)(...n))
144
+ }, M(t.label), 43, X)
145
145
  ]),
146
- N(e(j), {
146
+ N(e(R), {
147
147
  ref_key: "menu",
148
- ref: s,
149
- class: y({
148
+ ref: c,
149
+ class: C({
150
150
  show: e(d)
151
151
  }),
152
- style: F(e($)),
152
+ style: F(e(T)),
153
153
  onBlur: e(r),
154
- onClick: e(h),
154
+ onClick: e($),
155
155
  onMousedown: o[2] || (o[2] = V(() => {
156
156
  }, ["prevent"]))
157
157
  }, {
158
- default: v(() => [
159
- b(f.$slots, "default")
158
+ default: h(() => [
159
+ y(f.$slots, "default")
160
160
  ]),
161
161
  _: 3
162
162
  }, 8, ["class", "style", "onBlur", "onClick"])
163
163
  ], 2));
164
164
  }
165
- }), Y = ["aria-expanded"], Z = { class: "btn-group" }, _ = ["aria-expanded"], ee = ["aria-expanded"], te = /* @__PURE__ */ A({
165
+ }), Z = ["aria-expanded"], _ = { class: "btn-group" }, ee = ["aria-expanded"], te = ["aria-expanded"], oe = /* @__PURE__ */ A({
166
166
  __name: "BtnDropdownSplit",
167
167
  props: {
168
168
  align: {},
@@ -181,88 +181,88 @@ const W = ["aria-expanded"], X = /* @__PURE__ */ A({
181
181
  variant: { default: "btn-primary" }
182
182
  },
183
183
  emits: ["click", "clickToggle", "show", "hide"],
184
- setup(t, { expose: c, emit: p }) {
185
- const i = t, u = p, {
186
- target: a,
187
- menu: s,
188
- buttonClasses: k,
189
- classes: T,
184
+ setup(t, { expose: k, emit: p }) {
185
+ const g = t, s = p, {
186
+ target: u,
187
+ menu: c,
188
+ buttonClasses: a,
189
+ classes: i,
190
190
  expanded: d,
191
- floatingStyles: $,
192
- show: C,
191
+ floatingStyles: T,
192
+ show: B,
193
193
  hide: w,
194
- toggle: m,
194
+ toggle: b,
195
195
  onBlur: r,
196
- onClickToggle: g,
197
- onClickItem: h
198
- } = q(i, u);
199
- return c({
200
- show: C,
196
+ onClickToggle: m,
197
+ onClickItem: $
198
+ } = j(g, s);
199
+ return k({
200
+ show: B,
201
201
  hide: w,
202
- toggle: m
202
+ toggle: b
203
203
  }), (f, o) => (H(), I("div", {
204
- class: y(["btn-group btn-dropdown-split", e(T)])
204
+ class: C(["btn-group btn-dropdown-split", e(i)])
205
205
  }, [
206
- t.dropleft ? L("", !0) : b(f.$slots, "button", B(P({ key: 0 }, { expanded: e(d), onBlur: e(r), onClickToggle: e(g) })), () => [
206
+ t.dropleft ? L("", !0) : y(f.$slots, "button", v(P({ key: 0 }, { expanded: e(d), onBlur: e(r), onClickToggle: e(m) })), () => [
207
207
  z("button", {
208
208
  type: "button",
209
- class: y(e(k)),
209
+ class: C(e(a)),
210
210
  "aria-haspopup": "true",
211
211
  "aria-expanded": e(d),
212
212
  onBlur: o[0] || (o[0] = //@ts-ignore
213
213
  (...n) => e(r) && e(r)(...n)),
214
214
  onClick: o[1] || (o[1] = //@ts-ignore
215
215
  (...n) => f.onClick && f.onClick(...n))
216
- }, M(t.label), 43, Y)
216
+ }, M(t.label), 43, Z)
217
217
  ]),
218
- z("div", Z, [
219
- b(f.$slots, "toggle", B(S({ target: (n) => a.value = n, expanded: e(d), onBlur: e(r), onClickToggle: e(g) })), () => [
218
+ z("div", _, [
219
+ y(f.$slots, "toggle", v(S({ target: (n) => u.value = n, expanded: e(d), onBlur: e(r), onClickToggle: e(m) })), () => [
220
220
  z("button", {
221
221
  ref_key: "target",
222
- ref: a,
222
+ ref: u,
223
223
  type: "button",
224
224
  "aria-haspopup": "true",
225
225
  "aria-expanded": e(d),
226
- class: y({ ...e(k), "dropdown-toggle": !0, "dropdown-toggle-split": t.split }),
226
+ class: C({ ...e(a), "dropdown-toggle": !0, "dropdown-toggle-split": t.split }),
227
227
  onBlur: o[2] || (o[2] = //@ts-ignore
228
228
  (...n) => e(r) && e(r)(...n)),
229
229
  onClick: o[3] || (o[3] = //@ts-ignore
230
- (...n) => e(g) && e(g)(...n))
231
- }, null, 42, _)
230
+ (...n) => e(m) && e(m)(...n))
231
+ }, null, 42, ee)
232
232
  ]),
233
- N(e(j), {
233
+ N(e(R), {
234
234
  ref_key: "menu",
235
- ref: s,
236
- class: y({
235
+ ref: c,
236
+ class: C({
237
237
  show: e(d)
238
238
  }),
239
- style: F(e($)),
239
+ style: F(e(T)),
240
240
  onBlur: e(r),
241
- onClick: e(h),
241
+ onClick: e($),
242
242
  onMousedown: o[4] || (o[4] = V(() => {
243
243
  }, ["prevent"]))
244
244
  }, {
245
- default: v(() => [
246
- b(f.$slots, "default")
245
+ default: h(() => [
246
+ y(f.$slots, "default")
247
247
  ]),
248
248
  _: 3
249
249
  }, 8, ["class", "style", "onBlur", "onClick"])
250
250
  ]),
251
- t.dropleft ? b(f.$slots, "button", B(P({ key: 1 }, { expanded: e(d), onBlur: e(r), onClickToggle: e(g) })), () => [
251
+ t.dropleft ? y(f.$slots, "button", v(P({ key: 1 }, { expanded: e(d), onBlur: e(r), onClickToggle: e(m) })), () => [
252
252
  z("button", {
253
253
  type: "button",
254
- class: y(e(k)),
254
+ class: C(e(a)),
255
255
  "aria-haspopup": "true",
256
256
  "aria-expanded": e(d),
257
257
  onBlur: o[5] || (o[5] = //@ts-ignore
258
258
  (...n) => e(r) && e(r)(...n)),
259
259
  onClick: o[6] || (o[6] = //@ts-ignore
260
260
  (...n) => f.onClick && f.onClick(...n))
261
- }, M(t.label), 43, ee)
261
+ }, M(t.label), 43, te)
262
262
  ]) : L("", !0)
263
263
  ], 2));
264
264
  }
265
- }), ae = /* @__PURE__ */ A({
265
+ }), se = /* @__PURE__ */ A({
266
266
  __name: "BtnDropdown",
267
267
  props: {
268
268
  split: { type: Boolean, default: !1 },
@@ -281,31 +281,38 @@ const W = ["aria-expanded"], X = /* @__PURE__ */ A({
281
281
  variant: {}
282
282
  },
283
283
  emits: ["click", "clickToggle", "show", "hide"],
284
- setup(t, { emit: c }) {
285
- const p = t, i = c;
286
- return (u, a) => (H(), G(J(t.split ? te : X), P(p, {
287
- onClick: a[0] || (a[0] = (s) => i("click", s)),
288
- onClickToggle: a[1] || (a[1] = (s) => i("clickToggle", s)),
289
- onShow: a[2] || (a[2] = () => i("show")),
290
- onHide: a[3] || (a[3] = () => i("hide"))
284
+ setup(t, { expose: k, emit: p }) {
285
+ const g = t, s = p, u = G("el");
286
+ return k({
287
+ hide: () => u.value?.hide(),
288
+ show: () => u.value?.show(),
289
+ toggle: () => u.value?.toggle()
290
+ }), (c, a) => (H(), J(K(t.split ? oe : Y), P({
291
+ ref_key: "el",
292
+ ref: u
293
+ }, g, {
294
+ onClick: a[0] || (a[0] = (i) => s("click", i)),
295
+ onClickToggle: a[1] || (a[1] = (i) => s("clickToggle", i)),
296
+ onShow: a[2] || (a[2] = () => s("show")),
297
+ onHide: a[3] || (a[3] = () => s("hide"))
291
298
  }), {
292
- button: v((s) => [
293
- b(u.$slots, "button", B(S(s)))
299
+ button: h((i) => [
300
+ y(c.$slots, "button", v(S(i)))
294
301
  ]),
295
- toggle: v((s) => [
296
- b(u.$slots, "toggle", B(S(s)))
302
+ toggle: h((i) => [
303
+ y(c.$slots, "toggle", v(S(i)))
297
304
  ]),
298
- split: v((s) => [
299
- b(u.$slots, "split", B(S(s)))
305
+ split: h((i) => [
306
+ y(c.$slots, "split", v(S(i)))
300
307
  ]),
301
- default: v(() => [
302
- b(u.$slots, "default")
308
+ default: h(() => [
309
+ y(c.$slots, "default")
303
310
  ]),
304
311
  _: 3
305
312
  }, 16));
306
313
  }
307
314
  });
308
315
  export {
309
- ae as BtnDropdown
316
+ se as BtnDropdown
310
317
  };
311
318
  //# sourceMappingURL=btn-dropdown.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"btn-dropdown.js","sources":["../src/useDropdownHandler.ts","../src/BtnDropdownSingle.vue","../src/BtnDropdownSplit.vue","../src/BtnDropdown.vue"],"sourcesContent":["import { flip, offset, Placement, type Alignment, type Middleware, type OffsetOptions, type Side } from '@floating-ui/dom';\nimport { useFloating, UseFloatingReturn } from '@floating-ui/vue';\nimport { DropdownMenu } from '@vue-interface/dropdown-menu';\nimport { computed, ComputedRef, Ref, ref, watchEffect, type EmitFn, type HTMLAttributes } from 'vue';\n\ntype LiteralUnion<T extends U, U = string> = T | (U & Record<never, never>);\n\nexport type BtnGroupSizes = 'btn-group-xs'\n | 'btn-group-sm' \n | 'btn-group-md'\n | 'btn-group-lg'\n | 'btn-group-xl'\n | 'btn-group-2xl'\n | 'btn-group-3xl'\n | 'btn-group-4xl';\n\nexport type BtnDropdownProps = {\n align?: Alignment;\n block?: boolean;\n buttonClass?: HTMLAttributes['class'],\n caret?: boolean;\n dropup?: boolean;\n dropright?: boolean;\n dropleft?: boolean;\n label?: string;\n offset?: OffsetOptions,\n middleware?: Middleware[],\n side?: Side;\n size?: LiteralUnion<BtnGroupSizes>;\n split?: boolean;\n variant?: string;\n}\n\nexport type BtnDropdownEvents = {\n click: [event: MouseEvent];\n clickToggle: [event: MouseEvent];\n show: [],\n hide: []\n}\n\nexport type UseDropdownHandler = {\n target: Ref<HTMLElement|undefined>;\n menu: Ref<InstanceType<typeof DropdownMenu>|undefined>;\n alignment: ComputedRef<Alignment>;\n expanded: Ref<boolean>;\n floatingStyles: UseFloatingReturn['floatingStyles'];\n placement: ComputedRef<Placement>;\n side: ComputedRef<Side>;\n classes: ComputedRef<Record<string, boolean|undefined>>;\n buttonClasses: ComputedRef<Record<string, boolean>>;\n show: () => void;\n hide: () => void;\n toggle: () => void;\n onBlur: (e: FocusEvent) => void;\n onClick: (e: MouseEvent) => void;\n onClickToggle: (e: MouseEvent) => void;\n onClickItem: (e: PointerEvent) => void;\n}\n\nexport function useDropdownHandler(props: BtnDropdownProps, emit: EmitFn<BtnDropdownEvents>): UseDropdownHandler {\n const target = ref<HTMLElement>();\n const menu = ref<InstanceType<typeof DropdownMenu>>();\n const expanded = ref(false);\n\n const alignment = computed<Alignment>(() => props.align ?? 'start');\n\n const side = computed<Side>(() => {\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 placement = computed<Placement>(() => `${side.value}-${alignment.value}`);\n\n const classes = computed<Record<string,boolean|undefined>>(() => ({\n 'dropdown': props.dropup && props.dropright && props.dropleft,\n 'dropup': props.dropup,\n 'dropright': props.dropright,\n 'dropleft': props.dropleft,\n 'expanded': expanded.value,\n [props.size ?? '']: !!props.size,\n }));\n \n const buttonClasses = computed(() => {\n const classes = {\n btn: true,\n [props.variant ?? '']: !!props.variant,\n 'btn-block': !!props.block,\n 'no-caret': !props.caret\n };\n \n if(typeof props.buttonClass === 'string') {\n classes[props.buttonClass] = true;\n }\n else if(Array.isArray(props.buttonClass)) {\n for(const value of props.buttonClass) {\n classes[value] = true;\n }\n }\n else if(props.buttonClass) {\n Object.assign(classes, props.buttonClass);\n }\n\n return classes;\n });\n\n const { floatingStyles, update } = useFloating(target, menu, {\n placement: placement,\n middleware: props.middleware ?? [\n offset(props.offset ?? 5),\n flip()\n ]\n });\n\n function show() {\n expanded.value = true;\n\n if(!target.value || !menu.value) {\n return;\n }\n\n update();\n\n emit('show');\n }\n\n function hide() {\n expanded.value = false;\n\n target.value?.blur();\n\n emit('hide');\n }\n\n function toggle() {\n if(!expanded.value) {\n show();\n }\n else {\n hide();\n }\n }\n\n function isFocusable(element: HTMLElement) {\n const nodes = Array.from(menu.value?.$el.querySelectorAll('label, input, select, textarea') ?? []);\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 if(!(e.relatedTarget instanceof HTMLElement)) {\n hide();\n \n return;\n }\n \n if(menu.value && !menu.value?.$el.contains(e.relatedTarget) || !target.value?.contains(e.relatedTarget)) {\n hide();\n }\n }\n\n function onClick(e: MouseEvent) {\n emit('click', e);\n }\n\n function onClickToggle(e: MouseEvent) {\n e.target?.dispatchEvent(new Event('focus', e));\n \n emit('clickToggle', e);\n\n if(!e.defaultPrevented) {\n toggle();\n }\n }\n\n function onClickItem(e: PointerEvent) {\n if(!(e.target instanceof HTMLElement)) {\n hide();\n\n return;\n }\n\n if(!isFocusable(e.target) && !e.defaultPrevented) {\n hide();\n }\n }\n\n watchEffect(() => {\n if(expanded.value) {\n window.addEventListener('resize', update);\n }\n else {\n window.removeEventListener('resize', update);\n }\n });\n\n return {\n target,\n menu,\n alignment,\n expanded,\n floatingStyles,\n placement,\n side,\n classes,\n buttonClasses,\n show,\n hide,\n toggle,\n onBlur,\n onClick,\n onClickToggle,\n onClickItem\n };\n}","<script setup lang=\"ts\">\nimport { DropdownMenu } from '@vue-interface/dropdown-menu';\nimport { BtnDropdownEvents, BtnDropdownProps, useDropdownHandler } from './useDropdownHandler';\n\nconst props = withDefaults(defineProps<BtnDropdownProps>(), {\n caret: true,\n variant: 'btn-primary'\n});\n\nconst emit = defineEmits<BtnDropdownEvents>();\n\nconst {\n target,\n menu,\n buttonClasses,\n classes,\n expanded,\n floatingStyles,\n show,\n hide,\n toggle,\n onBlur,\n onClickToggle,\n onClickItem\n} = useDropdownHandler(props, emit);\n\ndefineExpose({\n show,\n hide,\n toggle,\n});\n</script>\n\n<template>\n <div\n class=\"btn-group\"\n :class=\"classes\">\n <slot\n name=\"button\"\n v-bind=\"{ target: (el: HTMLElement) => target = el, expanded, onBlur, onClickToggle }\">\n <button\n ref=\"target\"\n type=\"button\"\n :class=\"{...buttonClasses, ['dropdown-toggle']: true}\"\n aria-haspopup=\"true\"\n :aria-expanded=\"expanded\"\n @blur=\"onBlur\"\n @click=\"onClickToggle\">\n {{ label }}\n </button>\n </slot>\n <DropdownMenu\n ref=\"menu\"\n :class=\"{\n 'show': expanded\n }\"\n :style=\"floatingStyles\"\n @blur=\"onBlur\"\n @click=\"onClickItem\"\n @mousedown.prevent>\n <slot />\n </DropdownMenu>\n </div>\n</template>","<script setup lang=\"ts\">\nimport { DropdownMenu } from '@vue-interface/dropdown-menu';\nimport { BtnDropdownEvents, BtnDropdownProps, useDropdownHandler } from './useDropdownHandler';\n\nconst props = withDefaults(defineProps<BtnDropdownProps>(), {\n caret: true,\n variant: 'btn-primary'\n});\n\nconst emit = defineEmits<BtnDropdownEvents>();\n\nconst {\n target,\n menu,\n buttonClasses,\n classes,\n expanded,\n floatingStyles,\n show,\n hide,\n toggle,\n onBlur,\n onClickToggle,\n onClickItem\n} = useDropdownHandler(props, emit);\n\ndefineExpose({\n show,\n hide,\n toggle,\n});\n</script>\n\n<template>\n <div\n class=\"btn-group btn-dropdown-split\"\n :class=\"classes\">\n <slot\n v-if=\"!dropleft\"\n name=\"button\"\n v-bind=\"{ expanded, onBlur, onClickToggle }\">\n <button\n type=\"button\"\n :class=\"buttonClasses\"\n aria-haspopup=\"true\"\n :aria-expanded=\"expanded\"\n @blur=\"onBlur\"\n @click=\"onClick\">\n {{ label }}\n </button>\n </slot>\n <div class=\"btn-group\">\n <slot\n name=\"toggle\"\n v-bind=\"{ target: (el: HTMLElement) => target = el, expanded, onBlur, onClickToggle }\">\n <button\n ref=\"target\"\n type=\"button\"\n aria-haspopup=\"true\"\n :aria-expanded=\"expanded\"\n :class=\"{...buttonClasses, 'dropdown-toggle': true, 'dropdown-toggle-split': split}\"\n @blur=\"onBlur\"\n @click=\"onClickToggle\" />\n </slot>\n <DropdownMenu\n ref=\"menu\"\n :class=\"{\n 'show': expanded\n }\"\n :style=\"floatingStyles\"\n @blur=\"onBlur\"\n @click=\"onClickItem\"\n @mousedown.prevent>\n <slot />\n </DropdownMenu>\n </div>\n <slot\n v-if=\"dropleft\"\n name=\"button\"\n v-bind=\"{ expanded, onBlur, onClickToggle }\">\n <button\n type=\"button\"\n :class=\"buttonClasses\"\n aria-haspopup=\"true\"\n :aria-expanded=\"expanded\"\n @blur=\"onBlur\"\n @click=\"onClick\">\n {{ label }}\n </button>\n </slot>\n </div>\n</template>","<script setup lang=\"ts\">\nimport BtnDropdownSingle from './BtnDropdownSingle.vue';\nimport BtnDropdownSplit from './BtnDropdownSplit.vue';\nimport { BtnDropdownEvents, BtnDropdownProps } from './useDropdownHandler';\n\nconst props = withDefaults(defineProps<{\n split?: boolean\n} & BtnDropdownProps>(), {\n split: false,\n caret: true\n});\n\nconst emit = defineEmits<BtnDropdownEvents>();\n</script>\n\n<template>\n <Component\n :is=\"!split ? BtnDropdownSingle : BtnDropdownSplit\"\n v-bind=\"props\"\n @click=\"(e: MouseEvent) => emit('click', e)\"\n @click-toggle=\"(e: MouseEvent) => emit('clickToggle', e)\"\n @show=\"() => emit('show')\"\n @hide=\"() => emit('hide')\">\n <template #button=\"slot\">\n <slot\n name=\"button\"\n v-bind=\"slot\" />\n </template>\n <template #toggle=\"slot\">\n <slot\n name=\"toggle\"\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":["useDropdownHandler","props","emit","target","ref","menu","expanded","alignment","computed","side","placement","classes","buttonClasses","value","floatingStyles","update","useFloating","offset","flip","show","hide","toggle","isFocusable","element","nodes","i","onBlur","e","onClick","onClickToggle","onClickItem","watchEffect","__props","__emit","__expose","_createElementBlock","_normalizeClass","_unref","_renderSlot","_ctx","_normalizeProps","_guardReactiveProps","el","_createElementVNode","_cache","args","_hoisted_1","_createVNode","DropdownMenu","_hoisted_2","_hoisted_4","_createBlock","_resolveDynamicComponent","BtnDropdownSplit","BtnDropdownSingle","_mergeProps","_withCtx","slot"],"mappings":";;;;AA2DO,SAASA,EAAmBC,GAAyBC,GAAqD;AAC7G,QAAMC,IAASC,EAAA,GACTC,IAAOD,EAAA,GACPE,IAAWF,EAAI,EAAK,GAEpBG,IAAYC,EAAoB,MAAMP,EAAM,SAAS,OAAO,GAE5DQ,IAAOD,EAAe,MACrBP,EAAM,SACE,QAGRA,EAAM,WACE,SAGRA,EAAM,YACE,UAGJ,QACV,GAEKS,IAAYF,EAAoB,MAAM,GAAGC,EAAK,KAAK,IAAIF,EAAU,KAAK,EAAE,GAExEI,IAAUH,EAA2C,OAAO;AAAA,IAC9D,UAAYP,EAAM,UAAUA,EAAM,aAAaA,EAAM;AAAA,IACrD,QAAUA,EAAM;AAAA,IAChB,WAAaA,EAAM;AAAA,IACnB,UAAYA,EAAM;AAAA,IAClB,UAAYK,EAAS;AAAA,IACrB,CAACL,EAAM,QAAQ,EAAE,GAAG,CAAC,CAACA,EAAM;AAAA,EAAA,EAC9B,GAEIW,IAAgBJ,EAAS,MAAM;AACjC,UAAMG,IAAU;AAAA,MACZ,KAAK;AAAA,MACL,CAACV,EAAM,WAAW,EAAE,GAAG,CAAC,CAACA,EAAM;AAAA,MAC/B,aAAa,CAAC,CAACA,EAAM;AAAA,MACrB,YAAY,CAACA,EAAM;AAAA,IAAA;AAGvB,QAAG,OAAOA,EAAM,eAAgB;AAC5BU,MAAAA,EAAQV,EAAM,WAAW,IAAI;AAAA,aAEzB,MAAM,QAAQA,EAAM,WAAW;AACnC,iBAAUY,KAASZ,EAAM;AACrBU,QAAAA,EAAQE,CAAK,IAAI;AAAA,QAEzB,CACQZ,EAAM,eACV,OAAO,OAAOU,GAASV,EAAM,WAAW;AAG5C,WAAOU;AAAAA,EACX,CAAC,GAEK,EAAE,gBAAAG,GAAgB,QAAAC,EAAA,IAAWC,EAAYb,GAAQE,GAAM;AAAA,IACzD,WAAAK;AAAA,IACA,YAAYT,EAAM,cAAc;AAAA,MAC5BgB,EAAOhB,EAAM,UAAU,CAAC;AAAA,MACxBiB,EAAA;AAAA,IAAK;AAAA,EACT,CACH;AAED,WAASC,IAAO;AAGZ,IAFAb,EAAS,QAAQ,IAEd,GAACH,EAAO,SAAS,CAACE,EAAK,WAI1BU,EAAA,GAEAb,EAAK,MAAM;AAAA,EACf;AAEA,WAASkB,IAAO;AACZ,IAAAd,EAAS,QAAQ,IAEjBH,EAAO,OAAO,KAAA,GAEdD,EAAK,MAAM;AAAA,EACf;AAEA,WAASmB,IAAS;AACd,IAAIf,EAAS,QAITc,EAAA,IAHAD,EAAA;AAAA,EAKR;AAEA,WAASG,EAAYC,GAAsB;AACvC,UAAMC,IAAQ,MAAM,KAAKnB,EAAK,OAAO,IAAI,iBAAiB,gCAAgC,KAAK,EAAE;AAEjG,eAAUoB,KAAKD;AACX,UAAGD,MAAYC,EAAMC,CAAC;AAClB,eAAO;AAIf,WAAO;AAAA,EACX;AAEA,WAASC,EAAOC,GAAe;AAC3B,QAAG,EAAEA,EAAE,yBAAyB,cAAc;AAC1C,MAAAP,EAAA;AAEA;AAAA,IACJ;AAEA,KAAGf,EAAK,SAAS,CAACA,EAAK,OAAO,IAAI,SAASsB,EAAE,aAAa,KAAK,CAACxB,EAAO,OAAO,SAASwB,EAAE,aAAa,MAClGP,EAAA;AAAA,EAER;AAEA,WAASQ,EAAQD,GAAe;AAC5B,IAAAzB,EAAK,SAASyB,CAAC;AAAA,EACnB;AAEA,WAASE,EAAcF,GAAe;AAClC,IAAAA,EAAE,QAAQ,cAAc,IAAI,MAAM,SAASA,CAAC,CAAC,GAE7CzB,EAAK,eAAeyB,CAAC,GAEjBA,EAAE,oBACFN,EAAA;AAAA,EAER;AAEA,WAASS,EAAYH,GAAiB;AAClC,QAAG,EAAEA,EAAE,kBAAkB,cAAc;AACnC,MAAAP,EAAA;AAEA;AAAA,IACJ;AAEA,IAAG,CAACE,EAAYK,EAAE,MAAM,KAAK,CAACA,EAAE,oBAC5BP,EAAA;AAAA,EAER;AAEA,SAAAW,EAAY,MAAM;AACd,IAAGzB,EAAS,QACR,OAAO,iBAAiB,UAAUS,CAAM,IAGxC,OAAO,oBAAoB,UAAUA,CAAM;AAAA,EAEnD,CAAC,GAEM;AAAA,IACH,QAAAZ;AAAA,IACA,MAAAE;AAAA,IACA,WAAAE;AAAA,IACA,UAAAD;AAAA,IACA,gBAAAQ;AAAA,IACA,WAAAJ;AAAA,IACA,MAAAD;AAAA,IACA,SAAAE;AAAA,IACA,eAAAC;AAAA,IACA,MAAAO;AAAA,IACA,MAAAC;AAAA,IACA,QAAAC;AAAA,IACA,QAAAK;AAAA,IACA,SAAAE;AAAA,IACA,eAAAC;AAAA,IACA,aAAAC;AAAA,EAAA;AAER;;;;;;;;;;;;;;;;;;;;;AClOA,UAAM7B,IAAQ+B,GAKR9B,IAAO+B,GAEP;AAAA,MACF,QAAA9B;AAAA,MACA,MAAAE;AAAA,MACA,eAAAO;AAAA,MACA,SAAAD;AAAA,MACA,UAAAL;AAAA,MACA,gBAAAQ;AAAA,MACA,MAAAK;AAAA,MACA,MAAAC;AAAA,MACA,QAAAC;AAAA,MACA,QAAAK;AAAA,MACA,eAAAG;AAAA,MACA,aAAAC;AAAA,IAAA,IACA9B,EAAmBC,GAAOC,CAAI;AAElC,WAAAgC,EAAa;AAAA,MACT,MAAAf;AAAA,MACA,MAAAC;AAAA,MACA,QAAAC;AAAA,IAAA,CACH,mBAIGc,EA4BM,OAAA;AAAA,MA3BF,OAAKC,EAAA,CAAC,aACEC,EAAA1B,CAAA,CAAO,CAAA;AAAA,IAAA;MACf2B,EAaOC,EAAA,QAAA,UAAAC,EAAAC,EAAA,EAAA,QAAA,CAXgBC,MAAoBvC,EAAA,QAASuC,GAAE,UAAEL,EAAA/B,CAAA,GAAQ,QAAE+B,EAAAX,CAAA,GAAM,eAAEW,EAAAR,CAAA,EAAA,KAF1E,MAaO;AAAA,QAVHc,EASS,UAAA;AAAA,mBARD;AAAA,UAAJ,KAAIxC;AAAA,UACJ,MAAK;AAAA,UACJ,cAAWkC,EAAAzB,CAAA,GAAa,mBAAA,IAAA;AAAA,UACzB,iBAAc;AAAA,UACb,iBAAeyB,EAAA/B,CAAA;AAAA,UACf,QAAIsC,EAAA,CAAA,MAAAA,EAAA,CAAA;AAAA,oBAAEP,EAAAX,CAAA,KAAAW,EAAAX,CAAA,EAAA,GAAAmB,CAAA;AAAA,UACN,SAAKD,EAAA,CAAA,MAAAA,EAAA,CAAA;AAAA,oBAAEP,EAAAR,CAAA,KAAAQ,EAAAR,CAAA,EAAA,GAAAgB,CAAA;AAAA,QAAA,KACLb,EAAA,KAAK,GAAA,IAAAc,CAAA;AAAA,MAAA;MAGhBC,EAUeV,EAAAW,CAAA,GAAA;AAAA,iBATP;AAAA,QAAJ,KAAI3C;AAAA,QACH,OAAK+B,EAAA;AAAA,gBAA4BC,EAAA/B,CAAA;AAAA,QAAA;QAGjC,SAAO+B,EAAAvB,CAAA,CAAc;AAAA,QACrB,QAAMuB,EAAAX,CAAA;AAAA,QACN,SAAOW,EAAAP,CAAA;AAAA,QACP,+BAAD,MAAA;AAAA,QAAA,GAAkB,CAAA,SAAA,CAAA;AAAA,MAAA;mBAClB,MAAQ;AAAA,UAARQ,EAAQC,EAAA,QAAA,SAAA;AAAA,QAAA;;;;;;;;;;;;;;;;;;;;;;;;;ACxDpB,UAAMtC,IAAQ+B,GAKR9B,IAAO+B,GAEP;AAAA,MACF,QAAA9B;AAAA,MACA,MAAAE;AAAA,MACA,eAAAO;AAAA,MACA,SAAAD;AAAA,MACA,UAAAL;AAAA,MACA,gBAAAQ;AAAA,MACA,MAAAK;AAAA,MACA,MAAAC;AAAA,MACA,QAAAC;AAAA,MACA,QAAAK;AAAA,MACA,eAAAG;AAAA,MACA,aAAAC;AAAA,IAAA,IACA9B,EAAmBC,GAAOC,CAAI;AAElC,WAAAgC,EAAa;AAAA,MACT,MAAAf;AAAA,MACA,MAAAC;AAAA,MACA,QAAAC;AAAA,IAAA,CACH,mBAIGc,EAwDM,OAAA;AAAA,MAvDF,OAAKC,EAAA,CAAC,gCACEC,EAAA1B,CAAA,CAAO,CAAA;AAAA,IAAA;MAEJqB,EAAA,uBADXM,EAaOC,gDAVOF,EAAA/B,CAAA,GAAQ,QAAE+B,MAAM,eAAEA,EAAAR,CAAA,EAAA,KAHhC,MAaO;AAAA,QATHc,EAQS,UAAA;AAAA,UAPL,MAAK;AAAA,UACJ,SAAON,EAAAzB,CAAA,CAAa;AAAA,UACrB,iBAAc;AAAA,UACb,iBAAeyB,EAAA/B,CAAA;AAAA,UACf,QAAIsC,EAAA,CAAA,MAAAA,EAAA,CAAA;AAAA,oBAAEP,EAAAX,CAAA,KAAAW,EAAAX,CAAA,EAAA,GAAAmB,CAAA;AAAA,UACN,SAAKD,EAAA,CAAA,MAAAA,EAAA,CAAA;AAAA,oBAAEL,EAAA,WAAAA,EAAA,QAAA,GAAAM,CAAA;AAAA,QAAA,KACLb,EAAA,KAAK,GAAA,IAAAc,CAAA;AAAA,MAAA;MAGhBH,EAwBM,OAxBNM,GAwBM;AAAA,QAvBFX,EAWOC,EAAA,QAAA,UAAAC,EAAAC,EAAA,EAAA,QAAA,CATgBC,MAAoBvC,EAAA,QAASuC,GAAE,UAAEL,EAAA/B,CAAA,GAAQ,QAAE+B,EAAAX,CAAA,GAAM,eAAEW,EAAAR,CAAA,EAAA,KAF1E,MAWO;AAAA,UARHc,EAO6B,UAAA;AAAA,qBANrB;AAAA,YAAJ,KAAIxC;AAAA,YACJ,MAAK;AAAA,YACL,iBAAc;AAAA,YACb,iBAAekC,EAAA/B,CAAA;AAAA,YACf,OAAK8B,EAAA,EAAA,GAAMC,EAAAzB,CAAA,GAAa,mBAAA,IAAA,yBAAoDoB,EAAA,MAAA,CAAK;AAAA,YACjF,QAAIY,EAAA,CAAA,MAAAA,EAAA,CAAA;AAAA,sBAAEP,EAAAX,CAAA,KAAAW,EAAAX,CAAA,EAAA,GAAAmB,CAAA;AAAA,YACN,SAAKD,EAAA,CAAA,MAAAA,EAAA,CAAA;AAAA,sBAAEP,EAAAR,CAAA,KAAAQ,EAAAR,CAAA,EAAA,GAAAgB,CAAA;AAAA,UAAA;;QAEhBE,EAUeV,EAAAW,CAAA,GAAA;AAAA,mBATP;AAAA,UAAJ,KAAI3C;AAAA,UACH,OAAK+B,EAAA;AAAA,kBAAgCC,EAAA/B,CAAA;AAAA,UAAA;UAGrC,SAAO+B,EAAAvB,CAAA,CAAc;AAAA,UACrB,QAAMuB,EAAAX,CAAA;AAAA,UACN,SAAOW,EAAAP,CAAA;AAAA,UACP,+BAAD,MAAA;AAAA,UAAA,GAAkB,CAAA,SAAA,CAAA;AAAA,QAAA;qBAClB,MAAQ;AAAA,YAARQ,EAAQC,EAAA,QAAA,SAAA;AAAA,UAAA;;;;MAINP,EAAA,WADVM,EAaOC,gDAVOF,EAAA/B,CAAA,GAAQ,QAAE+B,MAAM,eAAEA,EAAAR,CAAA,EAAA,KAHhC,MAaO;AAAA,QATHc,EAQS,UAAA;AAAA,UAPL,MAAK;AAAA,UACJ,SAAON,EAAAzB,CAAA,CAAa;AAAA,UACrB,iBAAc;AAAA,UACb,iBAAeyB,EAAA/B,CAAA;AAAA,UACf,QAAIsC,EAAA,CAAA,MAAAA,EAAA,CAAA;AAAA,oBAAEP,EAAAX,CAAA,KAAAW,EAAAX,CAAA,EAAA,GAAAmB,CAAA;AAAA,UACN,SAAKD,EAAA,CAAA,MAAAA,EAAA,CAAA;AAAA,oBAAEL,EAAA,WAAAA,EAAA,QAAA,GAAAM,CAAA;AAAA,QAAA,KACLb,EAAA,KAAK,GAAA,IAAAkB,EAAA;AAAA,MAAA;;;;;;;;;;;;;;;;;;;;;;;AClFxB,UAAMjD,IAAQ+B,GAOR9B,IAAO+B;2BAITkB,EAuBYC,EAtBFpB,UAA4BqB,KAApBC,CAAoC,GADtDC,EAuBYtD,GArBK;AAAA,MACZ,SAAK2C,EAAA,CAAA,MAAAA,EAAA,CAAA,IAAA,CAAGjB,MAAkBzB,WAAcyB,CAAC;AAAA,MACzC,eAAYiB,EAAA,CAAA,MAAAA,EAAA,CAAA,IAAA,CAAGjB,MAAkBzB,iBAAoByB,CAAC;AAAA,MACtD,8BAAYzB,EAAI,MAAA;AAAA,MAChB,8BAAYA,EAAI,MAAA;AAAA,IAAA;MACN,QAAMsD,EACb,CAEoBC,MAHD;AAAA,QACnBnB,EAEoBC,wBAARkB,CAAI,CAAA,CAAA;AAAA,MAAA;MAET,QAAMD,EACb,CAEoBC,MAHD;AAAA,QACnBnB,EAEoBC,wBAARkB,CAAI,CAAA,CAAA;AAAA,MAAA;MAET,OAAKD,EACZ,CAEoBC,MAHF;AAAA,QAClBnB,EAEoBC,uBAARkB,CAAI,CAAA,CAAA;AAAA,MAAA;iBAEpB,MAAQ;AAAA,QAARnB,EAAQC,EAAA,QAAA,SAAA;AAAA,MAAA;;;;;"}
1
+ {"version":3,"file":"btn-dropdown.js","sources":["../src/useDropdownHandler.ts","../src/BtnDropdownSingle.vue","../src/BtnDropdownSplit.vue","../src/BtnDropdown.vue"],"sourcesContent":["import { flip, offset, Placement, type Alignment, type Middleware, type OffsetOptions, type Side } from '@floating-ui/dom';\nimport { useFloating, UseFloatingReturn } from '@floating-ui/vue';\nimport { DropdownMenu } from '@vue-interface/dropdown-menu';\nimport { computed, ComputedRef, Ref, ref, watchEffect, type EmitFn, type HTMLAttributes } from 'vue';\n\ntype LiteralUnion<T extends U, U = string> = T | (U & Record<never, never>);\n\nexport type BtnGroupSizes = 'btn-group-xs'\n | 'btn-group-sm' \n | 'btn-group-md'\n | 'btn-group-lg'\n | 'btn-group-xl'\n | 'btn-group-2xl'\n | 'btn-group-3xl'\n | 'btn-group-4xl';\n\nexport type BtnDropdownProps = {\n align?: Alignment;\n block?: boolean;\n buttonClass?: HTMLAttributes['class'],\n caret?: boolean;\n dropup?: boolean;\n dropright?: boolean;\n dropleft?: boolean;\n label?: string;\n offset?: OffsetOptions,\n middleware?: Middleware[],\n side?: Side;\n size?: LiteralUnion<BtnGroupSizes>;\n split?: boolean;\n variant?: string;\n}\n\nexport type BtnDropdownEvents = {\n click: [event: MouseEvent];\n clickToggle: [event: MouseEvent];\n show: [],\n hide: []\n}\n\nexport type UseDropdownHandler = {\n target: Ref<HTMLElement|undefined>;\n menu: Ref<InstanceType<typeof DropdownMenu>|undefined>;\n alignment: ComputedRef<Alignment>;\n expanded: Ref<boolean>;\n floatingStyles: UseFloatingReturn['floatingStyles'];\n placement: ComputedRef<Placement>;\n side: ComputedRef<Side>;\n classes: ComputedRef<Record<string, boolean|undefined>>;\n buttonClasses: ComputedRef<Record<string, boolean>>;\n show: () => void;\n hide: () => void;\n toggle: () => void;\n onBlur: (e: FocusEvent) => void;\n onClick: (e: MouseEvent) => void;\n onClickToggle: (e: MouseEvent) => void;\n onClickItem: (e: PointerEvent) => void;\n}\n\nexport function useDropdownHandler(props: BtnDropdownProps, emit: EmitFn<BtnDropdownEvents>): UseDropdownHandler {\n const target = ref<HTMLElement>();\n const menu = ref<InstanceType<typeof DropdownMenu>>();\n const expanded = ref(false);\n\n const alignment = computed<Alignment>(() => props.align ?? 'start');\n\n const side = computed<Side>(() => {\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 placement = computed<Placement>(() => `${side.value}-${alignment.value}`);\n\n const classes = computed<Record<string,boolean|undefined>>(() => ({\n 'dropdown': props.dropup && props.dropright && props.dropleft,\n 'dropup': props.dropup,\n 'dropright': props.dropright,\n 'dropleft': props.dropleft,\n 'expanded': expanded.value,\n [props.size ?? '']: !!props.size,\n }));\n \n const buttonClasses = computed(() => {\n const classes = {\n btn: true,\n [props.variant ?? '']: !!props.variant,\n 'btn-block': !!props.block,\n 'no-caret': !props.caret\n };\n \n if(typeof props.buttonClass === 'string') {\n classes[props.buttonClass] = true;\n }\n else if(Array.isArray(props.buttonClass)) {\n for(const value of props.buttonClass) {\n classes[value] = true;\n }\n }\n else if(props.buttonClass) {\n Object.assign(classes, props.buttonClass);\n }\n\n return classes;\n });\n\n const { floatingStyles, update } = useFloating(target, menu, {\n placement: placement,\n middleware: props.middleware ?? [\n offset(props.offset ?? 5),\n flip()\n ]\n });\n\n function show() {\n expanded.value = true;\n\n if(!target.value || !menu.value) {\n return;\n }\n\n update();\n\n emit('show');\n }\n\n function hide() {\n expanded.value = false;\n\n target.value?.blur();\n\n emit('hide');\n }\n\n function toggle() {\n if(!expanded.value) {\n show();\n }\n else {\n hide();\n }\n }\n\n function isFocusable(element: HTMLElement) {\n const nodes = Array.from(menu.value?.$el.querySelectorAll('label, input, select, textarea') ?? []);\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 if(!(e.relatedTarget instanceof HTMLElement)) {\n hide();\n \n return;\n }\n \n if(menu.value && !menu.value?.$el.contains(e.relatedTarget) || !target.value?.contains(e.relatedTarget)) {\n hide();\n }\n }\n\n function onClick(e: MouseEvent) {\n emit('click', e);\n }\n\n function onClickToggle(e: MouseEvent) {\n e.target?.dispatchEvent(new Event('focus', e));\n \n emit('clickToggle', e);\n\n if(!e.defaultPrevented) {\n toggle();\n }\n }\n\n function onClickItem(e: PointerEvent) {\n if(!(e.target instanceof HTMLElement)) {\n hide();\n\n return;\n }\n\n if(!isFocusable(e.target) && !e.defaultPrevented) {\n hide();\n }\n }\n\n watchEffect(() => {\n if(expanded.value) {\n window.addEventListener('resize', update);\n }\n else {\n window.removeEventListener('resize', update);\n }\n });\n\n return {\n target,\n menu,\n alignment,\n expanded,\n floatingStyles,\n placement,\n side,\n classes,\n buttonClasses,\n show,\n hide,\n toggle,\n onBlur,\n onClick,\n onClickToggle,\n onClickItem\n };\n}","<script setup lang=\"ts\">\nimport { DropdownMenu } from '@vue-interface/dropdown-menu';\nimport { BtnDropdownEvents, BtnDropdownProps, useDropdownHandler } from './useDropdownHandler';\n\nconst props = withDefaults(defineProps<BtnDropdownProps>(), {\n caret: true,\n variant: 'btn-primary'\n});\n\nconst emit = defineEmits<BtnDropdownEvents>();\n\nconst {\n target,\n menu,\n buttonClasses,\n classes,\n expanded,\n floatingStyles,\n show,\n hide,\n toggle,\n onBlur,\n onClickToggle,\n onClickItem\n} = useDropdownHandler(props, emit);\n\ndefineExpose({\n show,\n hide,\n toggle,\n});\n</script>\n\n<template>\n <div\n class=\"btn-group\"\n :class=\"classes\">\n <slot\n name=\"button\"\n v-bind=\"{ target: (el: HTMLElement) => target = el, expanded, onBlur, onClickToggle }\">\n <button\n ref=\"target\"\n type=\"button\"\n :class=\"{...buttonClasses, ['dropdown-toggle']: true}\"\n aria-haspopup=\"true\"\n :aria-expanded=\"expanded\"\n @blur=\"onBlur\"\n @click=\"onClickToggle\">\n {{ label }}\n </button>\n </slot>\n <DropdownMenu\n ref=\"menu\"\n :class=\"{\n 'show': expanded\n }\"\n :style=\"floatingStyles\"\n @blur=\"onBlur\"\n @click=\"onClickItem\"\n @mousedown.prevent>\n <slot />\n </DropdownMenu>\n </div>\n</template>","<script setup lang=\"ts\">\nimport { DropdownMenu } from '@vue-interface/dropdown-menu';\nimport { BtnDropdownEvents, BtnDropdownProps, useDropdownHandler } from './useDropdownHandler';\n\nconst props = withDefaults(defineProps<BtnDropdownProps>(), {\n caret: true,\n variant: 'btn-primary'\n});\n\nconst emit = defineEmits<BtnDropdownEvents>();\n\nconst {\n target,\n menu,\n buttonClasses,\n classes,\n expanded,\n floatingStyles,\n show,\n hide,\n toggle,\n onBlur,\n onClickToggle,\n onClickItem\n} = useDropdownHandler(props, emit);\n\ndefineExpose({\n show,\n hide,\n toggle,\n});\n</script>\n\n<template>\n <div\n class=\"btn-group btn-dropdown-split\"\n :class=\"classes\">\n <slot\n v-if=\"!dropleft\"\n name=\"button\"\n v-bind=\"{ expanded, onBlur, onClickToggle }\">\n <button\n type=\"button\"\n :class=\"buttonClasses\"\n aria-haspopup=\"true\"\n :aria-expanded=\"expanded\"\n @blur=\"onBlur\"\n @click=\"onClick\">\n {{ label }}\n </button>\n </slot>\n <div class=\"btn-group\">\n <slot\n name=\"toggle\"\n v-bind=\"{ target: (el: HTMLElement) => target = el, expanded, onBlur, onClickToggle }\">\n <button\n ref=\"target\"\n type=\"button\"\n aria-haspopup=\"true\"\n :aria-expanded=\"expanded\"\n :class=\"{...buttonClasses, 'dropdown-toggle': true, 'dropdown-toggle-split': split}\"\n @blur=\"onBlur\"\n @click=\"onClickToggle\" />\n </slot>\n <DropdownMenu\n ref=\"menu\"\n :class=\"{\n 'show': expanded\n }\"\n :style=\"floatingStyles\"\n @blur=\"onBlur\"\n @click=\"onClickItem\"\n @mousedown.prevent>\n <slot />\n </DropdownMenu>\n </div>\n <slot\n v-if=\"dropleft\"\n name=\"button\"\n v-bind=\"{ expanded, onBlur, onClickToggle }\">\n <button\n type=\"button\"\n :class=\"buttonClasses\"\n aria-haspopup=\"true\"\n :aria-expanded=\"expanded\"\n @blur=\"onBlur\"\n @click=\"onClick\">\n {{ label }}\n </button>\n </slot>\n </div>\n</template>","<script setup lang=\"ts\">\nimport { useTemplateRef } from 'vue';\nimport { type ComponentExposed } from 'vue-component-type-helpers';\nimport BtnDropdownSingle from './BtnDropdownSingle.vue';\nimport BtnDropdownSplit from './BtnDropdownSplit.vue';\nimport { BtnDropdownEvents, BtnDropdownProps } from './useDropdownHandler';\n\nconst props = withDefaults(defineProps<{\n split?: boolean\n} & BtnDropdownProps>(), {\n split: false,\n caret: true\n});\n\nconst emit = defineEmits<BtnDropdownEvents>();\n\nconst el = useTemplateRef<ComponentExposed<typeof BtnDropdownSingle | typeof BtnDropdownSplit>>('el');\n\ndefineExpose({\n hide: () => el.value?.hide(),\n show: () => el.value?.show(),\n toggle: () => el.value?.toggle(),\n});\n</script>\n\n<template>\n <Component\n ref=\"el\"\n :is=\"!split ? BtnDropdownSingle : BtnDropdownSplit\"\n v-bind=\"props\"\n @click=\"(e: MouseEvent) => emit('click', e)\"\n @click-toggle=\"(e: MouseEvent) => emit('clickToggle', e)\"\n @show=\"() => emit('show')\"\n @hide=\"() => emit('hide')\">\n <template #button=\"slot\">\n <slot\n name=\"button\"\n v-bind=\"slot\" />\n </template>\n <template #toggle=\"slot\">\n <slot\n name=\"toggle\"\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":["useDropdownHandler","props","emit","target","ref","menu","expanded","alignment","computed","side","placement","classes","buttonClasses","value","floatingStyles","update","useFloating","offset","flip","show","hide","toggle","isFocusable","element","nodes","i","onBlur","e","onClick","onClickToggle","onClickItem","watchEffect","__props","__emit","__expose","_createElementBlock","_normalizeClass","_unref","_renderSlot","_ctx","_normalizeProps","_guardReactiveProps","el","_createElementVNode","_cache","args","_hoisted_1","_createVNode","DropdownMenu","_hoisted_2","_hoisted_4","useTemplateRef","_openBlock","_createBlock","_resolveDynamicComponent","BtnDropdownSplit","BtnDropdownSingle","_mergeProps","_withCtx","slot"],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- (function(g,e){typeof exports=="object"&&typeof module<"u"?e(exports,require("vue"),require("@vue-interface/dropdown-menu"),require("@floating-ui/dom"),require("@floating-ui/vue")):typeof define=="function"&&define.amd?define(["exports","vue","@vue-interface/dropdown-menu","@floating-ui/dom","@floating-ui/vue"],e):(g=typeof globalThis<"u"?globalThis:g||self,e(g.BtnDropdown={},g.Vue,g.VueInterfaceDropdownMenu,g.FloatingUiDom,g.FloatingUiVue))})(this,(function(g,e,S,T,$){"use strict";function P(t,m){const u=e.ref(),s=e.ref(),d=e.ref(!1),i=e.computed(()=>t.align??"start"),a=e.computed(()=>t.dropup?"top":t.dropleft?"left":t.dropright?"right":"bottom"),k=e.computed(()=>`${a.value}-${i.value}`),w=e.computed(()=>({dropdown:t.dropup&&t.dropright&&t.dropleft,dropup:t.dropup,dropright:t.dropright,dropleft:t.dropleft,expanded:d.value,[t.size??""]:!!t.size})),f=e.computed(()=>{const r={btn:!0,[t.variant??""]:!!t.variant,"btn-block":!!t.block,"no-caret":!t.caret};if(typeof t.buttonClass=="string")r[t.buttonClass]=!0;else if(Array.isArray(t.buttonClass))for(const z of t.buttonClass)r[z]=!0;else t.buttonClass&&Object.assign(r,t.buttonClass);return r}),{floatingStyles:B,update:y}=$.useFloating(u,s,{placement:k,middleware:t.middleware??[T.offset(t.offset??5),T.flip()]});function b(){d.value=!0,!(!u.value||!s.value)&&(y(),m("show"))}function C(){d.value=!1,u.value?.blur(),m("hide")}function l(){d.value?C():b()}function c(r){const z=Array.from(s.value?.$el.querySelectorAll("label, input, select, textarea")??[]);for(const A in z)if(r===z[A])return!0;return!1}function h(r){if(!(r.relatedTarget instanceof HTMLElement)){C();return}(s.value&&!s.value?.$el.contains(r.relatedTarget)||!u.value?.contains(r.relatedTarget))&&C()}function p(r){m("click",r)}function n(r){r.target?.dispatchEvent(new Event("focus",r)),m("clickToggle",r),r.defaultPrevented||l()}function o(r){if(!(r.target instanceof HTMLElement)){C();return}!c(r.target)&&!r.defaultPrevented&&C()}return e.watchEffect(()=>{d.value?window.addEventListener("resize",y):window.removeEventListener("resize",y)}),{target:u,menu:s,alignment:i,expanded:d,floatingStyles:B,placement:k,side:a,classes:w,buttonClasses:f,show:b,hide:C,toggle:l,onBlur:h,onClick:p,onClickToggle:n,onClickItem:o}}const x=["aria-expanded"],D=e.defineComponent({__name:"BtnDropdownSingle",props:{align:{},block:{type:Boolean},buttonClass:{},caret:{type:Boolean,default:!0},dropup:{type:Boolean},dropright:{type:Boolean},dropleft:{type:Boolean},label:{},offset:{},middleware:{},side:{},size:{},split:{type:Boolean},variant:{default:"btn-primary"}},emits:["click","clickToggle","show","hide"],setup(t,{expose:m,emit:u}){const s=t,d=u,{target:i,menu:a,buttonClasses:k,classes:w,expanded:f,floatingStyles:B,show:y,hide:b,toggle:C,onBlur:l,onClickToggle:c,onClickItem:h}=P(s,d);return m({show:y,hide:b,toggle:C}),(p,n)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass(["btn-group",e.unref(w)])},[e.renderSlot(p.$slots,"button",e.normalizeProps(e.guardReactiveProps({target:o=>i.value=o,expanded:e.unref(f),onBlur:e.unref(l),onClickToggle:e.unref(c)})),()=>[e.createElementVNode("button",{ref_key:"target",ref:i,type:"button",class:e.normalizeClass({...e.unref(k),"dropdown-toggle":!0}),"aria-haspopup":"true","aria-expanded":e.unref(f),onBlur:n[0]||(n[0]=(...o)=>e.unref(l)&&e.unref(l)(...o)),onClick:n[1]||(n[1]=(...o)=>e.unref(c)&&e.unref(c)(...o))},e.toDisplayString(t.label),43,x)]),e.createVNode(e.unref(S.DropdownMenu),{ref_key:"menu",ref:a,class:e.normalizeClass({show:e.unref(f)}),style:e.normalizeStyle(e.unref(B)),onBlur:e.unref(l),onClick:e.unref(h),onMousedown:n[2]||(n[2]=e.withModifiers(()=>{},["prevent"]))},{default:e.withCtx(()=>[e.renderSlot(p.$slots,"default")]),_:3},8,["class","style","onBlur","onClick"])],2))}}),E=["aria-expanded"],V={class:"btn-group"},M=["aria-expanded"],N=["aria-expanded"],q=e.defineComponent({__name:"BtnDropdownSplit",props:{align:{},block:{type:Boolean},buttonClass:{},caret:{type:Boolean,default:!0},dropup:{type:Boolean},dropright:{type:Boolean},dropleft:{type:Boolean},label:{},offset:{},middleware:{},side:{},size:{},split:{type:Boolean},variant:{default:"btn-primary"}},emits:["click","clickToggle","show","hide"],setup(t,{expose:m,emit:u}){const s=t,d=u,{target:i,menu:a,buttonClasses:k,classes:w,expanded:f,floatingStyles:B,show:y,hide:b,toggle:C,onBlur:l,onClickToggle:c,onClickItem:h}=P(s,d);return m({show:y,hide:b,toggle:C}),(p,n)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass(["btn-group btn-dropdown-split",e.unref(w)])},[t.dropleft?e.createCommentVNode("",!0):e.renderSlot(p.$slots,"button",e.normalizeProps(e.mergeProps({key:0},{expanded:e.unref(f),onBlur:e.unref(l),onClickToggle:e.unref(c)})),()=>[e.createElementVNode("button",{type:"button",class:e.normalizeClass(e.unref(k)),"aria-haspopup":"true","aria-expanded":e.unref(f),onBlur:n[0]||(n[0]=(...o)=>e.unref(l)&&e.unref(l)(...o)),onClick:n[1]||(n[1]=(...o)=>p.onClick&&p.onClick(...o))},e.toDisplayString(t.label),43,E)]),e.createElementVNode("div",V,[e.renderSlot(p.$slots,"toggle",e.normalizeProps(e.guardReactiveProps({target:o=>i.value=o,expanded:e.unref(f),onBlur:e.unref(l),onClickToggle:e.unref(c)})),()=>[e.createElementVNode("button",{ref_key:"target",ref:i,type:"button","aria-haspopup":"true","aria-expanded":e.unref(f),class:e.normalizeClass({...e.unref(k),"dropdown-toggle":!0,"dropdown-toggle-split":t.split}),onBlur:n[2]||(n[2]=(...o)=>e.unref(l)&&e.unref(l)(...o)),onClick:n[3]||(n[3]=(...o)=>e.unref(c)&&e.unref(c)(...o))},null,42,M)]),e.createVNode(e.unref(S.DropdownMenu),{ref_key:"menu",ref:a,class:e.normalizeClass({show:e.unref(f)}),style:e.normalizeStyle(e.unref(B)),onBlur:e.unref(l),onClick:e.unref(h),onMousedown:n[4]||(n[4]=e.withModifiers(()=>{},["prevent"]))},{default:e.withCtx(()=>[e.renderSlot(p.$slots,"default")]),_:3},8,["class","style","onBlur","onClick"])]),t.dropleft?e.renderSlot(p.$slots,"button",e.normalizeProps(e.mergeProps({key:1},{expanded:e.unref(f),onBlur:e.unref(l),onClickToggle:e.unref(c)})),()=>[e.createElementVNode("button",{type:"button",class:e.normalizeClass(e.unref(k)),"aria-haspopup":"true","aria-expanded":e.unref(f),onBlur:n[5]||(n[5]=(...o)=>e.unref(l)&&e.unref(l)(...o)),onClick:n[6]||(n[6]=(...o)=>p.onClick&&p.onClick(...o))},e.toDisplayString(t.label),43,N)]):e.createCommentVNode("",!0)],2))}}),R=e.defineComponent({__name:"BtnDropdown",props:{split:{type:Boolean,default:!1},align:{},block:{type:Boolean},buttonClass:{},caret:{type:Boolean,default:!0},dropup:{type:Boolean},dropright:{type:Boolean},dropleft:{type:Boolean},label:{},offset:{},middleware:{},side:{},size:{},variant:{}},emits:["click","clickToggle","show","hide"],setup(t,{emit:m}){const u=t,s=m;return(d,i)=>(e.openBlock(),e.createBlock(e.resolveDynamicComponent(t.split?q:D),e.mergeProps(u,{onClick:i[0]||(i[0]=a=>s("click",a)),onClickToggle:i[1]||(i[1]=a=>s("clickToggle",a)),onShow:i[2]||(i[2]=()=>s("show")),onHide:i[3]||(i[3]=()=>s("hide"))}),{button:e.withCtx(a=>[e.renderSlot(d.$slots,"button",e.normalizeProps(e.guardReactiveProps(a)))]),toggle:e.withCtx(a=>[e.renderSlot(d.$slots,"toggle",e.normalizeProps(e.guardReactiveProps(a)))]),split:e.withCtx(a=>[e.renderSlot(d.$slots,"split",e.normalizeProps(e.guardReactiveProps(a)))]),default:e.withCtx(()=>[e.renderSlot(d.$slots,"default")]),_:3},16))}});g.BtnDropdown=R,Object.defineProperty(g,Symbol.toStringTag,{value:"Module"})}));
1
+ (function(C,e){typeof exports=="object"&&typeof module<"u"?e(exports,require("vue"),require("@vue-interface/dropdown-menu"),require("@floating-ui/dom"),require("@floating-ui/vue")):typeof define=="function"&&define.amd?define(["exports","vue","@vue-interface/dropdown-menu","@floating-ui/dom","@floating-ui/vue"],e):(C=typeof globalThis<"u"?globalThis:C||self,e(C.BtnDropdown={},C.Vue,C.VueInterfaceDropdownMenu,C.FloatingUiDom,C.FloatingUiVue))})(this,(function(C,e,S,T,x){"use strict";function P(t,k){const c=e.ref(),p=e.ref(),a=e.ref(!1),d=e.computed(()=>t.align??"start"),g=e.computed(()=>t.dropup?"top":t.dropleft?"left":t.dropright?"right":"bottom"),i=e.computed(()=>`${g.value}-${d.value}`),s=e.computed(()=>({dropdown:t.dropup&&t.dropright&&t.dropleft,dropup:t.dropup,dropright:t.dropright,dropleft:t.dropleft,expanded:a.value,[t.size??""]:!!t.size})),f=e.computed(()=>{const r={btn:!0,[t.variant??""]:!!t.variant,"btn-block":!!t.block,"no-caret":!t.caret};if(typeof t.buttonClass=="string")r[t.buttonClass]=!0;else if(Array.isArray(t.buttonClass))for(const z of t.buttonClass)r[z]=!0;else t.buttonClass&&Object.assign(r,t.buttonClass);return r}),{floatingStyles:B,update:w}=x.useFloating(c,p,{placement:i,middleware:t.middleware??[T.offset(t.offset??5),T.flip()]});function b(){a.value=!0,!(!c.value||!p.value)&&(w(),k("show"))}function y(){a.value=!1,c.value?.blur(),k("hide")}function l(){a.value?y():b()}function m(r){const z=Array.from(p.value?.$el.querySelectorAll("label, input, select, textarea")??[]);for(const A in z)if(r===z[A])return!0;return!1}function h(r){if(!(r.relatedTarget instanceof HTMLElement)){y();return}(p.value&&!p.value?.$el.contains(r.relatedTarget)||!c.value?.contains(r.relatedTarget))&&y()}function u(r){k("click",r)}function n(r){r.target?.dispatchEvent(new Event("focus",r)),k("clickToggle",r),r.defaultPrevented||l()}function o(r){if(!(r.target instanceof HTMLElement)){y();return}!m(r.target)&&!r.defaultPrevented&&y()}return e.watchEffect(()=>{a.value?window.addEventListener("resize",w):window.removeEventListener("resize",w)}),{target:c,menu:p,alignment:d,expanded:a,floatingStyles:B,placement:i,side:g,classes:s,buttonClasses:f,show:b,hide:y,toggle:l,onBlur:h,onClick:u,onClickToggle:n,onClickItem:o}}const $=["aria-expanded"],D=e.defineComponent({__name:"BtnDropdownSingle",props:{align:{},block:{type:Boolean},buttonClass:{},caret:{type:Boolean,default:!0},dropup:{type:Boolean},dropright:{type:Boolean},dropleft:{type:Boolean},label:{},offset:{},middleware:{},side:{},size:{},split:{type:Boolean},variant:{default:"btn-primary"}},emits:["click","clickToggle","show","hide"],setup(t,{expose:k,emit:c}){const p=t,a=c,{target:d,menu:g,buttonClasses:i,classes:s,expanded:f,floatingStyles:B,show:w,hide:b,toggle:y,onBlur:l,onClickToggle:m,onClickItem:h}=P(p,a);return k({show:w,hide:b,toggle:y}),(u,n)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass(["btn-group",e.unref(s)])},[e.renderSlot(u.$slots,"button",e.normalizeProps(e.guardReactiveProps({target:o=>d.value=o,expanded:e.unref(f),onBlur:e.unref(l),onClickToggle:e.unref(m)})),()=>[e.createElementVNode("button",{ref_key:"target",ref:d,type:"button",class:e.normalizeClass({...e.unref(i),"dropdown-toggle":!0}),"aria-haspopup":"true","aria-expanded":e.unref(f),onBlur:n[0]||(n[0]=(...o)=>e.unref(l)&&e.unref(l)(...o)),onClick:n[1]||(n[1]=(...o)=>e.unref(m)&&e.unref(m)(...o))},e.toDisplayString(t.label),43,$)]),e.createVNode(e.unref(S.DropdownMenu),{ref_key:"menu",ref:g,class:e.normalizeClass({show:e.unref(f)}),style:e.normalizeStyle(e.unref(B)),onBlur:e.unref(l),onClick:e.unref(h),onMousedown:n[2]||(n[2]=e.withModifiers(()=>{},["prevent"]))},{default:e.withCtx(()=>[e.renderSlot(u.$slots,"default")]),_:3},8,["class","style","onBlur","onClick"])],2))}}),E=["aria-expanded"],V={class:"btn-group"},M=["aria-expanded"],N=["aria-expanded"],R=e.defineComponent({__name:"BtnDropdownSplit",props:{align:{},block:{type:Boolean},buttonClass:{},caret:{type:Boolean,default:!0},dropup:{type:Boolean},dropright:{type:Boolean},dropleft:{type:Boolean},label:{},offset:{},middleware:{},side:{},size:{},split:{type:Boolean},variant:{default:"btn-primary"}},emits:["click","clickToggle","show","hide"],setup(t,{expose:k,emit:c}){const p=t,a=c,{target:d,menu:g,buttonClasses:i,classes:s,expanded:f,floatingStyles:B,show:w,hide:b,toggle:y,onBlur:l,onClickToggle:m,onClickItem:h}=P(p,a);return k({show:w,hide:b,toggle:y}),(u,n)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass(["btn-group btn-dropdown-split",e.unref(s)])},[t.dropleft?e.createCommentVNode("",!0):e.renderSlot(u.$slots,"button",e.normalizeProps(e.mergeProps({key:0},{expanded:e.unref(f),onBlur:e.unref(l),onClickToggle:e.unref(m)})),()=>[e.createElementVNode("button",{type:"button",class:e.normalizeClass(e.unref(i)),"aria-haspopup":"true","aria-expanded":e.unref(f),onBlur:n[0]||(n[0]=(...o)=>e.unref(l)&&e.unref(l)(...o)),onClick:n[1]||(n[1]=(...o)=>u.onClick&&u.onClick(...o))},e.toDisplayString(t.label),43,E)]),e.createElementVNode("div",V,[e.renderSlot(u.$slots,"toggle",e.normalizeProps(e.guardReactiveProps({target:o=>d.value=o,expanded:e.unref(f),onBlur:e.unref(l),onClickToggle:e.unref(m)})),()=>[e.createElementVNode("button",{ref_key:"target",ref:d,type:"button","aria-haspopup":"true","aria-expanded":e.unref(f),class:e.normalizeClass({...e.unref(i),"dropdown-toggle":!0,"dropdown-toggle-split":t.split}),onBlur:n[2]||(n[2]=(...o)=>e.unref(l)&&e.unref(l)(...o)),onClick:n[3]||(n[3]=(...o)=>e.unref(m)&&e.unref(m)(...o))},null,42,M)]),e.createVNode(e.unref(S.DropdownMenu),{ref_key:"menu",ref:g,class:e.normalizeClass({show:e.unref(f)}),style:e.normalizeStyle(e.unref(B)),onBlur:e.unref(l),onClick:e.unref(h),onMousedown:n[4]||(n[4]=e.withModifiers(()=>{},["prevent"]))},{default:e.withCtx(()=>[e.renderSlot(u.$slots,"default")]),_:3},8,["class","style","onBlur","onClick"])]),t.dropleft?e.renderSlot(u.$slots,"button",e.normalizeProps(e.mergeProps({key:1},{expanded:e.unref(f),onBlur:e.unref(l),onClickToggle:e.unref(m)})),()=>[e.createElementVNode("button",{type:"button",class:e.normalizeClass(e.unref(i)),"aria-haspopup":"true","aria-expanded":e.unref(f),onBlur:n[5]||(n[5]=(...o)=>e.unref(l)&&e.unref(l)(...o)),onClick:n[6]||(n[6]=(...o)=>u.onClick&&u.onClick(...o))},e.toDisplayString(t.label),43,N)]):e.createCommentVNode("",!0)],2))}}),q=e.defineComponent({__name:"BtnDropdown",props:{split:{type:Boolean,default:!1},align:{},block:{type:Boolean},buttonClass:{},caret:{type:Boolean,default:!0},dropup:{type:Boolean},dropright:{type:Boolean},dropleft:{type:Boolean},label:{},offset:{},middleware:{},side:{},size:{},variant:{}},emits:["click","clickToggle","show","hide"],setup(t,{expose:k,emit:c}){const p=t,a=c,d=e.useTemplateRef("el");return k({hide:()=>d.value?.hide(),show:()=>d.value?.show(),toggle:()=>d.value?.toggle()}),(g,i)=>(e.openBlock(),e.createBlock(e.resolveDynamicComponent(t.split?R:D),e.mergeProps({ref_key:"el",ref:d},p,{onClick:i[0]||(i[0]=s=>a("click",s)),onClickToggle:i[1]||(i[1]=s=>a("clickToggle",s)),onShow:i[2]||(i[2]=()=>a("show")),onHide:i[3]||(i[3]=()=>a("hide"))}),{button:e.withCtx(s=>[e.renderSlot(g.$slots,"button",e.normalizeProps(e.guardReactiveProps(s)))]),toggle:e.withCtx(s=>[e.renderSlot(g.$slots,"toggle",e.normalizeProps(e.guardReactiveProps(s)))]),split:e.withCtx(s=>[e.renderSlot(g.$slots,"split",e.normalizeProps(e.guardReactiveProps(s)))]),default:e.withCtx(()=>[e.renderSlot(g.$slots,"default")]),_:3},16))}});C.BtnDropdown=q,Object.defineProperty(C,Symbol.toStringTag,{value:"Module"})}));
2
2
  //# sourceMappingURL=btn-dropdown.umd.cjs.map