An Example Process#
Lets build an example process for checking in a user to a building. We will call this access management.
Process name: Building Access Request
Steps to Creating a Process#
You should always document your process first.
Build the model
Write the prose
Identify data
Define data in the system
Build the process parts
Model the process
Test, review, repeat from 5 if necessary
Implement
Model Process#
graph TD style End stroke-width:6px, width: 10px Start((Start)) A[Register for visit] B[Check-in] C[Check-out] End((End)) Start --> A A --> B B --> C C --> End
To build this process we need to prepare our system by creating the identified fields, for which we need to collect data.
Prose text#
A verbal description of the process, to help identify data and the parts of a process.
A user requests access to a facility beginning at ond ending on specific dates. The user must provide the dates of attendance per visitation, the facility to be visited, and the contact person within the organization. Upon arrival and on departure, the desk agent must enter the time and date of entry.
Identify Data#
The ticket requires, in addition to the user provided data, ticket data. It will be registered to the postmaster queue as a new ticket. It will be unlocked and of type “Access Request” with the normal priority. It will not be assigned to a specific user.
Define Data#
Dynamic field data to be collected:
- Facility
As a drop down field.
- Personal Contact
As a text field.
- Purpose of Visit
As a text area.
- Begin of Visit
As a date field.
- End of Visit
As a date field.
- Check-in Time
As a date time field.
- Check-out Time
As a date time field.
Note
I will not show how to create dynamic fields. See Extend Ticket Data (Dynamic Fields)
Build Process Parts#
To build the process, we must understand our workflow and identify its different parts. We recommend using BPMN .
Note
BPMN
The Business Process Modeling Notation (BPMN) is visual modeling language, which is an open standard notation for graphical flowcharts that is used to define business process workflows. It is popular and intuitive graphic that can be easily understand by all business stakeholders, including business users, business analysts, software developers, and data architects.
Roughly stated, each activity is represented as an user activity in Znuny and consists of an Activities Element and one or more Activity Dialogs.
We will start by modeling the process with tow activities and three dialogs.
Create a New Process#
Navigate to
Admin > Process Management
Click Create New Process
Process Management Actions Menu#
Add process name and description
data:image/s3,"s3://crabby-images/dd343/dd343d00839d2f63b810d9cdd6d69c86e13c2729" alt="../../../_images/add_process.png"
Name and Description#
Save
Add Activities#
We will identify two activities here. You can create a new activity in the process elements list.
data:image/s3,"s3://crabby-images/88227/88227d382af08b8f519b931456549699fb3ec016" alt="../../../_images/process_element_activity.png"
Add an activity.#
Register for Visit
data:image/s3,"s3://crabby-images/c8714/c8714d0e9528c3f951f65e14a9b96342d2c7b29e" alt="../../../_images/process_element_activity_add_register_visit.png"
Register for Visitation#
Record Visit
data:image/s3,"s3://crabby-images/82d70/82d70abaae42ab664e91f163544b75c438efe831" alt="../../../_images/process_element_activity_add_record_visit.png"
Record Visitation#
Process End
data:image/s3,"s3://crabby-images/bf1cc/bf1cc73e4fec522430d2927e5bfd56da2b99a379" alt="../../../_images/process_element_activity_add_process_end.png"
Process Ended#
Note
Process End
This is used as a general place holder, to allow us to later apply final ticket data via the Transition Actions
Add Activity Dialogs#
We will identify some of the activities in our model, as dialogs of the activity Record Visit, where we collect the check-in and checkout time.
You can create a new activity dyalog in the process elements list. Here we will:
define who can use the dialog
define the fields and field order
data:image/s3,"s3://crabby-images/aa7a1/aa7a106ec2593444d77dfef6fdfb53af86a7b135" alt="../../../_images/process_element_activity_dialog.png"
Add an activity dialog.#
Visitation Application
data:image/s3,"s3://crabby-images/4b40f/4b40f0aaf1b87e5b88b67b5d01e0c10f8d7eaccc" alt="../../../_images/process_element_activity_dialog_add_visitation_record.png"
Register for Visitation Dialog#
Check-in
data:image/s3,"s3://crabby-images/f6093/f6093e6075889bfab0e94101476fb6cbc44bcc12" alt="../../../_images/process_element_activity_dialog_add_check_in.png"
Check-in Dialog#
Check-out
data:image/s3,"s3://crabby-images/d8859/d88597970dac4ce167a847237dfc78a07b9acd3d" alt="../../../_images/process_element_activity_dialog_add_check_out.png"
Check-out Dialog#
Add Transitions#
We will add a transition to evaluate the data entered, and move our process between activities.
You can create a new transition in the process elements list.
data:image/s3,"s3://crabby-images/fd6b1/fd6b1ac20e2c87ee885e73cf3be71bf737eff3a0" alt="../../../_images/process_element_transition.png"
Add a transition.#
Application Recorded: Verify the ticket state via a regular expression, because a ticket always has state and we made all fields mandatory.
User checked out: Verify the user checked out.
Add Transition Actions#
We will add actions to be applied to the ticket during each step of the process. This automation allows us to streamline the process for the user. This eliminates many confusing aspects, and allows us to modify the process at any time, without it changing for the user. The user just has to enter data.
You can create a new transition action in the process elements list.
data:image/s3,"s3://crabby-images/5759d/5759dd7c3e3cbedf3fe9025faa5db2cc23775ce8" alt="../../../_images/process_element_transition_action.png"
Add a transition action.#
Pending 24 Hours
data:image/s3,"s3://crabby-images/56075/56075bbe9813629191d57fc5ca1ef6c714b8d410" alt="../../../_images/process_element_transition_action_add_Pending_24_Hours.png"
Set pending state and Time#
Ticket closed
data:image/s3,"s3://crabby-images/807f8/807f87454fe715910238e09279166479c0956da1" alt="../../../_images/process_element_transition_action_add_Ticket_closed.png"
CLose TIcket#
Ticket unlock
data:image/s3,"s3://crabby-images/b368e/b368e5e0af45e2c5ea6b71619bc21f13c73feba9" alt="../../../_images/process_element_transition_action_add_Ticket_unlock.png"
Unlock Ticket#
Model the Process#
By dragging the pieces onto the model, we can quickly assemble the process.
data:image/s3,"s3://crabby-images/3ad1b/3ad1b3ccad4e475d646ad5fe17eaa4108bacb74f" alt="../../../_images/model_process.gif"
Modelling the Process#
Drag all activities on to the canvas.
Drag and drop the dialogs on to the activities.
Drag the transition on to an activity, and connect the arrow to the following activity.
Drag and drop tho transition actions onto the transition.
Test, Review, Revise, Release#
Customer Creation#
The customer fill and submits the request.
data:image/s3,"s3://crabby-images/8cbc1/8cbc16aa2475f2212e16dfd8077806109a8be6de" alt="../../../_images/customer_form.png"
Customer Form#
Agent View#
The agent opens the pending ticket, and checks the user in and out.
data:image/s3,"s3://crabby-images/27abf/27abf075c9c90e6a0797bde5f0d1a12ba42b3f10" alt="../../../_images/agent_data.png"
Agent View#
Process End#
The process ends and the ticket is automatically closed.
data:image/s3,"s3://crabby-images/ce0f4/ce0f43b0484a70bdd7aedf62d334d6217126a849" alt="../../../_images/process_end.png"
Process Ended#
Touch-ups#
To get the full effect as seen above in the screenshots, you must:
data:image/s3,"s3://crabby-images/72fff/72fff141b6a88b07219b7ec6ef1bf56bbb937818" alt="../../../_images/assing_to_process_widget.png"
Add the Dynamic Field for Process Widget Screen#
data:image/s3,"s3://crabby-images/a6e8f/a6e8f24fbad909adfce235021603be636bb83770" alt="../../../_images/group_data.png"
Grouping the Fields via System Configuration#
This process is by no means complete, and should be enhanced with notifications and articles, but this cannot be covered by documentation alone.