mirror of
https://github.com/Sendouc/sendou.ink.git
synced 2026-03-21 18:04:39 -05:00
88 lines
2.1 KiB
TypeScript
88 lines
2.1 KiB
TypeScript
import * as React from "react";
|
|
import type { FormFieldProps } from "../types";
|
|
import {
|
|
FormFieldMessages,
|
|
FormFieldWrapper,
|
|
useTranslatedTexts,
|
|
} from "./FormFieldWrapper";
|
|
|
|
type TimeRange = { start: string; end: string } | null;
|
|
|
|
type TimeRangeFormFieldProps = Omit<FormFieldProps<"time-range">, "onBlur"> & {
|
|
value: TimeRange;
|
|
onChange: (value: TimeRange) => void;
|
|
onBlur?: () => void;
|
|
};
|
|
|
|
export function TimeRangeFormField({
|
|
name,
|
|
label,
|
|
bottomText,
|
|
startLabel,
|
|
endLabel,
|
|
error,
|
|
onBlur,
|
|
value,
|
|
onChange,
|
|
}: TimeRangeFormFieldProps) {
|
|
const startId = React.useId();
|
|
const endId = React.useId();
|
|
|
|
const { translatedLabel } = useTranslatedTexts({ label });
|
|
const { translatedLabel: translatedStartLabel } = useTranslatedTexts({
|
|
label: startLabel,
|
|
});
|
|
const { translatedLabel: translatedEndLabel } = useTranslatedTexts({
|
|
label: endLabel,
|
|
});
|
|
|
|
const handleStartChange = (e: React.ChangeEvent<HTMLInputElement>) => {
|
|
const newStart = e.target.value;
|
|
if (!newStart && !value?.end) {
|
|
onChange(null);
|
|
} else {
|
|
onChange({ start: newStart, end: value?.end ?? "" });
|
|
}
|
|
};
|
|
|
|
const handleEndChange = (e: React.ChangeEvent<HTMLInputElement>) => {
|
|
const newEnd = e.target.value;
|
|
if (!newEnd && !value?.start) {
|
|
onChange(null);
|
|
} else {
|
|
onChange({ start: value?.start ?? "", end: newEnd });
|
|
}
|
|
};
|
|
|
|
return (
|
|
<div className="stack xs">
|
|
{translatedLabel ? (
|
|
<span className="text-sm font-semi-bold">{translatedLabel}</span>
|
|
) : null}
|
|
<div className="stack horizontal sm">
|
|
<FormFieldWrapper id={startId} label={translatedStartLabel}>
|
|
<input
|
|
id={startId}
|
|
type="time"
|
|
value={value?.start ?? ""}
|
|
onChange={handleStartChange}
|
|
onBlur={() => onBlur?.()}
|
|
className="size-extra-small"
|
|
/>
|
|
</FormFieldWrapper>
|
|
<FormFieldWrapper id={endId} label={translatedEndLabel}>
|
|
<input
|
|
id={endId}
|
|
type="time"
|
|
value={value?.end ?? ""}
|
|
onChange={handleEndChange}
|
|
onBlur={() => onBlur?.()}
|
|
className="size-extra-small"
|
|
/>
|
|
</FormFieldWrapper>
|
|
</div>
|
|
<FormFieldMessages name={name} error={error} bottomText={bottomText} />
|
|
</div>
|
|
);
|
|
}
|