36 lines
1.1 KiB
JavaScript
36 lines
1.1 KiB
JavaScript
import config from '../../config.yaml'
|
|
|
|
const classes = {
|
|
green:
|
|
'bg-green-200 text-green-700 dark:bg-green-700 dark:text-green-200 border-green-300 dark:border-green-600',
|
|
yellow:
|
|
'bg-yellow-200 text-yellow-700 dark:bg-yellow-700 dark:text-yellow-200 border-yellow-300 dark:border-yellow-600',
|
|
}
|
|
|
|
export default function MonitorStatusHeader({ kvMonitorsMetadata }) {
|
|
let color = 'green'
|
|
let text = config.settings.allmonitorsOperational
|
|
|
|
if (!kvMonitorsMetadata.monitorsOperational) {
|
|
color = 'yellow'
|
|
text = config.settings.notAllmonitorsOperational
|
|
}
|
|
|
|
return (
|
|
<div className={`card mb-4 font-semibold ${classes[color]}`}>
|
|
<div className="flex flex-row justify-between items-center">
|
|
<div>{text}</div>
|
|
{kvMonitorsMetadata.lastUpdate && typeof window !== 'undefined' && (
|
|
<div className="text-xs font-light">
|
|
checked{' '}
|
|
{Math.round(
|
|
(Date.now() - kvMonitorsMetadata.lastUpdate.time) / 1000,
|
|
)}{' '}
|
|
sec ago (from {kvMonitorsMetadata.lastUpdate.loc})
|
|
</div>
|
|
)}
|
|
</div>
|
|
</div>
|
|
)
|
|
}
|