Skip to content

Latest commit

 

History

History
348 lines (219 loc) · 7.08 KB

README.md

File metadata and controls

348 lines (219 loc) · 7.08 KB

UNQtv: Netflix clone

Tutorial: https://youtu.be/mqUN4N2q4qY

GitHub: https://github.com/AntonioErdeljac/next-netflix-tutorial

Stacks

  • Next.js
  • Prisma
  • MongoDB

Digital Assets

qnoticias-0299

https://res.cloudinary.com/depkguybv/image/upload/v1680316888/unqtv/kvkmmcwgrtmtzzxrufih.jpg

https://res.cloudinary.com/depkguybv/video/upload/v1680288613/qnoticias-0299_seuma8.mp4

qnoticias-0300

https://res.cloudinary.com/depkguybv/image/upload/v1680316888/unqtv/tuzdja9pkqwipmbhv3ys.jpg

https://res.cloudinary.com/depkguybv/video/upload/v1680288689/qnoticias-0300_bofii3.mp4

institucional-0080

https://res.cloudinary.com/depkguybv/image/upload/v1680316888/unqtv/db9esqfjtafl6bdksdn5.jpg

https://res.cloudinary.com/depkguybv/video/upload/v1680288705/institucional-0080_gicbmf.mp4

institucional-0100

https://res.cloudinary.com/depkguybv/image/upload/v1680316888/unqtv/jzpqjjldyow3jzgivptp.jpg

https://res.cloudinary.com/depkguybv/video/upload/v1680288716/institucional-0100_e2yeye.mp4

conferenciasyjornadas-0001

https://res.cloudinary.com/depkguybv/image/upload/v1680316888/unqtv/nh3gtvb6mfdonwn1cnfl.jpg

https://res.cloudinary.com/depkguybv/video/upload/v1680288724/conferenciasyjornadas-0001_tozxp0.mp4

conferenciasyjornadas-0050

https://res.cloudinary.com/depkguybv/image/upload/v1680316888/unqtv/o29qejeoi9wdamhf5d4p.jpg

https://res.cloudinary.com/depkguybv/video/upload/v1680288735/conferenciasyjornadas-0050_ddvyvm.mp4


Timestamps

  • 00:00 Intro [DONE]
  • 02:05 Environment setup [DONE]
  • 08:47 Auth Screen UI [DONE]
  • 34:58 NextAuth, Prisma, Mongo Setup [DONE]
  • 01:20:39 Google and Github OAuth [DONE]
  • 01:33:40 Protecting routes, Profiles screen [DONE]
  • 02:00:22 Navbar Component [DONE]
  • 02:27:13 Billboard Component, Random Movie Endpoint [DONE]
  • 02:46:18 Movie List & Movie Card Components, Movies Endpoint, Cool hover effect [DONE]
  • 03:06:58 Favorites / My List functionality [DONE]
  • 03:29:19 Play Button, Video Player, Single Movie Endpoint [3:34:38]
  • 03:46:24 Info Modal Component [4:03:25]
  • 04:09:33 Vercel Deployment

Bash

Environment setup

  1. Crear un proyecto next.js (correrlo desde powershell para elegir Yes o No desde los cursores):
npx create-next-app --typescript
? What is your project named? unqtv

? Would you like to use ESLint with this project? [YES]

? Would you like to use 'src/' directory with this project? [NO]

? Would you like to use experimental `app/` directory with this project? [NO]

? What import alias would you like configured? [press ENTER]
  1. Abrir la carpeta creada y ejecutar el proyecto con:
npm run dev
  1. Borrar el archivo pages/_document.tsx

  2. Abrir el archivo pages/index.tsx y dejar el contenido siguiente:

export default function Home() {
    return (
        <>
            <h1>UNQtv</h1>
        </>
    );
}
  1. Borrar el archivo styles/Home.module.css

  2. Instalar Tailwind CSS:

npm install -D tailwindcss postcss autoprefixer
  1. Inicializar Tailwind CSS:
npx install tailwindcss init -p
  1. Abrir el archivo /tailwind.config.js y dejar el contenido siguiente:
/** @type {import('tailwindcss').Config} */
module.exports = {
  content: [
    "./app/**/*.{js,ts,jsx,tsx}",
    "./pages/**/*.{js,ts,jsx,tsx}",
    "./components/**/*.{js,ts,jsx,tsx}",
 
    // Or if using `src` directory:
    "./src/**/*.{js,ts,jsx,tsx}",
  ],
  theme: {
    extend: {},
  },
  plugins: [],
}
  1. Abrir el archivo styles/globals.css y dejar el contenido siguiente:
@tailwind base;
@tailwind components;
@tailwind utilities;

body {
  @apply bg-zinc-900 h-full overflow-x-hidden;
}

#__next {
  @apply h-full;
}

html {
  @apply h-full;
}
  1. Volver a ejecutar Next:
npm run dev

Auth Screen UI

TODO: SEGUIR CON VIDEO 10:20

Instalar Prisma:

npm install -D prisma

Crear el esquema inicial de Prisma:

npx prisma init

Instalar el paquete PrismaClient:

npm install @prisma/client

NextAuth, Prisma, Mongo Setup

Instalar el paquete Next Auth (para autenticación desde Next.js):

npm install next-auth

Instalar el paquete bcrypt:

npm install bcrypt

Instalar el paquete types de bcrypt:

npm i -D @types/bcrypt

Instalar el paquete axios:

npm i axios

Google and Github OAuth

Instalar el paquete axios:

npm install react-icons

Instalar el paquete Prisma-adapter:

npm install @next-auth/prisma-adapter

Protecting routes, Profiles screen

Instalar SWR:

npm install swr

Navbar Component

none

Billboard Component, Random Movie Endpoint

none

Movie List & Movie Card Components, Movies Endpoint, Cool hover effect

Instalar Lodash:

npm install lodash

Instalar Types de Lodash:

npm install -D @types/lodash

Favorites / My List functionality

none

Play Button, Video Player, Single Movie Endpoint

none

Info Modal Component

Instalar zustand (global state managment library):

npm install zustand

Vercel Deployment

Posible errors

Server selection timeout: No available servers.

  • Dinamic IP configuration: [1:46:46]

    • MongoDB cluster > Security > Network Access > + Add IP Address > Allow Access from Anywhere > Confirm

MongoDB Atlas

Cluster: unqtv-test

username: raullacabanne password: wPxjkbaQvhLib979


This is a Next.js project bootstrapped with create-next-app.

Getting Started

First, run the development server:

npm run dev
# or
yarn dev
# or
pnpm dev

Open http://localhost:3000 with your browser to see the result.

You can start editing the page by modifying pages/index.tsx. The page auto-updates as you edit the file.

API routes can be accessed on http://localhost:3000/api/hello. This endpoint can be edited in pages/api/hello.ts.

The pages/api directory is mapped to /api/*. Files in this directory are treated as API routes instead of React pages.

This project uses next/font to automatically optimize and load Inter, a custom Google Font.

Learn More

To learn more about Next.js, take a look at the following resources:

You can check out the Next.js GitHub repository - your feedback and contributions are welcome!

Deploy on Vercel

The easiest way to deploy your Next.js app is to use the Vercel Platform from the creators of Next.js.

Check out our Next.js deployment documentation for more details.


https://discord.gg/SPEBvAz4Vd