diff options
| author | crupest <crupest@outlook.com> | 2020-10-31 00:42:06 +0800 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2020-10-31 00:42:06 +0800 | 
| commit | a3c97f6fb6313da2e8c0fac0b4c08f2ef4265d0f (patch) | |
| tree | ee006874b0c93e9bfc76f141a092a8b9585a1f95 /FrontEnd/src/app/views/user/index.tsx | |
| parent | 0c4caaebe2480e77918d5d7df234f0edaeab74ba (diff) | |
| parent | 7ce0846d9ec968da3ea4f7ebcc6db26db8e49089 (diff) | |
| download | timeline-a3c97f6fb6313da2e8c0fac0b4c08f2ef4265d0f.tar.gz timeline-a3c97f6fb6313da2e8c0fac0b4c08f2ef4265d0f.tar.bz2 timeline-a3c97f6fb6313da2e8c0fac0b4c08f2ef4265d0f.zip | |
Merge pull request #161 from crupest/upgrade
Upgrade packages and split front end and back end.
Diffstat (limited to 'FrontEnd/src/app/views/user/index.tsx')
| -rw-r--r-- | FrontEnd/src/app/views/user/index.tsx | 72 | 
1 files changed, 72 insertions, 0 deletions
| diff --git a/FrontEnd/src/app/views/user/index.tsx b/FrontEnd/src/app/views/user/index.tsx new file mode 100644 index 00000000..7c0b1563 --- /dev/null +++ b/FrontEnd/src/app/views/user/index.tsx @@ -0,0 +1,72 @@ +import React, { useState } from "react"; +import { useParams } from "react-router"; + +import { UiLogicError } from "@/common"; +import { useUser, userInfoService } from "@/services/user"; + +import TimelinePageTemplate from "../timeline-common/TimelinePageTemplate"; + +import UserPageUI from "./UserPageUI"; +import { PersonalTimelineManageItem } from "./UserInfoCard"; +import ChangeNicknameDialog from "./ChangeNicknameDialog"; +import ChangeAvatarDialog from "./ChangeAvatarDialog"; + +const UserPage: React.FC = (_) => { +  const { username } = useParams<{ username: string }>(); + +  const user = useUser(); + +  const [dialog, setDialog] = useState<null | PersonalTimelineManageItem>(null); + +  let dialogElement: React.ReactElement | undefined; + +  const closeDialogHandler = (): void => { +    setDialog(null); +  }; + +  if (dialog === "nickname") { +    if (user == null) { +      throw new UiLogicError("Change nickname without login."); +    } + +    dialogElement = ( +      <ChangeNicknameDialog +        open +        close={closeDialogHandler} +        onProcess={(newNickname) => +          userInfoService.setNickname(username, newNickname) +        } +      /> +    ); +  } else if (dialog === "avatar") { +    if (user == null) { +      throw new UiLogicError("Change avatar without login."); +    } + +    dialogElement = ( +      <ChangeAvatarDialog +        open +        close={closeDialogHandler} +        process={(file) => userInfoService.setAvatar(username, file)} +      /> +    ); +  } + +  const onManage = React.useCallback((item: PersonalTimelineManageItem) => { +    setDialog(item); +  }, []); + +  return ( +    <> +      <TimelinePageTemplate +        name={`@${username}`} +        UiComponent={UserPageUI} +        onManage={onManage} +        notFoundI18nKey="timeline.userNotExist" +      /> +      {dialogElement} +    </> +  ); +}; + +export default UserPage; | 
