Overview
Morpheus is a desktop application used for hotel management. The user interacts with it using a CLI, and it has a GUI created with JavaFX. It is written in Java, and has about 15 kLoC.
Summary of contributions
-
Major enhancement: added the ability to show and switch between tabs
-
What it does: allows the user to quickly navigate between tabs.
-
Justification: This feature improves the product significantly because a user need to work with multiple type of data and the app should provide a convenient way to traverse between them.
-
Highlights: This enhancement affects existing commands and commands to be added in future. It required an in-depth analysis of design alternatives. The implementation was challenging as existed implementation only accounted for 1 tab.
-
-
Minor enhancement: modify old search command to accommodate new needs.
-
Code contributed: [Functional code]
-
Other contributions:
-
Project management:
-
Managed releases
v1.2
-v1.4
(3 releases) on GitHub
-
-
Enhancements to existing features:
-
Documentation:
-
Community:
-
Contributions to the User Guide
Given below are sections I contributed to the User Guide. They showcase my ability to write documentation targeting end-users. |
Switching between tabs : switch
(Johnny)
If you want to switch to a new tab and view all the data on the specified tab, use the command switch
.
Format:: switch TAB_NAME
TAB_NAME must be one of welcome , guest , room , booking , service , bill
|
Examples:
-
switch guest
Result: Switches to and shows all entries on guest tab.
Finding guests: findguest
(Johnny)
If you want to find guests using their names or id, use the commmand findguest
.
Format: findguest [n/NAME] … [n/NAME] [i/ID] … [i/ID]
- Name must be an exact match. - The order of the keywords does not matter. e.g. n/Alice i/A10 is same as i/A10 n/Alice .- Persons matching at least one keyword will be returned. |
Examples:
-
findguest i/A0000000 n/Alice
Result: Shows persons with name: Alice
or ID: A1000000
Contributions to the Developer Guide
Given below are sections I contributed to the Developer Guide. They showcase my ability to write technical documentation and the technical depth of my contributions to the project. |
UI component (Johnny)
data:image/s3,"s3://crabby-images/0f99b/0f99bedd8d54d2fd8b1e3229b99b251063d0bfec" alt="UIDiagram"
API : Ui.java
The UI consists of a MainWindow
that is made up of parts e.g.CommandBox
, RoomListPanel
, PersonListPanel
, WelcomePanel
etc. All these, including the MainWindow
, inherit from the abstract UiPart
class.
The UI
component uses JavaFx UI framework. The layout of these UI parts are defined in matching .fxml
files that are in the src/main/resources/view
folder. For example, the layout of the MainWindow
is specified in MainWindow.fxml
The UI
component,
-
Executes user commands using the
Logic
component. -
Listens for changes to
Model
data so that the UI can be updated with the modified data. -
Receive command result and change user view accordingly.
Below is diagram for how UI extract command result for changing view.
data:image/s3,"s3://crabby-images/e2409/e24099b7c4eb2fd6a58bef0fb5ebfa30aa19668e" alt="commandSwitchUi"
FindGuestCommand
Implementation
Currently this command only support searching for full name or/and id number.
The following steps show how the search guest feature works:
-
The search command from the user is parsed into a list of pattern contained in the search command.
-
The command then executes and filters the guest list based on the patterns.
The diagram below show how the search command store its pattern.
data:image/s3,"s3://crabby-images/55cb0/55cb0292d3af02178e0a5475298a62eaf0f06539" alt="FindGuestCommand"
The diagram below shows the execution of the command:
data:image/s3,"s3://crabby-images/caa7f/caa7f1d47979de5ab3cdba4d3822818ed1b8fd24" alt="SearchWorkflow"
Design Considerations
-
Alternative 1 (current choice): Store pattern as list of name and id.
-
Pros: Simpler to test and understand.
-
Cons: Difficult to extend the implementation.
-
-
Alternative 2: Store pattern as a combination of Predicate.
-
Pros: Easy to implement and add more complicated pattern.
-
Cons: Harder to test, more prone to error.
-