By: T09-3
Since: Sep 2019
Licence: MIT
ClerkPro is an appointment and queue management system targeted at clerks working in small clinics. This desktop application is optimised for individuals who prefer to work with a Command Line Interface (CLI). while still having the benefits of a Graphical User Interface (GUI).
ClerkPro enables clerks to rapidly manage patient’s details, appointments, queues and the staff’s duty roster. Typing fast allows you to complete your tasks much faster than GUI apps.
Interested? Refer to Section 2, “Quick Start” to get started. Enjoy!
-
Ensure you have Java
11
or above installed in your Computer. -
Download the latest
ClerkPro.jar
here. -
Copy the file to the folder you want to use as the home folder for ClerkPro.
-
Double-click the file to start the app. The User Interface (UI) should appear in a few seconds. For testing purposes, ClerkPro is pre-loaded with sample data to allow you to explore and familiarise with the application.
-
You may navigate through the entire UI with UP, DOWN, LEFT, RIGHT and TAB.
-
The figure below shows the layout.
-
Type the command in the command box and press Enter to execute it.
e.g. typinghelp
and pressing Enter will open the help window. Alternatively, just press F1. -
Some example commands you can try:
-
newpatient -id E0000001A -name John Doe -phone 98765432 -email johnd@example.com -address John street, block 123, #01-01
: registers a patient namedJohn Doe
. -
patient John Doe
: searches for a patient whose name containsJohn Doe
-
enqueue E0000001A
: enqueues patient with reference idE0000001A
into the queue. The patientE0000001A
must be registered. -
exit
: exits the app.
-
-
Refer to Section 3, “Features” for details of each command.
Do not directly edit any of the following json files: e.g. appointments.json
, dutyRoster.json
, patientDetails.json
, staffDetails.json
, preferences.json
, config.json
AutoComplete & History
-
When the command box is blank, UP & DOWN will auto-fill the command box with commands previously entered. UP gives older commands and DOWN gives newer commands.
-
When the command box is not blank, AutoComplete will come into action and tries to suggest commands that are available for whatever that has been typed. During which, you may traverse your selection of the suggestions via UP & DOWN then press ENTER to confirm selection.
Full keyboard navigable UI
-
LEFT & RIGHT changes focus between OmniPanel and TabBar when focus is not on CommandBox.
-
TAB changes focus from TabBar/OmniPanel to CommandBox and from CommandBox to TabBar.
Reactive search
-
The listing automatically filters to display only the most relevant results when searching for an existing entry.
-
When searching for a specific patient or staff, using the
patient
ordoctor
command, the results are filtered based on whether the person’s reference Id, name or phone number contains the given keyword. -
When searching for a specific appointment or duty shift, using the
appointments
orshifts
command, the results are filtered based on whether the events involves a person whose reference Id contains the given keyword.
Validity of Appointment’s timings
-
Ensures that appointments can only be scheduled at timings when there are sufficient staffing.
-
The scheduling of a patient’s appointment will be rejected by the system, if the doctors on-duty at that timing are already pre-occupied by other appointments.
-
The cancellation or changing of a doctor’s duty shift will be rejected by the system, if the action results in there being insufficient staffing to accommodate already scheduled appointments.
Command Format
-
Words in
<UPPER_CASE>
are the parameters to be supplied by the user e.g. inregister -name <NAME>
,NAME
is a parameter which can be used asregister -name John Doe
. -
Items in square brackets are optional e.g
-name <NAME> [-tag <TAG>]
can be used as-name John Doe -tag friend
or as-name John Doe
. -
Items with
…
after them can be used multiple times including zero times e.g.[-tag <TAG>]…
can be used as-tag friend
,-tag friend -tag family
etc. -
Parameters can be in any order e.g. if the command specifies
-name <NAME> -phone <PHONE_NUMBER>
,-phone <PHONE_NUMBER> -name <NAME>
is also acceptable. -
A Reference Id refers to a 9 case-insensitive alphanumeric characters, that can be used to uniquely identify a person, such as a membership number or NRIC.
-
A
<PATIENT_REFERENCE_ID>
refers to the reference id which belongs to a patient. Whereas, a<STAFF_REFERENCE_ID>
refers to the reference id of a staff doctor. -
Words in triangle brackets(
<
and>
) are the parameters to be supplied by the user e.g. inregister -name <NAME>
,NAME
is a parameter which can be used asregister -name John Doe
.
Important
|
All timings are based on the system’s clock. |
Filters patients whose reference ids, names or phone number contains the given keyword.
If no search keyword is provided, all registered patients will be displayed.
Format: patient [<SEARCH_KEYWORD>]
-
e.g.
patient S0000001A
Registers a new patient. Only patient’s reference id and name are compulsory fields
Format: newpatient -id <PATIENT_REFERENCE_ID> -name <PATIENT_NAME> [-phone <PHONE_NUM>]
[-email <EMAIL>] [-address <ADDRESS>] [-tag <Tags>]…
-
e.g.
newpatient -id E0000001A -name Edmond Halley -phone 85732743 -email halley@example.com -address 12, Kent ridge Ave 3, #01-11 -tag AIDS
Important
|
As a design decision, undoing the registration of a patient is allowed, via the undo command.
However, though our target users are clerks working at clinics, our clients would be the employers and stakeholders of said clinics.
Hence, the user should not have administrative privilege to unregister any patient already in the system.
|
Updates the particulars of a patients
ℹ️
|
Editing tags will overwrite all existing tags. Must not edit when patient is in queue or being served. |
Format: editpatient -entry <ENTRY_ID> [-id <PATIENT_REFERENCE_ID>] [-name <NAME>] [-phone <PHONE_NUM>]
[-email <EMAIL>] [-address <ADDRESS>] [-tag <Tags>]…
-
e.g.
editpatient -entry 1 -phone 91200567 -email edmond@example.com
Filters staff doctor whose reference ids, names or phone number contains the given keyword.
If no search keyword is provided, all registered doctors will be displayed.
Format: doctor [<SEARCH_KEYWORD>]
-
e.g.
doctor S0111111A
Registers a new doctor. Only doctor’s reference id and name are compulsory fields.
Format: newdoctor -id <STAFF_REFERENCE_ID> -name <NAME> [-phone <PHONE_NUM>]
[-email <EMAIL>] [-address <ADDRESS>] [-tag <TAGS>]…
-
e.g.
newdoctor -id W0000001A -name John Doe -phone 98765432 -email johnd@example.com -address 311, Clementi Ave 2, #02-25 -tag Male
Important
|
As a design decision, undoing the registration of a staff doctor is allowed, via the undo command.
However, though our target users are clerks working at clinics, our clients would be the employers and stakeholders of said clinics.
Hence, the user should not have administrative privilege to unregister any staff doctor already in the system.
|
If user is in the doctors listing screen, updates any change for doctor’s profiles.
ℹ️
|
Editing tags will overwrite all existing tags. Must not edit when the doctor is on duty. |
Format: editdoctor -entry <ENTRY_ID> [-id <STAFF_REFERENCE_ID>] [-name <NAME>] [-phone <PHONE_NUM>]
[-email <EMAIL>] [-address <ADDRESS>] [-tag <Tags>]…
-
e.g.
editdoctor -entry 1 -phone 91234567 -email johndoe@example.com
Marks the doctor, based on the index given, as on-duty and adds him/her to a list of on-duty doctors.
Format: onduty <ON_DUTY_DOCTOR_ENTRY_ID>
-
e.g.
onduty 1
Adds a patient to the queue based based on the patient’s Id. The enqueued patient must be a registered. Staff members cannot be enqueued.
Format: enqueue <PATIENT_REFERENCE_ID>
-
e.g.
enqueue E0000001A
Removes a patient from the queue based on their queue position.
Format: dequeue <QUEUE_INDEX>
-
e.g.
dequeue E0000001A
Assigns the next patient in the queue to a doctor.
Format: next <ENTRY_ID>
-
e.g.
next 1
Avoids directing patients to a doctor. e.g. Doctor is on a lunch break
Format: break <ENTRY_ID>
-
e.g.
break 1
Displays a sorted list of upcoming appointments for the patient that is associated to the given REFERENCE_ID
.
If no keyword is given, all upcoming appointments will be displayed.
Format: appointments [<REFERENCE_ID>]
-
e.g.
appointments E0000001A
Schedules a new appointments for a patient.
NOTE: The appointment will be rejected by the system, if there are insufficient staff doctors on duty at the time of the appointment.
e.g. Cannot schedule more appointments than available doctors on duty.
If both -reoccur <INTERVALS>
and -num <NUMBER_OF_TIMES>
fields are present, appointments of these <NUMBER_OF_TIMES>
will be added to the patient
appointment schedule in <INTERVALS>
. Otherwise, only one event will be added.
If the optional field [-end <END_TIMING>]
is absent, default end timing is 30 mins after start timing of the appointment. Otherwise, end Timing will be [-end <END_TIMING>]
.
The optional field [-reoccur <INTERVALS>]
can be -reoccur w
, -reoccur m
, or -reoccur y
.They represent to add weekly, monthly, yearly repeat appointment respectively.
Format: newappt -id <PATIENT_REFERENCE_ID> -start <START_TIMING> [-end <END_TIMING>] [-reoccur <INTERVALS> -num <NUMBER_OF_TIMES>]
-
e.g.
newappt -id E0000001A -start 12/12/19 0900 -end 12/12/19 1000 -reoccur m -num 2
Acknowledges the most upcoming appointment only if patient arrives on the same day and the arriving time is before the appointment’s end time
Format: ackappt <REFERENCE_ID>
-
e.g.
ackappt E0000001A
Cancels the specified appointment.
ℹ️
|
To avoid accidental cancellation of another patient’s appointments, the user must first narrow down the search to a single patient using the appointments [<REFERENCE_ID>] command. |
Format: cancelappt <ENTRY_ID>
-
e.g.
cancelappt 1
Changes the timing for an existing appointment.
If no optional fields [-end <END_TIMING>]
is present, default endTiming is 30 mins after startTiming. Otherwise new endTiming will be [-end <END_TIMING>]
.
ℹ️
|
To avoid accidental rescheduling of another patient’s appointments, the user must first narrow down the search to a single patient using the appointments [<REFERENCE_ID>] command. |
ℹ️
|
The operation is rejected if there are insufficient staff doctors on duty at the time of the new appointment. |
Format: editappt -entry <ENTRY_ID> -start <START_TIMING> [-end <END_TIMING>]
-
e.g.
editappt -entry 1 -start 12/12/19 1300 -end 12/12/19 1400
Lists all appointments that are missed.
ℹ️
|
An appointment is considered missed if the appointment was not acknowledged and the current time has passed the appointment’s end time. |
Format: missappt
-
e.g.
missappt
Settles and removes the missed appointment based on the given index.
Settling refers to the user following up on contacting the patient who has missed his/her appointment.
ℹ️
|
Only missed appointments can be settled. The user must first display the missed appointment listing, using missappt , before using this command. |
Format: settleappt <ENTRY_ID>
-
e.g.
settleappt 1
Displays a sorted list of upcoming duty shifts for the staff doctors that is associated to the given REFERENCE_ID
.
If no keyword is given, all upcoming appointments will be displayed.
Format: shifts [<REFERENCE_ID>]
-
e.g.
shifts S0111111A
Adds a new duty shift for a doctor.
If both -reoccur <INTERVALS> and -num <NUMBER_OF_TIMES> fields are present, duty shifts of these <NUMBER_OF_TIMES> will be added to the doctor duty roster in <INTERVALS>.
Otherwise, only one shift will be added.
Format: newshift -id <STAFF_REFERENCE_ID> -start <START_TIMING> -end <END_TIMING> [-reoccur REOCCURRING -num REOCCURRING_TIMES]
-
e.g.
newshift -id W0000001A -start 12/12/19 0900 -end 12/12/19 2100 -reoccur m -num 2
Cancels the specified duty shift for a doctor based on the given entry index.
ℹ️
|
To avoid accidental cancellation of another doctor’s shift, the user must first narrow down the search to a single doctor using the shift [<REFERENCE_ID>] command. |
ℹ️
|
The operation is rejected if it results in there being more appointments than staff doctors on duty at any given point in time. The appointments affected by the deletion of the duty shift must be resolved first. |
Format: cancelshift <ENTRY_ID>
-
e.g.
cancelshift 1
Changes the timing of an existing duty shift based on the given entry index.
ℹ️
|
To avoid accidental cancellation of another doctor’s shift, the user must first narrow down the search to a single doctor using the shift [<REFERENCE_ID>] command. |
ℹ️
|
The operation is rejected if it results in there being more appointments than staff doctors on duty at any given point in time. |
The patient’s appointment affected by the deletion of the duty shift must be resolved first.
Format: editshift -entry <ENTRY_ID> -start <START_TIMING> -end <END_TIMING>
-
e.g.
editshift -entry 1 -start 12/12/19 1200 -end 12/12/19 2100
Login with your username and password. The user will then be prompted to enter their password.
Format: login <USER_NAME>
Note: Search actions refers to the patient
, doctor
, appointments
and shift
commands.
-
Patient Management
-
Search for patient using reference Id, name or phone number:
patient [<SEARCH_KEYWORD>]
-
Register new patient:
newpatient -id <PATIENT_REFERENCE_ID> -name <PATIENT_NAME> [-phone <PHONE_NUM>] [-email <EMAIL>] [-address <ADDRESS>] -num [-tag <Tags>]…
-
Edits patient details:
editpatient -entry <ENTRY_ID>[-id <PATIENT_REFERENCE_ID>] [-name <NAME>] [-phone <PHONE_NUM>] [-email <EMAIL>] [-address <ADDRESS>] -num [-tag <Tags>]…
-
-
On-Duty Doctors Management
-
Search for doctors using reference Id, name or phone number:
doctor [<SEARCH_KEYWORD>]
-
Register new doctor:
newdoctor -id <STAFF_REFERENCE_ID> -name <NAME> [-phone <PHONE_NUM>] [-email <EMAIL>] [-address <ADDRESS>] [-tag <TAGS>]…
-
Edit doctor details:
editdoctor -entry <ENTRY_ID> [-id <STAFF_REFERENCE_ID>] [-name <NAME>] [-phone <PHONE_NUM>] [-email <EMAIL>] [-address <ADDRESS>]-num
-
Mark doctor as on-duty:
onduty <ENTRY_ID>
-
Mark doctor as off-duty:
offduty <ENTRY_ID>
-
-
Queue Management
-
enqueue:
enqueue <PATIENT_REFERENCE_ID>
-
dequeue:
dequeue <QUEUE_INDEX>
-
Assigns next Patient in queue to doctor:
next <DOCTOR_ENTRY_ID>
-
Marks doctor on break:
break <DOCTOR_ENTRY_ID>
-
Marks doctor on resuming work:
resume <DOCTOR_ENTRY_ID>
-
-
Appointment Management
-
Search for appointments:
appointments [<REFERENCE_ID>]
-
Add new appointment:
newappt -id <REFERENCE_ID> -start <START_TIMING> [-end <END_TIMING>] [-reoccur <INTERVALS> -num <NUMBER_OF_TIMES>]
-
Edit appointment:
editappt -entry <ENTRY_ID> -start <START_TIMING> [-end <END_TIMING>]
-
Cancel appointment:
cancelappt <ENTRY_ID>
-
Acknowledge arrival of patient for appointment:
ackappt <REFERENCE_ID>
-
List all missed appointments:
missappt
-
Mark missed appointment as settled:
settleappt <ENTRY_ID>
-
-
Duty-shift Management
-
Search for shift:
shifts [<REFERENCE_ID>]
-
Add new shift:
newshift -id STAFF_REFERENCE_ID -start <START_TIMING> -end <END_TIMING> [-reoccur <INTERVALS> -num <NUMBER_OF_TIMES>]
-
Change shift:
editshift -entry <ENTRY_ID> -start <START_TIMING> -end <END_TIMING>
-
Cancel shift:
cancelshift <ENTRY_ID>
-
-
Inventory commands (v2.0)
-
inventory:
inventory
-
prescription:
prescription <PRESCRIPTION_ID | PRESCRIPTION_NAME>
-
-
User Accounts (v2.0)
-
login:
login <USER_NAME>
-
logout:
logout
-
-
General Commands
-
help:
help
-
exit:
exit
-
undo:
undo
-
redo:
redo
-