bitboss-ui 2.0.69 → 2.0.70

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 (144) hide show
  1. package/dist/index110.js +5 -5
  2. package/dist/index118.js +1 -1
  3. package/dist/index120.js +5 -5
  4. package/dist/index122.js +1 -1
  5. package/dist/index126.js +1 -1
  6. package/dist/index127.js +1 -1
  7. package/dist/index128.js +1 -1
  8. package/dist/index13.js +1 -1
  9. package/dist/index130.js +1 -1
  10. package/dist/index132.js +2 -2
  11. package/dist/index133.js +2 -2
  12. package/dist/index15.js +4 -4
  13. package/dist/index17.js +3 -3
  14. package/dist/index19.js +2 -2
  15. package/dist/index204.js +81 -2
  16. package/dist/index205.js +2 -81
  17. package/dist/index206.js +4 -2
  18. package/dist/index207.js +2 -4
  19. package/dist/index208.js +53 -2
  20. package/dist/index21.js +14 -14
  21. package/dist/index210.js +13 -162
  22. package/dist/index211.js +19 -83
  23. package/dist/index212.js +6 -0
  24. package/dist/index213.js +3 -53
  25. package/dist/index214.js +43 -0
  26. package/dist/index215.js +6 -13
  27. package/dist/index216.js +7 -20
  28. package/dist/index217.js +8 -4
  29. package/dist/index218.js +162 -2
  30. package/dist/index219.js +79 -101
  31. package/dist/index221.js +2 -100
  32. package/dist/index222.js +128 -0
  33. package/dist/index223.js +5 -2
  34. package/dist/index224.js +125 -3
  35. package/dist/index225.js +19 -2
  36. package/dist/index226.js +14 -124
  37. package/dist/index227.js +16 -5
  38. package/dist/index228.js +2 -125
  39. package/dist/index229.js +2 -19
  40. package/dist/index23.js +15 -15
  41. package/dist/index230.js +5 -16
  42. package/dist/index231.js +367 -14
  43. package/dist/index232.js +18 -40
  44. package/dist/index233.js +27 -6
  45. package/dist/index234.js +3 -5
  46. package/dist/index235.js +246 -366
  47. package/dist/index236.js +52 -2
  48. package/dist/index237.js +42 -16
  49. package/dist/index238.js +5 -3
  50. package/dist/index239.js +60 -3
  51. package/dist/index240.js +3 -7
  52. package/dist/index241.js +2 -19
  53. package/dist/index242.js +18 -27
  54. package/dist/index243.js +101 -244
  55. package/dist/index245.js +96 -40
  56. package/dist/index247.js +2 -60
  57. package/dist/index25.js +5 -5
  58. package/dist/index250.js +4 -6
  59. package/dist/index251.js +3 -16
  60. package/dist/index253.js +6 -8
  61. package/dist/index254.js +176 -23
  62. package/dist/index255.js +430 -8
  63. package/dist/index256.js +88 -3
  64. package/dist/index257.js +6 -2
  65. package/dist/index258.js +15 -8
  66. package/dist/index259.js +1 -1
  67. package/dist/index260.js +8 -11
  68. package/dist/index261.js +23 -9
  69. package/dist/index262.js +3 -17
  70. package/dist/index263.js +12 -4
  71. package/dist/index264.js +9 -3
  72. package/dist/index265.js +11 -0
  73. package/dist/index266.js +17 -7
  74. package/dist/index267.js +3 -175
  75. package/dist/index268.js +9 -3
  76. package/dist/index269.js +200 -3
  77. package/dist/index27.js +1 -1
  78. package/dist/index270.js +280 -27
  79. package/dist/index271.js +5 -280
  80. package/dist/index272.js +2 -6
  81. package/dist/index273.js +2 -2
  82. package/dist/index274.js +2 -2
  83. package/dist/index277.js +126 -2
  84. package/dist/index278.js +21 -125
  85. package/dist/index280.js +2 -22
  86. package/dist/index281.js +4 -0
  87. package/dist/index282.js +2 -224
  88. package/dist/index283.js +2 -211
  89. package/dist/index284.js +2 -436
  90. package/dist/index285.js +2 -127
  91. package/dist/index286.js +25 -197
  92. package/dist/index287.js +22 -89
  93. package/dist/index289.js +434 -64
  94. package/dist/index29.js +3 -3
  95. package/dist/index290.js +127 -2
  96. package/dist/index291.js +224 -2
  97. package/dist/index292.js +3 -2
  98. package/dist/index293.js +3 -2
  99. package/dist/index294.js +211 -2
  100. package/dist/index295.js +2 -2
  101. package/dist/index296.js +61 -17
  102. package/dist/index298.js +33 -4
  103. package/dist/index299.js +5 -4
  104. package/dist/index300.js +7 -58
  105. package/dist/index301.js +4 -79
  106. package/dist/index302.js +6 -0
  107. package/dist/index303.js +58 -4
  108. package/dist/index304.js +3 -7
  109. package/dist/index305.js +79 -4
  110. package/dist/index307.js +6 -32
  111. package/dist/index308.js +6 -6
  112. package/dist/index309.js +19 -2
  113. package/dist/index31.js +2 -2
  114. package/dist/index310.js +10 -46
  115. package/dist/index311.js +46 -6
  116. package/dist/index312.js +2 -19
  117. package/dist/{index313.js → index314.js} +1 -1
  118. package/dist/index33.js +2 -2
  119. package/dist/index35.js +3 -3
  120. package/dist/index37.js +13 -13
  121. package/dist/index39.js +4 -4
  122. package/dist/index41.js +2 -2
  123. package/dist/index43.js +2 -2
  124. package/dist/index45.js +6 -6
  125. package/dist/index47.js +2 -2
  126. package/dist/index49.js +2 -2
  127. package/dist/index53.js +1 -1
  128. package/dist/index55.js +1 -1
  129. package/dist/index57.js +1 -1
  130. package/dist/index75.js +3 -3
  131. package/dist/index79.js +2 -2
  132. package/dist/index81.js +1 -1
  133. package/dist/index84.js +2 -2
  134. package/dist/index86.js +1 -1
  135. package/dist/index88.js +3 -3
  136. package/dist/index90.js +1 -1
  137. package/package.json +1 -1
  138. package/dist/index209.js +0 -10
  139. package/dist/index244.js +0 -54
  140. package/dist/index246.js +0 -7
  141. package/dist/index252.js +0 -5
  142. package/dist/index279.js +0 -433
  143. package/dist/index306.js +0 -13
  144. /package/dist/{index288.js → index297.js} +0 -0
package/dist/index245.js CHANGED
@@ -1,46 +1,102 @@
1
- import { defineComponent as _, computed as a, openBlock as o, createElementBlock as c, createElementVNode as p, Fragment as b, renderList as h, createBlock as k, normalizeClass as f, withCtx as y, createTextVNode as x, toDisplayString as B } from "vue";
2
- import C from "./index13.js";
3
- /* empty css */
4
- const M = { class: "bb-base-date-picker__button-menu bb-base-date-picker__month-selector" }, v = { class: "content" }, E = /* @__PURE__ */ _({
5
- __name: "BaseDatePickerMonthSelector",
1
+ import { defineComponent as F, ref as H, computed as L, watch as N, openBlock as d, createElementBlock as v, Fragment as S, renderList as A, normalizeClass as O, withModifiers as P, toDisplayString as V } from "vue";
2
+ import { hash as f } from "./index234.js";
3
+ import { isNil as i } from "./index129.js";
4
+ const z = ["text", "onClick:clear"], j = /* @__PURE__ */ F({
5
+ __name: "CommaBox",
6
6
  props: {
7
- cursor: {},
8
- disabled: { type: Boolean }
7
+ options: {}
9
8
  },
10
- emits: ["update:month"],
11
- setup(l, { emit: d }) {
12
- const s = l, m = d, i = a(() => s.cursor.month()), u = a(
13
- () => new Array(12).fill(0).map((r, t) => {
14
- const n = s.cursor.clone().startOf("year").add(t, "month");
15
- return {
16
- text: n.format("MMMM"),
17
- key: n.unix(),
18
- selected: n.month() === i.value,
19
- handler: () => m("update:month", t)
20
- };
21
- })
22
- );
23
- return (r, t) => (o(), c("div", M, [
24
- p("div", v, [
25
- (o(!0), c(b, null, h(u.value, (e) => (o(), k(C, {
26
- key: e.key,
27
- class: f({
28
- content__btn: !0,
29
- "content__btn--selected": e.selected
30
- }),
31
- disabled: r.disabled,
32
- type: "button",
33
- onClick: e.handler
34
- }, {
35
- default: y(() => [
36
- x(B(e.text), 1)
37
- ]),
38
- _: 2
39
- }, 1032, ["class", "disabled", "onClick"]))), 128))
40
- ])
41
- ]));
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 (!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) => (d(!0), v(S, null, A(e.options, (o, p) => (d(), v("span", {
88
+ key: o.valueHash,
89
+ class: O({
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": P((D) => a("option:unselected", o), ["stop"])
97
+ }, V(o.text), 43, z))), 128));
42
98
  }
43
99
  });
44
100
  export {
45
- E as default
101
+ j as default
46
102
  };
package/dist/index247.js CHANGED
@@ -1,62 +1,4 @@
1
- import { defineComponent as g, ref as i, computed as d, onMounted as h, openBlock as u, createElementBlock as m, createElementVNode as y, Fragment as x, renderList as B, createBlock as C, normalizeClass as S, withCtx as T, createTextVNode as E, toDisplayString as w } from "vue";
2
- import { range as H } from "./index308.js";
3
- import M from "./index13.js";
4
- /* empty css */
5
- const n = 10, l = 3, V = /* @__PURE__ */ g({
6
- __name: "BaseDatePickerYearSelector",
7
- props: {
8
- cursor: {},
9
- disabled: { type: Boolean }
10
- },
11
- emits: ["update:year"],
12
- setup(p, { emit: _ }) {
13
- const f = p, b = _, o = i(), r = d(() => f.cursor.year()), c = i(r.value - n * l), s = i(r.value + n * l), v = d(
14
- () => H(c.value, s.value).map((e) => ({
15
- text: e,
16
- key: e,
17
- selected: e === r.value,
18
- handler: () => b("update:year", e)
19
- }))
20
- ), k = (e) => {
21
- const t = e.target;
22
- t.scrollTop <= 100 ? c.value = Math.max(
23
- c.value - n * l,
24
- r.value - 200
25
- ) : t.scrollHeight - t.scrollTop === t.clientHeight && (s.value = Math.min(s.value + n * l, 2101));
26
- };
27
- return h(() => {
28
- if (!o.value) return;
29
- const e = o.value.querySelector(
30
- ".content__btn--selected"
31
- );
32
- e && (e.parentElement.scrollTop = e.offsetTop - e.parentElement.clientHeight / 2 + 16);
33
- }), (e, t) => (u(), m("div", {
34
- ref_key: "container",
35
- ref: o,
36
- class: "bb-base-date-picker__button-menu bb-base-date-picker__year-selector scrollbar-border"
37
- }, [
38
- y("div", {
39
- class: "content",
40
- onScrollPassive: k
41
- }, [
42
- (u(!0), m(x, null, B(v.value, (a) => (u(), C(M, {
43
- key: a.key,
44
- class: S({
45
- content__btn: !0,
46
- "content__btn--selected": a.selected
47
- }),
48
- disabled: e.disabled,
49
- onClick: a.handler
50
- }, {
51
- default: T(() => [
52
- E(w(a.text), 1)
53
- ]),
54
- _: 2
55
- }, 1032, ["class", "disabled", "onClick"]))), 128))
56
- ], 32)
57
- ], 512));
58
- }
59
- });
1
+ const o = (e) => e[0];
60
2
  export {
61
- V as default
3
+ o as head
62
4
  };
package/dist/index25.js CHANGED
@@ -1,11 +1,11 @@
1
1
  import { defineComponent as ae, ref as o, getCurrentInstance as se, computed as m, nextTick as N, useAttrs as ne, onMounted as ie, onBeforeUnmount as F, watch as re, openBlock as k, createBlock as ue, Teleport as de, createElementVNode as a, mergeProps as G, createElementBlock as T, renderSlot as u, createTextVNode as ce, toDisplayString as P, createCommentVNode as z } from "vue";
2
- import { throttle as ve } from "./index239.js";
3
- import { useFocusTrap as fe } from "./index232.js";
2
+ import { throttle as ve } from "./index213.js";
3
+ import { useFocusTrap as fe } from "./index214.js";
4
4
  import { useId as K } from "./index8.js";
5
5
  import { wait as H } from "./index131.js";
6
- import { waitFor as be } from "./index233.js";
7
- import { useModalsState as C } from "./index240.js";
8
- import { useLogger as pe } from "./index209.js";
6
+ import { waitFor as be } from "./index215.js";
7
+ import { useModalsState as C } from "./index216.js";
8
+ import { useLogger as pe } from "./index217.js";
9
9
  const me = { class: "bb-base-dialog-close" }, ge = ["aria-label"], De = /* @__PURE__ */ ae({
10
10
  __name: "BaseDialog",
11
11
  props: {
package/dist/index250.js CHANGED
@@ -1,8 +1,6 @@
1
- import e from "./index298.js";
2
- import r from "./index299.js";
3
- import o from "./index300.js";
4
- const f = new o(r, e)._freeze();
1
+ const e = function(t) {
2
+ return (...n) => n.length >= t.length ? t(...n) : e(t.bind(void 0, ...n));
3
+ };
5
4
  export {
6
- o as Mime,
7
- f as default
5
+ e as curry
8
6
  };
package/dist/index251.js CHANGED
@@ -1,18 +1,5 @@
1
- const e = (o, r, f) => o.reduce((t, n) => {
2
- if (t) return t;
3
- if (f(n))
4
- return n;
5
- if (r in n) {
6
- const i = e(
7
- [].concat(n[r]),
8
- r,
9
- f
10
- );
11
- if (i)
12
- return i;
13
- }
14
- return t;
15
- }, null);
1
+ import o from "./index208.js";
2
+ /* empty css */
16
3
  export {
17
- e as findInTree
4
+ o as default
18
5
  };
package/dist/index253.js CHANGED
@@ -1,11 +1,9 @@
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
+ const s = (t, e) => {
2
+ const o = t.__vccOpts || t;
3
+ for (const [r, c] of e)
4
+ o[r] = c;
5
+ return o;
8
6
  };
9
7
  export {
10
- o as findRightIndex
8
+ s as default
11
9
  };
package/dist/index254.js CHANGED
@@ -1,25 +1,178 @@
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
+ var P = Object.defineProperty, T = (a, t, e) => t in a ? P(a, t, { enumerable: !0, configurable: !0, writable: !0, value: e }) : a[t] = e, A = (a, t, e) => T(a, typeof t != "symbol" ? t + "" : t, e);
2
+ const R = {
3
+ "#": { pattern: /[0-9]/ },
4
+ "@": { pattern: /[a-zA-Z]/ },
5
+ "*": { pattern: /[a-zA-Z0-9]/ }
6
+ }, I = (a, t, e) => a.replaceAll(t, "").replace(e, ".").replace("..", ".").replace(/[^.\d]/g, ""), N = (a, t, e) => {
7
+ var s;
8
+ return new Intl.NumberFormat(((s = e.number) == null ? void 0 : s.locale) ?? "en", {
9
+ minimumFractionDigits: a,
10
+ maximumFractionDigits: t,
11
+ roundingMode: "trunc"
12
+ });
13
+ }, F = (a, t = !0, e) => {
14
+ var s, n, r, h;
15
+ const u = ((s = e.number) == null ? void 0 : s.unsigned) == null && a.startsWith("-") ? "-" : "", l = ((n = e.number) == null ? void 0 : n.fraction) ?? 0;
16
+ let o = N(0, l, e);
17
+ const k = o.formatToParts(1000.12), c = ((r = k.find((i) => i.type === "group")) == null ? void 0 : r.value) ?? " ", y = ((h = k.find((i) => i.type === "decimal")) == null ? void 0 : h.value) ?? ".", f = I(a, c, y);
18
+ if (Number.isNaN(parseFloat(f))) return u;
19
+ const g = f.split(".");
20
+ if (g[1] != null && g[1].length >= 1) {
21
+ const i = g[1].length <= l ? g[1].length : l;
22
+ o = N(i, l, e);
23
+ }
24
+ let m = o.format(parseFloat(f));
25
+ return t ? l > 0 && f.endsWith(".") && !f.slice(0, -1).includes(".") && (m += y) : m = I(m, c, y), u + m;
26
+ };
27
+ class O {
28
+ constructor(t = {}) {
29
+ A(this, "opts", {}), A(this, "memo", /* @__PURE__ */ new Map());
30
+ const e = { ...t };
31
+ if (e.tokens != null) {
32
+ e.tokens = e.tokensReplace ? { ...e.tokens } : { ...R, ...e.tokens };
33
+ for (const s of Object.values(e.tokens))
34
+ typeof s.pattern == "string" && (s.pattern = new RegExp(s.pattern));
35
+ } else
36
+ e.tokens = R;
37
+ Array.isArray(e.mask) && (e.mask.length > 1 ? e.mask = [...e.mask].sort((s, n) => s.length - n.length) : e.mask = e.mask[0] ?? ""), e.mask === "" && (e.mask = null), this.opts = e;
38
+ }
39
+ masked(t) {
40
+ return this.process(t, this.findMask(t));
41
+ }
42
+ unmasked(t) {
43
+ return this.process(t, this.findMask(t), !1);
44
+ }
45
+ isEager() {
46
+ return this.opts.eager === !0;
47
+ }
48
+ isReversed() {
49
+ return this.opts.reversed === !0;
50
+ }
51
+ completed(t) {
52
+ const e = this.findMask(t);
53
+ if (this.opts.mask == null || e == null) return !1;
54
+ const s = this.process(t, e).length;
55
+ return typeof this.opts.mask == "string" ? s >= this.opts.mask.length : s >= e.length;
56
+ }
57
+ findMask(t) {
58
+ const e = this.opts.mask;
59
+ if (e == null)
60
+ return null;
61
+ if (typeof e == "string")
62
+ return e;
63
+ if (typeof e == "function")
64
+ return e(t);
65
+ const s = this.process(t, e.slice(-1).pop() ?? "", !1);
66
+ return e.find((n) => this.process(t, n, !1).length >= s.length) ?? "";
67
+ }
68
+ escapeMask(t) {
69
+ const e = [], s = [];
70
+ return t.split("").forEach((n, r) => {
71
+ n === "!" && t[r - 1] !== "!" ? s.push(r - s.length) : e.push(n);
72
+ }), { mask: e.join(""), escaped: s };
73
+ }
74
+ process(t, e, s = !0) {
75
+ if (this.opts.number != null) return F(t, s, this.opts);
76
+ if (e == null) return t;
77
+ const n = `v=${t},mr=${e},m=${s ? 1 : 0}`;
78
+ if (this.memo.has(n)) return this.memo.get(n);
79
+ const { mask: r, escaped: h } = this.escapeMask(e), u = [], l = this.opts.tokens != null ? this.opts.tokens : {}, o = this.isReversed() ? -1 : 1, k = this.isReversed() ? "unshift" : "push", c = this.isReversed() ? 0 : r.length - 1, y = this.isReversed() ? () => i > -1 && p > -1 : () => i < r.length && p < t.length, f = (v) => !this.isReversed() && v <= c || this.isReversed() && v >= c;
80
+ let g, m = -1, i = this.isReversed() ? r.length - 1 : 0, p = this.isReversed() ? t.length - 1 : 0, M = !1;
81
+ for (; y(); ) {
82
+ const v = r.charAt(i), d = l[v], E = (d == null ? void 0 : d.transform) != null ? d.transform(t.charAt(p)) : t.charAt(p);
83
+ if (!h.includes(i) && d != null ? (E.match(d.pattern) != null ? (u[k](E), d.repeated ? (m === -1 ? m = i : i === c && i !== m && (i = m - o), c === m && (i -= o)) : d.multiple && (M = !0, i -= o), i += o) : d.multiple ? M && (i += o, p -= o, M = !1) : E === g ? g = void 0 : d.optional && (i += o, p -= o), p += o) : (s && !this.isEager() && u[k](v), E === v && !this.isEager() ? p += o : g = v, this.isEager() || (i += o)), this.isEager())
84
+ for (; f(i) && (l[r.charAt(i)] == null || h.includes(i)); ) {
85
+ if (s) {
86
+ if (u[k](r.charAt(i)), t.charAt(p) === r.charAt(i)) {
87
+ i += o, p += o;
88
+ continue;
89
+ }
90
+ } else r.charAt(i) === t.charAt(p) && (p += o);
91
+ i += o;
92
+ }
93
+ }
94
+ return this.memo.set(n, u.join("")), this.memo.get(n);
95
+ }
96
+ }
97
+ const w = (a) => JSON.parse(a.replaceAll("'", '"')), W = (a, t = {}) => {
98
+ const e = { ...t };
99
+ a.dataset.maska != null && a.dataset.maska !== "" && (e.mask = x(a.dataset.maska)), a.dataset.maskaEager != null && (e.eager = b(a.dataset.maskaEager)), a.dataset.maskaReversed != null && (e.reversed = b(a.dataset.maskaReversed)), a.dataset.maskaTokensReplace != null && (e.tokensReplace = b(a.dataset.maskaTokensReplace)), a.dataset.maskaTokens != null && (e.tokens = C(a.dataset.maskaTokens));
100
+ const s = {};
101
+ 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 = b(a.dataset.maskaNumberUnsigned)), (a.dataset.maskaNumber != null || Object.values(s).length > 0) && (e.number = s), e;
102
+ }, b = (a) => a !== "" ? !!JSON.parse(a) : !0, x = (a) => a.startsWith("[") && a.endsWith("]") ? w(a) : a, C = (a) => {
103
+ if (a.startsWith("{") && a.endsWith("}"))
104
+ return w(a);
105
+ const t = {};
106
+ return a.split("|").forEach((e) => {
107
+ const s = e.split(":");
108
+ t[s[0]] = {
109
+ pattern: new RegExp(s[1]),
110
+ optional: s[2] === "optional",
111
+ multiple: s[2] === "multiple",
112
+ repeated: s[2] === "repeated"
113
+ };
114
+ }), t;
115
+ };
116
+ class S {
117
+ constructor(t, e = {}) {
118
+ A(this, "items", /* @__PURE__ */ new Map()), A(this, "onInput", (s) => {
119
+ if (s instanceof CustomEvent && s.type === "input" && !s.isTrusted)
120
+ return;
121
+ const n = s.target, r = this.items.get(n), h = "inputType" in s && s.inputType.startsWith("delete"), u = r.isEager(), l = h && u && r.unmasked(n.value) === "" ? "" : n.value;
122
+ this.fixCursor(n, h, () => this.setValue(n, l));
123
+ }), this.options = e, this.init(this.getInputs(t));
124
+ }
125
+ update(t = {}) {
126
+ this.options = { ...t }, this.init(Array.from(this.items.keys()));
127
+ }
128
+ updateValue(t) {
129
+ t.value !== "" && t.value !== this.processInput(t).masked && this.setValue(t, t.value);
130
+ }
131
+ destroy() {
132
+ for (const t of this.items.keys())
133
+ t.removeEventListener("input", this.onInput);
134
+ this.items.clear();
135
+ }
136
+ init(t) {
137
+ const e = this.getOptions(this.options);
138
+ for (const s of t) {
139
+ this.items.has(s) || s.addEventListener("input", this.onInput, { capture: !0 });
140
+ const n = new O(W(s, e));
141
+ this.items.set(s, n), queueMicrotask(() => this.updateValue(s)), s.selectionStart === null && n.isEager() && console.warn("Maska: input of `%s` type is not supported", s.type);
142
+ }
143
+ }
144
+ getInputs(t) {
145
+ return typeof t == "string" ? Array.from(document.querySelectorAll(t)) : "length" in t ? Array.from(t) : [t];
146
+ }
147
+ getOptions(t) {
148
+ const { onMaska: e, preProcess: s, postProcess: n, ...r } = t;
149
+ return r;
150
+ }
151
+ fixCursor(t, e, s) {
152
+ const n = t.selectionStart, r = t.value;
153
+ if (s(), n === null || n === r.length && !e) return;
154
+ const h = t.value, u = r.slice(0, n), l = h.slice(0, n), o = this.processInput(t, u).unmasked, k = this.processInput(t, l).unmasked;
155
+ let c = n;
156
+ u !== l && (c += e ? h.length - r.length : o.length - k.length), t.setSelectionRange(c, c);
157
+ }
158
+ setValue(t, e) {
159
+ const s = this.processInput(t, e);
160
+ t.value = s.masked, this.options.onMaska != null && (Array.isArray(this.options.onMaska) ? this.options.onMaska.forEach((n) => n(s)) : this.options.onMaska(s)), t.dispatchEvent(new CustomEvent("maska", { detail: s })), t.dispatchEvent(new CustomEvent("input", { detail: s.masked }));
161
+ }
162
+ processInput(t, e) {
163
+ const s = this.items.get(t);
164
+ let n = e ?? t.value;
165
+ this.options.preProcess != null && (n = this.options.preProcess(n));
166
+ let r = s.masked(n);
167
+ return this.options.postProcess != null && (r = this.options.postProcess(r)), {
168
+ masked: r,
169
+ unmasked: s.unmasked(n),
170
+ completed: s.completed(n)
171
+ };
172
+ }
173
+ }
23
174
  export {
24
- n as default
175
+ O as Mask,
176
+ S as MaskInput,
177
+ R as tokens
25
178
  };