import { ActionIcon, LoadingOverlay, Space, Title, Tooltip } from '@mantine/core'; import React, { useEffect, useState } from 'react'; import { BsPlusLg } from "react-icons/bs"; import { useNavigate } from 'react-router-dom'; import ServiceRow from '../components/ServiceRow'; import { Service } from '../js/models'; import { errorNotify, eventUpdateName, fireUpdateRequest, servicelist } from '../js/utils'; import AddNewService from '../components/AddNewService'; import { useWindowEvent } from '@mantine/hooks'; function HomePage() { const [services, setServices] = useState([]); const [loader, setLoader] = useState(true); const navigator = useNavigate() const [open, setOpen] = useState(false); const [tooltipAddServOpened, setTooltipAddServOpened] = useState(false); const updateInfo = async () => { await servicelist().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
{services.length > 0?services.map( srv => { navigator("/"+srv.port) }} />):<> 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)}>
}
} export default HomePage;