/* ┌──────────────────────────────────────────────────────────────────────────────┐ │ @author: Davidson Gomes │ │ @file: /app/agents/SearchInput.tsx │ │ Developed by: Davidson Gomes │ │ Creation date: May 13, 2025 │ │ Contact: contato@evolution-api.com │ ├──────────────────────────────────────────────────────────────────────────────┤ │ @copyright © Evolution API 2025. All rights reserved. │ │ Licensed under the Apache License, Version 2.0 │ │ │ │ You may not use this file except in compliance with the License. │ │ You may obtain a copy of the License at │ │ │ │ http://www.apache.org/licenses/LICENSE-2.0 │ │ │ │ Unless required by applicable law or agreed to in writing, software │ │ distributed under the License is distributed on an "AS IS" BASIS, │ │ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. │ │ See the License for the specific language governing permissions and │ │ limitations under the License. │ ├──────────────────────────────────────────────────────────────────────────────┤ │ @important │ │ For any future changes to the code in this file, it is recommended to │ │ include, together with the modification, the information of the developer │ │ who changed it and the date of modification. │ └──────────────────────────────────────────────────────────────────────────────┘ */ "use client"; import { useState } from "react"; import { Input } from "@/components/ui/input"; import { Search, X, Filter } from "lucide-react"; import { Select, SelectContent, SelectItem, SelectTrigger, SelectValue, } from "@/components/ui/select"; import { Button } from "@/components/ui/button"; import { Popover, PopoverContent, PopoverTrigger, } from "@/components/ui/popover"; interface SearchInputProps { value: string; onChange: (value: string) => void; placeholder?: string; className?: string; selectedAgentType?: string | null; onAgentTypeChange?: (type: string | null) => void; agentTypes?: string[]; } // Using "all" as a special value to represent no filter const ANY_TYPE_VALUE = "all"; export function SearchInput({ value, onChange, placeholder = "Search agents...", className = "", selectedAgentType = null, onAgentTypeChange, agentTypes = [], }: SearchInputProps) { const [isFilterOpen, setIsFilterOpen] = useState(false); const handleTypeChange = (value: string) => { if (onAgentTypeChange) { onAgentTypeChange(value === ANY_TYPE_VALUE ? null : value); } }; return (