import type { CompletionContext, CompletionResult, } from "@codemirror/autocomplete"; import type { ComponentChildren, FunctionalComponent } from "preact"; import type { Notification } from "@silverbulletmd/silverbullet/type/client"; import type { FeatherProps } from "preact-feather/types"; import type { IconBaseProps } from "react-icons/types"; import { MiniEditor } from "./mini_editor.tsx"; export type ActionButton = { icon: FunctionalComponent; description: string; class?: string; callback: () => void; href?: string; mobile?: boolean; }; export function TopBar({ pageName, unsavedChanges, syncFailures, isLoading, notifications, onRename, actionButtons, darkMode, vimMode, progressPerc, completer, lhs, onClick, rhs, pageNamePrefix, cssClass, }: { pageName?: string; unsavedChanges: boolean; syncFailures: number; isLoading: boolean; notifications: Notification[]; darkMode: boolean; vimMode: boolean; progressPerc?: number; onRename: (newName?: string) => Promise; onClick: () => void; completer: (context: CompletionContext) => Promise; actionButtons: ActionButton[]; lhs?: ComponentChildren; rhs?: ComponentChildren; pageNamePrefix?: string; cssClass?: string; }) { return (
1 ? "sb-sync-error" : undefined} onClick={onClick} > {lhs}
{pageNamePrefix}
{ if (newName !== pageName) { return onRename(newName); } else { return onRename(); } }} completer={completer} onEnter={(newName) => { onRename(newName); }} /> {notifications.length > 0 && (
{notifications.map((notification) => (
{notification.message}
))}
)}
{progressPerc !== undefined && (
{progressPerc}
)} {actionButtons.map((actionButton) => { const button = ( ); return actionButton.href !== undefined ? {button} : button; })}
{rhs}
); }