import { Notification } from "../types";

function prettyName(s: string | undefined): string {
  if (!s) {
    return "";
  }
  return s.replaceAll("/", " / ");
}

export function TopBar({
  pageName,
  unsavedChanges,
  notifications,
  onClick,
  lhs,
  rhs,
}: {
  pageName?: string;
  unsavedChanges: boolean;
  notifications: Notification[];
  onClick: () => void;
  lhs?: React.ReactNode;
  rhs?: React.ReactNode;
}) {
  return (
    <div id="top" onClick={onClick}>
      {lhs}
      <div className="main">
        <div className="inner">
          {/*<span className={`icon ${unsavedChanges ? "unsaved" : "saved"}`}>*/}
          {/*  <FontAwesomeIcon icon={faFileLines} />*/}
          {/*</span>*/}

          <span
            className={`current-page ${unsavedChanges ? "unsaved" : "saved"}`}
          >
            {prettyName(pageName)}
          </span>
          {/*<button*/}
          {/*  onClick={(e) => {*/}
          {/*    // @ts-ignore*/}
          {/*    window.syncer();*/}
          {/*    e.stopPropagation();*/}
          {/*  }}*/}
          {/*>*/}
          {/*  Sync*/}
          {/*</button>*/}
          {notifications.length > 0 && (
            <div className="status">
              {notifications.map((notification) => (
                <div key={notification.id}>{notification.message}</div>
              ))}
            </div>
          )}
        </div>
      </div>
      {rhs}
    </div>
  );
}