Skip to content

0xDimzy/DRAMAKUS

Repository files navigation

Dramabox Clone

This is a Netflix-style streaming application built with React, Vite, Tailwind CSS, and Express.

Features

  • Homepage: Trending, Latest, VIP, For You, Dub Indo sections.
  • Search: Search for dramas.
  • Detail Page: Movie info and episode list.
  • Watch Page: Video player with episode selector and auto-next.
  • My List: Add to favorites (persisted in local storage).
  • Authentication: Firebase Auth (Google).
  • Cloud Progress Sync: Continue watching is synced to Firestore per user.
  • Responsive: Mobile and desktop optimized.

Tech Stack

  • Frontend: React 19, Vite, Tailwind CSS v4, Framer Motion, Swiper, Lucide React.
  • Backend: Express (for API proxying), Axios.
  • State Management: Zustand (with persistence).
  • Routing: React Router v7.

Setup

  1. Install Dependencies:

    npm install
  2. Environment Variables: Create a .env file (or update .env.example) with:

    DRAMABOX_API_KEY=your_api_key_here
    VITE_FIREBASE_API_KEY=your_firebase_api_key
    VITE_FIREBASE_AUTH_DOMAIN=your_project.firebaseapp.com
    VITE_FIREBASE_PROJECT_ID=your_project_id
    VITE_FIREBASE_APP_ID=your_app_id
    VITE_FIREBASE_MESSAGING_SENDER_ID=your_sender_id
    VITE_FIREBASE_STORAGE_BUCKET=your_project.appspot.com
    VITE_RECAPTCHA_SITE_KEY=your_recaptcha_v3_site_key
    RECAPTCHA_SECRET_KEY=your_recaptcha_v3_secret_key
    RECAPTCHA_MIN_SCORE=0.5

    Note:

    • Use Google reCAPTCHA v3 (auto verification, no image challenge by default).
    • RECAPTCHA_SECRET_KEY is server-only; do not expose it in client code.
  3. Run Development Server:

    npm run dev

    This starts the Express server with Vite middleware on http://localhost:3000.

  4. Build for Production:

    npm run build
    npm start

API

The app uses a proxy server at /api/proxy to forward requests to the Dramabox API, keeping your API key secure.

Firebase Firestore Rules

Firestore rules are provided in firestore.rules and Firebase config in firebase.json.

Deploy rules:

firebase login
firebase use <your-project-id>
firebase deploy --only firestore:rules

About

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

 
 
 

Contributors