mirror of https://github.com/usememos/memos
You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
63 lines
2.3 KiB
TypeScript
63 lines
2.3 KiB
TypeScript
4 years ago
|
import { useCallback, useContext, useState } from "react";
|
||
|
import appContext from "../stores/appContext";
|
||
|
import { locationService } from "../services";
|
||
|
import utils from "../helpers/utils";
|
||
|
import MenuBtnsPopup from "./MenuBtnsPopup";
|
||
|
import showDailyMemoDiaryDialog from "./DailyMemoDiaryDialog";
|
||
|
import "../less/user-banner.less";
|
||
|
|
||
|
interface Props {}
|
||
|
|
||
|
const UserBanner: React.FC<Props> = () => {
|
||
|
const {
|
||
|
memoState: { memos, tags },
|
||
|
userState: { user },
|
||
|
} = useContext(appContext);
|
||
|
const username = user ? user.username : "Memos";
|
||
|
const createdDays = user ? Math.ceil((Date.now() - utils.getTimeStampByDate(user.createdAt)) / 1000 / 3600 / 24) : 0;
|
||
|
|
||
|
const [shouldShowPopupBtns, setShouldShowPopupBtns] = useState(false);
|
||
|
|
||
|
const handleUsernameClick = useCallback(() => {
|
||
|
locationService.pushHistory("/");
|
||
|
locationService.clearQuery();
|
||
|
}, []);
|
||
|
|
||
|
const handlePopupBtnClick = () => {
|
||
|
const sidebarEl = document.querySelector(".sidebar-wrapper") as HTMLElement;
|
||
|
const popupEl = document.querySelector(".menu-btns-popup") as HTMLElement;
|
||
|
popupEl.style.top = 54 - sidebarEl.scrollTop + "px";
|
||
|
setShouldShowPopupBtns(true);
|
||
|
};
|
||
|
|
||
|
return (
|
||
|
<div className="user-banner-container">
|
||
|
<div className="userinfo-header-container">
|
||
|
<p className="username-text" onClick={handleUsernameClick}>
|
||
|
{username}
|
||
|
</p>
|
||
|
<span className="action-btn menu-popup-btn" onClick={handlePopupBtnClick}>
|
||
|
<img src="/icons/more.svg" className="icon-img" />
|
||
|
</span>
|
||
|
<MenuBtnsPopup shownStatus={shouldShowPopupBtns} setShownStatus={setShouldShowPopupBtns} />
|
||
|
</div>
|
||
|
<div className="status-text-container">
|
||
|
<div className="status-text memos-text">
|
||
|
<span className="amount-text">{memos.length}</span>
|
||
|
<span className="type-text">MEMO</span>
|
||
|
</div>
|
||
|
<div className="status-text tags-text">
|
||
|
<span className="amount-text">{tags.length}</span>
|
||
|
<span className="type-text">TAG</span>
|
||
|
</div>
|
||
|
<div className="status-text duration-text" onClick={() => showDailyMemoDiaryDialog()}>
|
||
|
<span className="amount-text">{createdDays}</span>
|
||
|
<span className="type-text">DAY</span>
|
||
|
</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
);
|
||
|
};
|
||
|
|
||
|
export default UserBanner;
|