Skip to content

Commit

Permalink
hotdrinkvote 서버에서 fetch 하도록 변경 (#188)
Browse files Browse the repository at this point in the history
* feat: module css 적용

* feat: module css에 global css, getClassNames 함수 구현

* feat: hotdrinkvote 서버에서 fetch 하도록 변경

* feat: hotdrinklist 컴포넌트 서버 컴포넌트로 변환
  • Loading branch information
ksmfou98 authored Oct 17, 2023
1 parent b297e7c commit 5812fcb
Show file tree
Hide file tree
Showing 21 changed files with 159 additions and 56 deletions.
8 changes: 8 additions & 0 deletions .pnp.cjs

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions apps/jurumarble/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@
"@monorepo/ui": "workspace:*",
"@next/bundle-analyzer": "13.3.5-canary.9",
"@react-hookz/web": "^23.1.0",
"@tanstack/query-core": "^4.36.1",
"@tanstack/react-query": "^4.33.0",
"@tanstack/react-query-devtools": "^4.33.0",
"axios": "^1.5.0",
Expand Down
2 changes: 2 additions & 0 deletions apps/jurumarble/src/app/main/components/Banner.tsx
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
"use client";

import styled, { css } from "styled-components";
import Image from "next/image";
import { MainBannerImage } from "public/images";
Expand Down
2 changes: 2 additions & 0 deletions apps/jurumarble/src/app/main/components/HotDrinkContainer.tsx
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
"use client";

import styled, { css } from "styled-components";
import useGetHotDrinkListService from "../services/useGetHotDrinkListService";
import Carousel from "./Carousel";
Expand Down
Original file line number Diff line number Diff line change
@@ -1,8 +1,10 @@
"use client";

import Path from "lib/Path";
import Image from "next/image";
import { useRouter } from "next/navigation";
import styled, { css } from "styled-components";
import useGetHotDrinkVoteService from "../services/useGetHotDrinkVoteService";
import { useGetHotDrinkVoteService } from "../services/useGetHotDrinkVoteService";

function HotDrinkVoteContainer() {
const router = useRouter();
Expand Down
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
"use client";

import SearchInput from "components/SearchInput";
import useInput from "hooks/useInput";
import Path from "lib/Path";
Expand Down
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
"use client";

import { useEffect, useRef, useState } from "react";
import { SvgStamp } from "src/assets/icons/components";
import styled, { css, useTheme } from "styled-components";
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
import { dehydrate } from "@tanstack/query-core";
import { getHotDrinkVote } from "lib/apis/vote/getHotDrinkVote";
import getQueryClient from "src/modules/getQueryClient";
import HydrateOnClient from "src/modules/hydrateOnClient";
import HotDrinkVoteContainer from "../components/HotDrinkVoteContainer";
import { hotDrinkVoteQueryKey } from "../services/queryKey";

export const HydratedDrinkVoteContainer = async () => {
const qc = getQueryClient();
await qc.prefetchQuery([hotDrinkVoteQueryKey], getHotDrinkVote);
const dehydratedState = dehydrate(qc);
return (
<HydrateOnClient state={dehydratedState}>
<HotDrinkVoteContainer />
</HydrateOnClient>
);
};
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
import { dehydrate } from "@tanstack/query-core";
import { getHotDrinkList } from "lib/apis/vote/getHotDrinkList";
import getQueryClient from "src/modules/getQueryClient";
import HydrateOnClient from "src/modules/hydrateOnClient";
import HotDrinkContainer from "../components/HotDrinkContainer";
import { hotDrinkListQueryKey } from "../services/queryKey";

export const HydratedHotDrinkContainer = async () => {
const qc = getQueryClient();
await qc.prefetchQuery([hotDrinkListQueryKey], getHotDrinkList);
const dehydratedState = dehydrate(qc);
return (
<HydrateOnClient state={dehydratedState}>
<HotDrinkContainer />
</HydrateOnClient>
);
};
2 changes: 2 additions & 0 deletions apps/jurumarble/src/app/main/services/queryKey.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
export const hotDrinkVoteQueryKey = "hotDrinkVote";
export const hotDrinkListQueryKey = "searchDrinkList";
Original file line number Diff line number Diff line change
@@ -1,11 +1,10 @@
import { useQuery } from "@tanstack/react-query";
import { getHotDrinkList } from "lib/apis/drink";
import { queryKeys } from "lib/queryKeys";

const getQueryKey = () => [queryKeys.SEARCH_DRINK_LIST];
import { hotDrinkListQueryKey } from "./queryKey";

export default function useGetHotDrinkListService() {
const { data } = useQuery(getQueryKey(), getHotDrinkList);
const { data } = useQuery([hotDrinkListQueryKey], getHotDrinkList);

return { data };
}
Original file line number Diff line number Diff line change
@@ -1,11 +1,11 @@
import { useQuery } from "@tanstack/react-query";
import { getHotDrinkVote } from "lib/apis/vote";
import { queryKeys } from "lib/queryKeys";

const getQueryKey = () => [queryKeys.HOT_DRINK_VOTE];

export default function useGetHotDrinkVoteService() {
const { data: hotDrinkVote } = useQuery(getQueryKey(), getHotDrinkVote);
import { getHotDrinkVote } from "lib/apis/vote/getHotDrinkVote";
import { hotDrinkVoteQueryKey } from "./queryKey";

export const useGetHotDrinkVoteService = () => {
const { data: hotDrinkVote } = useQuery({
queryKey: [hotDrinkVoteQueryKey],
queryFn: getHotDrinkVote,
});
return { hotDrinkVote };
}
};
15 changes: 15 additions & 0 deletions apps/jurumarble/src/app/page.module.css
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
.main-top-section {
padding: 0 20px;
}

.main-bottom-section {
padding: 0 20px 96px;
margin-top: 8px;
overflow: auto;
}

.main-divide-line {
height: 8px;
margin: 40px 0 8px 0;
background-color: var(--bg_01);
}
47 changes: 15 additions & 32 deletions apps/jurumarble/src/app/page.tsx
Original file line number Diff line number Diff line change
@@ -1,13 +1,10 @@
"use client";

import BottomBar from "components/BottomBar";
import Header from "components/Header";
import styled, { css } from "styled-components";
import dynamic from "next/dynamic";

const DynamicHotDrinkVoteContainer = dynamic(
() => import("./main/components/HotDrinkVoteContainer"),
);
import { getClassNames } from "lib/styles/getClassNames";
import styles from "./page.module.css";
import { HydratedDrinkVoteContainer } from "./main/containers/HydratedDrinkVoteContainer";
import { HydratedHotDrinkContainer } from "./main/containers/HydratedHotDrinkContainer";

const DynamicHotDrinkContainer = dynamic(() => import("./main/components/HotDrinkContainer"), {
ssr: false,
Expand All @@ -28,41 +25,27 @@ const DynamicSearchInputWrapper = dynamic(() => import("./main/components/Search

const DynamicBanner = dynamic(() => import("./main/components/Banner"));

const cx = getClassNames(styles);

function MainPage() {
return (
<>
<Header />
<DynamicTodayDrinkRecommendation />
<TopSection>
<section className={cx("main-top-section")}>
<DynamicBanner />
<DynamicSearchInputWrapper />
<DynamicHotDrinkContainer />
</TopSection>
<DivideLine />
<BottomSection>
<DynamicHotDrinkVoteContainer />
</BottomSection>
{/* @ts-expect-error Server Component */}
<HydratedHotDrinkContainer />
</section>
<div className={cx("main-divide-line")} />
<section className={cx("main-bottom-section")}>
{/* @ts-expect-error Server Component */}
<HydratedDrinkVoteContainer />
</section>
<BottomBar />
</>
);
}

const TopSection = styled.section`
padding: 0 20px;
`;

const BottomSection = styled.section`
padding: 0 20px 96px; // 64(BottomBar height) + 32(margin) = 96
margin-top: 8px;
overflow: auto;
`;

const DivideLine = styled.div`
${({ theme }) => css`
background-color: ${theme.colors.bg_01};
height: 8px;
margin: 40px 0 8px 0;
`}
`;

export default MainPage;
12 changes: 0 additions & 12 deletions apps/jurumarble/src/lib/apis/vote.ts
Original file line number Diff line number Diff line change
Expand Up @@ -163,18 +163,6 @@ export const getVotingCheck = async (voteId: number) => {
return response.data;
};

interface GetHotDrinkVoteResponse {
voteId: number;
voteTitle: string;
drinkAImage: string;
drinkBImage: string;
}

export const getHotDrinkVote = async () => {
const response = await baseApi.get<GetHotDrinkVoteResponse>("api/votes/drinks/hot");
return response.data;
};

export const deleteVote = async (voteId: number) => {
const response = await http.delete(`api/votes/${voteId}/`);
return response.data;
Expand Down
13 changes: 13 additions & 0 deletions apps/jurumarble/src/lib/apis/vote/getHotDrinkList.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
import { SERVER_URL } from "lib/env";

export interface GetHotDrinkResponse {
drinkId: number;
name: string;
manufactureAddress: string;
image: string;
}
export const getHotDrinkList = async () => {
const res = await fetch(`${SERVER_URL}api/drinks/hot`);
const data = await res.json();
return data as GetHotDrinkResponse[];
};
14 changes: 14 additions & 0 deletions apps/jurumarble/src/lib/apis/vote/getHotDrinkVote.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
import { SERVER_URL } from "lib/env";

interface GetHotDrinkVoteResponse {
voteId: number;
voteTitle: string;
drinkAImage: string;
drinkBImage: string;
}

export const getHotDrinkVote = async () => {
const res = await fetch(`${SERVER_URL}api/votes/drinks/hot`);
const data = await res.json();
return data as GetHotDrinkVoteResponse;
};
19 changes: 19 additions & 0 deletions apps/jurumarble/src/lib/env.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
import Path from "./Path";

export const CLIENT_URL = process.env.NEXT_PUBLIC_CLIENT_URL || "";
export const SERVER_URL = process.env.NEXT_PUBLIC_SERVER_URL || "";

export const KAKAO_CLIENT_ID = process.env.NEXT_PUBLIC_KAKAO_CLIENT_ID || "";
export const NAVER_CLIENT_ID = process.env.NEXT_PUBLIC_NAVER_CLIENT_ID || "";

export const KAKAO_MAP_API_KEY = process.env.NEXT_PUBLIC_KAKAO_MAP_API_KEY || "";
export const KAKAO_LOGIN_REDIRECT_URL =
process.env.NODE_ENV === "development"
? `http://localhost:3000/${Path.KAKAO_LOGIN_PROCESS}`
: `${CLIENT_URL}${Path.KAKAO_LOGIN_PROCESS}`;
export const NAVER_LOGIN_REDIRECT_URL =
process.env.NODE_ENV === "development"
? `http://localhost:3000${Path.NAVER_LOGIN_PROCESS}`
: `${CLIENT_URL}${Path.NAVER_LOGIN_PROCESS}`;

export const DATA_GO_API_KEY = process.env.NEXT_PUBLIC_DATA_GO_API_KEY || "";
5 changes: 5 additions & 0 deletions apps/jurumarble/src/modules/getQueryClient.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
import { QueryClient } from "@tanstack/query-core";
import { cache } from "react";

const getQueryClient = cache(() => new QueryClient());
export default getQueryClient;
4 changes: 4 additions & 0 deletions apps/jurumarble/src/modules/hydrateOnClient.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
"use client";

import { Hydrate as HydrateOnClient } from "@tanstack/react-query";
export default HydrateOnClient;
8 changes: 8 additions & 0 deletions yarn.lock
Original file line number Diff line number Diff line change
Expand Up @@ -1634,6 +1634,7 @@ __metadata:
"@svgr/core": ^8.0.0
"@svgr/plugin-jsx": ^8.0.1
"@svgr/plugin-prettier": ^8.0.1
"@tanstack/query-core": ^4.36.1
"@tanstack/react-query": ^4.33.0
"@tanstack/react-query-devtools": ^4.33.0
"@types/node": 20.5.7
Expand Down Expand Up @@ -2312,6 +2313,13 @@ __metadata:
languageName: node
linkType: hard

"@tanstack/query-core@npm:^4.36.1":
version: 4.36.1
resolution: "@tanstack/query-core@npm:4.36.1"
checksum: 47672094da20d89402d9fe03bb7b0462be73a76ff9ca715169738bc600a719d064d106d083a8eedae22a2c22de22f87d5eb5d31ef447aba771d9190f2117ed10
languageName: node
linkType: hard

"@tanstack/react-query-devtools@npm:^4.20.4, @tanstack/react-query-devtools@npm:^4.33.0":
version: 4.33.0
resolution: "@tanstack/react-query-devtools@npm:4.33.0"
Expand Down

0 comments on commit 5812fcb

Please sign in to comment.