import { AppBar, CircularProgress, Dialog, IconButton, TextField, Toolbar } from '@mui/material' import { Fragment, useState } from 'react' import { IRegion } from '../interfaces/fuel' import { useServerIps, useServers } from '../hooks/swrHooks' import ServerService from '../services/ServersService' import { GridColDef } from '@mui/x-data-grid' import { Close } from '@mui/icons-material' import ServerData from './ServerData' import { Autocomplete, CloseButton, Table } from '@mantine/core' import { IServer } from '../interfaces/servers' export default function ServerIpsView() { const [open, setOpen] = useState(false) const [selectedOption, setSelectedOption] = useState(null) const { servers, isLoading } = useServers() const [serverDataOpen, setServerDataOpen] = useState(false) const [currentServerData, setCurrentServerData] = useState(null) const handleInputChange = (value: string) => { return value } const handleOptionChange = (value: IRegion | null) => { setSelectedOption(value) } const { serverIps, isLoading: serversLoading } = useServerIps(selectedOption?.id, 0, 10) const serverIpsColumns: GridColDef[] = [ { field: 'id', headerName: 'ID', type: 'number' }, { field: 'server_id', headerName: 'Server ID', type: 'number' }, { field: 'name', headerName: 'Название', type: 'string' }, { field: 'is_actual', headerName: 'Действителен', type: 'boolean' }, { field: 'ip', headerName: 'IP', type: 'string' }, { field: 'servername', headerName: 'Название сервера', type: 'string' }, ] return ( <> { setServerDataOpen(false) }} aria-labelledby="modal-modal-title" aria-describedby="modal-modal-description"> { setServerDataOpen(false) }} aria-label="close" > {currentServerData && }
({ label: item.name, value: item.id.toString() })) : []} onSelect={(e) => console.log(e.currentTarget.value)} //onChange={(value) => setSearch(value)} onOptionSubmit={(value) => setSelectedOption(Number(value))} rightSection={ //search !== '' && ( event.preventDefault()} onClick={() => { //setSearch('') setSelectedOption(null) }} aria-label="Clear value" /> ) } //value={search} /> {serversLoading ? : // { // setOpen(true) // }} // onClose={() => { // setOpen(false) // }} // onInputChange={(_, value) => handleInputChange(value)} // onChange={(_, value) => handleOptionChange(value)} // filterOptions={(x) => x} // isOptionEqualToValue={(option: IRegion, value: IRegion) => option.name === value.name} // getOptionLabel={(option: IRegion) => option.name ? option.name : ""} // options={servers || []} // loading={isLoading} // value={selectedOption} // renderInput={(params) => ( // // {isLoading ? : null} // {params.InputProps.endAdornment} // // ) // }} /> // )} />} // onSave={() => { // }} // onDelete={ServerService.removeServer} // initialRows={serverIps || []} // columns={serverIpsColumns} // actions // onRowClick={(params) => { // setCurrentServerData(params.row) // setServerDataOpen(true) // }} loading={false} // /> {serverIpsColumns.map(column => ( {column.headerName} ))} {serverIpsColumns.map(column => ( {servers ? servers[column.field] : ''} ))}
} ) }