IRIS Code In 107 Task-2

Installation Steps:

  1. Install nodejs and npm on your device.
  2. Clone the repository to your local system.
  3. In the root folder, create a '.env' file.
  4. Create a MongoDB server and get the MongoDB URI.
  5. Add env variables as "MONGO_URI" to the .env file
  6. Add a PORT variable and JWT_SECRET variable too.
  7. Set PORT = 5000
  8. Set JWT_SECRET as a string of your choice.

Steps to run the project

  1. Open up the command terminal from the root directory and type npm start to start the backend server.

  2. Open another command prompt and type the following to start the frontend.
    cd frontend
    npm run dev

  3. The application would be run on http://127.0.0.1:5173/

  4. An admin user will be created in the database

    Email : admin@nitk.edu.in
    Password: admin123

List of implemented features

  • Register and Login User
  • Each user gets a unique avatar
  • Users can only register with NITK email id
  • Different roles like Admin, Internship Coordinator, Placement Coordinator and User.
  • List of categories with ability to add and delete category for the admin
  • List of Users with their information
  • Admin can change allowed categories for each user and handle their roles and status.
  • Internship and Placement coordinators can edit the User status.
  • User Dashboard where a user can see the categories he can write about and the gyans he has already wrote.
  • List of Gyans
  • Seperate page for each Gyan with an accordion
  • Forms to add and edit gyans
  • Pagination on the Gyan Page
  • Filtering based on category and User branch

List of planned features

  • User authentication with Google OAuth
  • Better and responsive UI
  • Charts to show metadata about the gyans
  • Dark mode
  • More filtering options

List of known bugs

  • The pagination only lets the filter to apply on the current Gyans being rendered on the page.
  • On deleting a category, a question or a user, the documents in which they were refered are not deleted. This renders them as null on populating from the database and breaks the application.
  • On smaller screen, the UI breaks
  • A user should be able to write a single gyan and each topic but he can write multiple of them.

References

  • Stack Overflow
  • LogRocket blog
  • Tailwind CSS docs
  • W3School
  • Jason Watmore's blog
  • Mongoose JS docs
  • Formik docs
  • Medium articles

Screenshots

Register Form

Register Form

Login Form

Login Form

User List

User List

User Details (1)

User Details (1)

User Details (2)

User Details (2)

Edit User Form

Edit User List of Gyans

List of Gyans Filtering

Filtering List of Categories

List of Categories Add Category

Add Category List of Questions in a category

List of Questions in a category

User Dashboard (1)

UserDashboard

User Dashboard (2)

UserDashboard

Single Gyan

Single Gyan

CREDITS: Harshit Gupta