bitboss-ui 2.1.27 → 2.1.29

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (175) hide show
  1. package/dist/components/BbNumberInput/BbNumberInput.vue.d.ts +1 -3
  2. package/dist/index.css +1 -1
  3. package/dist/index106.js +9 -9
  4. package/dist/index111.js +1 -1
  5. package/dist/index113.js +1 -1
  6. package/dist/index121.js +12 -12
  7. package/dist/index129.js +1 -1
  8. package/dist/index13.js +1 -1
  9. package/dist/index131.js +4 -4
  10. package/dist/index133.js +1 -1
  11. package/dist/index136.js +1 -1
  12. package/dist/index138.js +1 -1
  13. package/dist/index139.js +2 -2
  14. package/dist/index15.js +8 -8
  15. package/dist/index17.js +3 -3
  16. package/dist/index19.js +8 -8
  17. package/dist/index207.js +2 -2
  18. package/dist/index208.js +2 -2
  19. package/dist/index209.js +85 -12
  20. package/dist/index21.js +16 -16
  21. package/dist/index211.js +27 -9
  22. package/dist/index212.js +17 -34
  23. package/dist/index213.js +51 -86
  24. package/dist/index214.js +17 -0
  25. package/dist/index215.js +3 -29
  26. package/dist/index216.js +11 -16
  27. package/dist/index217.js +13 -48
  28. package/dist/index218.js +4 -15
  29. package/dist/index219.js +13 -3
  30. package/dist/index220.js +9 -10
  31. package/dist/index221.js +19 -15
  32. package/dist/index222.js +197 -2
  33. package/dist/index224.js +69 -2
  34. package/dist/index226.js +13 -2
  35. package/dist/index227.js +116 -17
  36. package/dist/index229.js +2 -6
  37. package/dist/index23.js +15 -15
  38. package/dist/index230.js +4 -106
  39. package/dist/index231.js +36 -0
  40. package/dist/index232.js +2 -100
  41. package/dist/index233.js +4 -0
  42. package/dist/index234.js +17 -68
  43. package/dist/index236.js +6 -13
  44. package/dist/index237.js +101 -112
  45. package/dist/index239.js +83 -212
  46. package/dist/index241.js +229 -2
  47. package/dist/index242.js +2 -7
  48. package/dist/index243.js +2 -7
  49. package/dist/index244.js +6 -3
  50. package/dist/index245.js +2 -4
  51. package/dist/index246.js +5 -20
  52. package/dist/index247.js +5 -197
  53. package/dist/index248.js +7 -0
  54. package/dist/index249.js +5 -5
  55. package/dist/index25.js +3 -3
  56. package/dist/index250.js +4 -4
  57. package/dist/index251.js +5 -5
  58. package/dist/index252.js +3 -5
  59. package/dist/index253.js +2 -5
  60. package/dist/index254.js +7 -5
  61. package/dist/index255.js +7 -2
  62. package/dist/index256.js +13 -5
  63. package/dist/index257.js +4 -4
  64. package/dist/index258.js +5 -8
  65. package/dist/index259.js +6 -248
  66. package/dist/index260.js +240 -42
  67. package/dist/index261.js +43 -35
  68. package/dist/index262.js +44 -5
  69. package/dist/index263.js +5 -60
  70. package/dist/index264.js +59 -182
  71. package/dist/index265.js +181 -7
  72. package/dist/index266.js +10 -23
  73. package/dist/index267.js +2 -9
  74. package/dist/index268.js +8 -2
  75. package/dist/index269.js +23 -6
  76. package/dist/index27.js +1 -1
  77. package/dist/index270.js +6 -16
  78. package/dist/index271.js +16 -3
  79. package/dist/index272.js +3 -9
  80. package/dist/index273.js +9 -9
  81. package/dist/index274.js +9 -8
  82. package/dist/index275.js +8 -2
  83. package/dist/index276.js +2 -67
  84. package/dist/index277.js +5 -5
  85. package/dist/index278.js +7 -4
  86. package/dist/index279.js +5 -8
  87. package/dist/index280.js +67 -2
  88. package/dist/index281.js +3 -7
  89. package/dist/index282.js +17 -11
  90. package/dist/index283.js +28 -3
  91. package/dist/index284.js +3 -17
  92. package/dist/index285.js +3 -28
  93. package/dist/index287.js +7 -4
  94. package/dist/index288.js +1 -1
  95. package/dist/index289.js +7 -3
  96. package/dist/index29.js +91 -87
  97. package/dist/index290.js +11 -3
  98. package/dist/index291.js +6 -0
  99. package/dist/index292.js +3 -6
  100. package/dist/index293.js +2 -3
  101. package/dist/index294.js +3 -2
  102. package/dist/index295.js +3 -5
  103. package/dist/index296.js +2 -3
  104. package/dist/index309.js +5 -6
  105. package/dist/index31.js +2 -2
  106. package/dist/index310.js +5 -18
  107. package/dist/index311.js +19 -2
  108. package/dist/index312.js +2 -27
  109. package/dist/index313.js +27 -2
  110. package/dist/index314.js +2 -2
  111. package/dist/index317.js +1 -1
  112. package/dist/index318.js +1 -21
  113. package/dist/index319.js +24 -0
  114. package/dist/index321.js +5 -366
  115. package/dist/index322.js +718 -58
  116. package/dist/index323.js +366 -5
  117. package/dist/index324.js +58 -2
  118. package/dist/index325.js +2 -58
  119. package/dist/index326.js +227 -57
  120. package/dist/index327.js +32 -6
  121. package/dist/index328.js +27 -18
  122. package/dist/index33.js +8 -8
  123. package/dist/index330.js +6 -128
  124. package/dist/index331.js +16 -366
  125. package/dist/index332.js +6 -46
  126. package/dist/index333.js +8 -7
  127. package/dist/index334.js +128 -32
  128. package/dist/index335.js +369 -28
  129. package/dist/index336.js +49 -0
  130. package/dist/index337.js +57 -227
  131. package/dist/index338.js +58 -8
  132. package/dist/index339.js +7 -5
  133. package/dist/index340.js +6 -8
  134. package/dist/index341.js +7 -92
  135. package/dist/index342.js +89 -125
  136. package/dist/index344.js +3 -127
  137. package/dist/index345.js +124 -483
  138. package/dist/{index343.js → index346.js} +1 -1
  139. package/dist/index347.js +127 -3
  140. package/dist/index348.js +483 -45
  141. package/dist/index349.js +52 -0
  142. package/dist/index35.js +4 -4
  143. package/dist/index37.js +20 -20
  144. package/dist/index39.js +7 -7
  145. package/dist/index41.js +2 -2
  146. package/dist/index43.js +8 -8
  147. package/dist/index45.js +8 -8
  148. package/dist/index47.js +2 -2
  149. package/dist/index49.js +3 -3
  150. package/dist/index53.js +1 -1
  151. package/dist/index55.js +1 -1
  152. package/dist/index57.js +2 -2
  153. package/dist/index61.js +3 -3
  154. package/dist/index67.js +1 -1
  155. package/dist/index79.js +4 -4
  156. package/dist/index81.js +1 -1
  157. package/dist/index83.js +2 -2
  158. package/dist/index85.js +1 -1
  159. package/dist/index87.js +1 -1
  160. package/dist/index88.js +2 -2
  161. package/dist/index90.js +3 -3
  162. package/dist/index92.js +2 -2
  163. package/dist/index94.js +3 -3
  164. package/dist/index96.js +1 -1
  165. package/dist/utilities/functions/clampPrecision.d.ts +1 -0
  166. package/dist/utilities/functions/exceedsPrecision.d.ts +1 -0
  167. package/package.json +1 -1
  168. package/dist/index210.js +0 -15
  169. package/dist/index223.js +0 -6
  170. package/dist/index225.js +0 -4
  171. package/dist/index240.js +0 -4
  172. package/dist/index286.js +0 -6
  173. package/dist/index320.js +0 -720
  174. package/dist/index329.js +0 -10
  175. /package/dist/{index228.js → index235.js} +0 -0
package/dist/index230.js CHANGED
@@ -1,108 +1,6 @@
1
- import { defineComponent as y, ref as F, computed as H, watch as N, createElementBlock as L, openBlock as p, Fragment as S, renderList as V, createBlock as A, withModifiers as O, normalizeClass as P, withCtx as $, createTextVNode as z, toDisplayString as D } from "vue";
2
- import { hash as d } from "./index219.js";
3
- import { isNil as l } from "./index241.js";
4
- import E from "./index67.js";
5
- /* empty css */
6
- const K = /* @__PURE__ */ y({
7
- __name: "ChipsBox",
8
- props: {
9
- options: {}
10
- },
11
- emits: ["option:unselected"],
12
- setup(f, { expose: v, emit: h }) {
13
- const t = f, u = h, n = F(null), i = H(() => t.options.some((e) => !e.disabled)), a = (e = 1) => {
14
- const s = l(n.value) ? -1 : n.value;
15
- let o = (s + e) % t.options.length;
16
- for (; t.options[o].disabled && o !== s; )
17
- o = a(e + 1);
18
- return o;
19
- }, x = () => {
20
- if (!i.value) return;
21
- const e = a();
22
- n.value = e;
23
- }, c = (e = 1) => {
24
- const s = l(n.value) ? 0 : n.value;
25
- let o = (s - e + t.options.length) % t.options.length;
26
- for (; t.options[o].disabled && o !== s; )
27
- o = c(e + 1);
28
- return o;
29
- }, m = async () => {
30
- if (!i.value) return;
31
- const e = c();
32
- n.value = e;
33
- }, w = () => {
34
- if (!i.value) return;
35
- let e = 0;
36
- for (; t.options[e].disabled; )
37
- e++;
38
- n.value = e;
39
- }, b = () => {
40
- if (!i.value) return;
41
- let e = t.options.length - 1;
42
- for (; t.options[e].disabled && e !== 0; )
43
- e--;
44
- n.value = e;
45
- }, I = () => {
46
- if (!i.value) return;
47
- let e = 0;
48
- for (; !t.options[e].selected && t.options.length !== e; )
49
- e++;
50
- n.value = e;
51
- }, g = () => {
52
- if (!i.value) return;
53
- let e = t.options.length - 1;
54
- for (; t.options[e].selected && e !== 0; )
55
- e--;
56
- n.value = e;
57
- }, _ = (e) => {
58
- if (!i.value) return;
59
- const s = t.options.findIndex(
60
- (o) => o.valueHash === e
61
- );
62
- s >= 0 && (n.value = s);
63
- }, r = () => {
64
- n.value = null;
65
- }, k = () => {
66
- if (l(n.value)) return;
67
- const e = t.options[n.value];
68
- e.selected && u("option:unselected", e);
69
- }, C = () => l(n.value) ? void 0 : t.options[n.value];
70
- return N(
71
- () => t.options,
72
- (e, s) => {
73
- d(e) !== d(s) && r();
74
- },
75
- {
76
- flush: "post"
77
- }
78
- ), v({
79
- focusNext: x,
80
- focusPrevious: m,
81
- focusFirst: w,
82
- focusFirstSelected: I,
83
- focusLast: b,
84
- focusLastSelected: g,
85
- blur: r,
86
- confirmOption: k,
87
- focusByHash: _,
88
- getHighlighted: C
89
- }), (e, s) => (p(!0), L(S, null, V(e.options, (o, B) => (p(), A(E, {
90
- key: o.valueHash,
91
- class: P({
92
- "bb-chipsbox-item": !0,
93
- "bb-chipsbox-item--focused": B === n.value
94
- }),
95
- clearable: !0,
96
- text: o.text,
97
- "onClick:clear": O((M) => u("option:unselected", o), ["stop"])
98
- }, {
99
- default: $(() => [
100
- z(D(o.text), 1)
101
- ]),
102
- _: 2
103
- }, 1032, ["class", "text", "onClick:clear"]))), 128));
104
- }
105
- });
1
+ import { curry as e } from "./index292.js";
2
+ const t = (n, o, r) => n(r) ? o(r) : r, s = e(t);
106
3
  export {
107
- K as default
4
+ t as baseWhen,
5
+ s as when
108
6
  };
@@ -0,0 +1,36 @@
1
+ import { defineComponent as p, getCurrentInstance as a, resolveComponent as u, createBlock as f, openBlock as k, resolveDynamicComponent as g, unref as d, withCtx as b, renderSlot as x } from "vue";
2
+ import { _config as e } from "./index4.js";
3
+ import { useLogger as l } from "./index259.js";
4
+ const $ = /* @__PURE__ */ p({
5
+ __name: "RouterComponent",
6
+ setup(y) {
7
+ var o, i, r, s;
8
+ const m = !!((i = (o = a()) == null ? void 0 : o.proxy) != null && i.$inertia), c = !!((s = (r = a()) == null ? void 0 : r.proxy) != null && s.$nuxt);
9
+ let t;
10
+ if (m) {
11
+ if (t = u(e.inertiaLinkName), typeof t == "string") {
12
+ const { warn: n } = l();
13
+ n(
14
+ `Inertia link component "${e.inertiaLinkName}" could not be resolved. Ensure you app registers a link component with the name "${e.inertiaLinkName}" or set bitboss-ui config key "inertiaLinkName" to the correct value globally. Please visit ${e.documentationURL}/getting-started to resolve setup issues in bitboss-ui.`
15
+ );
16
+ }
17
+ } else if (c) {
18
+ if (t = u(e.nuxtLinkName), typeof t == "string") {
19
+ const { warn: n } = l();
20
+ n(
21
+ `Nuxt link component "${e.nuxtLinkName}" could not be resolved. Ensure you app registers a link component with the name "${e.nuxtLinkName}" or set bitboss-ui config key "nuxtLinkName" to the correct value globally. Please visit ${e.documentationURL}/getting-started to resolve setup issues in bitboss-ui.`
22
+ );
23
+ }
24
+ } else
25
+ t = "router-link";
26
+ return (n, L) => (k(), f(g(d(t)), null, {
27
+ default: b(() => [
28
+ x(n.$slots, "default")
29
+ ]),
30
+ _: 3
31
+ }));
32
+ }
33
+ });
34
+ export {
35
+ $ as default
36
+ };
package/dist/index232.js CHANGED
@@ -1,102 +1,4 @@
1
- import { defineComponent as F, ref as H, computed as L, watch as N, createElementBlock as d, openBlock as v, Fragment as S, renderList as A, withModifiers as O, normalizeClass as P, toDisplayString as V } from "vue";
2
- import { hash as f } from "./index219.js";
3
- import { isNil as i } from "./index241.js";
4
- const z = ["text", "onClick:clear"], j = /* @__PURE__ */ F({
5
- __name: "CommaBox",
6
- props: {
7
- options: {}
8
- },
9
- emits: ["option:unselected"],
10
- setup(m, { expose: h, emit: x }) {
11
- const t = m, a = x, n = H(null), l = L(() => t.options.some((e) => !e.disabled)), u = (e = 1) => {
12
- const s = i(n.value) ? -1 : n.value;
13
- let o = (s + e) % t.options.length;
14
- for (; t.options[o].disabled && o !== s; )
15
- o = u(e + 1);
16
- return o;
17
- }, b = () => {
18
- if (!l.value) return;
19
- const e = u();
20
- n.value = e;
21
- }, c = (e = 1) => {
22
- const s = i(n.value) ? 0 : n.value;
23
- let o = (s - e + t.options.length) % t.options.length;
24
- for (; t.options[o].disabled && o !== s; )
25
- o = c(e + 1);
26
- return o;
27
- }, w = async () => {
28
- if (!l.value) return;
29
- const e = c();
30
- n.value = e;
31
- }, I = () => {
32
- if (!l.value) return;
33
- let e = 0;
34
- for (; t.options[e].disabled; )
35
- e++;
36
- n.value = e;
37
- }, g = () => {
38
- if (!l.value) return;
39
- let e = t.options.length - 1;
40
- for (; t.options[e].disabled && e !== 0; )
41
- e--;
42
- n.value = e;
43
- }, k = () => {
44
- if (!l.value) return;
45
- let e = 0;
46
- for (; !t.options[e].selected && t.options.length !== e; )
47
- e++;
48
- n.value = e;
49
- }, _ = () => {
50
- if (!l.value) return;
51
- let e = t.options.length - 1;
52
- for (; t.options[e].selected && e !== 0; )
53
- e--;
54
- n.value = e;
55
- }, C = (e) => {
56
- if (!l.value) return;
57
- const s = t.options.findIndex(
58
- (o) => o.valueHash === e
59
- );
60
- s >= 0 && (n.value = s);
61
- }, r = () => {
62
- n.value = null;
63
- }, y = () => {
64
- if (i(n.value)) return;
65
- const e = t.options[n.value];
66
- e.selected && a("option:unselected", e);
67
- }, B = () => i(n.value) ? void 0 : t.options[n.value];
68
- return N(
69
- () => t.options,
70
- (e, s) => {
71
- f(e) !== f(s) && r();
72
- },
73
- {
74
- flush: "post"
75
- }
76
- ), h({
77
- focusNext: b,
78
- focusPrevious: w,
79
- focusFirst: I,
80
- focusFirstSelected: k,
81
- focusLast: g,
82
- focusLastSelected: _,
83
- blur: r,
84
- confirmOption: y,
85
- focusByHash: C,
86
- getHighlighted: B
87
- }), (e, s) => (v(!0), d(S, null, A(e.options, (o, p) => (v(), d("span", {
88
- key: o.valueHash,
89
- class: P({
90
- "bb-commabox-item": !0,
91
- "bb-commabox-item--focused": p === n.value,
92
- "bb-commabox-item--has-comma": p !== e.options.length - 1
93
- }),
94
- clearable: !0,
95
- text: o.text,
96
- "onClick:clear": O((D) => a("option:unselected", o), ["stop"])
97
- }, V(o.text), 43, z))), 128));
98
- }
99
- });
1
+ const n = (t) => t == null || Number.isNaN(t) || typeof t == "object" && Object.keys(t).length === 0 || typeof t == "string" && t.trim().length === 0 || t instanceof Map && [...t.keys()].length === 0 || t instanceof Set && [...t.keys()].length === 0;
100
2
  export {
101
- j as default
3
+ n as isEmpty
102
4
  };
@@ -0,0 +1,4 @@
1
+ const e = (t) => t[t.length - 1];
2
+ export {
3
+ e as last
4
+ };
package/dist/index234.js CHANGED
@@ -1,71 +1,20 @@
1
- import { defineComponent as k, ref as y, createElementBlock as C, openBlock as t, normalizeClass as N, renderSlot as n, createBlock as s, createCommentVNode as l, createVNode as a, createElementVNode as m, unref as i } from "vue";
2
- /* empty css */
3
- /* empty css */
4
- import u from "./index85.js";
5
- /* empty css */
6
- import h from "./index113.js";
7
- /* empty css */
8
- import v from "./index334.js";
9
- import B from "./index335.js";
10
- /* empty css */
11
- const E = { class: "bb-common-input-inner-container__prefix" }, I = { class: "bb-common-input-inner-container__suffix" }, R = /* @__PURE__ */ k({
12
- __name: "CommonInputInnerContainer",
13
- props: {
14
- "append:icon": {},
15
- clearable: { type: Boolean },
16
- "prepend:icon": {},
17
- preventFocus: { type: Boolean }
18
- },
19
- emits: ["click:clear"],
20
- setup(f, { emit: d }) {
21
- const p = f, b = d, o = y(), _ = (e) => {
22
- var c;
23
- if (!o.value || p.preventFocus) return;
24
- const r = e.target;
25
- r.tagName === "INPUT" || r.tagName === "TEXTAREA" || (c = o.value.querySelector("input,textarea")) == null || c.focus();
26
- }, $ = () => {
27
- var e;
28
- b("click:clear"), (e = o.value.querySelector("input,textarea")) == null || e.focus();
29
- };
30
- return (e, r) => (t(), C("span", {
31
- ref_key: "container",
32
- ref: o,
33
- class: N(["bb-common-input-inner-container", {
34
- "bb-common-input-inner-container--clearable": p.clearable
35
- }]),
36
- onClick: _
37
- }, [
38
- n(e.$slots, "prepend", {}, () => [
39
- m("span", E, [
40
- n(e.$slots, "prefix")
41
- ])
42
- ]),
43
- e.$props["prepend:icon"] ? (t(), s(i(u), {
44
- key: 0,
45
- class: "bb-common-input-inner-container__prepend-icon",
46
- type: e.$props["prepend:icon"]
47
- }, null, 8, ["type"])) : l("", !0),
48
- n(e.$slots, "default"),
49
- a(B, {
50
- "aria-hidden": !e.clearable,
51
- tabindex: e.clearable ? 0 : -1,
52
- onClick: $
53
- }, null, 8, ["aria-hidden", "tabindex"]),
54
- e.$props["append:icon"] ? (t(), s(i(u), {
55
- key: 1,
56
- class: "bb-common-input-inner-container__append-icon",
57
- type: e.$props["append:icon"]
58
- }, null, 8, ["type"])) : l("", !0),
59
- a(v),
60
- a(i(h)),
61
- n(e.$slots, "append", {}, () => [
62
- m("span", I, [
63
- n(e.$slots, "suffix")
64
- ])
65
- ])
66
- ], 2));
1
+ import { isNil as c } from "./index245.js";
2
+ const a = (t, r) => {
3
+ if (!Object.prototype.hasOwnProperty.call(t, r))
4
+ throw new Error(
5
+ `Object ${JSON.stringify(t, null, 2)} has no property named "${r.toString()}"`
6
+ );
7
+ }, l = (t) => typeof t == "string" ? t.toLocaleLowerCase() : JSON.stringify(t).toLowerCase(), y = (t, r, s) => {
8
+ const i = s.toLocaleLowerCase();
9
+ for (let e = 0; e < r.length; e++) {
10
+ const n = r[e];
11
+ a(t, n);
12
+ const o = t[n];
13
+ if (c(o)) continue;
14
+ if (l(o).includes(i)) return !0;
67
15
  }
68
- });
16
+ return !1;
17
+ };
69
18
  export {
70
- R as default
19
+ y as matchAnyKey
71
20
  };
package/dist/index236.js CHANGED
@@ -1,15 +1,8 @@
1
- import { createElementBlock as t, openBlock as n, renderSlot as e } from "vue";
2
- /* empty css */
3
- import r from "./index292.js";
4
- const s = {}, c = { class: "bb-common-input-outer-container" };
5
- function p(o, a) {
6
- return n(), t("span", c, [
7
- e(o.$slots, "prepend-outer"),
8
- e(o.$slots, "default"),
9
- e(o.$slots, "append-outer")
10
- ]);
11
- }
12
- const i = /* @__PURE__ */ r(s, [["render", p]]);
1
+ const o = (e, t = 50) => new Promise((r) => {
2
+ const n = setInterval(() => {
3
+ e() && (clearInterval(n), r());
4
+ }, t);
5
+ });
13
6
  export {
14
- i as default
7
+ o as waitFor
15
8
  };
package/dist/index237.js CHANGED
@@ -1,119 +1,108 @@
1
- import { defineComponent as V, mergeModels as A, useModel as x, ref as l, watch as S, onMounted as z, computed as E, createBlock as b, openBlock as v, resolveDynamicComponent as g, normalizeStyle as F, normalizeClass as N, unref as n, withCtx as w, renderSlot as y, createCommentVNode as q, mergeProps as h, createElementVNode as C } from "vue";
2
- import { useMinimalQueue as Q } from "./index329.js";
3
- import { wait as U } from "./index135.js";
4
- import { useFloating as j, arrow as G } from "./index330.js";
5
- import { flip as H, offset as I, shift as J, hide as K, autoUpdate as L } from "./index331.js";
6
- const O = { class: "bb-common-popover__bubble" }, ee = /* @__PURE__ */ V({
7
- __name: "CommonPopover",
8
- props: /* @__PURE__ */ A({
9
- arrowPadding: {},
10
- offset: {},
11
- block: { type: Boolean },
12
- padding: { default: 0 },
13
- placement: {},
14
- transitionDuration: { default: 250 },
15
- containerAttributes: {},
16
- dialog: { type: Boolean },
17
- renderContent: { type: Boolean, default: !0 },
18
- tag: { default: "span" },
19
- flip: { type: Boolean, default: !0 }
20
- }, {
21
- modelValue: { type: Boolean, default: !1 },
22
- modelModifiers: {}
23
- }),
24
- emits: ["update:modelValue"],
25
- setup(s) {
26
- const o = s, a = x(s, "modelValue"), i = l(), t = l(), p = l(), { floatingStyles: k, placement: _, middlewareData: r, update: M } = j(
27
- i,
28
- t,
1
+ import { defineComponent as y, ref as F, computed as H, watch as N, createElementBlock as L, openBlock as p, Fragment as S, renderList as V, createBlock as A, withModifiers as O, normalizeClass as P, withCtx as $, createTextVNode as z, toDisplayString as D } from "vue";
2
+ import { hash as d } from "./index215.js";
3
+ import { isNil as l } from "./index245.js";
4
+ import E from "./index67.js";
5
+ /* empty css */
6
+ const K = /* @__PURE__ */ y({
7
+ __name: "ChipsBox",
8
+ props: {
9
+ options: {}
10
+ },
11
+ emits: ["option:unselected"],
12
+ setup(f, { expose: v, emit: h }) {
13
+ const t = f, u = h, n = F(null), i = H(() => t.options.some((e) => !e.disabled)), a = (e = 1) => {
14
+ const s = l(n.value) ? -1 : n.value;
15
+ let o = (s + e) % t.options.length;
16
+ for (; t.options[o].disabled && o !== s; )
17
+ o = a(e + 1);
18
+ return o;
19
+ }, x = () => {
20
+ if (!i.value) return;
21
+ const e = a();
22
+ n.value = e;
23
+ }, c = (e = 1) => {
24
+ const s = l(n.value) ? 0 : n.value;
25
+ let o = (s - e + t.options.length) % t.options.length;
26
+ for (; t.options[o].disabled && o !== s; )
27
+ o = c(e + 1);
28
+ return o;
29
+ }, m = async () => {
30
+ if (!i.value) return;
31
+ const e = c();
32
+ n.value = e;
33
+ }, w = () => {
34
+ if (!i.value) return;
35
+ let e = 0;
36
+ for (; t.options[e].disabled; )
37
+ e++;
38
+ n.value = e;
39
+ }, b = () => {
40
+ if (!i.value) return;
41
+ let e = t.options.length - 1;
42
+ for (; t.options[e].disabled && e !== 0; )
43
+ e--;
44
+ n.value = e;
45
+ }, I = () => {
46
+ if (!i.value) return;
47
+ let e = 0;
48
+ for (; !t.options[e].selected && t.options.length !== e; )
49
+ e++;
50
+ n.value = e;
51
+ }, g = () => {
52
+ if (!i.value) return;
53
+ let e = t.options.length - 1;
54
+ for (; t.options[e].selected && e !== 0; )
55
+ e--;
56
+ n.value = e;
57
+ }, _ = (e) => {
58
+ if (!i.value) return;
59
+ const s = t.options.findIndex(
60
+ (o) => o.valueHash === e
61
+ );
62
+ s >= 0 && (n.value = s);
63
+ }, r = () => {
64
+ n.value = null;
65
+ }, k = () => {
66
+ if (l(n.value)) return;
67
+ const e = t.options[n.value];
68
+ e.selected && u("option:unselected", e);
69
+ }, C = () => l(n.value) ? void 0 : t.options[n.value];
70
+ return N(
71
+ () => t.options,
72
+ (e, s) => {
73
+ d(e) !== d(s) && r();
74
+ },
29
75
  {
30
- placement: o.placement,
31
- whileElementsMounted: L,
32
- middleware: [
33
- ...o.flip ? [H()] : [],
34
- I(o.offset),
35
- J({ padding: o.padding }),
36
- K(),
37
- G({
38
- element: p,
39
- padding: o.arrowPadding
40
- })
41
- ],
42
- strategy: "fixed"
76
+ flush: "post"
43
77
  }
44
- ), { queueFunction: B } = Q(), u = B(async (e) => {
45
- e ? (M(), P()) : (await U(o.transitionDuration), t.value && (o.dialog ? t.value.close() : t.value.hidePopover()));
46
- }), P = () => {
47
- if (!t.value) return;
48
- if (!o.dialog) return t.value.showPopover();
49
- t.value.showModal();
50
- };
51
- S(a, u, { flush: "post" }), z(() => {
52
- a.value && u(a.value);
53
- });
54
- const $ = E(() => {
55
- if (r.value.arrow) {
56
- const { x: e, y: d } = r.value.arrow;
57
- return {
58
- style: {
59
- left: `${e}px`,
60
- top: `${d}px`
61
- }
62
- };
63
- }
64
- }), D = () => {
65
- a.value = !1;
66
- };
67
- return (e, d) => (v(), b(g(e.dialog ? "div" : e.tag), {
68
- ref_key: "wrapper",
69
- ref: i,
70
- class: N(["bb-common-popover", {
71
- "bb-common-popover--open": a.value && !!t.value,
72
- "bb-common-popover--block": o.block,
73
- [`bb-common-popover--${n(_)}`]: !0
74
- }]),
75
- style: F({
76
- "--transition-duration": `${o.transitionDuration}ms`
77
- })
78
- }, {
79
- default: w(() => {
80
- var m, c, f;
81
- return [
82
- y(e.$slots, "activator"),
83
- e.renderContent ? (v(), b(g(e.dialog ? "dialog" : e.tag), h({
84
- key: 0,
85
- ref_key: "content",
86
- ref: t,
87
- class: ["bb-common-popover__bubble-container", {
88
- "bb-common-popover__bubble-container--open": a.value && !!t.value
89
- }],
90
- popover: "manual",
91
- style: {
92
- ...((m = e.containerAttributes) == null ? void 0 : m.style) ?? {},
93
- ...n(k),
94
- "--arrow-offset-x": Math.round(((f = (c = n(r)) == null ? void 0 : c.arrow) == null ? void 0 : f.x) ?? 0) + "px",
95
- "--page-padding": `${e.padding}px`
96
- },
97
- tabindex: a.value ? void 0 : -1
98
- }, e.containerAttributes, { onClose: n(D) }), {
99
- default: w(() => [
100
- C("span", h({
101
- ref_key: "bubblearrow",
102
- ref: p,
103
- class: "bb-common-popover__arrow"
104
- }, $.value), null, 16),
105
- C("span", O, [
106
- y(e.$slots, "default")
107
- ])
108
- ]),
109
- _: 3
110
- }, 16, ["class", "style", "tabindex", "onClose"])) : q("", !0)
111
- ];
78
+ ), v({
79
+ focusNext: x,
80
+ focusPrevious: m,
81
+ focusFirst: w,
82
+ focusFirstSelected: I,
83
+ focusLast: b,
84
+ focusLastSelected: g,
85
+ blur: r,
86
+ confirmOption: k,
87
+ focusByHash: _,
88
+ getHighlighted: C
89
+ }), (e, s) => (p(!0), L(S, null, V(e.options, (o, B) => (p(), A(E, {
90
+ key: o.valueHash,
91
+ class: P({
92
+ "bb-chipsbox-item": !0,
93
+ "bb-chipsbox-item--focused": B === n.value
112
94
  }),
113
- _: 3
114
- }, 8, ["class", "style"]));
95
+ clearable: !0,
96
+ text: o.text,
97
+ "onClick:clear": O((M) => u("option:unselected", o), ["stop"])
98
+ }, {
99
+ default: $(() => [
100
+ z(D(o.text), 1)
101
+ ]),
102
+ _: 2
103
+ }, 1032, ["class", "text", "onClick:clear"]))), 128));
115
104
  }
116
105
  });
117
106
  export {
118
- ee as default
107
+ K as default
119
108
  };