umami/src/components/layout/PageHeader.tsx

37 lines
805 B
TypeScript
Raw Normal View History

2023-05-20 16:02:08 +00:00
import classNames from 'classnames';
2023-09-29 12:29:22 +00:00
import React, { ReactNode } from 'react';
2024-01-29 11:15:22 +00:00
import { Icon } from 'react-basics';
2020-08-07 07:24:01 +00:00
import styles from './PageHeader.module.css';
2024-01-29 11:15:22 +00:00
export function PageHeader({
title,
icon,
className,
2024-03-02 18:51:29 +00:00
breadcrumb,
2024-01-29 11:15:22 +00:00
children,
}: {
title?: ReactNode;
2024-01-29 11:15:22 +00:00
icon?: ReactNode;
2023-09-29 12:29:22 +00:00
className?: string;
2024-03-02 18:51:29 +00:00
breadcrumb?: ReactNode;
2023-10-01 23:11:12 +00:00
children?: ReactNode;
2024-01-29 11:15:22 +00:00
}) {
return (
2024-03-02 18:51:29 +00:00
<>
<div className={styles.breadcrumb}>{breadcrumb}</div>
<div className={classNames(styles.header, className)}>
{icon && (
<Icon size="lg" className={styles.icon}>
{icon}
</Icon>
)}
{title && <div className={styles.title}>{title}</div>}
<div className={styles.actions}>{children}</div>
</div>
</>
);
2020-08-07 07:24:01 +00:00
}
2023-04-21 15:00:42 +00:00
export default PageHeader;