Skip to content

Commit

Permalink
feat: add auto refresh button
Browse files Browse the repository at this point in the history
  • Loading branch information
MattKetmo committed Nov 8, 2024
1 parent 09edd0d commit 1fc4e65
Show file tree
Hide file tree
Showing 7 changed files with 403 additions and 116 deletions.
1 change: 1 addition & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@
"@radix-ui/react-collapsible": "^1.1.1",
"@radix-ui/react-dialog": "^1.1.2",
"@radix-ui/react-dropdown-menu": "^2.1.2",
"@radix-ui/react-select": "^2.1.2",
"@radix-ui/react-separator": "^1.1.0",
"@radix-ui/react-slot": "^1.1.0",
"@radix-ui/react-tooltip": "^1.1.3",
Expand Down
65 changes: 65 additions & 0 deletions pnpm-lock.yaml

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

79 changes: 55 additions & 24 deletions src/components/alerts/template.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -4,13 +4,20 @@ import { Alert } from '@/types/alertmanager'
import { useAlerts } from '@/contexts/alerts'
import AppHeader from '@/components/layout/app-header'
import { AlertGroups } from './alert-groups'
import { RefreshCcw, TriangleAlert } from 'lucide-react'
import { LoaderCircle, RefreshCcw, TriangleAlert } from 'lucide-react'
import { useState } from 'react'
import { AlertModal } from './alert-modal'
import { LabelFilter, Group } from './types'
import { useConfig } from '@/contexts/config'
import { alertFilter, alertSort } from './utils'
import { notFound } from 'next/navigation'
import {
Select,
SelectContent,
SelectItem,
SelectTrigger,
SelectValue,
} from "@/components/ui/select"

type Props = {
view: string
Expand All @@ -19,14 +26,14 @@ type Props = {
export function AlertsTemplate(props: Props) {
const { view } = props
const { config } = useConfig()
const { alerts, loading, errors, refreshAlerts } = useAlerts()
const { alerts, loading, errors, refreshAlerts, refreshInterval, setRefreshInterval } = useAlerts()
const [selectedAlert, setSelectedAlert] = useState<Alert | null>(null)

if (!config.views[view]) {
return notFound()
}

const { filters, groupBy } = config.views[view]
const { filters, groupBy, name: viewName } = config.views[view]

// Flatten alerts
const flattenedAlerts = Object.values(alerts).reduce((acc, val) => acc.concat(val), [])
Expand All @@ -53,30 +60,53 @@ export function AlertsTemplate(props: Props) {
return (
<div className="flex flex-col h-screen overflow-clip">
<AppHeader>
<div className='flex items-center gap-2'>
<span className="font-medium">
<div className='flex items-center gap-2'>
<div className="font-medium">
Alerts
</span>
</div>
<div className="text-muted-foreground">/</div>
<div>
{viewName ?? view}
</div>
<div>
{
!loading && Object.entries(errors).length > 0 && (
<TriangleAlert
size={16}
className='text-orange-500'
/>
)
}
</div>

{
loading && (
<span>loading…</span>
<div className='grow' />

<button
disabled={loading}
onClick={() => refreshAlerts()}
className={loading ? 'cursor-not-allowed text-muted-foreground ' : ''}
>
{loading && (
<LoaderCircle size={16} className='animate-[spin_1s]' />
) || (
<RefreshCcw
size={16}
className='cursor-pointer'
onClick={() => refreshAlerts()}
/>
)
}
{
!loading && Object.entries(errors).length > 0 && (
<TriangleAlert
size={16}
className='text-orange-500'
/>
)
}
<RefreshCcw size={16} />
)}
</button>

<div>
<Select value={`${refreshInterval}`} onValueChange={(value) => setRefreshInterval(Number(value))}>
<SelectTrigger className="w-[100px] h-[30px]">
<SelectValue placeholder="Refresh" />
</SelectTrigger>
<SelectContent>
<SelectItem value="0">Off</SelectItem>
<SelectItem value="5">5s</SelectItem>
<SelectItem value="10">10s</SelectItem>
<SelectItem value="30">30s</SelectItem>
<SelectItem value="60">60s</SelectItem>
</SelectContent>
</Select>
</div>
</div>
</AppHeader>

Expand All @@ -95,6 +125,7 @@ export function AlertsTemplate(props: Props) {
Total of <span className="font-semibold">{filteredAlerts.length} alerts</span> displayed.
</span>
<button
disabled={loading}
onClick={() => refreshAlerts()}
className="font-semibold hover:underline underline-offset-2"
>
Expand Down
8 changes: 4 additions & 4 deletions src/components/layout/app-header.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -12,14 +12,14 @@ const Header = ({ children }: Props) => {
const sidebar = useSidebar()

return (
<header className="flex text-sm items-center px-6 border-b w-full h-[50px] shrink-0">
<div className="flex items-center gap-2">
<header className="flex text-sm items-center px-6 border-b w-full h-[50px] shrink-0 bg-400">
<div className="flex items-center gap-2 w-full">
{!sidebar.open ? (
<SidebarTrigger />
) : null}
<>
<div className="w-full">
{children}
</>
</div>
</div>
</header>
)
Expand Down
Loading

0 comments on commit 1fc4e65

Please sign in to comment.