Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Documentation:Developer] Sahil GSoC Report #634

Merged
merged 2 commits into from
Aug 22, 2024
Merged
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
57 changes: 56 additions & 1 deletion _docs/developer/google_summer_of_code/2024_Sahil_Suman.md
Original file line number Diff line number Diff line change
Expand Up @@ -3,4 +3,59 @@ title: Sahil Suman
category: Developer > Google Summer of Code 2024
---

coming soon
# GSoC Final Submission Review: Streamlining the Notebook Builder UI for Automated Grading

Participating in the Submitty project during GSoC has been a transformative experience, offering a deep dive into software development, communication with mentors, and hands-on problem-solving. My project focused on enhancing the Notebook Builder, a user interface that allows instructors to create interactive notebooks. These notebooks can be used as tutorial teaching materials or web-based exams, supporting basic markdown text formatting and various types of student input, such as multiple choice, short answers, and syntax-highlighted code boxes.

Throughout this project, I raised several pull requests (PRs), each contributing to the functionality and usability of the Notebook Builder:

## PRs Done Before GSoC

* **[Bugfix: Submission] Added Note to Absence Extension**
[PR #10044](https://github.com/Submitty/Submitty/pull/10044)
I addressed an issue where the text for excused absence extensions needed clearer communication in the student view within rainbow grades.

* **[Bugfix: Instructor UI] Upload Validation Error**
[PR #10048](https://github.com/Submitty/Submitty/pull/10048)
This PR introduced a validation error for instructors attempting to upload PDFs with incorrect page counts. Instead of adding a PHP dependency, I utilized a Python daemon worker, which already had the necessary dependencies installed, streamlining the solution.

* **[Feature: Submission] Hide Accessibility Text for Disabled**
[PR #10649](https://github.com/Submitty/Submitty/pull/10649)
This feature focused on hiding accessibility help text in CodeMirror when code boxes are disabled, as the text was causing confusion in these scenarios.

* **[Feature: Instructor UI] Course Material Tracking**
[PR #10650](https://github.com/Submitty/Submitty/pull/10650)
I added database migration to support course material tracking. Given Submitty's unique DB migration system, this required extensive testing and careful implementation to ensure reliability.

* **[Bugfix: Submission] Moved Text Outside the Label Tag**
[PR #10040](https://github.com/Submitty/Submitty/pull/10040)
This PR fixed a bug where a warning message appeared incorrectly when the "hide from students" option was selected. I adjusted the label structure to resolve the issue.

## PRs Done During GSoC

* **[UI/UX: Submission] Notebook Button Styling**
[PR #10768](https://github.com/Submitty/Submitty/pull/10768)
I addressed several styling issues, ensuring the notebook buttons adhered to the standard website color guide, improving the overall UI consistency.

* **[Documentation: Developer] Update Advanced Setup Guideline**
[PR #606](https://github.com/Submitty/submitty.github.io/pull/606)
While setting up Submitty locally, I identified areas for improvement in the setup guidelines and added screenshots and instructions to enhance the developer experience.

* **[UI/UX: TAGrading] Notebook Preview Button**
[PR #10788](https://github.com/Submitty/Submitty/pull/10788)
This PR introduces a preview button in the Notebook Builder section, allowing users to see how the notebook will look on the student end.

* **[Feature: Submission] Autosave on Notebook Gradeable**
[PR #10875](https://github.com/Submitty/Submitty/pull/10875)
This PR introduces an autosave feature for Notebook. Now, whenever any option is changed in the Notebook Grading interface, the system will automatically save the changes to the server. This enhancement aims to prevent data loss and improve the overall user experience by ensuring that no changes are inadvertently lost.

* **[Bugfix: TAGrading] Improve Date Validation**
[PR #10876](https://github.com/Submitty/Submitty/pull/10876)
This pull request introduces an additional try-catch block to handle errors more effectively. Instead of displaying the frog error page, the error will now be caught and thrown appropriately.

## Acknowledgements

I am deeply grateful to [Barbara Cutler](https://github.com/bmcutler) and [William Allen](https://github.com/williamjallen) for their invaluable support throughout this project. Barbara provided crucial insights into the project's broader scope, while William's regular meetups were instrumental in guiding me through PHP debugging and best practices, especially as a newcomer to the language.

Thank you,
[Sahil Suman](https://github.com/sahilsuman933)
Loading