Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
29 commits
Select commit Hold shift + click to select a range
47e051f
Chore: #1 Next 프로젝트 초기 세팅
minnngo Apr 29, 2026
ac3f5c1
Feat: #2 하단 바 및 홈 인디케이터 구현
minnngo Apr 29, 2026
635397c
Feat: #3 검색 페이지 구현
minnngo Apr 30, 2026
3d941cf
Feat: #4 상세 페이지 구현
minnngo Apr 30, 2026
ab0ec47
Refactor: #5 파일 구조 수정
minnngo Apr 30, 2026
881d59c
Feat: 랜딩 페이지 구현
yiyoonseo Apr 30, 2026
5cef828
Merge branch 'master' into feature/landing_page-ui
yiyoonseo May 1, 2026
58930d7
Merge pull request #1 from CEOS-week5-Netflix/feature/landing_page-ui
yiyoonseo May 1, 2026
c8451ed
Feat: Header UI 구현
yiyoonseo May 1, 2026
9cdec5f
Feat: 영화 리스트 구현
yiyoonseo May 1, 2026
805e768
Feat: 라우팅
yiyoonseo May 1, 2026
504eeaf
Merge pull request #2 from CEOS-week5-Netflix/feature/main_page-ui
yiyoonseo May 1, 2026
bdf2f71
Merge chore/init-project into search UI
minnngo May 1, 2026
1d277c9
Merge pull request #3 from CEOS-week5-Netflix/feature/#3-search-ui
minnngo May 1, 2026
7fb0258
Feat: 페이지간 라우팅 연결
minnngo May 1, 2026
d2ec3cb
Feat: 검색 기능 구현
minnngo May 1, 2026
6a1591b
Fix: 검색 및 상세페이지 로딩 개선
minnngo May 1, 2026
98be864
Fix: 상세페이지 포스터 로딩 속도 개선
minnngo May 1, 2026
c0d31e6
Feat: pnpm migration
yiyoonseo May 8, 2026
ef35077
Feat: TurboPack migration
yiyoonseo May 8, 2026
32652b8
Merge pull request #4 from CEOS-week5-Netflix/feautre/migration
yiyoonseo May 8, 2026
ed31d03
Feat: 무한 스크롤 구현
minnngo May 8, 2026
8cc7f96
Feat: 검색 로딩 스켈레톤 구현
minnngo May 8, 2026
3f21be6
Chore: trigger ci
minnngo May 8, 2026
8df0711
Merge pull request #5 from CEOS-week5-Netflix/feature/refactoring
minnngo May 8, 2026
c77f82b
chore: trigger vercel redeploy
minnngo May 8, 2026
deb96d4
Refactor: 기타 리팩토링
yiyoonseo May 9, 2026
bbf9853
Mod: UI 개선
yiyoonseo May 9, 2026
3409fe9
Merge pull request #6 from CEOS-week5-Netflix/feature/main-refactor
yiyoonseo May 9, 2026
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
24 changes: 24 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
# dependencies
/node_modules

# next.js
/.next
/out
*.tsbuildinfo

# production
/build

# local env files
.env*.local
.env

# logs
npm-debug.log*
yarn-debug.log*
yarn-error.log*
pnpm-debug.log*

# misc
.DS_Store
.codex
5 changes: 5 additions & 0 deletions .prettierignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
node_modules
.next
out
build
package-lock.json
8 changes: 8 additions & 0 deletions .prettierrc
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
{
"semi": true,
"singleQuote": false,
"tabWidth": 2,
"trailingComma": "all",
"printWidth": 80,
"arrowParens": "always"
}
3 changes: 3 additions & 0 deletions .vscode/settings.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
{
"css.lint.unknownAtRules": "ignore"
}
26 changes: 26 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -56,3 +56,29 @@
- [Tanstack Query를 활용한 무한 스크롤 적용](https://oliveyoung.tech/2023-10-04/useInfiniteQuery-scroll/)
- [해외 숙소 리스트 성능 개선기-반쪽짜리 ssr에서 완벽한 인피니트 스크롤까지](https://techblog.gccompany.co.kr/%ED%95%B4%EC%99%B8-%EC%88%99%EC%86%8C-%EB%A6%AC%EC%8A%A4%ED%8A%B8-%EC%84%B1%EB%8A%A5-%EA%B0%9C%EC%84%A0%EA%B8%B0-%EB%B0%98%EC%AA%BD%EC%A7%9C%EB%A6%AC-ssr%EC%97%90%EC%84%9C-%EC%99%84%EB%B2%BD%ED%95%9C-%EC%9D%B8%ED%94%BC%EB%8B%88%ED%8A%B8-%EC%8A%A4%ED%81%AC%EB%A1%A4%EA%B9%8C%EC%A7%80-1ef7c7962dae)
- [react-intersection-observer 라이브러리](https://react-intersection-observer.vercel.app/?path=/docs/intro--docs)
- [React 18의 새로운 기능](https://www.youtube.com/watch?v=7mkQi0TlJQo)
- [react 서버 컴포넌트가 해결하는 문제들 in kakao 기술 블로그](https://tech.kakaopay.com/post/react-server-components/)

(Vercel)

- [vercel의 배포 방식](https://www.youtube.com/watch?v=8q-jCvLWwKc&t=11s)
- [조직 레포를 우회해 무료 배포하는 법](https://bori-note.tistory.com/73)

(랜딩페이지 Netflix 로고)

- [랜딩페이지 영상](https://lottiefiles.com/free-animation/netflix-logo-swoop-6nEmnysrGE)

(Next.js)

- [Next.js Docs](https://nextjs.org/docs)
- [Next.js 13에서 변한 것들](https://velog.io/@hang_kem_0531/Next.js-13%EC%9D%B4-%EB%82%98%EC%99%80%EB%B2%84%EB%A0%B8%EB%8B%A4)
- [Next.js 14에서 변한 것들](https://velog.io/@lee_1124/Next.js-14-%EC%97%85%EB%8D%B0%EC%9D%B4%ED%8A%B8)
- [Next.js 15, 16](https://beam307.github.io/2026/03/18/nextjs16-vs15/)
- [React & Next.js에서 발견된 취약점-(CVE-2025-55182(React2Shell)](https://news.hada.io/topic?id=24874)

(협업)

- [Git 협업 가이드](https://velog.io/@jinuku/Git-%ED%98%91%EC%97%85-%EA%B0%80%EC%9D%B4%EB%93%9C)
- [디자이너와 개발자가 협업하기 위한 피그마 기본 기능](https://chingguhl.tistory.com/entry/%EA%B0%9C%EB%B0%9C%EC%9E%90%EA%B0%80-%EA%BC%AD-%EC%95%8C%EC%95%84%EC%95%BC-%ED%95%A0-%ED%94%BC%EA%B7%B8%EB%A7%88-10%EA%B0%80%EC%A7%80-%EA%B8%B0%EB%8A%A5-%EB%94%94%EC%9E%90%EC%9D%B4%EB%84%88%EC%99%80-%EA%B0%9C%EB%B0%9C%EC%9E%90%EA%B0%80-%ED%98%91%EC%97%85%ED%95%98%EA%B8%B0-%EC%9C%84%ED%95%9C-%ED%94%BC%EA%B7%B8%EB%A7%88-%EA%B8%B0%EB%B3%B8-%EA%B8%B0%EB%8A%A5)

---
7 changes: 7 additions & 0 deletions eslint.config.mjs
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
import nextVitals from "eslint-config-next/core-web-vitals";
import nextTypescript from "eslint-config-next/typescript";
import prettier from "eslint-config-prettier/flat";

const eslintConfig = [...nextVitals, ...nextTypescript, prettier];

export default eslintConfig;
6 changes: 6 additions & 0 deletions next-env.d.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
/// <reference types="next" />
/// <reference types="next/image-types/global" />
import "./.next/dev/types/routes.d.ts";

// NOTE: This file should not be edited
// see https://nextjs.org/docs/app/api-reference/config/typescript for more information.
23 changes: 23 additions & 0 deletions next.config.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
import type { NextConfig } from "next";

const nextConfig: NextConfig = {
images: {
remotePatterns: [
{
protocol: "https",
hostname: "image.tmdb.org",
},
],
},
webpack(config) {
config.module.rules.push({
test: /\.svg$/i,
issuer: /\.[jt]sx?$/,
use: ["@svgr/webpack"],
});
return config;
},
turbopack: {},
};

export default nextConfig;
Loading