bitboss-ui 2.1.83 → 2.1.84

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 (182) hide show
  1. package/dist/index107.js +9 -9
  2. package/dist/index112.js +1 -1
  3. package/dist/index114.js +1 -1
  4. package/dist/index120.js +1 -1
  5. package/dist/index122.js +23 -23
  6. package/dist/index13.js +2 -2
  7. package/dist/index130.js +1 -1
  8. package/dist/index132.js +5 -5
  9. package/dist/index134.js +1 -1
  10. package/dist/index136.js +2 -2
  11. package/dist/index139.js +1 -1
  12. package/dist/index141.js +2 -2
  13. package/dist/index142.js +1 -1
  14. package/dist/index15.js +5 -5
  15. package/dist/index17.js +3 -3
  16. package/dist/index19.js +8 -8
  17. package/dist/index21.js +14 -14
  18. package/dist/index214.js +138 -2
  19. package/dist/index215.js +2 -138
  20. package/dist/index216.js +2 -2
  21. package/dist/index217.js +1 -1
  22. package/dist/index218.js +1 -1
  23. package/dist/index219.js +2 -13
  24. package/dist/index220.js +2 -13
  25. package/dist/index221.js +3 -13
  26. package/dist/index222.js +5 -4
  27. package/dist/index223.js +5 -20
  28. package/dist/index224.js +5 -201
  29. package/dist/index225.js +7 -0
  30. package/dist/index226.js +5 -135
  31. package/dist/index227.js +7 -0
  32. package/dist/index228.js +2 -3
  33. package/dist/index229.js +3 -6
  34. package/dist/index23.js +11 -11
  35. package/dist/index230.js +13 -16
  36. package/dist/index231.js +20 -2
  37. package/dist/index232.js +135 -11
  38. package/dist/index234.js +34 -9
  39. package/dist/index235.js +8 -8
  40. package/dist/index236.js +13 -23
  41. package/dist/index237.js +13 -4
  42. package/dist/index238.js +31 -21
  43. package/dist/index239.js +28 -188
  44. package/dist/index241.js +7 -4
  45. package/dist/index242.js +2 -67
  46. package/dist/index243.js +86 -5
  47. package/dist/index245.js +29 -5
  48. package/dist/index246.js +17 -5
  49. package/dist/index247.js +51 -5
  50. package/dist/index248.js +15 -5
  51. package/dist/index249.js +3 -2
  52. package/dist/index25.js +3 -3
  53. package/dist/index250.js +12 -3
  54. package/dist/index251.js +16 -34
  55. package/dist/index252.js +5 -5
  56. package/dist/index253.js +2 -3
  57. package/dist/index254.js +5 -8
  58. package/dist/index255.js +8 -10
  59. package/dist/index256.js +268 -3
  60. package/dist/index257.js +52 -3
  61. package/dist/index258.js +52 -33
  62. package/dist/index259.js +30 -26
  63. package/dist/index260.js +62 -0
  64. package/dist/index261.js +5 -7
  65. package/dist/index262.js +188 -2
  66. package/dist/index263.js +3 -3
  67. package/dist/index264.js +65 -7
  68. package/dist/index265.js +3 -29
  69. package/dist/index266.js +4 -16
  70. package/dist/index267.js +9 -17
  71. package/dist/index268.js +40 -50
  72. package/dist/index269.js +4 -12
  73. package/dist/index27.js +1 -1
  74. package/dist/index270.js +200 -40
  75. package/dist/index272.js +3 -2
  76. package/dist/index273.js +10 -5
  77. package/dist/index274.js +101 -263
  78. package/dist/index276.js +96 -48
  79. package/dist/index278.js +4 -60
  80. package/dist/index279.js +22 -85
  81. package/dist/index280.js +10 -0
  82. package/dist/index281.js +8 -14
  83. package/dist/index282.js +23 -8
  84. package/dist/index286.js +9 -2
  85. package/dist/index287.js +6 -18
  86. package/dist/index288.js +16 -12
  87. package/dist/index289.js +17 -105
  88. package/dist/index29.js +3 -3
  89. package/dist/index290.js +14 -0
  90. package/dist/index291.js +212 -83
  91. package/dist/index292.js +12 -0
  92. package/dist/index293.js +3 -229
  93. package/dist/index295.js +5 -0
  94. package/dist/index296.js +280 -3
  95. package/dist/index297.js +2 -2
  96. package/dist/index298.js +125 -4
  97. package/dist/index299.js +2 -3
  98. package/dist/index300.js +14 -3
  99. package/dist/index301.js +2 -2
  100. package/dist/index302.js +16 -3
  101. package/dist/index303.js +2 -719
  102. package/dist/index304.js +16 -366
  103. package/dist/index305.js +2 -57
  104. package/dist/index306.js +19 -5
  105. package/dist/index307.js +2 -280
  106. package/dist/index308.js +3 -2
  107. package/dist/index309.js +7 -125
  108. package/dist/index31.js +2 -2
  109. package/dist/index310.js +2 -2
  110. package/dist/index311.js +2 -15
  111. package/dist/index312.js +27 -2
  112. package/dist/index313.js +2 -16
  113. package/dist/index314.js +2 -2
  114. package/dist/index315.js +2 -16
  115. package/dist/index316.js +2 -2
  116. package/dist/index317.js +2 -19
  117. package/dist/index318.js +28 -2
  118. package/dist/index319.js +2 -5
  119. package/dist/index320.js +1 -1
  120. package/dist/index321.js +1 -1
  121. package/dist/index322.js +4 -28
  122. package/dist/index323.js +5 -27
  123. package/dist/index324.js +3 -2
  124. package/dist/index325.js +4 -2
  125. package/dist/index326.js +5 -2
  126. package/dist/index327.js +6 -2
  127. package/dist/index328.js +3 -2
  128. package/dist/index329.js +3 -2
  129. package/dist/index33.js +8 -8
  130. package/dist/index330.js +718 -57
  131. package/dist/index331.js +365 -57
  132. package/dist/index332.js +57 -3
  133. package/dist/index333.js +2 -3
  134. package/dist/index334.js +35 -2
  135. package/dist/index335.js +6 -35
  136. package/dist/index336.js +129 -6
  137. package/dist/index337.js +382 -113
  138. package/dist/index338.js +6 -397
  139. package/dist/index339.js +18 -5
  140. package/dist/index340.js +8 -7
  141. package/dist/index341.js +14 -5
  142. package/dist/index342.js +5 -8
  143. package/dist/index343.js +6 -227
  144. package/dist/index344.js +57 -92
  145. package/dist/index345.js +57 -133
  146. package/dist/index346.js +228 -5
  147. package/dist/index347.js +133 -6
  148. package/dist/index348.js +21 -18
  149. package/dist/index35.js +4 -4
  150. package/dist/index350.js +7 -14
  151. package/dist/index351.js +5 -6
  152. package/dist/index352.js +8 -22
  153. package/dist/index353.js +95 -0
  154. package/dist/index37.js +18 -18
  155. package/dist/index39.js +4 -4
  156. package/dist/index41.js +2 -2
  157. package/dist/index43.js +8 -8
  158. package/dist/index45.js +6 -6
  159. package/dist/index49.js +2 -2
  160. package/dist/index53.js +1 -1
  161. package/dist/index55.js +1 -1
  162. package/dist/index57.js +2 -2
  163. package/dist/index61.js +5 -5
  164. package/dist/index67.js +1 -1
  165. package/dist/index80.js +6 -6
  166. package/dist/index82.js +1 -1
  167. package/dist/index84.js +2 -2
  168. package/dist/index86.js +3 -3
  169. package/dist/index88.js +1 -1
  170. package/dist/index91.js +3 -3
  171. package/dist/index93.js +2 -2
  172. package/dist/index95.js +5 -5
  173. package/dist/index97.js +1 -1
  174. package/package.json +1 -1
  175. package/dist/index233.js +0 -10
  176. package/dist/index240.js +0 -5
  177. package/dist/index244.js +0 -7
  178. package/dist/index271.js +0 -7
  179. package/dist/index275.js +0 -54
  180. package/dist/index277.js +0 -34
  181. package/dist/index294.js +0 -9
  182. package/dist/index349.js +0 -11
package/dist/index232.js CHANGED
@@ -1,13 +1,137 @@
1
- function c(n, r, e) {
2
- const i = typeof r == "string" ? r.split(".") : r;
3
- let t = n;
4
- for (const o of i)
5
- if (t && typeof t == "object" && o in t)
6
- t = t[o];
7
- else
8
- return e;
9
- return t === void 0 ? e : t;
10
- }
1
+ import { defineComponent as A, mergeModels as L, useModel as T, ref as c, computed as a, watch as F, onMounted as S, createBlock as N, openBlock as w, resolveDynamicComponent as U, mergeProps as g, unref as y, withModifiers as h, withCtx as j, createElementVNode as q, createElementBlock as I, createCommentVNode as R, renderSlot as X, nextTick as z } from "vue";
2
+ import { useCancelableFunction as G } from "./index334.js";
3
+ import { useUntil as H } from "./index237.js";
4
+ import { extractDomContainer as x } from "./index278.js";
5
+ import { waitFor as J } from "./index335.js";
6
+ import { arrow as K, useFloating as O } from "./index336.js";
7
+ import { flip as Q, offset as W, shift as Y, hide as Z, autoUpdate as ee } from "./index337.js";
8
+ const oe = {
9
+ key: 0,
10
+ class: "bb-common-popover__bubble"
11
+ }, ue = /* @__PURE__ */ A({
12
+ __name: "CommonPopover",
13
+ props: /* @__PURE__ */ L({
14
+ arrowPadding: {},
15
+ eager: { type: Boolean },
16
+ offset: {},
17
+ padding: { default: 0 },
18
+ placement: {},
19
+ transitionDuration: { default: 250 },
20
+ anchor: {},
21
+ boundary: {},
22
+ dialog: { type: Boolean },
23
+ hideArrow: { type: Boolean },
24
+ tag: { default: "span" },
25
+ flip: { type: Boolean, default: !0 }
26
+ }, {
27
+ modelValue: { type: Boolean, default: !1 },
28
+ modelModifiers: {}
29
+ }),
30
+ emits: ["update:modelValue"],
31
+ setup(m) {
32
+ const o = m, r = T(m, "modelValue"), s = c(r.value), C = a(() => o.dialog ? "dialog" : "span"), t = c(), f = c(), _ = a(() => {
33
+ const e = o.anchor;
34
+ return e && typeof e == "object" && "getBoundingClientRect" in e && !(e instanceof Element) ? e : x(e);
35
+ }), B = H(r, { initialValue: o.eager }), P = a(() => {
36
+ if (o.boundary)
37
+ return typeof o.boundary == "string" ? document.querySelector(o.boundary) ?? void 0 : x(o.boundary) ?? void 0;
38
+ }), k = a(() => {
39
+ const e = P.value;
40
+ return [
41
+ ...o.flip ? [Q(e ? { boundary: e } : void 0)] : [],
42
+ W(o.offset),
43
+ Y({ padding: o.padding, ...e ? { boundary: e } : {} }),
44
+ Z(),
45
+ ...o.hideArrow ? [] : [
46
+ K({
47
+ element: f,
48
+ padding: o.arrowPadding
49
+ })
50
+ ]
51
+ ];
52
+ }), { floatingStyles: E, placement: M, middlewareData: u, update: v } = O(
53
+ _,
54
+ t,
55
+ {
56
+ placement: o.placement,
57
+ whileElementsMounted: ee,
58
+ middleware: k,
59
+ strategy: "fixed"
60
+ }
61
+ ), { execute: b } = G(
62
+ ({ signal: e }, n) => new Promise((l) => {
63
+ let i;
64
+ const p = () => {
65
+ i && clearTimeout(i);
66
+ };
67
+ e.addEventListener("abort", p), n ? ($(), v(), J(() => !!t.value).then(() => {
68
+ s.value = !0, e.removeEventListener("abort", p), l(void 0);
69
+ })) : (s.value = !1, i = setTimeout(() => {
70
+ z(() => {
71
+ t.value && (o.dialog ? t.value.close() : t.value.hidePopover()), e.removeEventListener("abort", p), v(), l(void 0);
72
+ });
73
+ }, o.transitionDuration));
74
+ })
75
+ ), $ = () => {
76
+ if (!t.value) return;
77
+ if (!o.dialog) return t.value.showPopover();
78
+ t.value.showModal();
79
+ };
80
+ F(r, b), S(() => {
81
+ r.value && b(r.value);
82
+ });
83
+ const D = a(() => {
84
+ const e = r.value ? void 0 : -1, n = Math.round(u.value.arrow?.x ?? 0), l = o.dialog ? void 0 : "manual";
85
+ return {
86
+ style: {
87
+ ...E.value,
88
+ "--transition-duration": `${o.transitionDuration}ms`,
89
+ "--page-padding": `${o.padding}px`,
90
+ "--arrow-offset-x": `${n}px`
91
+ },
92
+ popover: l,
93
+ tabindex: e
94
+ };
95
+ }), V = a(() => {
96
+ if (u.value.arrow) {
97
+ const { x: e, y: n } = u.value.arrow;
98
+ return {
99
+ style: {
100
+ left: `${e}px`,
101
+ top: `${n}px`
102
+ }
103
+ };
104
+ }
105
+ }), d = () => {
106
+ r.value = !1;
107
+ };
108
+ return (e, n) => (w(), N(U(C.value), g({
109
+ ref_key: "wrapper",
110
+ ref: t,
111
+ class: ["bb-common-popover", {
112
+ "bb-common-popover--open": s.value,
113
+ "bb-common-popover--no-arrow": e.hideArrow,
114
+ [`bb-common-popover--${y(M)}`]: !0
115
+ }]
116
+ }, D.value, {
117
+ onClick: h(d, ["self", "stop"]),
118
+ onContextmenu: h(d, ["self", "stop", "prevent"]),
119
+ onClose: d
120
+ }), {
121
+ default: j(() => [
122
+ q("span", g({
123
+ ref_key: "bubblearrow",
124
+ ref: f,
125
+ class: "bb-common-popover__arrow"
126
+ }, V.value), null, 16),
127
+ y(B) ? (w(), I("span", oe, [
128
+ X(e.$slots, "default")
129
+ ])) : R("", !0)
130
+ ]),
131
+ _: 3
132
+ }, 16, ["class"]));
133
+ }
134
+ });
11
135
  export {
12
- c as get
136
+ ue as default
13
137
  };
package/dist/index234.js CHANGED
@@ -1,11 +1,36 @@
1
- import { getCurrentInstance as e } from "vue";
2
- const s = () => {
3
- const t = e(), n = !!t?.proxy?.$inertia, r = !!t?.proxy?.$nuxt;
4
- return {
5
- isInertia: n,
6
- isNuxt: r
7
- };
8
- };
1
+ import { defineComponent as a, resolveComponent as o, createBlock as u, openBlock as l, resolveDynamicComponent as m, unref as c, withCtx as p, renderSlot as f } from "vue";
2
+ import { _config as e } from "./index4.js";
3
+ import { useLogger as i } from "./index255.js";
4
+ import { useFrameworkDetection as k } from "./index235.js";
5
+ const y = /* @__PURE__ */ a({
6
+ __name: "RouterComponent",
7
+ setup(g) {
8
+ const { isInertia: r, isNuxt: s } = k();
9
+ let t;
10
+ if (r) {
11
+ if (t = o(e.inertiaLinkName), typeof t == "string") {
12
+ const { warn: n } = i();
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 (s) {
18
+ if (t = o(e.nuxtLinkName), typeof t == "string") {
19
+ const { warn: n } = i();
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, d) => (l(), u(m(c(t)), null, {
27
+ default: p(() => [
28
+ f(n.$slots, "default")
29
+ ]),
30
+ _: 3
31
+ }));
32
+ }
33
+ });
9
34
  export {
10
- s as useFrameworkDetection
35
+ y as default
11
36
  };
package/dist/index235.js CHANGED
@@ -1,11 +1,11 @@
1
- const o = (n, t) => {
2
- for (let e = n.length - 1; e >= 0; e--) {
3
- const i = n[e];
4
- if (t(i, e, n))
5
- return e;
6
- }
7
- return -1;
1
+ import { getCurrentInstance as e } from "vue";
2
+ const s = () => {
3
+ const t = e(), n = !!t?.proxy?.$inertia, r = !!t?.proxy?.$nuxt;
4
+ return {
5
+ isInertia: n,
6
+ isNuxt: r
7
+ };
8
8
  };
9
9
  export {
10
- o as findRightIndex
10
+ s as useFrameworkDetection
11
11
  };
package/dist/index236.js CHANGED
@@ -1,25 +1,15 @@
1
- const e = {
2
- inert: ":not([inert]):not([inert] *)",
3
- negTabIndex: ':not([tabindex^="-"])',
4
- disabled: ":not(:disabled)"
5
- }, n = [
6
- `a[href]${e.inert}${e.negTabIndex}`,
7
- `area[href]${e.inert}${e.negTabIndex}`,
8
- `input:not([type="hidden"]):not([type="radio"])${e.inert}${e.negTabIndex}${e.disabled}`,
9
- `input[type="radio"]${e.inert}${e.negTabIndex}${e.disabled}`,
10
- `select${e.inert}${e.negTabIndex}${e.disabled}`,
11
- `textarea${e.inert}${e.negTabIndex}${e.disabled}`,
12
- `button${e.inert}${e.negTabIndex}${e.disabled}`,
13
- `details${e.inert} > summary:first-of-type${e.negTabIndex}`,
14
- // Discard until Firefox supports `:has()`
15
- // See: https://github.com/KittyGiraudel/focusable-selectors/issues/12
16
- // `details:not(:has(> summary))${not.inert}${not.negTabIndex}`,
17
- `iframe${e.inert}${e.negTabIndex}`,
18
- `audio[controls]${e.inert}${e.negTabIndex}`,
19
- `video[controls]${e.inert}${e.negTabIndex}`,
20
- `[contenteditable]${e.inert}${e.negTabIndex}`,
21
- `[tabindex]${e.inert}${e.negTabIndex}`
22
- ];
1
+ const c = (t, r) => {
2
+ if (typeof t == "string") {
3
+ const e = /^(\d+)([a-zA-Z%]+)?$/, n = t.match(e);
4
+ if (n) {
5
+ const [, o, a] = n;
6
+ return a ? t : o + "px";
7
+ } else if (t in r)
8
+ return r[t] + "px";
9
+ throw new Error(`Invalid size: ${t}`);
10
+ }
11
+ return t + "px";
12
+ };
23
13
  export {
24
- n as default
14
+ c as parseSize
25
15
  };
package/dist/index237.js CHANGED
@@ -1,6 +1,15 @@
1
- function e(n) {
2
- return n ? n instanceof HTMLElement ? n : typeof n == "object" && "$el" in n && n.$el instanceof HTMLElement ? n.$el : typeof n == "object" && "el" in n && n.el instanceof HTMLElement ? n.el : null : null;
3
- }
1
+ import { ref as c, watch as f, toValue as u } from "vue";
2
+ const p = (e, { initialValue: r = !1, nextValue: o = !0 } = {}) => {
3
+ const t = c(r);
4
+ if (r) return t;
5
+ const n = f(
6
+ () => u(e),
7
+ (s) => {
8
+ s && (t.value = o, n());
9
+ }
10
+ );
11
+ return t;
12
+ };
4
13
  export {
5
- e as extractDomContainer
14
+ p as useUntil
6
15
  };
package/dist/index238.js CHANGED
@@ -1,25 +1,35 @@
1
- const i = (t) => {
2
- const n = t.toString().replace(/\.0+$/, "").replace(/\.$/, "");
3
- return parseFloat(n) || 0;
1
+ import { createElementBlock as e, openBlock as t, createElementVNode as o } from "vue";
2
+ /* empty css */
3
+ import n from "./index213.js";
4
+ const l = {}, s = {
5
+ class: "bb-error-icon",
6
+ fill: "none",
7
+ viewBox: "0 0 20 20",
8
+ xmlns: "http://www.w3.org/2000/svg"
4
9
  };
5
- function s(t) {
6
- if (typeof t == "number")
7
- return {
8
- value: i(t),
9
- unit: "px"
10
- };
11
- if (typeof t == "string") {
12
- const r = /^(-?\d*\.?\d+)([a-zA-Z%]*)?$/, e = t.match(r);
13
- if (e) {
14
- const [, n, o = "px"] = e, a = parseFloat(n);
15
- return {
16
- value: i(a),
17
- unit: o
18
- };
19
- }
20
- }
21
- throw new Error(`Invalid width: ${t}`);
10
+ function i(c, r) {
11
+ return t(), e("svg", s, r[0] || (r[0] = [
12
+ o("path", {
13
+ d: "M9.99422 18.3333C14.5966 18.3333 18.3276 14.6024 18.3276 9.99999C18.3276 5.39762 14.5966 1.66666 9.99422 1.66666C5.39185 1.66666 1.66089 5.39762 1.66089 9.99999C1.66089 14.6024 5.39185 18.3333 9.99422 18.3333Z",
14
+ fill: "currentColor"
15
+ }, null, -1),
16
+ o("path", {
17
+ d: "M9.99414 6.66666V9.99999",
18
+ stroke: "white",
19
+ "stroke-linecap": "round",
20
+ "stroke-linejoin": "round",
21
+ "stroke-width": "2"
22
+ }, null, -1),
23
+ o("path", {
24
+ d: "M9.99414 13.3333H10.0025",
25
+ stroke: "white",
26
+ "stroke-linecap": "round",
27
+ "stroke-linejoin": "round",
28
+ "stroke-width": "2"
29
+ }, null, -1)
30
+ ]));
22
31
  }
32
+ const a = /* @__PURE__ */ n(l, [["render", i]]);
23
33
  export {
24
- s as parseWidthString
34
+ a as default
25
35
  };
package/dist/index239.js CHANGED
@@ -1,190 +1,30 @@
1
- var C = Object.defineProperty, x = (a, e, t) => e in a ? C(a, e, { enumerable: !0, configurable: !0, writable: !0, value: t }) : a[e] = t, y = (a, e, t) => x(a, typeof e != "symbol" ? e + "" : e, t);
2
- const M = {
3
- "#": { pattern: /[0-9]/ },
4
- "@": { pattern: /[a-zA-Z]/ },
5
- "*": { pattern: /[a-zA-Z0-9]/ }
6
- }, w = (a, e, t) => a.replaceAll(e, "").replace(t, ".").replace("..", ".").replace(/[^.\d]/g, ""), N = (a, e, t) => {
7
- var s;
8
- return new Intl.NumberFormat(((s = t.number) == null ? void 0 : s.locale) ?? "en", {
9
- minimumFractionDigits: a,
10
- maximumFractionDigits: e,
11
- roundingMode: "trunc"
12
- });
13
- }, P = (a, e = !0, t) => {
14
- var s, r, n, l;
15
- const u = ((s = t.number) == null ? void 0 : s.unsigned) !== !0 && a.startsWith("-") ? "-" : "", p = ((r = t.number) == null ? void 0 : r.fraction) ?? 0;
16
- let o = N(0, p, t);
17
- const k = o.formatToParts(1000.12), m = ((n = k.find((i) => i.type === "group")) == null ? void 0 : n.value) ?? " ", f = ((l = k.find((i) => i.type === "decimal")) == null ? void 0 : l.value) ?? ".", c = w(a, m, f);
18
- if (Number.isNaN(parseFloat(c))) return u;
19
- const v = c.split(".");
20
- if (v[1] != null && v[1].length >= 1) {
21
- const i = v[1].length <= p ? v[1].length : p;
22
- o = N(i, p, t);
23
- }
24
- let d = o.format(parseFloat(c));
25
- return e ? p > 0 && c.endsWith(".") && !c.slice(0, -1).includes(".") && (d += f) : d = w(d, m, f), u + d;
26
- }, I = (a) => JSON.parse(a.replaceAll("'", '"')), T = (a, e = {}) => {
27
- const t = { ...e };
28
- a.dataset.maska != null && a.dataset.maska !== "" && (t.mask = F(a.dataset.maska)), a.dataset.maskaEager != null && (t.eager = E(a.dataset.maskaEager)), a.dataset.maskaReversed != null && (t.reversed = E(a.dataset.maskaReversed)), a.dataset.maskaTokensReplace != null && (t.tokensReplace = E(a.dataset.maskaTokensReplace)), a.dataset.maskaTokens != null && (t.tokens = O(a.dataset.maskaTokens));
29
- const s = {};
30
- return a.dataset.maskaNumberLocale != null && (s.locale = a.dataset.maskaNumberLocale), a.dataset.maskaNumberFraction != null && (s.fraction = parseInt(a.dataset.maskaNumberFraction)), a.dataset.maskaNumberUnsigned != null && (s.unsigned = E(a.dataset.maskaNumberUnsigned)), (a.dataset.maskaNumber != null || Object.values(s).length > 0) && (t.number = s), t;
31
- }, E = (a) => a !== "" ? !!JSON.parse(a) : !0, F = (a) => a.startsWith("[") && a.endsWith("]") ? I(a) : a, O = (a) => {
32
- if (a.startsWith("{") && a.endsWith("}"))
33
- return I(a);
34
- const e = {};
35
- return a.split("|").forEach((t) => {
36
- const s = t.split(":");
37
- e[s[0]] = {
38
- pattern: S() ? new RegExp(s[1], "u") : new RegExp(s[1]),
39
- optional: s[2] === "optional",
40
- multiple: s[2] === "multiple",
41
- repeated: s[2] === "repeated"
42
- };
43
- }), e;
44
- }, S = () => {
45
- try {
46
- return new RegExp("\\p{L}", "u"), !0;
47
- } catch {
48
- return !1;
49
- }
50
- };
51
- class W {
52
- constructor(e = {}) {
53
- y(this, "opts", {}), y(this, "memo", /* @__PURE__ */ new Map());
54
- const t = { ...e };
55
- if (t.tokens != null) {
56
- t.tokens = t.tokensReplace ? { ...t.tokens } : { ...M, ...t.tokens };
57
- for (const s of Object.values(t.tokens))
58
- typeof s.pattern == "string" && (s.pattern = S() ? new RegExp(s.pattern, "u") : new RegExp(s.pattern));
59
- } else
60
- t.tokens = M;
61
- Array.isArray(t.mask) && (t.mask.length > 1 ? t.mask = [...t.mask].sort((s, r) => s.length - r.length) : t.mask = t.mask[0] ?? ""), t.mask === "" && (t.mask = null), this.opts = t;
62
- }
63
- masked(e) {
64
- return this.process(String(e), this.findMask(String(e)));
65
- }
66
- unmasked(e) {
67
- return this.process(String(e), this.findMask(String(e)), !1);
68
- }
69
- isEager() {
70
- return this.opts.eager === !0;
71
- }
72
- isReversed() {
73
- return this.opts.reversed === !0;
74
- }
75
- completed(e) {
76
- const t = this.findMask(String(e));
77
- if (this.opts.mask == null || t == null) return !1;
78
- const s = this.process(String(e), t).length;
79
- return typeof this.opts.mask == "string" ? s >= this.opts.mask.length : s >= t.length;
80
- }
81
- findMask(e) {
82
- const t = this.opts.mask;
83
- if (t == null)
84
- return null;
85
- if (typeof t == "string")
86
- return t;
87
- if (typeof t == "function")
88
- return t(e);
89
- const s = this.process(e, t.slice(-1).pop() ?? "", !1);
90
- return t.find((r) => this.process(e, r, !1).length >= s.length) ?? "";
91
- }
92
- escapeMask(e) {
93
- const t = [], s = [];
94
- return e.split("").forEach((r, n) => {
95
- r === "!" && e[n - 1] !== "!" ? s.push(n - s.length) : t.push(r);
96
- }), { mask: t.join(""), escaped: s };
97
- }
98
- process(e, t, s = !0) {
99
- if (this.opts.number != null) return P(e, s, this.opts);
100
- if (t == null) return e;
101
- const r = `v=${e},mr=${t},m=${s ? 1 : 0}`;
102
- if (this.memo.has(r)) return this.memo.get(r);
103
- const { mask: n, escaped: l } = this.escapeMask(t), u = [], p = this.opts.tokens != null ? this.opts.tokens : {}, o = this.isReversed() ? -1 : 1, k = this.isReversed() ? "unshift" : "push", m = this.isReversed() ? 0 : n.length - 1, f = this.isReversed() ? () => i > -1 && h > -1 : () => i < n.length && h < e.length, c = (b) => !this.isReversed() && b <= m || this.isReversed() && b >= m;
104
- let v, d = -1, i = this.isReversed() ? n.length - 1 : 0, h = this.isReversed() ? e.length - 1 : 0, R = !1;
105
- for (; f(); ) {
106
- const b = n.charAt(i), g = p[b], A = g?.transform != null ? g.transform(e.charAt(h)) : e.charAt(h);
107
- if (!l.includes(i) && g != null ? (A.match(g.pattern) != null ? (u[k](A), g.repeated ? (d === -1 ? d = i : i === m && i !== d && (i = d - o), m === d && (i -= o)) : g.multiple && (R = !0, i -= o), i += o) : g.multiple ? R && (i += o, h -= o, R = !1) : A === v ? v = void 0 : g.optional && (i += o, h -= o), h += o) : (s && !this.isEager() && u[k](b), A === b && !this.isEager() ? h += o : v = b, this.isEager() || (i += o)), this.isEager())
108
- for (; c(i) && (p[n.charAt(i)] == null || l.includes(i)); ) {
109
- if (s) {
110
- if (u[k](n.charAt(i)), e.charAt(h) === n.charAt(i)) {
111
- i += o, h += o;
112
- continue;
113
- }
114
- } else n.charAt(i) === e.charAt(h) && (h += o);
115
- i += o;
116
- }
117
- }
118
- return this.memo.set(r, u.join("")), this.memo.get(r);
119
- }
120
- }
121
- class V {
122
- constructor(e, t = {}) {
123
- y(this, "items", /* @__PURE__ */ new Map()), y(this, "eventAbortController"), y(this, "onInput", (s) => {
124
- if (s instanceof CustomEvent && s.type === "input" && !s.isTrusted && !s.bubbles)
125
- return;
126
- const r = s.target, n = this.items.get(r);
127
- if (n === void 0) return;
128
- const l = "inputType" in s && s.inputType.startsWith("delete"), u = n.isEager(), p = l && u && n.unmasked(r.value) === "" ? "" : r.value;
129
- this.fixCursor(r, l, () => this.setValue(r, p));
130
- }), this.options = t, this.eventAbortController = new AbortController(), this.init(this.getInputs(e));
131
- }
132
- update(e = {}) {
133
- this.options = { ...e }, this.init(Array.from(this.items.keys()));
134
- }
135
- updateValue(e) {
136
- var t;
137
- e.value !== "" && e.value !== ((t = this.processInput(e)) == null ? void 0 : t.masked) && this.setValue(e, e.value);
138
- }
139
- destroy() {
140
- this.eventAbortController.abort(), this.items.clear();
141
- }
142
- init(e) {
143
- const t = this.getOptions(this.options);
144
- for (const s of e) {
145
- if (!this.items.has(s)) {
146
- const { signal: n } = this.eventAbortController;
147
- s.addEventListener("input", this.onInput, { capture: !0, signal: n });
148
- }
149
- const r = new W(T(s, t));
150
- this.items.set(s, r), queueMicrotask(() => this.updateValue(s)), s.selectionStart === null && r.isEager() && console.warn("Maska: input of `%s` type is not supported", s.type);
151
- }
152
- }
153
- getInputs(e) {
154
- return typeof e == "string" ? Array.from(document.querySelectorAll(e)) : "length" in e ? Array.from(e) : [e];
155
- }
156
- getOptions(e) {
157
- const { onMaska: t, preProcess: s, postProcess: r, ...n } = e;
158
- return n;
159
- }
160
- fixCursor(e, t, s) {
161
- var r, n;
162
- const l = e.selectionStart, u = e.value;
163
- if (s(), l === null || l === u.length && !t) return;
164
- const p = e.value, o = u.slice(0, l), k = p.slice(0, l), m = (r = this.processInput(e, o)) == null ? void 0 : r.unmasked, f = (n = this.processInput(e, k)) == null ? void 0 : n.unmasked;
165
- if (m === void 0 || f === void 0) return;
166
- let c = l;
167
- o !== k && (c += t ? p.length - u.length : m.length - f.length), e.setSelectionRange(c, c);
168
- }
169
- setValue(e, t) {
170
- const s = this.processInput(e, t);
171
- s !== void 0 && (e.value = s.masked, this.options.onMaska != null && (Array.isArray(this.options.onMaska) ? this.options.onMaska.forEach((r) => r(s)) : this.options.onMaska(s)), e.dispatchEvent(new CustomEvent("maska", { detail: s })), e.dispatchEvent(new CustomEvent("input", { detail: s.masked })));
172
- }
173
- processInput(e, t) {
174
- const s = this.items.get(e);
175
- if (s === void 0) return;
176
- let r = t ?? e.value;
177
- this.options.preProcess != null && (r = this.options.preProcess(r));
178
- let n = s.masked(r);
179
- return this.options.postProcess != null && (n = this.options.postProcess(n)), {
180
- masked: n,
181
- unmasked: s.unmasked(r),
182
- completed: s.completed(r)
183
- };
184
- }
185
- }
1
+ import { defineComponent as l, createElementBlock as n, openBlock as r, unref as a, createElementVNode as t } from "vue";
2
+ import { useLocale as s } from "./index230.js";
3
+ const c = ["aria-label"], b = /* @__PURE__ */ l({
4
+ __name: "ClearableButton",
5
+ setup(u) {
6
+ const { t: o } = s();
7
+ return (i, e) => (r(), n("button", {
8
+ "aria-label": a(o)("common.clearLabel").value,
9
+ class: "bb-clearable-button",
10
+ type: "button"
11
+ }, e[0] || (e[0] = [
12
+ t("svg", {
13
+ viewBox: "0 0 24 24",
14
+ xmlns: "http://www.w3.org/2000/svg"
15
+ }, [
16
+ t("path", {
17
+ d: "M12 12l7 7M12 12l-7 -7M12 12l-7 7M12 12l7 -7",
18
+ fill: "none",
19
+ stroke: "currentColor",
20
+ "stroke-linecap": "round",
21
+ "stroke-linejoin": "round",
22
+ "stroke-width": "2"
23
+ })
24
+ ], -1)
25
+ ]), 8, c));
26
+ }
27
+ });
186
28
  export {
187
- W as Mask,
188
- V as MaskInput,
189
- M as tokens
29
+ b as default
190
30
  };
package/dist/index241.js CHANGED
@@ -1,6 +1,9 @@
1
- import { curry as e } from "./index298.js";
2
- const t = (n, o, r) => n(r) ? o(r) : r, s = e(t);
1
+ const s = (r, t) => {
2
+ if (r.endsWith("."))
3
+ return t === 0 ? r.slice(0, -1) : r;
4
+ const [n, i] = r.split(".");
5
+ return i ? `${n}.${i.slice(0, t)}` : r;
6
+ };
3
7
  export {
4
- t as baseWhen,
5
- s as when
8
+ s as clampPrecision
6
9
  };
package/dist/index242.js CHANGED
@@ -1,69 +1,4 @@
1
- import { defineComponent as d, createElementBlock as l, openBlock as o, normalizeClass as u, createElementVNode as t, createBlock as i, createCommentVNode as s, unref as f, withCtx as g, toDisplayString as n } from "vue";
2
- import { useLocale as k } from "./index220.js";
3
- import h from "./index13.js";
4
- /* empty css */
5
- import C from "./index86.js";
6
- /* empty css */
7
- const w = { class: "bb-toast-message__icon-container" }, v = { class: "bb-toast-message__content" }, y = {
8
- key: 1,
9
- class: "bb-toast-message__title"
10
- }, B = { class: "bb-toast-message__text" }, z = /* @__PURE__ */ d({
11
- __name: "BbToastMessage",
12
- props: {
13
- title: {},
14
- text: {},
15
- icon: {},
16
- theme: { default: "default" },
17
- id: {},
18
- showClose: { type: Boolean }
19
- },
20
- emits: ["click:close"],
21
- setup(r, { emit: c }) {
22
- const m = r, p = c, { t: _ } = k(), b = () => {
23
- p("click:close", m.id);
24
- };
25
- return (e, a) => (o(), l("div", {
26
- "aria-atomic": "true",
27
- "aria-live": "polite",
28
- "aria-role": "alert",
29
- class: u(["bb-toast-message", { [`bb-toast-message--${e.theme}`]: e.theme }])
30
- }, [
31
- t("div", w, [
32
- e.icon ? (o(), i(C, {
33
- key: 0,
34
- class: "bb-toast-message__icon",
35
- type: e.icon
36
- }, null, 8, ["type"])) : s("", !0)
37
- ]),
38
- t("div", v, [
39
- e.showClose ? (o(), i(h, {
40
- key: 0,
41
- "aria-label": f(_)("common.closeLabel").value,
42
- class: "bb-toast-message__close",
43
- onClick: b
44
- }, {
45
- default: g(() => a[0] || (a[0] = [
46
- t("svg", {
47
- fill: "none",
48
- viewBox: "0 0 24 24",
49
- xmlns: "http://www.w3.org/2000/svg"
50
- }, [
51
- t("path", {
52
- d: "M23 23L1 1M23 1L1 23",
53
- stroke: "currentColor",
54
- "stroke-linecap": "round",
55
- "stroke-width": "2"
56
- })
57
- ], -1)
58
- ])),
59
- _: 1
60
- }, 8, ["aria-label"])) : s("", !0),
61
- e.title ? (o(), l("p", y, n(e.title), 1)) : s("", !0),
62
- t("p", B, n(e.text), 1)
63
- ])
64
- ], 2));
65
- }
66
- });
1
+ const r = (e) => typeof e > "u" || e === null;
67
2
  export {
68
- z as default
3
+ r as isNil
69
4
  };