By: Team T13-2
Since: Nov 2018
Licence: MIT
- 1. Introduction
- 2. Quick Start
- 3. Features
- 3.1. Viewing help :
help
- 3.2. Adding a staff:
add
- 3.3. Listing all staff :
list
- 3.4. Editing a staff :
edit
- 3.5. Deleting a staff :
delete
- 3.6. Selecting a staff :
select
- 3.7. Giving feedback to a staff:
feedback
- 3.8. Rating a staff:
rate
- 3.9. Setting private fields:
privacy
- 3.10. Locating staff by name:
find-n
- 3.11. Locating staff by email:
find-e
- 3.12. Locating staff by department:
find-d
- 3.13. Locating staff by manager:
find-m
- 3.14. Sorting all staff by name :
sort
- 3.15. Sorting all staff by department :
sortDept
- 3.16. Sorting all staff by rating :
sortRatingDown
- 3.17. Sorting all staff by rating :
sortRatingUp
- 3.18. Favouriting a staff :
favourite
- 3.19. Unfavouriting a staff :
unfavourite
- 3.20. Listing entered commands :
history
- 3.21. Undoing previous command :
undo
- 3.22. Redoing the previously undone command :
redo
- 3.23. Counting the number of staff [coming in v2.0]:
count
- 3.24. Locking SSENISUB [coming in v2.0]:
lock
- 3.25. Unlocking SSENISUB [coming in v2.0]:
unlock
- 3.26. Authorization levels for features [coming in v2.0]:
login
,logout
- 3.27. Encrypting data files [coming in v2.0]
- 3.28. Clearing all entries :
clear
- 3.29. Saving the data
- 3.30. Exiting the program :
exit
- 3.1. Viewing help :
- 4. FAQ
- 5. Command Summary
SSENISUB is intended for organizations who follows a strict hierarchical structure to manage their manpower and allows the staff to use this as contact book.
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
SSENISUB.jar
here. -
Copy the file to the folder you want to use as the home folder for SSENISUB software.
-
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 staff -
add
n/John Doe p/98765432 e/[email protected] a/John Street Blk 123, #01-01 d/Tech m/Alice Tan
: adds a staff namedJohn Doe
to SSENISUB. -
delete
3
: deletes the 3rd staff 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/staff
,t/manager
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. -
Adding a 'p' infront of the parameter private. e.g. pp/PHONE makes the phone number private to the other user.
-
Only
PHONE
,EMAIL
andADDRESS
fields can be initialized as private.
Fields restrictions
NAME |
Names should only contain alphabetical characters and spaces, and should not be blank |
PHONE |
Phone numbers should only contain numbers, starts with digit '6', '8' or '9', and should be 8 digits long |
Emails should be of the format local-part@domain and adhere to the following constraints: 1. The local-part should only contain alphanumeric characters and these special characters, excluding the parentheses,
(!#$%&'*+/=?`{}~^.-), 1 to 50 characters long 2. This is followed by a '@' and then a domain name. |
|
ADDRESS |
Addresses can take any values, should not be blank, and should be 1 to 50 characters long |
SALARY |
Salary should only contain integers with no spaces or commas |
OT HOUR |
Overtime hours should only contain numbers up to two decimal places with no spaces or commas |
OT RATE |
Overtime rate should only contain numbers up to two decimal places with no spaces or commas |
DEDUCTIBLE |
Deductible should only contain numbers up to two decimal places with no spaces or commas |
DEPARTMENT |
Department should only contain alphabetic characters and spaces, should not be blank, and should be 1 to 30 characters long |
MANAGER |
Manager should only contain alphabetic characters and spaces, should not be blank, and should be 1 to 50 characters long |
RATING |
Rating should only contain numbers between 1 to 10 |
FEEDBACK |
Feedback can take any values, should not be blank, and should be 1 to 65 characters long |
INDEX |
Refers to the index number shown by the staff list command, and must be a positive integer 1, 2, 3, … |
Adds a staff to SSENISUB
Format: add n/NAME [p]p/PHONE_NUMBER [p]e/EMAIL [p]a/ADDRESS d/DEPARTMENT m/MANAGER [t/TAG]…
💡
|
A staff can have any number of tags (including 0) |
Caution
|
Phone numbers and Email addresses are unique, you will not be able to add a new staff with a pre-existing Phone number or Email address within SSENISUB
|
Examples:
-
add n/John Doe p/98765432 e/[email protected] a/John Street, Block 123, #01-01 d/Accounting m/Marcus Lim t/staff
-
add n/Betsy Crowe t/friend e/[email protected] a/Newgate Prison p/81729817 d/Marketing m/Edmund Tan t/staff
Edits an existing staff in SSENISUB.
Format: edit INDEX [n/NAME] [p/PHONE] [e/EMAIL] [a/ADDRESS] [s/SALARY] [oth/OTHOUR] [otr/OTRATE] [de/DEDUCTIBLES] [d/DEPARTMENT] [m/MANAGER] [t/TAG]…
-
Edits the staff at the specified
INDEX
. The index refers to the index number shown in the displayed staff list. The index must be a positive integer 1, 2, 3, … -
At least one of the optional fields must be provided.
-
Staff has 4 additional editable fields: salary, overtime hours (ot hours), overtime rate (ot rate) and pay deductibles.
-
Existing values will be updated to the input values.
-
When editing tags, the existing tags of the staff will be removed, i.e. adding of tags is not cumulative.
-
You can remove all the staff’s tags by typing
t/
without specifying any tags after it.
Examples:
-
edit 1 p/91234567 e/[email protected] s/1000
Edits the phone number, email address, salary of the 1st staff to be91234567
,[email protected]
and1000
respectively. -
edit 2 n/Betsy Crower t/
Edits the name of the 2nd staff to beBetsy Crower
and clears all existing tags.
Deletes the specified staff from SSENISUB.
Format: delete INDEX
-
Deletes the staff at the specified
INDEX
. -
The index refers to the index number shown in the displayed staff list.
-
The index must be a positive integer 1, 2, 3, …
Examples:
-
list
delete 2
Deletes the 2nd staff in SSENISUB. -
find Betsy
delete 1
Deletes the 1st staff in the results of thefind
command.
Selects the staff identified by the index number used in the displayed staff list.
Format: select INDEX
-
Selects the staff and loads the Google search page the staff at the specified
INDEX
. -
The index refers to the index number shown in the displayed staff list.
-
The index must be a positive integer
1, 2, 3, …
-
When a staff is selected, net salary is being displayed instead of gross salary
Examples:
-
list
select 2
Selects the 2nd staff in SSENISUB. -
find Betsy
select 1
Selects the 1st staff in the results of thefind
command.
Provides feedback for an existing staff in SSENISUB
Format: feedback INDEX fb/FEEDBACK
-
Updates the feedback of the staff at specified
INDEX
. The index refers to the index number shown in the displayed staff list. The index must be a positive integer 1, 2, 3, … -
The feedback field must be provided.
-
Profanities are not allowed, even if it is encapsulated within a word.
-
Profanities written in leetspeak will be caught as well.
Examples:
-
feedback 1 fb/You are great!
Gives the 1st staff a feedback of "You are great!".
Rates an existing staff in SSENISUB
Format: rate INDEX r/RATING
-
Rates the staff at the specified
INDEX
. The index refers to the index number shown in the displayed staff list. The index must be a positive integer 1, 2, 3, … -
The rating field must be provided.
-
Ratings can only be from 1 - 10.
-
Existing values will be updated to the input values if they are different.
Examples:
-
rate 3 r/8
Rates the 3rd staff of a rating 8.
Sets the mentioned field into a private field (displays as 'private' on staff panel).
Format: privacy INDEX [p/ y or n] [e/ y or n] [a/ y or n]
-
Modifies the privacy of the information of the staff at the specified
INDEX
. -
The index refers to the index number shown in the displayed staff list.
-
The index must be a positive integer 1, 2, 3, …
-
Only Phone, Email and Address can be set to private.
-
'y' means setting to private and 'n' means setting to public.
-
Coming in v2.0: View private fields
-
With the authorization level features implemented, a user with high enough level of authority will be able to see the actual values of the private field (instead of 'private').
-
Examples:
-
privacy 1 p/y a/n
Sets thePhone
number andAddress
of the 1st staff in SSENISUB to private and public respectively. -
privacy 4 e/n p/n
Sets theEmail
andPhone
number of the 4th staff in SSENISUB to public.
Finds staff whose names contain any of the given keywords.
Format: find-n KEYWORD [MORE_KEYWORDS]
-
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
-
Staff matching at least one keyword will be returned (i.e.
OR
search), e.g.Hans Bo
will returnHans Gruber
,Bo Yang
Examples:
-
find-n John
ReturnsJohn
andJohn Doe
-
find-n Betsy Tim John
Returns any staff having namesBetsy
,Tim
, orJohn
Finds staff whose email contain any of the given keywords.
Format: find-e KEYWORD [MORE_KEYWORDS]
-
The search is case insensitive, e.g
[email protected]
will match[email protected]
-
The order of the keywords does not matter, e.g.
[email protected]
[email protected]
will match[email protected]
[email protected]
-
Only the email is searched.
-
Only full words will be matched, e.g.
[email protected]
will not match[email protected]
Examples:
-
find-e [email protected]
ReturnsJohn
-
find-n [email protected] [email protected]
Returns any staff having emailsBetsy
,Tim
Finds staff whose department contain any of the given keywords.
Format: find-d KEYWORD [MORE_KEYWORDS]
-
The search is case insensitive, e.g
accounting
will matchAccountinG
-
The order of the keywords does not matter, e.g.
Accounting Tech
will matchTech Accounting
-
Only the department is searched.
-
Only full words will be matched, e.g.
Account
will not matchAccounting
-
Staff matching at least one keyword will be returned (i.e.
OR
search)
Examples:
-
find-d Accounting
Returns any staff in Accounting DepartmentJohn
-
find-d Accounting Tech
Returns any staff in Accounting or Tech DepartmentJohn
,Betsy
,Tim
Finds manager whose names contain any of the given keywords.
Format: find-m KEYWORD [MORE_KEYWORDS]
-
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 manager is searched.
-
Only full words will be matched e.g.
Han
will not matchHans
-
Manager matching at least one keyword will be returned (i.e.
OR
search). e.g.Hans Bo
will returnHans Gruber
,Bo Yang
Examples:
-
find-m John
Returnsjohn
andJohn Doe
-
find-m Betsy Tim John
Returns any manager having namesBetsy
,Tim
, orJohn
Sorts the staff list by name.
Format: sort
-
Sorts by favourite then by name, favourite staffs stay on top of the list
Sorts the staff list by department.
Format: sortDept
-
Sorts by department then by favourite then by name
Sorts the staff list by rating from highest to lowest.
Format: sortRatingDown
or sortRating
-
Sorts by rating (highest-lowest) then by favourite then by name
Sorts the staff list by rating from lowest to highest.
Format: sortRatingUp
-
Sorts by rating (lowest-highest) then by favourite then by name
Favourites the specified staff and moves it up to the top of the list.
Format: favourite INDEX
or fav INDEX
-
Favourites the staff at the specified
INDEX
. -
The index refers to the index number shown in the displayed staff list.
-
The index must be a positive integer
1, 2, 3, …
-
Staff at the specified
INDEX
needs to not be on the favourite list
Examples:
-
list
favourite 2
Favourites the 2nd staff in SSENISUB. -
find Betsy
fav 1
Favourites the 1st staff in the results of thefind
command.
Favourites the specified staff and moves it up to the top of the list.
Format: unfavourite INDEX
or unfav INDEX
-
Removes the staff at the specified
INDEX
from favourite list. -
The index refers to the index number shown in the displayed staff list.
-
The index must be a positive integer
1, 2, 3, …
-
Staff at the specified
INDEX
needs to be on the favourite list
Examples:
-
list
unfavourite 2
Removes the 2nd staff from favourite list. -
find Betsy
unfav 1
Removes the 1st staff in the results of thefind
command from favourite list.
Lists all the commands that you have entered in reverse chronological order.
Format: history
ℹ️
|
Pressing the ↑ and ↓ arrows will display the previous and next input respectively in the command box. |
Restores SSENISUB to the state before the previous undoable command was executed.
Format: undo
ℹ️
|
Undoable commands: those commands that modify SSENISUB’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
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)
Count the number of staff in specific department in SSENISUB
Format: count d/DEPARTMENT
Examples:
-
count d/accounting
Locks SSENISUB with a specified password.
Format: lock PASSWORD
Unlocks SSENISUB with a specified password.
Format: unlock PASSWORD
Allows a user to log into the SSENISUB system with different authorization levels.
Format: login USERNAME PASSWORD
, logout
-
In future versions, we plan to have features locked by authorization level, as we intend for SSENISUB to be used by all staff within the same Organization, it makes more sense if only a HR Manager is allowed to add or delete staff, or only the staff himself to be able to change his own information privacy settings.
-
Implementation of this authorization level feature will then allow us to develop new features makes the organization hierachy more understandable and obvious.
Examples:
-
login AmyBee 123456
-
logout
{explain how the user can enable/disable data encryption}
SSENISUB data are saved in the hard disk automatically after any command that changes the data.
There is no need to save manually.
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 SSENISUB folder.
-
Help :
help
-
Add
add n/NAME [p]p/PHONE_NUMBER [p]e/EMAIL [p]a/ADDRESS d/DEPARTMENT m/MANAGER [t/TAG]…
e.g.add n/James Ho p/91829309 e/[email protected] a/123, Clementi Rd, 1234665 d/Accounting m/David Choo t/staff
-
List :
list
-
Edit :
edit INDEX [n/NAME] [p/PHONE_NUMBER] [e/EMAIL] [a/ADDRESS] [s/SALARY] [oth/OTHOUR] [otr/OTRATE] [de/DEDUCTIBLES] [d/DEPARTMENT] [m/MANAGER] [t/TAG].. .
e.g.edit 2 n/James Lee e/[email protected] oth/10
-
Delete :
delete INDEX
e.g.delete 3
-
Select :
select INDEX
e.g.select 2
-
Feedback :
feedback INDEX fb/FEEDBACK
e.g.feedback 1 fb/Excellent job!
-
Rate :
rate INDEX r/RATING
e.g.rate 1 r/8
-
Privacy :
privacy INDEX [p/ y or n] [e/ y or n] [a/ y or n]
e.g.privacy 2 p/y a/n
-
Find by Name :
find-n KEYWORD [MORE_KEYWORDS]
e.g.find-n James Jake
-
Find by Email :
find-e KEYWORD [MORE_KEYWORDS]
e.g.find-e [email protected]
-
Find by Department :
find-d KEYWORD [MORE_KEYWORDS]
e.g.find-d Accounting
-
Find by Manager :
find-m KEYWORD [MORE_KEYWORDS]
e.g.find-m Moses Ben
-
Sort by Name :
sort
-
Sort by Department :
sortDept
-
Sort by Rating from Highest to Lowest :
sortRatingDown
orsortRating
-
Sort by Rating from Lowest to Highest :
sortRatingUp
-
Favourite :
favourite INDEX
orfav INDEX
e.g.favourite 1
orfav 2
-
Unfavourite :
unfavourite INDEX
orunfav INDEX
e.g.unfavourite 1
orunfav 2
-
History :
history
-
Undo :
undo
-
Redo :
redo
-
Lock SSENISUB [coming in v2.0] :
lock PASSWORD
-
Unlock SSENISUB [coming in v2.0]:
unlock PASSWORD
-
Login SSENISUB [coming in v2.0] :
login USERNAME PASSWORD
-
Logout SSENISUB [coming in v2.0] :
logout
-
Clear :
clear
-
Exit :
exit