51 lines
1.3 KiB
TypeScript
51 lines
1.3 KiB
TypeScript
import { Container, Group, Text } from '@mantine/core'
|
|
import classes from '@/styles/Header.module.css'
|
|
import { pageConfig } from '@/uptime.config'
|
|
|
|
export default function Header() {
|
|
const linkToElement = (link: { label: string; link: string; highlight?: boolean }) => {
|
|
return (
|
|
<a
|
|
key={link.label}
|
|
href={link.link}
|
|
target="_blank"
|
|
className={classes.link}
|
|
data-active={link.highlight}
|
|
>
|
|
{link.label}
|
|
</a>
|
|
)
|
|
}
|
|
|
|
return (
|
|
<header className={classes.header}>
|
|
<Container size="md" className={classes.inner}>
|
|
<div>
|
|
<a href="https://github.com/lyc8503/UptimeFlare" target="_blank">
|
|
<Text size="xl" span>
|
|
🕒
|
|
</Text>
|
|
<Text
|
|
size="xl"
|
|
span
|
|
fw={700}
|
|
variant="gradient"
|
|
gradient={{ from: 'blue', to: 'cyan', deg: 90 }}
|
|
>
|
|
UptimeFlare
|
|
</Text>
|
|
</a>
|
|
</div>
|
|
|
|
<Group gap={5} visibleFrom="sm">
|
|
{pageConfig.links.map(linkToElement)}
|
|
</Group>
|
|
|
|
<Group gap={5} hiddenFrom="sm">
|
|
{pageConfig.links.filter((link) => (link as any).highlight).map(linkToElement)}
|
|
</Group>
|
|
</Container>
|
|
</header>
|
|
)
|
|
}
|