1
0
mirror of https://github.com/phuoc-ng/csslayout.git synced 2025-10-24 03:06:22 +02:00
Files
csslayout/components/HeaderBlock.tsx
Phuoc Nguyen bced6a1df5 Add layout
2021-09-27 20:32:58 +07:00

38 lines
1.2 KiB
TypeScript

import Link from 'next/link';
import * as React from 'react';
import { Logo } from '@1milligram/design';
export const HeaderBlock = () => {
const [totalStars, setTotalStars] = React.useState(0);
React.useEffect(() => {
fetch('https://api.github.com/repos/1milligram/csslayout')
.then((res) => res.json())
.then((data) => setTotalStars(data.stargazers_count))
.catch(console.log);
}, []);
const HeaderLogo = React.forwardRef<HTMLAnchorElement, React.LinkHTMLAttributes<HTMLAnchorElement>>(
(props, ref) => (
<a href={props.href} onClick={props.onClick} ref={ref}>
<Logo brand="CSS Layout" />
</a>
)
);
return (
<header className="block-header">
<div className="block-container">
<div className="block-header__inner">
<Link href="/" passHref>
<HeaderLogo />
</Link>
<Link href="https://github.com/1milligram/csslayout">
<a className="block-header__cta">GitHub {totalStars}</a>
</Link>
</div>
</div>
</header>
);
};