diff options
author | crupest <crupest@outlook.com> | 2021-06-03 23:20:22 +0800 |
---|---|---|
committer | crupest <crupest@outlook.com> | 2021-06-03 23:20:22 +0800 |
commit | 5a96a88121f3ecb846c5cd55c3f51624b4e21402 (patch) | |
tree | 68ebf231a0887440c4390cba494fe43f34050b2d /FrontEnd/src/app/views/timeline-common/TimelinePostView.tsx | |
parent | b8a43d19cc3e850d42959ca019a3de6a453de11d (diff) | |
download | timeline-5a96a88121f3ecb846c5cd55c3f51624b4e21402.tar.gz timeline-5a96a88121f3ecb846c5cd55c3f51624b4e21402.tar.bz2 timeline-5a96a88121f3ecb846c5cd55c3f51624b4e21402.zip |
feat: Add change post property dialog.
Diffstat (limited to 'FrontEnd/src/app/views/timeline-common/TimelinePostView.tsx')
-rw-r--r-- | FrontEnd/src/app/views/timeline-common/TimelinePostView.tsx | 46 |
1 files changed, 36 insertions, 10 deletions
diff --git a/FrontEnd/src/app/views/timeline-common/TimelinePostView.tsx b/FrontEnd/src/app/views/timeline-common/TimelinePostView.tsx index 2f778ab1..a008d8e5 100644 --- a/FrontEnd/src/app/views/timeline-common/TimelinePostView.tsx +++ b/FrontEnd/src/app/views/timeline-common/TimelinePostView.tsx @@ -1,6 +1,7 @@ import React from "react"; import classnames from "classnames"; import { Link } from "react-router-dom"; +import { useTranslation } from "react-i18next"; import { getHttpTimelineClient, HttpTimelinePostInfo } from "@/http/timeline"; @@ -10,6 +11,7 @@ import UserAvatar from "../common/user/UserAvatar"; import TimelineLine from "./TimelineLine"; import TimelinePostContentView from "./TimelinePostContentView"; import TimelinePostDeleteConfirmDialog from "./TimelinePostDeleteConfirmDialog"; +import PostPropertyChangeDialog from "./PostPropertyChangeDialog"; export interface TimelinePostViewProps { post: HttpTimelinePostInfo; @@ -17,16 +19,20 @@ export interface TimelinePostViewProps { className?: string; style?: React.CSSProperties; cardStyle?: React.CSSProperties; - onDeleted?: () => void; + onChanged: (post: HttpTimelinePostInfo) => void; + onDeleted: () => void; } const TimelinePostView: React.FC<TimelinePostViewProps> = (props) => { - const { post, className, style, cardStyle, onDeleted } = props; + const { post, className, style, cardStyle, onChanged, onDeleted } = props; const current = props.current === true; + const { t } = useTranslation(); + const [operationMaskVisible, setOperationMaskVisible] = React.useState<boolean>(false); - const [deleteDialog, setDeleteDialog] = React.useState<boolean>(false); + const [dialog, setDialog] = + React.useState<"delete" | "changeproperty" | null>(null); const cardRef = React.useRef<HTMLDivElement>(null); React.useEffect(() => { @@ -84,25 +90,36 @@ const TimelinePostView: React.FC<TimelinePostViewProps> = (props) => { </div> {operationMaskVisible ? ( <div - className="position-absolute position-lt w-100 h-100 mask d-flex justify-content-center align-items-center" + className="position-absolute position-lt w-100 h-100 mask d-flex justify-content-around align-items-center" onClick={() => { setOperationMaskVisible(false); }} > - <i - className="bi-trash text-danger icon-button large" + <span + className="tl-color-primary" + onClick={(e) => { + setDialog("changeproperty"); + e.stopPropagation(); + }} + > + {t("changeProperty")} + </span> + <span + className="tl-color-danger" onClick={(e) => { - setDeleteDialog(true); + setDialog("delete"); e.stopPropagation(); }} - /> + > + {t("delete")} + </span> </div> ) : null} </div> - {deleteDialog ? ( + {dialog === "delete" ? ( <TimelinePostDeleteConfirmDialog onClose={() => { - setDeleteDialog(false); + setDialog(null); setOperationMaskVisible(false); }} onConfirm={() => { @@ -116,6 +133,15 @@ const TimelinePostView: React.FC<TimelinePostViewProps> = (props) => { }); }} /> + ) : dialog === "changeproperty" ? ( + <PostPropertyChangeDialog + onClose={() => { + setDialog(null); + setOperationMaskVisible(false); + }} + post={post} + onSuccess={onChanged} + /> ) : null} </div> ); |