@vue-interface/btn-dropdown 2.0.0-beta.21 → 2.0.0-beta.23

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,4 +1,4 @@
1
- import { defineComponent as A, openBlock as M, createBlock as N, resolveDynamicComponent as G, mergeProps as z, withCtx as p, renderSlot as s, ref as w, computed as k, onBeforeMount as x, unref as e, normalizeClass as C, normalizeProps as T, guardReactiveProps as V, createVNode as h, createTextVNode as I, toDisplayString as P, withKeys as R, withModifiers as U, createCommentVNode as O, createElementVNode as ee, useSlots as te, createSlots as oe } from "vue";
1
+ import { defineComponent as A, openBlock as M, createBlock as N, resolveDynamicComponent as G, mergeProps as z, withCtx as p, renderSlot as s, ref as w, computed as k, onBeforeMount as x, unref as e, normalizeClass as B, normalizeProps as T, guardReactiveProps as V, createVNode as h, createTextVNode as I, toDisplayString as P, withKeys as R, withModifiers as U, createCommentVNode as O, createElementVNode as ee, useSlots as te, createSlots as oe } from "vue";
2
2
  import { BtnGroup as q } from "@vue-interface/btn-group";
3
3
  import { DropdownMenu as H } from "@vue-interface/dropdown-menu";
4
4
  import { createPopper as ne } from "@popperjs/core";
@@ -46,45 +46,46 @@ function se(t, g, i, f, r, c) {
46
46
  }
47
47
  const F = /* @__PURE__ */ ae(le, [["render", se]]);
48
48
  function J(t, g) {
49
- const i = w(!1), f = w(!1), r = w(), c = w(), o = w(), v = w(), m = (l) => {
50
- c.value = l;
49
+ const i = w(!1), f = w(!1), r = w(), c = w(), n = w(), b = w(), m = (o) => {
50
+ c.value = o;
51
51
  }, K = k(
52
52
  () => {
53
- var l;
54
- return c.value instanceof Element ? c.value : (l = c.value) == null ? void 0 : l.$el;
53
+ var o;
54
+ return c.value instanceof Element ? c.value : (o = c.value) == null ? void 0 : o.$el;
55
55
  }
56
56
  ), $ = k(
57
- () => o.value instanceof Element ? o.value : o.value.$el
57
+ () => {
58
+ var o;
59
+ return n.value instanceof Element ? n.value : (o = n.value) == null ? void 0 : o.$el;
60
+ }
58
61
  ), d = k(
59
- () => v.value instanceof Element ? v.value : v.value.$el
60
- ), B = k(() => ({
62
+ () => {
63
+ var o;
64
+ return b.value instanceof Element ? b.value : (o = b.value) == null ? void 0 : o.$el;
65
+ }
66
+ ), C = k(() => ({
61
67
  [t.size]: !!t.size,
62
68
  dropdown: t.dropdown || !(t.dropright || t.dropleft || t.dropup),
63
69
  dropup: t.dropup,
64
70
  dropright: t.dropright,
65
71
  dropleft: t.dropleft,
66
- // 'icon-only': !this.nav && !this.split && !!this.$slots.icon && !this.$slots.label,
67
- // 'hide-caret': !this.caret,
68
72
  expanded: i.value
69
- // 'rotate-90': !this.nav && this.split && this.rotate && this.expanded,
70
- })), b = k(() => ({
71
- // [props.size]: !!props.size,
73
+ })), v = k(() => ({
72
74
  [t.variant]: !!t.variant,
73
75
  ...y.value
74
- })), y = k(() => typeof t.buttonClass == "object" ? { btn: !0, ...t.buttonClass } : {
76
+ })), y = k(() => ({
75
77
  btn: !0,
76
- [t.buttonClass]: !!t.buttonClass
77
- }), n = k(() => ({
78
+ ...typeof t.buttonClass == "object" ? t.buttonClass : { [t.buttonClass]: !!t.buttonClass }
79
+ })), l = k(() => ({
78
80
  active: t.active,
79
81
  "dropdown-toggle": !0,
80
82
  "dropdown-toggle-split": t.split,
81
- // [props.size]: !!props.size,
82
83
  [t.variant]: !!t.variant,
83
84
  ...y.value
84
85
  })), u = k(() => t.dropup ? "top" : t.dropleft ? "left" : t.dropright ? "right" : "bottom"), a = k(() => t.align && t.align === "right" ? "end" : "start");
85
86
  function S() {
86
- var l;
87
- (l = K.value) == null || l.focus(), i.value = !0, r.value ? r.value.update() : r.value = ne($.value, d.value.querySelector(".dropdown-menu"), {
87
+ var o;
88
+ (o = K.value) == null || o.focus(), i.value = !0, r.value ? r.value.update() : r.value = ne($.value, d.value.querySelector(".dropdown-menu"), {
88
89
  placement: `${u.value}-${a.value}`,
89
90
  onFirstUpdate: () => {
90
91
  f.value = !0;
@@ -110,37 +111,37 @@ function J(t, g) {
110
111
  'label, input, select, textarea, [tabindex]:not([tabindex="-1"])'
111
112
  );
112
113
  }
113
- function Q(l) {
114
+ function Q(o) {
114
115
  const E = L();
115
116
  for (const _ in E)
116
- if (l === E[_])
117
+ if (o === E[_])
117
118
  return !0;
118
119
  return !1;
119
120
  }
120
- function W(l) {
121
- g("blur", l), !l.defaultPrevented && (d.value && !d.value.contains(l.relatedTarget) || !d.value.contains(l.relatedTarget)) && D();
121
+ function W(o) {
122
+ g("blur", o), !o.defaultPrevented && (d.value && !d.value.contains(o.relatedTarget) || !d.value.contains(o.relatedTarget)) && D();
122
123
  }
123
- function X(l) {
124
- Q(l.target) || D();
124
+ function X(o) {
125
+ Q(o.target) || D();
125
126
  }
126
- function Y(l) {
127
- g("click-toggle", l), l.defaultPrevented || j();
127
+ function Y(o) {
128
+ g("click-toggle", o), o.defaultPrevented || j();
128
129
  }
129
- function Z(l) {
130
+ function Z(o) {
130
131
  var E;
131
- ((E = $.value.parentElement) == null ? void 0 : E.lastElementChild) === l.target && D();
132
+ ((E = $.value.parentElement) == null ? void 0 : E.lastElementChild) === o.target && D();
132
133
  }
133
134
  return x(() => {
134
135
  r.value && r.value.destroy();
135
136
  }), {
136
- actionClasses: b,
137
+ actionClasses: v,
137
138
  button: c,
138
139
  $button: m,
139
- classes: B,
140
+ classes: C,
140
141
  expanded: i,
141
- menu: v,
142
- target: o,
143
- toggleClasses: n,
142
+ menu: b,
143
+ target: n,
144
+ toggleClasses: l,
144
145
  triggerAnimation: f,
145
146
  hide: D,
146
147
  show: S,
@@ -172,32 +173,32 @@ const re = /* @__PURE__ */ A({
172
173
  const i = t, f = g, {
173
174
  button: r,
174
175
  $button: c,
175
- target: o,
176
- classes: v,
176
+ target: n,
177
+ classes: b,
177
178
  expanded: m,
178
179
  menu: K,
179
180
  toggleClasses: $,
180
181
  triggerAnimation: d,
181
- toggle: B,
182
- onBlur: b,
182
+ toggle: C,
183
+ onBlur: v,
183
184
  onClickToggle: y,
184
- onClickItem: n,
185
+ onClickItem: l,
185
186
  onKeydown: u
186
187
  } = J(i, f);
187
188
  return (a, S) => (M(), N(e(q), {
188
189
  ref_key: "target",
189
- ref: o,
190
- class: C(e(v))
190
+ ref: n,
191
+ class: B(e(b))
191
192
  }, {
192
193
  default: p(() => [
193
- s(a.$slots, "button", T(V({ button: e(r), $button: e(c), expanded: e(m), target: e(o), toggle: e(B), onBlur: e(b), onClickToggle: e(y), onClickItem: e(n), onKeydown: e(u) })), () => [
194
+ s(a.$slots, "button", T(V({ 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) })), () => [
194
195
  h(F, {
195
196
  id: a.$attrs.id,
196
197
  ref_key: "button",
197
198
  ref: r,
198
199
  expanded: e(m),
199
- class: C(e($)),
200
- onBlur: e(b),
200
+ class: B(e($)),
201
+ onBlur: e(v),
201
202
  onClick: e(y)
202
203
  }, {
203
204
  default: p(() => [
@@ -215,9 +216,9 @@ const re = /* @__PURE__ */ A({
215
216
  ref: K,
216
217
  align: a.align,
217
218
  show: e(m),
218
- class: C({ animated: e(d) }),
219
- onBlur: e(b),
220
- onClick: e(n),
219
+ class: B({ animated: e(d) }),
220
+ onBlur: e(v),
221
+ onClick: e(l),
221
222
  onKeydown: R(e(u), ["tab"]),
222
223
  onMousedown: S[0] || (S[0] = U(() => {
223
224
  }, ["prevent"]))
@@ -252,31 +253,31 @@ const re = /* @__PURE__ */ A({
252
253
  const i = t, f = g, {
253
254
  actionClasses: r,
254
255
  classes: c,
255
- expanded: o,
256
- menu: v,
256
+ expanded: n,
257
+ menu: b,
257
258
  target: m,
258
259
  toggleClasses: K,
259
260
  triggerAnimation: $,
260
261
  onBlur: d,
261
- onClickToggle: B,
262
- onClickItem: b,
262
+ onClickToggle: C,
263
+ onClickItem: v,
263
264
  onKeydown: y
264
265
  } = J(i, f);
265
- return (n, u) => (M(), N(e(q), {
266
- class: C([e(c), "btn-dropdown-split"])
266
+ return (l, u) => (M(), N(e(q), {
267
+ class: B([e(c), "btn-dropdown-split"])
267
268
  }, {
268
269
  default: p(() => [
269
- n.dropleft ? O("", !0) : s(n.$slots, "button", T(z({ key: 0 }, { expanded: e(o), onBlur: e(d), onClickToggle: e(B), onClickItem: e(b), onKeydown: e(y) })), () => [
270
+ l.dropleft ? O("", !0) : s(l.$slots, "button", T(z({ key: 0 }, { expanded: e(n), onBlur: e(d), onClickToggle: e(C), onClickItem: e(v), onKeydown: e(y) })), () => [
270
271
  h(F, {
271
- id: n.$attrs.id,
272
- expanded: e(o),
273
- class: C(e(r)),
272
+ id: l.$attrs.id,
273
+ expanded: e(n),
274
+ class: B(e(r)),
274
275
  onClick: u[0] || (u[0] = (a) => f("click", a))
275
276
  }, {
276
277
  default: p(() => [
277
- s(n.$slots, "icon"),
278
- s(n.$slots, "label", {}, () => [
279
- I(P(n.label), 1)
278
+ s(l.$slots, "icon"),
279
+ s(l.$slots, "label", {}, () => [
280
+ I(P(l.label), 1)
280
281
  ])
281
282
  ]),
282
283
  _: 3
@@ -287,50 +288,50 @@ const re = /* @__PURE__ */ A({
287
288
  ref: m
288
289
  }, {
289
290
  default: p(() => [
290
- s(n.$slots, "split", {}, () => [
291
+ s(l.$slots, "split", {}, () => [
291
292
  ee("button", {
292
- id: n.$attrs.id,
293
+ id: l.$attrs.id,
293
294
  type: "button",
294
295
  "aria-haspopup": "true",
295
- "aria-expanded": e(o),
296
- class: C(e(K)),
296
+ "aria-expanded": e(n),
297
+ class: B(e(K)),
297
298
  onBlur: u[1] || (u[1] = //@ts-ignore
298
299
  (...a) => e(d) && e(d)(...a)),
299
300
  onClick: u[2] || (u[2] = //@ts-ignore
300
- (...a) => e(B) && e(B)(...a))
301
+ (...a) => e(C) && e(C)(...a))
301
302
  }, null, 42, ie)
302
303
  ]),
303
304
  h(e(H), {
304
305
  ref_key: "menu",
305
- ref: v,
306
- align: n.align,
307
- show: e(o),
308
- class: C({ animated: e($) }),
306
+ ref: b,
307
+ align: l.align,
308
+ show: e(n),
309
+ class: B({ animated: e($) }),
309
310
  onBlur: e(d),
310
- onClick: e(b),
311
+ onClick: e(v),
311
312
  onKeydown: R(e(y), ["tab"]),
312
313
  onMousedown: u[3] || (u[3] = U(() => {
313
314
  }, ["prevent"]))
314
315
  }, {
315
316
  default: p(() => [
316
- s(n.$slots, "default")
317
+ s(l.$slots, "default")
317
318
  ]),
318
319
  _: 3
319
320
  }, 8, ["align", "show", "class", "onBlur", "onClick", "onKeydown"])
320
321
  ]),
321
322
  _: 3
322
323
  }, 512),
323
- n.dropleft ? s(n.$slots, "button", T(z({ key: 1 }, { expanded: e(o), onBlur: e(d), onClickToggle: e(B), onClickItem: e(b), onKeydown: e(y) })), () => [
324
+ l.dropleft ? s(l.$slots, "button", T(z({ key: 1 }, { expanded: e(n), onBlur: e(d), onClickToggle: e(C), onClickItem: e(v), onKeydown: e(y) })), () => [
324
325
  h(F, {
325
- id: n.$attrs.id,
326
- expanded: e(o),
327
- class: C(e(r)),
326
+ id: l.$attrs.id,
327
+ expanded: e(n),
328
+ class: B(e(r)),
328
329
  onClick: u[4] || (u[4] = (a) => f("click", a))
329
330
  }, {
330
331
  default: p(() => [
331
- s(n.$slots, "icon"),
332
- s(n.$slots, "label", {}, () => [
333
- I(P(n.label), 1)
332
+ s(l.$slots, "icon"),
333
+ s(l.$slots, "label", {}, () => [
334
+ I(P(l.label), 1)
334
335
  ])
335
336
  ]),
336
337
  _: 3
@@ -359,33 +360,33 @@ const re = /* @__PURE__ */ A({
359
360
  emits: ["click"],
360
361
  setup(t, { emit: g }) {
361
362
  const i = t, f = g;
362
- function r(o) {
363
- return f("click", o);
363
+ function r(n) {
364
+ return f("click", n);
364
365
  }
365
366
  const c = te();
366
- return (o, v) => (M(), N(G(o.split ? ue : re), z(i, {
367
+ return (n, b) => (M(), N(G(n.split ? ue : re), z(i, {
367
368
  class: "btn-dropdown",
368
369
  onClick: r
369
370
  }), oe({
370
371
  icon: p(() => [
371
- s(o.$slots, "icon")
372
+ s(n.$slots, "icon")
372
373
  ]),
373
374
  button: p((m) => [
374
- s(o.$slots, "button", T(V(m)))
375
+ s(n.$slots, "button", T(V(m)))
375
376
  ]),
376
377
  split: p((m) => [
377
- s(o.$slots, "split", T(V(m)))
378
+ s(n.$slots, "split", T(V(m)))
378
379
  ]),
379
380
  default: p(() => [
380
- s(o.$slots, "default")
381
+ s(n.$slots, "default")
381
382
  ]),
382
383
  _: 2
383
384
  }, [
384
- o.label || e(c).label ? {
385
+ n.label || e(c).label ? {
385
386
  name: "label",
386
387
  fn: p(() => [
387
- s(o.$slots, "label", {}, () => [
388
- I(P(o.label), 1)
388
+ s(n.$slots, "label", {}, () => [
389
+ I(P(n.label), 1)
389
390
  ])
390
391
  ]),
391
392
  key: "0"
@@ -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, 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: (ref: Element | ComponentPublicInstance | null, refs: Record<string, any>) => void = (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 \n 'dropdown': props.dropdown || !(props.dropright || props.dropleft || props.dropup),\n 'dropup': props.dropup,\n 'dropright': props.dropright,\n 'dropleft': props.dropleft,\n // 'icon-only': !this.nav && !this.split && !!this.$slots.icon && !this.$slots.label,\n // 'hide-caret': !this.caret,\n 'expanded': expanded.value,\n // 'rotate-90': !this.nav && this.split && this.rotate && this.expanded,\n }));\n\n const actionClasses = computed(() => ({\n // [props.size]: !!props.size,\n [props.variant]: !!props.variant,\n \n ...buttonsClasses.value,\n }));\n\n const buttonsClasses = computed(() => {\n if(typeof props.buttonClass === 'object') {\n return { btn: true, ...props.buttonClass };\n }\n\n return {\n btn: true,\n [props.buttonClass]: !!props.buttonClass\n };\n });\n\n const toggleClasses = computed(() => ({\n 'active': props.active,\n 'dropdown-toggle': true,\n 'dropdown-toggle-split': props.split,\n // [props.size]: !!props.size,\n [props.variant]: !!props.variant,\n \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","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,S,P,T){"use strict";const N=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"}}}),K=(t,c)=>{const i=t.__vccOpts||t;for(const[f,a]of c)i[f]=a;return i};function E(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 z=K(N,[["render",E]]);function D(t,c){const i=e.ref(!1),f=e.ref(!1),a=e.ref(),p=e.ref(),n=e.ref(),g=e.ref(),u=r=>{p.value=r},B=e.computed(()=>{var r;return p.value instanceof Element?p.value:(r=p.value)==null?void 0:r.$el}),w=e.computed(()=>n.value instanceof Element?n.value:n.value.$el),d=e.computed(()=>g.value instanceof Element?g.value:g.value.$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(()=>typeof t.buttonClass=="object"?{btn:!0,...t.buttonClass}:{btn:!0,[t.buttonClass]:!!t.buttonClass}),o=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 k(){var r;(r=B.value)==null||r.focus(),i.value=!0,a.value?a.value.update():a.value=T.createPopper(w.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 h(){i.value=!1}function V(){i.value?h():k()}function x(){return d.value&&d.value.querySelectorAll('label, input, select, textarea, [tabindex]:not([tabindex="-1"])')}function A(r){const $=x();for(const U in $)if(r===$[U])return!0;return!1}function F(r){c("blur",r),!r.defaultPrevented&&(d.value&&!d.value.contains(r.relatedTarget)||!d.value.contains(r.relatedTarget))&&h()}function O(r){A(r.target)||h()}function R(r){c("click-toggle",r),r.defaultPrevented||V()}function G(r){var $;(($=w.value.parentElement)==null?void 0:$.lastElementChild)===r.target&&h()}return e.onBeforeMount(()=>{a.value&&a.value.destroy()}),{actionClasses:C,button:p,$button:u,classes:b,expanded:i,menu:g,target:n,toggleClasses:o,triggerAnimation:f,hide:h,show:k,toggle:V,onBlur:F,onClickItem:O,onClickToggle:R,onKeydown:G}}const I=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:n,classes:g,expanded:u,menu:B,toggleClasses:w,triggerAnimation:d,toggle:b,onBlur:C,onClickToggle:y,onClickItem:o,onKeydown:s}=D(i,f);return(l,k)=>(e.openBlock(),e.createBlock(e.unref(S.BtnGroup),{ref_key:"target",ref:n,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(n),toggle:e.unref(b),onBlur:e.unref(C),onClickToggle:e.unref(y),onClickItem:e.unref(o),onKeydown:e.unref(s)})),()=>[e.createVNode(z,{id:l.$attrs.id,ref_key:"button",ref:a,expanded:e.unref(u),class:e.normalizeClass(e.unref(w)),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(P.DropdownMenu),{id:l.$attrs.id,ref_key:"menu",ref:B,align:l.align,show:e.unref(u),class:e.normalizeClass({animated:e.unref(d)}),onBlur:e.unref(C),onClick:e.unref(o),onKeydown:e.withKeys(e.unref(s),["tab"]),onMousedown:k[0]||(k[0]=e.withModifiers(()=>{},["prevent"]))},{default:e.withCtx(()=>[e.renderSlot(l.$slots,"default")]),_:3},8,["id","align","show","class","onBlur","onClick","onKeydown"])]),_:3},8,["class"]))}}),M=["id","aria-expanded"],j=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:n,menu:g,target:u,toggleClasses:B,triggerAnimation:w,onBlur:d,onClickToggle:b,onClickItem:C,onKeydown:y}=D(i,f);return(o,s)=>(e.openBlock(),e.createBlock(e.unref(S.BtnGroup),{class:e.normalizeClass([e.unref(p),"btn-dropdown-split"])},{default:e.withCtx(()=>[o.dropleft?e.createCommentVNode("",!0):e.renderSlot(o.$slots,"button",e.normalizeProps(e.mergeProps({key:0},{expanded:e.unref(n),onBlur:e.unref(d),onClickToggle:e.unref(b),onClickItem:e.unref(C),onKeydown:e.unref(y)})),()=>[e.createVNode(z,{id:o.$attrs.id,expanded:e.unref(n),class:e.normalizeClass(e.unref(a)),onClick:s[0]||(s[0]=l=>f("click",l))},{default:e.withCtx(()=>[e.renderSlot(o.$slots,"icon"),e.renderSlot(o.$slots,"label",{},()=>[e.createTextVNode(e.toDisplayString(o.label),1)])]),_:3},8,["id","expanded","class"])]),e.createVNode(e.unref(S.BtnGroup),{ref_key:"target",ref:u},{default:e.withCtx(()=>[e.renderSlot(o.$slots,"split",{},()=>[e.createElementVNode("button",{id:o.$attrs.id,type:"button","aria-haspopup":"true","aria-expanded":e.unref(n),class:e.normalizeClass(e.unref(B)),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,M)]),e.createVNode(e.unref(P.DropdownMenu),{ref_key:"menu",ref:g,align:o.align,show:e.unref(n),class:e.normalizeClass({animated:e.unref(w)}),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(o.$slots,"default")]),_:3},8,["align","show","class","onBlur","onClick","onKeydown"])]),_:3},512),o.dropleft?e.renderSlot(o.$slots,"button",e.normalizeProps(e.mergeProps({key:1},{expanded:e.unref(n),onBlur:e.unref(d),onClickToggle:e.unref(b),onClickItem:e.unref(C),onKeydown:e.unref(y)})),()=>[e.createVNode(z,{id:o.$attrs.id,expanded:e.unref(n),class:e.normalizeClass(e.unref(a)),onClick:s[4]||(s[4]=l=>f("click",l))},{default:e.withCtx(()=>[e.renderSlot(o.$slots,"icon"),e.renderSlot(o.$slots,"label",{},()=>[e.createTextVNode(e.toDisplayString(o.label),1)])]),_:3},8,["id","expanded","class"])]):e.createCommentVNode("",!0)]),_:3},8,["class"]))}}),q=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(n){return f("click",n)}const p=e.useSlots();return(n,g)=>(e.openBlock(),e.createBlock(e.resolveDynamicComponent(n.split?j:I),e.mergeProps(i,{class:"btn-dropdown",onClick:a}),e.createSlots({icon:e.withCtx(()=>[e.renderSlot(n.$slots,"icon")]),button:e.withCtx(u=>[e.renderSlot(n.$slots,"button",e.normalizeProps(e.guardReactiveProps(u)))]),split:e.withCtx(u=>[e.renderSlot(n.$slots,"split",e.normalizeProps(e.guardReactiveProps(u)))]),default:e.withCtx(()=>[e.renderSlot(n.$slots,"default")]),_:2},[n.label||e.unref(p).label?{name:"label",fn:e.withCtx(()=>[e.renderSlot(n.$slots,"label",{},()=>[e.createTextVNode(e.toDisplayString(n.label),1)])]),key:"0"}:void 0]),1040))}});m.BtnDropdown=q,Object.defineProperty(m,Symbol.toStringTag,{value:"Module"})});
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,S,P,T){"use strict";const N=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"}}}),K=(t,c)=>{const i=t.__vccOpts||t;for(const[f,a]of c)i[f]=a;return i};function E(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 z=K(N,[["render",E]]);function D(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},B=e.computed(()=>{var n;return p.value instanceof Element?p.value:(n=p.value)==null?void 0:n.$el}),w=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 k(){var n;(n=B.value)==null||n.focus(),i.value=!0,a.value?a.value.update():a.value=T.createPopper(w.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 h(){i.value=!1}function V(){i.value?h():k()}function x(){return d.value&&d.value.querySelectorAll('label, input, select, textarea, [tabindex]:not([tabindex="-1"])')}function A(n){const $=x();for(const U in $)if(n===$[U])return!0;return!1}function F(n){c("blur",n),!n.defaultPrevented&&(d.value&&!d.value.contains(n.relatedTarget)||!d.value.contains(n.relatedTarget))&&h()}function O(n){A(n.target)||h()}function R(n){c("click-toggle",n),n.defaultPrevented||V()}function G(n){var $;(($=w.value.parentElement)==null?void 0:$.lastElementChild)===n.target&&h()}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:h,show:k,toggle:V,onBlur:F,onClickItem:O,onClickToggle:R,onKeydown:G}}const I=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:B,toggleClasses:w,triggerAnimation:d,toggle:b,onBlur:C,onClickToggle:y,onClickItem:r,onKeydown:s}=D(i,f);return(l,k)=>(e.openBlock(),e.createBlock(e.unref(S.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(z,{id:l.$attrs.id,ref_key:"button",ref:a,expanded:e.unref(u),class:e.normalizeClass(e.unref(w)),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(P.DropdownMenu),{id:l.$attrs.id,ref_key:"menu",ref:B,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:k[0]||(k[0]=e.withModifiers(()=>{},["prevent"]))},{default:e.withCtx(()=>[e.renderSlot(l.$slots,"default")]),_:3},8,["id","align","show","class","onBlur","onClick","onKeydown"])]),_:3},8,["class"]))}}),M=["id","aria-expanded"],j=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:B,triggerAnimation:w,onBlur:d,onClickToggle:b,onClickItem:C,onKeydown:y}=D(i,f);return(r,s)=>(e.openBlock(),e.createBlock(e.unref(S.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(z,{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(S.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(B)),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,M)]),e.createVNode(e.unref(P.DropdownMenu),{ref_key:"menu",ref:g,align:r.align,show:e.unref(o),class:e.normalizeClass({animated:e.unref(w)}),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(z,{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"]))}}),q=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?j:I),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=q,Object.defineProperty(m,Symbol.toStringTag,{value:"Module"})});
2
2
  //# sourceMappingURL=btn-dropdown.umd.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"btn-dropdown.umd.cjs","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, 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: (ref: Element | ComponentPublicInstance | null, refs: Record<string, any>) => void = (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 \n 'dropdown': props.dropdown || !(props.dropright || props.dropleft || props.dropup),\n 'dropup': props.dropup,\n 'dropright': props.dropright,\n 'dropleft': props.dropleft,\n // 'icon-only': !this.nav && !this.split && !!this.$slots.icon && !this.$slots.label,\n // 'hide-caret': !this.caret,\n 'expanded': expanded.value,\n // 'rotate-90': !this.nav && this.split && this.rotate && this.expanded,\n }));\n\n const actionClasses = computed(() => ({\n // [props.size]: !!props.size,\n [props.variant]: !!props.variant,\n \n ...buttonsClasses.value,\n }));\n\n const buttonsClasses = computed(() => {\n if(typeof props.buttonClass === 'object') {\n return { btn: true, ...props.buttonClass };\n }\n\n return {\n btn: true,\n [props.buttonClass]: !!props.buttonClass\n };\n });\n\n const toggleClasses = computed(() => ({\n 'active': props.active,\n 'dropdown-toggle': true,\n 'dropdown-toggle-split': props.split,\n // [props.size]: !!props.size,\n [props.variant]: !!props.variant,\n \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.umd.cjs","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","onClickItem","onClickToggle","onKeydown","onBeforeMount","__props","__emit","onClick","slots","useSlots"],"mappings":"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"}
@@ -1,35 +1,34 @@
1
1
  import { BtnDropdownProps } from './dropdown.js';
2
- declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<__VLS_TypePropsToRuntimeProps<BtnDropdownProps>, {}, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {
3
- click: (e: Event) => void;
4
- }, string, import("vue").PublicProps, Readonly<import("vue").ExtractPropTypes<__VLS_TypePropsToRuntimeProps<BtnDropdownProps>>> & {
5
- onClick?: (e: Event) => any;
6
- }, {}, {}>, {
7
- icon?(_: {}): any;
8
- label?(_: {}): any;
9
- button?(_: {
10
- button: Element | import("vue").ComponentPublicInstance;
11
- $button: (ref: Element | import("vue").ComponentPublicInstance, refs: Record<string, any>) => void;
12
- expanded: boolean;
13
- target: Element | import("vue").ComponentPublicInstance;
14
- toggle: () => void;
15
- onBlur: (e: FocusEvent) => void;
16
- onClickToggle: (e: MouseEvent) => void;
17
- onClickItem: (e: any) => void;
18
- onKeydown: (e: KeyboardEvent) => void;
19
- }): any;
20
- split?(_: any): any;
21
- default?(_: {}): any;
22
- }>;
23
- export default _default;
24
- type __VLS_NonUndefinedable<T> = T extends undefined ? never : T;
25
- type __VLS_TypePropsToRuntimeProps<T> = {
26
- [K in keyof T]-?: {} extends Pick<T, K> ? {
27
- type: import('vue').PropType<__VLS_NonUndefinedable<T[K]>>;
28
- } : {
29
- type: import('vue').PropType<T[K]>;
30
- required: true;
2
+ declare function __VLS_template(): {
3
+ attrs: Partial<{}>;
4
+ slots: {
5
+ icon?(_: {}): any;
6
+ label?(_: {}): any;
7
+ button?(_: {
8
+ button: Element | import("vue").ComponentPublicInstance;
9
+ $button: any;
10
+ expanded: boolean;
11
+ target: Element | import("vue").ComponentPublicInstance;
12
+ toggle: () => void;
13
+ onBlur: (e: FocusEvent) => void;
14
+ onClickToggle: (e: MouseEvent) => void;
15
+ onClickItem: (e: any) => void;
16
+ onKeydown: (e: KeyboardEvent) => void;
17
+ }): any;
18
+ split?(_: any): any;
19
+ default?(_: {}): any;
31
20
  };
21
+ refs: {};
22
+ rootEl: any;
32
23
  };
24
+ type __VLS_TemplateResult = ReturnType<typeof __VLS_template>;
25
+ declare const __VLS_component: import("vue").DefineComponent<BtnDropdownProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {
26
+ click: (e: Event) => any;
27
+ }, string, import("vue").PublicProps, Readonly<BtnDropdownProps> & Readonly<{
28
+ onClick?: (e: Event) => any;
29
+ }>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, true, {}, any>;
30
+ declare const _default: __VLS_WithTemplateSlots<typeof __VLS_component, __VLS_TemplateResult["slots"]>;
31
+ export default _default;
33
32
  type __VLS_WithTemplateSlots<T, S> = T & {
34
33
  new (): {
35
34
  $slots: S;
@@ -1,4 +1,4 @@
1
- declare const _default: import("vue").DefineComponent<{
1
+ declare const _default: import("vue").DefineComponent<import("vue").ExtractPropTypes<{
2
2
  expanded: {
3
3
  type: BooleanConstructor;
4
4
  default: boolean;
@@ -15,7 +15,7 @@ declare const _default: import("vue").DefineComponent<{
15
15
  type: (StringConstructor | ObjectConstructor)[];
16
16
  default: any;
17
17
  };
18
- }, unknown, unknown, {
18
+ }>, {}, {}, {
19
19
  is(): "router-link" | "a" | "button";
20
20
  }, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<import("vue").ExtractPropTypes<{
21
21
  expanded: {
@@ -34,10 +34,10 @@ declare const _default: import("vue").DefineComponent<{
34
34
  type: (StringConstructor | ObjectConstructor)[];
35
35
  default: any;
36
36
  };
37
- }>>, {
37
+ }>> & Readonly<{}>, {
38
38
  expanded: boolean;
39
39
  id: string;
40
40
  href: string;
41
41
  to: string | Record<string, any>;
42
- }, {}>;
42
+ }, {}, {}, {}, string, import("vue").ComponentProvideOptions, true, {}, any>;
43
43
  export default _default;
@@ -1,38 +1,223 @@
1
1
  import { BtnDropdownProps } from './dropdown.js';
2
- declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<__VLS_TypePropsToRuntimeProps<BtnDropdownProps>, {}, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {
3
- click: (e: PointerEvent) => void;
4
- "click-toggle": (e: MouseEvent) => void;
5
- blur: (e: FocusEvent) => void;
6
- }, string, import("vue").PublicProps, Readonly<import("vue").ExtractPropTypes<__VLS_TypePropsToRuntimeProps<BtnDropdownProps>>> & {
7
- onBlur?: (e: FocusEvent) => any;
2
+ declare function __VLS_template(): {
3
+ attrs: Partial<{}>;
4
+ slots: {
5
+ button?(_: {
6
+ button: Element | import("vue").ComponentPublicInstance;
7
+ $button: any;
8
+ expanded: boolean;
9
+ target: Element | import("vue").ComponentPublicInstance;
10
+ toggle: () => void;
11
+ onBlur: (e: FocusEvent) => void;
12
+ onClickToggle: (e: MouseEvent) => void;
13
+ onClickItem: (e: any) => void;
14
+ onKeydown: (e: KeyboardEvent) => void;
15
+ }): any;
16
+ icon?(_: {}): any;
17
+ label?(_: {}): any;
18
+ default?(_: {}): any;
19
+ };
20
+ refs: {
21
+ target: {
22
+ $: import("vue").ComponentInternalInstance;
23
+ $data: {};
24
+ $props: Partial<{}> & Omit<{
25
+ readonly size?: string;
26
+ readonly toggle?: boolean;
27
+ readonly vertical?: boolean;
28
+ } & import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, never>;
29
+ $attrs: {
30
+ [x: string]: unknown;
31
+ };
32
+ $refs: {
33
+ [x: string]: unknown;
34
+ };
35
+ $slots: Readonly<{
36
+ [name: string]: import("vue").Slot<any>;
37
+ }>;
38
+ $root: import("vue").ComponentPublicInstance | null;
39
+ $parent: import("vue").ComponentPublicInstance | null;
40
+ $host: Element | null;
41
+ $emit: (event: string, ...args: any[]) => void;
42
+ $el: any;
43
+ $options: import("vue").ComponentOptionsBase<Readonly<import("vue").ExtractPropTypes<{
44
+ size: {
45
+ type: import("vue").PropType<string>;
46
+ };
47
+ toggle: {
48
+ type: import("vue").PropType<boolean>;
49
+ };
50
+ vertical: {
51
+ type: import("vue").PropType<boolean>;
52
+ };
53
+ }>>, {}, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, {}, {}, string, {}, import("vue").GlobalComponents, import("vue").GlobalDirectives, string, import("vue").ComponentProvideOptions> & {
54
+ beforeCreate?: (() => void) | (() => void)[];
55
+ created?: (() => void) | (() => void)[];
56
+ beforeMount?: (() => void) | (() => void)[];
57
+ mounted?: (() => void) | (() => void)[];
58
+ beforeUpdate?: (() => void) | (() => void)[];
59
+ updated?: (() => void) | (() => void)[];
60
+ activated?: (() => void) | (() => void)[];
61
+ deactivated?: (() => void) | (() => void)[];
62
+ beforeDestroy?: (() => void) | (() => void)[];
63
+ beforeUnmount?: (() => void) | (() => void)[];
64
+ destroyed?: (() => void) | (() => void)[];
65
+ unmounted?: (() => void) | (() => void)[];
66
+ renderTracked?: ((e: import("vue").DebuggerEvent) => void) | ((e: import("vue").DebuggerEvent) => void)[];
67
+ renderTriggered?: ((e: import("vue").DebuggerEvent) => void) | ((e: import("vue").DebuggerEvent) => void)[];
68
+ errorCaptured?: ((err: unknown, instance: import("vue").ComponentPublicInstance | null, info: string) => boolean | void) | ((err: unknown, instance: import("vue").ComponentPublicInstance | null, info: string) => boolean | void)[];
69
+ };
70
+ $forceUpdate: () => void;
71
+ $nextTick: typeof import("vue").nextTick;
72
+ $watch<T extends string | ((...args: any) => any)>(source: T, cb: T extends (...args: any) => infer R ? (...args: [R, R, import("@vue/reactivity").OnCleanup]) => any : (...args: [any, any, import("@vue/reactivity").OnCleanup]) => any, options?: import("vue").WatchOptions): import("vue").WatchStopHandle;
73
+ } & Readonly<{}> & Omit<Readonly<import("vue").ExtractPropTypes<{
74
+ size: {
75
+ type: import("vue").PropType<string>;
76
+ };
77
+ toggle: {
78
+ type: import("vue").PropType<boolean>;
79
+ };
80
+ vertical: {
81
+ type: import("vue").PropType<boolean>;
82
+ };
83
+ }>>, never> & import("vue").ShallowUnwrapRef<{}> & {} & import("vue").ComponentCustomProperties & {} & {
84
+ $slots: {
85
+ default?(_: {}): any;
86
+ };
87
+ };
88
+ button: import("vue").CreateComponentPublicInstanceWithMixins<Readonly<import("vue").ExtractPropTypes<{
89
+ expanded: {
90
+ type: BooleanConstructor;
91
+ default: boolean;
92
+ };
93
+ id: {
94
+ type: StringConstructor;
95
+ default: any;
96
+ };
97
+ href: {
98
+ type: StringConstructor;
99
+ default: any;
100
+ };
101
+ to: {
102
+ type: (StringConstructor | ObjectConstructor)[];
103
+ default: any;
104
+ };
105
+ }>> & Readonly<{}>, {}, {}, {
106
+ is(): "router-link" | "a" | "button";
107
+ }, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, import("vue").PublicProps, {
108
+ expanded: boolean;
109
+ id: string;
110
+ href: string;
111
+ to: string | Record<string, any>;
112
+ }, true, {}, {}, import("vue").GlobalComponents, import("vue").GlobalDirectives, string, {}, any, import("vue").ComponentProvideOptions, {
113
+ P: {};
114
+ B: {};
115
+ D: {};
116
+ C: {};
117
+ M: {};
118
+ Defaults: {};
119
+ }, Readonly<import("vue").ExtractPropTypes<{
120
+ expanded: {
121
+ type: BooleanConstructor;
122
+ default: boolean;
123
+ };
124
+ id: {
125
+ type: StringConstructor;
126
+ default: any;
127
+ };
128
+ href: {
129
+ type: StringConstructor;
130
+ default: any;
131
+ };
132
+ to: {
133
+ type: (StringConstructor | ObjectConstructor)[];
134
+ default: any;
135
+ };
136
+ }>> & Readonly<{}>, {}, {}, {
137
+ is(): "router-link" | "a" | "button";
138
+ }, {}, {
139
+ expanded: boolean;
140
+ id: string;
141
+ href: string;
142
+ to: string | Record<string, any>;
143
+ }>;
144
+ menu: {
145
+ $: import("vue").ComponentInternalInstance;
146
+ $data: {};
147
+ $props: Partial<{}> & Omit<{
148
+ readonly align: "left" | "right";
149
+ readonly show?: boolean;
150
+ } & import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, never>;
151
+ $attrs: {
152
+ [x: string]: unknown;
153
+ };
154
+ $refs: {
155
+ [x: string]: unknown;
156
+ };
157
+ $slots: Readonly<{
158
+ [name: string]: import("vue").Slot<any>;
159
+ }>;
160
+ $root: import("vue").ComponentPublicInstance | null;
161
+ $parent: import("vue").ComponentPublicInstance | null;
162
+ $host: Element | null;
163
+ $emit: (event: string, ...args: any[]) => void;
164
+ $el: any;
165
+ $options: import("vue").ComponentOptionsBase<Readonly<import("vue").ExtractPropTypes<{
166
+ align: {
167
+ type: import("vue").PropType<"left" | "right">;
168
+ required: true;
169
+ };
170
+ show: {
171
+ type: import("vue").PropType<boolean>;
172
+ };
173
+ }>>, {}, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, {}, {}, string, {}, import("vue").GlobalComponents, import("vue").GlobalDirectives, string, import("vue").ComponentProvideOptions> & {
174
+ beforeCreate?: (() => void) | (() => void)[];
175
+ created?: (() => void) | (() => void)[];
176
+ beforeMount?: (() => void) | (() => void)[];
177
+ mounted?: (() => void) | (() => void)[];
178
+ beforeUpdate?: (() => void) | (() => void)[];
179
+ updated?: (() => void) | (() => void)[];
180
+ activated?: (() => void) | (() => void)[];
181
+ deactivated?: (() => void) | (() => void)[];
182
+ beforeDestroy?: (() => void) | (() => void)[];
183
+ beforeUnmount?: (() => void) | (() => void)[];
184
+ destroyed?: (() => void) | (() => void)[];
185
+ unmounted?: (() => void) | (() => void)[];
186
+ renderTracked?: ((e: import("vue").DebuggerEvent) => void) | ((e: import("vue").DebuggerEvent) => void)[];
187
+ renderTriggered?: ((e: import("vue").DebuggerEvent) => void) | ((e: import("vue").DebuggerEvent) => void)[];
188
+ errorCaptured?: ((err: unknown, instance: import("vue").ComponentPublicInstance | null, info: string) => boolean | void) | ((err: unknown, instance: import("vue").ComponentPublicInstance | null, info: string) => boolean | void)[];
189
+ };
190
+ $forceUpdate: () => void;
191
+ $nextTick: typeof import("vue").nextTick;
192
+ $watch<T extends string | ((...args: any) => any)>(source: T, cb: T extends (...args: any) => infer R ? (...args: [R, R, import("@vue/reactivity").OnCleanup]) => any : (...args: [any, any, import("@vue/reactivity").OnCleanup]) => any, options?: import("vue").WatchOptions): import("vue").WatchStopHandle;
193
+ } & Readonly<{}> & Omit<Readonly<import("vue").ExtractPropTypes<{
194
+ align: {
195
+ type: import("vue").PropType<"left" | "right">;
196
+ required: true;
197
+ };
198
+ show: {
199
+ type: import("vue").PropType<boolean>;
200
+ };
201
+ }>>, never> & import("vue").ShallowUnwrapRef<{}> & {} & import("vue").ComponentCustomProperties & {} & {
202
+ $slots: {
203
+ default?(_: {}): any;
204
+ };
205
+ };
206
+ };
207
+ rootEl: any;
208
+ };
209
+ type __VLS_TemplateResult = ReturnType<typeof __VLS_template>;
210
+ declare const __VLS_component: import("vue").DefineComponent<BtnDropdownProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {} & {
211
+ click: (e: PointerEvent) => any;
212
+ "click-toggle": (e: MouseEvent) => any;
213
+ blur: (e: FocusEvent) => any;
214
+ }, string, import("vue").PublicProps, Readonly<BtnDropdownProps> & Readonly<{
8
215
  onClick?: (e: PointerEvent) => any;
9
216
  "onClick-toggle"?: (e: MouseEvent) => any;
10
- }, {}, {}>, {
11
- button?(_: {
12
- button: Element | import("vue").ComponentPublicInstance;
13
- $button: (ref: Element | import("vue").ComponentPublicInstance, refs: Record<string, any>) => void;
14
- expanded: boolean;
15
- target: Element | import("vue").ComponentPublicInstance;
16
- toggle: () => void;
17
- onBlur: (e: FocusEvent) => void;
18
- onClickToggle: (e: MouseEvent) => void;
19
- onClickItem: (e: any) => void;
20
- onKeydown: (e: KeyboardEvent) => void;
21
- }): any;
22
- icon?(_: {}): any;
23
- label?(_: {}): any;
24
- default?(_: {}): any;
25
- }>;
217
+ onBlur?: (e: FocusEvent) => any;
218
+ }>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, true, {}, any>;
219
+ declare const _default: __VLS_WithTemplateSlots<typeof __VLS_component, __VLS_TemplateResult["slots"]>;
26
220
  export default _default;
27
- type __VLS_NonUndefinedable<T> = T extends undefined ? never : T;
28
- type __VLS_TypePropsToRuntimeProps<T> = {
29
- [K in keyof T]-?: {} extends Pick<T, K> ? {
30
- type: import('vue').PropType<__VLS_NonUndefinedable<T[K]>>;
31
- } : {
32
- type: import('vue').PropType<T[K]>;
33
- required: true;
34
- };
35
- };
36
221
  type __VLS_WithTemplateSlots<T, S> = T & {
37
222
  new (): {
38
223
  $slots: S;
@@ -1,35 +1,173 @@
1
1
  import { BtnDropdownProps } from './dropdown.js';
2
- declare const _default: __VLS_WithTemplateSlots<import("vue").DefineComponent<__VLS_TypePropsToRuntimeProps<BtnDropdownProps>, {}, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {
3
- click: (e: PointerEvent) => void;
4
- "click-toggle": (e: MouseEvent) => void;
5
- blur: (e: FocusEvent) => void;
6
- }, string, import("vue").PublicProps, Readonly<import("vue").ExtractPropTypes<__VLS_TypePropsToRuntimeProps<BtnDropdownProps>>> & {
7
- onBlur?: (e: FocusEvent) => any;
2
+ declare function __VLS_template(): {
3
+ attrs: Partial<{}>;
4
+ slots: {
5
+ button?(_: {
6
+ expanded: boolean;
7
+ onBlur: (e: FocusEvent) => void;
8
+ onClickToggle: (e: MouseEvent) => void;
9
+ onClickItem: (e: any) => void;
10
+ onKeydown: (e: KeyboardEvent) => void;
11
+ }): any;
12
+ button?(_: {
13
+ expanded: boolean;
14
+ onBlur: (e: FocusEvent) => void;
15
+ onClickToggle: (e: MouseEvent) => void;
16
+ onClickItem: (e: any) => void;
17
+ onKeydown: (e: KeyboardEvent) => void;
18
+ }): any;
19
+ icon?(_: {}): any;
20
+ icon?(_: {}): any;
21
+ label?(_: {}): any;
22
+ label?(_: {}): any;
23
+ split?(_: {}): any;
24
+ default?(_: {}): any;
25
+ };
26
+ refs: {
27
+ target: {
28
+ $: import("vue").ComponentInternalInstance;
29
+ $data: {};
30
+ $props: Partial<{}> & Omit<{
31
+ readonly size?: string;
32
+ readonly toggle?: boolean;
33
+ readonly vertical?: boolean;
34
+ } & import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, never>;
35
+ $attrs: {
36
+ [x: string]: unknown;
37
+ };
38
+ $refs: {
39
+ [x: string]: unknown;
40
+ };
41
+ $slots: Readonly<{
42
+ [name: string]: import("vue").Slot<any>;
43
+ }>;
44
+ $root: import("vue").ComponentPublicInstance | null;
45
+ $parent: import("vue").ComponentPublicInstance | null;
46
+ $host: Element | null;
47
+ $emit: (event: string, ...args: any[]) => void;
48
+ $el: any;
49
+ $options: import("vue").ComponentOptionsBase<Readonly<import("vue").ExtractPropTypes<{
50
+ size: {
51
+ type: import("vue").PropType<string>;
52
+ };
53
+ toggle: {
54
+ type: import("vue").PropType<boolean>;
55
+ };
56
+ vertical: {
57
+ type: import("vue").PropType<boolean>;
58
+ };
59
+ }>>, {}, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, {}, {}, string, {}, import("vue").GlobalComponents, import("vue").GlobalDirectives, string, import("vue").ComponentProvideOptions> & {
60
+ beforeCreate?: (() => void) | (() => void)[];
61
+ created?: (() => void) | (() => void)[];
62
+ beforeMount?: (() => void) | (() => void)[];
63
+ mounted?: (() => void) | (() => void)[];
64
+ beforeUpdate?: (() => void) | (() => void)[];
65
+ updated?: (() => void) | (() => void)[];
66
+ activated?: (() => void) | (() => void)[];
67
+ deactivated?: (() => void) | (() => void)[];
68
+ beforeDestroy?: (() => void) | (() => void)[];
69
+ beforeUnmount?: (() => void) | (() => void)[];
70
+ destroyed?: (() => void) | (() => void)[];
71
+ unmounted?: (() => void) | (() => void)[];
72
+ renderTracked?: ((e: import("vue").DebuggerEvent) => void) | ((e: import("vue").DebuggerEvent) => void)[];
73
+ renderTriggered?: ((e: import("vue").DebuggerEvent) => void) | ((e: import("vue").DebuggerEvent) => void)[];
74
+ errorCaptured?: ((err: unknown, instance: import("vue").ComponentPublicInstance | null, info: string) => boolean | void) | ((err: unknown, instance: import("vue").ComponentPublicInstance | null, info: string) => boolean | void)[];
75
+ };
76
+ $forceUpdate: () => void;
77
+ $nextTick: typeof import("vue").nextTick;
78
+ $watch<T extends string | ((...args: any) => any)>(source: T, cb: T extends (...args: any) => infer R ? (...args: [R, R, import("@vue/reactivity").OnCleanup]) => any : (...args: [any, any, import("@vue/reactivity").OnCleanup]) => any, options?: import("vue").WatchOptions): import("vue").WatchStopHandle;
79
+ } & Readonly<{}> & Omit<Readonly<import("vue").ExtractPropTypes<{
80
+ size: {
81
+ type: import("vue").PropType<string>;
82
+ };
83
+ toggle: {
84
+ type: import("vue").PropType<boolean>;
85
+ };
86
+ vertical: {
87
+ type: import("vue").PropType<boolean>;
88
+ };
89
+ }>>, never> & import("vue").ShallowUnwrapRef<{}> & {} & import("vue").ComponentCustomProperties & {} & {
90
+ $slots: {
91
+ default?(_: {}): any;
92
+ };
93
+ };
94
+ menu: {
95
+ $: import("vue").ComponentInternalInstance;
96
+ $data: {};
97
+ $props: Partial<{}> & Omit<{
98
+ readonly align: "left" | "right";
99
+ readonly show?: boolean;
100
+ } & import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, never>;
101
+ $attrs: {
102
+ [x: string]: unknown;
103
+ };
104
+ $refs: {
105
+ [x: string]: unknown;
106
+ };
107
+ $slots: Readonly<{
108
+ [name: string]: import("vue").Slot<any>;
109
+ }>;
110
+ $root: import("vue").ComponentPublicInstance | null;
111
+ $parent: import("vue").ComponentPublicInstance | null;
112
+ $host: Element | null;
113
+ $emit: (event: string, ...args: any[]) => void;
114
+ $el: any;
115
+ $options: import("vue").ComponentOptionsBase<Readonly<import("vue").ExtractPropTypes<{
116
+ align: {
117
+ type: import("vue").PropType<"left" | "right">;
118
+ required: true;
119
+ };
120
+ show: {
121
+ type: import("vue").PropType<boolean>;
122
+ };
123
+ }>>, {}, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, {}, {}, string, {}, import("vue").GlobalComponents, import("vue").GlobalDirectives, string, import("vue").ComponentProvideOptions> & {
124
+ beforeCreate?: (() => void) | (() => void)[];
125
+ created?: (() => void) | (() => void)[];
126
+ beforeMount?: (() => void) | (() => void)[];
127
+ mounted?: (() => void) | (() => void)[];
128
+ beforeUpdate?: (() => void) | (() => void)[];
129
+ updated?: (() => void) | (() => void)[];
130
+ activated?: (() => void) | (() => void)[];
131
+ deactivated?: (() => void) | (() => void)[];
132
+ beforeDestroy?: (() => void) | (() => void)[];
133
+ beforeUnmount?: (() => void) | (() => void)[];
134
+ destroyed?: (() => void) | (() => void)[];
135
+ unmounted?: (() => void) | (() => void)[];
136
+ renderTracked?: ((e: import("vue").DebuggerEvent) => void) | ((e: import("vue").DebuggerEvent) => void)[];
137
+ renderTriggered?: ((e: import("vue").DebuggerEvent) => void) | ((e: import("vue").DebuggerEvent) => void)[];
138
+ errorCaptured?: ((err: unknown, instance: import("vue").ComponentPublicInstance | null, info: string) => boolean | void) | ((err: unknown, instance: import("vue").ComponentPublicInstance | null, info: string) => boolean | void)[];
139
+ };
140
+ $forceUpdate: () => void;
141
+ $nextTick: typeof import("vue").nextTick;
142
+ $watch<T extends string | ((...args: any) => any)>(source: T, cb: T extends (...args: any) => infer R ? (...args: [R, R, import("@vue/reactivity").OnCleanup]) => any : (...args: [any, any, import("@vue/reactivity").OnCleanup]) => any, options?: import("vue").WatchOptions): import("vue").WatchStopHandle;
143
+ } & Readonly<{}> & Omit<Readonly<import("vue").ExtractPropTypes<{
144
+ align: {
145
+ type: import("vue").PropType<"left" | "right">;
146
+ required: true;
147
+ };
148
+ show: {
149
+ type: import("vue").PropType<boolean>;
150
+ };
151
+ }>>, never> & import("vue").ShallowUnwrapRef<{}> & {} & import("vue").ComponentCustomProperties & {} & {
152
+ $slots: {
153
+ default?(_: {}): any;
154
+ };
155
+ };
156
+ };
157
+ rootEl: any;
158
+ };
159
+ type __VLS_TemplateResult = ReturnType<typeof __VLS_template>;
160
+ declare const __VLS_component: import("vue").DefineComponent<BtnDropdownProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {} & {
161
+ click: (e: PointerEvent) => any;
162
+ "click-toggle": (e: MouseEvent) => any;
163
+ blur: (e: FocusEvent) => any;
164
+ }, string, import("vue").PublicProps, Readonly<BtnDropdownProps> & Readonly<{
8
165
  onClick?: (e: PointerEvent) => any;
9
166
  "onClick-toggle"?: (e: MouseEvent) => any;
10
- }, {}, {}>, {
11
- button?(_: {
12
- expanded: boolean;
13
- onBlur: (e: FocusEvent) => void;
14
- onClickToggle: (e: MouseEvent) => void;
15
- onClickItem: (e: any) => void;
16
- onKeydown: (e: KeyboardEvent) => void;
17
- }): any;
18
- icon?(_: {}): any;
19
- label?(_: {}): any;
20
- split?(_: {}): any;
21
- default?(_: {}): any;
22
- }>;
167
+ onBlur?: (e: FocusEvent) => any;
168
+ }>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, true, {}, any>;
169
+ declare const _default: __VLS_WithTemplateSlots<typeof __VLS_component, __VLS_TemplateResult["slots"]>;
23
170
  export default _default;
24
- type __VLS_NonUndefinedable<T> = T extends undefined ? never : T;
25
- type __VLS_TypePropsToRuntimeProps<T> = {
26
- [K in keyof T]-?: {} extends Pick<T, K> ? {
27
- type: import('vue').PropType<__VLS_NonUndefinedable<T[K]>>;
28
- } : {
29
- type: import('vue').PropType<T[K]>;
30
- required: true;
31
- };
32
- };
33
171
  type __VLS_WithTemplateSlots<T, S> = T & {
34
172
  new (): {
35
173
  $slots: S;
@@ -1,4 +1,4 @@
1
- import { ComponentPublicInstance } from 'vue';
1
+ import { ComponentPublicInstance, ComputedRef } from 'vue';
2
2
  export type BtnDropdownProps = {
3
3
  active?: boolean;
4
4
  align?: 'left' | 'right';
@@ -19,12 +19,13 @@ export type BtnDropdownEmits = {
19
19
  (name: 'blur', e: FocusEvent): void;
20
20
  };
21
21
  export declare function useBtnDropdown<Props extends BtnDropdownProps, Emits extends BtnDropdownEmits>(props: Props, emit: Emits): {
22
- actionClasses: import("vue").ComputedRef<{
23
- btn: boolean;
22
+ actionClasses: ComputedRef<{
23
+ [x: string]: boolean;
24
+ btn: true;
24
25
  }>;
25
- button: import("vue").Ref<Element | ComponentPublicInstance>;
26
- $button: (ref: Element | ComponentPublicInstance | null, refs: Record<string, any>) => void;
27
- classes: import("vue").ComputedRef<{
26
+ button: import("vue").Ref<Element | ComponentPublicInstance, Element | ComponentPublicInstance>;
27
+ $button: any;
28
+ classes: ComputedRef<{
28
29
  [x: string]: boolean;
29
30
  dropdown: boolean;
30
31
  dropup: boolean;
@@ -32,16 +33,17 @@ export declare function useBtnDropdown<Props extends BtnDropdownProps, Emits ext
32
33
  dropleft: boolean;
33
34
  expanded: boolean;
34
35
  }>;
35
- expanded: import("vue").Ref<boolean>;
36
- menu: import("vue").Ref<Element | ComponentPublicInstance>;
37
- target: import("vue").Ref<Element | ComponentPublicInstance>;
38
- toggleClasses: import("vue").ComputedRef<{
39
- btn: boolean;
36
+ expanded: import("vue").Ref<boolean, boolean>;
37
+ menu: import("vue").Ref<Element | ComponentPublicInstance, Element | ComponentPublicInstance>;
38
+ target: import("vue").Ref<Element | ComponentPublicInstance, Element | ComponentPublicInstance>;
39
+ toggleClasses: ComputedRef<{
40
+ [x: string]: boolean;
41
+ btn: true;
40
42
  active: boolean;
41
43
  'dropdown-toggle': boolean;
42
44
  'dropdown-toggle-split': boolean;
43
45
  }>;
44
- triggerAnimation: import("vue").Ref<boolean>;
46
+ triggerAnimation: import("vue").Ref<boolean, boolean>;
45
47
  hide: () => void;
46
48
  show: () => void;
47
49
  toggle: () => void;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@vue-interface/btn-dropdown",
3
- "version": "2.0.0-beta.21",
3
+ "version": "2.0.0-beta.23",
4
4
  "description": "A Vue button dropdown component.",
5
5
  "files": [
6
6
  "dist"
@@ -43,35 +43,35 @@
43
43
  },
44
44
  "homepage": "https://github.com/vue-interface/btn-dropdown",
45
45
  "dependencies": {
46
- "@popperjs/core": "^2.11.2",
47
- "@vue-interface/btn": "^3.0.0-beta.21",
48
- "@vue-interface/btn-group": "^2.0.0-beta.8",
49
- "@vue-interface/dropdown-menu": "^2.0.0-beta.13"
46
+ "@popperjs/core": "^2.11.8",
47
+ "@vue-interface/btn": "^3.0.0-beta.26",
48
+ "@vue-interface/btn-group": "^2.0.0-beta.10",
49
+ "@vue-interface/dropdown-menu": "^2.0.0-beta.21"
50
50
  },
51
51
  "peerDependencies": {
52
52
  "vue": "^3.3.4"
53
53
  },
54
54
  "devDependencies": {
55
- "@commitlint/config-conventional": "^17.7.0",
55
+ "@commitlint/config-conventional": "^17.8.1",
56
56
  "@semantic-release/changelog": "^6.0.3",
57
57
  "@semantic-release/git": "^10.0.1",
58
- "@semantic-release/npm": "^10.0.5",
59
- "@types/color": "^3.0.3",
60
- "@vitejs/plugin-vue": "^4.3.2",
61
- "@vue-interface/eslint-config": "^1.0.0-beta.0",
62
- "autoprefixer": "^10.4.15",
58
+ "@semantic-release/npm": "^10.0.6",
59
+ "@types/color": "^3.0.6",
60
+ "@vitejs/plugin-vue": "^4.6.2",
61
+ "@vue-interface/eslint-config": "^1.0.0-beta.4",
62
+ "autoprefixer": "^10.4.20",
63
63
  "change-case": "^4.1.2",
64
- "commitlint": "^17.7.1",
65
- "dotenv": "^16.3.1",
66
- "eslint": "^8.47.0",
64
+ "commitlint": "^17.8.1",
65
+ "dotenv": "^16.4.7",
66
+ "eslint": "^8.57.1",
67
67
  "husky": "^8.0.3",
68
68
  "pascalcase": "^2.0.0",
69
- "postcss": "^8.4.6",
70
- "semantic-release": "^21.0.7",
71
- "tailwindcss": "^3.3.3",
72
- "typescript": "^5.2.2",
73
- "vite": "^4.4.9",
74
- "vue": "^3.4.0",
75
- "vue-tsc": "^1.8.8"
69
+ "postcss": "^8.4.49",
70
+ "semantic-release": "^21.1.2",
71
+ "tailwindcss": "^3.4.16",
72
+ "typescript": "~5.6.0",
73
+ "vite": "^4.5.5",
74
+ "vue": "^3.5.13",
75
+ "vue-tsc": "^2.1.10"
76
76
  }
77
77
  }