blob: 91add77e6b9cf3d58fa755738a62d571160a5b35 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
|
import { type ForwardRefRenderFunction, forwardRef } from 'react';
import { AUTHOR_ID } from '../../../../utils/constants';
import { Header, type HeaderProps } from '../../../atoms';
import { SiteBranding } from './site-branding';
import styles from './site-header.module.scss';
import { SiteNavbar } from './site-navbar';
export type SiteHeaderProps = Omit<HeaderProps, 'children'> & {
isHome?: boolean;
};
const SiteHeaderWithRef: ForwardRefRenderFunction<
HTMLElement,
SiteHeaderProps
> = ({ className = '', isHome = false, ...props }, ref) => {
const headerClass = `${styles.header} ${className}`;
return (
<Header {...props} className={headerClass} ref={ref}>
<SiteBranding
className={styles.branding}
id={AUTHOR_ID}
isHome={isHome}
/>
<SiteNavbar className={styles.navbar} />
</Header>
);
};
export const SiteHeader = forwardRef(SiteHeaderWithRef);
|