You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
43 lines
1.0 KiB
43 lines
1.0 KiB
import type {
|
|
BaseFormBuilderProps,
|
|
GenericFormElementProps,
|
|
} from "@components/Form/DynamicForm.js";
|
|
import { Switch } from "@components/UI/Switch.js";
|
|
import { ChangeEvent } from "react";
|
|
import { Controller, FieldValues } from "react-hook-form";
|
|
|
|
export interface ToggleFieldProps<T> extends BaseFormBuilderProps<T> {
|
|
type: "toggle";
|
|
}
|
|
|
|
export function ToggleInput<T extends FieldValues>({
|
|
control,
|
|
disabled,
|
|
field,
|
|
}: GenericFormElementProps<T, ToggleFieldProps<T>>) {
|
|
const onChangeHandler = (e: (event: ChangeEvent) => void) => {
|
|
return (value: boolean) => {
|
|
e({
|
|
target: {
|
|
value: value,
|
|
},
|
|
} as unknown as ChangeEvent);
|
|
};
|
|
};
|
|
|
|
return (
|
|
<Controller
|
|
name={field.name}
|
|
control={control}
|
|
render={({ field: { value, onChange, ...rest } }) => (
|
|
<Switch
|
|
checked={value}
|
|
onCheckedChange={onChangeHandler(onChange)}
|
|
disabled={disabled}
|
|
{...field.properties}
|
|
{...rest}
|
|
/>
|
|
)}
|
|
/>
|
|
);
|
|
}
|
|
|