bitboss-ui 2.1.10 → 2.1.11

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 (181) hide show
  1. package/dist/components/BaseDatePickerInput/BaseDatePickerInput.vue.d.ts +2 -2
  2. package/dist/index.css +1 -1
  3. package/dist/index106.js +9 -9
  4. package/dist/index111.js +1 -1
  5. package/dist/index113.js +1 -1
  6. package/dist/index121.js +12 -12
  7. package/dist/index13.js +1 -1
  8. package/dist/index131.js +4 -4
  9. package/dist/index133.js +1 -1
  10. package/dist/index136.js +1 -1
  11. package/dist/index137.js +2 -2
  12. package/dist/index138.js +1 -1
  13. package/dist/index15.js +8 -8
  14. package/dist/index17.js +3 -3
  15. package/dist/index19.js +8 -8
  16. package/dist/index206.js +138 -2
  17. package/dist/index207.js +2 -2
  18. package/dist/index208.js +2 -138
  19. package/dist/index209.js +13 -3
  20. package/dist/index21.js +16 -16
  21. package/dist/index210.js +13 -2
  22. package/dist/index211.js +11 -2
  23. package/dist/index212.js +2 -18
  24. package/dist/index213.js +4 -12
  25. package/dist/index214.js +2 -51
  26. package/dist/index215.js +66 -15
  27. package/dist/index217.js +13 -17
  28. package/dist/index218.js +181 -27
  29. package/dist/index219.js +5 -13
  30. package/dist/index220.js +5 -16
  31. package/dist/index221.js +5 -6
  32. package/dist/index222.js +5 -4
  33. package/dist/index223.js +5 -106
  34. package/dist/index224.js +7 -0
  35. package/dist/index225.js +2 -100
  36. package/dist/index226.js +4 -0
  37. package/dist/index227.js +2 -66
  38. package/dist/index228.js +22 -0
  39. package/dist/index229.js +113 -13
  40. package/dist/index23.js +155 -153
  41. package/dist/index231.js +6 -0
  42. package/dist/index232.js +189 -222
  43. package/dist/index234.js +86 -2
  44. package/dist/index236.js +28 -6
  45. package/dist/index237.js +17 -7
  46. package/dist/index238.js +51 -5
  47. package/dist/index239.js +15 -5
  48. package/dist/index240.js +3 -5
  49. package/dist/index241.js +12 -5
  50. package/dist/index242.js +16 -5
  51. package/dist/index243.js +10 -5
  52. package/dist/index244.js +3 -2
  53. package/dist/index245.js +2 -11
  54. package/dist/index246.js +7 -18
  55. package/dist/index247.js +23 -2
  56. package/dist/index248.js +9 -5
  57. package/dist/index249.js +8 -5
  58. package/dist/index25.js +3 -3
  59. package/dist/index250.js +3 -8
  60. package/dist/index251.js +101 -245
  61. package/dist/index253.js +96 -40
  62. package/dist/index255.js +6 -60
  63. package/dist/index256.js +15 -85
  64. package/dist/index257.js +36 -0
  65. package/dist/index258.js +3 -34
  66. package/dist/index259.js +5 -4
  67. package/dist/index260.js +5 -197
  68. package/dist/index261.js +10 -0
  69. package/dist/index262.js +250 -3
  70. package/dist/index263.js +51 -12
  71. package/dist/index264.js +44 -183
  72. package/dist/index265.js +4 -5
  73. package/dist/index266.js +59 -15
  74. package/dist/index267.js +9 -3
  75. package/dist/index268.js +16 -7
  76. package/dist/index269.js +12 -23
  77. package/dist/index27.js +1 -1
  78. package/dist/index270.js +6 -9
  79. package/dist/index271.js +230 -10
  80. package/dist/index272.js +2 -3
  81. package/dist/index273.js +7 -9
  82. package/dist/index274.js +7 -8
  83. package/dist/index275.js +2 -5
  84. package/dist/index276.js +5 -2
  85. package/dist/index277.js +1 -1
  86. package/dist/index278.js +1 -1
  87. package/dist/index279.js +1 -1
  88. package/dist/index280.js +4 -3
  89. package/dist/index281.js +7 -3
  90. package/dist/index282.js +11 -3
  91. package/dist/index283.js +5 -0
  92. package/dist/index285.js +7 -17
  93. package/dist/index286.js +3 -28
  94. package/dist/index287.js +3 -4
  95. package/dist/index288.js +4 -3
  96. package/dist/index289.js +280 -2
  97. package/dist/index29.js +4 -4
  98. package/dist/index290.js +2 -7
  99. package/dist/index291.js +124 -10
  100. package/dist/index292.js +2 -4
  101. package/dist/index293.js +13 -278
  102. package/dist/index294.js +2 -2
  103. package/dist/index299.js +1 -1
  104. package/dist/index301.js +3 -15
  105. package/dist/index302.js +17 -2
  106. package/dist/index303.js +27 -18
  107. package/dist/index304.js +6 -2
  108. package/dist/index305.js +5 -27
  109. package/dist/index306.js +3 -2
  110. package/dist/index307.js +3 -2
  111. package/dist/index308.js +718 -2
  112. package/dist/index309.js +366 -2
  113. package/dist/index31.js +2 -2
  114. package/dist/index310.js +58 -2
  115. package/dist/index311.js +1 -21
  116. package/dist/index312.js +7 -0
  117. package/dist/index313.js +19 -2
  118. package/dist/index314.js +2 -3
  119. package/dist/index315.js +26 -5
  120. package/dist/index316.js +2 -125
  121. package/dist/index317.js +2 -2
  122. package/dist/index318.js +2 -3
  123. package/dist/index319.js +2 -5
  124. package/dist/index320.js +2 -718
  125. package/dist/index321.js +22 -366
  126. package/dist/index323.js +2 -5
  127. package/dist/index324.js +2 -33
  128. package/dist/index325.js +33 -28
  129. package/dist/index326.js +30 -0
  130. package/dist/index328.js +128 -6
  131. package/dist/index329.js +366 -16
  132. package/dist/index33.js +8 -8
  133. package/dist/index330.js +58 -47
  134. package/dist/index331.js +58 -7
  135. package/dist/index332.js +7 -128
  136. package/dist/index333.js +5 -368
  137. package/dist/index334.js +8 -228
  138. package/dist/index335.js +92 -7
  139. package/dist/index336.js +227 -5
  140. package/dist/index337.js +7 -8
  141. package/dist/index338.js +17 -91
  142. package/dist/index339.js +7 -58
  143. package/dist/index340.js +47 -58
  144. package/dist/index342.js +1 -1
  145. package/dist/index343.js +124 -483
  146. package/dist/index344.js +430 -44
  147. package/dist/index345.js +121 -123
  148. package/dist/index346.js +473 -421
  149. package/dist/index347.js +48 -125
  150. package/dist/index35.js +4 -4
  151. package/dist/index37.js +20 -20
  152. package/dist/index39.js +8 -8
  153. package/dist/index41.js +2 -2
  154. package/dist/index43.js +8 -8
  155. package/dist/index45.js +8 -8
  156. package/dist/index47.js +2 -2
  157. package/dist/index49.js +3 -3
  158. package/dist/index53.js +1 -1
  159. package/dist/index55.js +1 -1
  160. package/dist/index57.js +2 -2
  161. package/dist/index61.js +3 -3
  162. package/dist/index67.js +1 -1
  163. package/dist/index79.js +4 -4
  164. package/dist/index81.js +1 -1
  165. package/dist/index83.js +2 -2
  166. package/dist/index85.js +1 -1
  167. package/dist/index87.js +1 -1
  168. package/dist/index90.js +3 -3
  169. package/dist/index92.js +2 -2
  170. package/dist/index94.js +3 -3
  171. package/dist/index96.js +1 -1
  172. package/package.json +1 -1
  173. package/dist/index216.js +0 -14
  174. package/dist/index230.js +0 -115
  175. package/dist/index233.js +0 -4
  176. package/dist/index235.js +0 -4
  177. package/dist/index252.js +0 -54
  178. package/dist/index254.js +0 -7
  179. package/dist/index284.js +0 -9
  180. package/dist/index322.js +0 -60
  181. package/dist/index327.js +0 -4
package/dist/index262.js CHANGED
@@ -1,5 +1,252 @@
1
- import r from "./index319.js";
2
- const t = r;
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 "./index225.js";
4
+ import { isNotNil as me } from "./index140.js";
5
+ import { last as ge } from "./index227.js";
6
+ import { sort as E } from "./index338.js";
7
+ import b from "./index219.js";
8
+ import he from "./index265.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
+ });
3
250
  export {
4
- t as deburr
251
+ Ce as default
5
252
  };
package/dist/index263.js CHANGED
@@ -1,15 +1,54 @@
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}`);
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 "./index265.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");
17
+ };
18
+ _(
19
+ () => s.cursor,
20
+ (e, a) => {
21
+ l(e, a);
22
+ }
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));
10
50
  }
11
- return t + "px";
12
- };
51
+ });
13
52
  export {
14
- c as parseSize
53
+ C as default
15
54
  };
package/dist/index264.js CHANGED
@@ -1,185 +1,46 @@
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"
113
- };
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 });
143
- }
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
- }
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
+ });
181
44
  export {
182
- T as Mask,
183
- O as MaskInput,
184
- R as tokens
45
+ E as default
185
46
  };
package/dist/index265.js CHANGED
@@ -1,8 +1,7 @@
1
- import e from "./index320.js";
2
1
  import o from "./index321.js";
3
- import r from "./index322.js";
4
- const f = new r(o, e)._freeze();
2
+ /* empty css */
3
+ import t from "./index285.js";
4
+ const m = /* @__PURE__ */ t(o, [["__scopeId", "data-v-8c6b13bd"]]);
5
5
  export {
6
- r as Mime,
7
- f as default
6
+ m as default
8
7
  };
package/dist/index266.js CHANGED
@@ -1,18 +1,62 @@
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;
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 "./index339.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));
13
58
  }
14
- return t;
15
- }, null);
59
+ });
16
60
  export {
17
- e as findInTree
61
+ V as default
18
62
  };
package/dist/index267.js CHANGED
@@ -1,5 +1,11 @@
1
- import t from "./index323.js";
2
- const r = t;
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
+ }
3
9
  export {
4
- r as throttle
10
+ u as debounce
5
11
  };