What GPA? is a web-based application designed specifically for students of FAST National University of Computer and Emerging Sciences (NUCES) to calculate their semester GPA with precision. This tool supports students across all FAST campuses and departments, providing an intuitive and accurate way to track grades and compute GPAs.
The application is built using modern web technologies, including React, Vite, and Tailwind CSS, ensuring a fast, responsive, and user-friendly experience. It is hosted on Vercel and accessible at what-gpa.vercel.app.
- Accurate GPA Calculation: Computes semester GPA tailored to FAST NUCES grading policies.
- User-Friendly Interface: Simple and intuitive design for easy grade input and result viewing.
- Responsive Design: Optimized for both desktop and mobile devices.
- SEO Optimized: Includes meta tags, Open Graph, and Twitter Card data for better visibility and sharing.
- No-Cost Access: Completely free to use for all FAST students.
- Offline Support: Displays a "No Connection" page when offline.
- Customizable: Modular React components for easy updates and maintenance.
- Frontend: React, JSX, Tailwind CSS
- Build Tool: Vite
- Linting: ESLint
- Hosting: Vercel
- Icons: Flaticon (University icons by Freepik)
- Images: Storyset
abdulahad968-what-gpa/
├── README.md # Project documentation
├── eslint.config.js # ESLint configuration
├── index.html # Main HTML entry point
├── LICENSE # Project license
├── package.json # Project dependencies and scripts
├── vite.config.js # Vite configuration
└── src/
├── App.css # Global styles
├── App.jsx # Main React component
├── main.jsx # React entry point
├── components/ # Reusable React components
│ ├── CourseInput.jsx
│ ├── GradeTable.jsx
│ ├── Header.jsx
│ ├── ResultDisplay.jsx
├── pages/ # Page components
│ ├── Calculator.jsx
│ ├── Home.jsx
│ ├── NoConnection.jsx
│ ├── NotFound.jsx
│ ├── Result.jsx
│ ├── working.jsx
└── styles/ # Component-specific CSS
├── calculator.css
├── gradeTable.css
├── header.css
├── home.css
├── noconnection.css
├── notfound.css
├── result.css
├── working.css
To run the project locally, follow these steps:
-
Clone the Repository:
git clone https://github.com/AbdulAHAD968/What-GPA.git cd abdulahad968-what-gpa
-
Install Dependencies:
npm install
-
Run the Development Server:
npm run dev
-
Open in Browser: Navigate to
http://localhost:5173
to view the application.
- Visit what-gpa.vercel.app.
- Navigate to the Calculator page.
- Enter your course details and grades using the CourseInput component.
- View your calculated GPA in the ResultDisplay component.
- Use the GradeTable to review your entered grades.
Contributions are welcome! To contribute:
- Fork the repository.
- Create a new branch (
git checkout -b feature-branch
). - Make your changes and commit (
git commit -m "Add feature"
). - Push to the branch (
git push origin feature-branch
). - Open a Pull Request.
Please ensure your code follows the ESLint rules defined in eslint.config.js
.
This project is licensed under the MIT License.
For questions or feedback, reach out via GitHub Issues or connect on LinkedIn.