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

[CS2113-F10-3] TARBS #26

Open
wants to merge 200 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 66 commits
Commits
Show all changes
200 commits
Select commit Hold shift + click to select a range
5c616f8
Set theme jekyll-theme-minimal
Mar 4, 2022
80c25f7
Update AboutUs.md
Mar 4, 2022
6035a3d
update AboutUs
chintaiann Mar 4, 2022
4fda6aa
Add brendan to aboutus
bbawj Mar 4, 2022
e8f9de0
Merge branch 'master' into taiann-AboutUs
chintaiann Mar 4, 2022
8407b47
Merge pull request #1 from chintaiann/taiann-AboutUs
chintaiann Mar 4, 2022
d40c81f
update about-us
timchang27 Mar 4, 2022
cd544ae
Merge branch 'master' into master
bbawj Mar 4, 2022
06dd055
Merge pull request #2 from bbawj/master
bbawj Mar 4, 2022
354e627
v1.0
chintaiann Mar 10, 2022
d41ab0e
Merge pull request #4 from chintaiann/master
chintaiann Mar 10, 2022
8c7ce9b
Add OOP abstractions
bbawj Mar 10, 2022
b4799bf
Merge pull request #5 from bbawj/master
bbawj Mar 10, 2022
5628838
v1.0 - Some bugs
timchang27 Mar 11, 2022
146fd7c
v1.0 - Some bugs
timchang27 Mar 11, 2022
9142291
v1.0 - Some bugs
timchang27 Mar 11, 2022
aa628d0
v1.0 - Some bugs
timchang27 Mar 11, 2022
66bf249
v1.0
chintaiann Mar 17, 2022
20ecd8b
Merge pull request #6 from chintaiann/master
chintaiann Mar 17, 2022
ba42c73
make general revision
Mar 17, 2022
40314b7
revise the style
Mar 17, 2022
5932e94
revise the style
Mar 17, 2022
4b66d08
Merge pull request #7 from edemirkirkan/master
Mar 17, 2022
2b759a9
Added storage
mafpovbul Mar 24, 2022
b9fc095
Merge branch 'master' of https://github.com/AY2122S2-CS2113-F10-3/tp
timchang27 Mar 24, 2022
212b268
v1.0 - Initial Changes
timchang27 Mar 24, 2022
2948ac2
Added the 'help' command
Mar 24, 2022
add2be9
Revise the import issue
Mar 24, 2022
d809612
Merge pull request #10 from edemirkirkan/master
Mar 24, 2022
9b7ebe6
Update DeveloperGuide.md
timchang27 Mar 24, 2022
64ba090
Merge pull request #8 from mafpovbul/master
mafpovbul Mar 26, 2022
098dc21
Refactored storage, added more exception handling
mafpovbul Mar 26, 2022
3006887
changed save file
mafpovbul Mar 26, 2022
6f15baa
Merge branch 'master' into master
mafpovbul Mar 26, 2022
a73a44c
Update DeveloperGuide.md
mafpovbul Mar 26, 2022
122fc40
Merge pull request #11 from mafpovbul/master
mafpovbul Mar 27, 2022
03f2e88
Add files via upload
mafpovbul Mar 27, 2022
d01889c
Update DeveloperGuide.md
mafpovbul Mar 27, 2022
4c85f6b
Delete storage sequence diagram.png
mafpovbul Mar 27, 2022
300b235
Add files via upload
mafpovbul Mar 27, 2022
fd4f689
Update DeveloperGuide.md
mafpovbul Mar 27, 2022
acdd0fb
Update DeveloperGuide.md
mafpovbul Mar 27, 2022
d6f852f
Update DeveloperGuide.md
mafpovbul Mar 27, 2022
9654fc6
Update UserGuide.md
mafpovbul Mar 27, 2022
6aa0c39
Update UserGuide.md
mafpovbul Mar 27, 2022
54f4643
Abstract reservations out from packages
bbawj Mar 27, 2022
bc3456c
Merge pull request #12 from bbawj/master
bbawj Mar 27, 2022
66c0907
Update DeveloperGuide.md
bbawj Mar 27, 2022
e449f68
Add ParserTest
bbawj Mar 27, 2022
87c824f
Merge pull request #13 from bbawj/master
bbawj Mar 27, 2022
20ee0ca
Update to TARBS
bbawj Mar 27, 2022
175cf40
Merge pull request #14 from bbawj/master
bbawj Mar 27, 2022
2b93114
Update DeveloperGuide.md
mafpovbul Mar 27, 2022
b6b12f9
Delete StorageSeqDiag.png
mafpovbul Mar 27, 2022
297d751
Add files via upload
mafpovbul Mar 27, 2022
b371ad8
Delete StorageSeqDiag.png
mafpovbul Mar 27, 2022
c6b416a
Add files via upload
mafpovbul Mar 27, 2022
a75449a
Update to TARBS
bbawj Mar 27, 2022
77b29ee
Merge pull request #15 from bbawj/master
bbawj Mar 27, 2022
1f74e31
Update DeveloperGuide.md
bbawj Mar 27, 2022
9077526
Merge branch 'master' into master
timchang27 Mar 27, 2022
de7169f
Merge pull request #9 from timchang27/master
timchang27 Mar 27, 2022
d123fc4
v2.0
chintaiann Mar 29, 2022
9cd44c1
Merge pull request #16 from chintaiann/master
chintaiann Mar 29, 2022
85419f6
Add exception handling and print reservations
bbawj Mar 30, 2022
42bcaef
Merge pull request #17 from bbawj/master
bbawj Mar 30, 2022
24aea0c
Add override equals for testing
bbawj Mar 31, 2022
f9486b4
Merge pull request #18 from bbawj/master
bbawj Mar 31, 2022
6e0658c
Update DeveloperGuide.md
mafpovbul Mar 31, 2022
86fc569
Add files via upload
mafpovbul Mar 31, 2022
5770959
Update DeveloperGuide.md
mafpovbul Mar 31, 2022
24cd456
v2.0
chintaiann Mar 31, 2022
00eaf19
Merge pull request #19 from chintaiann/master
chintaiann Mar 31, 2022
b8da5d6
Update DeveloperGuide.md
chintaiann Mar 31, 2022
c58d435
Update DeveloperGuide.md
chintaiann Mar 31, 2022
dcabde9
Update storage
mafpovbul Mar 31, 2022
b813516
Merge pull request #20 from mafpovbul/master
mafpovbul Mar 31, 2022
3f89b4e
Update TARBS.java
mafpovbul Mar 31, 2022
8876ca1
Delete SaveFileSeqDiag.png
mafpovbul Mar 31, 2022
da2c5b8
Delete StorageSeqDiag.png
mafpovbul Mar 31, 2022
66050d9
Add files via upload
mafpovbul Mar 31, 2022
bfd3199
Delete SaveFileSeqDiag.png
mafpovbul Mar 31, 2022
cb5c05c
Add files via upload
mafpovbul Mar 31, 2022
8baf8b1
Update DeveloperGuide.md
mafpovbul Mar 31, 2022
15874e3
Add SLAP for parser
bbawj Mar 31, 2022
896c5ea
Merge pull request #21 from bbawj/master
bbawj Mar 31, 2022
8e581cb
Update UserGuide.md
bbawj Mar 31, 2022
00ed778
v2.0 - Edited packages command and added info command
timchang27 Mar 31, 2022
a9c753b
Merge pull request #22 from timchang27/master
timchang27 Mar 31, 2022
340d229
Update DeveloperGuide.md
timchang27 Mar 31, 2022
2c872a5
v2.0 - Edited packages command and added info command
timchang27 Mar 31, 2022
32a3257
Merge pull request #23 from timchang27/master
timchang27 Mar 31, 2022
0020ae1
Exception handling
mafpovbul Apr 1, 2022
708bd52
Merge pull request #24 from mafpovbul/master
mafpovbul Apr 1, 2022
39e9523
Add Date support
bbawj Apr 1, 2022
cb25cf6
Merge pull request #25 from bbawj/master
bbawj Apr 1, 2022
c2dfe9a
Add .jar to gitignore
bbawj Apr 1, 2022
e3b8a37
Exception handling for storage
mafpovbul Apr 1, 2022
37f4bdc
Merge pull request #79 from mafpovbul/master
mafpovbul Apr 1, 2022
5e4da5f
Merge remote-tracking branch 'upstream/master'
bbawj Apr 2, 2022
bab17d8
Update help command, closes #77, closes #73, closes #51
bbawj Apr 2, 2022
6569dea
Merge pull request #80 from bbawj/master
bbawj Apr 2, 2022
eb94f62
Code review closes #26
bbawj Apr 2, 2022
3b1d3d8
Merge pull request #81 from bbawj/master
bbawj Apr 2, 2022
be7cda6
Date exception handling
mafpovbul Apr 2, 2022
40ed8a8
Date exception handling
mafpovbul Apr 2, 2022
608e954
Merge pull request #82 from mafpovbul/master
mafpovbul Apr 2, 2022
a690e3b
Add exception handling and tests, closes #42, closes #69, closes #66
bbawj Apr 2, 2022
7181984
Find package logic, added error messages
mafpovbul Apr 2, 2022
25c7843
Merge pull request #83 from mafpovbul/master
mafpovbul Apr 2, 2022
c0fc452
Fix conflict
bbawj Apr 2, 2022
1aa1306
Merge pull request #84 from bbawj/master
bbawj Apr 2, 2022
728cb32
Error checking when loading storage data
mafpovbul Apr 2, 2022
c3a5171
Merge pull request #85 from mafpovbul/master
mafpovbul Apr 2, 2022
231b364
v2.0 - Removed Unused Command Classes and Deleted Dead Code
timchang27 Apr 2, 2022
74cf9ab
Merge pull request #86 from timchang27/master
timchang27 Apr 2, 2022
4c09fe0
Add storage test code
mafpovbul Apr 2, 2022
f905639
Merge pull request #87 from mafpovbul/master
mafpovbul Apr 2, 2022
733bd63
Add date range test
bbawj Apr 2, 2022
1c40c95
Merge pull request #88 from bbawj/master
bbawj Apr 2, 2022
b6b8dde
small fix
chintaiann Apr 4, 2022
78bfb2e
Merge pull request #89 from chintaiann/master
chintaiann Apr 4, 2022
b60b0ae
Update chintaiann.md
chintaiann Apr 6, 2022
15f00bd
Create justyn.md
mafpovbul Apr 7, 2022
2764c3e
Update justyn.md
mafpovbul Apr 7, 2022
8154180
Add Brendan PPP
bbawj Apr 7, 2022
b1dc964
Merge pull request #90 from bbawj/master
bbawj Apr 7, 2022
a90d94e
Merge pull request #1 from AY2122S2-CS2113-F10-3/master
Apr 7, 2022
ece0522
Fix the same package bug
Apr 7, 2022
9e0ab99
Fix the big integer delete bug
Apr 7, 2022
d7d75b8
Update Project Portfolio Page
timchang27 Apr 7, 2022
ab804e0
Fix exit command documentation bug
Apr 7, 2022
e065dc5
Update user guide and help documentation
Apr 7, 2022
44cce7b
Fix documentation issue
Apr 7, 2022
0a820ca
Update documentation
Apr 7, 2022
142421e
Resolve Issue
timchang27 Apr 7, 2022
10fac69
Merge pull request #91 from timchang27/master
timchang27 Apr 7, 2022
2b954f0
Improved Help and HelpCommand, Corrected Add Instructions
timchang27 Apr 7, 2022
0a94da3
Format Data
timchang27 Apr 7, 2022
724c9cb
Merge pull request #92 from timchang27/master
timchang27 Apr 7, 2022
885c839
Update UserGuide.md
timchang27 Apr 7, 2022
6f3ee1a
Added PPP
timchang27 Apr 7, 2022
17b7f09
Update UserGuide.md
timchang27 Apr 7, 2022
141351b
Merge branch 'master' into master
Apr 8, 2022
5424332
Merge pull request #93 from edemirkirkan/master
Apr 8, 2022
ba84d08
Rename brendan PPP
bbawj Apr 9, 2022
0d5af47
Update justyn.md
mafpovbul Apr 9, 2022
ecd630f
Merge pull request #94 from bbawj/master
bbawj Apr 9, 2022
55e6f2a
Rename justyn.md to mafpovbul.md
mafpovbul Apr 9, 2022
ca39a96
Merge branch 'master' of https://github.com/AY2122S2-CS2113-F10-3/tp
timchang27 Apr 9, 2022
0002a5e
Rename timothy.md to timchang27.md
timchang27 Apr 9, 2022
82791e8
Merge pull request #95 from timchang27/master
timchang27 Apr 9, 2022
57de34d
Added Hotel and Country Class
timchang27 Apr 9, 2022
c04d893
Merge pull request #96 from timchang27/master
timchang27 Apr 9, 2022
ea1ce11
Update timchang27.md
timchang27 Apr 9, 2022
76eb910
Update DeveloperGuide.md
chintaiann Apr 10, 2022
4f0cdcf
Add and View Hotels Command
timchang27 Apr 10, 2022
e46e412
Merge pull request #97 from timchang27/master
timchang27 Apr 10, 2022
98f99e4
Update User Guide
chintaiann Apr 10, 2022
0445a59
Update DeveloperGuide.md
timchang27 Apr 10, 2022
af9f247
Update README.md
chintaiann Apr 10, 2022
67dabef
Update README.md
chintaiann Apr 10, 2022
effd44e
Update README.md
chintaiann Apr 10, 2022
b01ae46
Update Help Command with Hotel related commands
timchang27 Apr 10, 2022
46027b4
Merge pull request #98 from timchang27/master
timchang27 Apr 10, 2022
c9678ea
Update DeveloperGuide.md
chintaiann Apr 10, 2022
c52e37a
implement sort and print package function
chintaiann Apr 10, 2022
e181cf4
Merge branch 'master' of https://github.com/chintaiann/tp
chintaiann Apr 10, 2022
c6477c3
Merge branch 'master' into master
chintaiann Apr 10, 2022
378da6f
Merge pull request #1 from AY2122S2-CS2113-F10-3/master
chintaiann Apr 10, 2022
09fbaac
Merge pull request #99 from chintaiann/master
chintaiann Apr 10, 2022
2c01e2c
Update DeveloperGuide.md
chintaiann Apr 11, 2022
5c5b2ac
Update DeveloperGuide.md
chintaiann Apr 11, 2022
54c8511
Update DeveloperGuide.md
chintaiann Apr 11, 2022
d3c4822
Merge branch 'AY2122S2-CS2113-F10-3:master' into master
chintaiann Apr 11, 2022
25ce741
Update UserGuide.md
chintaiann Apr 11, 2022
9174973
Update data.txt
chintaiann Apr 11, 2022
580c48d
Merge branch 'AY2122S2-CS2113-F10-3:master' into master
chintaiann Apr 11, 2022
da9996a
Merge pull request #100 from chintaiann/master
chintaiann Apr 11, 2022
69994cc
Update chintaiann.md
chintaiann Apr 11, 2022
c87982b
Update AboutUs.md
chintaiann Apr 11, 2022
4835e4c
Update AboutUs.md
timchang27 Apr 11, 2022
7cd5b49
Update AboutUs.md
mafpovbul Apr 11, 2022
a961318
Update AboutUs.md
mafpovbul Apr 11, 2022
dcb082f
Fixed AddHotelCommand
timchang27 Apr 11, 2022
22ab575
Fixed AddHotelCommand
timchang27 Apr 11, 2022
fe73ca9
Merge pull request #101 from timchang27/master
timchang27 Apr 11, 2022
faeab7e
Add portfolio to AboutUs.md
Apr 11, 2022
b0feb67
Merge remote-tracking branch 'origin/master'
Apr 11, 2022
cc1434c
Merge branch 'master' into master
Apr 11, 2022
fb358a7
Update AboutUs.md
Apr 11, 2022
d0a073b
Update AboutUs.md
Apr 11, 2022
231098d
Fixed AddHotelCommand
timchang27 Apr 11, 2022
200d75a
Merge pull request #103 from timchang27/master
timchang27 Apr 11, 2022
db95f13
Update timchang27.md
timchang27 Apr 11, 2022
c6d88d7
Merge branch 'master' into master
Apr 13, 2022
bd890aa
Merge pull request #102 from edemirkirkan/master
Apr 13, 2022
28e8c64
Merge pull request #2 from AY2122S2-CS2113-F10-3/master
Apr 13, 2022
8d02948
Review bug issues
Apr 19, 2022
f5d4f48
Merge pull request #104 from edemirkirkan/master
Apr 19, 2022
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
2 changes: 2 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -15,3 +15,5 @@ bin/

/text-ui-test/ACTUAL.txt
text-ui-test/EXPECTED-UNIX.TXT

.vscode/
1 change: 1 addition & 0 deletions build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -43,4 +43,5 @@ checkstyle {

run{
standardInput = System.in
enableAssertions = true
}
14 changes: 7 additions & 7 deletions docs/AboutUs.md
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
# About us

Display | Name | Github Profile | Portfolio
--------|:----:|:--------------:|:---------:
![](https://via.placeholder.com/100.png?text=Photo) | John Doe | [Github](https://github.com/) | [Portfolio](docs/team/johndoe.md)
![](https://via.placeholder.com/100.png?text=Photo) | Don Joe | [Github](https://github.com/) | [Portfolio](docs/team/johndoe.md)
![](https://via.placeholder.com/100.png?text=Photo) | Ron John | [Github](https://github.com/) | [Portfolio](docs/team/johndoe.md)
![](https://via.placeholder.com/100.png?text=Photo) | John Roe | [Github](https://github.com/) | [Portfolio](docs/team/johndoe.md)
![](https://via.placeholder.com/100.png?text=Photo) | Don Roe | [Github](https://github.com/) | [Portfolio](docs/team/johndoe.md)
| Display | Name | Github Profile | Portfolio |
| --------------------------------------------------- |:---------------:|:-----------------------------------------:| :-------------------------------: |
| ![](https://via.placeholder.com/100.png?text=Photo) | Ege Demirkirkan | [Github](https://github.com/edemirkirkan) | [Portfolio](docs/team/johndoe.md) |
| ![](https://via.placeholder.com/100.png?text=Photo) | Don Joe | [Github](https://github.com/) | [Portfolio](docs/team/johndoe.md) |
| ![](https://via.placeholder.com/100.png?text=Photo) | Timothy Chang | [Github](https://github.com/timchang27) | [Portfolio](docs/team/timothy.md) |
| ![](https://via.placeholder.com/100.png?text=Photo) | Brendan Ang | [Github](https://github.com/bbawj) | [Portfolio](docs/team/brendan.md) |
| ![](https://via.placeholder.com/100.png?text=Photo) | Chin Tai Ann | [Github](https://github.com/chintaiann) | [Portfolio](docs/team/chintaiann.md) |
75 changes: 70 additions & 5 deletions docs/DeveloperGuide.md
Original file line number Diff line number Diff line change
Expand Up @@ -7,32 +7,97 @@
## Design & implementation

{Describe the design and implementation of the product. Use UML diagrams and short code snippets where applicable.}
### Basic Class Diagram
![image](https://user-images.githubusercontent.com/53790951/160271319-4a351f51-afd7-4e04-9451-f04143146551.png)

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think more descriptive roles can be used to describe these relationships, since things like uses or instantiates can already be implied by the arrows? Also, if instantiates implies an association, consider using a solid line for it instead.

image

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Even if the class methods and fields are not represented, there should be another line separating the contents of the class.

Screenshot 2022-03-31 at 11 39 38 AM

Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Remember to use standard UML syntaxes taught in the module. Some of the notations are not compliant with the notation covered in the module.
Consider adding multiplicity to and other detailed information to the diagram to help understanding.



## Product scope
### Target user profile

{Describe the target user profile}
- Studies in a non-IT field
- Usually works alone
- Working in a small travel agency that offers affordable budget travel packages to only some countries
- Handles many customers a day
- Is unfamiliar with using CLI apps

### Value proposition

{Describe the value proposition: what problem does it solve?}
- Travel agencies often have to manage multiple customers and their respective bookings or plans.
- For employees of the travel agencies to track and record customers’ booking of travel packages.


## User Stories

|Version| As a ... | I want to ... | So that I can ...|
|--------|----------|---------------|------------------|
|v1.0|new user|see usage instructions|refer to them when I forget how to use the application|
|v2.0|user|find a to-do item by name|locate a to-do without having to go through the entire list|
|v1.0|new user|Add reservation for a customer with basic information such as name, country etc. |Make a reservation|
|v1.0|new user|Print a list of all current and available travel packages |View all current travel packages and tell customers about our travel packages with one look|
|v1.0|new user|Remove an existing reservation|Remove information that we do not need anymore|
|v1.0|User ready to start using the app| Find out which travel packages are available for the specific location and duration|Make a recommendation of travel package to customers based on their desired location|
|v1.0|new user|Search for a specific travel package|Make recommendations to a customer based on their desired travel package requirements|
|v2.0|User ready to start using the app|Upload existing reservation data|Get started quickly|
|v2.0|User ready to start using the app|Make reservations based on custom input and edit them where necessary|Get familiar with inputting|
|v2.0|User ready to start using the app|See the changes I made from the previous day|Continue working|
|v2.1|Expert user|Create and use shortcuts|Quickly enter the details needed for a reservation and query any details I might need for an existing reservation|
|v2.1|Expert user|Update ratings of travel packages based on customer feedback|Provide a better recommendations for future customers|
|v2.1|Expert user|Ascertain the error in my input based on the error messages from the application|Quickly troubleshoot any mistakes that would slow down my work|
|v2.1|Expert user|View all reservations currently under a specific travel package|Optimize that travel package according to user’s feedback|
|v2.1|Expert user|I can build a customized travel package based on what the customer wants|It appeals to customers who do not want our existing tour packages|
|v2.1|Expert user|Add in hotels to the list of available hotel options|Update the itinerary |
|v2.1|Expert user|Add in countries to the list of available countries|Update the itinerary|
|v2.1|Expert user|Sort all reservations according to month|Analyze trends throughout the year|
|v2.1|Expert user|Mark a reservation as ‘completed’|Access both completed and ongoing reservations|
|v2.1|Expert user|Compute the price of custom travel packages|Get a rough estimate for what to charge the customer|

## Non-Functional Requirements

{Give non-functional requirements}
### Performance Requirements
- Should work on any mainstream OS as long as it has Java 11 or above installed.

### Usability
- A user with above average typing speed for regular English text (i.e. not code, not system admin commands) should be able to accomplish most of the tasks faster using commands than using the mouse.
- Prompts and instructions must be in proper and concise sentences for ease of understanding.

## Glossary

* *glossary item* - Definition
* Packages - Travel Package within the agency's database
* Reservations - Reservation of travel package made by one customer through the app

## Instructions for manual testing

{Give instructions on how to do a manual product testing e.g., how to load sample data to be used for testing}

### Summary of User Commands

| Command | Format Examples |
| ------- | --------------- |
|packages|packages|
|info|info {num} (num < number of available packages) <br/> e.g. info 2 |
|add|add {package_name} {country} {duration} {price} {vacancies} <br/> e.g. add Skiing_Trip Sweden 15/2/2022-19/2/2022 800 100|
|delete|delete {num} (num < number of available packages) <br/> e.g. delete 2|
|reserve|reserve {package_number} {contact_name} {contact_number} {number_pax} <br/> e..g reserve 3 John 91234567 3 |
|remove|remove {reservation_id} <br/> e..g remove R001|
|reservations|reservations {package_number} <br/> eg. reservations 2|

## Feature - Help Command
Aim: Displays a list of all available commands that the user can refer to as a guide

## Feature - Storage
#### Initialisation (Loading Data)
The sequence diagram that shows how `Storage` is created and the data is loaded from the saved files when the program is initialised is shown below: </br>

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Perhaps you mean

Suggested change
The sequence diagram that shows how `Storage` is created and the data is loaded from the saved files when the program is initialised is shown below: </br>
The sequence diagram that shows how `Storage` is created and the data is loaded from the saved files when the program is initialised is shown below: <br>

![](StorageSeqDiag.png)

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Perhaps can add an activation bar when you call the constructor of Storage?
image

Copy link

@thedarie thedarie Mar 31, 2022

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

image
Should this line be a solid line since dotted lines are used for return values? Also, there should be an activation bar to represent the constructor and the entity storage is missing a colon

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

image
Since parseReservationFile() and parseTravelPackagesFile() are self-invocations, maybe adding 'overlapping' activation bars would be good

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Perhaps can add colons for the class entity?

Copy link

@aiman-imtiaz aiman-imtiaz Mar 31, 2022

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The self-invocation calls should probably show small activation bars of their own, and should have return lines if something is being returned from the method calls.

Screenshot 2022-03-31 at 11 22 16 AM

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

  • Since this is an instance of the Storage class, it should be written as :Storage
  • There should be a constructor shown that would instantiate an object of the Storage class
  • The call to the constructor should have a return line that would return the object
  • The call to the constructor should be represented by a solid line

Screenshot 2022-03-31 at 11 27 46 AM


1. `TARBS` creates a Storage object with the relevant file names.
2. `TARBS` then calls the `createPackages()` method of the Storage class
3. `storage` will then load the contents of the file in the `Reservation` and `TravelPackages` file calling the different `parse` methods. The exact implementation is not shown in the diagram.
4. A new `Package` object is constructed with the relevant data.
5. `storage` returns `package` object to `TARBS`.

## Feature - Parser
The sequence diagram shows an example of how a user input is parsed and returns a new `Command`.

For simplicity, `ByeCommand` is shown here:

![image](https://user-images.githubusercontent.com/53790951/160289728-5a17b2ea-0599-48f4-a18b-cadfbbcbfb11.png)

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Perhaps can add an activation bar when you call the constructor of ByeCommand?
image

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is it better to include User in the left most of the sequence diagram?
image

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

image
Similar to the storage diagram, maybe the highlighted line should be a solid line

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Should this vertical bar extending below the boundary of the alt box be there?

Also, I think this diagram would be clearer if it came with a step-by-step explanation.

image

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

There should be a constructor activation bar here that should also return the instantiated object.

Screenshot 2022-03-31 at 11 42 04 AM

Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

  1. Consider moving the condition for the [alt] path to beside the icon, instead of on the first method call.
  2. Consider adding crosses to indicate EoL if applicable
  3. The classes are lacking a colon
  4. Is there any code after return ByeCommand? If not consider ending both activation bars on the return arrow.


Binary file added docs/StorageSeqDiag.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
13 changes: 11 additions & 2 deletions docs/UserGuide.md
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,15 @@ Example of usage:

## Command Summary

{Give a 'cheat sheet' of commands here}
| Command | Syntax |
| --- | :--- |
| packages | packages |
| info | info {num} |
| add | add {package_name} {country} {duration} {price} {vacancies} |
| delete | delete {num} |
| reserve | reserve {package_number} {contact_name} {contact_number} {number_pax} |
| remove | remove {reservation_id} |
| reservations | reservations {package_number} |



* Add todo `todo n/TODO_NAME d/DEADLINE`
1 change: 1 addition & 0 deletions docs/_config.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
theme: jekyll-theme-minimal
Empty file added docs/team/brendan.md
Empty file.
6 changes: 6 additions & 0 deletions docs/team/chintaiann.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
# Tai Ann - Project Portfolio Page

## Overview


### Summary of Contributions
Empty file added docs/team/ege.md
Empty file.
1 change: 1 addition & 0 deletions packages.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
mugg | 2 | 1 | mariott | 50.0 | korea | 30 | 0
1 change: 1 addition & 0 deletions reservations.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
1 | 123 | bawj | 98765432 | 2
23 changes: 23 additions & 0 deletions src/main/java/seedu/duke/Customer.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
package seedu.duke;

public class Customer {
private String customerID;
private String name;
private String contactNumber;

public Customer(String customerID, String name, String contactNumber){
this.customerID = customerID;
this.name = name;
this.contactNumber = contactNumber;
}

public String getCustomerID() {
return customerID;
}
public String getName() {
return name;
}
public String getContactNumber() {
return contactNumber;
}
}
21 changes: 0 additions & 21 deletions src/main/java/seedu/duke/Duke.java

This file was deleted.

31 changes: 31 additions & 0 deletions src/main/java/seedu/duke/Help.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
package seedu.duke;
import java.util.ArrayList;

public class Help {
private ArrayList<String[]> desc;

public Help(){
this.desc = new ArrayList<>();
String[] packages = {"View all available packages", "packages"};
desc.add(packages);
String[] info = {"View package details", "info {num}"};
desc.add(info);
String[] add = {"Add a new package", "add {package_name} {country} {duration} {price} {vacancies}"};
desc.add(add);
String[] delete = {"Delete a package", "delete {num}"};
desc.add(delete);
String[] reserve = {"Create a reservation for a package", "reserve {package_number},{contact_name},{contact_number},{number_pax}"};
desc.add(reserve);
String[] remove = {"Remove a reservation","remove {travelpackageID},{contact_number}"};
desc.add(remove);
String[] reservations = {"Shows all reservations for a package", "reservations {package_number}"};
desc.add(reservations);
}

public void printHelp(){
for (String[] strings : desc) {
String foo = String.format("%-50s %s", strings[0], strings[1]);
System.out.println(foo);
}
}
}
54 changes: 54 additions & 0 deletions src/main/java/seedu/duke/Packages.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,54 @@
package seedu.duke;

import java.util.ArrayList;
//Packages include arrayList packages to hold all TravelPackages

public class Packages {
private ArrayList<TravelPackage> packages;

public Packages() {
this.packages = new ArrayList<>();
}

public Packages(ArrayList<TravelPackage> t) {
this.packages = t;
}

public int getSize() {
return packages.size();
}

public TravelPackage getPackage(int index) {
return packages.get(index);
}

public TravelPackage getPackageByID(int id) {
for (TravelPackage travelPackage : packages) {
if (travelPackage.getID() == id) {
return travelPackage;
}
}
return null;
}

public void addPackage(TravelPackage newPackage) {
packages.add(newPackage);
}

public void removePackage(int index) {
packages.remove(index);
}

// check if packageID already exists. return true if already exists - unique IDs
// only!
public boolean idExists(int id) {
for (int i = 0; i < packages.size(); i++) {
if (packages.get(i).getID() == id) {
return true;
}
}

return false;
}

}
80 changes: 80 additions & 0 deletions src/main/java/seedu/duke/Parser.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,80 @@
package seedu.duke;

import seedu.duke.command.*;

public class Parser {
public static Command parse(String input) {
String[] inputArray = input.split(" ");
String commandType = inputArray[0];
System.out.println(commandType);
int id;
String start;
String end;
int vacancies;
double price;
String name;
String hotel;
String country;

switch (commandType) {
case "bye":
return new ByeCommand();
case "help":
return new HelpCommand();
case "add":
String[] temp = input.split(" ", 2); // remove add from string
String[] temp1 = temp[1].split(","); // process the rest and split by comma

System.out.println(temp.length);
if (temp1.length != 8) {
return new WrongFormatCommand(input);
} else {
final int nameIndex = 0;
final int idIndex = 1;
final int startIndex = 2;
final int endIndex = 3;
final int hotelIndex = 4;
final int priceIndex = 5;
final int countryIndex = 6;
final int vacanciesIndex = 7;
name = temp1[nameIndex];
id = Integer.parseInt(temp1[idIndex]);
start = temp1[startIndex];
end = temp1[endIndex];
hotel = temp1[hotelIndex];
price = Double.parseDouble(temp1[priceIndex]);
country = temp1[countryIndex];
vacancies = Integer.parseInt(temp1[vacanciesIndex]);
return new AddCommand(name, id, start, end, hotel, price, country, vacancies);
}
case "delete": // delete TravelPackage by its ID
id = Integer.parseInt(inputArray[1]);
return new DeleteCommand(id);
case "packages":
return new PackagesCommand();
case "reserve":
temp = input.split(" ", 2); // remove reserve from string
temp1 = temp[1].split(","); // process the rest and split by comma
int packageID = Integer.parseInt(temp1[0]);
name = temp1[1];
String number = temp1[2];
int pax = Integer.parseInt(temp1[3]);

return new ReservationCommand(packageID, name, number, pax);

case "remove": // delete reservation by giving travelpackage ID and contact number.
temp = input.split(" ", 2);
temp1 = temp[1].split(",");
packageID = Integer.parseInt(temp1[0]);
number = temp1[1];
return new RemoveReservationCommand(packageID, number);

case "reservations":
id = Integer.parseInt(inputArray[1]);
return new PrintReservationsCommand(id);

default:
return new ErrorCommand(input);
}
}
}
Loading