@7pmlabs/design-system 1.0.9 → 1.0.10

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 (126) hide show
  1. package/dist/design-system.css +1 -1
  2. package/dist/design-system.js +24 -16
  3. package/dist/design-system177.js +29 -326
  4. package/dist/design-system177.js.map +1 -1
  5. package/dist/design-system179.js +1 -1
  6. package/dist/design-system179.js.map +1 -1
  7. package/dist/design-system180.js +73 -85
  8. package/dist/design-system180.js.map +1 -1
  9. package/dist/design-system182.js +1 -1
  10. package/dist/design-system182.js.map +1 -1
  11. package/dist/design-system183.js +32 -105
  12. package/dist/design-system183.js.map +1 -1
  13. package/dist/design-system185.js +4 -5
  14. package/dist/design-system185.js.map +1 -1
  15. package/dist/design-system186.js +26 -104
  16. package/dist/design-system186.js.map +1 -1
  17. package/dist/design-system188.js +4 -5
  18. package/dist/design-system188.js.map +1 -1
  19. package/dist/design-system189.js +23 -727
  20. package/dist/design-system189.js.map +1 -1
  21. package/dist/design-system191.js +1 -1
  22. package/dist/design-system191.js.map +1 -1
  23. package/dist/design-system192.js +31 -11
  24. package/dist/design-system192.js.map +1 -1
  25. package/dist/design-system194.js +8 -0
  26. package/dist/design-system194.js.map +1 -0
  27. package/dist/design-system195.js +332 -5
  28. package/dist/design-system195.js.map +1 -1
  29. package/dist/design-system197.js +5 -46
  30. package/dist/design-system197.js.map +1 -1
  31. package/dist/design-system198.js +100 -4
  32. package/dist/design-system198.js.map +1 -1
  33. package/dist/design-system200.js +8 -0
  34. package/dist/design-system200.js.map +1 -0
  35. package/dist/design-system201.js +19 -5
  36. package/dist/design-system201.js.map +1 -1
  37. package/dist/design-system202.js +4 -119
  38. package/dist/design-system202.js.map +1 -1
  39. package/dist/design-system203.js +6 -0
  40. package/dist/design-system203.js.map +1 -0
  41. package/dist/design-system204.js +419 -5
  42. package/dist/design-system204.js.map +1 -1
  43. package/dist/design-system206.js +8 -0
  44. package/dist/design-system206.js.map +1 -0
  45. package/dist/design-system207.js +108 -5
  46. package/dist/design-system207.js.map +1 -1
  47. package/dist/design-system209.js +6 -4
  48. package/dist/design-system209.js.map +1 -1
  49. package/dist/design-system210.js +90 -154
  50. package/dist/design-system210.js.map +1 -1
  51. package/dist/design-system212.js +5 -4
  52. package/dist/design-system212.js.map +1 -1
  53. package/dist/design-system213.js +737 -7
  54. package/dist/design-system213.js.map +1 -1
  55. package/dist/design-system215.js +8 -0
  56. package/dist/design-system215.js.map +1 -0
  57. package/dist/design-system216.js +11 -5
  58. package/dist/design-system216.js.map +1 -1
  59. package/dist/design-system217.js +451 -506
  60. package/dist/design-system217.js.map +1 -1
  61. package/dist/design-system219.js +4 -5
  62. package/dist/design-system219.js.map +1 -1
  63. package/dist/design-system220.js +3 -7
  64. package/dist/design-system220.js.map +1 -1
  65. package/dist/design-system221.js +41 -369
  66. package/dist/design-system221.js.map +1 -1
  67. package/dist/design-system222.js +7 -0
  68. package/dist/design-system222.js.map +1 -0
  69. package/dist/design-system223.js +283 -6
  70. package/dist/design-system223.js.map +1 -1
  71. package/dist/design-system225.js +8 -0
  72. package/dist/design-system225.js.map +1 -0
  73. package/dist/design-system226.js +122 -0
  74. package/dist/design-system226.js.map +1 -0
  75. package/dist/design-system228.js +8 -0
  76. package/dist/design-system228.js.map +1 -0
  77. package/dist/{design-system205.js → design-system229.js} +1 -1
  78. package/dist/{design-system205.js.map → design-system229.js.map} +1 -1
  79. package/dist/design-system231.js +8 -0
  80. package/dist/design-system231.js.map +1 -0
  81. package/dist/{design-system208.js → design-system232.js} +1 -1
  82. package/dist/{design-system208.js.map → design-system232.js.map} +1 -1
  83. package/dist/design-system233.js +7 -0
  84. package/dist/design-system233.js.map +1 -0
  85. package/dist/design-system234.js +173 -0
  86. package/dist/design-system234.js.map +1 -0
  87. package/dist/design-system236.js +8 -0
  88. package/dist/design-system236.js.map +1 -0
  89. package/dist/design-system237.js +10 -0
  90. package/dist/design-system237.js.map +1 -0
  91. package/dist/{design-system214.js → design-system238.js} +2 -2
  92. package/dist/{design-system214.js.map → design-system238.js.map} +1 -1
  93. package/dist/design-system240.js +8 -0
  94. package/dist/design-system240.js.map +1 -0
  95. package/dist/design-system241.js +583 -0
  96. package/dist/design-system241.js.map +1 -0
  97. package/dist/design-system243.js +9 -0
  98. package/dist/design-system243.js.map +1 -0
  99. package/dist/design-system244.js +10 -0
  100. package/dist/design-system244.js.map +1 -0
  101. package/dist/design-system245.js +377 -0
  102. package/dist/design-system245.js.map +1 -0
  103. package/dist/design-system247.js +9 -0
  104. package/dist/design-system247.js.map +1 -0
  105. package/dist/types/components/BSkeleton/BSkeleton.spec.d.ts +1 -0
  106. package/dist/types/components/BSkeleton/BSkeleton.vue.d.ts +46 -0
  107. package/dist/types/components/BSkeleton/BSkeletonAvatar.vue.d.ts +12 -0
  108. package/dist/types/components/BSkeleton/BSkeletonButton.vue.d.ts +14 -0
  109. package/dist/types/components/BSkeleton/BSkeletonImage.vue.d.ts +7 -0
  110. package/dist/types/components/BSkeleton/BSkeletonInput.vue.d.ts +12 -0
  111. package/dist/types/components/BSkeleton/BSkeletonNode.vue.d.ts +19 -0
  112. package/dist/types/components/BSkeleton/index.d.ts +7 -0
  113. package/dist/types/components/BSkeleton/types.d.ts +20 -0
  114. package/dist/types/components/BSplitter/BSplitter.spec.d.ts +1 -0
  115. package/dist/types/components/BSplitter/BSplitter.vue.d.ts +45 -0
  116. package/dist/types/components/BSplitter/BSplitterPanel.vue.d.ts +40 -0
  117. package/dist/types/components/BSplitter/index.d.ts +3 -0
  118. package/dist/types/components/BSplitter/types.d.ts +42 -0
  119. package/dist/types/components/index.d.ts +2 -0
  120. package/package.json +1 -1
  121. package/dist/design-system193.js +0 -528
  122. package/dist/design-system193.js.map +0 -1
  123. package/dist/design-system196.js +0 -6
  124. package/dist/design-system196.js.map +0 -1
  125. package/dist/design-system199.js +0 -286
  126. package/dist/design-system199.js.map +0 -1
@@ -1,528 +0,0 @@
1
- import { useComponentId as e } from "./design-system10.js";
2
- import { BTimePickerPlacement as t, BTimePickerSize as n, BTimePickerVariant as r } from "./design-system192.js";
3
- import { Fragment as i, computed as a, createCommentVNode as o, createElementBlock as s, createElementVNode as c, defineComponent as l, mergeModels as u, nextTick as d, normalizeClass as f, normalizeStyle as ee, onBeforeUnmount as te, onMounted as ne, openBlock as p, ref as m, renderList as h, toDisplayString as g, unref as _, useModel as re, watch as ie } from "vue";
4
- //#region src/components/BTimePicker/BTimePicker.vue?vue&type=script&setup=true&lang.ts
5
- var ae = [
6
- "id",
7
- "aria-expanded",
8
- "aria-controls",
9
- "aria-describedby",
10
- "aria-label",
11
- "placeholder",
12
- "disabled",
13
- "readonly",
14
- "value"
15
- ], oe = { class: "b-time-picker__suffix" }, se = {
16
- key: 0,
17
- class: "b-time-picker__icon",
18
- "aria-hidden": "true",
19
- viewBox: "0 0 24 24",
20
- fill: "none",
21
- stroke: "currentColor",
22
- "stroke-width": "2"
23
- }, ce = ["id"], le = ["id"], ue = {
24
- class: "b-time-picker__columns",
25
- role: "group",
26
- "aria-label": "Time selection columns"
27
- }, de = ["aria-activedescendant"], fe = [
28
- "id",
29
- "aria-selected",
30
- "aria-disabled",
31
- "onClick"
32
- ], pe = ["aria-activedescendant"], me = [
33
- "id",
34
- "aria-selected",
35
- "aria-disabled",
36
- "onClick"
37
- ], he = ["aria-activedescendant"], ge = [
38
- "id",
39
- "aria-selected",
40
- "aria-disabled",
41
- "onClick"
42
- ], _e = ["aria-selected"], ve = ["aria-selected"], ye = {
43
- key: 0,
44
- class: "b-time-picker__footer"
45
- }, v = /* @__PURE__ */ l({
46
- __name: "BTimePicker",
47
- props: /* @__PURE__ */ u({
48
- size: { default: () => n.Medium },
49
- variant: { default: () => r.Outlined },
50
- placeholder: { default: "Select time" },
51
- disabled: {
52
- type: Boolean,
53
- default: !1
54
- },
55
- inputReadOnly: {
56
- type: Boolean,
57
- default: !1
58
- },
59
- allowClear: {
60
- type: Boolean,
61
- default: !0
62
- },
63
- showNow: {
64
- type: Boolean,
65
- default: !0
66
- },
67
- use12Hours: {
68
- type: Boolean,
69
- default: !1
70
- },
71
- hourStep: { default: 1 },
72
- minuteStep: { default: 1 },
73
- secondStep: { default: 1 },
74
- format: {},
75
- placement: { default: () => t.BottomLeft },
76
- status: {},
77
- hideDisabledOptions: {
78
- type: Boolean,
79
- default: !1
80
- },
81
- needConfirm: {
82
- type: Boolean,
83
- default: !0
84
- },
85
- changeOnScroll: {
86
- type: Boolean,
87
- default: !1
88
- },
89
- showHour: {
90
- type: Boolean,
91
- default: !0
92
- },
93
- showMinute: {
94
- type: Boolean,
95
- default: !0
96
- },
97
- showSecond: {
98
- type: Boolean,
99
- default: !0
100
- },
101
- defaultOpen: {
102
- type: Boolean,
103
- default: !1
104
- },
105
- defaultValue: {},
106
- open: { type: Boolean },
107
- disabledTime: { type: Function }
108
- }, {
109
- modelValue: { default: void 0 },
110
- modelModifiers: {}
111
- }),
112
- emits: /* @__PURE__ */ u(["change", "openChange"], ["update:modelValue"]),
113
- setup(t, { expose: n, emit: r }) {
114
- let l = re(t, "modelValue"), u = r, v = m(null), y = m(null), b = m(null), x = m(null), S = m(null), C = m(null);
115
- n({
116
- focus: () => v.value?.focus(),
117
- blur: () => v.value?.blur()
118
- });
119
- let { componentUID: w } = e(), T = a(() => `--b-time-picker-${w.value}`), E = m(t.defaultOpen), D = m(t.open === void 0 ? t.defaultOpen : !!t.open), be = m(t.defaultValue ?? null), O = m(null), k = m(null), A = m(null), j = m(null), M = m(""), N = m("hour"), P = a({
120
- get: () => l.value ?? be.value,
121
- set: (e) => {
122
- be.value = e, l.value = e;
123
- }
124
- }), xe = a(() => {
125
- if (t.format) return t.format;
126
- let e = [];
127
- t.showHour && e.push(t.use12Hours ? "hh" : "HH"), t.showMinute && e.push("mm"), t.showSecond && e.push("ss");
128
- let n = e.join(":");
129
- return t.use12Hours ? `${n} A` : n;
130
- });
131
- function F(e) {
132
- return String(e).padStart(2, "0");
133
- }
134
- function I(e) {
135
- if (!e) return "";
136
- let n = e.getHours(), r = e.getMinutes(), i = e.getSeconds(), a = n >= 12 ? "PM" : "AM", o = xe.value;
137
- if (t.use12Hours) {
138
- let e = n % 12 || 12;
139
- o = o.replace("hh", F(e)), o = o.replace("h", String(e)), o = o.replace("A", a), o = o.replace("a", a.toLowerCase());
140
- } else o = o.replace("HH", F(n)), o = o.replace("H", String(n));
141
- return o = o.replace("mm", F(r)), o = o.replace("ss", F(i)), o;
142
- }
143
- function L(e) {
144
- if (!e.trim()) return null;
145
- let n = e.match(/(\d{1,2}):(\d{2})(?::(\d{2}))?\s*(AM|PM|am|pm)?/);
146
- if (!n) return null;
147
- let r = parseInt(n[1], 10), i = parseInt(n[2], 10), a = n[3] ? parseInt(n[3], 10) : 0, o = n[4]?.toUpperCase();
148
- if (t.use12Hours && o && (o === "PM" && r < 12 && (r += 12), o === "AM" && r === 12 && (r = 0)), r < 0 || r > 23 || i < 0 || i > 59 || a < 0 || a > 59) return null;
149
- let s = /* @__PURE__ */ new Date();
150
- return s.setHours(r, i, a, 0), s;
151
- }
152
- let R = a(() => t.disabledTime ? t.disabledTime().disabledHours?.() ?? [] : []), z = a(() => {
153
- if (!t.disabledTime) return [];
154
- let e = t.disabledTime(), n = O.value ?? P.value?.getHours() ?? 0;
155
- return e.disabledMinutes?.(n) ?? [];
156
- }), B = a(() => {
157
- if (!t.disabledTime) return [];
158
- let e = t.disabledTime(), n = O.value ?? P.value?.getHours() ?? 0, r = k.value ?? P.value?.getMinutes() ?? 0;
159
- return e.disabledSeconds?.(n, r) ?? [];
160
- }), V = a(() => {
161
- let e = [];
162
- if (t.use12Hours) for (let n = 1; n <= 12; n += t.hourStep) e.push(n);
163
- else for (let n = 0; n < 24; n += t.hourStep) e.push(n);
164
- return t.hideDisabledOptions ? e.filter((e) => !R.value.includes(t.use12Hours ? W(e, j.value ?? "AM") : e)) : e;
165
- }), H = a(() => {
166
- let e = [];
167
- for (let n = 0; n < 60; n += t.minuteStep) e.push(n);
168
- return t.hideDisabledOptions ? e.filter((e) => !z.value.includes(e)) : e;
169
- }), U = a(() => {
170
- let e = [];
171
- for (let n = 0; n < 60; n += t.secondStep) e.push(n);
172
- return t.hideDisabledOptions ? e.filter((e) => !B.value.includes(e)) : e;
173
- });
174
- function W(e, t) {
175
- return t === "AM" ? e === 12 ? 0 : e : e === 12 ? 12 : e + 12;
176
- }
177
- function G(e) {
178
- let t = e >= 12 ? "PM" : "AM";
179
- return {
180
- hour: e % 12 || 12,
181
- period: t
182
- };
183
- }
184
- function K() {
185
- t.disabled || (E.value = !0, D.value = !0, u("openChange", !0), y.value?.showPopover?.(), we(), d(() => Pe()));
186
- }
187
- function q() {
188
- E.value = !1, D.value = !1, u("openChange", !1), y.value?.hidePopover?.(), v.value?.focus();
189
- }
190
- function Se() {
191
- D.value ? q() : K();
192
- }
193
- function Ce(e) {
194
- let t = e.newState === "open";
195
- E.value = t, D.value = t, t || u("openChange", !1);
196
- }
197
- function we() {
198
- let e = P.value;
199
- if (e) {
200
- if (t.use12Hours) {
201
- let { hour: t, period: n } = G(e.getHours());
202
- O.value = t, j.value = n;
203
- } else O.value = e.getHours();
204
- k.value = e.getMinutes(), A.value = e.getSeconds();
205
- } else O.value = null, k.value = null, A.value = null, j.value = null;
206
- }
207
- function J(e) {
208
- let n = t.use12Hours ? W(e, j.value ?? "AM") : e;
209
- R.value.includes(n) || (O.value = e, !t.needConfirm && !t.changeOnScroll ? Z() : t.changeOnScroll && Q());
210
- }
211
- function Y(e) {
212
- z.value.includes(e) || (k.value = e, !t.needConfirm && !t.changeOnScroll ? Z() : t.changeOnScroll && Q());
213
- }
214
- function Te(e) {
215
- B.value.includes(e) || (A.value = e, !t.needConfirm && !t.changeOnScroll ? Z() : t.changeOnScroll && Q());
216
- }
217
- function X(e) {
218
- j.value = e, !t.needConfirm && !t.changeOnScroll ? Z() : t.changeOnScroll && Q();
219
- }
220
- function Z() {
221
- if (O.value !== null && k.value !== null) {
222
- if (t.showSecond && A.value === null || t.use12Hours && j.value === null) return;
223
- Q(), q();
224
- }
225
- }
226
- function Q() {
227
- let e = O.value ?? 0, n = k.value ?? 0, r = A.value ?? 0, i = t.use12Hours ? W(e, j.value ?? "AM") : e, a = /* @__PURE__ */ new Date();
228
- a.setHours(i, n, r, 0), P.value = a, M.value = I(a), u("change", a, I(a));
229
- }
230
- function Ee() {
231
- Q(), q();
232
- }
233
- function De() {
234
- let e = /* @__PURE__ */ new Date();
235
- if (t.use12Hours) {
236
- let { hour: t, period: n } = G(e.getHours());
237
- O.value = t, j.value = n;
238
- } else O.value = e.getHours();
239
- k.value = e.getMinutes(), A.value = e.getSeconds(), d(() => Pe()), t.needConfirm || (Q(), q());
240
- }
241
- function Oe(e) {
242
- e.stopPropagation(), P.value = null, M.value = "", O.value = null, k.value = null, A.value = null, j.value = null, u("change", null, "");
243
- }
244
- function ke(e) {
245
- M.value = e.target.value;
246
- }
247
- function Ae() {
248
- if (!D.value) {
249
- let e = L(M.value);
250
- e ? (P.value = e, M.value = I(e), u("change", e, I(e))) : M.value === "" ? (P.value = null, u("change", null, "")) : M.value = I(P.value);
251
- }
252
- }
253
- function je(e) {
254
- if (e.key === "Enter" || e.key === " ") {
255
- if (!D.value) e.preventDefault(), K();
256
- else if (e.key === "Enter") {
257
- e.preventDefault();
258
- let t = L(M.value);
259
- t && (P.value = t, M.value = I(t), u("change", t, I(t))), q();
260
- }
261
- } else e.key === "Escape" && D.value && (e.preventDefault(), q());
262
- }
263
- function Me(e) {
264
- if (e.key === "Escape") {
265
- e.preventDefault(), q();
266
- return;
267
- }
268
- if (e.key === "Tab") {
269
- let n = [];
270
- t.showHour && n.push("hour"), t.showMinute && n.push("minute"), t.showSecond && n.push("second"), t.use12Hours && n.push("ampm");
271
- let r = n.indexOf(N.value);
272
- e.shiftKey ? r > 0 && (e.preventDefault(), N.value = n[r - 1]) : r < n.length - 1 && (e.preventDefault(), N.value = n[r + 1]);
273
- return;
274
- }
275
- if (e.key === "ArrowUp" || e.key === "ArrowDown") {
276
- e.preventDefault(), Ne(e.key === "ArrowUp" ? -1 : 1);
277
- return;
278
- }
279
- e.key === "Enter" && (e.preventDefault(), Ee());
280
- }
281
- function Ne(e) {
282
- if (N.value === "hour") {
283
- let t = V.value, n = O.value ?? t[0], r = t.indexOf(n), i = t[Math.max(0, Math.min(t.length - 1, r + e))];
284
- J(i), $(b.value, t.indexOf(i));
285
- } else if (N.value === "minute") {
286
- let t = H.value, n = k.value ?? t[0], r = t.indexOf(n), i = t[Math.max(0, Math.min(t.length - 1, r + e))];
287
- Y(i), $(x.value, t.indexOf(i));
288
- } else if (N.value === "second") {
289
- let t = U.value, n = A.value ?? t[0], r = t.indexOf(n), i = t[Math.max(0, Math.min(t.length - 1, r + e))];
290
- Te(i), $(S.value, t.indexOf(i));
291
- } else N.value === "ampm" && X(j.value === "AM" ? "PM" : "AM");
292
- }
293
- function $(e, t) {
294
- !e || !e.scrollTo || e.scrollTo({
295
- top: t * 28,
296
- behavior: "smooth"
297
- });
298
- }
299
- function Pe() {
300
- if (O.value !== null) {
301
- let e = V.value.indexOf(O.value);
302
- e >= 0 && $(b.value, e);
303
- }
304
- if (k.value !== null) {
305
- let e = H.value.indexOf(k.value);
306
- e >= 0 && $(x.value, e);
307
- }
308
- if (A.value !== null && t.showSecond) {
309
- let e = U.value.indexOf(A.value);
310
- e >= 0 && $(S.value, e);
311
- }
312
- if (j.value && t.use12Hours) {
313
- let e = j.value === "AM" ? 0 : 1;
314
- $(C.value, e);
315
- }
316
- }
317
- function Fe(e) {
318
- if (!D.value) return;
319
- let t = e.target;
320
- y.value?.contains(t) || v.value?.parentElement?.contains(t) || q();
321
- }
322
- ne(() => {
323
- document.addEventListener("mousedown", Fe);
324
- }), te(() => {
325
- document.removeEventListener("mousedown", Fe);
326
- }), ie(() => t.open, (e) => {
327
- e !== void 0 && (e ? K() : q());
328
- }), ie(P, (e) => {
329
- M.value = I(e);
330
- }), M.value = I(P.value);
331
- let Ie = a(() => [
332
- "b-time-picker",
333
- `b-time-picker--${t.size}`,
334
- `b-time-picker--${t.variant}`,
335
- {
336
- "b-time-picker--disabled": t.disabled,
337
- "b-time-picker--open": D.value,
338
- [`b-time-picker--${t.status}`]: !!t.status
339
- }
340
- ]), Le = (e) => {
341
- let n = t.use12Hours ? W(e, j.value ?? "AM") : e;
342
- return R.value.includes(n);
343
- }, Re = (e) => z.value.includes(e), ze = (e) => B.value.includes(e);
344
- return (e, n) => (p(), s("div", { class: f(Ie.value) }, [c("div", {
345
- class: "b-time-picker__input-wrap",
346
- style: ee({ anchorName: T.value }),
347
- onClick: Se
348
- }, [
349
- c("input", {
350
- id: `b-time-picker-input-${_(w)}`,
351
- ref_key: "inputEl",
352
- ref: v,
353
- class: "b-time-picker__input",
354
- type: "text",
355
- role: "combobox",
356
- "aria-expanded": D.value,
357
- "aria-haspopup": "dialog",
358
- "aria-controls": D.value ? `b-time-picker-panel-${_(w)}` : void 0,
359
- "aria-describedby": t.status ? `b-time-picker-status-${_(w)}` : void 0,
360
- "aria-label": t.placeholder,
361
- placeholder: t.placeholder,
362
- disabled: t.disabled,
363
- readonly: t.inputReadOnly,
364
- value: M.value,
365
- autocomplete: "off",
366
- onInput: ke,
367
- onBlur: Ae,
368
- onKeydown: je
369
- }, null, 40, ae),
370
- c("span", oe, [!t.allowClear || !P.value ? (p(), s("svg", se, [...n[2] ||= [c("circle", {
371
- cx: "12",
372
- cy: "12",
373
- r: "10"
374
- }, null, -1), c("polyline", { points: "12 6 12 12 16 14" }, null, -1)]])) : (p(), s("button", {
375
- key: 1,
376
- class: "b-time-picker__clear",
377
- type: "button",
378
- "aria-label": "Clear time",
379
- tabindex: "-1",
380
- onClick: Oe
381
- }, [...n[3] ||= [c("svg", {
382
- "aria-hidden": "true",
383
- viewBox: "0 0 24 24",
384
- fill: "none",
385
- stroke: "currentColor",
386
- "stroke-width": "2"
387
- }, [
388
- c("circle", {
389
- cx: "12",
390
- cy: "12",
391
- r: "10"
392
- }),
393
- c("line", {
394
- x1: "15",
395
- y1: "9",
396
- x2: "9",
397
- y2: "15"
398
- }),
399
- c("line", {
400
- x1: "9",
401
- y1: "9",
402
- x2: "15",
403
- y2: "15"
404
- })
405
- ], -1)]]))]),
406
- t.status ? (p(), s("span", {
407
- key: 0,
408
- id: `b-time-picker-status-${_(w)}`,
409
- class: "b-time-picker__status-text",
410
- "aria-live": "polite"
411
- }, g(t.status), 9, ce)) : o("", !0)
412
- ], 4), c("div", {
413
- id: `b-time-picker-panel-${_(w)}`,
414
- ref_key: "panelEl",
415
- ref: y,
416
- class: "b-time-picker__panel",
417
- popover: "",
418
- role: "dialog",
419
- "aria-label": "Time picker",
420
- "aria-modal": !0,
421
- style: ee({ positionAnchor: T.value }),
422
- onToggle: Ce,
423
- onKeydown: Me
424
- }, [c("div", ue, [
425
- t.showHour ? (p(), s("div", {
426
- key: 0,
427
- ref_key: "hourColEl",
428
- ref: b,
429
- class: "b-time-picker__column",
430
- role: "listbox",
431
- "aria-label": "Hours",
432
- "aria-activedescendant": O.value === null ? void 0 : `b-time-picker-hour-${O.value}-${_(w)}`
433
- }, [(p(!0), s(i, null, h(V.value, (e) => (p(), s("div", {
434
- id: `b-time-picker-hour-${e}-${_(w)}`,
435
- key: e,
436
- class: f(["b-time-picker__cell", {
437
- "b-time-picker__cell--selected": O.value === e,
438
- "b-time-picker__cell--disabled": Le(e),
439
- "b-time-picker__cell--focused": N.value === "hour" && O.value === e
440
- }]),
441
- role: "option",
442
- "aria-selected": O.value === e,
443
- "aria-disabled": Le(e),
444
- onClick: (t) => J(e)
445
- }, g(F(e)), 11, fe))), 128))], 8, de)) : o("", !0),
446
- t.showMinute ? (p(), s("div", {
447
- key: 1,
448
- ref_key: "minuteColEl",
449
- ref: x,
450
- class: "b-time-picker__column",
451
- role: "listbox",
452
- "aria-label": "Minutes",
453
- "aria-activedescendant": k.value === null ? void 0 : `b-time-picker-minute-${k.value}-${_(w)}`
454
- }, [(p(!0), s(i, null, h(H.value, (e) => (p(), s("div", {
455
- id: `b-time-picker-minute-${e}-${_(w)}`,
456
- key: e,
457
- class: f(["b-time-picker__cell", {
458
- "b-time-picker__cell--selected": k.value === e,
459
- "b-time-picker__cell--disabled": Re(e),
460
- "b-time-picker__cell--focused": N.value === "minute" && k.value === e
461
- }]),
462
- role: "option",
463
- "aria-selected": k.value === e,
464
- "aria-disabled": Re(e),
465
- onClick: (t) => Y(e)
466
- }, g(F(e)), 11, me))), 128))], 8, pe)) : o("", !0),
467
- t.showSecond ? (p(), s("div", {
468
- key: 2,
469
- ref_key: "secondColEl",
470
- ref: S,
471
- class: "b-time-picker__column",
472
- role: "listbox",
473
- "aria-label": "Seconds",
474
- "aria-activedescendant": A.value === null ? void 0 : `b-time-picker-second-${A.value}-${_(w)}`
475
- }, [(p(!0), s(i, null, h(U.value, (e) => (p(), s("div", {
476
- id: `b-time-picker-second-${e}-${_(w)}`,
477
- key: e,
478
- class: f(["b-time-picker__cell", {
479
- "b-time-picker__cell--selected": A.value === e,
480
- "b-time-picker__cell--disabled": ze(e),
481
- "b-time-picker__cell--focused": N.value === "second" && A.value === e
482
- }]),
483
- role: "option",
484
- "aria-selected": A.value === e,
485
- "aria-disabled": ze(e),
486
- onClick: (t) => Te(e)
487
- }, g(F(e)), 11, ge))), 128))], 8, he)) : o("", !0),
488
- t.use12Hours ? (p(), s("div", {
489
- key: 3,
490
- ref_key: "ampmColEl",
491
- ref: C,
492
- class: "b-time-picker__column b-time-picker__column--ampm",
493
- role: "listbox",
494
- "aria-label": "AM/PM"
495
- }, [c("div", {
496
- class: f(["b-time-picker__cell", {
497
- "b-time-picker__cell--selected": j.value === "AM",
498
- "b-time-picker__cell--focused": N.value === "ampm" && j.value === "AM"
499
- }]),
500
- role: "option",
501
- "aria-selected": j.value === "AM",
502
- onClick: n[0] ||= (e) => X("AM")
503
- }, " AM ", 10, _e), c("div", {
504
- class: f(["b-time-picker__cell", {
505
- "b-time-picker__cell--selected": j.value === "PM",
506
- "b-time-picker__cell--focused": N.value === "ampm" && j.value === "PM"
507
- }]),
508
- role: "option",
509
- "aria-selected": j.value === "PM",
510
- onClick: n[1] ||= (e) => X("PM")
511
- }, " PM ", 10, ve)], 512)) : o("", !0)
512
- ]), t.needConfirm || t.showNow ? (p(), s("div", ye, [t.showNow ? (p(), s("button", {
513
- key: 0,
514
- class: "b-time-picker__now-btn",
515
- type: "button",
516
- onClick: De
517
- }, " Now ")) : o("", !0), t.needConfirm ? (p(), s("button", {
518
- key: 1,
519
- class: "b-time-picker__ok-btn",
520
- type: "button",
521
- onClick: Ee
522
- }, " OK ")) : o("", !0)])) : o("", !0)], 44, le)], 2));
523
- }
524
- });
525
- //#endregion
526
- export { v as default };
527
-
528
- //# sourceMappingURL=design-system193.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"design-system193.js","names":[],"sources":["../src/components/BTimePicker/BTimePicker.vue?vue&type=script&setup=true&lang.ts"],"sourcesContent":["import { useModel as _useModel, mergeModels as _mergeModels, defineComponent as _defineComponent } from 'vue'\nimport { unref as _unref, createElementVNode as _createElementVNode, openBlock as _openBlock, createElementBlock as _createElementBlock, createCommentVNode as _createCommentVNode, toDisplayString as _toDisplayString, normalizeStyle as _normalizeStyle, renderList as _renderList, Fragment as _Fragment, normalizeClass as _normalizeClass } from \"vue\"\n\nconst _hoisted_1 = [\"id\", \"aria-expanded\", \"aria-controls\", \"aria-describedby\", \"aria-label\", \"placeholder\", \"disabled\", \"readonly\", \"value\"]\nconst _hoisted_2 = { class: \"b-time-picker__suffix\" }\nconst _hoisted_3 = {\n key: 0,\n class: \"b-time-picker__icon\",\n \"aria-hidden\": \"true\",\n viewBox: \"0 0 24 24\",\n fill: \"none\",\n stroke: \"currentColor\",\n \"stroke-width\": \"2\"\n}\nconst _hoisted_4 = [\"id\"]\nconst _hoisted_5 = [\"id\"]\nconst _hoisted_6 = {\n class: \"b-time-picker__columns\",\n role: \"group\",\n \"aria-label\": \"Time selection columns\"\n}\nconst _hoisted_7 = [\"aria-activedescendant\"]\nconst _hoisted_8 = [\"id\", \"aria-selected\", \"aria-disabled\", \"onClick\"]\nconst _hoisted_9 = [\"aria-activedescendant\"]\nconst _hoisted_10 = [\"id\", \"aria-selected\", \"aria-disabled\", \"onClick\"]\nconst _hoisted_11 = [\"aria-activedescendant\"]\nconst _hoisted_12 = [\"id\", \"aria-selected\", \"aria-disabled\", \"onClick\"]\nconst _hoisted_13 = [\"aria-selected\"]\nconst _hoisted_14 = [\"aria-selected\"]\nconst _hoisted_15 = {\n key: 0,\n class: \"b-time-picker__footer\"\n}\n\nimport { useComponentId } from '@/composables/useComponentId.ts';\nimport { computed, nextTick, onBeforeUnmount, onMounted, ref, watch } from 'vue';\n\nimport {\n BTimePickerPlacement,\n BTimePickerSize,\n BTimePickerStatus,\n BTimePickerVariant,\n type BTimePickerDisabledTime,\n} from './types';\n\n\nexport default /*@__PURE__*/_defineComponent({\n __name: 'BTimePicker',\n props: /*@__PURE__*/_mergeModels({\n size: { default: () => (BTimePickerSize.Medium) },\n variant: { default: () => (BTimePickerVariant.Outlined) },\n placeholder: { default: 'Select time' },\n disabled: { type: Boolean, default: false },\n inputReadOnly: { type: Boolean, default: false },\n allowClear: { type: Boolean, default: true },\n showNow: { type: Boolean, default: true },\n use12Hours: { type: Boolean, default: false },\n hourStep: { default: 1 },\n minuteStep: { default: 1 },\n secondStep: { default: 1 },\n format: {},\n placement: { default: () => (BTimePickerPlacement.BottomLeft) },\n status: {},\n hideDisabledOptions: { type: Boolean, default: false },\n needConfirm: { type: Boolean, default: true },\n changeOnScroll: { type: Boolean, default: false },\n showHour: { type: Boolean, default: true },\n showMinute: { type: Boolean, default: true },\n showSecond: { type: Boolean, default: true },\n defaultOpen: { type: Boolean, default: false },\n defaultValue: {},\n open: { type: Boolean },\n disabledTime: { type: Function }\n }, {\n \"modelValue\": { default: undefined },\n \"modelModifiers\": {},\n }),\n emits: /*@__PURE__*/_mergeModels([\"change\", \"openChange\"], [\"update:modelValue\"]),\n setup(__props: any, { expose: __expose, emit: __emit }) {\n\n\n\nconst model = _useModel<Date | null>(__props, \"modelValue\");\n\nconst emit = __emit;\n\nconst inputEl = ref<HTMLInputElement | null>(null);\nconst panelEl = ref<HTMLElement | null>(null);\nconst hourColEl = ref<HTMLElement | null>(null);\nconst minuteColEl = ref<HTMLElement | null>(null);\nconst secondColEl = ref<HTMLElement | null>(null);\nconst ampmColEl = ref<HTMLElement | null>(null);\n\n__expose({\n focus: () => inputEl.value?.focus(),\n blur: () => inputEl.value?.blur(),\n});\n\nconst { componentUID } = useComponentId();\nconst anchorName = computed(() => `--b-time-picker-${componentUID.value}`);\n\n// ─────────────────────────────────────────────\n// State\n// ─────────────────────────────────────────────\nconst isOpen = ref(__props.defaultOpen);\nconst isPanelOpen = ref(__props.open !== undefined ? !!__props.open : __props.defaultOpen);\nconst internalValue = ref<Date | null>(__props.defaultValue ?? null);\nconst pendingHour = ref<number | null>(null);\nconst pendingMinute = ref<number | null>(null);\nconst pendingSecond = ref<number | null>(null);\nconst pendingAmpm = ref<'AM' | 'PM' | null>(null);\nconst inputText = ref('');\nconst focusedColumn = ref<'hour' | 'minute' | 'second' | 'ampm'>('hour');\n\nconst selectedTime = computed({\n get: () => model.value ?? internalValue.value,\n set: (val) => {\n internalValue.value = val;\n model.value = val;\n },\n});\n\n// ─────────────────────────────────────────────\n// Format\n// ─────────────────────────────────────────────\nconst activeFormat = computed(() => {\n if (__props.format) return __props.format;\n const parts: string[] = [];\n if (__props.showHour) parts.push(__props.use12Hours ? 'hh' : 'HH');\n if (__props.showMinute) parts.push('mm');\n if (__props.showSecond) parts.push('ss');\n const base = parts.join(':');\n return __props.use12Hours ? `${base} A` : base;\n});\n\nfunction pad(n: number): string {\n return String(n).padStart(2, '0');\n}\n\nfunction formatTime(d: Date | null): string {\n if (!d) return '';\n const h = d.getHours();\n const m = d.getMinutes();\n const s = d.getSeconds();\n const ampm = h >= 12 ? 'PM' : 'AM';\n\n let result = activeFormat.value;\n if (__props.use12Hours) {\n const h12 = h % 12 || 12;\n result = result.replace('hh', pad(h12));\n result = result.replace('h', String(h12));\n result = result.replace('A', ampm);\n result = result.replace('a', ampm.toLowerCase());\n } else {\n result = result.replace('HH', pad(h));\n result = result.replace('H', String(h));\n }\n result = result.replace('mm', pad(m));\n result = result.replace('ss', pad(s));\n return result;\n}\n\nfunction parseTimeString(str: string): Date | null {\n if (!str.trim()) return null;\n const timeRegex12 = /(\\d{1,2}):(\\d{2})(?::(\\d{2}))?\\s*(AM|PM|am|pm)?/;\n const match = str.match(timeRegex12);\n if (!match) return null;\n\n let h = parseInt(match[1], 10);\n const m = parseInt(match[2], 10);\n const s = match[3] ? parseInt(match[3], 10) : 0;\n const period = match[4]?.toUpperCase();\n\n if (__props.use12Hours && period) {\n if (period === 'PM' && h < 12) h += 12;\n if (period === 'AM' && h === 12) h = 0;\n }\n\n if (h < 0 || h > 23 || m < 0 || m > 59 || s < 0 || s > 59) return null;\n\n const d = new Date();\n d.setHours(h, m, s, 0);\n return d;\n}\n\n// ─────────────────────────────────────────────\n// Disabled time logic\n// ─────────────────────────────────────────────\nconst disabledHours = computed<number[]>(() => {\n if (!__props.disabledTime) return [];\n const dt = __props.disabledTime();\n return dt.disabledHours?.() ?? [];\n});\n\nconst disabledMinutes = computed<number[]>(() => {\n if (!__props.disabledTime) return [];\n const dt = __props.disabledTime();\n const h = pendingHour.value ?? selectedTime.value?.getHours() ?? 0;\n return dt.disabledMinutes?.(h) ?? [];\n});\n\nconst disabledSeconds = computed<number[]>(() => {\n if (!__props.disabledTime) return [];\n const dt = __props.disabledTime();\n const h = pendingHour.value ?? selectedTime.value?.getHours() ?? 0;\n const m = pendingMinute.value ?? selectedTime.value?.getMinutes() ?? 0;\n return dt.disabledSeconds?.(h, m) ?? [];\n});\n\n// ─────────────────────────────────────────────\n// Column data\n// ─────────────────────────────────────────────\nconst hours = computed(() => {\n const list: number[] = [];\n if (__props.use12Hours) {\n for (let i = 1; i <= 12; i += __props.hourStep) list.push(i);\n } else {\n for (let i = 0; i < 24; i += __props.hourStep) list.push(i);\n }\n if (__props.hideDisabledOptions) {\n return list.filter((h) => !disabledHours.value.includes(__props.use12Hours ? to24Hour(h, pendingAmpm.value ?? 'AM') : h));\n }\n return list;\n});\n\nconst minutes = computed(() => {\n const list: number[] = [];\n for (let i = 0; i < 60; i += __props.minuteStep) list.push(i);\n if (__props.hideDisabledOptions) {\n return list.filter((m) => !disabledMinutes.value.includes(m));\n }\n return list;\n});\n\nconst seconds = computed(() => {\n const list: number[] = [];\n for (let i = 0; i < 60; i += __props.secondStep) list.push(i);\n if (__props.hideDisabledOptions) {\n return list.filter((s) => !disabledSeconds.value.includes(s));\n }\n return list;\n});\n\nfunction to24Hour(h12: number, period: 'AM' | 'PM'): number {\n if (period === 'AM') return h12 === 12 ? 0 : h12;\n return h12 === 12 ? 12 : h12 + 12;\n}\n\nfunction to12Hour(h24: number): { hour: number; period: 'AM' | 'PM' } {\n const period: 'AM' | 'PM' = h24 >= 12 ? 'PM' : 'AM';\n const hour = h24 % 12 || 12;\n return { hour, period };\n}\n\n// ─────────────────────────────────────────────\n// Panel open/close\n// ─────────────────────────────────────────────\nfunction openPanel() {\n if (__props.disabled) return;\n isOpen.value = true;\n isPanelOpen.value = true;\n emit('openChange', true);\n panelEl.value?.showPopover?.();\n syncPendingFromValue();\n nextTick(() => scrollToSelected());\n}\n\nfunction closePanel() {\n isOpen.value = false;\n isPanelOpen.value = false;\n emit('openChange', false);\n panelEl.value?.hidePopover?.();\n inputEl.value?.focus();\n}\n\nfunction togglePanel() {\n if (isPanelOpen.value) closePanel();\n else openPanel();\n}\n\nfunction handlePopoverToggle(e: Event) {\n const toggleEvent = e as ToggleEvent;\n const nowOpen = toggleEvent.newState === 'open';\n isOpen.value = nowOpen;\n isPanelOpen.value = nowOpen;\n if (!nowOpen) emit('openChange', false);\n}\n\n// ─────────────────────────────────────────────\n// Sync pending state\n// ─────────────────────────────────────────────\nfunction syncPendingFromValue() {\n const t = selectedTime.value;\n if (t) {\n if (__props.use12Hours) {\n const { hour, period } = to12Hour(t.getHours());\n pendingHour.value = hour;\n pendingAmpm.value = period;\n } else {\n pendingHour.value = t.getHours();\n }\n pendingMinute.value = t.getMinutes();\n pendingSecond.value = t.getSeconds();\n } else {\n pendingHour.value = null;\n pendingMinute.value = null;\n pendingSecond.value = null;\n pendingAmpm.value = null;\n }\n}\n\n// ─────────────────────────────────────────────\n// Selection\n// ─────────────────────────────────────────────\nfunction selectHour(h: number) {\n const h24 = __props.use12Hours ? to24Hour(h, pendingAmpm.value ?? 'AM') : h;\n if (disabledHours.value.includes(h24)) return;\n pendingHour.value = h;\n if (!__props.needConfirm && !__props.changeOnScroll) applyPendingIfComplete();\n else if (__props.changeOnScroll) applyPending();\n}\n\nfunction selectMinute(m: number) {\n if (disabledMinutes.value.includes(m)) return;\n pendingMinute.value = m;\n if (!__props.needConfirm && !__props.changeOnScroll) applyPendingIfComplete();\n else if (__props.changeOnScroll) applyPending();\n}\n\nfunction selectSecond(s: number) {\n if (disabledSeconds.value.includes(s)) return;\n pendingSecond.value = s;\n if (!__props.needConfirm && !__props.changeOnScroll) applyPendingIfComplete();\n else if (__props.changeOnScroll) applyPending();\n}\n\nfunction selectAmpm(val: 'AM' | 'PM') {\n pendingAmpm.value = val;\n if (!__props.needConfirm && !__props.changeOnScroll) applyPendingIfComplete();\n else if (__props.changeOnScroll) applyPending();\n}\n\nfunction applyPendingIfComplete() {\n if (pendingHour.value !== null && pendingMinute.value !== null) {\n if (__props.showSecond && pendingSecond.value === null) return;\n if (__props.use12Hours && pendingAmpm.value === null) return;\n applyPending();\n closePanel();\n }\n}\n\nfunction applyPending() {\n const h = pendingHour.value ?? 0;\n const m = pendingMinute.value ?? 0;\n const s = pendingSecond.value ?? 0;\n const h24 = __props.use12Hours ? to24Hour(h, pendingAmpm.value ?? 'AM') : h;\n\n const d = new Date();\n d.setHours(h24, m, s, 0);\n selectedTime.value = d;\n inputText.value = formatTime(d);\n emit('change', d, formatTime(d));\n}\n\nfunction handleOk() {\n applyPending();\n closePanel();\n}\n\nfunction handleNow() {\n const now = new Date();\n if (__props.use12Hours) {\n const { hour, period } = to12Hour(now.getHours());\n pendingHour.value = hour;\n pendingAmpm.value = period;\n } else {\n pendingHour.value = now.getHours();\n }\n pendingMinute.value = now.getMinutes();\n pendingSecond.value = now.getSeconds();\n nextTick(() => scrollToSelected());\n if (!__props.needConfirm) {\n applyPending();\n closePanel();\n }\n}\n\nfunction handleClear(e: Event) {\n e.stopPropagation();\n selectedTime.value = null;\n inputText.value = '';\n pendingHour.value = null;\n pendingMinute.value = null;\n pendingSecond.value = null;\n pendingAmpm.value = null;\n emit('change', null, '');\n}\n\n// ─────────────────────────────────────────────\n// Input handling\n// ─────────────────────────────────────────────\nfunction handleInputChange(e: Event) {\n const val = (e.target as HTMLInputElement).value;\n inputText.value = val;\n}\n\nfunction handleInputBlur() {\n if (!isPanelOpen.value) {\n const parsed = parseTimeString(inputText.value);\n if (parsed) {\n selectedTime.value = parsed;\n inputText.value = formatTime(parsed);\n emit('change', parsed, formatTime(parsed));\n } else if (inputText.value === '') {\n selectedTime.value = null;\n emit('change', null, '');\n } else {\n inputText.value = formatTime(selectedTime.value);\n }\n }\n}\n\nfunction handleInputKeydown(e: KeyboardEvent) {\n if (e.key === 'Enter' || e.key === ' ') {\n if (!isPanelOpen.value) {\n e.preventDefault();\n openPanel();\n } else if (e.key === 'Enter') {\n e.preventDefault();\n const parsed = parseTimeString(inputText.value);\n if (parsed) {\n selectedTime.value = parsed;\n inputText.value = formatTime(parsed);\n emit('change', parsed, formatTime(parsed));\n }\n closePanel();\n }\n } else if (e.key === 'Escape') {\n if (isPanelOpen.value) {\n e.preventDefault();\n closePanel();\n }\n }\n}\n\n// ─────────────────────────────────────────────\n// Panel keyboard navigation\n// ─────────────────────────────────────────────\nfunction handlePanelKeydown(e: KeyboardEvent) {\n if (e.key === 'Escape') {\n e.preventDefault();\n closePanel();\n return;\n }\n\n if (e.key === 'Tab') {\n const columns: ('hour' | 'minute' | 'second' | 'ampm')[] = [];\n if (__props.showHour) columns.push('hour');\n if (__props.showMinute) columns.push('minute');\n if (__props.showSecond) columns.push('second');\n if (__props.use12Hours) columns.push('ampm');\n\n const idx = columns.indexOf(focusedColumn.value);\n if (e.shiftKey) {\n if (idx > 0) {\n e.preventDefault();\n focusedColumn.value = columns[idx - 1];\n }\n } else {\n if (idx < columns.length - 1) {\n e.preventDefault();\n focusedColumn.value = columns[idx + 1];\n }\n }\n return;\n }\n\n if (e.key === 'ArrowUp' || e.key === 'ArrowDown') {\n e.preventDefault();\n const delta = e.key === 'ArrowUp' ? -1 : 1;\n adjustFocusedColumn(delta);\n return;\n }\n\n if (e.key === 'Enter') {\n e.preventDefault();\n handleOk();\n }\n}\n\nfunction adjustFocusedColumn(delta: number) {\n if (focusedColumn.value === 'hour') {\n const list = hours.value;\n const current = pendingHour.value ?? list[0];\n const idx = list.indexOf(current);\n const next = list[Math.max(0, Math.min(list.length - 1, idx + delta))];\n selectHour(next);\n scrollColumnTo(hourColEl.value, list.indexOf(next));\n } else if (focusedColumn.value === 'minute') {\n const list = minutes.value;\n const current = pendingMinute.value ?? list[0];\n const idx = list.indexOf(current);\n const next = list[Math.max(0, Math.min(list.length - 1, idx + delta))];\n selectMinute(next);\n scrollColumnTo(minuteColEl.value, list.indexOf(next));\n } else if (focusedColumn.value === 'second') {\n const list = seconds.value;\n const current = pendingSecond.value ?? list[0];\n const idx = list.indexOf(current);\n const next = list[Math.max(0, Math.min(list.length - 1, idx + delta))];\n selectSecond(next);\n scrollColumnTo(secondColEl.value, list.indexOf(next));\n } else if (focusedColumn.value === 'ampm') {\n const val = pendingAmpm.value === 'AM' ? 'PM' : 'AM';\n selectAmpm(val);\n }\n}\n\n// ─────────────────────────────────────────────\n// Scroll helpers\n// ─────────────────────────────────────────────\nfunction scrollColumnTo(col: HTMLElement | null, idx: number) {\n if (!col || !col.scrollTo) return;\n const cellHeight = 28;\n col.scrollTo({ top: idx * cellHeight, behavior: 'smooth' });\n}\n\nfunction scrollToSelected() {\n if (pendingHour.value !== null) {\n const idx = hours.value.indexOf(pendingHour.value);\n if (idx >= 0) scrollColumnTo(hourColEl.value, idx);\n }\n if (pendingMinute.value !== null) {\n const idx = minutes.value.indexOf(pendingMinute.value);\n if (idx >= 0) scrollColumnTo(minuteColEl.value, idx);\n }\n if (pendingSecond.value !== null && __props.showSecond) {\n const idx = seconds.value.indexOf(pendingSecond.value);\n if (idx >= 0) scrollColumnTo(secondColEl.value, idx);\n }\n if (pendingAmpm.value && __props.use12Hours) {\n const idx = pendingAmpm.value === 'AM' ? 0 : 1;\n scrollColumnTo(ampmColEl.value, idx);\n }\n}\n\n// ─────────────────────────────────────────────\n// Click outside\n// ─────────────────────────────────────────────\nfunction handleClickOutside(e: MouseEvent) {\n if (!isPanelOpen.value) return;\n const target = e.target as Node;\n if (panelEl.value?.contains(target)) return;\n if (inputEl.value?.parentElement?.contains(target)) return;\n closePanel();\n}\n\nonMounted(() => {\n document.addEventListener('mousedown', handleClickOutside);\n});\nonBeforeUnmount(() => {\n document.removeEventListener('mousedown', handleClickOutside);\n});\n\n// ─────────────────────────────────────────────\n// Watchers\n// ─────────────────────────────────────────────\nwatch(\n () => __props.open,\n (val) => {\n if (val !== undefined) {\n if (val) openPanel();\n else closePanel();\n }\n },\n);\n\nwatch(selectedTime, (val) => {\n inputText.value = formatTime(val);\n});\n\n// Init display\ninputText.value = formatTime(selectedTime.value);\n\n// ─────────────────────────────────────────────\n// Computed classes\n// ─────────────────────────────────────────────\nconst rootClasses = computed(() => [\n 'b-time-picker',\n `b-time-picker--${__props.size}`,\n `b-time-picker--${__props.variant}`,\n {\n 'b-time-picker--disabled': __props.disabled,\n 'b-time-picker--open': isPanelOpen.value,\n [`b-time-picker--${__props.status}`]: !!__props.status,\n },\n]);\n\nconst isHourDisabled = (h: number) => {\n const h24 = __props.use12Hours ? to24Hour(h, pendingAmpm.value ?? 'AM') : h;\n return disabledHours.value.includes(h24);\n};\nconst isMinuteDisabled = (m: number) => disabledMinutes.value.includes(m);\nconst isSecondDisabled = (s: number) => disabledSeconds.value.includes(s);\n\nreturn (_ctx: any,_cache: any) => {\n return (_openBlock(), _createElementBlock(\"div\", {\n class: _normalizeClass(rootClasses.value)\n }, [\n _createElementVNode(\"div\", {\n class: \"b-time-picker__input-wrap\",\n style: _normalizeStyle({ anchorName: anchorName.value }),\n onClick: togglePanel\n }, [\n _createElementVNode(\"input\", {\n id: `b-time-picker-input-${_unref(componentUID)}`,\n ref_key: \"inputEl\",\n ref: inputEl,\n class: \"b-time-picker__input\",\n type: \"text\",\n role: \"combobox\",\n \"aria-expanded\": isPanelOpen.value,\n \"aria-haspopup\": \"dialog\",\n \"aria-controls\": isPanelOpen.value ? `b-time-picker-panel-${_unref(componentUID)}` : undefined,\n \"aria-describedby\": __props.status ? `b-time-picker-status-${_unref(componentUID)}` : undefined,\n \"aria-label\": __props.placeholder,\n placeholder: __props.placeholder,\n disabled: __props.disabled,\n readonly: __props.inputReadOnly,\n value: inputText.value,\n autocomplete: \"off\",\n onInput: handleInputChange,\n onBlur: handleInputBlur,\n onKeydown: handleInputKeydown\n }, null, 40, _hoisted_1),\n _createElementVNode(\"span\", _hoisted_2, [\n (!__props.allowClear || !selectedTime.value)\n ? (_openBlock(), _createElementBlock(\"svg\", _hoisted_3, [...(_cache[2] || (_cache[2] = [\n _createElementVNode(\"circle\", {\n cx: \"12\",\n cy: \"12\",\n r: \"10\"\n }, null, -1),\n _createElementVNode(\"polyline\", { points: \"12 6 12 12 16 14\" }, null, -1)\n ]))]))\n : (_openBlock(), _createElementBlock(\"button\", {\n key: 1,\n class: \"b-time-picker__clear\",\n type: \"button\",\n \"aria-label\": \"Clear time\",\n tabindex: \"-1\",\n onClick: handleClear\n }, [...(_cache[3] || (_cache[3] = [\n _createElementVNode(\"svg\", {\n \"aria-hidden\": \"true\",\n viewBox: \"0 0 24 24\",\n fill: \"none\",\n stroke: \"currentColor\",\n \"stroke-width\": \"2\"\n }, [\n _createElementVNode(\"circle\", {\n cx: \"12\",\n cy: \"12\",\n r: \"10\"\n }),\n _createElementVNode(\"line\", {\n x1: \"15\",\n y1: \"9\",\n x2: \"9\",\n y2: \"15\"\n }),\n _createElementVNode(\"line\", {\n x1: \"9\",\n y1: \"9\",\n x2: \"15\",\n y2: \"15\"\n })\n ], -1)\n ]))]))\n ]),\n (__props.status)\n ? (_openBlock(), _createElementBlock(\"span\", {\n key: 0,\n id: `b-time-picker-status-${_unref(componentUID)}`,\n class: \"b-time-picker__status-text\",\n \"aria-live\": \"polite\"\n }, _toDisplayString(__props.status), 9, _hoisted_4))\n : _createCommentVNode(\"\", true)\n ], 4),\n _createElementVNode(\"div\", {\n id: `b-time-picker-panel-${_unref(componentUID)}`,\n ref_key: \"panelEl\",\n ref: panelEl,\n class: \"b-time-picker__panel\",\n popover: \"\",\n role: \"dialog\",\n \"aria-label\": 'Time picker',\n \"aria-modal\": true,\n style: _normalizeStyle({ positionAnchor: anchorName.value }),\n onToggle: handlePopoverToggle,\n onKeydown: handlePanelKeydown\n }, [\n _createElementVNode(\"div\", _hoisted_6, [\n (__props.showHour)\n ? (_openBlock(), _createElementBlock(\"div\", {\n key: 0,\n ref_key: \"hourColEl\",\n ref: hourColEl,\n class: \"b-time-picker__column\",\n role: \"listbox\",\n \"aria-label\": 'Hours',\n \"aria-activedescendant\": pendingHour.value !== null ? `b-time-picker-hour-${pendingHour.value}-${_unref(componentUID)}` : undefined\n }, [\n (_openBlock(true), _createElementBlock(_Fragment, null, _renderList(hours.value, (h) => {\n return (_openBlock(), _createElementBlock(\"div\", {\n id: `b-time-picker-hour-${h}-${_unref(componentUID)}`,\n key: h,\n class: _normalizeClass([\"b-time-picker__cell\", {\n 'b-time-picker__cell--selected': pendingHour.value === h,\n 'b-time-picker__cell--disabled': isHourDisabled(h),\n 'b-time-picker__cell--focused': focusedColumn.value === 'hour' && pendingHour.value === h,\n }]),\n role: \"option\",\n \"aria-selected\": pendingHour.value === h,\n \"aria-disabled\": isHourDisabled(h),\n onClick: ($event: any) => (selectHour(h))\n }, _toDisplayString(pad(h)), 11, _hoisted_8))\n }), 128))\n ], 8, _hoisted_7))\n : _createCommentVNode(\"\", true),\n (__props.showMinute)\n ? (_openBlock(), _createElementBlock(\"div\", {\n key: 1,\n ref_key: \"minuteColEl\",\n ref: minuteColEl,\n class: \"b-time-picker__column\",\n role: \"listbox\",\n \"aria-label\": 'Minutes',\n \"aria-activedescendant\": pendingMinute.value !== null ? `b-time-picker-minute-${pendingMinute.value}-${_unref(componentUID)}` : undefined\n }, [\n (_openBlock(true), _createElementBlock(_Fragment, null, _renderList(minutes.value, (m) => {\n return (_openBlock(), _createElementBlock(\"div\", {\n id: `b-time-picker-minute-${m}-${_unref(componentUID)}`,\n key: m,\n class: _normalizeClass([\"b-time-picker__cell\", {\n 'b-time-picker__cell--selected': pendingMinute.value === m,\n 'b-time-picker__cell--disabled': isMinuteDisabled(m),\n 'b-time-picker__cell--focused': focusedColumn.value === 'minute' && pendingMinute.value === m,\n }]),\n role: \"option\",\n \"aria-selected\": pendingMinute.value === m,\n \"aria-disabled\": isMinuteDisabled(m),\n onClick: ($event: any) => (selectMinute(m))\n }, _toDisplayString(pad(m)), 11, _hoisted_10))\n }), 128))\n ], 8, _hoisted_9))\n : _createCommentVNode(\"\", true),\n (__props.showSecond)\n ? (_openBlock(), _createElementBlock(\"div\", {\n key: 2,\n ref_key: \"secondColEl\",\n ref: secondColEl,\n class: \"b-time-picker__column\",\n role: \"listbox\",\n \"aria-label\": 'Seconds',\n \"aria-activedescendant\": pendingSecond.value !== null ? `b-time-picker-second-${pendingSecond.value}-${_unref(componentUID)}` : undefined\n }, [\n (_openBlock(true), _createElementBlock(_Fragment, null, _renderList(seconds.value, (s) => {\n return (_openBlock(), _createElementBlock(\"div\", {\n id: `b-time-picker-second-${s}-${_unref(componentUID)}`,\n key: s,\n class: _normalizeClass([\"b-time-picker__cell\", {\n 'b-time-picker__cell--selected': pendingSecond.value === s,\n 'b-time-picker__cell--disabled': isSecondDisabled(s),\n 'b-time-picker__cell--focused': focusedColumn.value === 'second' && pendingSecond.value === s,\n }]),\n role: \"option\",\n \"aria-selected\": pendingSecond.value === s,\n \"aria-disabled\": isSecondDisabled(s),\n onClick: ($event: any) => (selectSecond(s))\n }, _toDisplayString(pad(s)), 11, _hoisted_12))\n }), 128))\n ], 8, _hoisted_11))\n : _createCommentVNode(\"\", true),\n (__props.use12Hours)\n ? (_openBlock(), _createElementBlock(\"div\", {\n key: 3,\n ref_key: \"ampmColEl\",\n ref: ampmColEl,\n class: \"b-time-picker__column b-time-picker__column--ampm\",\n role: \"listbox\",\n \"aria-label\": \"AM/PM\"\n }, [\n _createElementVNode(\"div\", {\n class: _normalizeClass([\"b-time-picker__cell\", {\n 'b-time-picker__cell--selected': pendingAmpm.value === 'AM',\n 'b-time-picker__cell--focused': focusedColumn.value === 'ampm' && pendingAmpm.value === 'AM',\n }]),\n role: \"option\",\n \"aria-selected\": pendingAmpm.value === 'AM',\n onClick: _cache[0] || (_cache[0] = ($event: any) => (selectAmpm('AM')))\n }, \" AM \", 10, _hoisted_13),\n _createElementVNode(\"div\", {\n class: _normalizeClass([\"b-time-picker__cell\", {\n 'b-time-picker__cell--selected': pendingAmpm.value === 'PM',\n 'b-time-picker__cell--focused': focusedColumn.value === 'ampm' && pendingAmpm.value === 'PM',\n }]),\n role: \"option\",\n \"aria-selected\": pendingAmpm.value === 'PM',\n onClick: _cache[1] || (_cache[1] = ($event: any) => (selectAmpm('PM')))\n }, \" PM \", 10, _hoisted_14)\n ], 512))\n : _createCommentVNode(\"\", true)\n ]),\n (__props.needConfirm || __props.showNow)\n ? (_openBlock(), _createElementBlock(\"div\", _hoisted_15, [\n (__props.showNow)\n ? (_openBlock(), _createElementBlock(\"button\", {\n key: 0,\n class: \"b-time-picker__now-btn\",\n type: \"button\",\n onClick: handleNow\n }, \" Now \"))\n : _createCommentVNode(\"\", true),\n (__props.needConfirm)\n ? (_openBlock(), _createElementBlock(\"button\", {\n key: 1,\n class: \"b-time-picker__ok-btn\",\n type: \"button\",\n onClick: handleOk\n }, \" OK \"))\n : _createCommentVNode(\"\", true)\n ]))\n : _createCommentVNode(\"\", true)\n ], 44, _hoisted_5)\n ], 2))\n}\n}\n\n})"],"mappings":"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"}
@@ -1,6 +0,0 @@
1
- //#region src/components/BTabs/types.ts
2
- var e = Symbol("BTabsContext");
3
- //#endregion
4
- export { e as BTabsContextKey };
5
-
6
- //# sourceMappingURL=design-system196.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"design-system196.js","names":[],"sources":["../src/components/BTabs/types.ts"],"sourcesContent":["import type { ComputedRef, InjectionKey, VNode } from 'vue';\n\nexport type BTabsType = 'line' | 'card' | 'editable-card';\nexport type BTabsPlacement = 'top' | 'bottom' | 'left' | 'right';\nexport type BTabsSize = 'small' | 'middle' | 'large';\n\nexport interface BTabItem {\n /** Unique identifier for the tab. */\n key: string;\n /** Tab header text or VNode. */\n label?: string | VNode;\n /** Whether the tab is disabled. @default false */\n disabled?: boolean;\n /** Whether the close button is shown (editable-card only). @default true */\n closable?: boolean;\n /** Whether to destroy content when tab is hidden. @default false */\n destroyOnHidden?: boolean;\n /** Whether to force render content even when not active. @default false */\n forceRender?: boolean;\n /** Whether to keep this tab's component state alive when switching away. Overrides global keepAlive. */\n keepAlive?: boolean;\n}\n\n// ─────────────────────────────────────────────\n// BTabPane registration (provide/inject)\n// ─────────────────────────────────────────────\n\nexport interface BTabPaneRegistration {\n /** Unique key for this pane. */\n key: string;\n /** Tab label (text or VNode). */\n label?: string | VNode;\n /** Whether tab is disabled. */\n disabled?: boolean;\n /** Whether close button shows in editable-card mode. */\n closable?: boolean;\n /** Whether to destroy when hidden. */\n destroyOnHidden?: boolean;\n /** Whether to force render even when inactive. */\n forceRender?: boolean;\n /** Per-pane keepAlive override. */\n keepAlive?: boolean;\n /** Render function for the pane content (from BTabPane's default slot). */\n renderContent: () => VNode[];\n /** Optional render function for custom label (from BTabPane's tab slot). */\n renderLabel?: () => VNode[];\n}\n\n// ─────────────────────────────────────────────\n// Context injected from BTabs to BTabPane children\n// ─────────────────────────────────────────────\n\nexport interface BTabsContext {\n /** Currently active tab key. */\n activeKey: ComputedRef<string>;\n /** Tab type. */\n type: ComputedRef<BTabsType>;\n /** Tab size. */\n size: ComputedRef<BTabsSize>;\n /** Tab placement. */\n placement: ComputedRef<BTabsPlacement>;\n /** Global keepAlive setting. */\n keepAlive: ComputedRef<boolean>;\n /** Global destroyOnHidden setting. */\n destroyOnHidden: ComputedRef<boolean>;\n /** Register a pane. */\n register: (pane: BTabPaneRegistration) => void;\n /** Unregister a pane by key. */\n unregister: (key: string) => void;\n /** Update a registered pane's data (when props change reactively). */\n update: (key: string, pane: BTabPaneRegistration) => void;\n}\n\nexport const BTabsContextKey: InjectionKey<BTabsContext> = Symbol('BTabsContext');\n"],"mappings":";AAyEA,IAAa,IAA8C,OAAO,eAAe"}