From b087a2f1960b604d11bd0bd29a4283d393adb8e8 Mon Sep 17 00:00:00 2001 From: Ashuh Date: Fri, 8 Apr 2022 16:49:33 +0800 Subject: [PATCH 1/6] Add model component description --- docs/DeveloperGuide.md | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/docs/DeveloperGuide.md b/docs/DeveloperGuide.md index 33d767d3575..e1ceb308a8e 100644 --- a/docs/DeveloperGuide.md +++ b/docs/DeveloperGuide.md @@ -21,6 +21,16 @@ Take a look at our design which is mostly based off [AddressBook Level 3 (AB3)]( ##UI Component +# Model Component +The `Model` component, + +- stores the address book data, i.e., all Person objects (which are contained in a UniquePersonList object). +- stores the currently ‘selected’ `Person` objects (i.e., results of a search query) as a separate *filtered* list that is not exposed to outsiders. +- stores the *sorted* 'selected' `Person` objects (i.e., results of a sort operation) as a separate *sorted* list that 'observes' the *filtered* list, i.e., it updates itself whenever the data in the *filtered* list changes. +- The *sorted* list is exposed to outsiders as an unmodifiable `ObservableList` that can be 'observed', e.g., the UI can be bound to this list so that the UI automatically updates when the data in the list changes. +- stores a UserPref object that represents the user’s preferences. This is exposed to the outside as a ReadOnlyUserPref objects. +- does not depend on any of the other three components (as the Model represents data entities of the domain, they should make sense on their own without depending on other components) + # Implementation This section describes some noteworthy details on how certain features are implemented. From 340710ba480a4f89d7719e6a28dc046ee2b3ddf5 Mon Sep 17 00:00:00 2001 From: Ashuh Date: Sun, 10 Apr 2022 14:00:16 +0800 Subject: [PATCH 2/6] Update sorting implementation in DG --- docs/DeveloperGuide.md | 24 +++++++++--------------- 1 file changed, 9 insertions(+), 15 deletions(-) diff --git a/docs/DeveloperGuide.md b/docs/DeveloperGuide.md index e1ceb308a8e..ca9b9892f1a 100644 --- a/docs/DeveloperGuide.md +++ b/docs/DeveloperGuide.md @@ -154,27 +154,21 @@ Displaying statistics of lower price and higher price of preferences of clients ## Sorting -The sorting feature allows the user to sort the list of `Person` displayed. +The sorting feature is implemented by using a `SortedList` to observe the `FilteredList` in `ModelManager`. Whenever the data in the list containing all `Person` objects is changed, the `FilteredList` is notified first and will filter the data. Whenever the data in the `FilteredList` changes, the `SortedList` is notified and will sort the filtered data. This allows the *sort* feature to be used in conjunction with the *find* feature, i.e., it is possible to *sort* the results found by the *find* feature. -The following table shows the attributes that the list can be sorted by and their corresponding keywords. +The `SortedList` is exposed in the `Model` interface as `Model#getFilteredAndSortedPersonList()` while the `FilteredList` is not exposed. -| Attribute | Keyword | -|----------------------|----------------| -| `Name` | `name` | -| `Phone` | `phone` | -| `Email` | `email` | -| `Favourite` | `favourite` | -| `Address` | `address` | -| `UserType` | `usertype` | -| Number of `Property` | `num_property` | +Comparisons between `Person` objects are facilitated by `PersonComparator` which holds a list of `Comparator`. It implements `Comparator` and compares `Person` objects using the first `Comparator` in the list, followed by the subsequent elements in the event of a tie. -Sorting the list is done by using the `sort` command, which has the following syntax: `sort [KEYWORD]...`. +Given below is an example usage scenario. -If multiple attributes are specified, the first attribute is given the highest priority, while the last attribute is given the lowest priority. For example, `sort address name` will sort the list by `Address` first, followed by `Name` if `Address` is equal. +Step 1. The user launches the application. Both the `FilteredList` and `SortedList` will contain the same data as the list containing all `Person` objects. -The sorting feature is implemented by using a `SortedList` to observe the `FilteredList` in `ModelManager`. +Step 2. The user executes `find name john`, causing the `FilteredList` to only contain clients with `john` in their name. -Whenever the underlying application data is modified, the `FilteredList` is notified first and will filter the data. If there is any change in the `FilteredList`, the `SortedList` is notified and will sort the filtered data. +Step 3. The user executes `sort phone` to sort the clients according to their phone number. The `sort` command calls `Model#updateSortedPersonList()`. This in turn calls `FilteredList#setComparator()` which causes the `FilteredList` to sort the data it contains. + +Step 4. The user executes `list` to list all clients, which causes the `FilteredList` to now contain all clients. The `SortedList` is automatically notified and sorts the new data in the `FilteredList`. Similarly, other commands that cause the data in the `FilteredList` to change, such as `add`, `delete`,`edit`,`favourite`, will cause the `SortedList` to automatically update itself. ## Feature `find` enhanced In addition to the original `NameContainsKeywordsPredicate`, more predicates concerning each of the attributes in a `Person` are created. From df8435766a7dede5985495bcbbf7859fc2c1d9be Mon Sep 17 00:00:00 2001 From: Ashuh Date: Mon, 11 Apr 2022 10:40:24 +0800 Subject: [PATCH 3/6] Add use case for sort --- docs/DeveloperGuide.md | 23 +++++++++++++++++++++++ 1 file changed, 23 insertions(+) diff --git a/docs/DeveloperGuide.md b/docs/DeveloperGuide.md index 95de10ba499..86635f137ab 100644 --- a/docs/DeveloperGuide.md +++ b/docs/DeveloperGuide.md @@ -431,6 +431,29 @@ Actor: User Use case resumes at step 2 +**Use Case: Sort** + +Actor: User + +**MSS** +1. User requests to sort the list of clients +2. REP displays clients in the requested order + + Use case ends + +**Extensions:** +* 1a. The list is empty + + Use case ends + + +* 1b. REP detects an error in the entered command + * 1b1. REP displays an error message + * 1b2. User enters the sort command again + * Steps 1b1-1b2 are repeated until the command entered is valid + + Use case resumes at step 2 + ## Non-functional Requirements 1. Should be able to work on any mainstream OS as long as it has Java 11 or above installed From 78cef3239eb862894f414d2566ee10f6368f2457 Mon Sep 17 00:00:00 2001 From: Ashuh Date: Mon, 11 Apr 2022 11:15:41 +0800 Subject: [PATCH 4/6] Add sort manual testing instructions --- docs/DeveloperGuide.md | 13 +++++++++++++ 1 file changed, 13 insertions(+) diff --git a/docs/DeveloperGuide.md b/docs/DeveloperGuide.md index 86635f137ab..c28a67caabb 100644 --- a/docs/DeveloperGuide.md +++ b/docs/DeveloperGuide.md @@ -563,6 +563,19 @@ Given below are instructions to test the app manually. ## Sorting clients +1. Sorting clients while all clients are being shown. + 1. Prerequisites: List all clients using the `list` command. Multiple clients in the list. + 2. Test case: `sort address`
+ Expected: Clients in the list are sorted according to their address in lexicographical order (capitalization is ignored). The number of clients listed is shown in the result display. + 3. Test case: `sort !phone`
+ Expected: Clients in the list are sorted according to their phone number in reverse numerical order. The number of clients listed is shown in the result display. + 4. Test case: `sort address !phone`
+ Expected: Clients in the list are sorted according to their address in lexicographical order (capitalization is ignored) first. Clients with the same address are then sorted by their phone number in reverse numerical order. The number of clients listed is shown in the result display. + 5. Test case: `sort invalid_key`
+ Expected: Clients are not sorted. Error details are shown in the result display and the list remains the same. + 6. Other incorrect sort commands to try: `sort`, `sort name invalid_key`, `sort invalid_key name`, `...`
+ Expected: Similar to previous. + ## Matching clients ## Uploading an Image From d79718240408ca4a63fd1c53c1ec483884128f93 Mon Sep 17 00:00:00 2001 From: Ashuh Date: Mon, 11 Apr 2022 11:26:28 +0800 Subject: [PATCH 5/6] Update RealEstatePro description in PPP --- docs/team/ashuh.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docs/team/ashuh.md b/docs/team/ashuh.md index 32538700e7f..1fbdc1d0e7f 100644 --- a/docs/team/ashuh.md +++ b/docs/team/ashuh.md @@ -5,7 +5,7 @@ title: Bryan Zheng's Project Portfolio Page ### Project: RealEstatePro -RealEstatePro is a desktop address book application used for teaching Software Engineering principles. The user interacts with it using a CLI, and it has a GUI created with JavaFX. It is written in Java, and has about 10 kLoC. +RealEstatePro is a desktop application for managing your client details for real estate agents. While it has a GUI, most of the user interactions happen using a CLI (Command Line Interface). With RealEstatePro managing your clients will be breeze by using the various features such as reminders, client matching and many more! Given below are my contributions to the project. From 3fbc071eceeac680dbab338a7fc03b3dd087f526 Mon Sep 17 00:00:00 2001 From: Ashuh Date: Mon, 11 Apr 2022 14:09:21 +0800 Subject: [PATCH 6/6] Update PPP contributions --- docs/team/ashuh.md | 43 ++++++++++++++++++------------------------- 1 file changed, 18 insertions(+), 25 deletions(-) diff --git a/docs/team/ashuh.md b/docs/team/ashuh.md index 1fbdc1d0e7f..603d09dd4a3 100644 --- a/docs/team/ashuh.md +++ b/docs/team/ashuh.md @@ -9,38 +9,31 @@ RealEstatePro is a desktop application for managing your client details for real Given below are my contributions to the project. -* **New Feature**: Added the ability to undo/redo previous commands. - * What it does: allows the user to undo all previous commands one at a time. Preceding undo commands can be reversed by using the redo command. - * Justification: This feature improves the product significantly because a user can make mistakes in commands and the app should provide a convenient way to rectify 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 too was challenging as it required changes to existing commands. - * Credits: *{mention here if you reused any code/ideas from elsewhere or if a third-party library is heavily used in the feature so that a reader can make a more accurate judgement of how much effort went into the feature}* +* **New Feature**: Added the ability to represent real estate listings using new classes: `Property`, `Region`, `Size`, `Price`. + * What it does: Represents the real estate listing of a client using the `Property` class which can be held by a `Person` object. + * Justification: This feature is required for the basic functionality of the application. + * Highlights: This feature was challenging to implement as it required significant changes to existing commands, and their unit tests. -* **New Feature**: Added a history command that allows the user to navigate to previous commands using up/down keys. +* **New Feature**: Added the ability to sort clients. + * What it does: Allows the user to sort clients according to one or more of their attributes. The sorting order for each attribute can also be reversed individually. This feature is integrated with the find feature, meaning that it is possible to sort the filtered list obtained after using the `find` command. + * Justification: This feature improves the product significantly because a user can have a large list of clients, and the application should provide a convenient way to organize them. + * Highlights: This feature was difficult to test as there are a large number of possible sorting orders. -* **Code contributed**: [RepoSense link]() +* **Code contributed**: [RepoSense link](https://nus-cs2103-ay2122s2.github.io/tp-dashboard/?search=w16-4&sort=groupTitle&sortWithin=title&timeframe=commit&mergegroup=&groupSelect=groupByRepos&breakdown=true&checkedFileTypes=docs~functional-code~test-code~other&since=2022-02-18&tabOpen=true&tabType=authorship&tabAuthor=Ashuh&tabRepo=AY2122S2-CS2103-W16-4%2Ftp%5Bmaster%5D&authorshipIsMergeGroup=false&authorshipFileTypes=docs~functional-code~test-code&authorshipIsBinaryFileTypeChecked=false) * **Project management**: - * Managed releases `v1.3` - `v1.5rc` (3 releases) on GitHub - -* **Enhancements to existing features**: - * Updated the GUI color scheme (Pull requests [\#33](), [\#34]()) - * Wrote additional tests for existing features to increase coverage from 88% to 92% (Pull requests [\#36](), [\#38]()) + * Maintained the issue tracker * **Documentation**: * User Guide: - * Added documentation for the features `delete` and `find` [\#72]() - * Did cosmetic tweaks to existing documentation of features `clear`, `exit`: [\#74]() + * Added documentation for the command format used to specify a `Property`: [\#50](https://github.com/AY2122S2-CS2103-W16-4/tp/pull/50) + * Added documentation for the `sort` feature: [\#67](https://github.com/AY2122S2-CS2103-W16-4/tp/pull/67) + * Improved readability of user guide by using alerts: [\#187](https://github.com/AY2122S2-CS2103-W16-4/tp/pull/187) * Developer Guide: - * Added implementation details of the `delete` feature. + * Added implementation details of the `Property` feature. + * Added implementation details of the `sort` feature. * **Community**: - * PRs reviewed (with non-trivial review comments): [\#12](), [\#32](), [\#19](), [\#42]() - * Contributed to forum discussions (examples: [1](), [2](), [3](), [4]()) - * Reported bugs and suggestions for other teams in the class (examples: [1](), [2](), [3]()) - * Some parts of the history feature I added was adopted by several other class mates ([1](), [2]()) - -* **Tools**: - * Integrated a third party library (Natty) to the project ([\#42]()) - * Integrated a new Github plugin (CircleCI) to the team repo - -* _{you can add/remove categories in the list above}_ + * PRs reviewed (with non-trivial review comments): [\#74](https://github.com/AY2122S2-CS2103-W16-4/tp/pull/74), [\#96](https://github.com/AY2122S2-CS2103-W16-4/tp/pull/96), [\#43](https://github.com/AY2122S2-CS2103-W16-4/tp/pull/43), [\#186](https://github.com/AY2122S2-CS2103-W16-4/tp/pull/186), [\#94](https://github.com/AY2122S2-CS2103-W16-4/tp/pull/94) + * Reported bugs in team member features (examples: [1](https://github.com/AY2122S2-CS2103-W16-4/tp/issues/68)) + * Helped team members with issues related to their features: [\#55](https://github.com/AY2122S2-CS2103-W16-4/tp/pull/55)