bitboss-ui 2.1.12 → 2.1.13

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 (172) hide show
  1. package/dist/index106.js +7 -7
  2. package/dist/index111.js +1 -1
  3. package/dist/index113.js +1 -1
  4. package/dist/index121.js +9 -9
  5. package/dist/index129.js +1 -1
  6. package/dist/index13.js +1 -1
  7. package/dist/index131.js +4 -4
  8. package/dist/index133.js +1 -1
  9. package/dist/index15.js +8 -8
  10. package/dist/index17.js +3 -3
  11. package/dist/index19.js +8 -8
  12. package/dist/index209.js +34 -5
  13. package/dist/index21.js +16 -16
  14. package/dist/index210.js +86 -5
  15. package/dist/index212.js +29 -5
  16. package/dist/index213.js +17 -5
  17. package/dist/index214.js +51 -5
  18. package/dist/index215.js +15 -2
  19. package/dist/index216.js +3 -2
  20. package/dist/index217.js +12 -2
  21. package/dist/index218.js +16 -13
  22. package/dist/index219.js +4 -11
  23. package/dist/index220.js +13 -20
  24. package/dist/index221.js +11 -66
  25. package/dist/index222.js +22 -0
  26. package/dist/index223.js +197 -13
  27. package/dist/index225.js +68 -0
  28. package/dist/index227.js +13 -2
  29. package/dist/index228.js +113 -4
  30. package/dist/index23.js +15 -15
  31. package/dist/index230.js +12 -85
  32. package/dist/{index226.js → index231.js} +1 -1
  33. package/dist/index232.js +2 -29
  34. package/dist/index233.js +4 -17
  35. package/dist/index234.js +2 -51
  36. package/dist/index235.js +2 -15
  37. package/dist/index236.js +5 -3
  38. package/dist/index237.js +5 -12
  39. package/dist/index238.js +5 -16
  40. package/dist/index239.js +5 -2
  41. package/dist/index240.js +5 -2
  42. package/dist/index241.js +5 -7
  43. package/dist/index242.js +2 -7
  44. package/dist/index243.js +2 -106
  45. package/dist/index244.js +20 -0
  46. package/dist/index245.js +12 -100
  47. package/dist/index246.js +8 -0
  48. package/dist/index247.js +106 -4
  49. package/dist/index249.js +102 -0
  50. package/dist/index25.js +3 -3
  51. package/dist/index251.js +228 -180
  52. package/dist/index252.js +5 -18
  53. package/dist/index253.js +5 -12
  54. package/dist/index254.js +7 -5
  55. package/dist/index255.js +238 -218
  56. package/dist/index256.js +51 -12
  57. package/dist/index257.js +44 -5
  58. package/dist/index258.js +5 -5
  59. package/dist/index259.js +58 -6
  60. package/dist/index260.js +2 -250
  61. package/dist/index261.js +181 -50
  62. package/dist/index262.js +10 -44
  63. package/dist/index263.js +3 -5
  64. package/dist/index264.js +2 -60
  65. package/dist/index265.js +7 -6
  66. package/dist/index266.js +7 -16
  67. package/dist/index269.js +3 -10
  68. package/dist/index27.js +1 -1
  69. package/dist/index270.js +6 -3
  70. package/dist/index271.js +16 -3
  71. package/dist/index273.js +1 -1
  72. package/dist/index275.js +67 -5
  73. package/dist/index277.js +5 -67
  74. package/dist/index278.js +1 -1
  75. package/dist/index279.js +1 -1
  76. package/dist/index280.js +2 -280
  77. package/dist/index281.js +3 -2
  78. package/dist/index282.js +16 -124
  79. package/dist/index283.js +28 -2
  80. package/dist/index284.js +3 -15
  81. package/dist/index285.js +3 -2
  82. package/dist/index287.js +7 -2
  83. package/dist/index288.js +3 -16
  84. package/dist/index289.js +7 -2
  85. package/dist/index29.js +3 -3
  86. package/dist/index290.js +10 -18
  87. package/dist/index291.js +4 -2
  88. package/dist/index292.js +4 -3
  89. package/dist/index293.js +7 -0
  90. package/dist/index294.js +280 -7
  91. package/dist/index295.js +2 -3
  92. package/dist/index296.js +125 -7
  93. package/dist/index297.js +2 -11
  94. package/dist/index298.js +15 -5
  95. package/dist/index299.js +2 -4
  96. package/dist/index300.js +15 -5
  97. package/dist/index301.js +2 -4
  98. package/dist/index302.js +16 -3
  99. package/dist/index303.js +2 -17
  100. package/dist/index304.js +17 -26
  101. package/dist/index305.js +2 -3
  102. package/dist/index306.js +19 -3
  103. package/dist/index307.js +2 -3
  104. package/dist/index308.js +27 -2
  105. package/dist/index309.js +2 -2
  106. package/dist/index31.js +2 -2
  107. package/dist/index310.js +2 -19
  108. package/dist/index311.js +2 -2
  109. package/dist/index312.js +2 -27
  110. package/dist/index313.js +2 -2
  111. package/dist/index314.js +21 -1
  112. package/dist/index316.js +6 -2
  113. package/dist/index317.js +3 -2
  114. package/dist/index318.js +3 -22
  115. package/dist/index319.js +4 -0
  116. package/dist/index320.js +5 -718
  117. package/dist/index321.js +715 -363
  118. package/dist/index322.js +366 -58
  119. package/dist/index323.js +58 -5
  120. package/dist/index324.js +1 -1
  121. package/dist/index325.js +128 -32
  122. package/dist/index326.js +369 -28
  123. package/dist/index327.js +35 -0
  124. package/dist/index328.js +27 -227
  125. package/dist/index33.js +8 -8
  126. package/dist/index330.js +8 -58
  127. package/dist/index331.js +5 -128
  128. package/dist/index332.js +6 -367
  129. package/dist/index333.js +58 -47
  130. package/dist/index334.js +58 -8
  131. package/dist/index335.js +227 -5
  132. package/dist/index336.js +7 -8
  133. package/dist/index337.js +18 -6
  134. package/dist/index338.js +5 -17
  135. package/dist/index339.js +46 -6
  136. package/dist/index340.js +1 -1
  137. package/dist/index341.js +131 -0
  138. package/dist/index343.js +3 -129
  139. package/dist/index344.js +421 -473
  140. package/dist/index345.js +113 -422
  141. package/dist/index346.js +484 -123
  142. package/dist/index35.js +4 -4
  143. package/dist/index37.js +92 -89
  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 +2 -2
  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/index90.js +3 -3
  161. package/dist/index92.js +1 -1
  162. package/dist/index94.js +3 -3
  163. package/package.json +2 -2
  164. package/dist/index211.js +0 -7
  165. package/dist/index224.js +0 -115
  166. package/dist/index229.js +0 -4
  167. package/dist/index248.js +0 -199
  168. package/dist/index250.js +0 -36
  169. package/dist/index286.js +0 -18
  170. package/dist/index315.js +0 -4
  171. package/dist/index329.js +0 -60
  172. package/dist/index342.js +0 -5
package/dist/index259.js CHANGED
@@ -1,10 +1,62 @@
1
- const o = "bitboss-ui | ", e = () => ({
2
- warn: (r) => console.warn(`${o}${r}`),
3
- error: (r) => console.error(`${o}${r}`),
4
- throw: (r) => {
5
- throw new Error(`${o}${r}`);
1
+ import { defineComponent as g, ref as i, computed as d, onMounted as h, createElementBlock as m, openBlock as u, 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 "./index338.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));
6
58
  }
7
59
  });
8
60
  export {
9
- e as useLogger
61
+ V as default
10
62
  };
package/dist/index260.js CHANGED
@@ -1,252 +1,4 @@
1
- import { defineComponent as le, ref as A, computed as _, watch as ce, createElementBlock as c, openBlock as u, withKeys as f, normalizeClass as k, withModifiers as p, createVNode as ue, withCtx as fe, createElementVNode as M, Fragment as O, renderList as S, toDisplayString as C, renderSlot as L, nextTick as pe } from "vue";
2
- import { chunk as be } from "./index337.js";
3
- import { identity as T } from "./index215.js";
4
- import { isNotNil as me } from "./index140.js";
5
- import { last as ge } from "./index217.js";
6
- import { sort as E } from "./index338.js";
7
- import b from "./index209.js";
8
- import he from "./index263.js";
9
- const ye = ["onKeydown"], _e = { class: "bb-base-date-picker__header-container" }, ke = ["abbr"], Oe = ["id", "disabled", "tabindex"], Ce = /* @__PURE__ */ le({
10
- __name: "BaseDatePickerInputDaySelector",
11
- props: {
12
- cursor: {},
13
- current: { type: Boolean },
14
- disabled: { type: Boolean },
15
- firstDayOfWeek: {},
16
- id: {},
17
- modelValue: {},
18
- max: {},
19
- min: {},
20
- selectable: { type: Function },
21
- range: { type: Boolean },
22
- multiple: { type: Boolean },
23
- readonly: { type: Boolean }
24
- },
25
- emits: ["update:modelValue", "update:cursor"],
26
- setup(N, { emit: x }) {
27
- const a = N, s = x, g = A(null), R = b().startOf("day"), m = _(() => {
28
- let e = 1 / 0, r = -1 / 0, o = {};
29
- return a.modelValue && [].concat(a.modelValue).filter(T).map((i) => b(i).startOf("day")).map((i) => i.valueOf()).forEach((i, h) => {
30
- i < e && (e = i), i > r && (r = i), o[i] = h;
31
- }), {
32
- min: e,
33
- max: r,
34
- index: (t) => o[t.valueOf()],
35
- selected: (t) => me(o[t.valueOf()]),
36
- isFirstOfRange: (t) => t.valueOf() === e,
37
- isLastOfRange: (t) => t.valueOf() === r,
38
- isBetween: (t) => t.valueOf() > e && t.valueOf() < r
39
- };
40
- }), K = _(() => new Array(7).fill("").map((e, r) => b().day((r + a.firstDayOfWeek) % 7)).map((e) => ({
41
- accessibleLabel: e.format("dddd"),
42
- label: e.format("dd").slice(0, 1).toUpperCase(),
43
- id: e.toISOString(),
44
- original: e
45
- }))), v = _(() => {
46
- const e = a.cursor.year().toString(), r = a.cursor.month().toString();
47
- let t = a.cursor.clone().startOf("month").clone().startOf("week"), h = a.cursor.clone().endOf("month").clone().endOf("week"), Z = b(a.cursor).startOf("day"), D = [];
48
- for (let n = t; n.isBefore(h); n = n.add(1, "day"))
49
- D.push(n.clone());
50
- const ee = D.map((n) => {
51
- const y = n.toISOString(), te = n.week().toString();
52
- let re = m.value.selected(n);
53
- const B = a.range && m.value.isFirstOfRange(n), I = a.range && m.value.isLastOfRange(n), ae = a.range && !B && !I && m.value.isBetween(n), oe = n.month().toString() === r && n.year().toString() === e, ne = n.isSame(R), se = n.isSame(Z), ie = d(n), de = n.get("D").toString();
54
- return {
55
- buttonId: [a.id, y].filter(T).join("_"),
56
- current: se,
57
- disabled: ie,
58
- first: B,
59
- highlighted: oe,
60
- id: y,
61
- label: de,
62
- last: I,
63
- middle: ae,
64
- original: n,
65
- selected: re,
66
- slotName: y,
67
- today: ne,
68
- week: te
69
- };
70
- });
71
- return be(ee, 7);
72
- }), d = (e) => {
73
- let r = !0;
74
- return a.min && r && (r = e.isSameOrAfter(b(a.min).startOf("day"))), a.max && r && (r = e.isSameOrBefore(b(a.max).startOf("day"))), typeof a.selectable == "function" && r && (r = a.selectable(e.toDate())), !r;
75
- }, w = A("left"), F = (e, r) => {
76
- e && r && (w.value = e.isBefore(r) ? "left" : "right");
77
- };
78
- ce(
79
- () => a.cursor,
80
- (e, r) => {
81
- F(e, r);
82
- }
83
- );
84
- const V = (e) => s("update:cursor", e), l = async () => {
85
- if (!g.value) return;
86
- await pe();
87
- const e = ge([
88
- ...g.value.querySelectorAll(
89
- ".bb-base-date-picker__date--current button"
90
- )
91
- ]);
92
- e instanceof HTMLElement && e.focus();
93
- }, H = (e) => {
94
- if (!a.readonly && e.target instanceof HTMLButtonElement) {
95
- const [, r] = e.target.id.split("_"), o = b(r);
96
- if (a.cursor.month() !== o.month()) {
97
- V(o);
98
- return;
99
- }
100
- const t = v.value.flat().find((i) => i.id === r);
101
- if (t.disabled) return;
102
- V(o), P(t);
103
- }
104
- }, P = (e) => {
105
- a.range ? U(e) : a.multiple ? j(e) : W(e);
106
- }, U = (e) => {
107
- if (!Array.isArray(a.modelValue)) return;
108
- const r = e.original.toISOString();
109
- if (a.modelValue.length !== 1) s("update:modelValue", [r]);
110
- else {
111
- const o = E([a.modelValue[0], e.original.toISOString()]);
112
- s("update:modelValue", o);
113
- }
114
- }, j = (e) => {
115
- if (Array.isArray(a.modelValue))
116
- if (e.selected) {
117
- const r = e.original.toISOString(), o = a.modelValue.filter((t) => t !== r);
118
- s("update:modelValue", o);
119
- } else {
120
- const r = E([...a.modelValue, e.original.toISOString()]);
121
- s("update:modelValue", r);
122
- }
123
- }, W = (e) => {
124
- e.selected ? s("update:modelValue", null) : s("update:modelValue", e.original.toISOString());
125
- }, $ = () => {
126
- const e = a.cursor.clone().add(1, "day");
127
- d(e) || (s("update:cursor", e), l());
128
- }, q = () => {
129
- const e = a.cursor.clone().subtract(1, "day");
130
- d(e) || (s("update:cursor", e), l());
131
- }, z = () => {
132
- const e = a.cursor.clone().subtract(1, "week");
133
- d(e) || (s("update:cursor", e), l());
134
- }, G = () => {
135
- const e = a.cursor.clone().add(1, "week");
136
- d(e) || (s("update:cursor", e), l());
137
- }, J = () => {
138
- const e = a.cursor.clone().endOf("week");
139
- d(e) || (s("update:cursor", e), l());
140
- }, Q = () => {
141
- const e = a.cursor.clone().startOf("week");
142
- d(e) || (s("update:cursor", e), l());
143
- }, X = (e) => {
144
- if (e.shiftKey) {
145
- const r = a.cursor.clone().subtract(1, "year");
146
- if (d(r)) return;
147
- s("update:cursor", r);
148
- } else {
149
- const r = a.cursor.clone().subtract(1, "month");
150
- if (d(r)) return;
151
- s("update:cursor", r);
152
- }
153
- l();
154
- }, Y = (e) => {
155
- if (e.shiftKey) {
156
- const r = a.cursor.clone().add(1, "year");
157
- if (d(r)) return;
158
- s("update:cursor", r);
159
- } else {
160
- const r = a.cursor.clone().add(1, "month");
161
- if (d(r)) return;
162
- s("update:cursor", r);
163
- }
164
- l();
165
- };
166
- return (e, r) => (u(), c("div", {
167
- ref_key: "calendar",
168
- ref: g,
169
- class: k(["bb-base-date-picker__days-selector", { "bb-base-date-picker__days-selector--hidden": !e.current }]),
170
- onKeydown: [
171
- f(p(G, ["prevent"]), ["down"]),
172
- f(p(J, ["prevent"]), ["end"]),
173
- f(p(Q, ["prevent"]), ["home"]),
174
- f(p(q, ["prevent"]), ["left"]),
175
- f(p(Y, ["prevent"]), ["page-down"]),
176
- f(p(X, ["prevent"]), ["page-up"]),
177
- f(p($, ["prevent"]), ["right"]),
178
- f(p(z, ["prevent"]), ["up"])
179
- ]
180
- }, [
181
- ue(he, {
182
- direction: w.value,
183
- gap: 30
184
- }, {
185
- default: fe(() => [
186
- (u(), c("div", {
187
- key: e.cursor.month().toString(),
188
- class: "bb-base-date-picker__month"
189
- }, [
190
- M("div", _e, [
191
- (u(!0), c(O, null, S(K.value, (o) => (u(), c("div", {
192
- key: o.id,
193
- abbr: o.accessibleLabel,
194
- class: "bb-base-date-picker__header-cell"
195
- }, C(o.label), 9, ke))), 128))
196
- ]),
197
- (u(!0), c(O, null, S(v.value, (o) => (u(), c("div", {
198
- key: o[0].id,
199
- class: "bb-base-date-picker__week"
200
- }, [
201
- (u(!0), c(O, null, S(o, (t) => (u(), c("div", {
202
- key: t.id,
203
- class: k({
204
- "bb-base-date-picker__date--current": t.current,
205
- "bb-base-date-picker__date--disabled": e.disabled || t.disabled,
206
- "bb-base-date-picker__date--first": t.first,
207
- "bb-base-date-picker__date--highlighted": t.highlighted,
208
- "bb-base-date-picker__date--last": t.last,
209
- "bb-base-date-picker__date--middle": t.middle,
210
- "bb-base-date-picker__date--selected": t.selected,
211
- "bb-base-date-picker__date--today": t.today,
212
- "bb-base-date-picker__date": !0
213
- })
214
- }, [
215
- M("button", {
216
- id: t.buttonId,
217
- class: k("bb-base-date-picker__date-button"),
218
- disabled: e.disabled || t.disabled,
219
- tabindex: Number(t.current) - 1,
220
- type: "button",
221
- onClick: H
222
- }, C(t.label), 9, Oe),
223
- L(e.$slots, "day", {
224
- first: t.first,
225
- highlighted: t.highlighted,
226
- item: t.original,
227
- label: t.label,
228
- last: t.last,
229
- middle: t.middle,
230
- selected: t.selected
231
- }),
232
- L(e.$slots, t.slotName, {
233
- first: t.first,
234
- highlighted: t.highlighted,
235
- item: t.original,
236
- label: t.label,
237
- last: t.last,
238
- middle: t.middle,
239
- selected: t.selected
240
- })
241
- ], 2))), 128))
242
- ]))), 128))
243
- ]))
244
- ]),
245
- _: 3
246
- }, 8, ["direction"])
247
- ], 42, ye));
248
- }
249
- });
1
+ const r = (e) => typeof e > "u" || e === null;
250
2
  export {
251
- Ce as default
3
+ r as isNil
252
4
  };
package/dist/index261.js CHANGED
@@ -1,54 +1,185 @@
1
- import { defineComponent as p, ref as b, watch as _, computed as m, createElementBlock as d, openBlock as c, normalizeClass as u, createElementVNode as t, createVNode as h, withCtx as f, toDisplayString as o } from "vue";
2
- import k from "./index263.js";
3
- const y = { class: "bb-base-date-picker__year-container" }, v = {
4
- "aria-live": "polite",
5
- class: "bb-base-date-picker__selected-day-label"
6
- }, B = { class: "bb-base-date-picker__weekday" }, D = { class: "bb-base-date-picker__monthday" }, M = { class: "bb-base-date-picker__month-button" }, C = /* @__PURE__ */ p({
7
- __name: "BaseDatePickerHeader",
8
- props: {
9
- cursor: {},
10
- disabled: { type: Boolean },
11
- hidden: { type: Boolean }
12
- },
13
- emits: ["mode:year", "mode:month"],
14
- setup(n) {
15
- const s = n, r = b("top"), l = (e, a) => {
16
- e && a && (r.value = e.isBefore(a) ? "top" : "bottom");
1
+ var w = Object.defineProperty, C = (a, e, t) => e in a ? w(a, e, { enumerable: !0, configurable: !0, writable: !0, value: t }) : a[e] = t, A = (a, e, t) => C(a, typeof e != "symbol" ? e + "" : e, t);
2
+ const R = {
3
+ "#": { pattern: /[0-9]/ },
4
+ "@": { pattern: /[a-zA-Z]/ },
5
+ "*": { pattern: /[a-zA-Z0-9]/ }
6
+ }, N = (a, e, t) => a.replaceAll(e, "").replace(t, ".").replace("..", ".").replace(/[^.\d]/g, ""), I = (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 = I(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 = N(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 = I(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 = N(d, m, f), u + d;
26
+ };
27
+ class T {
28
+ constructor(e = {}) {
29
+ A(this, "opts", {}), A(this, "memo", /* @__PURE__ */ new Map());
30
+ const t = { ...e };
31
+ if (t.tokens != null) {
32
+ t.tokens = t.tokensReplace ? { ...t.tokens } : { ...R, ...t.tokens };
33
+ for (const s of Object.values(t.tokens))
34
+ typeof s.pattern == "string" && (s.pattern = new RegExp(s.pattern));
35
+ } else
36
+ t.tokens = R;
37
+ 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;
38
+ }
39
+ masked(e) {
40
+ return this.process(String(e), this.findMask(String(e)));
41
+ }
42
+ unmasked(e) {
43
+ return this.process(String(e), this.findMask(String(e)), !1);
44
+ }
45
+ isEager() {
46
+ return this.opts.eager === !0;
47
+ }
48
+ isReversed() {
49
+ return this.opts.reversed === !0;
50
+ }
51
+ completed(e) {
52
+ const t = this.findMask(String(e));
53
+ if (this.opts.mask == null || t == null) return !1;
54
+ const s = this.process(String(e), t).length;
55
+ return typeof this.opts.mask == "string" ? s >= this.opts.mask.length : s >= t.length;
56
+ }
57
+ findMask(e) {
58
+ const t = this.opts.mask;
59
+ if (t == null)
60
+ return null;
61
+ if (typeof t == "string")
62
+ return t;
63
+ if (typeof t == "function")
64
+ return t(e);
65
+ const s = this.process(e, t.slice(-1).pop() ?? "", !1);
66
+ return t.find((r) => this.process(e, r, !1).length >= s.length) ?? "";
67
+ }
68
+ escapeMask(e) {
69
+ const t = [], s = [];
70
+ return e.split("").forEach((r, n) => {
71
+ r === "!" && e[n - 1] !== "!" ? s.push(n - s.length) : t.push(r);
72
+ }), { mask: t.join(""), escaped: s };
73
+ }
74
+ process(e, t, s = !0) {
75
+ if (this.opts.number != null) return P(e, s, this.opts);
76
+ if (t == null) return e;
77
+ const r = `v=${e},mr=${t},m=${s ? 1 : 0}`;
78
+ if (this.memo.has(r)) return this.memo.get(r);
79
+ 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;
80
+ let v, d = -1, i = this.isReversed() ? n.length - 1 : 0, h = this.isReversed() ? e.length - 1 : 0, M = !1;
81
+ for (; f(); ) {
82
+ const b = n.charAt(i), g = p[b], y = (g == null ? void 0 : g.transform) != null ? g.transform(e.charAt(h)) : e.charAt(h);
83
+ if (!l.includes(i) && g != null ? (y.match(g.pattern) != null ? (u[k](y), g.repeated ? (d === -1 ? d = i : i === m && i !== d && (i = d - o), m === d && (i -= o)) : g.multiple && (M = !0, i -= o), i += o) : g.multiple ? M && (i += o, h -= o, M = !1) : y === v ? v = void 0 : g.optional && (i += o, h -= o), h += o) : (s && !this.isEager() && u[k](b), y === b && !this.isEager() ? h += o : v = b, this.isEager() || (i += o)), this.isEager())
84
+ for (; c(i) && (p[n.charAt(i)] == null || l.includes(i)); ) {
85
+ if (s) {
86
+ if (u[k](n.charAt(i)), e.charAt(h) === n.charAt(i)) {
87
+ i += o, h += o;
88
+ continue;
89
+ }
90
+ } else n.charAt(i) === e.charAt(h) && (h += o);
91
+ i += o;
92
+ }
93
+ }
94
+ return this.memo.set(r, u.join("")), this.memo.get(r);
95
+ }
96
+ }
97
+ const S = (a) => JSON.parse(a.replaceAll("'", '"')), F = (a, e = {}) => {
98
+ const t = { ...e };
99
+ a.dataset.maska != null && a.dataset.maska !== "" && (t.mask = W(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 = x(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 = E(a.dataset.maskaNumberUnsigned)), (a.dataset.maskaNumber != null || Object.values(s).length > 0) && (t.number = s), t;
102
+ }, E = (a) => a !== "" ? !!JSON.parse(a) : !0, W = (a) => a.startsWith("[") && a.endsWith("]") ? S(a) : a, x = (a) => {
103
+ if (a.startsWith("{") && a.endsWith("}"))
104
+ return S(a);
105
+ const e = {};
106
+ return a.split("|").forEach((t) => {
107
+ const s = t.split(":");
108
+ e[s[0]] = {
109
+ pattern: new RegExp(s[1]),
110
+ optional: s[2] === "optional",
111
+ multiple: s[2] === "multiple",
112
+ repeated: s[2] === "repeated"
17
113
  };
18
- _(
19
- () => s.cursor,
20
- (e, a) => {
21
- l(e, a);
114
+ }), e;
115
+ };
116
+ class O {
117
+ constructor(e, t = {}) {
118
+ A(this, "items", /* @__PURE__ */ new Map()), A(this, "eventAbortController"), A(this, "onInput", (s) => {
119
+ if (s instanceof CustomEvent && s.type === "input" && !s.isTrusted && !s.bubbles)
120
+ return;
121
+ const r = s.target, n = this.items.get(r);
122
+ if (n === void 0) return;
123
+ const l = "inputType" in s && s.inputType.startsWith("delete"), u = n.isEager(), p = l && u && n.unmasked(r.value) === "" ? "" : r.value;
124
+ this.fixCursor(r, l, () => this.setValue(r, p));
125
+ }), this.options = t, this.eventAbortController = new AbortController(), this.init(this.getInputs(e));
126
+ }
127
+ update(e = {}) {
128
+ this.options = { ...e }, this.init(Array.from(this.items.keys()));
129
+ }
130
+ updateValue(e) {
131
+ var t;
132
+ e.value !== "" && e.value !== ((t = this.processInput(e)) == null ? void 0 : t.masked) && this.setValue(e, e.value);
133
+ }
134
+ destroy() {
135
+ this.eventAbortController.abort(), this.items.clear();
136
+ }
137
+ init(e) {
138
+ const t = this.getOptions(this.options);
139
+ for (const s of e) {
140
+ if (!this.items.has(s)) {
141
+ const { signal: n } = this.eventAbortController;
142
+ s.addEventListener("input", this.onInput, { capture: !0, signal: n });
22
143
  }
23
- );
24
- const i = m(() => s.cursor.format("YYYY"));
25
- return (e, a) => (c(), d("div", {
26
- class: u(["bb-base-date-picker__header", { "bb-base-date-picker__header--hidden": e.hidden }])
27
- }, [
28
- t("div", y, [
29
- h(k, {
30
- direction: r.value,
31
- duration: 500,
32
- gap: 30
33
- }, {
34
- default: f(() => [
35
- (c(), d("span", {
36
- key: i.value,
37
- "aria-live": "polite",
38
- class: "bb-base-date-picker__year-button"
39
- }, o(i.value), 1))
40
- ]),
41
- _: 1
42
- }, 8, ["direction"])
43
- ]),
44
- t("div", v, [
45
- t("span", B, o(e.cursor.format("ddd")) + ", ", 1),
46
- t("span", D, o(e.cursor.format("DD")), 1),
47
- t("span", M, o(e.cursor.format("MMMM")), 1)
48
- ])
49
- ], 2));
50
- }
51
- });
144
+ const r = new T(F(s, t));
145
+ 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);
146
+ }
147
+ }
148
+ getInputs(e) {
149
+ return typeof e == "string" ? Array.from(document.querySelectorAll(e)) : "length" in e ? Array.from(e) : [e];
150
+ }
151
+ getOptions(e) {
152
+ const { onMaska: t, preProcess: s, postProcess: r, ...n } = e;
153
+ return n;
154
+ }
155
+ fixCursor(e, t, s) {
156
+ var r, n;
157
+ const l = e.selectionStart, u = e.value;
158
+ if (s(), l === null || l === u.length && !t) return;
159
+ 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;
160
+ if (m === void 0 || f === void 0) return;
161
+ let c = l;
162
+ o !== k && (c += t ? p.length - u.length : m.length - f.length), e.setSelectionRange(c, c);
163
+ }
164
+ setValue(e, t) {
165
+ const s = this.processInput(e, t);
166
+ 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 })));
167
+ }
168
+ processInput(e, t) {
169
+ const s = this.items.get(e);
170
+ if (s === void 0) return;
171
+ let r = t ?? e.value;
172
+ this.options.preProcess != null && (r = this.options.preProcess(r));
173
+ let n = s.masked(r);
174
+ return this.options.postProcess != null && (n = this.options.postProcess(n)), {
175
+ masked: n,
176
+ unmasked: s.unmasked(r),
177
+ completed: s.completed(r)
178
+ };
179
+ }
180
+ }
52
181
  export {
53
- C as default
182
+ T as Mask,
183
+ O as MaskInput,
184
+ R as tokens
54
185
  };
package/dist/index262.js CHANGED
@@ -1,46 +1,12 @@
1
- import { defineComponent as _, computed as a, createElementBlock as c, openBlock as o, 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
- })
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
- ]));
42
- }
43
- });
1
+ const o = (t, r) => {
2
+ const e = {};
3
+ for (const c in t)
4
+ if (Object.prototype.hasOwnProperty.call(t, c)) {
5
+ const n = t[c];
6
+ r(n, c, t) && (e[c] = n);
7
+ }
8
+ return e;
9
+ };
44
10
  export {
45
- E as default
11
+ o as pickBy
46
12
  };
package/dist/index263.js CHANGED
@@ -1,7 +1,5 @@
1
- import o from "./index318.js";
2
- /* empty css */
3
- import t from "./index294.js";
4
- const m = /* @__PURE__ */ t(o, [["__scopeId", "data-v-8c6b13bd"]]);
1
+ const o = () => {
2
+ };
5
3
  export {
6
- m as default
4
+ o as noop
7
5
  };