bits-ui 2.16.1 → 2.16.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.
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import type { Updater } from "svelte/store";
|
|
2
2
|
import { Time } from "@internationalized/date";
|
|
3
3
|
import { type WritableBox, DOMContext, type ReadableBoxedValues, type WritableBoxedValues } from "svelte-toolbelt";
|
|
4
|
-
import type { BitsFocusEvent, BitsKeyboardEvent, BitsMouseEvent, RefAttachment, WithRefOpts } from "../../internal/types.js";
|
|
4
|
+
import type { BitsFocusEvent, BitsInputEvent, BitsKeyboardEvent, BitsMouseEvent, RefAttachment, WithRefOpts } from "../../internal/types.js";
|
|
5
5
|
import type { TimeSegmentObj, SegmentPart, HourCycle, TimeValidator, TimeOnInvalid, EditableTimeSegmentPart } from "../../shared/date/types.js";
|
|
6
6
|
import { type TimeFormatter } from "../../internal/date-time/formatter.js";
|
|
7
7
|
import { type Announcer } from "../../internal/date-time/announcer.js";
|
|
@@ -288,6 +288,7 @@ declare class TimeFieldDayPeriodSegmentState {
|
|
|
288
288
|
readonly root: TimeFieldRootState;
|
|
289
289
|
readonly attachment: RefAttachment;
|
|
290
290
|
constructor(opts: TimeFieldDayPeriodSegmentStateOpts, root: TimeFieldRootState);
|
|
291
|
+
onbeforeinput(e: BitsInputEvent): void;
|
|
291
292
|
onkeydown(e: BitsKeyboardEvent): void;
|
|
292
293
|
readonly props: {
|
|
293
294
|
"aria-invalid": "true" | undefined;
|
|
@@ -305,6 +306,7 @@ declare class TimeFieldDayPeriodSegmentState {
|
|
|
305
306
|
"aria-valuenow": number;
|
|
306
307
|
"aria-valuetext": string;
|
|
307
308
|
onkeydown: (e: BitsKeyboardEvent) => void;
|
|
309
|
+
onbeforeinput: (e: BitsInputEvent) => void;
|
|
308
310
|
onclick: (e: BitsMouseEvent) => void;
|
|
309
311
|
role: string;
|
|
310
312
|
contenteditable: string;
|
|
@@ -335,6 +337,7 @@ declare class TimeFieldDayPeriodSegmentState {
|
|
|
335
337
|
"aria-valuenow": number;
|
|
336
338
|
"aria-valuetext": string;
|
|
337
339
|
onkeydown: (e: BitsKeyboardEvent) => void;
|
|
340
|
+
onbeforeinput: (e: BitsInputEvent) => void;
|
|
338
341
|
onclick: (e: BitsMouseEvent) => void;
|
|
339
342
|
role: string;
|
|
340
343
|
spellcheck: boolean;
|
|
@@ -836,6 +836,22 @@ class TimeFieldDayPeriodSegmentState {
|
|
|
836
836
|
this.#announcer = this.root.announcer;
|
|
837
837
|
this.attachment = attachRef(opts.ref, (v) => (this.root.dayPeriodNode = v));
|
|
838
838
|
this.onkeydown = this.onkeydown.bind(this);
|
|
839
|
+
this.onbeforeinput = this.onbeforeinput.bind(this);
|
|
840
|
+
}
|
|
841
|
+
onbeforeinput(e) {
|
|
842
|
+
if (this.root.disabled.current)
|
|
843
|
+
return;
|
|
844
|
+
const data = typeof e.data === "string" ? e.data.trim().toLowerCase() : "";
|
|
845
|
+
if (!data)
|
|
846
|
+
return;
|
|
847
|
+
e.preventDefault();
|
|
848
|
+
if (data === "a" || data === "p") {
|
|
849
|
+
this.root.updateSegment("dayPeriod", () => {
|
|
850
|
+
const next = data === "a" ? "AM" : "PM";
|
|
851
|
+
this.#announcer.announce(next);
|
|
852
|
+
return next;
|
|
853
|
+
});
|
|
854
|
+
}
|
|
839
855
|
}
|
|
840
856
|
onkeydown(e) {
|
|
841
857
|
if (e.ctrlKey || e.metaKey || this.root.disabled.current)
|
|
@@ -894,6 +910,7 @@ class TimeFieldDayPeriodSegmentState {
|
|
|
894
910
|
"aria-valuenow": valueNow,
|
|
895
911
|
"aria-valuetext": valueText,
|
|
896
912
|
onkeydown: this.onkeydown,
|
|
913
|
+
onbeforeinput: this.onbeforeinput,
|
|
897
914
|
onclick: this.root.handleSegmentClick,
|
|
898
915
|
...this.root.getBaseSegmentAttrs("dayPeriod", this.opts.id.current),
|
|
899
916
|
...this.attachment,
|
package/dist/internal/types.d.ts
CHANGED
|
@@ -90,4 +90,5 @@ export type BitsPointerEvent<T extends HTMLElement = HTMLElement> = BitsEvent<Po
|
|
|
90
90
|
export type BitsKeyboardEvent<T extends HTMLElement = HTMLElement> = BitsEvent<KeyboardEvent, T>;
|
|
91
91
|
export type BitsMouseEvent<T extends HTMLElement = HTMLElement> = BitsEvent<MouseEvent, T>;
|
|
92
92
|
export type BitsFocusEvent<T extends HTMLElement = HTMLElement> = BitsEvent<FocusEvent, T>;
|
|
93
|
+
export type BitsInputEvent<T extends HTMLElement = HTMLElement> = BitsEvent<InputEvent, T>;
|
|
93
94
|
export type RefAttachment<T extends HTMLElement = HTMLElement> = ReturnType<typeof attachRef<T>>;
|