import { ActionIcon, Badge, Box, LoadingOverlay, Space, ThemeIcon, Title, Tooltip } from '@mantine/core'; import { useEffect, useState } from 'react'; import { BsPlusLg } from "react-icons/bs"; import { useNavigate, useParams } from 'react-router-dom'; import ServiceRow from '../../components/NFProxy/ServiceRow'; import { errorNotify, getErrorMessage, isMediumScreen } from '../../js/utils'; import AddEditService from '../../components/NFProxy/AddEditService'; import { useQueryClient } from '@tanstack/react-query'; import { TbPlugConnected, TbReload } from 'react-icons/tb'; import { nfproxyServiceQuery } from '../../components/NFProxy/utils'; import { FaFilter, FaPencilAlt, FaServer } from 'react-icons/fa'; import { VscRegex } from 'react-icons/vsc'; export default function NFProxy({ children }: { children: any }) { const navigator = useNavigate() const [open, setOpen] = useState(false); const {srv} = useParams() const queryClient = useQueryClient() const [tooltipRefreshOpened, setTooltipRefreshOpened] = useState(false); const [tooltipAddServOpened, setTooltipAddServOpened] = useState(false); const [tooltipAddOpened, setTooltipAddOpened] = useState(false); const isMedium = isMediumScreen() const services = nfproxyServiceQuery() useEffect(()=> { if(services.isError) errorNotify("NFProxy Update failed!", getErrorMessage(services.error)) },[services.isError]) const closeModal = () => {setOpen(false);} return <> <ThemeIcon radius="md" size="md" variant='filled' color='lime' ><TbPlugConnected size={20} /></ThemeIcon><Space w="xs" />Netfilter Proxy {isMedium?:} General stats: Services: {services.isLoading?0:services.data?.length} {services.isLoading?0:services.data?.reduce((acc, s)=> acc+=s.blocked_packets, 0)} {services.isLoading?0:services.data?.reduce((acc, s)=> acc+=s.edited_packets, 0)} {services.isLoading?0:services.data?.reduce((acc, s)=> acc+=s.n_filters, 0)} {isMedium?null:} {/* Will become the null a button to edit the source code? TODO */} { srv?null : setOpen(true)} size="lg" radius="md" variant="filled" onFocus={() => setTooltipAddOpened(false)} onBlur={() => setTooltipAddOpened(false)} onMouseEnter={() => setTooltipAddOpened(true)} onMouseLeave={() => setTooltipAddOpened(false)}> } queryClient.invalidateQueries(["nfproxy"])} size="lg" radius="md" variant="filled" loading={services.isFetching} onFocus={() => setTooltipRefreshOpened(false)} onBlur={() => setTooltipRefreshOpened(false)} onMouseEnter={() => setTooltipRefreshOpened(true)} onMouseLeave={() => setTooltipRefreshOpened(false)}> {srv?null:<> {(services.data && services.data?.length > 0)?services.data.map( srv => { navigator("/nfproxy/"+srv.service_id) }} />):<> No services found! Add one clicking the "+" buttons setOpen(true)} size="xl" radius="md" variant="filled" onFocus={() => setTooltipAddServOpened(false)} onBlur={() => setTooltipAddServOpened(false)} onMouseEnter={() => setTooltipAddServOpened(true)} onMouseLeave={() => setTooltipAddServOpened(false)}> } } {srv?children:null} {!srv?:null} }