MathPlan is a Node.js web application developed to streamline the management of mathematics courses at TU Darmstadt. It simplifies the submission and approval of student's examination plans. It also allows members of the study office of mathematics to enter or modify data, such as courses/modules and examination regulations.
This README provides some basic information on how to install and run the application. For more detailed information, please refer to the documentation.
- 
Clone the Repository: git clone https://github.com/CodingTarik/MathPlan.git cd MathPlan
- 
Install Dependencies: npm install 
- 
Set Up Environment Variables: Checkout .envfile and configure the required variables.
- 
Database Setup: MySQL: Set up a MySQL database (follow online tutorial) and update the connection string in the .envfile. Locally, create a database with name as specified in.envfile, or else update the.envfile.SQLite: A sqlite file should be generated automatically. It has the name (and path) as specified in database.js. Scheme changes: Whenever there are changes in the scheme of tables (in Sequelize), change line db.sequelize.sync()to db.sequelize.sync({force: true})in app.js. Otherwise, the database still works with the old scheme and errors might occur. WARNING: this will delete all entries in the database. 
 Do not forget to redo this change after you have started the application once (if you want to keep your database content). For sqlite, you can alternatively simply delete the sqlite file in your file manager (please not while running the application).
- 
Start the Application: npm start The application will be accessible. 
- 
Build the Application: npm run build This command builds the application for production. 
- 
Run the Application: npm run start Start the application in development mode. 
- 
Start the application: node app.js Works properly only when application is already built, i.e. the build command was run and no changes in the frontend occurred afterwards. This command starts the application much faster than the other commands. 
- 
Linting: npm run lint Check coding standards using ESLint. 
- 
Linting and Fixing: npm run lint:fix Check and automatically fix coding standards using ESLint. 
- 
Prepare Husky: npm run prepare Install Husky, which runs ESLint and Jest before each commit. 
- 
Install Husky with Jest and ESLint: npm run installHusky Install Husky and initialize .husky with Jest and ESLint tests. 
- 
Run Tests: npm run testExecute tests using Jest. 
- 
Format Code: npm run format Format code using Prettier. 
- 
Student Submission: Students can log in and fill in the examination plan. They are also supposed to be able to alter and submit their examination plans and see feedback that was given on their submissions. 
- 
Instructor Management: Instructors are supposed to be able to log in, choose courses they want to teach, and specify room preferences for examinations. So far, they can only log in. 
- 
Admin Dashboard: Admins have access to a dashboard for managing courses and examination regulation. They are also supposed to be able to review as well as export examination plans. 
We welcome contributions from the community! If you'd like to contribute to MathPlan, please follow these steps:
- Fork the repository.
- Create a new branch: git checkout -b feature.
- Commit your changes: git commit -m 'Add your feature'.
- Push to the branch: git push origin feature/your-feature-name.
- Open a pull request.
Please ensure that your code follows the project's coding standards and includes relevant tests.
MathPlan is open-source software licensed under the GPL v3.