diff --git a/docs/DeveloperGuide.md b/docs/DeveloperGuide.md
index aecb021bd02..ca407deeab4 100644
--- a/docs/DeveloperGuide.md
+++ b/docs/DeveloperGuide.md
@@ -15,8 +15,8 @@ pageNav: 3
## **Acknowledgements**
-Libraries used: [JavaFX](https://openjfx.io/), [Jackson](https://github.com/FasterXML/jackson), [JUnit5](https://github.com/junit-team/junit5)
-
+Libraries used: [JavaFX](https://openjfx.io/), [Jackson](https://github.com/FasterXML/jackson), [JUnit5](https://github.com/junit-team/junit5).\
+This project is based on the AddressBook-Level3 project created by the [SE-EDU initiative](https://se-education.org).
---
@@ -32,74 +32,75 @@ Refer to the guide [_Setting up and getting started_](SettingUp.md).
-The **_Architecture Diagram_** given above explains the high-level design of the App.
+The **_Architecture Diagram_** given above explains the high-level design of the application.
-Given below is a quick overview of main components and how they interact with each other.
+Given below is a quick overview of the main components of the application and how they interact with each other.
**Main components of the architecture**
-**`Main`** (consisting of classes [`Main`](https://github.com/AY2425S1-CS2103T-W14-3/tp/blob/master/src/main/java/hallpointer/address/Main.java) and [`MainApp`](https://github.com/AY2425S1-CS2103T-W14-3/tp/blob/master/src/main/java/hallpointer/address/MainApp.java)) is in charge of the app launch and shut down.
+**`Main`** (consisting of classes [`Main`](https://github.com/AY2425S1-CS2103T-W14-3/tp/blob/master/src/main/java/hallpointer/address/Main.java) and [`MainApp`](https://github.com/AY2425S1-CS2103T-W14-3/tp/blob/master/src/main/java/hallpointer/address/MainApp.java)) is in charge of the application launch and shut down.
-- At app launch, it initializes the other components in the correct sequence, and connects them up with each other.
+- At application launch, it initializes the other components in the correct sequence, and connects them up with each other.
- At shut down, it shuts down the other components and invokes cleanup methods where necessary.
-The bulk of the app's work is done by the following four components:
+[**`Commons`**](#common-classes) represents a collection of classes used by multiple other components.
-- [**`UI`**](#ui-component): The UI of the App.
-- [**`Logic`**](#logic-component): The command executor.
-- [**`Model`**](#model-component): Holds the data of the App in memory.
-- [**`Storage`**](#storage-component): Reads data from, and writes data to, the hard disk.
+The bulk of the application's work is done by the following four components:
-[**`Commons`**](#common-classes) represents a collection of classes used by multiple other components.
+- [**`UI`**](#ui-component): The user interface of the app.
+- [**`Logic`**](#logic-component): Handles parsing and executing the commands received through user input.
+- [**`Model`**](#model-component): Holds the data of the application in memory.
+- [**`Storage`**](#storage-component): Reads data from, and writes data to the hard disk.
**How the architecture components interact with each other**
-The _Sequence Diagram_ below shows how the components interact with each other for the scenario where the user issues the command `delete_member 1`.
+The _Sequence Diagram_ below shows how the components interact with each other when the user issues the command `delete_member 1`.
-Each of the four main components (also shown in the diagram above),
+Each of the four main components (also shown in the diagram above) has these properties:
-- defines its _API_ in an `interface` with the same name as the Component.
-- implements its functionality using a concrete `{Component Name}Manager` class (which follows the corresponding API `interface` mentioned in the previous point.
+- It defines its _API_ (Application Programming Interface) in an `interface` with the same name as the Component.
+- It implements its functionality using a concrete `{Component Name}Manager` class (which follows the corresponding API `interface` mentioned above).
-For example, the `Logic` component defines its API in the `Logic.java` interface and implements its functionality using the `LogicManager.java` class which follows the `Logic` interface. Other components interact with a given component through its interface rather than the concrete class (reason: to prevent outside component's being coupled to the implementation of a component), as illustrated in the (partial) class diagram below.
+For example, the `Logic` component defines its API in the `Logic.java` interface and implements its functionality using the `LogicManager.java` class which follows the `Logic` interface. Other components interact with a given component through its interface rather than the concrete class (to prevent outside components being coupled to the concrete implementation of a component), as illustrated in the partial class diagram below.
+
While the `Storage` component provides an abstraction layer for persistent data, it also exposes access to specific data structures, such as `ReadOnlyHallPointer` and `UserPrefs`. This design balances abstraction with the need for practical access to certain data classes critical to the application’s functionality.
Ideally, the `Storage` interface would fully abstract storage details by exposing methods like `getHallPointerData()` or `getUserPreferences()`, thus hiding specifics like `ReadOnlyHallPointer`. However, for simplicity and to meet the application’s needs, `Storage` directly returns these specific data structures.
-
-The sections below give more details of each component.
+
+The sections below give more details about each component.
### UI component
-The **API** of this component is specified in [`Ui.java`](https://github.com/AY2425S1-CS2103T-W14-3/tp/blob/master/src/main/java/hallpointer/address/ui/Ui.java)
+As mentioned above, the **API** of this component is specified in [`Ui.java`](https://github.com/AY2425S1-CS2103T-W14-3/tp/blob/master/src/main/java/hallpointer/address/ui/Ui.java), and a partial but representative class diagram thereof is shown below.
-The UI consists of a `MainWindow` that is made up of parts e.g.`CommandBox`, `ResultDisplay`, `MemberListPanel`, `StatusBarFooter` etc. All these, including the `MainWindow`, inherit from the abstract `UiPart` class which captures the commonalities between classes that represent parts of the visible GUI.
+The UI consists of a `MainWindow` that is made up of various parts like `CommandBox`, `ResultDisplay`, `MemberListPanel`, `StatusBarFooter` and so on. All these, including the `MainWindow`, inherit from the abstract `UiPart` class which captures the commonalities between classes that represent parts of the visible GUI.
-The `UI` component uses the 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`](https://ay2425s1-cs2103t-w14-3.github.io/tree/master/src/main/java/hallpointer/address/ui/MainWindow.java) is specified in [`MainWindow.fxml`](https://ay2425s1-cs2103t-w14-3.github.io/tree/master/src/main/resources/view/MainWindow.fxml)
+The `UI` component uses the 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`](https://ay2425s1-cs2103t-w14-3.github.io/tree/master/src/main/java/hallpointer/address/ui/MainWindow.java) is specified in [`MainWindow.fxml`](https://ay2425s1-cs2103t-w14-3.github.io/tree/master/src/main/resources/view/MainWindow.fxml).
-The `UI` component,
+The `UI` component has the following responsibilities:
-- executes user commands using the `Logic` component.
-- listens for changes to `Model` data so that the UI can be updated with the modified data.
-- keeps a reference to the `Logic` component, because the `UI` relies on the `Logic` to execute commands.
-- depends on some classes in the `Model` component, as it displays `Member` object residing in the `Model`.
+- Passing user commands to the `Logic` component using its reference thereof, so that the commands can be parsed and executed.
+- Keeping the display up to date with `Model` data, by listening for changes in `Model` data to update the display when appropriate.
+
+It also depends on some classes in the `Model` component like the `Member` or `Session` objects residing in the `Model`, the details of which inform what sort of visual layout is appropriate.
### Logic component
**API** : [`Logic.java`](https://github.com/AY2425S1-CS2103T-W14-3/tp/blob/master/src/main/java/hallpointer/address/logic/Logic.java)
-Here's a (partial) class diagram of the `Logic` component:
+Here's a partial and representative class diagram of the `Logic` component:
-The sequence diagram below illustrates the interactions within the `Logic` component, taking `execute("delete_member 1")` API call as an example.
+The sequence diagram below illustrates the interactions within the `Logic` component, taking an API call `execute("delete_member 1")` as an example.
@@ -111,11 +112,11 @@ The sequence diagram below illustrates the interactions within the `Logic` compo
How the `Logic` component works:
-1. When `Logic` is called upon to execute a command, it is passed to an `Parser` object which in turn creates a parser that matches the command (e.g., `DeleteMemberCommandParser`) and uses it to parse the command.
-2. This results in a `Command` object (more precisely, an object of one of its subclasses e.g., `DeleteCommand`) which is executed by the `LogicManager`.
-3. The command can communicate with the `Model` when it is executed (e.g. to delete a member).
+1. When `Logic` is called upon to execute a command, the API call is passed to an `Parser` object, which in turn creates a parser that matches the command (e.g. `DeleteMemberCommandParser`) and uses it to parse the command.
+2. This results in a `Command` object (more precisely, an object of one of its subclasses e.g. `DeleteCommand`) being created, which is then executed by the `LogicManager`.
+3. The `Command` communicates with the `Model` when it is executed (e.g. to delete a member).
Note that although this is shown as a single step in the diagram above (for simplicity), in the code it can take several interactions (between the command object and the `Model`) to achieve.
-4. The result of the command execution is encapsulated as a `CommandResult` object which is returned back from `Logic`.
+4. The result of the command execution is encapsulated as a `CommandResult` object which is then returned by `Logic`.
Here are the other classes in `Logic` (omitted from the class diagram above) that are used for parsing a user command:
@@ -123,18 +124,20 @@ Here are the other classes in `Logic` (omitted from the class diagram above) tha
How the parsing works:
-- When called upon to parse a user command, the `Parser` class creates an `XYZCommandParser` (`XYZ` is a placeholder for the specific command name e.g., `AddMemberCommandParser`) which uses the other classes shown above to parse the user command and create a `XYZCommand` object (e.g., `AddMemberCommand`) which the `Parser` returns back as a `Command` object.
-- All `XYZCommandParser` classes (e.g., `AddMemberCommandParser`, `DeleteSessionCommandParser`, ...) inherit from the `Parser` interface so that they can be treated similarly where possible e.g, during testing.
+- When called upon to parse a user command, the `HallPointerParser` class creates an `XYZCommandParser` (where `XYZCommandParser` is a placeholder for the specific command name that matches the API call e.g. `AddMemberCommandParser`). This newly created `Parser` then uses the other classes shown above to parse the user command, creating a `XYZCommand` object (e.g. `AddMemberCommand`) which the `Parser` returns back as a `Command` object.
+- All `XYZCommandParser` classes (e.g., `AddMemberCommandParser`, `DeleteSessionCommandParser`, ...) inherit from the `Parser` interface so that they can be treated similarly where possible, making adding more commands and further testing easier.
### Model component
**API** : [`Model.java`](https://github.com/AY2425S1-CS2103T-W14-3/tp/blob/master/src/main/java/hallpointer/address/model/Model.java)
+Here is a partial and representative class diagram of the `Model` component:
+
-The `Model` component,
+The `Model` component has the following responsibilites:
-- stores the hall pointer data i.e., all `Member` objects (which are contained in a `UniqueMemberList` object).
+- Storing the HallPointer data (i.e. any `Member` and `Session` objects, and application configuration files) in the hard disk.
- stores the currently 'selected' `Member` objects (e.g., results of a search query) as a separate _filtered_ list which 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 change.
- 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)
@@ -291,13 +294,13 @@ Priorities: High (must have) - `* * *`, Medium (nice to have) - `* *`, Low (unli
| Priority | As a … | I want to … | So that I can … | Remarks/Notes |
|----------|-----------------|------------------------------------------------------------------|-------------------------------------------------------------------------|---------------------------------------------------------------------------------------|
-| `* * *` | First-time user | Explore the app using sample data | I can understand its features without manually entering data | |
-| `* * *` | First-time user | See a guide on how to use the app | I can better understand its functionalities | |
-| `* * *` | First-time user | Save the changes I made | I won’t have to redo my work after reopening the app | |
+| `* * *` | First-time user | Explore the application using sample data | I can understand its features without manually entering data | |
+| `* * *` | First-time user | See a guide on how to use the application | I can better understand its functionalities | |
+| `* * *` | First-time user | Save the changes I made | I won’t have to redo my work after reopening the application | |
| `* * *` | First-time user | See sample data with a predefined structure | I have a format to follow when inputting my own data | |
-| `* * *` | First-time user | Delete all data in the app | I can start over when I make a mistake and remove sample data | |
-| `* * *` | User | Add new Hall members to the app | I can track points for new Hall members | |
-| `* * *` | User | Delete ex-Hall members from the app | I can stop tracking points for ex-Hall members | |
+| `* * *` | First-time user | Delete all data in the application | I can start over when I make a mistake and remove sample data | |
+| `* * *` | User | Add new Hall members to the application | I can track points for new Hall members | |
+| `* * *` | User | Delete ex-Hall members from the application | I can stop tracking points for ex-Hall members | |
| `* * *` | User | Customize point allocation criteria | I can reward members based on different participation criteria | E.g., different point weights for different activities |
| `* * *` | Frequent user | Add or delete points for each Hall member | I can track the overall participation status in the CCA | |
| `* * *` | Frequent user | Adjust attendance records if there are any errors | I can fix mistakes and maintain accurate records | |
@@ -310,7 +313,7 @@ Priorities: High (must have) - `* * *`, Medium (nice to have) - `* *`, Low (unli
| `*` | User | View analytics or visual reports of attendance and participation | I can see trends and member engagement at a glance | Charts or graphs to visualize data |
| `*` | User | Sort members by name | I can locate a member easily | |
| `*` | Frequent user | Automatically save changes without manual intervention | I don’t lose progress if I forget to click save | Auto-save feature |
-| `*` | Expert user | Perform all actions using the CLI | I can interact with the app more efficiently without relying on the GUI | |
+| `*` | Expert user | Perform all actions using the CLI | I can interact with the application more efficiently without relying on the GUI | |
| `*` | Expert user | Automate repetitive tasks, such as attendance updates | I can save time by reducing manual input | |
| `*` | User | Add notes for each member | I can track special situations or reasons for absences | |
| `*` | First-time user | Import data from an existing Google Sheets document or csv file | I can quickly upload my data without manual entry | |
@@ -496,7 +499,7 @@ None.
## **Appendix: Instructions for manual testing**
-Given below are instructions to test the app manually.
+Given below are instructions to test the application manually.
@@ -517,7 +520,7 @@ testers are expected to do more _exploratory_ testing.
2. Saving Window Preferences
1. Resize the window to an optimum size. Move the window to a different location. Close the window.
- 2. Re-launch the app by double-clicking the `.jar` file.
+ 2. Re-launch the application by double-clicking the `.jar` file.
**Expected:** The most recent window size and location is retained.
@@ -570,14 +573,14 @@ testers are expected to do more _exploratory_ testing.
1. Dealing with missing/corrupted data files
- 1. Open the hallpointer.json file located in the data directory (this file is created after the app is first launched). Modify it by deleting the name of the first entry.
+ 1. Open the hallpointer.json file located in the data directory (this file is created after the application is first launched). Modify it by deleting the name of the first entry.
**Expected:** Upon restarting, all data should be cleared, and an empty Hall Pointer should be displayed.
2. Confirming data persistence
1. Add or modify member/session data.
- 2. Exit the app and re-launch it.
+ 2. Exit the application and re-launch it.
**Expected:** All previous data should be saved and displayed upon restart.
### Other Features