import { ActionIcon, Badge, Box, LoadingOverlay, Space, ThemeIcon, Title, Tooltip } from '@mantine/core';
import { useEffect, useState } from 'react';
import { BsPlusLg, BsRegex } from "react-icons/bs";
import { useNavigate, useParams } from 'react-router-dom';
import ServiceRow from '../../components/NFRegex/ServiceRow';
import { nfregexServiceQuery } from '../../components/NFRegex/utils';
import { errorNotify, getErrorMessage, isMediumScreen } from '../../js/utils';
import AddEditService from '../../components/NFRegex/AddEditService';
import AddNewRegex from '../../components/AddNewRegex';
import { useQueryClient } from '@tanstack/react-query';
import { TbReload } from 'react-icons/tb';
import { FaFilter } from 'react-icons/fa';
import { FaServer } from "react-icons/fa6";
import { VscRegex } from "react-icons/vsc";
import { DocsButton } from '../../components/DocsButton';
function NFRegex({ children }: { children: any }) {
const navigator = useNavigate()
const [open, setOpen] = useState(false);
const {srv} = useParams()
const queryClient = useQueryClient()
const isMedium = isMediumScreen()
const services = nfregexServiceQuery()
useEffect(()=> {
if(services.isError)
errorNotify("NFRegex Update failed!", getErrorMessage(services.error))
},[services.isError])
const closeModal = () => {setOpen(false);}
return <>
Netfilter Regex
{isMedium?:}
{isMedium?"General stats:":null}
Services: {services.isLoading?0:services.data?.length}
{services.isLoading?0:services.data?.reduce((acc, s)=> acc+=s.n_packets, 0)}
{services.isLoading?0:services.data?.reduce((acc, s)=> acc+=s.n_regex, 0)}
{isMedium?null:}
{ srv?
setOpen(true)} size="lg" radius="md" variant="filled">
:
setOpen(true)} size="lg" radius="md" variant="filled">
}
queryClient.invalidateQueries(["nfregex"])} size="lg" radius="md" variant="filled"
loading={services.isFetching}>
{srv?null:<>
{(services.data && services.data?.length > 0)?services.data.map( srv => {
navigator("/nfregex/"+srv.service_id)
}} />):<> No services found! Add one clicking the "+" buttons
setOpen(true)} size="xl" radius="md" variant="filled">
>}
>}
{srv?children:null}
{srv?
:
}
>
}
export default NFRegex;