| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899 |
- /** @jsx h */
- import { h } from "preact";
- import { useEffect, useState } from "preact/hooks";
- interface TopBarProps {
- allowMode: "edit" | "read" | "both";
- }
- export default function TopBar(props: TopBarProps) {
- const [mode, setMode] = useState(props.allowMode);
- const [isLogin, setIsLogin] = useState(false);
- // Event listener
- const modeChangeListener = (e: CustomEvent) => {
- if (
- e.detail &&
- (props.allowMode === e.detail || props.allowMode === "both")
- ) {
- setMode(e.detail);
- }
- };
- // Event dispatche
- const modeChangeDispatcher = (mode: string) => {
- dispatchEvent(new CustomEvent("ModeChange", { detail: mode }));
- };
- const checkUserLogin = async () => {
- const resp = await fetch("/api/user/login");
- const respJson = await resp.json();
- if (respJson.success) {
- setIsLogin(true);
- return true;
- }
- // Redirect to login page if not valid
- location.href = "/login";
- return false;
- };
- // Init event listeners
- useEffect(() => {
- checkUserLogin();
- addEventListener("ModeChange", modeChangeListener);
- return () => {
- removeEventListener("ModeChange", modeChangeListener);
- };
- }, []);
- return (
- <div className="pd-top-bar">
- <div className="pd-top-bar-mode-switcher">
- <button
- className={`pd-top-bar-btn${mode === "edit" ? " active" : ""}${
- props.allowMode === "read" ? " disabled" : ""
- }`}
- id="edit"
- type="button"
- onClick={() => {
- modeChangeDispatcher("edit");
- }}
- >
- Edit
- </button>
- <button
- className={`pd-top-bar-btn${mode === "read" ? " active" : ""}${
- props.allowMode === "edit" ? " disabled" : ""
- }`}
- id="read"
- type="button"
- onClick={() => {
- modeChangeDispatcher("read");
- }}
- >
- Read
- </button>
- <button
- className={`pd-top-bar-btn${mode === "both" ? " active" : ""}${
- props.allowMode !== "both" ? " disabled" : ""
- }`}
- id="both"
- type="button"
- onClick={() => {
- modeChangeDispatcher("both");
- }}
- >
- Both
- </button>
- </div>
- {isLogin ? (
- <div className="pd-top-bar-tool-icons">
- <i className="bi bi-house-door" />
- <i className="bi bi-share" />
- <i className="bi bi-gear" />
- </div>
- ) : null}
- </div>
- );
- }
|