import { ActionIcon, Badge, LoadingOverlay, Space, Title, Tooltip } from '@mantine/core'; import React, { useEffect, useState } from 'react'; import { BsPlusLg } from "react-icons/bs"; import { useNavigate, useParams } from 'react-router-dom'; import ServiceRow from '../../components/NFRegex/ServiceRow'; import { GeneralStats, nfregex, Service } from '../../components/NFRegex/utils'; import { errorNotify, eventUpdateName, fireUpdateRequest } from '../../js/utils'; import AddNewService from '../../components/NFRegex/AddNewService'; import { useWindowEvent } from '@mantine/hooks'; import AddNewRegex from '../../components/AddNewRegex'; function NFRegex({ children }: { children: any }) { const [services, setServices] = useState([]); const [loader, setLoader] = useState(true); const navigator = useNavigate() const [open, setOpen] = useState(false); const {srv} = useParams() const [tooltipAddServOpened, setTooltipAddServOpened] = useState(false); const [tooltipAddOpened, setTooltipAddOpened] = useState(false); const [generalStats, setGeneralStats] = useState({closed:0, regexes:0, services:0}); const updateInfo = async () => { await Promise.all([ nfregex.stats().then(res => { setGeneralStats(res) }).catch( err => errorNotify("General Info Auto-Update failed!", err.toString()) ), nfregex.services().then(res => { setServices(res) }).catch(err => { errorNotify("Home Page Auto-Update failed!", err.toString()) }) ]) setLoader(false) } useWindowEvent(eventUpdateName, updateInfo) useEffect(fireUpdateRequest,[]) const closeModal = () => {setOpen(false);} return <>
Netfilter Regex
Services: {generalStats.services} Filtered Connections: {generalStats.closed} Regexes: {generalStats.regexes} { srv? setOpen(true)} size="lg" radius="md" variant="filled" onFocus={() => setTooltipAddOpened(false)} onBlur={() => setTooltipAddOpened(false)} onMouseEnter={() => setTooltipAddOpened(true)} onMouseLeave={() => setTooltipAddOpened(false)}> : setOpen(true)} size="lg" radius="md" variant="filled" onFocus={() => setTooltipAddOpened(false)} onBlur={() => setTooltipAddOpened(false)} onMouseEnter={() => setTooltipAddOpened(true)} onMouseLeave={() => setTooltipAddOpened(false)}> }
{srv?null:<> {services.length > 0?services.map( srv => { navigator("/nfregex/"+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? : } } export default NFRegex;