Files
frp-panel/www/components/base/server-selector.tsx
2024-12-04 16:24:04 +00:00

35 lines
1.1 KiB
TypeScript

import React from 'react'
import { keepPreviousData, useQuery } from '@tanstack/react-query'
import { listServer } from '@/api/server'
import { Combobox } from './combobox'
export interface ServerSelectorProps {
serverID?: string
setServerID: (serverID: string) => void
onOpenChange?: () => void
}
export const ServerSelector: React.FC<ServerSelectorProps> = ({ serverID, setServerID, onOpenChange }) => {
const handleServerChange = (value: string) => { setServerID(value) }
const [keyword, setKeyword] = React.useState('')
const { data: serverList, refetch: refetchServers } = useQuery({
queryKey: ['listServer', keyword],
queryFn: () => {
return listServer({ page: 1, pageSize: 8, keyword: keyword })
},
placeholderData: keepPreviousData,
})
return (<Combobox
placeholder='服务端名称'
value={serverID}
setValue={handleServerChange}
dataList={serverList?.servers.map((server) => ({ value: server.id || '', label: server.id || '' })) || []}
onKeyWordChange={setKeyword}
onOpenChange={() => {
onOpenChange && onOpenChange()
refetchServers()
}}
/>)
}