mirror of
https://github.com/maelgangloff/domain-watchdog.git
synced 2025-12-29 16:15:04 +00:00
chore: avoid overloading the watchlist page
This commit is contained in:
@@ -11,12 +11,13 @@ import UserPage from "./pages/UserPage";
|
|||||||
import React, {useCallback, useEffect, useMemo, useState} from "react";
|
import React, {useCallback, useEffect, useMemo, useState} from "react";
|
||||||
import {getUser} from "./utils/api";
|
import {getUser} from "./utils/api";
|
||||||
import LoginPage, {AuthenticatedContext} from "./pages/LoginPage";
|
import LoginPage, {AuthenticatedContext} from "./pages/LoginPage";
|
||||||
import ConnectorsPage from "./pages/tracking/ConnectorsPage";
|
import ConnectorPage from "./pages/tracking/ConnectorPage";
|
||||||
import NotFoundPage from "./pages/NotFoundPage";
|
import NotFoundPage from "./pages/NotFoundPage";
|
||||||
import useBreakpoint from "./hooks/useBreakpoint";
|
import useBreakpoint from "./hooks/useBreakpoint";
|
||||||
import {Sider} from "./components/Sider";
|
import {Sider} from "./components/Sider";
|
||||||
import {jt, t} from "ttag";
|
import {jt, t} from "ttag";
|
||||||
import {BugOutlined, InfoCircleOutlined, MergeOutlined} from '@ant-design/icons'
|
import {BugOutlined, InfoCircleOutlined, MergeOutlined} from '@ant-design/icons'
|
||||||
|
import TrackedDomainPage from "./pages/tracking/TrackedDomainPage";
|
||||||
|
|
||||||
const PROJECT_LINK = 'https://github.com/maelgangloff/domain-watchdog'
|
const PROJECT_LINK = 'https://github.com/maelgangloff/domain-watchdog'
|
||||||
const LICENSE_LINK = 'https://www.gnu.org/licenses/agpl-3.0.txt'
|
const LICENSE_LINK = 'https://www.gnu.org/licenses/agpl-3.0.txt'
|
||||||
@@ -100,7 +101,8 @@ export default function App() {
|
|||||||
<Route path="/search/tld" element={<TldPage/>}/>
|
<Route path="/search/tld" element={<TldPage/>}/>
|
||||||
|
|
||||||
<Route path="/tracking/watchlist" element={<WatchlistPage/>}/>
|
<Route path="/tracking/watchlist" element={<WatchlistPage/>}/>
|
||||||
<Route path="/tracking/connectors" element={<ConnectorsPage/>}/>
|
<Route path="/tracking/domains" element={<TrackedDomainPage/>}/>
|
||||||
|
<Route path="/tracking/connectors" element={<ConnectorPage/>}/>
|
||||||
|
|
||||||
<Route path="/stats" element={<StatisticsPage/>}/>
|
<Route path="/stats" element={<StatisticsPage/>}/>
|
||||||
<Route path="/user" element={<UserPage/>}/>
|
<Route path="/user" element={<UserPage/>}/>
|
||||||
|
|||||||
@@ -4,7 +4,6 @@ import {
|
|||||||
AimOutlined,
|
AimOutlined,
|
||||||
ApiOutlined,
|
ApiOutlined,
|
||||||
BankOutlined,
|
BankOutlined,
|
||||||
CloudServerOutlined,
|
|
||||||
CompassOutlined,
|
CompassOutlined,
|
||||||
FileSearchOutlined,
|
FileSearchOutlined,
|
||||||
HomeOutlined,
|
HomeOutlined,
|
||||||
@@ -12,10 +11,10 @@ import {
|
|||||||
LoginOutlined,
|
LoginOutlined,
|
||||||
LogoutOutlined,
|
LogoutOutlined,
|
||||||
SearchOutlined,
|
SearchOutlined,
|
||||||
TeamOutlined,
|
TableOutlined,
|
||||||
UserOutlined
|
UserOutlined
|
||||||
} from "@ant-design/icons";
|
} from "@ant-design/icons";
|
||||||
import {Badge, Menu} from "antd";
|
import {Menu} from "antd";
|
||||||
import React from "react";
|
import React from "react";
|
||||||
import {useNavigate} from "react-router-dom";
|
import {useNavigate} from "react-router-dom";
|
||||||
|
|
||||||
@@ -50,6 +49,7 @@ export function Sider({isAuthenticated}: { isAuthenticated: boolean }) {
|
|||||||
disabled: !isAuthenticated,
|
disabled: !isAuthenticated,
|
||||||
onClick: () => navigate('/search/tld')
|
onClick: () => navigate('/search/tld')
|
||||||
},
|
},
|
||||||
|
/*
|
||||||
{
|
{
|
||||||
key: 'entity-finder',
|
key: 'entity-finder',
|
||||||
icon: <TeamOutlined/>,
|
icon: <TeamOutlined/>,
|
||||||
@@ -66,6 +66,7 @@ export function Sider({isAuthenticated}: { isAuthenticated: boolean }) {
|
|||||||
disabled: true,
|
disabled: true,
|
||||||
onClick: () => navigate('/search/nameserver')
|
onClick: () => navigate('/search/nameserver')
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -75,11 +76,18 @@ export function Sider({isAuthenticated}: { isAuthenticated: boolean }) {
|
|||||||
children: [
|
children: [
|
||||||
{
|
{
|
||||||
key: 'watchlist',
|
key: 'watchlist',
|
||||||
icon: <Badge count={0} size="small"><FileSearchOutlined/></Badge>,
|
icon: <FileSearchOutlined/>,
|
||||||
label: t`My Watchlists`,
|
label: t`My Watchlists`,
|
||||||
disabled: !isAuthenticated,
|
disabled: !isAuthenticated,
|
||||||
onClick: () => navigate('/tracking/watchlist')
|
onClick: () => navigate('/tracking/watchlist')
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
key: 'tracked-domain',
|
||||||
|
icon: <TableOutlined/>,
|
||||||
|
label: t`Tracked domain names`,
|
||||||
|
disabled: !isAuthenticated,
|
||||||
|
onClick: () => navigate('/tracking/domains')
|
||||||
|
},
|
||||||
{
|
{
|
||||||
key: 'connectors',
|
key: 'connectors',
|
||||||
icon: <ApiOutlined/>,
|
icon: <ApiOutlined/>,
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ import {ConnectorElement, ConnectorsList} from "../../components/tracking/connec
|
|||||||
|
|
||||||
import {showErrorAPI} from "../../utils/functions/showErrorAPI";
|
import {showErrorAPI} from "../../utils/functions/showErrorAPI";
|
||||||
|
|
||||||
export default function ConnectorsPage() {
|
export default function ConnectorPage() {
|
||||||
const [form] = Form.useForm()
|
const [form] = Form.useForm()
|
||||||
const [messageApi, contextHolder] = message.useMessage()
|
const [messageApi, contextHolder] = message.useMessage()
|
||||||
const [connectors, setConnectors] = useState<ConnectorElement[] | null>()
|
const [connectors, setConnectors] = useState<ConnectorElement[] | null>()
|
||||||
14
assets/pages/tracking/TrackedDomainPage.tsx
Normal file
14
assets/pages/tracking/TrackedDomainPage.tsx
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
import {Card, Flex} from "antd";
|
||||||
|
import {t} from "ttag";
|
||||||
|
import {TrackedDomainTable} from "../../components/tracking/watchlist/TrackedDomainTable";
|
||||||
|
import React from "react";
|
||||||
|
|
||||||
|
export default function TrackedDomainPage() {
|
||||||
|
|
||||||
|
return <Flex gap="middle" align="center" justify="center" vertical>
|
||||||
|
<Card title={t`Tracked domain names`}
|
||||||
|
style={{width: '100%', height: '80vh'}}>
|
||||||
|
<TrackedDomainTable/>
|
||||||
|
</Card>
|
||||||
|
</Flex>
|
||||||
|
}
|
||||||
@@ -1,5 +1,5 @@
|
|||||||
import React, {useEffect, useState} from "react";
|
import React, {useEffect, useState} from "react";
|
||||||
import {Card, Divider, Flex, Form, message, Tag} from "antd";
|
import {Card, Divider, Flex, Form, message} from "antd";
|
||||||
import {EventAction, getWatchlists, postWatchlist, putWatchlist} from "../../utils/api";
|
import {EventAction, getWatchlists, postWatchlist, putWatchlist} from "../../utils/api";
|
||||||
import {AxiosError} from "axios";
|
import {AxiosError} from "axios";
|
||||||
import {t} from 'ttag'
|
import {t} from 'ttag'
|
||||||
@@ -8,8 +8,6 @@ import {WatchlistsList} from "../../components/tracking/watchlist/WatchlistsList
|
|||||||
import {Connector, getConnectors} from "../../utils/api/connectors";
|
import {Connector, getConnectors} from "../../utils/api/connectors";
|
||||||
|
|
||||||
import {showErrorAPI} from "../../utils/functions/showErrorAPI";
|
import {showErrorAPI} from "../../utils/functions/showErrorAPI";
|
||||||
import {TrackedDomainTable} from "../../components/tracking/watchlist/TrackedDomainTable";
|
|
||||||
import {AimOutlined} from "@ant-design/icons";
|
|
||||||
|
|
||||||
|
|
||||||
export type Watchlist = {
|
export type Watchlist = {
|
||||||
@@ -99,16 +97,6 @@ export default function WatchlistPage() {
|
|||||||
|
|
||||||
return <Flex gap="middle" align="center" justify="center" vertical>
|
return <Flex gap="middle" align="center" justify="center" vertical>
|
||||||
{contextHolder}
|
{contextHolder}
|
||||||
<Card title={
|
|
||||||
<>
|
|
||||||
<Tag icon={<AimOutlined/>} color="cyan-inverse"/>
|
|
||||||
{t`Tracked domain names`}
|
|
||||||
</>
|
|
||||||
}
|
|
||||||
style={{width: '100%'}}>
|
|
||||||
<TrackedDomainTable/>
|
|
||||||
</Card>
|
|
||||||
<Divider/>
|
|
||||||
<Card loading={connectors === undefined} title={t`Create a Watchlist`} style={{width: '100%'}}>
|
<Card loading={connectors === undefined} title={t`Create a Watchlist`} style={{width: '100%'}}>
|
||||||
{connectors &&
|
{connectors &&
|
||||||
<WatchlistForm form={form} onFinish={onCreateWatchlist} connectors={connectors} isCreation={true}/>
|
<WatchlistForm form={form} onFinish={onCreateWatchlist} connectors={connectors} isCreation={true}/>
|
||||||
|
|||||||
Reference in New Issue
Block a user