Files
firegex-traffic-viewer/frontend/src/pages/PortHijack/index.tsx

73 lines
4.1 KiB
TypeScript
Raw Normal View History

2023-10-12 20:01:48 +02:00
import { ActionIcon, Badge, Divider, LoadingOverlay, Space, Title, Tooltip } from '@mantine/core';
2023-09-24 05:48:54 +02:00
import { useEffect, useState } from 'react';
import { BsPlusLg } from "react-icons/bs";
import ServiceRow from '../../components/PortHijack/ServiceRow';
2023-09-24 05:48:54 +02:00
import { porthijackServiceQuery } from '../../components/PortHijack/utils';
2023-10-12 20:01:48 +02:00
import { errorNotify, getErrorMessage, isMediumScreen } from '../../js/utils';
import AddNewService from '../../components/PortHijack/AddNewService';
2023-09-24 17:05:55 +02:00
import { useQueryClient } from '@tanstack/react-query';
import { TbReload } from 'react-icons/tb';
function PortHijack() {
const [open, setOpen] = useState(false);
const [tooltipAddServOpened, setTooltipAddServOpened] = useState(false);
const [tooltipAddOpened, setTooltipAddOpened] = useState(false);
2023-09-24 17:05:55 +02:00
const queryClient = useQueryClient()
const [tooltipRefreshOpened, setTooltipRefreshOpened] = useState(false);
2023-10-12 20:01:48 +02:00
const isMedium = isMediumScreen()
2023-09-24 05:48:54 +02:00
const services = porthijackServiceQuery()
useEffect(()=>{
2023-09-24 17:05:55 +02:00
if(services.isError)
2023-09-24 05:48:54 +02:00
errorNotify("Porthijack Update failed!", getErrorMessage(services.error))
},[services.isError])
const closeModal = () => {setOpen(false);}
return <>
2022-08-12 16:00:58 +00:00
<Space h="sm" />
2023-10-12 20:01:48 +02:00
<div className={isMedium?'center-flex':'center-flex-row'}>
2022-08-12 16:00:58 +00:00
<Title order={4}>Hijack port to proxy</Title>
2023-10-12 20:01:48 +02:00
{isMedium?<div className='flex-spacer' />:<Space h="sm" />}
<div className='center-flex'>
<Badge size="sm" color="yellow" variant="filled">Services: {services.isLoading?0:services.data?.length}</Badge>
<Space w="xs" />
<Tooltip label="Add a new service" position='bottom' color="blue" opened={tooltipAddOpened}>
<ActionIcon color="blue" onClick={()=>setOpen(true)} size="lg" radius="md" variant="filled"
onFocus={() => setTooltipAddOpened(false)} onBlur={() => setTooltipAddOpened(false)}
onMouseEnter={() => setTooltipAddOpened(true)} onMouseLeave={() => setTooltipAddOpened(false)}><BsPlusLg size={18} /></ActionIcon>
</Tooltip>
<Space w="xs" />
<Tooltip label="Refresh" position='bottom' color="indigo" opened={tooltipRefreshOpened}>
<ActionIcon color="indigo" onClick={()=>queryClient.invalidateQueries(["porthijack"])} size="lg" radius="md" variant="filled"
loading={services.isFetching}
onFocus={() => setTooltipRefreshOpened(false)} onBlur={() => setTooltipRefreshOpened(false)}
onMouseEnter={() => setTooltipRefreshOpened(true)} onMouseLeave={() => setTooltipRefreshOpened(false)}><TbReload size={18} /></ActionIcon>
</Tooltip>
</div>
2022-08-12 16:00:58 +00:00
</div>
2023-10-12 20:01:48 +02:00
<Space h="md" /><Divider size="sm" style={{width:"100%"}}/>
2022-08-12 16:00:58 +00:00
<div id="service-list" className="center-flex-row">
2023-09-24 05:48:54 +02:00
<LoadingOverlay visible={services.isLoading} />
2023-10-12 20:01:48 +02:00
2023-09-24 05:48:54 +02:00
{(services.data && services.data.length > 0) ?services.data.map( srv => <ServiceRow service={srv} key={srv.service_id} />):<>
<Space h="xl"/> <Title className='center-flex' align='center' order={3}>No services found! Add one clicking the "+" buttons</Title>
2023-09-25 20:43:29 +02:00
<Space h="xl" /> <Space h="xl" />
2022-08-12 16:00:58 +00:00
<div className='center-flex'>
2023-06-05 00:55:38 +02:00
<Tooltip label="Add a new service" color="blue" opened={tooltipAddServOpened}>
2022-08-12 16:00:58 +00:00
<ActionIcon color="blue" onClick={()=>setOpen(true)} size="xl" radius="md" variant="filled"
onFocus={() => setTooltipAddServOpened(false)} onBlur={() => setTooltipAddServOpened(false)}
onMouseEnter={() => setTooltipAddServOpened(true)} onMouseLeave={() => setTooltipAddServOpened(false)}><BsPlusLg size="20px" /></ActionIcon>
</Tooltip>
</div>
</>}
<AddNewService opened={open} onClose={closeModal} />
</div>
</>
}
export default PortHijack;