bitboss-ui 2.0.72 → 2.0.74

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 (142) hide show
  1. package/dist/components/BbBreadcrumbs/BbBreadcrumbs.vue.d.ts +5 -0
  2. package/dist/components/BbPagination/BbPagination.vue.d.ts +5 -0
  3. package/dist/index106.js +16 -16
  4. package/dist/index108.js +52 -57
  5. package/dist/index110.js +59 -60
  6. package/dist/index118.js +1 -1
  7. package/dist/index120.js +56 -57
  8. package/dist/index122.js +1 -1
  9. package/dist/index126.js +21 -19
  10. package/dist/index127.js +1 -1
  11. package/dist/index128.js +1 -1
  12. package/dist/index13.js +1 -1
  13. package/dist/index130.js +1 -1
  14. package/dist/index132.js +2 -2
  15. package/dist/index15.js +4 -4
  16. package/dist/index17.js +3 -3
  17. package/dist/index19.js +2 -2
  18. package/dist/index204.js +2 -81
  19. package/dist/index205.js +53 -2
  20. package/dist/index207.js +13 -2
  21. package/dist/index208.js +20 -4
  22. package/dist/index209.js +4 -2
  23. package/dist/index21.js +14 -14
  24. package/dist/index210.js +3 -53
  25. package/dist/index211.js +83 -0
  26. package/dist/index212.js +5 -13
  27. package/dist/index213.js +15 -19
  28. package/dist/index214.js +16 -4
  29. package/dist/index215.js +17 -162
  30. package/dist/index216.js +19 -84
  31. package/dist/index217.js +29 -0
  32. package/dist/index218.js +3 -3
  33. package/dist/index219.js +2 -41
  34. package/dist/index220.js +7 -5
  35. package/dist/index221.js +249 -7
  36. package/dist/index222.js +49 -123
  37. package/dist/index223.js +44 -5
  38. package/dist/index224.js +5 -125
  39. package/dist/index225.js +60 -19
  40. package/dist/index226.js +2 -16
  41. package/dist/index227.js +4 -16
  42. package/dist/index228.js +2 -2
  43. package/dist/index229.js +126 -2
  44. package/dist/index23.js +15 -15
  45. package/dist/index230.js +125 -5
  46. package/dist/index231.js +2 -369
  47. package/dist/index232.js +41 -3
  48. package/dist/index233.js +6 -19
  49. package/dist/index234.js +5 -27
  50. package/dist/index235.js +369 -3
  51. package/dist/index236.js +3 -249
  52. package/dist/index237.js +7 -52
  53. package/dist/index238.js +163 -43
  54. package/dist/index239.js +84 -5
  55. package/dist/index241.js +1 -1
  56. package/dist/index243.js +1 -1
  57. package/dist/index245.js +1 -1
  58. package/dist/index25.js +5 -5
  59. package/dist/index252.js +1 -1
  60. package/dist/index255.js +3 -9
  61. package/dist/index257.js +7 -3
  62. package/dist/index258.js +178 -0
  63. package/dist/index259.js +224 -7
  64. package/dist/index260.js +8 -175
  65. package/dist/index261.js +281 -66
  66. package/dist/index262.js +6 -2
  67. package/dist/index263.js +2 -9
  68. package/dist/index264.js +2 -3
  69. package/dist/index265.js +2 -12
  70. package/dist/index266.js +2 -9
  71. package/dist/index267.js +2 -17
  72. package/dist/index268.js +2 -4
  73. package/dist/index269.js +2 -431
  74. package/dist/index27.js +1 -1
  75. package/dist/index270.js +2 -89
  76. package/dist/index271.js +2 -281
  77. package/dist/index272.js +2 -6
  78. package/dist/index273.js +28 -2
  79. package/dist/index274.js +22 -2
  80. package/dist/index276.js +4 -2
  81. package/dist/index277.js +2 -2
  82. package/dist/index279.js +429 -20
  83. package/dist/index280.js +24 -0
  84. package/dist/index282.js +83 -218
  85. package/dist/index283.js +3 -436
  86. package/dist/index284.js +11 -126
  87. package/dist/index285.js +9 -2
  88. package/dist/index286.js +9 -2
  89. package/dist/index287.js +17 -2
  90. package/dist/index288.js +4 -2
  91. package/dist/index289.js +200 -2
  92. package/dist/index29.js +18 -19
  93. package/dist/index290.js +436 -2
  94. package/dist/index291.js +125 -26
  95. package/dist/index292.js +3 -22
  96. package/dist/index293.js +5 -0
  97. package/dist/index294.js +211 -5
  98. package/dist/index295.js +65 -2
  99. package/dist/index296.js +5 -3
  100. package/dist/index297.js +2 -211
  101. package/dist/index301.js +1 -1
  102. package/dist/index302.js +1 -1
  103. package/dist/index303.js +33 -79
  104. package/dist/index304.js +86 -0
  105. package/dist/index306.js +4 -2
  106. package/dist/index307.js +6 -32
  107. package/dist/index31.js +2 -2
  108. package/dist/index310.js +46 -6
  109. package/dist/index311.js +2 -11
  110. package/dist/index312.js +10 -46
  111. package/dist/{index313.js → index314.js} +2 -2
  112. package/dist/index315.js +1 -1
  113. package/dist/index316.js +47 -2
  114. package/dist/index317.js +2 -47
  115. package/dist/index33.js +2 -2
  116. package/dist/index35.js +3 -3
  117. package/dist/index37.js +9 -9
  118. package/dist/index39.js +3 -3
  119. package/dist/index41.js +2 -2
  120. package/dist/index43.js +2 -2
  121. package/dist/index45.js +4 -4
  122. package/dist/index47.js +2 -2
  123. package/dist/index49.js +2 -2
  124. package/dist/index55.js +1 -1
  125. package/dist/index57.js +1 -1
  126. package/dist/index59.js +21 -20
  127. package/dist/index61.js +21 -23
  128. package/dist/index75.js +45 -46
  129. package/dist/index79.js +2 -5
  130. package/dist/index81.js +1 -1
  131. package/dist/index84.js +2 -2
  132. package/dist/index86.js +27 -26
  133. package/dist/index88.js +85 -85
  134. package/dist/index90.js +1 -1
  135. package/dist/style.css +1 -1
  136. package/package.json +1 -1
  137. package/dist/index206.js +0 -10
  138. package/dist/index240.js +0 -62
  139. package/dist/index256.js +0 -6
  140. package/dist/index275.js +0 -4
  141. package/dist/index281.js +0 -202
  142. package/dist/index305.js +0 -6
package/dist/index238.js CHANGED
@@ -1,46 +1,166 @@
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",
6
- props: {
7
- cursor: {},
8
- disabled: { type: Boolean }
9
- },
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
- })
1
+ import { ref as s, computed as a, onServerPrefetch as $, onBeforeMount as ee, onBeforeUnmount as te, watch as b, nextTick as Q } from "vue";
2
+ import { last as le } from "./index219.js";
3
+ import { useArray as E } from "./index284.js";
4
+ import { uniqBy as ne } from "./index285.js";
5
+ import { useItemValue as ue } from "./index286.js";
6
+ import { useItemText as oe } from "./index287.js";
7
+ import { hash as f } from "./index218.js";
8
+ import { isNotNil as F } from "./index134.js";
9
+ import { waitFor as ie } from "./index233.js";
10
+ import { isNil as se } from "./index129.js";
11
+ import { pipe as H } from "./index288.js";
12
+ const xe = (t) => {
13
+ const r = s(""), P = s(), o = (e) => {
14
+ P.value = e, t.emit("update:modelValue", e);
15
+ }, m = s([]), {
16
+ array: k,
17
+ add: j,
18
+ remove: J,
19
+ set: h
20
+ } = E(), {
21
+ array: O,
22
+ add: L,
23
+ remove: U
24
+ } = E(), { getItemText: z } = oe(), { getItemValue: G } = ue();
25
+ if (t.max && t.max < 1)
26
+ throw new Error("Invalid value for `max` property");
27
+ const B = (e) => {
28
+ const l = !!(t.disabled.value || e.disabled), n = z(e, t.itemText), u = G(e, t.itemValue);
29
+ if (u === void 0)
30
+ throw new Error(
31
+ 'The result of extracting "value" from option was undefined. Affected item is ' + JSON.stringify(e) + " please check itemValue property is correct."
32
+ );
33
+ const _ = f(u);
34
+ return {
35
+ item: e,
36
+ text: n,
37
+ value: u,
38
+ valueHash: _,
39
+ disabled: l,
40
+ selected: !1
41
+ };
42
+ }, V = (e) => (e.selected = F(q.value[e.valueHash]), e), K = t.max || 1 / 0, g = (e) => (e.disabled = e.disabled || t.multiple && t.modelValue.value.length >= K && !e.selected, e), x = a(() => {
43
+ const e = [].concat(
44
+ m.value.map(H(B, V, g)),
45
+ O.value.map(H(V, g)),
46
+ k.value.map(H(V, g))
22
47
  );
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
- ]));
42
- }
43
- });
48
+ return ne(e, (n) => n.valueHash);
49
+ }), R = (e) => {
50
+ t.multiple ? (o(t.modelValue.value.concat(e.value)), t.stash && j(e), t.resetQueryOnOptionSelected && i()) : (t.stash && h(e), o(e.value), Q(() => i()));
51
+ }, W = async (e) => {
52
+ if (U((l) => l.valueHash !== e.valueHash), J((l) => l.valueHash !== e.valueHash), t.multiple) {
53
+ const l = { ...q.value };
54
+ delete l[e.valueHash], o(Object.values(l));
55
+ } else
56
+ o(null), await Q(), i();
57
+ }, q = a(() => {
58
+ const e = {}, l = [].concat(t.modelValue.value);
59
+ for (let n = 0; n < l.length; n++) {
60
+ const u = l[n];
61
+ e[f(u)] = u;
62
+ }
63
+ return e;
64
+ }), I = async ({ prefill: e = !1 }) => {
65
+ let l = [];
66
+ if (Array.isArray(t.items.value))
67
+ l = t.items.value;
68
+ else if (typeof t.items.value == "function") {
69
+ const n = ++d.value;
70
+ try {
71
+ l = await t.items.value(
72
+ r.value,
73
+ e,
74
+ t.modelValue.value
75
+ ), n < d.value && (await ie(() => n === d.value), l = m.value);
76
+ } catch (u) {
77
+ console.error(u);
78
+ }
79
+ d.value--;
80
+ }
81
+ m.value = l;
82
+ }, C = a(() => {
83
+ const e = {};
84
+ for (let l = 0; l < x.value.length; l++) {
85
+ const n = x.value[l], { valueHash: u } = n;
86
+ e[u] = n;
87
+ }
88
+ return {
89
+ get: (l) => e[f(l)]
90
+ };
91
+ }), c = a(() => [].concat(t.modelValue.value).reduce((e, l) => {
92
+ const n = C.value.get(l);
93
+ return n && e.push(n), e;
94
+ }, [])), M = (e) => F(C.value.get(e)), i = () => {
95
+ if (t.multiple) {
96
+ r.value = "";
97
+ return;
98
+ }
99
+ let e;
100
+ c.value && (e = le(c.value)), r.value = (e == null ? void 0 : e.text) || "";
101
+ }, X = () => {
102
+ const e = r.value.trim(), l = B(e);
103
+ L(l), i();
104
+ }, d = s(0), A = a(() => [].concat(t.modelValue.value).reduce(
105
+ (e, l) => (M(l) ? e.coherent.push(l) : e.incoherent.push(l), e),
106
+ { coherent: [], incoherent: [] }
107
+ )), D = a(() => t.multiple && !t.modelValue.value.length || !t.multiple && se(t.modelValue.value) ? !0 : !A.value.incoherent.length), Y = () => {
108
+ t.enforceCoherence && !D.value && (t.multiple ? o(A.value.coherent) : o(null));
109
+ }, y = s(!1), w = s(!1), v = async () => {
110
+ w.value = !0, await I({ prefill: !0 }), Y(), i(), y.value = !0, w.value = !1;
111
+ };
112
+ $(async () => {
113
+ t.prefill && (await v(), t.stash && h(...c.value));
114
+ }), ee(async () => {
115
+ t.prefill && !y.value && (await v(), t.stash && h(...c.value));
116
+ });
117
+ let T;
118
+ const Z = () => {
119
+ T && clearTimeout(T), T = setTimeout(async () => {
120
+ try {
121
+ await I({ prefill: !1 });
122
+ } catch (e) {
123
+ console.error(e);
124
+ }
125
+ }, t.queryDebounceTime);
126
+ };
127
+ te(() => clearTimeout(T));
128
+ let p;
129
+ b(
130
+ () => t.modelValue.value,
131
+ () => {
132
+ D.value || (p && clearTimeout(p), p = setTimeout(async () => {
133
+ v();
134
+ }, t.modelValueDebounceTime));
135
+ }
136
+ );
137
+ let S;
138
+ const N = async (e, l) => {
139
+ f(l) !== f(e) && y.value && (S && clearTimeout(S), S = setTimeout(async () => {
140
+ await v();
141
+ }, t.depsDebounceTime));
142
+ };
143
+ return b(() => t.items.value, N), b(() => t.dependencies.value, N), {
144
+ addCurrentQueryToManualItems: X,
145
+ alignQueryToState: i,
146
+ getOptions: I,
147
+ hasPrefilled: y,
148
+ innerLoading: d,
149
+ isPrefilling: w,
150
+ manualItems: O,
151
+ options: x,
152
+ prefillItems: v,
153
+ query: r,
154
+ searchByQuery: Z,
155
+ selectedOptions: c,
156
+ selectOption: R,
157
+ setStash: h,
158
+ unselectOption: W,
159
+ updateModelValue: o,
160
+ valueIsSelected: M,
161
+ internalItems: m
162
+ };
163
+ };
44
164
  export {
45
- E as default
165
+ xe as useOptions
46
166
  };
package/dist/index239.js CHANGED
@@ -1,7 +1,86 @@
1
- import o from "./index292.js";
2
- /* empty css */
3
- import t from "./index259.js";
4
- const m = /* @__PURE__ */ t(o, [["__scopeId", "data-v-8c6b13bd"]]);
1
+ import { defineComponent as b, openBlock as t, createElementBlock as n, normalizeClass as r, createElementVNode as l, renderSlot as s, createTextVNode as o, toDisplayString as d, createCommentVNode as h, Fragment as c, renderList as m } from "vue";
2
+ const p = { class: "bb-cr-container__container" }, u = {
3
+ key: 0,
4
+ class: "bb-cr-container__loading-container"
5
+ }, g = {
6
+ key: 1,
7
+ class: "bb-cr-container__no-data-container"
8
+ }, f = /* @__PURE__ */ b({
9
+ __name: "OptionsContainer",
10
+ props: {
11
+ direction: {},
12
+ hasErrors: { type: Boolean },
13
+ hideLabel: { type: Boolean },
14
+ loadingText: {},
15
+ loading: { type: Boolean },
16
+ noDataText: {},
17
+ options: {}
18
+ },
19
+ setup(k) {
20
+ return (a, y) => (t(), n("span", {
21
+ ref: "container",
22
+ class: r(["bb-cr-container", {
23
+ "bb-cr-container--errors": a.hasErrors,
24
+ "bb-cr-container--horizontal": a.direction === "horizontal",
25
+ "bb-cr-container--vertical": a.direction === "vertical"
26
+ }])
27
+ }, [
28
+ l("span", p, [
29
+ s(a.$slots, "prepend"),
30
+ !a.options.length && a.loading ? (t(), n("span", u, [
31
+ s(a.$slots, "loading", {}, () => [
32
+ o(d(a.loadingText), 1)
33
+ ])
34
+ ])) : a.options.length ? h("", !0) : (t(), n("span", g, [
35
+ s(a.$slots, "no-data", {}, () => [
36
+ o(d(a.noDataText), 1)
37
+ ])
38
+ ])),
39
+ (t(!0), n(c, null, m(a.options, (e, i) => (t(), n(c, {
40
+ key: (e == null ? void 0 : e.valueHash) || i
41
+ }, [
42
+ s(a.$slots, "option:prepend", {
43
+ id: e.valueHash,
44
+ checked: !!e.selected,
45
+ disabled: !!e.disabled,
46
+ item: e.item,
47
+ text: e.text
48
+ }),
49
+ l("label", {
50
+ class: r(["bb-cr-container-option", { "bb-base-radio-selected": e.selected }])
51
+ }, [
52
+ s(a.$slots, "input", {
53
+ index: i,
54
+ option: e
55
+ }),
56
+ l("span", {
57
+ class: r({
58
+ "bb-cr-container-option__text": !0,
59
+ "sr-only": a.hideLabel
60
+ })
61
+ }, [
62
+ s(a.$slots, "label", {
63
+ checked: !!e.selected,
64
+ item: e.item,
65
+ text: e.text
66
+ }, () => [
67
+ o(d(e.text), 1)
68
+ ])
69
+ ], 2)
70
+ ], 2),
71
+ s(a.$slots, "option:append", {
72
+ id: e.valueHash,
73
+ checked: !!e.selected,
74
+ disabled: !!e.disabled,
75
+ item: e.item,
76
+ text: e.text
77
+ })
78
+ ], 64))), 128)),
79
+ s(a.$slots, "append")
80
+ ])
81
+ ], 2));
82
+ }
83
+ });
5
84
  export {
6
- m as default
85
+ f as default
7
86
  };
package/dist/index241.js CHANGED
@@ -1,4 +1,4 @@
1
- import f from "./index297.js";
1
+ import f from "./index294.js";
2
2
  export {
3
3
  f as default
4
4
  };
package/dist/index243.js CHANGED
@@ -1,5 +1,5 @@
1
1
  import { defineComponent as y, ref as F, computed as H, watch as N, openBlock as p, createElementBlock as L, Fragment as S, renderList as V, createBlock as A, normalizeClass as O, withModifiers as P, withCtx as $, createTextVNode as z, toDisplayString as D } from "vue";
2
- import { hash as d } from "./index235.js";
2
+ import { hash as d } from "./index218.js";
3
3
  import { isNil as l } from "./index129.js";
4
4
  import E from "./index124.js";
5
5
  /* empty css */
package/dist/index245.js CHANGED
@@ -1,5 +1,5 @@
1
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 "./index235.js";
2
+ import { hash as f } from "./index218.js";
3
3
  import { isNil as i } from "./index129.js";
4
4
  const z = ["text", "onClick:clear"], j = /* @__PURE__ */ F({
5
5
  __name: "CommaBox",
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 "./index218.js";
3
- import { useFocusTrap as fe } from "./index219.js";
2
+ import { throttle as ve } from "./index236.js";
3
+ import { useFocusTrap as fe } from "./index232.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 "./index220.js";
7
- import { useModalsState as C } from "./index221.js";
8
- import { useLogger as pe } from "./index206.js";
6
+ import { waitFor as be } from "./index233.js";
7
+ import { useModalsState as C } from "./index237.js";
8
+ import { useLogger as pe } from "./index220.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/index252.js CHANGED
@@ -1,4 +1,4 @@
1
- import o from "./index303.js";
1
+ import o from "./index304.js";
2
2
  /* empty css */
3
3
  export {
4
4
  o as default
package/dist/index255.js CHANGED
@@ -1,11 +1,5 @@
1
- function u(e, i) {
2
- let t;
3
- return function(...o) {
4
- t !== void 0 && clearTimeout(t), t = setTimeout(() => {
5
- e.apply(this, o);
6
- }, i);
7
- };
8
- }
1
+ import o from "./index205.js";
2
+ /* empty css */
9
3
  export {
10
- u as debounce
4
+ o as default
11
5
  };
package/dist/index257.js CHANGED
@@ -1,5 +1,9 @@
1
- import o from "./index210.js";
2
- /* empty css */
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;
6
+ };
3
7
  export {
4
- o as default
8
+ s as default
5
9
  };
@@ -0,0 +1,178 @@
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
+ }
174
+ export {
175
+ O as Mask,
176
+ S as MaskInput,
177
+ R as tokens
178
+ };