By: Team W13-1
Since: Sep 2018
Licence: MIT
- 1. Introduction
- 2. Quick Start
- 3. Features
- 3.1. Viewing help :
help
- 3.2. Adding a person:
add
- 3.3. Listing all persons :
list
- 3.4. Editing a person :
edit
- 3.5. Locating persons by name:
find
- 3.6. Deleting a person :
delete
- 3.7. Selecting a person :
select
- 3.8. Listing entered commands :
history
- 3.9. Undoing previous command :
undo
- 3.10. Redoing the previously undone command :
redo
- 3.11. Clearing all entries :
clear
- 3.12. Exiting the program :
exit
- 3.13. Mass import contacts:
import
- 3.14. Export contact list:
export
- 3.15. Add meeting time:
schedule
- 3.16. View meeting timings:
meetings
- 3.17. Notifications for expiring plans
[coming in v2.0]
- 3.18. Adding a picture to contact:
pic
- 3.19. Using tags:
tag
- 3.20. Saving the data
- 3.21. Encrypting data files
[coming in v2.0]
- 3.22. Adding a picture from URL to contact
[coming in v2.0]
- 3.1. Viewing help :
- 4. FAQ
- 5. Command Summary
InsuRen is for insurance salesmen who prefer to use a desktop app for managing contacts. It can help to manage one’s network of clients in an organized, efficient and intuitive manner. More importantly, InsuRen is optimized for those who prefer to work with a Command Line Interface (CLI) while still having the benefits of a Graphical User Interface (GUI). If you can type fast, InsuRen can get your contact management tasks done faster than traditional GUI apps. Interested? Jump to the Section 2, “Quick Start” to get started. Enjoy!
-
Ensure you have Java version
9
or later installed in your Computer. -
Download the latest
insuren.jar
here. -
Copy the file to the folder you want to use as the home folder for InsuRen.
-
Double-click the file to start the app. The GUI should appear in a few seconds.
-
Type the command in the command box and press Enter to execute it.
e.g. typinghelp
and pressing Enter will open the help window. -
Some example commands you can try:
-
list
: lists all contacts -
add
n/John Doe p/98765432 e/[email protected] a/John street, block 123, #01-01
: adds a contact namedJohn Doe
to the InsuRen. -
delete
3
: deletes the 3rd contact shown in the current list -
exit
: exits the app
-
-
Refer to Section 3, “Features” for details of each command.
Command Format
-
Words in
UPPER_CASE
are the parameters to be supplied by the user e.g. inadd n/NAME
,NAME
is a parameter which can be used asadd n/John Doe
. -
Items in square brackets are optional e.g
n/NAME [t/TAG]
can be used asn/John Doe t/friend
or asn/John Doe
. -
Items with
…
after them can be used multiple times including zero times e.g.[t/TAG]…
can be used ast/friend
,t/friend t/family
etc. -
Parameters can be in any order e.g. if the command specifies
n/NAME p/PHONE_NUMBER
,p/PHONE_NUMBER n/NAME
is also acceptable. -
All commands have a shorthand version for easy access. Simply replace the command word with the shorthand. All other syntax is identical.
Adds a person to InsuRen.
Format: add n/NAME [p/PHONE_NUMBER] [e/EMAIL] [a/ADDRESS] [t/TAG]…
ℹ️
|
We recommend against (but do not forbid) using edit or delete (case-insensitive) as tags, as you may run into complications when using the tag edit and tag delete functionality.
|
Shorthand: a
💡
|
Only the Name field is compulsory, all other fields need not be included. A person can have one name, phone, email and address, and any number of tags (including 0) |
Examples:
-
add n/John Doe p/98765432 e/[email protected] a/John street block 123 #01-01
Adds aPerson
with name John Doe, phone number 98765432, email [email protected], and address John street block 123 #01-01, to InsuRen, provided that he does not already exist in InsuRen. -
a n/Betsy Crowe t/friend e/[email protected] a/Newgate Prison p/1234567 t/criminal
Adds aPerson
with name Betsy Crowe, phone number 1234567, email [email protected], address Newgate Prison, and tags friend and criminal to InsuRen, provided that she does not already exist in InsuRen. -
add n/Abigail
Adds aPerson
with name Abigail to InsuRen.
Edits an existing person in InsuRen by the displayed list’s index or by an existing name.
Format: edit INDEX/EXISTING_NAME [n/NAME] [p/PHONE] [e/EMAIL] [a/ADDRESS] [t/TAG]…
ℹ️
|
We recommend against (but do not forbid) using edit or delete (case-insensitive) as tags, as you may run into complications when using the tag edit and tag delete functionality.
|
Shorthand: e
-
You can edit a person by index or by name.
-
For editing the person at the specified
INDEX
, the index refers to the index number shown in the displayed person list.-
The index must be a positive integer 1, 2, 3, …
-
-
For editing the person with a name matching the EXISTING_NAME, the name must uniquely identify a person.
-
If nobody matches the EXISTING_NAME, or there are multiple contacts matching it, InsuRen will notify you and not carry out changes.
-
You can be less specific or more specific in the existing name to identify a person, but in the case that two people have exactly the same name, you have to use the edit by index command.
-
-
-
At least one of the optional fields must be provided.
-
Existing values will be updated to the input values.
-
When editing tags, the existing tags of the person will be removed i.e adding of tags is not cumulative.
-
You can remove all the person’s tags by typing
t/
without specifying any tags after it.
Examples:
-
edit 1 p/91234567 e/[email protected]
Edits the phone number and email address of the 1st person to be91234567
and[email protected]
respectively. -
e 2 n/Betsy Crower t/
Edits the name of the 2nd person to beBetsy Crower
and clears all existing tags. -
edit John Doe p/91234567 e/[email protected]
Edits the phone number and email address of John Doe to be 91234567 and [email protected] respectively, if John Doe can be uniquely identified by name in InsuRen. -
e Johnny n/Betsy Crower
Edits the name of Johnny to beBetsy Crower
if Johnny can be uniquely identified by name in InsuRen.
Finds persons whose names contain any of the given keywords.
Format: find KEYWORD [MORE_KEYWORDS]
Shorthand: f
-
The search is case insensitive. e.g
hans
will matchHans
-
The order of the keywords does not matter. e.g.
Hans Bo
will matchBo Hans
-
Only the name is searched.
-
Only full words will be matched e.g.
Han
will not matchHans
-
Persons matching at least one keyword will be returned (i.e.
OR
search). e.g.Hans Bo
will returnHans Gruber
,Bo Yang
Examples:
-
find John
Returnsjohn
andJohn Doe
-
find Betsy Tim John
Returns any person having namesBetsy
,Tim
, orJohn
Deletes the specified person from InsuRen by the displayed list’s index or by an existing name.
Format: delete INDEX/EXISTING_NAME
Shorthand: d
-
Deletes the person by index or by name.
-
For deleting by
INDEX
,-
The index refers to the index number shown in the displayed person list.
-
The index must be a positive integer 1, 2, 3, …
-
-
For deleting by
EXISTING_NAME
,-
The name must uniquely identify a person.
-
If nobody matches the EXISTING_NAME, or there are multiple contacts matching it, InsuRen will notify you and not carry out changes.
-
You can be less specific or more specific in the existing name to identify a person, but in the case that two people have exactly the same name, you have to delete by
INDEX
.
-
-
Examples:
-
list
delete 2
Deletes the 2nd person in InsuRen. -
find Betsy
d 1
Deletes the 1st person in the results of thefind
command. -
delete John
Deletes John if John can be uniquely identified by name in InsuRen. -
d Abel Lee
Deletes Abel Lee if Abel Lee can be uniquely identified by name in InsuRen.
Selects the person identified by the index number used in the displayed person list.
Format: select INDEX
Shorthand: s
-
Selects the person and loads the Google search page the person at the specified
INDEX
. -
The index refers to the index number shown in the displayed person list.
-
The index must be a positive integer
1, 2, 3, …
Examples:
-
list
select 2
Selects the 2nd person in InsuRen. -
find Betsy
select 1
Selects the 1st person in the results of thefind
command.
Lists all the commands that you have entered in reverse chronological order.
Format: history
Shorthand: hs
ℹ️
|
Pressing the ↑ and ↓ arrows will display the previous and next input respectively in the command box. |
Restores InsuRen to the state before the previous undoable command was executed.
Format: undo
Shorthand: u
ℹ️
|
Undoable commands: those commands that modify InsuRen’s content ( |
Examples:
-
delete 1
list
undo
(reverses thedelete 1
command) -
select 1
list
undo
Theundo
command fails as there are no undoable commands executed previously. -
delete 1
clear
undo
(reverses theclear
command)
undo
(reverses thedelete 1
command)
Reverses the most recent undo
command.
Format: redo
Shorthand: r
Examples:
-
delete 1
undo
(reverses thedelete 1
command)
redo
(reapplies thedelete 1
command) -
delete 1
redo
Theredo
command fails as there are noundo
commands executed previously. -
delete 1
clear
undo
(reverses theclear
command)
undo
(reverses thedelete 1
command)
redo
(reapplies thedelete 1
command)
redo
(reapplies theclear
command)
Import contacts from a csv file.
If no file path is given, a file browser will open for users to navigate to their desired file (.txt and .csv only)
If a file path is given, InsuRen will attempt to obtain and read the file specified by the given file path.
Format: import
Shorthand: i
-
InsuRen will fetch the file from the given path.
-
InsuRen will throw an error message if the file cannot be found from the given (typed) file path
-
InsuRen will NOT throw an error message if the formatting of the file is incorrect.
-
Improperly formatted contacts and/or duplicate contacts will be ignored.
Example (user does not provide a file path):
Example (user provides a file path):
-
FOR WINDOWS:
-
import l/D:/AddressbookCorrect.csv
(absolute pathing) or -
import l/AddressbookCorrect.csv
(relative pathing - if you save the .csv file in the same directory as the .jar file).
-
-
FOR MAC:
-
import l//FILEPATH
(absolute pathing - note the double slashes) or -
import l/AddressbookCorrect.csv
(relative pathing).
-
-
Regardless which method is used, InsuRen will load contacts from the given csv file.
-
Each contact’s Name, Phone, Email, Address, Meeting and Tag(s) fields must be keyed in the csv in that order.
-
All fields are optional, except for Name. Contacts with no Address, Phone etc. must have those fields left BLANK. Ie. the corresponding Excel cell MUST have nothing in it.
-
Any invalid entries (contacts with no name) will be ignored.
-
Examples of properly formatted csv files are shown below. (Can be both csv or txt)
Exports the current contact list into a csv file whose name is given as the second argument. The export file
can be found in the root directory of the project/application.
Format: export DESTINATION_FILE_NAME.csv
Shorthand: x
-
InsuRen will copy all contacts and format them into a csv file, with each row representing a unique contact.
-
InsuRen will throw an error message if given file name is invalid (has no .csv suffix).
Example:
Add a meeting at the input date and time with a specified person.
Format: schedule INDEX m/DD/MM/YY HHMM
Shorthand: sch
-
InsuRen will add the meeting to your list of meetings, as well as mark the person with the meeting.
-
You may use any special characters such as '/' and '-', or whitespace to seperate the entries. As long as the relative order of the numbers is DDMMYYHHMM, InsuRen will save it.
-
Meetings can be scheduled on any valid date in the past (to keep a record) or in the future (as a reminder).
-
If the date is invalid (i.e. it is not a real date), an error will be thrown.
-
If there are any meetings scheduled at the same time, it will be flagged out.
Example:
-
schedule 1 m/12/03/19 0930
InsuRen will record that a meeting is scheduled on 12 March 2019, 0930 with the first entry.
Displays the details of the meeting at the input date and time.
Format: meetings [DD/MM/YY]
shorthand: m
-
If there are meetings scheduled on the queried date, the details of the clients the meetings are scheduled with are displayed.
-
If the query has no date, then all meetings scheduled in InsuRen are displayed.
-
If there is no meeting scheduled on the day, an empty list is displayed.
Example:
-
meetings 23/02/18
InsuRen displays meetings scheduled on 23rd February, 2018.
InsuRen entries have an optional field for date of plan expiry. You will automatically be notified of clients
with plans expiring within a month from the day when InsuRen is initialized.
No additional search queries are needed.
Adds a picture to a person in InsuRen.
Format: pic INDEX l/FILE_LOCATION
Shorthand: p
-
InsuRen will add the image to the contact.
-
Only
.jpg
and.png
files are accepted. -
Supports file location for any mainstream OS.
-
Windows:
C:/Users/John/Downloads/InsuRen/images/petertan.jpg
-
Mac:
/Users/John/Downloads/Insuren/images/petertan.jpg
-
-
File location can be an absolute path (
/Users/John/Downloads/InsuRen/images/petertan.jpg
), or a relative path (images/petertan.jpg
). -
If the picture gets deleted or renamed, InsuRen will show the default user picture.
Examples:
-
pic 2 l/john.jpg
The second person in the list will now have imagejohn.jpg
in his contact. -
pic 1 l//Users/John/Downloads/InsuRen/images/petertan.jpg
The first person in the list will now have imagepetertan.jpg
from the given path in his contact. -
p 3 l/C:/Users/John/Downloads/InsuRen/images/davidlee.png
The third person in the list will now have imagedavidlee.png
from the given path in his contact.
View all contacts in any existing tag.
Format: tag TAG_NAME [MORE_TAG_NAMES]
Shorthand: t
-
View all contacts that belong to the same tag.
Example:
-
tag Work
Returns all contacts with theWork
tag. -
tag Work Important
Returns all contacts with theWork
orImportant
tags.
Edit a tag, replacing all its occurrences with a new user-specified tag.
Format: tag edit EXISTING_TAG_NAME NEW_TAG_NAME
ℹ️
|
We recommend against (but do not forbid) using edit or delete (case-insensitive) as tags, as you may run into complications when using the tag edit and tag delete functionality.
|
-
All contacts tagged with
EXISTING_TAG_NAME
will have the tag replaced byNEW_TAG_NAME
.
Example:
-
tag edit Work Business
All contacts that had theWork
tag have the tag changed toBusiness
. -
t EDIT Friends Buddies
Usage of "edit" is not case-sensitive.
Delete a tag, removing it from all contacts.
Format: tag TAG_NAME [MORE_TAG_NAMES…] delete
-
All contacts in
TAG_NAME
will be removed from the tag. Contacts that were previously tagged are not deleted.
Example:
-
tag Work delete
All contacts that were previously tagged withWork
have theWork
tag removed.Work
tag is deleted. -
t Work Important delete
All contacts that were previously tagged withWork
andImportant
have the aforementioned tags removed.Work
andImportant
tags are deleted.
InsuRen data are saved in the hard disk automatically after any command that changes the data.
There is no need to save manually.
Encrypt all data in InsuRen behind a password.
Format: encrypt PASSWORD
-
The next time a user opens InsuRen, he will have to enter a password before the contact list populates.
Example:
-
encrypt Pa$$w0rd
All data will be encrypted. The next time the user opens InsuRen, InsuRen will prompt her for a password.
Adds a picture from a URL to a person in InsuRen.
Format: pic INDEX l/FILE_URL
Shorthand: p
-
InsuRen will add the image to the contact.
-
If the URL is broken after it is successfully added, InsuRen will show a picture indicating that the URL is broken.
Examples:
-
pic 1 l/https://cs2103-ay1819s1-w13-1.github.io/main/images/denzelchung.png
The first person in the list will now have imagedenzelchung.png
from theGithub
webpage in his contact.
Q: How do I transfer my data to another Computer?
A: Install the app in the other computer and overwrite the empty data file it creates with the file that contains the data of your previous InsuRen folder.
Alternatively, use the export command to get your current contact list and save it in portable storage (email, thumbdrive). Install InsuRen on the other computer and import the abovementioned csv file into your new computer’s copy of InsuRen.
-
Add
add n/NAME p/PHONE_NUMBER e/EMAIL a/ADDRESS [t/TAG]…
e.g.add n/James Ho p/22224444 e/[email protected] a/123, Clementi Rd, 1234665 t/friend t/colleague
-
Clear :
clear
-
Delete :
delete INDEX/EXISTING_NAME
e.g.delete 3
ordelete John Doe Kah Wai
-
Edit :
edit INDEX/EXISTING_NAME [n/NAME] [p/PHONE_NUMBER] [e/EMAIL] [a/ADDRESS] [t/TAG]…
e.g.edit 2 n/James Lee e/[email protected]
oredit John Doe n/John Chan a/525 East 80th Street, New York
-
Find :
find KEYWORD [MORE_KEYWORDS]
e.g.find James Jake
-
List :
list
-
Help :
help
-
Select :
select INDEX
e.g.select 2
-
History :
history
-
Undo :
undo
-
Redo :
redo
-
Import contacts :
import
orimport l/FILE_PATH
-
Export contacts :
export DESTINATION_DIRECTORY
-
Schedule :
schedule INDEX m/DD/MM/YY HHMM
-
Meetings :
meetings [DD/MM/YY]
-
Add picture :
pic INDEX l/FILE_LOCATION
-
View all contacts with a specified tag :
tag TAG_NAME
-
Remove all contacts from a specified tag :
tag TAG_NAME remove