Hey everyone, it’s atz here!
I'm thrilled to share an exciting update on our Attendance Management System. We've created a robust web application using the MERN stack (MongoDB, Express.js, React.js, Node.js) with Firebase Authentication and Storage. This system streamlines the management of student attendance, making it easier than ever to track, update, and export attendance records.
If you find this project helpful or interesting, please consider starring the repository on GitHub! Your support is greatly appreciated.
- 👋 Introduction
- ✨ Features
- 🛠️ Technologies Used
- 🔧 Prerequisites
- 🚀 Installation
- 📖 Usage
- 📡 API Endpoints
- 📂 Folder Structure
- 🤝 Contributing
- 📧 Contact
The Attendance Management System is a web application built using the MERN stack (MongoDB, Express.js, React.js, Node.js) with Firebase Authentication and Storage. It provides a comprehensive solution for managing student attendance, adding or removing student data, and generating attendance reports.
-
🔐 User Authentication: Securely register and login with email and password using Firebase Authentication. This ensures that only authorized personnel can access and manage the system.
-
📋 Manage Attendance:
- View Attendance: Displays a list of all students with their names, register numbers, and images.
- Search Students: Quickly find students by their name.
- Update Attendance: Admins can mark students as present or absent using radio buttons, updating their status multiple times throughout the day. The system maintains the attendance status for the current date, resetting it automatically at the start of each new day.
-
📝 Student Data Management:
- Add Student: Capture essential student information including name, register number, and image. Images are stored in Firebase Storage, renamed with the student's register number for unique identification.
- Delete Student: Remove student records easily by entering their register number, which deletes both the record from MongoDB and the image from Firebase Storage.
- Retrieve Student: Fetch student details by their register number.
-
📊 Export Attendance Data:
- Excel Export: Download attendance records between specified dates in Excel format. This report includes student names, gender, year, and their attendance records within the selected range.
- Word Export: Download the current day's attendance in Word format, listing the names, departments, register numbers, and years of present students.
-
📱 Responsive Design: The application is designed to work seamlessly across various devices, including desktops, tablets, and mobile phones.
- Frontend: React.js
- Backend: Node.js, Express.js
- Database: MongoDB
- Authentication: Firebase Authentication
- Storage: Firebase Storage
- Excel Export: csv-writer library
- Word Export: officegen library
- Node.js (v14.x or later)
- MongoDB (Local or Atlas)
- Firebase Project (for Authentication and Storage)
- Git
-
Clone the repository:
git clone https://github.com/atzgg132/attendance-management.git cd attendance-management
-
Backend Setup:
cd server npm install
-
Create a
.env
file in theserver
directory with the following environment variables:PORT=5000 MONGO_URI=<your_mongo_db_connection_string>
-
Start the backend server:
npm start
-
-
Frontend Setup:
cd ../client npm install
-
Create a
.env
file in theclient
directory with the following environment variables:REACT_APP_FIREBASE_API_KEY=<your_firebase_api_key> REACT_APP_FIREBASE_AUTH_DOMAIN=<your_firebase_auth_domain> REACT_APP_FIREBASE_PROJECT_ID=<your_firebase_project_id> REACT_APP_FIREBASE_STORAGE_BUCKET=<your_firebase_storage_bucket> REACT_APP_FIREBASE_MESSAGING_SENDER_ID=<your_firebase_messaging_sender_id> REACT_APP_FIREBASE_APP_ID=<your_firebase_app_id>
-
Start the frontend development server:
npm start
-
- Login/Register: Register a new user or login with existing credentials.
- Manage Attendance: View the list of students and update their attendance.
- Add Student: Use the "Add Student" feature to include new student data and their image.
- Delete Student: Remove a student by their register number.
- Retrieve Student: Fetch student details by their register number.
- Export Data:
- Excel: Export attendance records between selected dates.
- Word: Download the current day's attendance.
- Register User:
POST /api/auth/register
- Login User:
POST /api/auth/login
-
Add Student:
POST /form/insert
- Request Body:
{ "Name": "John Doe", "Register_number": "12345", "Year_of_studying": "2", "Branch_of_studying": "CSE", "Date_of_Birth": "2000-01-01", "Gender": "Male", "Community": "General", "Minority_Community": "No", "Blood_Group": "O+", "Aadhar_number": "123456789012", "Mobile_number": "9876543210", "Email_id": "[email protected]" }
- Request Body:
-
Get Student:
GET /remove/getStudent/:registerNumber
- Response:
{ "_id": "60d1f5c8d6e5d435c8763e1a", "Name": "John Doe", "Register_number": "12345", "Year_of_studying": "2", "Branch_of_studying": "CSE", "Date_of_Birth": "2000-01-01", "Gender": "Male", "Community": "General", "Minority_Community": "No", "Blood_Group": "O+", "Aadhar_number": "123456789012", "Mobile_number": "9876543210", "Email_id": "[email protected]" }
- Response:
-
Delete Student:
DELETE /remove/delete/:registerNumber
- Response:
Student removed successfully
- Response:
-
Record Attendance:
POST /attendance
- Request Body:
{ "attendanceData": [ { "studentId": "60d1f5c8d6e5d435c8763e1a", "attendance": "present" }, { "studentId": "60d1f5c8d6e5d435c8763e1b", "attendance": "absent" } ] }
- Request Body:
-
Export Attendance Data (Excel):
GET /data/download?start=2023-01-01&end=2023-12-31
- Query Parameters:
start
: Start date of the range inYYYY-MM-DD
format.end
: End date of the range inYYYY-MM-DD
format.
- Response: A downloadable CSV file containing the attendance data.
- Query Parameters:
-
Download Today’s Attendance (Word):
GET /attendanceToday/:date
- Query Parameter:
date
: Date inYYYY-MM-DD
format.
- Response: A downloadable Word document containing the attendance details of present students for the specified date.
- Query Parameter:
- Get All Students:
GET /read
- Response:
[ { "_id": "60d1f5c8d6e5d435c8763e1a", "Name": "John Doe", "Register_number": "12345", "Year_of_studying": "2", "Branch_of_studying": "CSE", "Date_of_Birth": "2000-01-01", "Gender": "Male", "Community": "General", "Minority_Community": "No", "Blood_Group": "O+", "Aadhar_number": "123456789012", "Mobile_number": "9876543210", "Email_id": "[email protected]" }, ... ]
- Response:
attendance-management-system/
│
├── client/ # React frontend
│ ├── public/
│
└──
src/
│ ├── components/
│ ├── pages/
│ ├── App.js
│ ├── index.js
│ └── ...
│
├── server/ # Node.js backend
│ ├── models/
│ ├── routes/
│ ├── index.js
│ └── ...
│
├── .gitignore
├── README.md
└── ...
Contributions are welcome! Please open an issue or submit a pull request.
For any questions or suggestions, please reach out to:
- Name: Arnav Bhattacharya
- Email: [email protected]
- GitHub: atzgg132
Feel free to further customize the README according to your project's requirements and structure.
Happy coding
Cheers atz