40 lines
981 B
TypeScript
40 lines
981 B
TypeScript
import { AppViewState, PageMeta } from "../types";
|
|
import { FontAwesomeIcon } from "@fortawesome/react-fontawesome";
|
|
import { faFileLines } from "@fortawesome/free-solid-svg-icons";
|
|
import { Notification } from "../types";
|
|
|
|
function prettyName(s: string | undefined): string {
|
|
if (!s) {
|
|
return "";
|
|
}
|
|
return s.replaceAll("/", " / ");
|
|
}
|
|
|
|
export function TopBar({
|
|
pageName,
|
|
status,
|
|
notifications,
|
|
onClick,
|
|
}: {
|
|
pageName?: string;
|
|
status?: string;
|
|
notifications: Notification[];
|
|
onClick: () => void;
|
|
}) {
|
|
return (
|
|
<div id="top" onClick={onClick}>
|
|
<div className="inner">
|
|
<span className="icon">
|
|
<FontAwesomeIcon icon={faFileLines} />
|
|
</span>
|
|
<span className="current-page">{prettyName(pageName)}</span>
|
|
<div className="status">
|
|
{notifications.map((notification) => (
|
|
<div key={notification.id}>{notification.message}</div>
|
|
))}
|
|
</div>
|
|
</div>
|
|
</div>
|
|
);
|
|
}
|