|
|
|
@ -1,20 +1,16 @@
|
|
|
|
|
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.name : "Memos";
|
|
|
|
|
const createdDays = user ? Math.ceil((Date.now() - utils.getTimeStampByDate(user.createdAt)) / 1000 / 3600 / 24) : 0;
|
|
|
|
|
|
|
|
|
|
const [shouldShowPopupBtns, setShouldShowPopupBtns] = useState(false);
|
|
|
|
|
|
|
|
|
@ -32,29 +28,13 @@ const UserBanner: React.FC<Props> = () => {
|
|
|
|
|
|
|
|
|
|
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>
|
|
|
|
|
<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>
|
|
|
|
|
);
|
|
|
|
|
};
|
|
|
|
|