bitboss-ui 2.1.0 → 2.1.2
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.
- package/dist/components/BaseButton/BaseButton.vue.d.ts +1 -1
- package/dist/components/BaseDialog/BaseDialog.vue.d.ts +1 -1
- package/dist/components/BaseNumberInput/BaseNumberInput.vue.d.ts +2 -0
- package/dist/components/BbNumberInput/BbNumberInput.vue.d.ts +10 -2
- package/dist/components/BbOffCanvas/BbOffCanvas.vue.d.ts +1 -1
- package/dist/components/BbPopover/BbPopover.vue.d.ts +1 -1
- package/dist/components/BbSmoothHeight/BbSmoothHeight.vue.d.ts +2 -2
- package/dist/components/BbTooltip/BbTooltip.vue.d.ts +1 -1
- package/dist/index.css +1 -1
- package/dist/index106.js +9 -9
- package/dist/index111.js +1 -1
- package/dist/index113.js +1 -1
- package/dist/index121.js +12 -12
- package/dist/index129.js +1 -1
- package/dist/index13.js +1 -1
- package/dist/index131.js +4 -4
- package/dist/index133.js +1 -1
- package/dist/index136.js +1 -1
- package/dist/index137.js +2 -2
- package/dist/index139.js +2 -2
- package/dist/index15.js +8 -8
- package/dist/index17.js +3 -3
- package/dist/index19.js +8 -8
- package/dist/index206.js +138 -2
- package/dist/index207.js +2 -138
- package/dist/index209.js +86 -2
- package/dist/index21.js +16 -16
- package/dist/index211.js +29 -2
- package/dist/index212.js +17 -66
- package/dist/index213.js +53 -0
- package/dist/index214.js +15 -13
- package/dist/index215.js +3 -13
- package/dist/index216.js +12 -13
- package/dist/index217.js +15 -10
- package/dist/index218.js +4 -5
- package/dist/index219.js +13 -5
- package/dist/index220.js +11 -5
- package/dist/index221.js +20 -5
- package/dist/index222.js +197 -5
- package/dist/index224.js +66 -2
- package/dist/index226.js +13 -2
- package/dist/index227.js +111 -18
- package/dist/index229.js +36 -0
- package/dist/index23.js +15 -15
- package/dist/index230.js +2 -86
- package/dist/index231.js +4 -0
- package/dist/index232.js +17 -28
- package/dist/index233.js +11 -15
- package/dist/index234.js +6 -17
- package/dist/index235.js +4 -51
- package/dist/index236.js +106 -15
- package/dist/index238.js +100 -12
- package/dist/index240.js +219 -188
- package/dist/index241.js +5 -0
- package/dist/index242.js +2 -5
- package/dist/index243.js +2 -5
- package/dist/index244.js +12 -7
- package/dist/index245.js +5 -250
- package/dist/index246.js +5 -52
- package/dist/index247.js +5 -44
- package/dist/index248.js +4 -4
- package/dist/index249.js +5 -60
- package/dist/index25.js +35 -42
- package/dist/index250.js +5 -18
- package/dist/index251.js +2 -12
- package/dist/index252.js +2 -6
- package/dist/index253.js +176 -105
- package/dist/index254.js +12 -0
- package/dist/index255.js +3 -100
- package/dist/index256.js +7 -0
- package/dist/index257.js +5 -228
- package/dist/index258.js +7 -176
- package/dist/index259.js +250 -2
- package/dist/index260.js +52 -3
- package/dist/index261.js +42 -32
- package/dist/index262.js +5 -2
- package/dist/index263.js +60 -10
- package/dist/index264.js +2 -3
- package/dist/index265.js +9 -6
- package/dist/index266.js +8 -16
- package/dist/index267.js +9 -3
- package/dist/index268.js +23 -9
- package/dist/index269.js +9 -9
- package/dist/index27.js +1 -1
- package/dist/index270.js +3 -23
- package/dist/index271.js +6 -9
- package/dist/index272.js +16 -8
- package/dist/index273.js +2 -5
- package/dist/index274.js +67 -8
- package/dist/index275.js +5 -2
- package/dist/index276.js +5 -67
- package/dist/index277.js +8 -5
- package/dist/index278.js +3 -4
- package/dist/index279.js +17 -3
- package/dist/index280.js +30 -0
- package/dist/index281.js +3 -7
- package/dist/index282.js +3 -7
- package/dist/index284.js +7 -4
- package/dist/index285.js +1 -1
- package/dist/index286.js +7 -3
- package/dist/index287.js +11 -3
- package/dist/index288.js +4 -17
- package/dist/index289.js +2 -28
- package/dist/index29.js +91 -87
- package/dist/index290.js +3 -280
- package/dist/index291.js +3 -2
- package/dist/index292.js +2 -125
- package/dist/index293.js +4 -2
- package/dist/index294.js +5 -15
- package/dist/index295.js +280 -2
- package/dist/index296.js +2 -16
- package/dist/index297.js +125 -2
- package/dist/index298.js +2 -16
- package/dist/index299.js +15 -2
- package/dist/index300.js +2 -19
- package/dist/index301.js +16 -2
- package/dist/index302.js +2 -19
- package/dist/index303.js +16 -2
- package/dist/index304.js +2 -27
- package/dist/index305.js +19 -2
- package/dist/index306.js +2 -2
- package/dist/index307.js +6 -2
- package/dist/index308.js +19 -2
- package/dist/index309.js +2 -2
- package/dist/index31.js +2 -2
- package/dist/index310.js +27 -22
- package/dist/index311.js +4 -0
- package/dist/index312.js +2 -3
- package/dist/index313.js +2 -3
- package/dist/index314.js +1 -1
- package/dist/index315.js +2 -6
- package/dist/index316.js +21 -1
- package/dist/index318.js +1 -1
- package/dist/index322.js +7 -32
- package/dist/index323.js +6 -28
- package/dist/index324.js +10 -0
- package/dist/index325.js +33 -2
- package/dist/index326.js +27 -128
- package/dist/index328.js +2 -8
- package/dist/index329.js +227 -5
- package/dist/index33.js +8 -8
- package/dist/index330.js +57 -7
- package/dist/index331.js +58 -47
- package/dist/index332.js +46 -6
- package/dist/index333.js +127 -17
- package/dist/index334.js +367 -56
- package/dist/index335.js +7 -58
- package/dist/index336.js +17 -226
- package/dist/index338.js +1 -1
- package/dist/index340.js +1 -1
- package/dist/index342.js +467 -421
- package/dist/index343.js +422 -113
- package/dist/index344.js +123 -478
- package/dist/index35.js +4 -4
- package/dist/index37.js +20 -20
- package/dist/index39.js +15 -15
- package/dist/index41.js +2 -2
- package/dist/index43.js +8 -8
- package/dist/index45.js +8 -8
- package/dist/index47.js +2 -2
- package/dist/index49.js +3 -3
- package/dist/index53.js +1 -1
- package/dist/index55.js +1 -1
- package/dist/index57.js +2 -2
- package/dist/index61.js +3 -3
- package/dist/index67.js +1 -1
- package/dist/index79.js +4 -4
- package/dist/index81.js +1 -1
- package/dist/index83.js +2 -2
- package/dist/index85.js +1 -1
- package/dist/index87.js +1 -1
- package/dist/index90.js +59 -66
- package/dist/index92.js +2 -2
- package/dist/index94.js +3 -3
- package/dist/index96.js +1 -1
- package/package.json +2 -2
- package/dist/index210.js +0 -6
- package/dist/index223.js +0 -7
- package/dist/index225.js +0 -4
- package/dist/index228.js +0 -115
- package/dist/index237.js +0 -5
- package/dist/index239.js +0 -6
- package/dist/index283.js +0 -13
- package/dist/index317.js +0 -7
- package/dist/index327.js +0 -371
package/dist/index258.js
CHANGED
@@ -1,179 +1,10 @@
|
|
1
|
-
|
2
|
-
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
}, N = (a, t, e) => a.replaceAll(t, "").replace(e, ".").replace("..", ".").replace(/[^.\d]/g, ""), I = (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
|
-
}, P = (a, t = !0, e) => {
|
14
|
-
var s, r, n, h;
|
15
|
-
const u = ((s = e.number) == null ? void 0 : s.unsigned) !== !0 && a.startsWith("-") ? "-" : "", l = ((r = e.number) == null ? void 0 : r.fraction) ?? 0;
|
16
|
-
let o = I(0, l, e);
|
17
|
-
const k = o.formatToParts(1000.12), c = ((n = k.find((i) => i.type === "group")) == null ? void 0 : n.value) ?? " ", b = ((h = k.find((i) => i.type === "decimal")) == null ? void 0 : h.value) ?? ".", f = N(a, c, b);
|
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 = I(i, l, e);
|
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}`);
|
23
6
|
}
|
24
|
-
|
25
|
-
return t ? l > 0 && f.endsWith(".") && !f.slice(0, -1).includes(".") && (m += b) : m = N(m, c, b), u + m;
|
26
|
-
};
|
27
|
-
class T {
|
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, r) => s.length - r.length) : e.mask = e.mask[0] ?? ""), e.mask === "" && (e.mask = null), this.opts = e;
|
38
|
-
}
|
39
|
-
masked(t) {
|
40
|
-
return this.process(String(t), this.findMask(String(t)));
|
41
|
-
}
|
42
|
-
unmasked(t) {
|
43
|
-
return this.process(String(t), this.findMask(String(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(String(t));
|
53
|
-
if (this.opts.mask == null || e == null) return !1;
|
54
|
-
const s = this.process(String(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((r) => this.process(t, r, !1).length >= s.length) ?? "";
|
67
|
-
}
|
68
|
-
escapeMask(t) {
|
69
|
-
const e = [], s = [];
|
70
|
-
return t.split("").forEach((r, n) => {
|
71
|
-
r === "!" && t[n - 1] !== "!" ? s.push(n - s.length) : e.push(r);
|
72
|
-
}), { mask: e.join(""), escaped: s };
|
73
|
-
}
|
74
|
-
process(t, e, s = !0) {
|
75
|
-
if (this.opts.number != null) return P(t, s, this.opts);
|
76
|
-
if (e == null) return t;
|
77
|
-
const r = `v=${t},mr=${e},m=${s ? 1 : 0}`;
|
78
|
-
if (this.memo.has(r)) return this.memo.get(r);
|
79
|
-
const { mask: n, 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 : n.length - 1, b = this.isReversed() ? () => i > -1 && p > -1 : () => i < n.length && p < t.length, f = (v) => !this.isReversed() && v <= c || this.isReversed() && v >= c;
|
80
|
-
let g, m = -1, i = this.isReversed() ? n.length - 1 : 0, p = this.isReversed() ? t.length - 1 : 0, M = !1;
|
81
|
-
for (; b(); ) {
|
82
|
-
const v = n.charAt(i), d = l[v], y = (d == null ? void 0 : d.transform) != null ? d.transform(t.charAt(p)) : t.charAt(p);
|
83
|
-
if (!h.includes(i) && d != null ? (y.match(d.pattern) != null ? (u[k](y), 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) : y === g ? g = void 0 : d.optional && (i += o, p -= o), p += o) : (s && !this.isEager() && u[k](v), y === v && !this.isEager() ? p += o : g = v, this.isEager() || (i += o)), this.isEager())
|
84
|
-
for (; f(i) && (l[n.charAt(i)] == null || h.includes(i)); ) {
|
85
|
-
if (s) {
|
86
|
-
if (u[k](n.charAt(i)), t.charAt(p) === n.charAt(i)) {
|
87
|
-
i += o, p += o;
|
88
|
-
continue;
|
89
|
-
}
|
90
|
-
} else n.charAt(i) === t.charAt(p) && (p += 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, t = {}) => {
|
98
|
-
const e = { ...t };
|
99
|
-
a.dataset.maska != null && a.dataset.maska !== "" && (e.mask = W(a.dataset.maska)), a.dataset.maskaEager != null && (e.eager = E(a.dataset.maskaEager)), a.dataset.maskaReversed != null && (e.reversed = E(a.dataset.maskaReversed)), a.dataset.maskaTokensReplace != null && (e.tokensReplace = E(a.dataset.maskaTokensReplace)), a.dataset.maskaTokens != null && (e.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) && (e.number = s), e;
|
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 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 O {
|
117
|
-
constructor(t, e = {}) {
|
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), h = "inputType" in s && s.inputType.startsWith("delete"), u = n.isEager(), l = h && u && n.unmasked(r.value) === "" ? "" : r.value;
|
122
|
-
this.fixCursor(r, h, () => this.setValue(r, l));
|
123
|
-
}), this.options = e, this.eventAbortController = new AbortController(), 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
|
-
this.eventAbortController.abort(), this.items.clear();
|
133
|
-
}
|
134
|
-
init(t) {
|
135
|
-
const e = this.getOptions(this.options);
|
136
|
-
for (const s of t) {
|
137
|
-
if (!this.items.has(s)) {
|
138
|
-
const { signal: n } = this.eventAbortController;
|
139
|
-
s.addEventListener("input", this.onInput, { capture: !0, signal: n });
|
140
|
-
}
|
141
|
-
const r = new T(F(s, e));
|
142
|
-
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);
|
143
|
-
}
|
144
|
-
}
|
145
|
-
getInputs(t) {
|
146
|
-
return typeof t == "string" ? Array.from(document.querySelectorAll(t)) : "length" in t ? Array.from(t) : [t];
|
147
|
-
}
|
148
|
-
getOptions(t) {
|
149
|
-
const { onMaska: e, preProcess: s, postProcess: r, ...n } = t;
|
150
|
-
return n;
|
151
|
-
}
|
152
|
-
fixCursor(t, e, s) {
|
153
|
-
const r = t.selectionStart, n = t.value;
|
154
|
-
if (s(), r === null || r === n.length && !e) return;
|
155
|
-
const h = t.value, u = n.slice(0, r), l = h.slice(0, r), o = this.processInput(t, u).unmasked, k = this.processInput(t, l).unmasked;
|
156
|
-
let c = r;
|
157
|
-
u !== l && (c += e ? h.length - n.length : o.length - k.length), t.setSelectionRange(c, c);
|
158
|
-
}
|
159
|
-
setValue(t, e) {
|
160
|
-
const s = this.processInput(t, e);
|
161
|
-
t.value = s.masked, this.options.onMaska != null && (Array.isArray(this.options.onMaska) ? this.options.onMaska.forEach((r) => r(s)) : this.options.onMaska(s)), t.dispatchEvent(new CustomEvent("maska", { detail: s })), t.dispatchEvent(new CustomEvent("input", { detail: s.masked }));
|
162
|
-
}
|
163
|
-
processInput(t, e) {
|
164
|
-
const s = this.items.get(t);
|
165
|
-
let r = e ?? t.value;
|
166
|
-
this.options.preProcess != null && (r = this.options.preProcess(r));
|
167
|
-
let n = s.masked(r);
|
168
|
-
return this.options.postProcess != null && (n = this.options.postProcess(n)), {
|
169
|
-
masked: n,
|
170
|
-
unmasked: s.unmasked(r),
|
171
|
-
completed: s.completed(r)
|
172
|
-
};
|
173
|
-
}
|
174
|
-
}
|
7
|
+
});
|
175
8
|
export {
|
176
|
-
|
177
|
-
O as MaskInput,
|
178
|
-
R as tokens
|
9
|
+
e as useLogger
|
179
10
|
};
|
package/dist/index259.js
CHANGED
@@ -1,4 +1,252 @@
|
|
1
|
-
|
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 "./index335.js";
|
3
|
+
import { identity as T } from "./index251.js";
|
4
|
+
import { isNotNil as me } from "./index140.js";
|
5
|
+
import { last as ge } from "./index231.js";
|
6
|
+
import { sort as E } from "./index336.js";
|
7
|
+
import b from "./index245.js";
|
8
|
+
import he from "./index262.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
|
+
});
|
2
250
|
export {
|
3
|
-
|
251
|
+
Ce as default
|
4
252
|
};
|
package/dist/index260.js
CHANGED
@@ -1,5 +1,54 @@
|
|
1
|
-
import
|
2
|
-
|
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 "./index262.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));
|
50
|
+
}
|
51
|
+
});
|
3
52
|
export {
|
4
|
-
|
53
|
+
C as default
|
5
54
|
};
|
package/dist/index261.js
CHANGED
@@ -1,36 +1,46 @@
|
|
1
|
-
import { defineComponent as
|
2
|
-
import
|
3
|
-
|
4
|
-
const
|
5
|
-
__name: "
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
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
|
+
]));
|
32
42
|
}
|
33
43
|
});
|
34
44
|
export {
|
35
|
-
|
45
|
+
E as default
|
36
46
|
};
|
package/dist/index262.js
CHANGED
package/dist/index263.js
CHANGED
@@ -1,12 +1,62 @@
|
|
1
|
-
|
2
|
-
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
}
|
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 "./index337.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
|
+
});
|
10
60
|
export {
|
11
|
-
|
61
|
+
V as default
|
12
62
|
};
|
package/dist/index264.js
CHANGED