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

60 lines
3.1 KiB
TypeScript
Raw Normal View History

import { ActionIcon, Badge, 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';
import { errorNotify, getErrorMessage } from '../../js/utils';
import AddNewService from '../../components/PortHijack/AddNewService';
function PortHijack() {
const [open, setOpen] = useState(false);
const [tooltipAddServOpened, setTooltipAddServOpened] = useState(false);
const [tooltipAddOpened, setTooltipAddOpened] = useState(false);
2023-09-24 05:48:54 +02:00
const services = porthijackServiceQuery()
useEffect(()=>{
if(services.isError){
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" />
<div className='center-flex'>
<Title order={4}>Hijack port to proxy</Title>
<div className='flex-spacer' />
2023-09-24 05:48:54 +02:00
<Badge size="sm" color="yellow" variant="filled">Services: {services.isLoading?0:services.data?.length}</Badge>
2022-08-12 16:00:58 +00:00
<Space w="xs" />
2023-06-05 00:55:38 +02:00
<Tooltip label="Add a new service" position='bottom' color="blue" opened={tooltipAddOpened}>
2022-08-12 16:00:58 +00:00
<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>
</div>
<div id="service-list" className="center-flex-row">
2023-09-24 05:48:54 +02:00
<LoadingOverlay visible={services.isLoading} />
{(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>
2022-08-12 16:00:58 +00:00
<Space h="xl" /> <Space h="xl" /> <Space h="xl" /> <Space h="xl" />
<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>
<AddNewService opened={open} onClose={closeModal} />
</>
}
export default PortHijack;