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.
50 lines
1.1 KiB
50 lines
1.1 KiB
import {
|
|
GenericInput,
|
|
type InputFieldProps,
|
|
} from "@components/Form/FormInput.js";
|
|
import {
|
|
type SelectFieldProps,
|
|
SelectInput,
|
|
} from "@components/Form/FormSelect.js";
|
|
import {
|
|
type ToggleFieldProps,
|
|
ToggleInput,
|
|
} from "@components/Form/FormToggle.js";
|
|
import type { Control, FieldValues } from "react-hook-form";
|
|
|
|
export type FieldProps<T> =
|
|
| InputFieldProps<T>
|
|
| SelectFieldProps<T>
|
|
| ToggleFieldProps<T>;
|
|
|
|
export interface DynamicFormFieldProps<T extends FieldValues> {
|
|
field: FieldProps<T>;
|
|
control: Control<T>;
|
|
disabled?: boolean;
|
|
}
|
|
|
|
export function DynamicFormField<T extends FieldValues>({
|
|
field,
|
|
control,
|
|
disabled,
|
|
}: DynamicFormFieldProps<T>) {
|
|
switch (field.type) {
|
|
case "text":
|
|
case "password":
|
|
case "number":
|
|
return (
|
|
<GenericInput field={field} control={control} disabled={disabled} />
|
|
);
|
|
|
|
case "toggle":
|
|
return (
|
|
<ToggleInput field={field} control={control} disabled={disabled} />
|
|
);
|
|
case "select":
|
|
return (
|
|
<SelectInput field={field} control={control} disabled={disabled} />
|
|
);
|
|
case "multiSelect":
|
|
return <div>tmp</div>;
|
|
}
|
|
}
|
|
|