Skip to content

Commit

Permalink
Merge pull request #126 from LikeLionHGU/jongyhun_feat/#123
Browse files Browse the repository at this point in the history
feat: 이미지 업로드API
  • Loading branch information
dkrehd0519 authored Aug 6, 2024
2 parents 96089d0 + 4e14597 commit 1b99210
Show file tree
Hide file tree
Showing 6 changed files with 154 additions and 138 deletions.
21 changes: 21 additions & 0 deletions src/apis/createImg.jsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
import axios from "axios";

const createImg = async (csrfToken, formData) => {
try {
const serverResponse = await axios.post(`${process.env.REACT_APP_HOST_URL}/v1/images`, formData, {
withCredentials: true,
headers: {
"X-CSRF-TOKEN": csrfToken,
"Content-Type": "multipart/form-data",
},
});
console.log("이미지가 정상적으로 추가되었음", serverResponse);

return serverResponse.data.imageUrl;
} catch (error) {
console.error("이미지 추가 실패:", error);
throw error;
}
};

export default createImg;
22 changes: 22 additions & 0 deletions src/apis/deleteDiary.jsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
import axios from "axios";

const deleteDiary = async (csrfToken, journalId) => {
console.log("API 코드에서 잘 넘어왔는지", csrfToken, journalId);
try {
const serverResponse = await axios.delete(`${process.env.REACT_APP_HOST_URL}/v1/journals/${journalId}`, {
withCredentials: true,
headers: {
"Content-Type": "application/json",
"X-CSRF-TOKEN": csrfToken,
},
});
console.log("일지가 정상적으로 삭제되었음", serverResponse);

return serverResponse.data;
} catch (error) {
console.error("일지 삭제 실패:", error);
throw error;
}
};

export default deleteDiary;
18 changes: 13 additions & 5 deletions src/diaryDetailPage/components/DeleteConfirmModal.jsx
Original file line number Diff line number Diff line change
@@ -1,16 +1,24 @@
import React from "react";
import { useNavigate } from "react-router-dom";
import styled from "styled-components";
import deleteDiary from "../../apis/deleteDiary";
import { useRecoilValue } from "recoil";
import { tokenState } from "../../atom/atom";

function DeleteConfirmModal({ setDeleteModal, goalId }) {
function DeleteConfirmModal({ setDeleteModal, goalId, journalId }) {
const navigate = useNavigate();
const csrfToken = useRecoilValue(tokenState);
const closeDeleteModal = () => {
setDeleteModal(false);
};
const deleteModal = () => {
//일지 삭제하는 부분 필요.
setDeleteModal(false);
navigate(`/diarylist`, { state: { goalId } });
const deleteModal = async () => {
try {
await deleteDiary(csrfToken, journalId);
setDeleteModal(false);
navigate(`/diarylist`, { state: { goalId } });
} catch (error) {
console.error("목표 삭제 실패", error);
}
};
return (
<div>
Expand Down
10 changes: 3 additions & 7 deletions src/diaryDetailPage/components/DiaryDetail.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@ function DiaryDetail() {
}
};
fetchGoalList();
}, [goalId, csrfToken]);
}, [diaryId, csrfToken]);

return (
<Wrapper>
Expand All @@ -55,16 +55,12 @@ function DiaryDetail() {
<ContentArea>
<Contents>
{/* html 태그 적용된 일지 내용 보여주는 부분 */}
<div
dangerouslySetInnerHTML={{ __html: diaryDetail.content }}
></div>
<div dangerouslySetInnerHTML={{ __html: diaryDetail.content }}></div>
</Contents>
</ContentArea>
</CenterBox>

{deleteModal && (
<DeleteConfirmModal setDeleteModal={setDeleteModal} goalId={goalId} />
)}
{deleteModal && <DeleteConfirmModal setDeleteModal={setDeleteModal} goalId={goalId} journalId={diaryId} />}
</BoxWrapper>
</Wrapper>
);
Expand Down
22 changes: 16 additions & 6 deletions src/homepage/component/goals/CreateGoalModal/CreateGoalModal.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,8 @@ import ImgUpload from "../../../../asset/Icon/ImgUpload.svg";
import { Toggle } from "./Toggle";
import { CSSTransition, TransitionGroup } from "react-transition-group";
import updateGoal from "../../../../apis/updateGoal";
import { fi } from "date-fns/locale";
import createImg from "../../../../apis/\bcreateImg";

const formatDate = (date) => {
const year = date.getFullYear();
Expand All @@ -32,6 +34,7 @@ function CreateGoalModal({
setIsUpdate,
setIsGoalEditedModalOpen,
expiredData,
setExpiredData,
}) {
const [isDateSetting, setIsDateSetting] = useState(true);
const csrfToken = useRecoilValue(tokenState);
Expand Down Expand Up @@ -61,19 +64,22 @@ function CreateGoalModal({
isUpdate && updateData?.thumbnail ? updateData.thumbnail : expiredData?.thumbnail ? expiredData.thumbnail : "",
});

const [imageUrl, setImageUrl] = useState("");

const goalId = isUpdate && updateData.goalId ? updateData.goalId : expiredData?.goalId;
const status = isUpdate && updateData.status ? updateData.status : expiredData?.status;
const [previewUrl, setPreviewUrl] = useState(
isUpdate && updateData?.thumbnail ? updateData.thumbnail : expiredData?.thumbnail ? expiredData.thumbnail : null
);

useEffect(() => {
console.log("formData updated:", formData, csrfToken, updateData, isUpdate);
console.log("formData updated:", formData, csrfToken, updateData, isUpdate, imageUrl);
}, [formData]);

const closeCreateGoalModal = () => {
setIsModalOpen(false);
setIsUpdate(false);
setExpiredData(undefined);
};

const handleImageUploadClick = () => {
Expand All @@ -93,8 +99,11 @@ function CreateGoalModal({
}
};

const handleFileInputChange = (event) => {
const handleFileInputChange = async (event) => {
const file = event.target.files[0];
const formData = new FormData();
formData.append("file", file);
setImageUrl(await createImg(csrfToken, formData));

if (file) {
const reader = new FileReader();
Expand Down Expand Up @@ -140,8 +149,8 @@ function CreateGoalModal({
formDataToSend.append("startDate", startDate);
formDataToSend.append("endDate", endDate);

if (fileInputRef.current.files[0]) {
formDataToSend.append("thumbnail", fileInputRef.current.files[0]);
if (imageUrl) {
formDataToSend.append("thumbnail", imageUrl);
}
await createGoal(formDataToSend, csrfToken);
closeCreateGoalModal();
Expand Down Expand Up @@ -175,15 +184,16 @@ function CreateGoalModal({
);
formDataToSend.append("status", status);

if (fileInputRef.current.files[0]) {
formDataToSend.append("thumbnail", fileInputRef.current.files[0]);
if (imageUrl) {
formDataToSend.append("thumbnail", imageUrl);
}
await updateGoal(formDataToSend, csrfToken, goalId);
closeCreateGoalModal();
setIsGoalEditedModalOpen(true);
} catch (error) {
console.error("목표 수정 실패", error);
}
setExpiredData(undefined);
};

const handleToggleDateSetting = () => {
Expand Down
Loading

0 comments on commit 1b99210

Please sign in to comment.