import { ActionIcon, Badge, LoadingOverlay, Space, Title, Tooltip } from "@mantine/core" import { useEffect, useState } from "react"; import { BsPlusLg } from "react-icons/bs" import { ActionType, GeneralStats, RuleInfo, firewall } from "../../components/Firewall/utils"; import { errorNotify, eventUpdateName, fireUpdateRequest } from "../../js/utils"; import { useWindowEvent } from "@mantine/hooks"; export const Firewall = () => { const [generalStats, setGeneralStats] = useState({ rules: 0 }); const [rules, setRules] = useState({rules:[], policy:ActionType.ACCEPT}); const [loader, setLoader] = useState(true); const [tooltipAddOpened, setTooltipAddOpened] = useState(false); const [open, setOpen] = useState(false); const updateInfo = async () => { await Promise.all([ firewall.stats().then(res => { setGeneralStats(res) }).catch( err => errorNotify("General Info Auto-Update failed!", err.toString()) ), firewall.rules().then(res => { setRules(res) }).catch(err => { errorNotify("Home Page Auto-Update failed!", err.toString()) }) ]) setLoader(false) } useWindowEvent(eventUpdateName, updateInfo) useEffect(fireUpdateRequest,[]) return <>
Firewall Rules
Rules: {generalStats.rules} setOpen(true)} size="lg" radius="md" variant="filled" onFocus={() => setTooltipAddOpened(false)} onBlur={() => setTooltipAddOpened(false)} onMouseEnter={() => setTooltipAddOpened(true)} onMouseLeave={() => setTooltipAddOpened(false)}>
}