Skip to content

Commit

Permalink
chore: remove investigation select search
Browse files Browse the repository at this point in the history
  • Loading branch information
luizakp committed Apr 26, 2024
1 parent 5c6f52e commit 9e3ba17
Showing 1 changed file with 62 additions and 66 deletions.
128 changes: 62 additions & 66 deletions src/components/FormBuilder/fields/selects/SearchableSelectField.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -27,70 +27,66 @@ import { withConditional } from "../../fields";
import { SelectFieldProps } from "./SelectField";

export const SearchableSelectField = withConditional<SelectFieldProps>(
({ form, field }) => {
// eslint-disable-next-line no-console
console.log(field);
return (
<FormField
control={form.control}
name={field.name}
render={({ field: formField }) => (
<FormItem className="flex flex-col">
<input hidden {...formField} value={formField.value} />
<FormLabel tooltip={field.tooltip}>{field.label}</FormLabel>
<FormDescription>{field.description}</FormDescription>
<Popover>
<PopoverTrigger asChild>
<FormControl>
<Button
variant="outline"
role="combobox"
className={cn(
"w-[200px] justify-between",
!formField.value && "text-muted-foreground"
)}
>
{formField.value
? field.options?.find(
(option) => option.value === formField.value
)?.label
: "Select an option"}
<CaretSortIcon className="ml-2 size-4 shrink-0 opacity-50" />
</Button>
</FormControl>
</PopoverTrigger>
<PopoverContent className="w-[200px] p-0">
<Command>
<CommandInput placeholder="Search options..." />
<CommandEmpty>No options found.</CommandEmpty>
<CommandGroup className="max-h-80 overflow-y-auto">
{field.options?.map((option) => (
<CommandItem
value={option.label}
key={option.value}
onSelect={() => {
form.setValue(field.name, option.value);
}}
>
<CheckIcon
className={cn(
"mr-2 h-4 w-4",
option.value === formField.value
? "opacity-100"
: "opacity-0"
)}
/>
{option.label}
</CommandItem>
))}
</CommandGroup>
</Command>
</PopoverContent>
</Popover>
<FormMessage />
</FormItem>
)}
/>
);
}
({ form, field }) => (
<FormField
control={form.control}
name={field.name}
render={({ field: formField }) => (
<FormItem className="flex flex-col">
<input hidden {...formField} value={formField.value} />
<FormLabel tooltip={field.tooltip}>{field.label}</FormLabel>
<FormDescription>{field.description}</FormDescription>
<Popover>
<PopoverTrigger asChild>
<FormControl>
<Button
variant="outline"
role="combobox"
className={cn(
"w-[200px] justify-between",
!formField.value && "text-muted-foreground"
)}
>
{formField.value
? field.options?.find(
(option) => option.value === formField.value
)?.label
: "Select an option"}
<CaretSortIcon className="ml-2 size-4 shrink-0 opacity-50" />
</Button>
</FormControl>
</PopoverTrigger>
<PopoverContent className="w-[200px] p-0">
<Command>
<CommandInput placeholder="Search options..." />
<CommandEmpty>No options found.</CommandEmpty>
<CommandGroup className="max-h-80 overflow-y-auto">
{field.options?.map((option) => (
<CommandItem
value={option.label}
key={option.value}
onSelect={() => {
form.setValue(field.name, option.value);
}}
>
<CheckIcon
className={cn(
"mr-2 h-4 w-4",
option.value === formField.value
? "opacity-100"
: "opacity-0"
)}
/>
{option.label}
</CommandItem>
))}
</CommandGroup>
</Command>
</PopoverContent>
</Popover>
<FormMessage />
</FormItem>
)}
/>
)
);

0 comments on commit 9e3ba17

Please sign in to comment.