From f5ad360d02303ce27a65e67feb8ae38f1e26742c Mon Sep 17 00:00:00 2001 From: Arda Serdar Pektezol <1669855+pektezol@users.noreply.github.com> Date: Thu, 31 Oct 2024 23:58:14 +0300 Subject: frontend: convert all native confirm and alerts to custom hooks --- frontend/src/components/Discussions.tsx | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) (limited to 'frontend/src/components/Discussions.tsx') diff --git a/frontend/src/components/Discussions.tsx b/frontend/src/components/Discussions.tsx index c22de79..0522910 100644 --- a/frontend/src/components/Discussions.tsx +++ b/frontend/src/components/Discussions.tsx @@ -6,6 +6,7 @@ import { time_ago } from '../utils/Time'; import { API } from '../api/Api'; import "../css/Maps.css" import { Link } from 'react-router-dom'; +import useConfirm from '../hooks/UseConfirm'; interface DiscussionsProps { token?: string @@ -17,6 +18,8 @@ interface DiscussionsProps { const Discussions: React.FC = ({ token, data, isModerator, mapID, onRefresh }) => { + const { confirm, ConfirmDialogComponent } = useConfirm(); + const [discussionThread, setDiscussionThread] = React.useState(undefined); const [discussionSearch, setDiscussionSearch] = React.useState(""); @@ -48,7 +51,7 @@ const Discussions: React.FC = ({ token, data, isModerator, map }; const _delete_map_discussion = async (discussion: MapDiscussionsDetail) => { - if (window.confirm(`Are you sure you want to remove post: ${discussion.title}?`)) { + if (await confirm("Delete Map Discussion", `Are you sure you want to remove post: ${discussion.title}?`)) { if (token) { await API.delete_map_discussion(token, mapID, discussion.id); onRefresh(); @@ -58,6 +61,7 @@ const Discussions: React.FC = ({ token, data, isModerator, map return (
+ {ConfirmDialogComponent}
- e.key === "Enter" && _create_map_discussion_comment(discussionThread.discussion.id)} - onChange={(e) => setCreateDiscussionCommentContent(e.target.value)} /> + e.key === "Enter" && _create_map_discussion_comment(discussionThread.discussion.id)} + onChange={(e) => setCreateDiscussionCommentContent(e.target.value)} />