Vimuth's Project Portfolio Page
Project: SafeFor(H)All
SafeFor(H)All is a desktop app for hall admins to keep track of hall residents’ information to keep hall residents safe during the COVID-19 pandemic via a Command Line Interface (CLI) while still having the benefits of a Graphical User Interface (GUI). It is written in Java, and has about 15 kLoC.
Given below are my contributions to the project.
- Key contribution: Refactored the AB3 codebase to the context of SafeFor(H)All #45
- Changed package name from
seedu.address
tosafeforhall
- Enhanced the
Person
model to fit that of a resident - Updated the ui to show all details of a resident
- Updated storage for residents and added testing for all new files
- Changed package name from
- New Feature: Added the ability to contact trace residents
- What it does:
- Allows the user to get a list of all residents a given resident has been in contact with. This is done using information provided by the events data. The user is free to specify how far back to trace (number of days) as well as the depth which indicates if contacts are simply immediate contacts (depth 1) or contacts of contacts (depth 2, 3…)
- Justification:
- This feature adds significant value to the product and is strongly in line with the value proposition. It provides the admin with an easy way to find all close contacts in case of a positive case.
- Highlights:
- This enhancement required working with the model to access the list of events. There was a need for a good understanding of the design structure to not breaking existing abstraction and design. It was fun and challenging to implement the depth and duration restrictions.
- What it does:
- New Feature: Added the ability to import data from a csv
- What it does:
- Allows the user to mass import resident data from a provided csv file. This replaces the existing resident data provided no errors were raised while reading and creating
Person
objects. All resident lists of each event is then wiped to remove dependencies to old residents.
- Allows the user to mass import resident data from a provided csv file. This replaces the existing resident data provided no errors were raised while reading and creating
- Justification:
- This feature greatly improves the transition from an admins existing workflow to our product. It removes the need for entry of countless tedious add commands and improves the user experience.
- Highlights:
- This enhancement required thorough reading of the opencsv documentation. It required a number of decisions to be taken where I had to balance usabilty vs complicated implementations.
- Credits: The third part library, opencsv, was used to ease the reading of csv files.
- What it does:
- New Feature: Added the ability to traverse the history of command inputs
- What it does:
- Allows the user to use the up and down arrow keys when the command box is in focus, to traverse their past command line inputs. There is no hard limit on how many inputs are stored but there is no persistence after exiting the app.
- Justification:
- This feature really adds to the ease of use of the application. Since long commands are tedious to type but have a higher chance of being similar, and taking into account repetitive commands, this feature drastically reduces time waste and enhances the user experience.
- Highlights:
- This enhancement interacts mostly with the ui and required an understanding of how to send updates to it. Adding event handlers, resetting the text and even moving the cursor to the rightmost end of the text, were interesting and exciting tasks.
- What it does:
- Enhancements to existing features:
- Enhanced the
find
feature to allow filtering by any provided parameter #53- What it does:
- Allows the user to filter by other variables such as vaccination, faculty, email in addition to name.
- Justification:
- This significantly increases the usability of the
find
feature. In the context of the app, there’s a need to be able to filter by vaccination status, different blocks, levels and faculties for the admin to disemminate information to the right students.
- This significantly increases the usability of the
- What it does:
- Implement tab-specific behaviour of the same command keyword #80
- Contributions to the UI:
- Contributions to testing:
- Added 100% coverage for the
Person
model #142 - Added testing for the
find
,trace
andimport
features - Added ~2 kLoC in total for testing
- Added 100% coverage for the
- Enhanced the
-
Code contributed: RepoSense link
- Project management:
- Set up the GitHub team org/repo and tools such as CodeCov and Gradle
- Did work related to renaming the product and changing the product icon
- Delegated work and issues and managed the issue tracker throughout
- Managed releases
v1.2
,v1.3.trial
,v1.3
andv.1.3.1
(4 releases) on GitHub
- Documentation:
- User Guide:
- Developer Guide:
- Community:
- Tools: