Nahhas LMS Website

This is a Learning Management System (LMS) website built with Next.js. The purpose of this project is to provide a comprehensive platform for online education, tailored for the Syrian community.

Demo Video

Check out the demo video for this project on YouTube: Demo Video


Table of Contents

Features

  • Browse & Filter Courses
  • Purchase Courses using Stripe
  • NoSQL database using Mongodb
  • Authentication using Clerk
  • ORM using Prisma
  • Mark Chapters as Completed or Uncompleted
  • Progress Calculation of each Course
  • Student Dashboard
  • Teacher mode
  • Create new Courses
  • Create new Chapters
  • Easily reorder chapter position with drag n’ drop
  • Upload thumbnails, attachments and videos using UploadThing
  • Video player using react-player
  • Rich text editor for chapter description

Tech Stack

  • Framework: Next.js 14
  • Database: Prisma
  • Authentication: Clerk
  • UI Components: Radix UI, Shadcn/ui
  • Forms: React Hook Form
  • API Requests: Axios
  • Styling: Tailwind CSS
  • File Uploads: Uploadthing, Cloudinary
  • Markdown Support: React Markdown Preview, React MD Editor

Installation

Prerequisites

Make sure you have the following installed:

  • Node.js
  • npm or yarn
  • Git

Clone the Repository

To clone the project, run the following command in your terminal:

git clone https://github.com/AbdulrahmanNahhas/nahhas-lms.git

Navigate to the Project Directory

cd nahhas-lms

Install Dependencies

Using npm:

npm install

Or using yarn:

yarn install

Set Up Environment Variables

Create a .env.local file in the root directory and add your environment variables. Here is an example:

NEXT_PUBLIC_CLERK_PUBLISHABLE_KEY=
CLERK_SECRET_KEY=

NEXT_PUBLIC_CLERK_SIGN_IN_URL=/sign-in
NEXT_PUBLIC_CLERK_SIGN_UP_URL=/sign-up
NEXT_PUBLIC_CLERK_AFTER_SIGN_IN_URL=/
NEXT_PUBLIC_CLERK_AFTER_SIGN_UP_URL=/
NEXT_REDIRECT=/

DATABASE_URL=

NEXT_PUBLIC_CLOUDINARY_CLOUD_NAME=
NEXT_PUBLIC_CLOUDINARY_API_KEY=
CLOUDINARY_API_SECRET=

NEXT_PUBLIC_TEACHER_ID=
NEXT_PUBLIC_APP_URL=http://localhost:3000

STRIPE_API_KEY=
STRIPE_WEBHOOK_SECRET=

You can also find an example environment file in .env.example.

Start the Development Server

Using npm:

npm run dev

Or using yarn:

yarn dev

Open http://localhost:3000 to view it in your browser.

Usage

To use the LMS website, navigate to http://localhost:3000 in your web browser. From here, you can access all the features of the platform.

Contributing

Contributions are welcome! Please fork the repository and create a pull request with your changes.

  1. Fork the Project
  2. Create your Feature Branch (git checkout -b feature/AmazingFeature)
  3. Commit your Changes (git commit -m 'Add some AmazingFeature')
  4. Push to the Branch (git push origin feature/AmazingFeature)
  5. Open a Pull Request

License

This project is licensed under the MIT License - see the LICENSE file for details.