Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Refactor] 과제 api 연결 및 바뀐 dto 반영 #114

Merged
merged 26 commits into from
Sep 4, 2024
Merged
Show file tree
Hide file tree
Changes from 15 commits
Commits
Show all changes
26 commits
Select commit Hold shift + click to select a range
473c397
feat: 큐에이 반영
SeieunYoo Sep 1, 2024
4d96c98
fix: 소문자로 변경
SeieunYoo Sep 2, 2024
0a470e4
refactor: api dto 반영, 이번 주 과제 조회 api 연결
SeieunYoo Sep 2, 2024
15efae9
feat: 히스토리 api 수정된 dto 반영
SeieunYoo Sep 2, 2024
98ca46f
feat: 히스토리 api 수정된 거 반영, 레포지토리 입력 api 반영
SeieunYoo Sep 2, 2024
14e3318
refactor: 레포 모달 창 상태 관리 컴포넌트로 벼녕
SeieunYoo Sep 2, 2024
4a2bdaa
feat: 필요없는 로직 삭제
SeieunYoo Sep 2, 2024
e4e81a7
feat: 이번 주 과제 조회 스터디 추가
SeieunYoo Sep 2, 2024
02ccc06
feat: merge dev
SeieunYoo Sep 2, 2024
c40f35d
feat: 모달 라우팅 삭제
SeieunYoo Sep 2, 2024
3f55541
feat: submissionLink 에서 폴더
SeieunYoo Sep 2, 2024
c535042
chore: 안쓰는 상수 삭제
SeieunYoo Sep 2, 2024
3ba2820
chore: 말줄임 처리, github url 인지 체크
SeieunYoo Sep 3, 2024
30b1482
feat: 스터디 시작 날짜가 현재 날짜인지 확인하고 disabled 처리
SeieunYoo Sep 3, 2024
5300dab
feat: 공통 타입은 common 으로 옮기기, 리뷰 반영
SeieunYoo Sep 3, 2024
2353d51
fix: 빠진 네이밍 수정 반영
SeieunYoo Sep 3, 2024
44b6eae
feat: Button asProp 으로 Link 전달, css 수정
SeieunYoo Sep 4, 2024
87913e4
refactor: NonNullable 처리, Initial 로 관리
SeieunYoo Sep 4, 2024
9e1ec27
feat: github 관련 유틸 분리,css 수정
SeieunYoo Sep 4, 2024
083fd28
chore: 필요없는 프래그먼트 삭제
SeieunYoo Sep 4, 2024
9193df3
chore: cache 속서 추가
SeieunYoo Sep 4, 2024
9807666
feat: currentPath href 매치될 때만 active 되게 navItem 수정
SeieunYoo Sep 4, 2024
70a1a10
chore: myStudy 용 타입 추가
SeieunYoo Sep 4, 2024
2f2237c
chore: EDITING_WITH_WARNING 타입 삭제, 상태 네이밍 변경
SeieunYoo Sep 4, 2024
172f10c
chore: 조건식 간소화
SeieunYoo Sep 4, 2024
329f205
chore: submissionLink null 로 내려오는 부분 우선 삭제
SeieunYoo Sep 4, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
15 changes: 14 additions & 1 deletion apps/client/apis/studyDetailApi.ts
Original file line number Diff line number Diff line change
@@ -1,7 +1,10 @@
import { fetcher } from "@wow-class/utils";
import { apiPath } from "constants/apiPath";
import { tags } from "constants/tags";
import type { StudyDetailDashboardDto } from "types/dtos/studyDetail";
import type {
StudyDetailDashboardDto,
UpcomingStudyDto,
} from "types/dtos/studyDetail";

export const studyDetailApi = {
getStudyDetailDashboard: async (studyId: number) => {
Expand All @@ -12,6 +15,16 @@ export const studyDetailApi = {
}
);

return response.data;
},
getUpcomingStudy: async (studyId: number) => {
const response = await fetcher.get<UpcomingStudyDto>(
`${apiPath.studyDetail}/upcoming?studyId=${studyId}`,
{
next: { tags: [tags.upcomingStudy] },
}
);

return response.data;
},
ghdtjgus76 marked this conversation as resolved.
Show resolved Hide resolved
};
ghdtjgus76 marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ import { padWithZero, parseISODate } from "@wow-class/utils";
import { routePath } from "constants/routePath";
import Link from "next/link";
import type { ComponentProps } from "react";
import type { AssignmentSubmissionStatusType } from "types/entities/myStudy";
import type { AssignmentSubmissionStatusType } from "types/entities/common/assignment";
import Box from "wowds-ui/Box";
import Button from "wowds-ui/Button";
import Tag from "wowds-ui/Tag";
Expand Down

This file was deleted.

This file was deleted.

This file was deleted.

Original file line number Diff line number Diff line change
@@ -1,29 +1,66 @@
"use client";

import { Space } from "@wow-class/ui";
import { myStudyApi } from "apis/myStudyApi";
import { studyHistoryApi } from "apis/studyHistoryApi";
import { tags } from "constants/tags";
import Link from "next/link";
import { useEffect, useState } from "react";
import type { Assignment } from "types/dtos/studyDetail";
import type { AssignmentSubmissionStatusType } from "types/entities/common/assignment";
import { isDeadlinePassed } from "utils";
import { getIsAfterStartDate } from "utils/getIsAfterStartDate";
import { isDeadlinePassed } from "utils/isDeadlinePassed";
import { revalidateTagByName } from "utils/revalidateTagByName";
import { Link as LinkIcon, Reload as ReloadIcon } from "wowds-icons";
import Button from "wowds-ui/Button";

interface AssignmentBoxButtonsProps {
assignment: Assignment;
buttonsDisabled?: boolean;
}

export const AssignmentBoxButtons = ({
...rest
buttonsDisabled: _buttonDisabled,
assignment,
SeieunYoo marked this conversation as resolved.
Show resolved Hide resolved
}: AssignmentBoxButtonsProps) => {
const [period, setPeriod] = useState("");

const targetWeek = assignment.week;

useEffect(() => {
const fetchAssignmentStartDate = async () => {
const ongoingStudyInfo = await myStudyApi.getMyOngoingStudyInfo();

if (ongoingStudyInfo?.studyId) {
const curriculumData = await myStudyApi.getStudyCurriculumList(
ongoingStudyInfo.studyId
);

const matchingWeek = curriculumData?.find(
(item) => item.week === targetWeek
);

if (matchingWeek) {
setPeriod(matchingWeek.period.startDate);
}
}
};

fetchAssignmentStartDate();
}, [targetWeek]);

const buttonsDisabled = _buttonDisabled || !getIsAfterStartDate(period);

return (
<>
<PrimaryButton {...rest} />
<PrimaryButton
assignment={assignment}
buttonsDisabled={buttonsDisabled}
/>
<Space height={8} />
<SecondaryButton {...rest} />
<SecondaryButton
assignment={assignment}
buttonsDisabled={buttonsDisabled}
/>
</>
);
};
Expand All @@ -33,7 +70,10 @@ const PrimaryButton = ({
}: AssignmentBoxButtonsProps) => {
const { assignmentSubmissionStatus, submissionFailureType, submissionLink } =
assignment;
const { primaryButtonText } = buttonProps[assignmentSubmissionStatus];
const { primaryButtonText } =
assignmentSubmissionStatus === null
? buttonProps.null
: buttonProps[assignmentSubmissionStatus];

if (
assignmentSubmissionStatus === "FAILURE" &&
Expand All @@ -43,7 +83,7 @@ const PrimaryButton = ({
}
const stroke = buttonsDisabled ? "mono100" : "primary";
return (
<Link href={submissionLink} target="_blank">
<Link href={submissionLink ?? ""} target="_blank">
SeieunYoo marked this conversation as resolved.
Show resolved Hide resolved
<Button
disabled={buttonsDisabled}
icon={<LinkIcon height={20} stroke={stroke} width={20} />}
Expand All @@ -62,7 +102,10 @@ const SecondaryButton = ({
}: AssignmentBoxButtonsProps) => {
const { assignmentSubmissionStatus, studyDetailId, deadline, committedAt } =
assignment;
const { secondaryButtonText } = buttonProps[assignmentSubmissionStatus];
const { secondaryButtonText } =
assignmentSubmissionStatus === null
? buttonProps.null
: buttonProps[assignmentSubmissionStatus];
const handleClickSubmissionComplete = async () => {
const response = await studyHistoryApi.submitAssignment(studyDetailId);
if (response.success) {
Expand Down Expand Up @@ -101,10 +144,12 @@ const buttonStyle = {
};

const buttonProps: Record<
AssignmentSubmissionStatusType,
Exclude<AssignmentSubmissionStatusType, null>,
{ primaryButtonText: string; secondaryButtonText: string }
SeieunYoo marked this conversation as resolved.
Show resolved Hide resolved
> = {
PENDING: {
> & {
null: { primaryButtonText: string; secondaryButtonText: string };
} = {
null: {
primaryButtonText: "제출하러 가기",
secondaryButtonText: "제출 완료하기",
},
SeieunYoo marked this conversation as resolved.
Show resolved Hide resolved
SeieunYoo marked this conversation as resolved.
Show resolved Hide resolved
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,8 +10,12 @@ interface AssignmentBoxInfoProps {
}

export const AssignmentBoxInfo = ({ assignment }: AssignmentBoxInfoProps) => {
const { deadline, title, assignmentSubmissionStatus, submissionFailureType } =
assignment;
const {
deadline,
assignmentSubmissionStatus,
submissionFailureType,
submissionLink,
} = assignment;

const { year, month, day, hours, minutes } = parseISODate(deadline);

Expand All @@ -31,7 +35,7 @@ export const AssignmentBoxInfo = ({ assignment }: AssignmentBoxInfoProps) => {
<Text as="div" color="sub">
제출한 과제
<Text as="span" color="textBlack">
{title}
{getTitleOfAssignment(submissionLink)}
</Text>
</Text>
<Image alt="dot" height={6} src="/images/dot.svg" width={6} />
Expand All @@ -51,3 +55,14 @@ const failMapping: Record<Assignment["submissionFailureType"], string> = {
NOT_SUBMITTED: "제출 안함",
NONE: "없음",
};

const getTitleOfAssignment = (submissionLink: string) => {
const regex = /github\.com\/[^/]+\/([^/]+)\/([^/]+)/;
const match = submissionLink.match(regex);

if (match) {
const repoName = match[1];
const folderName = match[2];
return `${repoName}/${folderName}`;
}
};
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,9 @@ interface AssignmentBoxTitleProps {
export const AssignmentBoxTitle = ({ assignment }: AssignmentBoxTitleProps) => {
const { week, title, assignmentSubmissionStatus } = assignment;
const { color, message } =
assignmentSubmissionMap[assignmentSubmissionStatus];
assignmentSubmissionStatus !== null
? assignmentSubmissionMap[assignmentSubmissionStatus]
: assignmentSubmissionMap.null;

return (
<>
Expand All @@ -21,10 +23,10 @@ export const AssignmentBoxTitle = ({ assignment }: AssignmentBoxTitleProps) => {
</Text>
<Space height={16} />
<Flex gap="xs">
<Text as="h2" typo="h2">
<Text as="h2" style={textStyle} typo="h2">
{title}
</Text>
{assignmentSubmissionStatus !== "PENDING" && (
{assignmentSubmissionStatus !== null && (
<Tag color={color ?? "blue"} variant="solid2">
{message}
</Tag>
Expand All @@ -34,10 +36,17 @@ export const AssignmentBoxTitle = ({ assignment }: AssignmentBoxTitleProps) => {
);
};

const textStyle = {
textOverflow: "ellipsis",
whiteSpace: "nowrap",
overflow: "hidden",
};
const assignmentSubmissionMap: Record<
AssignmentSubmissionStatusType,
Exclude<AssignmentSubmissionStatusType, null>, // null을 제외한 타입만 처리
{ message: string; color: ComponentProps<typeof Tag>["color"] }
> = {
> & {
null: { message: string; color: ComponentProps<typeof Tag>["color"] }; // null에 대한 별도 처리
} = {
FAILURE: {
message: "제출 실패",
color: "red",
Expand All @@ -46,7 +55,7 @@ const assignmentSubmissionMap: Record<
message: "제출 완료",
color: "blue",
},
PENDING: {
null: {
message: "",
color: "grey",
},
Expand Down
Original file line number Diff line number Diff line change
@@ -1,20 +1,14 @@
import { Space, Text } from "@wow-class/ui";
import { Text } from "@wow-class/ui";
import Box from "wowds-ui/Box";

export const EmptyAssignmentBox = ({ week }: { week: number }) => {
export const EmptyAssignmentBox = () => {
return (
<Box
style={boxStyle}
text={
<>
<Text color="primary" typo="label2">
{week}주차
</Text>
<Space height={16} />
<Text as="h2" typo="h2">
과제가 없어요
</Text>
</>
<Text as="h2" typo="h2">
과제가 없어요
</Text>
}
/>
);
Expand Down
Loading
Loading