{"id":31760078,"url":"https://github.com/sanidhyy/yt-clone","last_synced_at":"2025-10-09T21:20:09.206Z","repository":{"id":317312533,"uuid":"1002351454","full_name":"sanidhyy/yt-clone","owner":"sanidhyy","description":"AI-Powered YouTube Clone using Next.js 15 and Mux","archived":false,"fork":false,"pushed_at":"2025-09-30T04:58:40.000Z","size":2925,"stargazers_count":5,"open_issues_count":0,"forks_count":0,"subscribers_count":0,"default_branch":"main","last_synced_at":"2025-09-30T06:24:54.401Z","etag":null,"topics":["clerk","css","google","html","javascript","mux","nextjs","postgresql","react","react-query","shadcn","shadcn-ui","tailwindcss","trpc","typescript","uploadthing","upstash","youtube","youtube-clone","yt-clone"],"latest_commit_sha":null,"homepage":"https://newtube-clone.vercel.app","language":"TypeScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/sanidhyy.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":"CONTRIBUTING.md","funding":".github/FUNDING.yml","license":"LICENSE","code_of_conduct":"CODE_OF_CONDUCT.md","threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":"SECURITY.md","support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null,"notice":null,"maintainers":null,"copyright":null,"agents":null,"dco":null,"cla":null},"funding":{"github":["sanidhyy"],"patreon":"sanidhy","custom":"https://www.buymeacoffee.com/sanidhy"}},"created_at":"2025-06-15T09:30:16.000Z","updated_at":"2025-09-30T04:58:37.000Z","dependencies_parsed_at":"2025-10-01T08:46:40.895Z","dependency_job_id":null,"html_url":"https://github.com/sanidhyy/yt-clone","commit_stats":null,"previous_names":["sanidhyy/yt-clone"],"tags_count":null,"template":false,"template_full_name":null,"purl":"pkg:github/sanidhyy/yt-clone","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/sanidhyy%2Fyt-clone","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/sanidhyy%2Fyt-clone/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/sanidhyy%2Fyt-clone/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/sanidhyy%2Fyt-clone/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/sanidhyy","download_url":"https://codeload.github.com/sanidhyy/yt-clone/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/sanidhyy%2Fyt-clone/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":279002074,"owners_count":26083285,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","status":"online","status_checked_at":"2025-10-09T02:00:07.460Z","response_time":59,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["clerk","css","google","html","javascript","mux","nextjs","postgresql","react","react-query","shadcn","shadcn-ui","tailwindcss","trpc","typescript","uploadthing","upstash","youtube","youtube-clone","yt-clone"],"created_at":"2025-10-09T21:19:46.098Z","updated_at":"2025-10-09T21:20:09.195Z","avatar_url":"https://github.com/sanidhyy.png","language":"TypeScript","funding_links":["https://github.com/sponsors/sanidhyy","https://patreon.com/sanidhy","https://www.buymeacoffee.com/sanidhy"],"categories":[],"sub_categories":[],"readme":"\u003ca name=\"readme-top\"\u003e\u003c/a\u003e\n\n# AI-Powered YouTube Clone using Next.js 15 and Mux\n\n![AI-Powered YouTube Clone using Next.js 15 and Mux](/.github/images/img_main.png 'AI-Powered YouTube Clone using Next.js 15 and Mux')\n\n[![Ask Me Anything!](https://flat.badgen.net/static/Ask%20me/anything?icon=github\u0026color=black\u0026scale=1.01)](https://github.com/sanidhyy 'Ask Me Anything!')\n[![GitHub license](https://flat.badgen.net/github/license/sanidhyy/yt-clone?icon=github\u0026color=black\u0026scale=1.01)](https://github.com/sanidhyy/yt-clone/blob/main/LICENSE 'GitHub license')\n[![Maintenance](https://flat.badgen.net/static/Maintained/yes?icon=github\u0026color=black\u0026scale=1.01)](https://github.com/sanidhyy/yt-clone/commits/main 'Maintenance')\n[![GitHub branches](https://flat.badgen.net/github/branches/sanidhyy/yt-clone?icon=github\u0026color=black\u0026scale=1.01)](https://github.com/sanidhyy/yt-clone/branches 'GitHub branches')\n[![Github commits](https://flat.badgen.net/github/commits/sanidhyy/yt-clone?icon=github\u0026color=black\u0026scale=1.01)](https://github.com/sanidhyy/yt-clone/commits 'Github commits')\n[![GitHub issues](https://flat.badgen.net/github/issues/sanidhyy/yt-clone?icon=github\u0026color=black\u0026scale=1.01)](https://github.com/sanidhyy/yt-clone/issues 'GitHub issues')\n[![GitHub pull requests](https://flat.badgen.net/github/prs/sanidhyy/yt-clone?icon=github\u0026color=black\u0026scale=1.01)](https://github.com/sanidhyy/yt-clone/pulls 'GitHub pull requests')\n[![Vercel status](https://img.shields.io/badge/Vercel-000000?style=for-the-badge\u0026logo=vercel\u0026logoColor=white)](https://newtube-clone.vercel.app 'Vercel status')\n\n\u003c!-- Table of Contents --\u003e\n\u003cdetails\u003e\n\n\u003csummary\u003e\n\n# :notebook_with_decorative_cover: Table of Contents\n\n\u003c/summary\u003e\n\n- [Folder Structure](#bangbang-folder-structure)\n- [Getting Started](#toolbox-getting-started)\n- [Screenshots](#camera-screenshots)\n- [Tech Stack](#gear-tech-stack)\n- [Stats](#wrench-stats)\n- [Contribute](#raised_hands-contribute)\n- [Acknowledgements](#gem-acknowledgements)\n- [Buy Me a Coffee](#coffee-buy-me-a-coffee)\n- [Follow Me](#rocket-follow-me)\n- [Learn More](#books-learn-more)\n- [Deploy on Vercel](#page_with_curl-deploy-on-vercel)\n- [Give A Star](#star-give-a-star)\n- [Star History](#star2-star-history)\n- [Give A Star](#star-give-a-star)\n\n\u003c/details\u003e\n\n## :bangbang: Folder Structure\n\nHere is the folder structure of this app.\n\n```bash\nyt-clone/\n  |- migrations/\n  |- public/\n    |-- github.svg\n    |-- logo.svg\n    |-- placeholder.svg\n    |-- user-placeholder.svg\n    |-- web-app-manifest-192x192.png\n    |-- web-app-manifest-512x512.png\n  |- src/\n    |-- app/\n        |--- (auth)/\n          |---- sign-in/\n          |---- sign-up/\n          |---- layout.tsx\n        |--- (home)/\n          |---- feed/\n          |---- playlists/\n          |---- search/\n          |---- subscriptions/\n          |---- users/\n          |---- videos/\n          |---- layout.tsx\n          |---- page.tsx\n        |--- (studio)/\n          |---- studio/\n          |---- layout.tsx\n        |--- api/\n          |---- trpc/\n          |---- uploadthing/\n          |---- users/\n          |---- videos/\n        |--- apple-icon.png\n        |--- error.tsx\n        |--- favicon.ico\n        |--- globals.css\n        |--- icon0.svg\n        |--- icon1.png\n        |--- layout.tsx\n        |--- manifest.json\n        |--- not-found.tsx\n    |-- components/\n        |--- providers/\n        |--- ui/\n        |--- filter-carousel.tsx\n        |--- infinite-scroll.tsx\n        |--- responsive-modal.tsx\n        |--- user-avatar.tsx\n    |-- config/\n        |--- http-status-codes.ts\n        |--- index.ts\n    |-- constants/\n        |--- index.ts\n    |-- db/\n        |--- index.ts\n        |--- schema.ts\n    |-- env/\n        |--- client.ts\n        |--- server.ts\n    |-- hooks/\n        |--- use-confirm.tsx\n        |--- use-intersection-observer.ts\n        |--- use-mobile.tsx\n    |-- lib/\n        |--- encryption.ts\n        |--- mux.ts\n        |--- qstash.ts\n        |--- ratelimit.ts\n        |--- redis.ts\n        |--- uploadthing.ts\n        |--- utils.ts\n    |-- modules\n        |--- auth/\n        |--- categories/\n        |--- comment-reactions/\n        |--- comments/\n        |--- home/\n        |--- playlists/\n        |--- search/\n        |--- studio/\n        |--- subscriptions/\n        |--- suggestions/\n        |--- users/\n        |--- video-reactions/\n        |--- video-views/\n        |--- videos/\n    |-- scripts/\n        |--- seed-categories.ts\n    |-- trpc/\n        |--- routers/\n        |--- client.tsx\n        |--- init.ts\n        |--- query-client.ts\n        |--- server.tsx\n    |-- middleware.ts\n  |- .env.example\n  |- .env.local\n  |- .gitignore\n  |- .prettierrc.mjs\n  |- bun.lock\n  |- components.json\n  |- drizzle.config.ts\n  |- environment.d.ts\n  |- eslint.config.mjs\n  |- next.config.js\n  |- package.json\n  |- postcss.config.mjs\n  |- README.md\n  |- tailwind.config.ts\n  |- tsconfig.json\n```\n\n\u003cbr /\u003e\n\n## :toolbox: Getting Started\n\n1. Make sure **Git** and **NodeJS** is installed.\n2. Clone this repository to your local computer.\n3. Create `.env.local` file in **root** directory.\n4. Contents of `.env.local`:\n\n```env\n# .env.local\n\n# disable telemetry\nDO_NOT_TRACK=\"1\"\nCLERK_TELEMETRY_DISABLED=\"1\"\nCLERK_TELEMETRY_DEBUG=\"1\"\nNEXT_TELEMETRY_DISABLED=\"1\"\n\n# app base url\nNEXT_PUBLIC_APP_BASE_URL=\"http://localhost:3000\"\n\n# clerk api keys\nNEXT_PUBLIC_CLERK_PUBLISHABLE_KEY=\"pk_test_XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX\"\nCLERK_SECRET_KEY=\"sk_test_XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX\"\n\n# clerk webhook\nCLERK_WEBHOOK_SECRET=\"whsec_XXXXXXXXXXXXXXXXXXXXXXXXXXXXXX\"\n\n# clerk redirect urls\nNEXT_PUBLIC_CLERK_SIGN_IN_URL=\"/sign-in\"\nNEXT_PUBLIC_CLERK_SIGN_UP_URL=\"/sign-up\"\nNEXT_PUBLIC_CLERK_SIGN_IN_FALLBACK_REDIRECT_URL=\"/\"\nNEXT_PUBLIC_CLERK_SIGN_UP_FALLBACK_REDIRECT_URL=\"/\"\n\n# neon db uri\nDATABASE_URL=\"postgresql://\u003cusername\u003e:\u003cpassword\u003e@\u003chostname\u003e/NewTube?sslmode=require\"\n\n# upstash redis url and token\nUPSTASH_REDIS_REST_URL=\"https://\u003cdb-slug\u003e.upstash.io\"\nUPSTASH_REDIS_REST_TOKEN=\"XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX\"\n\n# qstash token, url and keys\nQSTASH_TOKEN=\"XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX\"\nUPSTASH_WORKFLOW_URL=\"https://\u003cslug\u003e.ngrok-free.app\"\nQSTASH_CURRENT_SIGNING_KEY=\"sig_xxxxxxxxxxxxxxxxxxxxxxxx\"\nQSTASH_NEXT_SIGNING_KEY=\"sig_xxxxxxxxxxxxxxxxxxxxxxxxxxx\"\n\n# mux image and stream base url\nNEXT_PUBLIC_MUX_IMAGE_BASE_URL=\"https://image.mux.com\"\nNEXT_PUBLIC_MUX_STREAM_BASE_URL=\"https://stream.mux.com\"\n\n# mux token and webhook secret\nMUX_TOKEN_ID=\"xxxxxxxxx-xxx-xxxx-xxxx-xxxxxxxxxxxxxx\"\nMUX_TOKEN_SECRET=\"XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX\"\nMUX_WEBHOOK_SECRET=\"xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx\"\n\n# uploadthing app id and token\nUPLOADTHING_APP_ID=\"xxxxxxxxx\"\nUPLOADTHING_TOKEN=\"XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX\"\n\n# openai api base url\nOPENAI_API_BASE_URL=\"https://api.openai.com/v1\"\n\n# open ai api key cookie name and verification secret (generated by `openssl rand -hex 32`)\nOPENAI_API_KEY_COOKIE_NAME=\"XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX\"\nVERIFICATION_SECRET=\"XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX\"\n\n```\n\n### 5. Disable Telemetry (Optional)\n\n```bash\nDO_NOT_TRACK=\"1\"\nCLERK_TELEMETRY_DISABLED=\"1\"\nCLERK_TELEMETRY_DEBUG=\"1\"\nNEXT_TELEMETRY_DISABLED=\"1\"\n```\n\n- These disable analytics/telemetry from Clerk and Next.js. Keep them as provided.\n\n---\n\n### 6. App Base URL\n\n```bash\nNEXT_PUBLIC_APP_BASE_URL=\"http://localhost:3000\"\n```\n\n- Keep as `http://localhost:3000` during development.\n- Change to your deployed URL (e.g., `https://yourdomain.com`) in production.\n\n---\n\n### 7. Clerk (Authentication)\n\n- Go to [Clerk Dashboard](https://dashboard.clerk.com/).\n- Create a new application.\n- Navigate to **API Keys**:\n  - Copy **Publishable Key** → `NEXT_PUBLIC_CLERK_PUBLISHABLE_KEY`\n  - Copy **Secret Key** → `CLERK_SECRET_KEY`\n- Set up a **Webhook** (under \"Webhooks\") pointing to:\n  `https://\u003cyour-domain\u003e/api/users/webhook` (this will be your server endpoint, can be tunneled via [ngrok](https://ngrok.com/)).\n  Copy the generated secret → `CLERK_WEBHOOK_SECRET`\n- Redirect URLs: Keep as provided unless you modify authentication routes.\n\n---\n\n### 8. Neon (PostgreSQL Database)\n\n- Sign up at [Neon](https://neon.tech/).\n- Create a new **PostgreSQL project**.\n- Go to **Connection Details** and copy the **Connection String**.\n- Replace `\u003cusername\u003e`, `\u003cpassword\u003e`, and `\u003chostname\u003e` with your Neon credentials.\n- Append `?sslmode=require` at the end (needed for secure connections).\n\n---\n\n### 9. Upstash Redis (API Ratelimit)\n\n- Sign up at [Upstash](https://upstash.com/).\n- Create a **Redis database**.\n- In the database dashboard:\n  - Copy the **REST URL** → `UPSTASH_REDIS_REST_URL`\n  - Copy the **REST Token** → `UPSTASH_REDIS_REST_TOKEN`\n\n---\n\n### 10. Upstash QStash (AI Workflows)\n\n- In your [Upstash Dashboard](https://console.upstash.com/), create a **QStash project**.\n- Copy the **QStash Token** → `QSTASH_TOKEN`.\n- Configure your **Workflow URL** (this will be your server endpoint, can be tunneled via [ngrok](https://ngrok.com/)).\n- Obtain the **Signing Keys** from the QStash dashboard:\n  - Current Signing Key → `QSTASH_CURRENT_SIGNING_KEY`\n  - Next Signing Key → `QSTASH_NEXT_SIGNING_KEY`\n\n---\n\n### 11. Mux (Video Uploads)\n\n- Sign up at [Mux](https://mux.com/) and create a new project.\n- In your **Dashboard → Settings → API Access Tokens**:\n  - Create a new token with Videos (**Read \u0026 Write**) permissions.\n  - Copy **Token ID** → `MUX_TOKEN_ID`\n  - Copy **Token Secret** → `MUX_TOKEN_SECRET`\n- Set up a **Webhook** in Mux (point to `https://\u003cyour-domain\u003e/api/videos/webhook` (this will be your server endpoint, can be tunneled via [ngrok](https://ngrok.com/)).) and copy the **Webhook Signing Secret** → `MUX_WEBHOOK_SECRET`\n\n---\n\n### 12. UploadThing (File Uploads)\n\n- Sign up at [UploadThing](https://uploadthing.com/).\n- Create a new app.\n- Copy the **App ID** → `UPLOADTHING_APP_ID`\n- Copy the **API Token** → `UPLOADTHING_TOKEN`\n\n---\n\n### 13. OpenAI (AI Features)\n\n- Store it in your cookies under the name specified by `OPENAI_API_KEY_COOKIE_NAME`.\n- Generate both **verification secret** and **cookie name** (for cryptographic signing):\n\n  ```bash\n  openssl rand -hex 32\n  ```\n\n  Copy the output → `VERIFICATION_SECRET` and `OPENAI_API_KEY_COOKIE_NAME` separately\n\n---\n\n14. Install Project Dependencies using `npm install --legacy-peer-deps` or `yarn install --legacy-peer-deps` or `bun install --legacy-peer-deps`.\n\n15. Now app is fully configured 👍 and you can start using this app using either one of `npm run dev` or `yarn dev` or `bun dev`.\n\n**NOTE:** Please make sure to keep your API keys and configuration values secure and do not expose them publicly.\n\n## :camera: Screenshots\n\n![Modern UI/UX](/.github/images/img1.png 'Modern UI/UX')\n\n![Playlist functionality](/.github/images/img2.png 'Playlist functionality')\n\n![Creator profile](/.github/images/img3.png 'Creator profile')\n\n## :gear: Tech Stack\n\n[![React JS](https://skillicons.dev/icons?i=react 'React JS')](https://react.dev/ 'React JS') [![Next JS](https://skillicons.dev/icons?i=next 'Next JS')](https://nextjs.org/ 'Next JS') [![Typescript](https://skillicons.dev/icons?i=ts 'Typescript')](https://www.typescriptlang.org/ 'Typescript') [![Tailwind CSS](https://skillicons.dev/icons?i=tailwind 'Tailwind CSS')](https://tailwindcss.com/ 'Tailwind CSS') [![Vercel](https://skillicons.dev/icons?i=vercel 'Vercel')](https://vercel.app/ 'Vercel')\n\n## :wrench: Stats\n\n[![Stats for NewTube](/.github/images/stats.svg 'Stats for NewTube')](https://pagespeed.web.dev/analysis?url=https://newtube-clone.vercel.app 'Stats for NewTube')\n\n## :raised_hands: Contribute\n\nYou might encounter some bugs while using this app. You are more than welcome to contribute. Just submit changes via pull request and I will review them before merging. Make sure you follow community guidelines.\n\n## :gem: Acknowledgements\n\nUseful resources and dependencies that are used in NewTube.\n\n- Thanks to CodeWithAntonio: https://codewithantonio.com/\n- [@clerk/nextjs](https://www.npmjs.com/package/@clerk/nextjs): ^6.22.0\n- [@hookform/resolvers](https://www.npmjs.com/package/@hookform/resolvers): ^5.1.1\n- [@mux/mux-node](https://www.npmjs.com/package/@mux/mux-node): ^11.1.0\n- [@mux/mux-uploader-react](https://www.npmjs.com/package/@mux/mux-uploader-react): ^1.2.0\n- [@mux/mux-video-react](https://www.npmjs.com/package/@mux/mux-video-react): ^0.26.0\n- [@neondatabase/serverless](https://www.npmjs.com/package/@neondatabase/serverless): ^1.0.1\n- [@radix-ui/react-avatar](https://www.npmjs.com/package/@radix-ui/react-avatar): ^1.1.10\n- [@radix-ui/react-dialog](https://www.npmjs.com/package/@radix-ui/react-dialog): ^1.1.14\n- [@radix-ui/react-dropdown-menu](https://www.npmjs.com/package/@radix-ui/react-dropdown-menu): ^2.1.15\n- [@radix-ui/react-label](https://www.npmjs.com/package/@radix-ui/react-label): ^2.1.7\n- [@radix-ui/react-select](https://www.npmjs.com/package/@radix-ui/react-select): ^2.2.5\n- [@radix-ui/react-separator](https://www.npmjs.com/package/@radix-ui/react-separator): ^1.1.7\n- [@radix-ui/react-slot](https://www.npmjs.com/package/@radix-ui/react-slot): ^1.2.3\n- [@radix-ui/react-tooltip](https://www.npmjs.com/package/@radix-ui/react-tooltip): ^1.2.7\n- [@radix-ui/react-visually-hidden](https://www.npmjs.com/package/@radix-ui/react-visually-hidden): ^1.2.3\n- [@t3-oss/env-nextjs](https://www.npmjs.com/package/@t3-oss/env-nextjs): ^0.13.8\n- [@tanstack/react-query](https://www.npmjs.com/package/@tanstack/react-query): ^5.80.7\n- [@trpc/client](https://www.npmjs.com/package/@trpc/client): ^11.4.1\n- [@trpc/react-query](https://www.npmjs.com/package/@trpc/react-query): ^11.4.1\n- [@trpc/server](https://www.npmjs.com/package/@trpc/server): ^11.4.1\n- [@uploadthing/react](https://www.npmjs.com/package/@uploadthing/react): ^7.3.2\n- [@upstash/ratelimit](https://www.npmjs.com/package/@upstash/ratelimit): ^2.0.5\n- [@upstash/redis](https://www.npmjs.com/package/@upstash/redis): ^1.35.0\n- [@upstash/workflow](https://www.npmjs.com/package/@upstash/workflow): ^0.2.14\n- [class-variance-authority](https://www.npmjs.com/package/class-variance-authority): ^0.7.1\n- [client-only](https://www.npmjs.com/package/client-only): ^0.0.1\n- [clsx](https://www.npmjs.com/package/clsx): ^2.1.1\n- [date-fns](https://www.npmjs.com/package/date-fns): ^4.1.0\n- [dotenv](https://www.npmjs.com/package/dotenv): ^16.5.0\n- [drizzle-orm](https://www.npmjs.com/package/drizzle-orm): ^0.44.2\n- [drizzle-zod](https://www.npmjs.com/package/drizzle-zod): ^0.8.2\n- [embla-carousel-react](https://www.npmjs.com/package/embla-carousel-react): ^8.6.0\n- [jiti](https://www.npmjs.com/package/jiti): ^2.4.2\n- [lucide-react](https://www.npmjs.com/package/lucide-react): ^0.515.0\n- [next](https://www.npmjs.com/package/next): 15.5.4\n- [openai](https://www.npmjs.com/package/openai): ^5.22.1\n- [player.style](https://www.npmjs.com/package/player.style): ^0.1.9\n- [react](https://www.npmjs.com/package/react): ^19.0.0\n- [react-dom](https://www.npmjs.com/package/react-dom): ^19.0.0\n- [react-error-boundary](https://www.npmjs.com/package/react-error-boundary): ^6.0.0\n- [react-hook-form](https://www.npmjs.com/package/react-hook-form): ^7.58.1\n- [react-hot-toast](https://www.npmjs.com/package/react-hot-toast): ^2.5.2\n- [server-only](https://www.npmjs.com/package/server-only): ^0.0.1\n- [superjson](https://www.npmjs.com/package/superjson): ^2.2.2\n- [tailwind-merge](https://www.npmjs.com/package/tailwind-merge): ^3.0.1\n- [tailwindcss-animate](https://www.npmjs.com/package/tailwindcss-animate): ^1.0.7\n- [uploadthing](https://www.npmjs.com/package/uploadthing): ^7.7.3\n- [vaul](https://www.npmjs.com/package/vaul): ^1.1.2\n- [zod](https://www.npmjs.com/package/zod): ^3.25.67\n- [@babel/eslint-parser](https://www.npmjs.com/package/@babel/eslint-parser): ^7.26.8\n- [@eslint/eslintrc](https://www.npmjs.com/package/@eslint/eslintrc): ^3\n- [@ianvs/prettier-plugin-sort-imports](https://www.npmjs.com/package/@ianvs/prettier-plugin-sort-imports): ^4.4.1\n- [@trivago/prettier-plugin-sort-imports](https://www.npmjs.com/package/@trivago/prettier-plugin-sort-imports): ^5.2.2\n- [@types/node](https://www.npmjs.com/package/@types/node): ^20\n- [@types/react](https://www.npmjs.com/package/@types/react): ^19\n- [@types/react-dom](https://www.npmjs.com/package/@types/react-dom): ^19\n- [concurrently](https://www.npmjs.com/package/concurrently): ^9.1.2\n- [drizzle-kit](https://www.npmjs.com/package/drizzle-kit): ^0.31.1\n- [eslint](https://www.npmjs.com/package/eslint): ^9\n- [eslint-config-next](https://www.npmjs.com/package/eslint-config-next): 15.1.7\n- [eslint-config-prettier](https://www.npmjs.com/package/eslint-config-prettier): ^10.0.1\n- [eslint-plugin-prettier](https://www.npmjs.com/package/eslint-plugin-prettier): ^5.2.3\n- [eslint-plugin-tailwindcss](https://www.npmjs.com/package/eslint-plugin-tailwindcss): ^3.18.0\n- [postcss](https://www.npmjs.com/package/postcss): ^8\n- [prettier](https://www.npmjs.com/package/prettier): ^3.5.1\n- [prettier-plugin-tailwindcss](https://www.npmjs.com/package/prettier-plugin-tailwindcss): ^0.6.11\n- [tailwindcss](https://www.npmjs.com/package/tailwindcss): ^3.4.1\n- [typescript](https://www.npmjs.com/package/typescript): ^5\n\n## :coffee: Buy Me a Coffee\n\n[\u003cimg src=\"https://img.shields.io/badge/Buy_Me_A_Coffee-FFDD00?style=for-the-badge\u0026logo=buy-me-a-coffee\u0026logoColor=black\" width=\"200\" /\u003e](https://www.buymeacoffee.com/sanidhy 'Buy me a Coffee')\n\n## :rocket: Follow Me\n\n[![Follow Me](https://img.shields.io/github/followers/sanidhyy?style=social\u0026label=Follow\u0026maxAge=2592000)](https://github.com/sanidhyy 'Follow Me')\n[![Tweet about this project](https://img.shields.io/twitter/url?style=social\u0026url=https%3A%2F%2Ftwitter.com%2FTechnicalShubam)](https://twitter.com/intent/tweet?text=Check+out+this+amazing+app:\u0026url=https%3A%2F%2Fgithub.com%2Fsanidhyy%2Fyt-clone 'Tweet about this project')\n[![Subscribe to my YouTube Channel](https://img.shields.io/youtube/channel/subscribers/UCNAz_hUVBG2ZUN8TVm0bmYw)](https://www.youtube.com/@OPGAMER./?sub_confirmation=1 'Subscribe to my YouTube Channel')\n\n## :books: Learn More\n\nTo learn more about Next.js, take a look at the following resources:\n\n- [Next.js Documentation](https://nextjs.org/docs) - learn about Next.js features and API.\n- [Learn Next.js](https://nextjs.org/learn) - an interactive Next.js tutorial.\n\nYou can check out [the Next.js GitHub repository](https://github.com/vercel/next.js/) - your feedback and contributions are welcome!\n\n## :page_with_curl: Deploy on Vercel\n\nThe easiest way to deploy your Next.js app is to use the [Vercel Platform](https://vercel.com/new?utm_medium=default-template\u0026filter=next.js\u0026utm_source=create-next-app\u0026utm_campaign=create-next-app-readme) from the creators of Next.js.\n\nCheck out [Next.js deployment documentation](https://nextjs.org/docs/deployment) for more details.\n\n## :star: Give A Star\n\nYou can also give this repository a star to show more people and they can use this repository.\n\n## :star2: Star History\n\n\u003ca href=\"https://star-history.com/#sanidhyy/yt-clone\u0026Timeline\"\u003e\n\u003cpicture\u003e\n  \u003csource media=\"(prefers-color-scheme: dark)\" srcset=\"https://api.star-history.com/svg?repos=sanidhyy/yt-clone\u0026type=Timeline\u0026theme=dark\" /\u003e\n  \u003csource media=\"(prefers-color-scheme: light)\" srcset=\"https://api.star-history.com/svg?repos=sanidhyy/yt-clone\u0026type=Timeline\" /\u003e\n  \u003cimg alt=\"Star History Chart\" src=\"https://api.star-history.com/svg?repos=sanidhyy/yt-clone\u0026type=Timeline\" /\u003e\n\u003c/picture\u003e\n\u003c/a\u003e\n\n\u003cbr /\u003e\n\u003cp align=\"right\"\u003e(\u003ca href=\"#readme-top\"\u003eback to top\u003c/a\u003e)\u003c/p\u003e\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fsanidhyy%2Fyt-clone","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fsanidhyy%2Fyt-clone","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fsanidhyy%2Fyt-clone/lists"}