diff --git a/keep-ui/app/alerts/quality/alert-quality-table.tsx b/keep-ui/app/alerts/quality/alert-quality-table.tsx index f2a1f0ffe..5fe8f2877 100644 --- a/keep-ui/app/alerts/quality/alert-quality-table.tsx +++ b/keep-ui/app/alerts/quality/alert-quality-table.tsx @@ -1,10 +1,77 @@ "use client"; // Add this line at the top to make this a Client Component -import React, { useState, useEffect } from 'react'; -import { GenericTable } from '@/components/table/GenericTable'; -import { useAlertQualityMetrics } from 'utils/hooks/useAlertQuality'; -import { useProviders } from 'utils/hooks/useProviders'; -import { Providers } from 'app/providers/providers'; +import React, { + useState, + useEffect, + Dispatch, + SetStateAction, + useMemo, +} from "react"; +import { GenericTable } from "@/components/table/GenericTable"; +import { useAlertQualityMetrics } from "utils/hooks/useAlertQuality"; +import { useProviders } from "utils/hooks/useProviders"; +import { + Provider, + Providers, + ProvidersResponse, +} from "app/providers/providers"; +import { TabGroup, TabList, Tab } from "@tremor/react"; +import { GenericFilters } from "@/components/filters/GenericFilters"; + +const tabs = [ + { name: "All", value: "alltime" }, + { name: "Installed", value: "last_30d" }, + { name: "Linked", value: "last_7d" }, +]; + +const ALERT_QUALITY_FILTERS = [ + { + type: "date", + key: "time_stamp", + value: "", + name: "Last received", + }, + { + type: "select", + key: "field", + value: "", + name: "Field", + options: [ + { value: "team", label: "Team" }, + { value: "application", label: "Application" }, + { value: "subsystem", label: "Subsystem" }, + { value: "severity", label: "Severity" }, + { value: "priority", label: "Priority" }, + ], + }, +]; + +export const FilterTabs = ({ + tabs, + setTab, + tab, +}: { + tabs: { name: string; value: string }[]; + setTab: Dispatch>; + tab: number; +}) => { + return ( +
+ { + setTab(index); + }} + > + + {tabs.map((tabItem, index) => ( + {tabItem.name} + ))} + + +
+ ); +}; interface ProviderAlertQuality { alertsReceived: number; @@ -17,79 +84,140 @@ interface Pagination { limit: number; offset: number; } -const AlertQualityTable = () => { - const {data: providersMeta} = useProviders(); - const {data: alertsQualityMetrics, error} = useAlertQualityMetrics() + +const QualityTable = ({ + providersMeta, + alertsQualityMetrics, +}: { + providersMeta: ProvidersResponse | undefined; + alertsQualityMetrics: Record> | undefined; +}) => { const [pagination, setPagination] = useState({ - limit: 25, + limit: 10, offset: 0, -}); + }); + const [tab, setTab] = useState(0); + + const handlePaginationChange = (newLimit: number, newOffset: number) => { + setPagination({ limit: newLimit, offset: newOffset }); + }; + + useEffect(() => { + handlePaginationChange(10, 0); + },[tab]) + const columns = [ { - header: 'Provider Name', - accessorKey: 'display_name', + header: "Provider Name", + accessorKey: "display_name", }, { - header: 'Alerts Received', - accessorKey: 'alertsReceived', + header: "Alerts Received", + accessorKey: "alertsReceived", }, { - header: '% of Alerts Correlated to Incidents', - accessorKey: 'alertsCorrelatedToIncidentsPercentage', + header: "% of Alerts Correlated to Incidents", + accessorKey: "alertsCorrelatedToIncidentsPercentage", cell: (info: any) => `${info.getValue().toFixed(2)}%`, }, { - header: '% of Alerts Having Severity',//we are considering critical and warning as severe - accessorKey: 'alertsWithSeverityPercentage', + header: "% of Alerts Having Severity", //we are considering critical and warning as severe + accessorKey: "alertsWithSeverityPercentage", cell: (info: any) => `${info.getValue().toFixed(2)}%`, }, ]; - const finalData: Providers&ProviderAlertQuality[] = []; - const providers = providersMeta?.providers; + const finalData = useMemo(() => { + let providers: Provider[] | null = null; + + if (!providersMeta || !alertsQualityMetrics) { + return null; + } + switch (tab) { + case 0: + providers = providersMeta?.providers || providers; + break; + case 1: + providers = providersMeta?.installed_providers || providers; + break; + case 2: + providers = providersMeta.linked_providers || providers; + break; + default: + providers = providersMeta?.providers || providers; + break; + } - if (alertsQualityMetrics && providers) { - providers.forEach( provider => { - const providerType = provider.type; + if (!providers) { + return null; + } + + const innerData: Providers & ProviderAlertQuality[] = []; + + providers.forEach((provider) => { + const providerType = provider.type; const alertQuality = alertsQualityMetrics[providerType]; const totalAlertsReceived = alertQuality?.total_alerts ?? 0; const correlated_alerts = alertQuality?.correlated_alerts ?? 0; - const correltedPert = totalAlertsReceived && correlated_alerts ? (correlated_alerts/totalAlertsReceived)*100 : 0; - const severityPert = totalAlertsReceived ? ((alertQuality?.severity_count ?? 0)/totalAlertsReceived)*100 : 0 - finalData.push({ + const correltedPert = + totalAlertsReceived && correlated_alerts + ? (correlated_alerts / totalAlertsReceived) * 100 + : 0; + const severityPert = totalAlertsReceived + ? ((alertQuality?.severity_count ?? 0) / totalAlertsReceived) * 100 + : 0; + innerData.push({ ...provider, alertsReceived: totalAlertsReceived, alertsCorrelatedToIncidentsPercentage: correltedPert, alertsWithSeverityPercentage: severityPert, }); }); - } - const handlePaginationChange = (newLimit: number, newOffset: number) => { - setPagination({ limit: newLimit, offset: newOffset }) - }; + return innerData; + }, [tab, providersMeta, alertsQualityMetrics]); + + return ( + <> +

+ Alert Quality Dashboard +

+
+ + {/* TODO: filters are not working need to intergate with backend logic */} + +
+ {finalData && ( + { + console.log("Row clicked:", row); + }} + /> + )} + + ); +}; +const AlertQuality = () => { + const { data: providersMeta } = useProviders(); + const { data: alertsQualityMetrics, error } = useAlertQualityMetrics(); return (
-

- Alert Quality Dashboard -

- {providers && alertsQualityMetrics && { - console.log('Row clicked:', row); - }} - />} +
); }; -export default AlertQualityTable; +export default AlertQuality;