Skip to content

razak571/mern_task_manager_app

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

46 Commits
 
 
 
 
 
 
 
 

Repository files navigation

MERN Task Manager App

MERN Stack License

A functional task management application built using the MERN (MongoDB, Express, React, Node.js) stack. The app allows users to manage tasks with features like user authentication (JWT & Google OAuth), task creation, task arrangement using drag-and-drop, and much more.

Task Manager App home Task Manager App signup Task Manager App login Task Manager App taskdetail Task Manager App edittask

🌟 Features

  • User Authentication: Secure login, registration, and logout using JWT (HttpOnly cookies) for protection against XSS attacks. Google OAuth is also integrated.
  • Task Management: Users can create, search, update, and delete tasks.
  • Drag-and-Drop: Easily manage tasks between "To Do", "In Progress", and "Done" columns.
  • Protected Routes: Only authenticated users can access protected pages, and already logged-in users cannot access login or signup pages.
  • Optimistic Updates: React Query is used for server-side caching and optimistic UI updates.
  • Responsive UI: Developed with React Beautiful DnD and customized UI components.

🛠️ Technologies Used

Frontend:

  • React (v18.3.1)
  • Redux Toolkit for global state management
  • React Router for routing
  • React Query for handling server data and caching
  • React Hook Form (with Zod validation)
  • React Beautiful DnD for drag-and-drop interactions
  • Axios for HTTP requests
  • Flowbite-React for UI components
  • React Toastify for user notifications

Backend:

  • Node.js (v18.x)
  • Express.js (v4.19.2) for the API
  • MongoDB with Mongoose for the database
  • JWT for user authentication
  • Bcrypt.js for password hashing
  • Cookie-Parser for handling JWT cookies

🚀 Live Demo

Check out the live deployed version here.

🏁 Getting Started Locally

To get this project running on your local machine, follow these steps:

Prerequisites

  • Node.js (v18.x or later)
  • MongoDB (local installation or MongoDB Atlas)

Installation

  1. Clone the repository:

    git clone https://github.com/razak571/mern_task_manager_app.git
  2. Navigate into the project directory:

    cd mern_task_manager_app

Backend Setup

  1. Navigate to the backend folder:

    cd backend
  2. Install backend dependencies:

    npm install
  3. Create a .env file in the backend folder and set the following environment variables:

    MONGO_URI=your_mongodb_connection_string
    JWT_SECRET=your_jwt_secret
  4. Start the backend server:

    npm start

The backend server will start at http://localhost:5000.

Frontend Setup

  1. Navigate to the frontend folder:

    cd ../frontend
  2. Install frontend dependencies:

    npm install
  3. Create a .env file in the frontend folder and add the backend URL:

    REACT_APP_API_URL=http://localhost:5000
  4. Start the frontend development server:

    npm start

The app will be running at http://localhost:3000.

🧪 Testing Locally

Once both servers (backend and frontend) are running, you can test the application by navigating to http://localhost:3000 in your browser.

📜 Available Scripts

In the project directories, you can run:

  • npm start: Starts the development server.
  • npm build: Builds the app for production.

🚀 Future Enhancements

  • User Avatar: Implement profile avatars for users.
  • Notifications: Add real-time notifications for task updates.
  • Improved UI: Align UI elements like search button and filters with a more polished design.

🐛 Known Issues

  • Minor alignment issues with the search button and add task button.
  • A small bug with cookies in production when using JWT (will be fixed soon).

🤝 Contributing

Feel free to fork the repository, submit issues, or make pull requests. Any contributions are welcome!

📄 License

This project is licensed under the MIT License.

👨‍💻 Author

Razak - GitHub


⭐️ If you found this project helpful, please give it a star on GitHub! ⭐️