- React
- React Router DOM
- Redux Toolkit Query
- Redux Persist
- Eslint, Prettier, Lint Staged, Husky
- Swiper
- Supabase (for authentication)
- Tailwindcss & Postcss
- clsx
- Redux Toolkit Query services
- Get popular movies
- Get now playing movies
- Get upcoming movies
- Get top rated movies
- Get trending movies
- Get movies by genre (filter movie by genre)
- Search movies
- Get movie detail
- Infinite scroll
- Add to favorite movies using Redux Persist
- Authentication
- Login
- Register
- Login with Google
- Reusable custom hooks
- Auth provider context
- Structured folder
- Responsive design
- React Router layouting
- Scalable and maintainable
- Automatic linting that can maintain code style with Eslint, Prettier, Husky, and Lint Staged.
- Setup Supabase auth.
- Create account/login.
- Create new app to get the project URL and anon key.
- Enable Google provider (requires client ID and client secret from Google Cloud)
- Setup TMDB account.
- Get API key/access token.
- See
.env.example
and create your .env
file. Fill it with the correct values.
- Run
pnpm install
- Run
pnpm dev
data:image/s3,"s3://crabby-images/d1ede/d1edea5aa628fbbf97e7515938c50bdc3428a18d" alt="Home Page" |
Home Page |
data:image/s3,"s3://crabby-images/6db28/6db280da3450716d4a22f2998833fdeb85b4955d" alt="Movie Detail Page" |
Movie Detail Page |
data:image/s3,"s3://crabby-images/d1d8e/d1d8e157b9bd1598ba07ca856702f684936aefe8" alt="Search Movie by Genre Page" |
Search Movie by Genre Page |
data:image/s3,"s3://crabby-images/6c29c/6c29c044e6f3982dce17491cc9b4be1cb99c354e" alt="Search Page" |
Search Movie Page |
data:image/s3,"s3://crabby-images/99968/99968ab73626afaa47d43f907861f50dad9bfea4" alt="Login Page" |
Login Page |
data:image/s3,"s3://crabby-images/6d8b2/6d8b229394d3fc2887bd56e1a70e84090e633edf" alt="Example Login Page" |
Example Login Page |
Licensed under MIT License, Copyright (c) 2023 Rhenald Karrel.