SystemArchitectEssentials731StudentGuide 1052732915 PDF
SystemArchitectEssentials731StudentGuide 1052732915 PDF
SystemArchitectEssentials731StudentGuide 1052732915 PDF
7.3.1
Student Guide
© 2018
Pegasystems Inc., Cambridge, MA
All rights reserved.
Trademarks
For Pegasystems Inc. trademarks and registered trademarks, all rights reserved. All other trademarks or service marks are property of their
respective holders.
For information about the third-party software that is delivered with the product, refer to the third-party license file on your installation media
that is specific to your release.
Notices
This publication describes and/or represents products and services of Pegasystems Inc. It may contain trade secrets and proprietary information
that are protected by various federal, state, and international laws, and distributed under licenses restricting their use, copying, modification,
distribution, or transmittal in any form without prior written authorization of Pegasystems Inc.
This publication is current as of the date of publication only. Changes to the publication may be made from time to time at the discretion of
Pegasystems Inc. This publication remains the property of Pegasystems Inc. and must be returned to it upon request. This publication does not
imply any commitment to offer or deliver the products or services described herein.
This publication may include references to Pegasystems Inc. product features that have not been licensed by you or your company. If you have
questions about whether a particular capability is included in your installation, please consult your Pegasystems Inc. services consultant.
Although Pegasystems Inc. strives for accuracy in its publications, any publication may contain inaccuracies or typographical errors, as well as
technical inaccuracies. Pegasystems Inc. shall not be liable for technical or editorial errors or omissions contained herein. Pegasystems Inc. may
make improvements and/or changes to the publication at any time without notice.
Any references in this publication to non-Pegasystems websites are provided for convenience only and do not serve as an endorsement of these
websites. The materials at these websites are not part of the material for Pegasystems products, and use of those websites is at your own risk.
Information concerning non-Pegasystems products was obtained from the suppliers of those products, their publications, or other publicly
available sources. Address questions about non-Pegasystems products to the suppliers of those products.
This publication may contain examples used in daily business operations that include the names of people, companies, products, and other third-
party publications. Such examples are fictitious and any similarity to the names or other data used by an actual business enterprise or individual is
coincidental.
Pegasystems Inc.
One Rogers Street
Cambridge, MA 02142-1209
USA
Phone: 617-374-9600
Fax: (617) 374-9620
www.pega.com
COURSE INTRODUCTION 1
Before you begin 2
System Architect Essentials overview 3
Objectives
After completing this course, you should be able to:
l Explain the benefits of using the Pega model-driven application design and development approach
l Model the life cycle of a case that mirrors the way business people think about how work is completed
l Identify the high-level responsibilities associated with Pega Platform for both Pega business architects and
system architects
l Describe Pega's Direct Capture of Objectives™ approach to increasing the speed and accuracy of application
delivery
l Explain the purpose and benefits of best practices and guardrails
l Validate case data to ensure that user entries match required patterns
l Configure a Wait shape to enforce a case processing dependency
l Configure user views and data elements during case life cycle creation
l Use the Clipboard tool to review case data in memory
l Set property values automatically using data transforms and declare expressions
l Configure and populate a work party with case data
l Create data classes and properties for use in a Pega application
l Automate decision-making to improve process efficiency
l Design responsive user forms for use on any platform or browser
l Design reports to deliver key insights to business users
l Incorporate and manage reference data to allow applications to adapt to changing business conditions
l Test your application design to analyze rule behavior and identify configuration errors
Intended audience
This course is for system architects who are responsible for developing business applications.
Prerequisites
To succeed in this course, students should have completed:
Some experience developing software applications is helpful, but not required.
INTRODUCTION TO PEGA
PLATFORM
5
©2018 Pegasystems
Pega Platform
Introduction to Pega Platform
Pega Platform is a visually driven application development environment that enables you to deliver
applications faster than traditional approaches. People in business and IT roles work together, using
visual models to capture business requirements at any time.
After this lesson, you should be able to:
l Explain the benefits of using a model-driven application design and development approach
l Identify the key navigational elements of the Pega Express portal
l Describe the roles of a Business Architect and a System Architect
l Describe Pega's Direct Capture of Objectives™ approach to increasing the speed and accuracy of
application delivery
l Identify the high-level responsibilities associated with Pega Platform for both Pega business
architects and system architects
6
©2018 Pegasystems
The magic of Pega
In the following video, you learn about the magic of Pega: how it empowers your business; how you can
leverage Pega smart technology to do the work for you; how Pega uses Software That Writes Your
Software™; how you run your application where it makes sense for your organization; and how Pega's
application offerings jump start your digital transformation journey. All through the magic of Pega.
Before you learn the technology, take a few minutes to experience the magic of Pega. The Pega mission
is to change the way the world builds software to create unprecedented business outcomes by
connecting, engaging, and empowering people. How do you empower employees to create software?
The answer is to get rid of code. Instead of coding apps, business users connect with IT to configure
applications using visual tools. This model-driven approach is faster than code and more accurate.
This approach engages everyone — business people and IT — using software to transform your
business. Pega empowers business people to create and evolve the systems they use every day.
How do you use Pega to create this magic? You use Pega’s differentiated capabilities and products.
l Empower the business. Pega magic happens when business people use tools that allow them to
create and evolve the applications they need to successfully run their businesses.
l Systems do the work. Pega magic happens when systems do the work, not people. The systems
should be smart and leverage Pega technology such as decisioning, robotics, and AI to do the work
for you.
l Let the software write the software. Pega magic happens through software that writes your
software. Business users focus on building value into application using model driven development,
not writing and managing Java code.
l Run your application where it makes sense for your organization. Magic happens when Pega
applications run anywhere — Cloud, on premise, and in topologies such as Pivotal Cloud Foundry
and containers such as Docker. With Pega, you are not tied to a topology or deployment model. As a
result, Pega allows your systems to be future-proof.
l Jump start your transformation with Pega's application offerings. Pega magic happens when
you gain advantage in your digital transformation journey by starting with Pega's customer
engagement and industry applications. Pega's prebuilt applications allow you to deliver value to
your customers faster than building the application from scratch. However, if you need the flexibility
to build a custom application you can use Pega Platform to build whatever type of application you
want.
You can start your digital transformation from the center and work your way out using end-to-end
automation. You use visual models to automate the user process. Extend your model with Pega’s next-
best-action decisioning to dynamically meet each customer’s needs. When you start with the outcomes
that you want to deliver and work out from there, you can radically transform the experience for your
customers. You get value, and you have built for reuse across channels and into the future.
Here is one example of using the magic of Pega. To counter deteriorating market share and the highest
churn rate in the wireless industry, one mobile communications company needed to overhaul its
approach to customer care. In just 90 days, the company transformed its contact center operations
across 1,000 service agents, ensuring the right retention offers for each customer. The company saw a
40% increase in Net Promoter Score, an 800% increase in customer upgrades to higher value plans,
and a 50% reduction in post-paid churn, to the lowest level in company history. All through the magic
of Pega!
Are you ready to learn how to use the magic of Pega?
7
©2018 Pegasystems
Pega Platform overview
The Pega Platform overview introduces you to some of the benefits and uses of the Pega Platform. In
the following video, you will learn how Pega Platform helps you to automate your complex business
processes while accommodating differences in products, regions, and channels. You will also see that
Pega Platform future-proofs your application by continually updating with the latest technologies.
Pega Platform transforms the way organizations do business. You use Pega to quickly and easily model
your complex business processes. Pega Platform includes built-in tools to ensure that you follow best
practices while building your application. By following best practices, you reduce development costs,
work more efficiently, and keep pace with today’s changing business environment.
Pega uses a set of business-friendly metaphors, an intermediate visual language that enables the
computer to really understand how you want things to work. Pega Platform is a model-driven
application development tool you use to define your business systems. Rather than traditional
programming, Pega’s approach to marketing and customer engagement is in terms of specific business
cases. Those cases may involve orders, supply chain, or your specific pain-points. Pega’s Next-Best-
Action predicts customer needs and provides the right offer.
Pega thinks in terms of specific business cases. Your case represents a business transaction you want
to complete or resolve. Cases follow stages and steps in a process from beginning to end. Cases can
accomplish a variety of tasks across many businesses and sectors. Examples of cases include legal
cases, home mortgages, auto insurance claims, and software bug tracking. Your case has at least one
process that people work on to resolve the case. And your case has a status that changes as the case
completes each stage of the process.
Using Pega Platform you automate your business process by building a case. For example, imagine
processing an expense for reimbursement. The work moves from an employee incurring the expense,
to a manager reviewing the expense, and then to a higher-level manager approving the expense, and
finally to the finance department for payment. Using Pega Platform you create a case that models the
business process. The case automates each stage and the steps involved in moving the case to
completion.
Here are some examples of Pega Platform automation:
l Communications – including email and text notifications,
l Business policies – including decision logic and service level agreements,
l Routing assignments – including routing work to case participants, and
l Reporting – including running and sending scheduled reports.
Once you configure a case that automates your business process, Pega Platform enables you to reuse
policies and procedures throughout your organization. Pega's Situational Layer Cake managed by the
Pega brain makes reusing common policies and procedures easy while allowing for differences
between products, regions, channels, and customer segments.
The Pega brain enables you to think differently about the connections and think about customer
journeys. It’s what makes an organization agile, fluid, smart, and responsive. Pega Platform’s model-
driven development tools enable you to future-proof your enterprise applications. Pega does this by
continually updating Pega Platform with the latest technologies that generate new code from the same
business-friendly metaphors you create to automate your business processes. Pega Platform enables
you to Build for Change®.
8
©2018 Pegasystems
The roles of team members
The following video covers the roles of team members during the design, build, and production phases
of your Pega Platform application. During the design and build phase, you see how case designers,
Business and System Architects, work with subject matter experts and stakeholders to create the
application. During the production phase you see how case participants, case workers and case
managers, interact to resolve cases.
During the design and build phase of a Pega Platform application, a team of case designers collaborate
on the project. Case designers are business architects and system architects, who collaborate with
subject matter experts and stakeholders. Subject Matter Experts work with business architects and
system architects to design the metaphors that represent your business processes. Stakeholders help
to review, refine, and approve the solution. When your Pega Platform application moves to production,
case participants, consisting of case workers and managers, use the application to resolve your
business cases.
Business architects are members of the application development team who define business rules,
service-level agreements, and processes. They are advocates for business users. Business architects
work with subject-matter experts and key project stakeholders to understand business needs and
define use cases and features.
System architects are application developers who contributes object-oriented design and technical
implementation skills to an application development project. System architects configure application
assets such as user interface forms and automated decisions.
Here is an example of a candidate interview and hiring process that illustrates how case workers and
managers interact with the case. In production, case workers schedule phone screenings and
interviews, and prepare and extend offers. Case managers evaluate and assess the candidates and
approve offers. Pega Platform automates the business process and ensures case participants work
together to resolve cases.
9
©2018 Pegasystems
Configuring a Pega Platform
application
Introduction to configuring a Pega Platform
application
The Pega Platform provides a unified platform with everything you need to build or modify an
enterprise application. To improve application quality and maintainability, the Pega Platform includes
built-in tools that ensure that you follow best practices for application development.
After this lesson, you should be able to:
l Identify the key Pega Express features you use to create and build your application
l Create a case type
l Create a field to store case data
l Configure a user view to display case data
10
©2018 Pegasystems
Best practices and application
guardrails
Introduction to best practices and guardrails
In this lesson, you will learn best practices for designing and building applications.
Some best practices help you deliver business application development projects successfully. Other
best practices help you design business applications with fewer defects. Following best practices
increases your chances of overall project success.
Objectives
At the end of this lesson, you should be able to:
l Explain the purpose and benefits of best practices.
l Identify Pega best practices
l Identify the most important best practices when building a Pega application
l Explain how Pega guardrails indicate flaws in an application design
l Describe the information provided in guardrail warnings
Best practices are used in everyday life. For example, when preparing
a meal, a best practice is to always use a potholder when touching a
hot pot. The goal is to not burn yourself, and using a potholder is a
proven way to prevent you from burning yourself.
As you design and build your application, establish and follow best
practices to increase your chances of project success. Look for existing
best practices used by your organization and by Pega. Select existing
11
©2018 Pegasystems
best practices or create new best practices to meet your goals.
Applying best practices increases the likelihood that your application is
delivered on time and meets all of its design requirements.
Does the best practice fit with the structure of your organization?
If a best practice places authority in a single person or part of the organization, it does not provide
value if your project teams are supposed to be able to make their own decisions.
12
©2018 Pegasystems
DCO helps eliminate translation errors, saves the team time and effort, facilitates direct engagement of
business and IT resources around visible working models, and enables project participants to optimally
review work progress.
Pega recommends that all projects leverage DCO as a core part of the delivery process.
13
©2018 Pegasystems
Begin testing early in the project life cycle to drive higher levels of product quality. Test each new
feature or capability to make sure it works. Then, test the system for processing issues that may affect
performance. Also, check to see if the new features work together without error. Finally, have analysts
test the application to make sure the application meets the requirements and business objectives.
14
©2018 Pegasystems
Pega recommends that business architect and project management resources pass the Certified
Business Architect exam. All developers should, at a minimum, pass the Certified System Architect
exam.
15
©2018 Pegasystems
Collaborate with everyone invested in the success of the
project
Collaborate with individuals interested in making your project succeed. Bring business users, business
analysts, and system architects together so they can share their unique skills and viewpoints. For
example, business users and business analysts who have in-depth knowledge of the business process
can help capture accurate requirements as well as design and optimize business processes. System
architects can help provide guidance on the best way to implement a business requirement.
KNOWLEDGE CHECK
What are the possible consequences of not following best practices and guardrails when
designing and building an application on the Pega 7 platform?
When not following best practices, you may spend more time re-creating existing functionality, or
debugging a component that is not well designed. There is also the risk that you will implement a
feature that does not work correctly.
16
©2018 Pegasystems
DESIGNING A CASE LIFE CYCLE
17
©2018 Pegasystems
Designing a case life cycle
Introduction to designing a case life cycle
Case life cycle design is a modeling technique used to describe, in business terms, how a business
application works. Case life cycle design provides a more natural, business-friendly way to develop an
application, and allows business users to interact with a case in the same way they think about it.
After this lesson, you should be able to:
l Explain the relationship between a case and a business outcome
l Explain the purpose of case life cycle design
l Describe the elements of a case life cycle
l Design a case life cycle
Traditional business applications are based on individual transactions and are built as standalone
applications for different departmental functions.
These separate applications make it hard for business users to complete work in a coordinated
manner. When working with separate applications, business users lack the visibility they need to
effectively achieve business outcomes.
18
©2018 Pegasystems
A business view of work
To help business users effectively achieve business outcomes, business users need a way to work in a
coordinated manner. Business applications should function in the same way business users naturally
think about and describe their work.
Business users often think of the work they do — investigating a fraud claim, processing a loan
application or dental claim— as a case.
A case is work that delivers a business outcome. The outcome of a case is a meaningful deliverable
provided to a customer, partner, or internal stakeholder. A deliverable can be processing a health
insurance claim, onboarding a new mortgage, or designing and releasing a new product. In all these
examples, the work to be done can be defined in terms of its resolution (the insurance claim is paid,
the new account is opened, or the new product is released).
Business users understand, and work with the case as it moves from one person to the other, from one
part of the organization to another. What business users are describing is the life cycle of a case —
how they manage the case as it is opened, worked on, and resolved.
In a Pega application, you model repeatable business transactions with case types. A case type is an
abstract model of a business transaction, while a case is a specific instance of the transaction. You can
think of a case type as a template for creating and processing cases. When a new transaction starts, a
new case is created based on the case type definition.
Each case type captures the life cycle of a specific type of transaction, from creation to resolution. A
case type defines data structures, processes, tasks, and user interfaces required for processing the
transaction.
KNOWLEDGE CHECK
19
©2018 Pegasystems
Case life cycle design is a modeling technique Pega uses to describe, in business terms, how a
business application should work. Case life cycle design allows business users to see, and interact with
a case in the same way they think about it.
Cases are organized into high-level milestones, known as stages. Stages are the first level of organizing
the different tasks, or processes required to complete work associated with a case. Stages help to
organize the life cycle of a case around the key events that support the primary goal of the case.
Stages are further organized into processes which define one or more paths the case must follow.
Processes contain a series of actions, or steps that must be completed to resolve the case.
KNOWLEDGE CHECK
The modeling technique used to describe in business terms how a business application
should work is called ______________.
case life cycle design
Stages
A stage is the first level of organizing work in your case. It contains the workflows, or processes, that
users follow before they can move a case to the next phase in the case life cycle.
By capturing business requirements in stages, you get a sense of what needs to be done first, what
must happen in sequence, and what can happen in parallel during case processing. In a case life cycle,
stages that lead to the expected outcome are called primary stages. The sequence of primary stages
is often referred to as the happy path.
20
©2018 Pegasystems
As an example, consider the construction of a new home. If you were asked to organize the tasks
required to build a house into key phases of construction, you might organize the tasks in a series of
three stages. The foundation of any building is always the first phase. Then the house itself — the
frame — is constructed. Finally, the roof is added.
Each stage represents a distinct phase of the home construction case life cycle. In the home
construction example, foundation, framing, and roofing are primary stages that lead to the completion
of the house which is the business outcome.
Alternate Stages
Cases usually progress in order from one primary stage to the next. In some situations, work does not
always go according to plan. When that happens, use an alternate stage to describe the actions
needed to resolve the situation. Alternate stages are used to organize process steps that are not part
of the “normal course of events” but must be available under certain circumstances.
For example, when modeling the life cycle of an online ordering application, you must consider that
orders can be canceled prior to being shipped. If an order is canceled, a number of tasks must be
completed before the order is considered canceled. The first task is to process the order for
cancellation, then the payment must be refunded and, finally the customer must be notified that the
order was canceled.
Use alternate stages to organize the process steps used to manage exceptions from the primary path.
21
©2018 Pegasystems
Organizing stages
Stages typically represent the transfer of the case from one authority to another, or from one part of
the organization to another. Stages may also represent a significant change in the status of the case.
Naming stages
Use names that are most meaningful and relevant to the business users. Use a noun, or noun phrase,
to describe the context of the stage. As much as possible, try to limit the stage name to no more than
two words.
Number of stages
Consider limiting the number of primary stages in any given case to seven and the number of alternate
stages to five. If you find yourself needing more than 10 primary stages or more than 5 alternate
stages, consider combining two or more stages, or using a separate case type.
Tip: There is no minimum number of stages for a case. Focus on maintaining a number of stages less
than the maximum guidelines outlined here.
KNOWLEDGE CHECK
Stage transitions
Stage transitions allow you to further refine the run-time order of stages.
22
©2018 Pegasystems
For primary stages, when all steps in a stage are completed, the default option is an automatic
transition to the next primary stage.
To allow transitions to other stages before the completion of the current stage, you can add a
controlled transition to a stage. Controlled transitions can be configured for any primary or alternate
stage, and can occur either as an action in a step or as a specific step in a process.
You can configure a step to allow a user to select the stage to which the case transitions. This type of
configuration is most useful for steps that require a Yes/No decision. For example, a case worker must
review a request and can either approve or reject the request. If the request is approved, normal
processing continues, and the case advances to the next step or stage in the primary path. If the
request is rejected, the case advances to a predefined stage, which may or may not be in the primary
path.
You can use a Change Stage process step to automatically transition the case flow to a specified stage.
This type of configuration is most useful for automating transitions to and from alternate stages. For
example, a rejected request is sent back to the originator to be updated. The process steps for
updating the request are organized in an alternate stage. When the Change Stage step is encountered,
the case flow automatically transitions to the stage defined in the Change Stage step.
23
©2018 Pegasystems
Controlling stage transitions
To allow transitions to alternate stages, or before the completion of a stage, you can add a controlled
transition to a stage. Controlled transitions can be added as a process step using the Change Stage
smart shape, or as an optional user action in a process step.
6. In the Stage drop-down list, indicate which stage the case transitions to when the Change Stage
shape is executed.
24
©2018 Pegasystems
Use the Approve/Reject step to control the stage to
which a case transitions
Follow these steps to allow a user to select the stage to which a case transitions.
1. In the process where you want to add the Approve/Reject step, click +STEP to add a step.
2. In the palette that is displayed, select the Approve/Reject step to add an approval step.
3. On the Flow tab of the contextual property panel, set the option for If APPROVED then or If
REJECTED then to Change stage, and then select the stage to which the case transitions when the
Approve/Reject step is executed.
25
©2018 Pegasystems
Processes
In a case life cycle, processes are organized within stages and define one or more paths the case must
follow. You add a process to a stage in a case type to define a set of tasks that users accomplish as they
work on a case.
Process steps
A process contains a series of tasks, or steps. A step can be an action that a user performs, an
automatic action performed by the application, or other processes that contain a separate set of
actions.
By organizing related tasks into processes, you can control how, when, and by whom work is performed
in each stage of the case life cycle.
26
©2018 Pegasystems
Consider every process as a distinct action taken to help resolve a case. Every process should have a
goal that can be expressed as a singular outcome.
If more than seven obvious steps are needed, consider breaking down some steps into other
processes.
KNOWLEDGE CHECK
In Pega Platform, _______________ are organized within stages and define one or more paths
the case must follow.
processes
27
©2018 Pegasystems
Adding optional actions
Introduction to adding optional actions
As a user works on a case, situations arise that may require the user to stray from the primary path to
perform a task. You can define optional actions that users can perform while a case is in any stage or
step of the life cycle. By allowing users to choose when additional processing is needed, you can
support out-of-sequence events in a case.
Objectives
At the end of this lesson, you should be able to:
l Explain the role of optional actions in a case
l Differentiate between optional user actions and optional processes
l Add optional actions to a case
Optional actions
Optional actions supplement the tasks users can do as they work on a case. Optional actions enable
users to leave the primary path of a case to complete another task or process. The key is that users
make the determination to execute the optional action; the optional action is not part of the automated
workflow.
For example, a customer gives you a new cell phone number while you are processing the car details of
an Auto Loan. You can use the Update Contact Info optional user action to update the number. By
using the optional user action, you do not need to move the Auto Loan case to an earlier step or stage.
When determining if you need to use an optional user action, consider the following questions:
l Should users be allowed to update information at any time during a case or stage?
l Do you need multiple steps to update information?
l Can information be updated in a single screen?
Optional actions can be made available for a stage or an entire case. By adding an optional action to a
case, the action is available to users while the case is open. By adding an optional action in a stage, the
action is available only in the stage where the action is defined.
You can add two types of optional actions: optional processes and optional user actions. You use an
optional user action to display a single screen to users, whereas you use an optional process to launch
an entire process.
28
©2018 Pegasystems
Optional process
You use an optional process when you need multiple steps to update information. An optional
process allows users to run a new process from within the case. The only difference between an
optional process and the other processes in a case is that users determine when the optional process
executes.
An optional process allows users to perform a series of tasks outside of the primary path of a case.
After completion of the optional process, uses may or may not return to the primary path.
For example, in a commerce application, you could have a Cancel Order optional process that allows a
user to cancel an order as long as it has not shipped.
1. After shopping, a user starts the checkout process. While confirming billing details, a user might
decide to cancel the order. A Cancel Order optional process launches.
2. The Cancel Order process executes. The configuration of the process determines if the case
completes or it transitions back to continue the original flow.
29
©2018 Pegasystems
For example, in an automobile loan application, you want to give the user the ability to change
customer contact information at any time in the case, but you do not want the user to lose their place
in processing the case.
1. A user enters the personal information for a customer. While entering the loan information, the
customer asks to update a cell phone number. The user launches the Update Contact
Information local action.
2. The user completes the Update Contact Information local action.
3. After completing the local action, the user sees the loan information screen.
KNOWLEDGE CHECK
What are the main differences between an optional user action and an optional process?
An optional user action is a single task and typically returns to the primary path of a case, whereas
an optional process is a series of steps that may or may not return to the primary path of a case.
30
©2018 Pegasystems
1. In Pega Express or the Case Designer, select a case type.
2. Click the Workflow tab.
3. Select the Optional actions view to see the optional actions.
4. Click + ACTION in Case wide actions or Stage-only actions, then select the type of optional action to
add.
31
©2018 Pegasystems
Guiding users through a case life
cycle
Introduction to guiding users through a case
life cycle
You can boost operational efficiency by guiding users through the most effective actions to take that
help accelerate results and achieve desired business outcomes faster. Adding work statuses and
instructions helps to keep users informed about the progress of a case. By using these options, you can
help users complete their work more productively.
Objectives
At the end of this lesson, you should be able to:
l Explain how work status adds context to a case
l Update the work status for a case
l Explain how instructions add context to an assignment for a user
l Add instructions to assignments
You would have difficulty determining the status of your online order.
Every case, whether it is an online order, a loan origination request, or an insurance claim, has a status.
The case status is the primary indicator of the progress of a case towards resolution.
32
©2018 Pegasystems
The case status is updated as the case moves through the case life cycle.
For example, a case status of New is assigned to each case when the case is created. As the case
progresses through the case life cycle, the status of the case is updated at each step.
You can set the case status on each step in the case life cycle. When the case advances to a step, Pega
automatically updates the status of the case to the value defined for that step.
Pega includes standard case status values, such as Open, Pending-Approval, and Resolved-Completed.
You can also add custom status values.
33
©2018 Pegasystems
Adding instructions
Imagine you are a loan processing agent. Your company offers car loans, home mortgages, and
personal loans. When it is time for you to work on your next case, you could see many cases with
arbitrary IDs such as B-5, I-23, N-33, G-57, or O-62. Which case do you choose? These case IDs by
themselves give you no help in determining what work you need to perform on those cases. Some
could take five minutes, others could take one hour. Pega solves this problem by allowing an architect
to write an instruction for each step in a process.
An instruction for a step identifies to an user what should be accomplished in an assignment. Users
see instructions in their worklist, when they open a case, or when they are prompted for input in a user
view. For example, in a loan application there is a step for the applicant to supply personal information
to apply for a loan.
When configuring the case, you switch to Designer Studio and add the instruction in the contextual
properties panel so it is clear what work needs to be done on the collect information step.
34
©2018 Pegasystems
Defining user views
Introduction to defining user views
Pega application users perform tasks by entering information in views. In Pega, you can create views
while developing case life cycles.
This lesson shows you how to configure user views and the data elements in those fields while creating
case life cycles.
After this lesson, you should be able to:
l Describe the purpose of a user view
l Define data elements
l Explain how to configure user views and data elements during case life cycle creation
l Configure a user view and its data elements while creating a case life cycle
35
©2018 Pegasystems
Identify the user tasks
You determine the information users need to see or collect in order to perform their specific tasks. You
create a view in which users enter the specified information.
Before you create a view, ask the following questions:
l What fields do users need to see?
l How will users enter values in those fields?
l Can users modify the field values or only read the values?
Record the values users enter in a specification. The following example shows fields for a loan
application form.
36
©2018 Pegasystems
KNOWLEDGE CHECK
Design an intent-driven UI
Provide users with information when they need it. An intent-driven UI shows users what they need to
know to perform a task. The following view of a shopping cart for an online order is an example of an
intent-driven UI. The shopping cart review UI displays only relevant information, such as the intended
items and the number and price of each item.
37
©2018 Pegasystems
Options such as changing the billing address are not relevant in this step. Making an address change
could distract the user from the shopping cart.
Users spend less time searching for relevant information when the intent is the focus of each case life
cycle step.
Design a model-driven UI
Align the user view with the case life cycle to ensure the user interface is model-driven. The following
image of a case life cycle shows each step. The requirements of each step dictate the information in
the view.
A model-driven approach results in faster application development, and a contextually sensitive UI.
Another benefit of the model-driven approach is a UI that can quickly change when business rules
change.
38
©2018 Pegasystems
Keep the UI simple and obvious
The best interfaces are almost invisible to the user. The following view is an example of an almost
invisible interface. It uses meaningful labels that describe the required information.
Minimize data elements to an optimal set that is critical to the task. Focus on what users are trying to
accomplish. Be aware of where users are in the life cycle and the next best action. Users should not
have to guess how to proceed while looking at a view.
Create patterns in language, layout, and design to help users complete their tasks. Design consistency
enables users to recognize similar tasks in other application views.
39
©2018 Pegasystems
Data elements in Pega applications
All applications collect data to use for case processing. Collected data informs decisions on how to best
process and resolve cases. For example, the data in a purchase request case can include the customer
information and line items.
In Pega, you create data elements as you configure user views during case life cycle creation. The data
elements or collection of related data elements in a case type comprise the case type's data model.
The data model defines the case type data structure. A collection of related elements is called a data
type or data object.
The following table shows the data model for a purchase request case.
The purchase request case has a unique identifier, date, customer, list of line items, and total. The
unique identifier, date, and total are single value data elements. The customer and line items are data
objects. A data object or data type contains more than one related property element.
The purchase request has a one-to-one relationship with the customer and a one-to-many relationship
with the line items.
The customer has a name and lists of phone numbers, addresses, and discounts. The name is a single
value element. The name has a one-to-many relationship to the phone number, address, and discount
code elements.
Properties
In Pega, data elements are called properties or fields. Property and field are different names for the
same thing. Properties can be either single value with no intended correlation with any other value, or
a collection of related values. This distinction is explained by the mode of a property. System architects
typically work with two types of property modes: value modes and page modes. Value modes describe
a single piece of information such as a total. Page modes describe a data object such as a customer.
The following screenshot highlights the value and page mode property types.
40
©2018 Pegasystems
Value mode properties
Use value mode for properties with no correlation to other properties. For example, the identifier and
date in the purchase request are value mode properties. There are three value mode properties
available: single value, value list, and value group.
l A single value or scalar property stores text, numbers, dates, Boolean values, and amounts.
l A value list acts as a container for an ordered list of single values. The discount codes property is
an example of a value list. Each code is a single piece of information, but a clear relationship exists
between the codes.
41
©2018 Pegasystems
l A value group acts as a container for an unordered list of single values. The customer's phone
numbers are defined as a value group identifying the contextual meaning of each number: home,
work, or mobile.
When you create a value property, you can assign it to one of 10 different property types. This
identifies the type of information the property stores. By assigning a type to a property, you ensure
that users provide valid information as shown in the following image.
The following table shows a list of property types and the information each type stores.
42
©2018 Pegasystems
Property type Type of data stored Example
Date Calendar date in the format YYYYMMDD 20131202
TimeOfDay Local time in the format HHMMSS 052709
DateTime UTC (Coordinated Universal Time) value normalized to 20131202T052709
Greenwich Mean Time (GMT)
Integer Positive and negative whole numbers, and zero 4
Double Double-precision (64-bit) floating point values (available 23.55
only in Designer Studio)
TrueFalse Boolean value True
Decimal Numbers with a fractional component 32.5
l A page list is a numerically ordered list. The line items that make up the purchase request is an
example of a page list. A page list is also referred to as a field group list.
l A page group is an unordered list. The address property is an example of a page group.
43
©2018 Pegasystems
Note: The page mode properties require you to specify a definition, or a data type, that defines the
structure of the page property.
2. In the Navigation panel on the left, click Cases to view a list of current case types.
3. From the list of available case types, select the case type for which you want to configure a user
view.
44
©2018 Pegasystems
4. Select the step for which you want to configure a user view to display the Contextual Properties
panel for that step. The Contextual Properties panel displays to the right of the case life cycle.
5. In the Contextual Properties panel, click Configure view . The Views configuration page displays.
2. If you require any of the default fields, select the row for the field, and then click the plus sign to the
right of the field name.
Note: After you add the required data elements and save your view, the system adds new data
elements to your application. You can then reuse those data elements when you create new views.
2. Use the Tab key to move to the second field on the row.
45
©2018 Pegasystems
3. Select a data type for the data element. The data type defines how users enter a value in the
UI field.
For example, if you want the user to select a type of loan from a drop-down list in the Loan types UI
field, select Picklist from the drop-down in the data type field as shown in the following image.
The Picklist data type has an additional field for you to choose the type of list (drop-down list or
radio buttons) and the names of the items on the list. To learn how to choose the type of list and to
configure the item names, see the steps under Designing a picklist.
4. Use the Tab key to move to the third field, select either Optional or Required if you want to allow
users to enter a value in a field. If you do not want users to enter or update the field value, select
Read-only. In the following example, the developer is selecting Required to ensure the user selects a
value from the Loan Types list.
5. To add more fields, click Add Field beneath the bottom row.
46
©2018 Pegasystems
2. Click Save to save your changes to the case type.
3. In the upper right corner, click Run to run the application. The new fields in the standard Create
view display.
4. Verify that the fields you selected and created appear in the user view.
Designing a picklist
If you select the picklist data type, you need to use an additional field to choose how to display the list
and the names of the items you want to include on the list. To design the list, do the following:
1. From the end of the row containing the picklist data type, click the Gear icon.
2. In the Display As field, select one of the following:
a. Drop-down list if you want users to select an item from a drop-down list.
b. Radio buttons if you want users to select an item by clicking a radio button.
3. Under List Choices, enter the name of the first list item.
4. Click Add choice to add more fields for items in the list. The following example shows list choices
for loan types.
47
©2018 Pegasystems
5. Click Submit in the dialog box to save your list. The items you entered in the List Choices column
display in the Loan Types drop-down list in the user view.
48
©2018 Pegasystems
Validating case data
Introduction to Validating case data
When you design a user form, you add all the fields and controls required by a design specification.
However, users must enter data that uses a format or contains a value that the system can process
correctly. Pega provides rules that validate the data and help prevent processing errors when a form is
submitted.
After this lesson, you should be able to:
l Identify appropriate options for ensuring valid data entry by users
l Configure controls to require user entry in specific fields
l Explain how controls can satisfy validation requirements
l Configure and apply a validate rule to validate case data
l Apply an edit validate rule to ensure that user data matches required patterns
49
©2018 Pegasystems
Methods of data validation
When you design a view, you add all the fields and controls that the specification requires. You must
also consider how to ensure that the data values entered by users are valid. Valid data is required so
that the system can process the information without error.
The following list describes a few important design requirements.
l The data must be the right type. For example, a user must enter a number in a total purchase
amount field.
l The data must fit the business logic. For example, a date of birth field is usually in the past.
l The data must be restricted to possible values. For example, a user can only select a valid loan type
by selecting the type from a list of options.
To prevent processing errors, Pega provides property types, controls, and rules that support most
validation requirements.
Properties
Single value properties have property types such as date, decimal, integer, text, or true/false. Selecting
the appropriate property type ensures that users enter a valid value. For example, a purchase price
field that uses a decimal property type ensures that users can enter only numeric values and cannot
enter text.
Controls
Controls are another way you restrict users from entering or selecting invalid values on a form. For
example, when a form requires a date, using a calendar control ensures that users enter a date value.
If a user needs to enter free-form text such an address, you would use a text input control.
You can also use controls to allow users to select only valid values. For example, you can use drop-
down lists or radio buttons so that users can select only the available values.
In addition to ensuring valid values, you can make required fields. This ensures that users enter a
value before they can complete an assignment.
KNOWLEDGE CHECK
You have added fields for entering the name and address of a loan applicant. What
validation methods would you use?
Define the name and address properties as text property types.
Validation rules
You use validation rules when you cannot predict or control the value a user enters in a form. There
are two types of validation rules: validate and edit validate.
50
©2018 Pegasystems
Validate rules
You use validate rules to compare a property against a condition when the user submits a form. If the
user enters a value that fails to meet the condition, the form displays an error when the form is
submitted. For example, assume your view contains a field for date of birth. The property type and
control cannot prevent users from entering a date that is in the future. However, you can design a
validate rule to display an error if the user submits a date that is in the future.
Which validation method would be appropriate for checking that a user enters a date for
scheduling a home inspection that is in the future?
A validate rule
51
©2018 Pegasystems
How to validate user data with controls
Controls used on views provide the most common approach to validation. The three basic ways you can
use controls for validation are control types, required fields, and editable settings.
Control types
Using the correct control type for a specific purpose helps users enter valid values. The following table
shows some example use cases for the different control types.
Users must select one of Radio buttons Restrict choices to a set of valid values and
three possible loan types. allows users to select only one value. You can
The user must see all types use radio buttons when only a small number
on the form. of options (for example, fewer than five) is
available.
Users must select one of 10 Dropdown Restricts valid values to the ones that appear
types of office chairs from a in the list. A drop-down list presents the
list. The options do not need options only when the user clicks the control.
to be displayed on the form. This helps reduce the clutter on the form.
Unlike radio buttons, you can configure the
drop-down control so that users can select
multiple values.
Users must select the Autocomplete When a user enters one or more values in the
country in which they reside control, the control filters the available
from a list. The user can options. This helps users find an option in a
enter text in the control to list if there is a large number (for example,
help find the right country. more than 20) of possible options.
Users select an option to Checkbox The user can select the check box or leave it
purchase extra travel blank. This ensures that a true/false property
insurance. is either true (selected) or false (unselected).
52
©2018 Pegasystems
Specifying control types
Most of the fields you add in the Data Model tab in either Pega Express or the Case Designer are
associated with default control types. The control type depends upon the field type you select. The
following table shows some examples.
When working with sections in Designer Studio, you add fields by selecting a control type from a list as
shown in the following image.
53
©2018 Pegasystems
After you add the field, click the gear icon to open the field's Properties panel and specify the
property.
Note that most properties are associated with default control types. For instance, assume you select a
Text Area control. This control is the default for Text property types. However, you specify in the
Properties panel a property that is a TrueFalse property type. The text area control you select overrides
the property's default check box control. In this situation, you may want to add a Checkbox control to
the section rather than a Text Area control for that property.
Note: Pega standard controls are designed to display in the application platform's native format. For
example, a calendar control on an iPhone lets users select a date by tapping it. On the Windows
platform, users select a date by clicking it with a mouse.
For more information about control rules, see the help topic Standard Controls.
KNOWLEDGE CHECK
How would you configure a field in which a user selects one of four possible shipping
methods?
You would use a picklist field and specify either a radio button or dropdown control type.
Required fields
Configuring a control as a required field ensures that the user enters a value. If there is no value, users
receive an error when they try to submit a form. For instance, assume you design a view in which users
enter a date of birth to qualify for a discounted auto insurance policy. You configure the date of birth
number control as a required field. If the user does not enter a date in the field, an error message
appears when the user attempts to submit the form.
54
©2018 Pegasystems
The error message does not appear if there is a date in the field.
55
©2018 Pegasystems
Note: Never and Always correspond to the Optional and Required settings respectively in
Pega Express and the Case Designer. The conditional options can only be configured in a section.
KNOWLEDGE CHECK
Editable settings
You can use editable settings on controls to restrict the input values to valid formats. The settings are
specific to the control type. For example, you can specify the minimum and maximum of characters
allowed in a text input control. You can also specify that users cannot enter dates as text — users must
select a date from a calendar icon control.
56
©2018 Pegasystems
For example, if the user enters fewer than 20 characters, the field displays the following error.
KNOWLEDGE CHECK
How would you ensure that a user always enters 20 characters in a field?
You would use editable settings to set both the minimum and maximum number to 20 characters.
57
©2018 Pegasystems
How to validate case data with validate rules
Property types and the associated controls — for example, a date type property that uses a date picker
control — help ensure valid data entry into user forms. However, these types of validation methods
cannot ensure the input provided by end users conforms to business policies.
For example, two forms may contain the same employee start date property. In a job history form, a
user enters the start date of an employee who already works at the company. The user must enter a
date before the current date. In a new hire form, a user enters a start date for an employee who has
not started work. The user must enter a start date after the current date.
Using two validate rules, one for each business condition, you can ensure that the correct dates are
entered on each form.
Validate rules are often associated with processes. The association between validate rules and
processes enables you to validate the property based on specific business logic. For example, you can
use a single property — in this case, a date type property — and separate the type of property from the
business conditions that affect the acceptable values.
You can also use validate rules in other areas of the case life cycle. For example, you can use a validate
rule on a stage. Use a validate rule to ensure users have entered the correct data or performed all the
processes before the case can enter a specific stage. For example, in a mortgage application, a valid
credit score must be available before the case can enter the underwriting stage.
58
©2018 Pegasystems
KNOWLEDGE CHECK
59
©2018 Pegasystems
Validating a flow action with a validate rule
Validating an input field with a validate rule is a two-step process. First, create and define a validate
rule. Then update the process to execute the validate rule when submitting a user view on an
assignment step. This is done by configuring the flow action rule Pega automatically creates when
adding a Collect information step in your case life cycle. Flow actions provide additional processing
capabilities such as running data transforms and calling validation rules. Flow actions can be accessed
from the Process Modeler or from the Application Explorer under the Process category.
You use Pega Express to validate simple form validations that compare the value of a field to a constant
value and return an error message if the condition is not met. When you use Pega Express to create
simple form validations, Pega Express creates the validate rule and applies the rule to the flow action
that corresponds to the user view.
You use Designer Studio to create more complex validations that require you to manually update the
flow action properties panel.
60
©2018 Pegasystems
KNOWLEDGE CHECK
How is the validation creation process in Pega Express different than the process in
Designer Studio?
First, Pega Express automatically applies the validation rule to the flow action that corresponds to the
user view. Second, Pega Express only supports comparisons against a constant value.
61
©2018 Pegasystems
5. In the Validate form, enter the property you want to test in the Property field. In the following
example, the value for .Employee.StartDate tests when a user enters a date and submits the form.
62
©2018 Pegasystems
8. In the dialog, click Submit.
The Validation form displays your updates as shown in the following example.
9. In the validate form, click Save to complete the configuration of the validate rule.
63
©2018 Pegasystems
4. On the flow action form, open the Validation tab.
5. In the Validate field, select your validation rule IsStartDateInTheFuture.
6. Click Save.
When a user enters a date in the Start date field that is not a future date and submits the form,
your error message is displayed.
KNOWLEDGE CHECK
Why must a validation condition that tests whether a date is in the future or the past be
configured in Designer Studio?
Validating that a date is in the future or the past requires the use of a function.
64
©2018 Pegasystems
How to use edit validate rules
Edit validate rules validate character patterns. For example, assume you want users to enter a valid
email address in a field using a text property type. However, the field cannot verify that the input value
contains an "at" (@) symbol. You can use an edit validate rule to ensure that the field contains the
symbol. If it does not, an error message appears when the form is submitted.
When the email address contains the symbol, the error message does not appear.
65
©2018 Pegasystems
The logic in edit validate rules is written as a Java procedure. Pega provides a large set of the standard
edit validate rules so you do not have to create your own rules.
You can associate a single edit validate rule with a property. You can also reference edit validate rules
in a validate rule. This approach enables you to apply multiple edit rules to a single property.
l To associate an edit validate rule with a property, open the property rule. The property must be a
single value, value list, or value group. Open the Advanced tab and select an edit validate rule in the
Use validate field.
l To use an edit validate rule with a validate rule, open the validate rule. In the Select a function
field, select the function Validation of [Property Name] using [Edit Validate Name]. In the Validation of
field, enter the property you want to validate. Then in the using field, select an edit validate rule.
For more information about edit validate rules, see the help topic About Edit Validate rules.
KNOWLEDGE CHECK
You have added a field for entering a U.S. phone number. Do you use a integer data type
or an edit validate rule to validate that the phone number is in the correct format?
An edit validate rule ensures that the phone number contains the correct number of digits. The
integer data type only ensures that the user enters numbers in the field.
66
©2018 Pegasystems
Managing case-processing
dependencies
Introduction to managing case-processing
dependencies
When coordinating work between parent and child cases, you may need to enforce a dependency
between a parent case and one or more child cases. For example, you may need to prevent users from
advancing a parent case to a new stage until all of its child cases have been resolved. Thus, the
processing of the parent case is dependent upon the processing of the child cases.
After this lesson, you should be able to:
l Identify use cases that justify the use of a child case to manage case processing
l Configure a Create Case shape to create a child case during case processing
l Describe the impact of processing dependencies on the case life cycle
l Explain the role of the Wait shape in controlling the case life cycle
l Configure a Wait shape to enforce a case processing dependency
67
©2018 Pegasystems
Case relationships
A business transaction can be complicated and involve multiple cases. For example, consider the new
hire process. During the interview process, the human resources (HR) department opens a Candidate
case for each job applicant. The applicant may be interviewed. If the interview is successful, the
applicant receives a job offer. When the candidate accepts the job offer, HR considers the candidate
hired and is now an employee. The Candidate case is completed and creates an Onboarding case to
prepare for the new employee's start date. In this example, the Onboarding case is independent of the
Candidate case.
Sometimes, the created case is closely related to the original case. In the previous example, part of the
onboarding process is to enroll the new employee in a benefits plan. You create a Benefits Enrollment
case because it is a separate business transaction. The outcome of the transaction is an employee's
benefits plan — a business transaction that is distinct from the onboarding transaction.
However, before an Onboarding case can be approved the Benefits Plan case must be resolved. In this
example, the Onboarding case and the Benefits Enrollment case have a case-subcase relationship. The
system associates the Benefits Enrollment information with the Onboarding case. This allows you to
join this associated information when reporting or auditing Onboarding cases. For example, you can
create a report for a set of employees showing the medical, dental, and vision plans for each employee.
In a Pega application, you can model this case-subcase relationship with a case hierarchy that contains
a top-level case and child case.
l Top-level — A case that does not have a parent case, but can cover, or become a parent of, other
cases.
l Child— A case that is covered by a parent case. When you configure a case as a child case, Pega
maintains a relationship between the parent and child cases. Child cases represent work that must
be completed to resolve the parent.
Note: Use case type records to establish the parent child relationships.
68
©2018 Pegasystems
For example, an Auto Insurance application has a Accident Claim top-level case. The Accident Claim
includes two child cases — Vehicle Damage and Bodily Injury. For any Accident Claim case, both of its
child cases — vehicle damage and bodily injury — must be addressed before the Accident Claim can
be closed. In addition, reports can associate a parent case with any or all of its child cases.
A parent case creating multiple child cases allows for work to be processed in parallel. Each child case
can be handled by different parties with different expertise. When processing child cases in parallel,
the parent case may need to wait until a child case is complete before the parent case can be resolved.
Under the cover of an Accident Claim case, the Vehicle Damage child case can be handled between a
customer service representative, an adjustor, and a repair shop. Meanwhile, the Bodily Injury child
case can be handled by a medical claim specialist and certain medical providers.
Implementing a business process in a separate case type also allows you to reuse the case type as
needed. For example, claims for both automobile and property insurance may involve a bodily injury
claim. By implementing bodily injury claims as a separate case type, you can use the bodily injury case
type with both automobile and property claims.
KNOWLEDGE CHECK
69
©2018 Pegasystems
How to enforce a dependency between case
types
You can enforce dependencies between parent and child cases with the Wait step. When a parent case
reaches the Wait step, the case pauses until the dependency resolves. Once the dependency resolves,
the case resumes processing.
70
©2018 Pegasystems
KNOWLEDGE CHECK
What are the two ways you can configure a Wait step to pause a case?
You can configure a case to wait for a set amount of time or until a subcase reaches a defined status.
71
©2018 Pegasystems
Adding a child case to a case
You use Pega Express to add child cases to a case. To add a child case to a case type you add a Create
Case step to your case. The Create Case step creates an instance of the configured case type when
the step is executed.
To add a create case shape:
1. In the Case Designer, click + STEP > ... More Utilities > Create Case > Select to add a Create Case
step to the Case life cycle.
2. In the Contextual Properties panel (right side of your screen), configure the step by specifying which
case to create.
72
©2018 Pegasystems
3. Click Save to update the case.
Note: Designer Studio gives you one additional option to create a case as a top level case instead of a
child case.
73
©2018 Pegasystems
MODELING CASE DATA
74
©2018 Pegasystems
The building blocks of a Pega
application
Introduction to the building blocks of a Pega
application
From a business perspective, the key building block of a Pega application is a case. A case is work that
delivers a business outcome, for example, creating an expense report or onboarding a new employee.
From a technical perspective, the key building block of a Pega application is a rule. A rule is an object
that defines the behavior of a case, or part of an application.
When you create a case, Pega will create the rules that provide the required behavior. If you need to
further define that behavior, you can directly modify or create a rule.
You can reuse existing assets (for example, cases and rules) to limit development of new assets. Pega
delivers an impressive array of application assets.
When an application requires new assets, you only need to create key features and functions once.
Pega's inheritance structure lets you reuse the new resources wherever needed in your application.
Eliminating redundant assets simplifies maintaining and extending the application.
In this lesson, you learn how Pega manages rules and how you can reuse rules through application
design and Pega's principle of inheritance.
After this lesson, you should be able to:
l Describe the relationship between an application and rules
l Differentiate between a rule and a rule type
l Explain the principles of rule inheritance and scope
l Differentiate between pattern inheritance and directed inheritance
l Update inheritance for a class
75
©2018 Pegasystems
Rules and rule types
When you play a game of chess, you and your opponent agree to
follow a specific set of instructions. These instructions govern
game play, such as how each piece moves on the game board.
These basic instructions are the rules of chess.
When you model a case type in a Pega application, you
configure the application with instructions to create, process,
and resolve a case. These instructions are rules. Rules describe
the behavior of individual cases. The Pega platform uses the
rules you create to generate application code.
Each rule is an instance of a rule type. A rule type is an
abstract model of a specific case behavior. Pega provides many
rule types. For example, Pega provides one type of rule to
describe a process flow, and another type of rule to describe an
automated email notification.
You can think of a rule type as a template for creating a rule. When you create a new rule, you first
select the rule type, which determines the properties that are required to implement the associated
case behavior.
KNOWLEDGE CHECK
Pega provides wizards that create and modify many of the rules in an application for you. For example,
when you configure a case in Pega Express, it generates rules to describe cases, processes, and UI
forms. Much of the work of designing an application can be completed by using these wizards. If you
need more control over how an application creates and reuses a rule, you can access a rule directly in
Designer Studio.
The following screenshot shows an example of a flow rule. Pega Express and the Case Designer create
a flow rule whenever you add a process to a case life cycle.
76
©2018 Pegasystems
The use of individual rules makes your application modular. By describing case behavior with modular,
task-focused rules, you can combine and reuse rules as needed. In this manner, rules are analogous to
classes in Java or other object-oriented programming languages. For example, you create a rule to
describe the content of an email to send to a customer regarding the status of a change of address.
Your application sends an automated email after the customer enters the old and new address. By
creating the message as a separate rule, rather than embedding the message in the case life cycle, you
can update the content of the email without impacting the rest of the business process.
This modularity provides three significant benefits:
1. Versioning – System architects create a new version of a rule whenever case behavior needs to
change. Pega maintains a history of changes to a rule, allowing system architects to review the
change history and undo changes if needed. Since each rule describes a specific case behavior, the
rest of the case remains unaffected. For example, a system architect updates a UI form with
instructions and removes a critical field. You can review the history of the form and revert back to
the version before the changes were made, without changing other rules in the application.
2. Delegation – System architects delegate rules to business users to allow business users to update
case behavior as business conditions change. The business user updates the delegated rule, while
other parts of the application remain unchanged. For example, expense reports that total USD25 or
less receive automatic approval. You create a rule to test whether an expense report totals USD25 or
less and delegate the rule to the Accounting department. The Accounting department can then
update the rule to increase the threshold for automatic approval increases to USD50, without
submitting a change request for the application.
3. Reuse – System architects reuse rules whenever an application needs to incorporate existing case
behavior. Otherwise, you must reconfigure the behavior every time you need the behavior. For
example, you create a UI form to collect policyholder information for auto insurance claims. You can
then reuse this UI form for property insurance claims and marine insurance claims.
Ruleset versioning
System architects collect individual rules into an instance of a ruleset, called a ruleset version. To
update the contents of the ruleset, you create a new ruleset version. Ruleset versioning allows system
architects to easily update applications by providing access to an entire set of rules at once.
Note: If you use Pega Express to develop your application, note that Pega Express manages the
creation of rules for you and identifies the ruleset and version in which to store a rule.
You identify each ruleset by its name and version number. For example, an application to process
expense reports includes a ruleset named Expense. You refer to the ruleset as Expense:01-02-03,
where Expense is the name of the ruleset and 01-02-03 is the version number.
77
©2018 Pegasystems
The version number is divided into three segments: a major version, a minor version, and a patch
version.
l The major version represents a substantial release of an application. A major version change
encompasses extensive changes to application functionality. For example, the Accounting
department uses an application to manage expense reports. If Accounting wants to extend the
application to track employee time off for payroll accounting, you create a new major version of the
ruleset.
l The minor version represents an interim release or enhancements to a major release. For example,
you need to update an expense reporting application to make automatic audit travel
reimbursements. You create a new minor version of the ruleset.
l The patch version consists of fixes to address bugs in an application. For example, you notice that
a field in the current version of an application has an incorrect label. You create a new minor
version to correct the field label.
Each segment is a two-digit number starting at 01 and increasing to 99. Ruleset version numbering
starts at 01-01-01, and increments upward.
Ruleset stack
Each application consists of a sequence of rulesets, called a ruleset stack. The ruleset stack
determines the order in which Pega looks through rulesets to find the rule being used. Each entry in
the ruleset stack represents all the versions of the specified ruleset, starting with the listed version and
working down to the lowest minor and patch version for the specified major version.
Each version of an application contains a unique ruleset stack. This allows an updated application to
reference new ruleset versions that contain updates and new features.
78
©2018 Pegasystems
Bob is a system architect working on the first version of an
application to manage expense reports. Bob creates rules for
the first version of the application, such as processes, UIs, and
notifications. Bob collects these rules into the first version of
the Expense ruleset, Expense:01-01-01.
Months later, Tanya receives an enhancement request to
update a UI in the application to collect extra information from
employees due to a policy change. This update enhances the
rules created earlier by Bob. Tanya creates rules to model this
new behavior in a second version of the ruleset, Expense:01-02-
01. She then uses the Expense:01-02-01 ruleset in the updated
expense reporting application.
Employees who use the first version of the application view the
UI that Bob created. Only employees who use the updated
application view the UI that Tanya created. The ruleset stack for
the first version does not include Tanya's version. This allows
users to use the first version of the application while the second version is in development.
KNOWLEDGE CHECK
A ruleset version is identified with a string of three numbers. What do these three
numbers indicate?
The three numbers used to identify a ruleset version indicate the major version, minor version, and
patch version of the ruleset.
79
©2018 Pegasystems
Note: When you create a rule in Pega Express, Pega Express identifies the appropriate class for you.
You can focus on what you want the rule to do, rather than on how to create the rule. If you need
control over the class, you can use Designer Studio to create the rule. The main reason for switching to
Designer Studio is to create a rule that you plan to reuse in a different application.
A class can also contain other classes. A class that contains
another class is called a parent class, while a class that is
contained by another class is called a child class. A child class
can reuse, or inherit, any of the rules defined for its parent
class.
The work class contains a child class for each case type in your
application. Each child class contains all of the rules unique to
a case type, such as an auto insurance claim. The data class
contains a child class for each data object.
The classes that comprise an application are
called a class hierarchy. The class hierarchy
determines how system architects can reuse
rules within the application. The class hierarchy
consists of several groups of classes:
l Classes that describe a specific case type, such
as expense reports or auto insurance claims.
l Classes that collect common rules and data elements. These classes allow the reuse
of rules at the division and organization level, such as an approval process shared
across the entire IT department.
l Classes from other applications, such as industry-specific Pega applications. You can
use a generic application for policy administration as a base for customizing versions
for different policy types.
l Base classes provided by the Pega platform. These classes contain rules that provide basic
functionality for processing cases. For example, the Pega platform provides data elements that
record who created a case and the time needed to complete an assignment.
Any rule available to an application through the class hierarchy is considered in scope. Rules that an
application cannot access through the class hierarchy are considered out of scope.
Pega names each class to identify the position of the class within the class hierarchy. Consider the
class TGB-HR-Work. Each level of the class hierarchy is separated by a hyphen (-). So TGB-HR-Work is a
child of the class TGB-HR, which is a child of the class TGB.
KNOWLEDGE CHECK
80
©2018 Pegasystems
How to create a rule
When you create a rule, Pega provides you with the New Record form. The New Record form allows you
to create either a rule or a data instance.
Note: When you configure application behavior in Pega Express (for example, when you create a case),
Pega Express creates and manages the underlying rules for you. If you need more control over how a
rule is created and reused, you can create or edit the rule in Designer Studio.
When you create a rule, the New Record form prompts you to provide four pieces of information: rule
type, identifier, class, and ruleset. This information is used to identify the rule uniquely within your
application.
1. The rule type determines the type of behavior modeled by the rule. Each rule type models a
specific type of behavior, such as automated decisions, UI design, or data storage. To model a
process, for example, you use a specific type of rule called a flow rule. You determine the rule type
when you open the New Record form.
2. The identifier identifies the purpose of the rule. For example, to model the process for approving
insurance claims, you use a identifier such as ClaimsApproval. This identifier allows you to
differentiate the approval process from a submission process. Pega determines the identifier from
your entry in the Label field.
3. The class identifies the scope of the rule. You specify the class of a rule in the Apply to field. The
class you select determines the extent of how you can use the rule: within one case type, or across
case types.
81
©2018 Pegasystems
4. The ruleset is the container for the rule. The ruleset identifies, stores, and manages the set of rules
that define an application or a major portion of an application.
The combination of rule type, name, class, and ruleset allows Pega to provide a unique identity for each
rule. This combination allows an application to call the correct rule during case processing, through a
process called rule resolution. With rule resolution, Pega determines the appropriate rule to run
when an application calls a rule.
You can access the New Record form several ways. Based on your choice, Pega provides default values
in some or all of the fields on the form. You can change these values before you create the rule.
After you complete the New Record form, click Create and open to configure the rule behavior.
82
©2018 Pegasystems
Checking out a rule creates a copy of the original rule in your personal ruleset and prevents other
system architects from checking the rule out until you check in your changes.
The personal ruleset occupies the top spot in the ruleset stack. The rules in your personal ruleset
override rules in the rest of the application. This allows you to test your changes to the rule without
affecting other system architects.
In the rule header, click Private to view a list of the rules you have checked out.
Checking in a rule
When you check out a rule, the rule header updates with three new buttons: Save, Check in, and
Discard.
When you finish editing the rule, click Save to save your changes to the checked out rule. This commits
the updated rule to your personal ruleset. After you save the rule, you can test your changes.
After you test the rule and confirm that your configuration works as expected, click Check in to replace
the original rule with the version in your personal ruleset. Unless approval is required, your changes
immediately affect application behavior.
You are not required to check in your changes immediately. You can log off and return to a checked out
rule later or click Discard to remove the rule from your personal ruleset.
Select Private > Bulk actions to check in several records at the same time.
Private edit
A private edit provides a nonexclusive check out of a rule. This allows other system architects to edit a
rule at the same time. Private edits are useful for quick debugging without interrupting development
by other team members. This option is not available in Pega Express.
It is best practice to lock older versions of a ruleset in order to prevent
changes. For rules in a locked ruleset, a lock icon is displayed on the rule
form. To update a rule in a locked ruleset version, save the rule to an
unlocked ruleset version, then check out the rule if necessary.
83
©2018 Pegasystems
How to reuse rules through inheritance
Inheritance allows your application to reuse rules that have already been created for other cases or
applications. By reusing a rule through inheritance, rather than creating an identical copy of the rule,
you reduce development and testing time without sacrificing application quality.
Pega provides two methods for inheriting rules: pattern inheritance and directed inheritance.
Pattern Inheritance
Pattern inheritance describes the business relationship between classes. Pattern inheritance allows
your application to share rules with other applications throughout an organization. The following
image demonstrates a basic pattern inheritance hierarchy.
1. Rules for a specific type of case are stored at the lowest level of the hierarchy. Rules at this level
only affect a single type of case, such as IT service tickets or onboarding requests.
2. The next level is the class group. The class group contains all of the case types in an application. In
the previous image, TGB-IT-Work contains all of the case types for the IT department, while TGB-HR-
Work contains all of the case types for the human resources (HR) department. Rules at this level
affect all the case types in the class group.
3. Above the class group is the division layer. The division layer contains the work, data, and
integration classes for the division.
4. Above the division layer is the organization layer. The organization layer contains all of the classes
for applications across an entire business or other organization. The organization layer often
contains data and integration classes that can be applied across the entire organization.
For example, an organization creates an application to manage IT requests. In this application, you use
a data element to record the due date for the request. The concept of a due date is not unique to IT
requests. Other business processes also use due dates, such as expense reports. If you create the data
84
©2018 Pegasystems
element for the due date in the organization layer, an application used by the Accounting department
to track expense reports can reuse this data element.
KNOWLEDGE CHECK
Directed inheritance
Directed inheritance describes the functional relationship between classes. Directed inheritance
allows your application to reuse rules from classes in other applications and standard rules provided
with the Pega platform. For example, a class that describes automobile insurance policies can inherit
from a class that describes a generic insurance policy, and even the generic case type defined by the
Work-Cover class provided by the Pega platform.
Organizations can get the benefits of reuse by building on existing Pega applications, which are built
on the Pega Platform. For example, directed inheritance allows you to reuse the standard data element
to record the case ID, provided as part of the Pega platform, in your application.
Important: Directed inheritance is the only option that allows an application class to inherit rules
defined for standard Pega classes, such as the Work- or Data- class.
KNOWLEDGE CHECK
85
©2018 Pegasystems
1. An auto claim case, described by the class Inscorp-PA-Work-AutoClaim, references the case ID data
element.
2. The data element is not found in the class Inscorp-PA-Work-AutoClaim, so Pega searches through the
parent classes using pattern inheritance.
3. The data element is not found though pattern inheritance, so Pega searches the parent class
specified by directed inheritance, InsApp-PA-Work-Claim. This class belongs to the generic policy
administration application.
4. The data element is not found in the class InsApp-PA-Work-Claim, so Pega searches its parent classes
using pattern inheritance.
5. The data element is not found though pattern inheritance, so Pega searches the parent class
specified by directed inheritance, Work-Cover-. This class belongs to the Pega platform.
6. The data element is not found in the class Work-Cover-, so Pega searches its parent classes using
pattern inheritance, finally locating the data element in @baseclass.
KNOWLEDGE CHECK
86
©2018 Pegasystems
Data elements in Pega applications
Introduction to Data Elements in Pega
Applications
Pega applications allow users to create, process, and resolve cases. The applications collect data that is
important to the case. Based on the data collected, decisions on how to best process and resolve the
case are made.
For example, if you want to create a case to process a change of address for a customer, you need data.
The data includes the identity of the customer and the new address.
After this lesson, you should be able to:
l Explain the role of the Data Explorer in managing data types
l Reference properties in Pega applications
l Define the components of a data model
87
©2018 Pegasystems
How to manage properties
Pega Platform provides several tools that help manage properties. The tools provide easy-to-use
interfaces that add, update, and remove classes and properties. This section looks at the Data Explorer
and the Data Model tab as well as the property rule form.
88
©2018 Pegasystems
You can extend an existing data type if it only partly meets your needs. For example, you might want to
create an employee data type based on the Party-Person data type. Select a new data type and specify
the data type you want to extend as the parent in the advanced settings. You can use all properties
defined in the parent in addition to the ones you create in your new data type.
KNOWLEDGE CHECK
What data modeling capability is available in Designer Studio but not Pega Express?
The capability to reuse an existing data type.
89
©2018 Pegasystems
The Data model tab
You can use the Data model tab in the Case Designer to add or remove properties from your case type.
Properties are called fields in the Data model tab. In Designer Studio, you can enable Show reusable
fields to display all fields inherited and available in the case type.
The Data model tab for a data type looks very similar.
90
©2018 Pegasystems
Selecting the field type
When creating a new field, you need to specify a type. The options in the list pair the field with a
control in the user interface. The type options are divided into three categories: simple, fancy, and
complex.
The simple types are similar to the property types defined on the property itself. Use a picklist if you
need to display a static list of options to the user. For example, if you want to capture a phone number,
you might want to specify a list of types, such as home, work, and mobile.
The fancy types provide the capability to upload an attachment, show a location on a map, or reference
a user on the system.
Use the complex types to define page and page list properties. A field group is a page and a field
group (list) is a page list.
91
©2018 Pegasystems
The Property rule form
The property rule form contains the property definition. Because a property definition is a rule, it
shares the benefits of versioning, inheritance, and access control that the Pega Platform provides to all
rules.
Prefix Meaning
px Identifies special properties — your application can read but not write to these
properties.
py You can use these properties in your application.
pz Supports internal system processing — the meaning of values may change with new
product releases. Your application can read but not write to these properties.
92
©2018 Pegasystems
How to reference a property
You have learned about two property modes: value and page. Value mode properties store single
strings of data such as text, numbers, or dates. Page mode properties act as a container for value mode
properties. You refer to a property in Pega 7 by prefixing the property name with a period (or dot, ".").
l To refer to a single value property named OrderDate, type .OrderDate.
l To refer to an entry in a value group property, such as the mobile phone number, type .Phone
(Mobile), where Mobile is the group subscript.
l To refer to the first entry in a value list property, such as one of the discount codes, type
.DiscountCode(1), where 1 is the list index.
Page mode properties are similar.
l To refer to a page that contains customer information, type .Customer.
l To refer to an entry in a page group property, such as the work address, type .Address(Work).
l To refer to the third page of a page list that contains purchase request line items, type .LineItems(3).
To refer to a specific property on the page, use the name of the page as a prefix for the property name.
By doing this, you establish an important piece of information about that property — its context. The
context of a page — by itself or as part of a page list or page group — acts as a container for the
properties it contains. If you want the city in the work address, specify .Address(Work).City.
93
©2018 Pegasystems
Defining properties
In Designer Studio, you use the Data Explorer to create or reuse a data type and use the Data Model
tab to manage properties.
3. Select New Data Type if you want to create a new data type, or select Existing Data Type to
include an existing one.
4. Provide a label and description.
94
©2018 Pegasystems
Managing properties in a case or data types
Use the Data Model tab in the Case Designer to add or remove properties from your case type.
Properties are called fields in the Data model tab.
The Data Model tab for a data type looks very similar.
95
©2018 Pegasystems
4. The ID field is automatically populated by the system. You can choose to edit the ID field.
5. Select the type.
6. If you select a field group or field group list, you need to provide a data type in the options field.
Property rules are automatically added, removed, or updated as you use the Data Model tab.
96
©2018 Pegasystems
Reviewing application data
Introduction to reviewing application data
Applications generate large amounts of data. Sources of data include case data, user data, and data
from outside sources. While developing applications, you may need to review the application data for
debugging. Incorrect information can cause errors that lead to undesired results for cases.
In this lesson, students learn how to review application data.
After this lesson, you should be able to:
l Explain how data is stored in memory for use in Pega applications
l Describe the relationship between pyWorkPage and case data
l Explain how the Clipboard tool organizes data in memory
l Use the Clipboard tool to review case data in memory
l Use the Clipboard tool to set values for case data
Each data element is stored in memory on a page. A page is a structure for organizing data elements
in an application. Some pages are created by the system to track user or session data. Other pages are
created by system architects to describe a data object, such as a hotel reservation or a customer.
97
©2018 Pegasystems
During case processing, each page remains in memory in a structure known as the clipboard. The
clipboard is the portion of memory on the server reserved by Pega for the data generated by
applications. The clipboard consists of all of the pages used to track the name-value pairs that
represent case and session data. The clipboard receives its name because pages can be added to or
removed from memory as needed to track case or session data. So, when a value is assigned to a data
element, the data element and its value are said to be on the clipboard.
As you run a process, Pega sends information to the clipboard, adding or removing pages and
properties from memory. Your application uses this information to populate fields on UI forms,
perform calculations, and evaluate decisions.
KNOWLEDGE CHECK
How is information, such as a customer's date of birth, stored in memory for use in a
Pega application?
Information such as the customer's date of birth is associated with a data element. The data
element (property and value) is stored on the clipboard in a structure called a page.
pyWorkPage
When you debug case behavior, you often need to view the case data that is in memory on the
clipboard. Viewing the data on the clipboard can help you identify the cause of the issue. For example,
if a data transform returns an unexpected result, you can review the contents of the clipboard to
determine if one of the input properties has been set with an unexpected value.
The following image shows a list of properties and their values. A data transform that populates the
EmployeeFullName field with the values in the EmployeeFirstName and EmployeeLastName properties
98
©2018 Pegasystems
contains an error. The EmployeeFullName field seems to be pulling the first two letters of the
EmployeeEmail field. Your next debugging step is to examine the data transform.
pyWorkPage stores all the data generated while creating and processing a case. pyWorkPage is a
specific page on the clipboard. For example, pyWorkPage stores data such as the case creation date or
the case ID. An embedded page with pyWorkPage stores data that describes a data type. For example,
if a case uses a data type named Customer, then Customer is an embedded page within pyWorkPage.
Pega Platform writes all the properties that describe the Customer data type — such as first name — to
the embedded page.
When you open a child case, the clipboard also contains the page pyWorkCover. pyWorkCover
contains the case data for the parent case. This enables you to copy data between the parent case and
the child case.
KNOWLEDGE CHECK
pyWorkPage in reports
Each page on the clipboard is an instance of a specific class, including pyWorkPage. When you
configure a report to refer to data on pyWorkPage, you may need to specify the class of the page. If you
omit the class information, Pega cannot obtain property values from the correct page. Pega does not
know if the properties are valid, and the rule that references the properties does not function correctly.
To ensure that the report obtains the correct information whenever you reference pyWorkPage, you
need to specify the class of pyWorkPage.
For example, consider an application to process automobile insurance quotes. To price the quote, you
need to know the accident history of the driver. Each accident record is an instance of a specific data
type. You create a report to return the accident history for a driver and use a filter to return only
accidents for the driver requesting the quote. If the report filter uses the UserName property from
99
©2018 Pegasystems
pyWorkPage, you must tell the report the class for pyWorkPage (for example INSCO-Quotes-Work). This
allows Pega to reference the UserName property and the report filter functions as intended. Otherwise,
Pega assumes that UserName is part of the data type, rather than the case, and the filter does not work
correctly.
KNOWLEDGE CHECK
Why is it important to include class information when you reference data on pyWorkPage?
If you omit the class information, Pega cannot obtain property values from the correct page. Pega
does not know if the properties are valid, and the rule that references the properties does not
function correctly.
The Clipboard tool is organized into three parts: the header, the left pane, and the right pane.
You can use the header to select the thread to view. Each thread corresponds to a unique action
currently managed by Pega. The clipboard contains one thread dedicated to the Designer Studio
environment. Other threads are dedicated to open rule forms. Pega assigns each open case a unique
thread. By assigning each case or action its own thread, Pega ensures that the data for one case or
action does not affect data for another case or action.
The left pane lists each page defined on the clipboard for the selected thread. For each page, the
Clipboard tool identifies the name and class of the page. If a page contains embedded pages, an
expand arrow is displayed to the left of the page name. To view the embedded pages, click the expand
arrow.
Pages on the clipboard are organized into four categories:
l The User Pages category contains pages created due to user action, either directly or indirectly.
User pages contain data related to work being performed in the selected thread. While a user
100
©2018 Pegasystems
processes a case, all the pages used to store data about the case are listed in the User Pages
category. Likewise, when a system architect configures or tests a rule, all the pages that store data
used by the rule are listed in this category. For example, the data you enter onto a form is stored on
the user page pyWorkPage.
l The Data Pages category contains read-only data pages defined by data page rules. Data pages are
persistent pages in memory, used to cache data. This data is often sourced from outside the
application, such as from a third-party or a system of record. For example, your application converts
currency from one type to another, such as converting US dollars to Euros. The conversion rates,
which are determined by the currency markets, are cached to a data page for use by one or more
users of the application.
l The Linked Property Pages contains read-only pages created by linked properties, which contain
information from data objects referenced by a linked property. Linked properties are advanced data
constructs, typically created and configured by Senior System Architects (SSAs) or Lead System
Architects (LSAs).
l The System Pages category contains pages that describe the current user session, such as the
active user and the active application. For example, while a user is logged in to Pega, Pega maintains
a clipboard page containing information about the user, such as their current time zone.
The right pane lists all of the properties defined on the selected page, and their values. In the right
pane, you view data in memory. You can also update property values and even add new properties to
the page to represent data not captured in your application. This allows you to test application
features that rely on data that has not been added to the case type, such as decisions and UI forms.
For example, in an expense report case you want to branch a flow based on the project type. The
application currently lacks a field in the UI to allow the user to select the project type. In this situation,
you can use the clipboard to set a value for the property and verify that the flow branches properly.
When you view data with the Clipboard tool, you see a snapshot of the contents in memory. As you
navigate your process, refresh pages in the Clipboard tool to ensure that the Clipboard tool always
displays current property values and page contents.
KNOWLEDGE CHECK
While testing case behavior for an online shopping application, you want to confirm that the
application properly generates a list of the customer's previous orders when querying the company's
order management system. In which category of clipboard pages would you expect to find the page
that contains this list?
This page should be located in the Data Pages category.
101
©2018 Pegasystems
Setting property values automatically
Introduction to Setting Property Values
Automatically
As you design and implement a case type, you may need to copy or manipulate data. For example, you
may have a requirement to collect an individual’s first and last name, and then combine them into a
full name. In other situations, you may want to set default values for properties.
After this lesson, you should be able to:
l Explain the use of data transforms in an application
l Identify situations in which to set property values automatically
l Explain how data transform superclassing works
l Set initial property values using the pyDefault and pySetFieldDefaults data transforms
102
©2018 Pegasystems
Data transforms
When you create and process a case, you need data. You collect, process, act upon, and present that
data back to the user. Sometimes, you need to copy data from one place to another. Other times, your
data is not in the form you require, so you need to find a way to manipulate that data into an
acceptable form.
In a purchasing application, for example, items are added to a cart and the checkout process begins.
The customer provides a shipping address and credit card information, and is prompted to provide a
billing address.
The shipping address might be the customer's home address — the billing address and shipping
address are likely to be the same. Reusing rather than having to reenter the shipping address is
helpful and more efficient. Similarly, you might collect an individual’s first name and last name, but
need to combine the two into a full name for credit card processing.
103
©2018 Pegasystems
One option for copying and manipulating data is the data transform. The purpose of a data
transform is self-explanatory: it transforms data in the application. This example uses a data transform
to copy the shipping address to another page — in this case, the billing address — and to copy the first
and last name properties into a single property full name.
You can use data transforms in several ways. For example, you can call a data transform from a flow
action rule or from a connector. Also, you can use a special data transform rules — pyDefault or
pySetFieldDefaults — to initialize property values when creating a case. Data transforms can be used
to iterate over page lists or page groups, and copy entire pages at a time.
104
©2018 Pegasystems
How to set values with data transforms
Use a data transform to define how to take source data values — data that is in one format and class —
and turn those values into data of another target format and class. In general, data transformation
involves mapping data from a source to a target as well as performing transformations on that data
required to achieve the intended mapped results.
To use a data transform, you first configure it and then indicate where in the process flow the data
transfer occurs using the Process Modeler.
Next, enter the Target, Relation, and Source. Depending on the selected action, the Target field has a
different meaning. For the Set and Update Page actions, the Target field identifies a property or page
105
©2018 Pegasystems
reference, and the Source column provides an expression that results in a value or values. For the
when action, a when condition needs to be specified.
KNOWLEDGE CHECK
106
©2018 Pegasystems
In the following data transform, the first step checks if the billing address is the same as the shipping
address. If the two addresses are the same, the shipping address is copied to the billing address.
Otherwise, the billing address is set to empty values.
KNOWLEDGE CHECK
To edit the flow rule in the Process Modeler, click Open process.
107
©2018 Pegasystems
Most data transforms occur between assignments. Double-click the connector between the
assignments to open the connector properties panel. In the Connector properties panel, under Set
properties, select Apply Data Transform. The Data transform field is displayed, listing the available
data transforms. Select the appropriate data transfer and click Submit, then save the process.
KNOWLEDGE CHECK
108
©2018 Pegasystems
How to set default property values
When a user creates a case, you may want to set default values for some properties. In an insurance
claim case, you could set the date of loss to today's date. In other situations, you might want to use
data from the operator record — such as the user's organization unit — to initiate property values.
In a development environment, setting default values can also be useful. When you iteratively run a
process to test your changes, using a data transform to enter default values in required fields saves
time.
Pega Platform provides a pair of data transforms (pyDefault and pySetFieldDefaults) that are used to
automatically set default property values and page properties when you create a case.
The first time you create a view for your case type in the Case Designer, Pega Platform creates these
data transforms. You can also create these data transforms manually. When a new case is created, the
pyDefault data transform is invoked by the process. pyDefault then invokes the pySetFieldDefaults data
transform.
Using pyDefault
Configure pyDefault to set default values when a user creates a case. For example, when a user opens a
loan application case, you may want to initialize the application date to the current date and the terms
to 30 years.
To set a default value, configure a row in pyDefault as shown here. You can enter the property in the
Target column and the default value in the Source column.
The following table shows target properties that use a number, a literal constant, and an expression
source value.
KNOWLEDGE CHECK
You are using pyDefault to set the manager property to Sharon Smith. What do you use as
your Target and Source values?
You use the manager property as the Target and "Sharon Smith" as the Source.
109
©2018 Pegasystems
Using pySetFieldDefaults
Similar to pyDefault, you can use the pySetFieldDefaults data transform to set default values for
properties. In addition, you use pySetFieldDefaults to automatically initialize page (field group) and page
list (field group list) properties. When pyDefault invokes pySetFieldDefaults, properties are immediately
available to the case when it is created.
For example, your view may contain fields from a Customer page group that includes first name, last
name, phone number, and email address properties. The pySetFieldDefaults data transform can create
a blank Customer page in the clipboard, which makes the page available to the view. When the case is
created, pySetFieldDefaults sets the .pyLabel property to an empty string which causes the page to be
created on the clipboard. If there were no page, users would not see the view.
Note: Even if the fields are not visible in the UI, the system may need access to the page for
processing the case.
You do not need to update pySetFieldDefaults when you add a page or page list to a view in the Case
Designer. Pega Platform adds these properties for you automatically. You can also use
pySetFieldDefaults to initialize any page properties you create manually outside of the Case Designer.
Example configuration
In the following example, you have created your first view in your case type. The view contains the
Employee page group. The Case Designer creates the pySetFieldDefaults and pyDefault data transforms.
pySetFieldDefaults
To initalize pages used by the view, pySetFieldDefault sets the .pyLabel fields. In this example, the
Target value is .Employee.pyLabel. The default Source value remains empty so that the user sees a
blank form that contains all the fields (such as start date, manager, and department).
You can update pySetFieldDefaults to define default property values. For example, you can set the
default department page property so that Sales is displayed in the Department field when the user
opens the view.
pyDefault
Because the pyDefault data transform is always invoked when a case is created, pyDefault includes the
Apply Data Transform action. This ensures that pySetFieldDefaults is also invoked when a case is
created. This action does not use Relation or Source settings.
110
©2018 Pegasystems
Action Target Relation Source
Apply Data pySetFieldDefaults <NA> <NA>
Transform
KNOWLEDGE CHECK
What action is defined in pyDefault to ensure that pySetFieldDefaults is invoked when a case
is created?
The Apply Data Transform action.
111
©2018 Pegasystems
Data transforms and superclassing
You can combine several data transforms using the superclass feature to set values at multiple levels
of the class hierarchy. For example, you can have a class Claim with a subclass Home. The subclass
Home in turn has a subclass Rental with data transforms at each level that sets default values.
You can set up your data transforms so that common default values are set in the claim class and
specific values are set in the subclasses. Taking advantage of this feature improves the maintainability
of data transforms.
Here, the date of loss and prefix are in the Claim class, address is set in the Home class, and name on
the lease in the Rental class. The system first identifies parents until it reaches the highest parent. In
this case, the highest parent is the Claim class. The system locates and then invokes the data
transforms with the same name in the parent class.
112
©2018 Pegasystems
The system then goes down to the second highest parent and locates the data transforms with the
same name to invoke. Note that the prefix is overwritten.
113
©2018 Pegasystems
Finally, the data transform in the Rental class is invoked. Note that the prefix is overwritten again.
KNOWLEDGE CHECK
What data transform feature do you use when you want to set a different default value for
the same property within a hierarchy of subclasses?
The superclass feature
114
©2018 Pegasystems
You must select the Call superclass data transform option to cause the system to invoke data
transforms of the same name in parent and child classes before the data transform gets invoked itself.
KNOWLEDGE CHECK
When you create data transforms in a class hierarchy and want to use the superclass
feature, how do you name each data transform?
You give each data transform the same name.
115
©2018 Pegasystems
Setting property values declaratively
Introduction to setting property values
declaratively
When a user enters a value in a form, related values can also change. When you buy an item like a
laptop online, you enter the quantity you want to purchase. The system displays the amount of your
order automatically. Declarative processing allows you to easily configure your application so that the
system can automatically update property values such as an order amount.
After this lesson, you should be able to:
l Describe the declarative processing model
l Describe the procedural processing model
l Calculate a property value with a declare expression
l Explain how forward chaining works to update property values
l Explain how backward chaining works to update property values
116
©2018 Pegasystems
Declarative and procedural processing
When a user enters a property value in a form, related values on the same form or on other forms can
change as a result. The application must make the changes automatically so that users see the most
current information. For example, assume you are purchasing a laptop online. On the form, you enter 1
as the quantity. A total order amount field displays the price of one laptop. However, when you change
the quantity to 2, the total order amount automatically doubles. Alternatively, you may want to see
changes to a form only after the user submits the form. Declarative and procedural processing
techniques help you to automate updates to your application.
Declarative processing
Declarative processing allows you to configure your application so that the system automatically
updates property values such as a total order amount. Declarative processing identifies and maintains
computational relationships among properties. When input values change, the declarative process
automatically updates related property values. In the previous example, a declarative process
maintains a relationship between the total order amount property value with the quantity and price
property values. When a user orders laptops, the system multiplies the price of one laptop times the
quantity of laptops to calculate the total order amount.
The primary benefit of declarative processing is that updates occur only when triggered in the
application. You use declarative rules to define the trigger event. The system monitors the application
to determine when a trigger event occurs. Using the previous example, the system is always monitoring
changes to the item quantity property. When the value changes, the system triggers a computation to
update the order total.
The following video describes how declarative processing works and provides an example.
KNOWLEDGE CHECK
A single declarative expression can monitor trigger events no matter where that expression is used in
the application. Declarative processing rules do not depend upon other rules, such as data transforms,
activities, or user interface (UI) rules, to perform updates.
Procedural processing
Procedural processing depends upon rules, such as data transforms, activities, or user interface (UI)
rules, to instruct the application when to look for a trigger event. For instance, to trigger updates to the
order total, you add a data transform to a flow action. When a user enters values, nothing changes
until the user submits the form. The updates are not automatic. The submit process triggers the data
transform to perform the update. In order to make the changes visible to users as they enter values,
you must configure sections to use the data transform to refresh the fields.
117
©2018 Pegasystems
Procedural processing maintenance
Procedural processing is more difficult to configure and maintain than declarative processing. For
example, assume you have designed an Enter Order form that uses a data transform to calculate the
total order amount based on the item price and order quantity. Then, you add a Review Order form to
your application. This form reuses the fields for calculating the total order amount. If you do not add
the same data transform to the Review Order form, the Total order amount is not updated when the
user changes the order quantity from 2 to 3.
In contrast, when you use a declare expression the system monitors changes to the source property
values. In the following example, when a user updates the quantity from 2 to 3 in the Review Order
form, the declare expression recalculates the total.
Pega provides many types of standard declarative rules that support declarative processing. For more
information, see the PDN article Declaratives, Decisions, and Validation.
118
©2018 Pegasystems
KNOWLEDGE CHECK
Which technique should you use if you want to update values when the user submits a
form?
Use a procedural processing by putting a data transform on a flow action.
KNOWLEDGE CHECK
Which technique should you use if you want the total price to update immediately when a
quantity is changed?
Use a declare expression.
119
©2018 Pegasystems
Declare expressions
You most often use declare expressions to calculate and make immediate updates to property values
on user forms. Declare expressions contain an expression and a target property. The expression
calculates and updates the target property value. The expression uses source property values in its
calculation. Referencing a source property used in the expression initiates the calculation. The
calculation then updates the target property value.
For example, assume an office furniture purchase order form includes fields for three target properties
items: chairs, desks, and lamps. Each item has fields in which users select an item and enter the
quantity. A declare expression uses the two source properties, item cost, and quantity to calculate the
target property — item total. The expression multiplies the item cost times the number of quantity to
calculate the item total. When the user changes the quantity, the expression recalculates the item
total.
120
©2018 Pegasystems
KNOWLEDGE CHECK
Declarative networks
You can use a sequence of interdependent declare expressions in a declarative network. A declare
expression in a network can use a target property from another declare expression as a source
property.
For example, assume you added an Order Total field to your purchase order form. This field uses a
declare expression to calculate its target property — order total. The source property in this expression
uses the item total target value.
121
©2018 Pegasystems
When a user updates a Quantity value, the system updates the Order Total value.
Pega provides the Declarative Network Analysis tool to display a list of declarative networks in your
application. Access this tool by selecting the Designer Studio > Process & Rules > Business Rules
menu. For more information about using the Declarative Analysis Network tool, see the help topic
Business Rules landing page.
KNOWLEDGE CHECK
122
©2018 Pegasystems
How to set a property value with a
declare expression
Setting a property value using a declare expression involves three major steps. You first define the
target property — the value that is updated when a declare expression calculation is performed. Then,
you define the computation type. Finally, you define the expression that calculates the target property
value. You can create declare expressions in either the Case Designer or in Designer Studio.
Setting the TotalBenefitCost property to the sum of the PlanCost properties associated with each
insurance plan property selection calculates the total cost of your employee health plan benefit.
You can add the TotalBenefitCost property as a read-only property on case views to show total
employee cost as health insurance plans are selected.
When the user selects a type of insurance plan, the total employee cost automatically updates in the
view.
Note: If the target is a numeric type property, you can perform functions such as sum, average,
minimum, or maximum on numeric items on a page list.
123
©2018 Pegasystems
Creating a declare expression Designer Studio
You enter the target property as a key part of a declare expression rule when you create one in
Designer Studio. The easiest way to create a declare expression is to select the target property in the
Application Explorer. Right-click and select the Define Expression option.
After you have selected a declare expression, on the Expression tab, configure the expression in a row
as shown in the following example. The row consists of three fields. The target property is entered for
you. You select the Computation Type from the drop-down list. You enter the source or sources in the
Expression field.
The drop-down next to the target property field allows you to select the type of computation for the
expression. The default is Value of as shown in the previous example. This means that the source for
the expression is one or more property values. You can select other options. The choices available
depend upon the target property type. Options include the value of the first matching property. You
can also use the result of a decision tree, decision table, or a map value to provide a value.
Note: Value of is the default computation type when you create an declare expression in the Case
Designer.
You enter an expression in the form of a function and its inputs. You can also use the gear icon on the
right side of the field if you want to build your expression using Pega standard functions such as
CompareDates or getLocalizedValue in the Expression builder. For more information on Expression
Builder, see the help topic Building expressions with the Expression Builder.
The declare expression created in the Case Designer for calculating the total benefit cost in the
previous example looks like the following:
Note: You can configure a declare expression to control how it performs its computations in a
declarative network. This feature is discussed in the Forward and backward chaining in declarative
networks topic later in this lesson.
KNOWLEDGE CHECK
Where are the source values entered when creating declare expressions in Case Designer
and Designer Studio?
In Case Designer, the source values are entered in the Calculation field. In Designer Studio, the
source values are entered in the Expression field.
124
©2018 Pegasystems
Forward and backward chaining in
declarative networks
Forward chaining in a declare expression updates the target property value when a source property
value changes. For example, when you display a shopping cart where users add items and need the
cart to reflect the total based on the changes immediately, choose forward chaining. By default, declare
expressions use forward chaining. Declarative networks are commonly designed with declare
expressions that are configured for forward chaining.
Backward chaining in a declare expression means that a target property value is not automatically
updated when other declare expressions in a network update their target values. An expression using
backward chaining only updates its target property when the application references the property by
name. A form, a decision table, or a data transform can reference the property. When the property is
referenced, the expression goes back in the network to reference the source property or properties the
expression needs to update its target.
125
©2018 Pegasystems
Specifying the chaining method
You can specify forward or backward chaining on the Change Tracking tab on the Declare Expression
rule form. Use the Whenever Inputs Change option for forward chaining. There are three backward
chaining options. For example, select Whenever used if you want the declare expression target value
to be updated whenever the property is referenced in a form.
KNOWLEDGE CHECK
When does an expression using backward chaining update its target property?
When the application references the property by name
126
©2018 Pegasystems
If you are only going to display the insurance quote after you collect all the values, use backward
chaining for the home insurance quote expression. When you display the home insurance quote on
the form, the expression performs the update only once. If you use forward chaining, the system
performs the calculation even if the user does not see or need the value.
For more information about declare expressions and chaining, see the help topic More about Declare
Expression rules.
KNOWLEDGE CHECK
127
©2018 Pegasystems
Configuring a work party
Introduction to configuring a work party
Pega applications allow system architects to describe the people and organizations interested in a case
by their role, such as Customer or Manager. Identifying a party to the case by role allows you to
describe their participation in a business process, such as receiving correspondence. For example, you
can notify the Customer party of the status of their insurance claim throughout the claims adjustment
process.
In this lesson, you learn how Pega describes the participants or interested parties for a case, and how
you can design cases to interact with these parties throughout a business process.
After this lesson, you should be able to:
l Explain how work parties are used in an application
l List the standard work party classes available in Pega applications
l Configure a work party for a case type
l Populate a work party with case data
128
©2018 Pegasystems
Work parties
Accomplishing work requires participants with different roles, such as managers, case workers, and
customers. For example, an automobile insurance claim management process includes roles such as
the customer service representative (CSR) who creates the claim, the customer, on whose behalf the
claim is filed, and the claims adjustor, who reviews the claim.
In Pega, you create a work party to describe each role. Work parties allow you to refer to a case
participant by role, without knowing any identifying information. For this reason, applications
commonly use a work party as the recipient of correspondence. Also, work parties are sometimes used
to assign work.
Imagine your automobile insurance claims management process requires an email be sent to every
customer who submits a claim. You would need the email address for every person submitting a claim
in your application. There is no practical way to get this information prior to the claim. Instead, you
model correspondence by role during development and provide the identifying information (in this
case, email address) for each case. So, you configure your claims management process to send an
email to the Customer party to confirm receipt of the insurance claim. For each case, the application
populates the work party with information about the customer submitting the claim, and sends the
email to the correct customer.
In the following image, you see how the work party is defined by a system architect during
development, but the information about the party is provided only at run-time when a user processes
a case.
129
©2018 Pegasystems
KNOWLEDGE CHECK
130
©2018 Pegasystems
How to add a work party to a case
Adding a work party to a case requires you to perform two actions: define the party and populate an
instance of the party at the desired steps in your case workflow. To facilitate this, Pega creates a Work
Parties rule named pyCaseManagementDefault for each case type. To add or modify a work party for a
case type, use the Settings tab on the Case Designer to make your changes under the Parties section.
Behind the scenes, Pega edits the pyCaseManagementDefault work parties rule created in the class of
the case type.
131
©2018 Pegasystems
When you create a work party, consider the following information:
l What type of case participant do you need to model? Is the participant an individual or an
organization? Does the party work on the case, or only receive status updates?
In Pega, work parties derive from the Data-Party class. Data-Party contains rules to describe a party,
such as properties to store identifying information. Pega also provides five child classes that build
upon the rules in Data-Party. These child classes represent specific types of persons and
organizations. The party class for a work party describes the person or entity participating in the
case and determines how the participant interacts with other participants in the business process.
132
©2018 Pegasystems
Data-Party-Com models a business that has a web domain ending in .com, such as a corporation.
Data-Party-Gov models a government agency, such as the Department of Revenue.
Data-Party-Org models a non-profit organization that has a web domain ending in .org, such as a
charity.
Data-Party-Operator models a case participant with a Pega login and represents a case participant,
such as a case worker or case manager.
Data-Party-Person models a case participant who lacks a Pega login, such as a customer. Typically
this class is used to describe a work party that receives correspondence about a case, but who does
not perform any actions on the case.
l What information do you need to know about the party? For example, do you only need the name
and email address, or do you also need to know their marital status?
l How will you obtain the information to populate the party details? Do you expect the user to enter
this information? Can you copy the information from session information or case data?
l Is the information available when the case is created? Or does the information become available
during case processing?
l Are multiple instances of the party associated with the case? For example, does the case involve one
customer or several customers?
133
©2018 Pegasystems
l If you want case workers to provide party information when creating a case, select the Display on
creation option for the party in the Case Designer Parties configuration section. When you enable
this option, Pega automatically presents users with a form to enter the information needed to create
the work party. For example, a CSR must enter customer information to open a new savings account
for the customer. The initial form in the new account case allows CSRs to create a work party using
information provided by the customer.
134
©2018 Pegasystems
Configuring a work party for a case type
In Pega applications, work parties are defined using the work parties rule pyCaseManagementDefault. To
use a work party in a case, use the Case Designer to add the work party for the case type.
135
©2018 Pegasystems
System tasks
One goal of a Pega application is to make a business process more efficient by identifying tasks that
can be automated. Tasks that are good candidates for automation do not require user input or
decisions. For example, you can automate adding a work party provided the application already has
access to the data necessary to define a given work party. You can add automated system tasks as an
additional step in a process. In a step, an orange icon represents the system task.
The Case Designer allows you to directly add over a dozen automated tasks, such as sending an email
or creating a child case. Additional system tasks beyond what is available in the Case Designer can be
added using the Process Modeler, which is available on a flow rule. Whenever you add a process to a
case life cycle in Case Designer, Pega automatically creates a flow rule. The Process Modeler provides
the graphical interface to edit the flow rule, which stores the sequence of events for your business
process.
136
©2018 Pegasystems
The Process Modeler gives you more flexibility to add additional flow shapes that represent a step or
task accomplished as part of the business process. You can sequence the shapes with connectors to
accurately model a business process in your application. Flow shapes are differentiated by color,
symbol, and name. For example, you use a Utility shape to add an automated system action that does
not require any human intervention. The Utility shape allows you to reference an activity that defines
the automated processing to perform.
Below are some common shapes Pega provides that enable you to model your process.
KNOWLEDGE CHECK
137
©2018 Pegasystems
How to add system tasks to process flows
Use Pega Express or Case Designer to add standard processes used to define the case life cycle. You
can then use the Process Modeler to add advanced features to the processes such as automated
system tasks.
138
©2018 Pegasystems
Add a shape using the Flow Shapes menu
1. On the Diagram tab of the flow rule, click the plus icon to open the Flow Shapes menu.
2. Click and drag the Utility shape onto the diagram. A rectangle icon follows the pointer to indicate
where the flow shape is added.
3. Release the mouse button. The Utility flow shape appends to the process with a generic name that
identifies the purpose of the flow shape.
Note: To quickly add a shape to the diagram, click the shape once from the Flow Shapes menu.
After you add the shape to the diagram, drag the shape to the desired position on the diagram.
4. Double click the Utility shape. The Utility properties panel is displayed.
5. Under the Rule text box, enter the name of the activity.
Note: Tab away from the Rule text box to show the list of activity parameters.
6. Enter any parameters as defined by the activity.
139
©2018 Pegasystems
7. Click Submitto save your changes.
140
©2018 Pegasystems
4. Position the pointer over the shape on which you want to end the connector. A green highlight
surrounds the flow shape and the connector points are displayed on the border of the flow shape.
141
©2018 Pegasystems
Exchanging data between cases
Introduction to exchanging data between
cases
When creating and managing cases, applications often copy data values from one case to another. For
example, information about an insured party can be copied from an insurance claim case to a medical
claim child case, or cost information from a set of child cases can be summed on a parent purchase
order case. By sharing information among case types, you can make data-driven decisions.
After this lesson, you should be able to:
l Explain the role of data propagation in case processing
l Explain the role of case calculations in case processing
l Select the appropriate option for passing data from one case to another
l Copy data from one case to another during case processing
142
©2018 Pegasystems
Data propagation
The role of data propagation
Data propagation is the mechanism of copying data within the case hierarchy. By sharing data among
cases, you save time by eliminating the manual task of copying data and you provide relevant
information to caseworkers.
Data propagation ensures that the appropriate information is moved into a child case. The following
image illustrates an example of a purchase request case that initiates an inventory selection child case
when units in stock must be confirmed. In the purchase request case, each line item in the purchase
request contains a product identifier and a quantity. The inventory selection child case then uses the
product identifier and quantity to verify that the units are in stock.
In Pega, data propagation happens on case creation. When you propagate a property from a parent
case to a child case or to a spin-off case, and the property value later changes on the parent case, the
property on the child case or spin-off case does not get updated.
For example, the product identifier is set to 0211 and the quantity is set to 3 in a purchase request.
These values are propagated to the inventory selection child case on creation. If the quantity in the
purchase request later changes to 4, the value is not automatically propagated to the inventory
selection child case. The quantity in the inventory case will remain set to 3. You need to handle the
subsequent synching of data between the cases separately.
143
©2018 Pegasystems
propagate.). For example, you might use a data transform to loop through a list and only propagate
items that were selected.
l In Designer Studio, in the Case Designer, you can create child cases and spin-off cases using the
Create Case step. The Create Case step allows you to copy property values using a data transform.
144
©2018 Pegasystems
Propagating data when creating a case
Data propagation to a child case can be configured in Pega Express, with additional options available in
Designer Studio, using the Case Designer.
Data propagation to a spin-off case is configured in the Designer Studio, using the Case Designer.
4. In the Case type name field, enter a unique name for the case type and click Create. A child case
type is added to your hierarchy of case types.
5. In the properties panel, select Transfer information to new case. The Transfer Information dialog
is displayed.
Important: When you select Transfer information to new case, the selected case type converts
to a child case.
145
©2018 Pegasystems
6. In the Transfer Information dialog, define how data in the current case is propagated to the new
case.
a. Select the check box next to a From field to copy its value from the current case to the new case.
b. Optional: To change which field stores the value in the new case, enter a field name in the To
field.
c. After selecting the fields you want to transfer, click OK.
7. Click Save. The new case is created with the fields propagated from the current case.
146
©2018 Pegasystems
1. In Designer Studio, select the parent case in the Case Explorer.
2. Click the Settings tab, then click Data propagation.
3. Click the child case (for example, Into Benefits Enrollment) to which you want to propagate
properties.
4. In the panel on the right, below Propagated properties, click the Add Property link to select the
properties you want to propagate into the purchase order.
5. If you want to specify a data transform with the data propagation settings, in the panel on the right,
below Propagated properties, select Apply data transform
147
©2018 Pegasystems
4. In the Data transform field, specify a data transform for the case.
You can specify a data transform when creating a spin-off, child, or multiple child cases.
148
©2018 Pegasystems
Updating data for an existing case
When you create a new case, you can configure data propagation to populate the new case with
default properties. When you copy a property from a parent case to a child case or spin-off case, and
the property value later changes on the parent case, the property on the child case does not get
updated.
For example, consider a purchase request that has a child case for each item on the request. The
parent purchase request is changed to reflect a discount for all items. To update the price for each
item, you want to update the discount data on each child case.
You can update a child case, or all the child cases of a parent case, by using the Update a Case smart
shape in the case designer.
By maintaining case information automatically, you can save time and resolve cases more quickly.
Updating an existing case can be configured in Designer Studio, in the Case Designer. This feature is
not available in Pega Express.
Follow these steps to update data for an existing child or spin-off case:
1. In Designer Studio, select the parent case in the Case Explorer.
2. In the Workflow tab, identify the process where you want to update the case data, select the
header, then click Open Process.
149
©2018 Pegasystems
5. Double-click the shape to display the Update a case properties.
150
©2018 Pegasystems
Calculating case values from child case data
Case calculations let you sum values from child cases back to the parent case. For example, consider a
purchase request that generates purchase orders. The parent case is the purchase request. The child
cases confirm the cost for each item on the purchase request. You can configure a case calculation on
the parent purchase request to sum the total cost for all items in the order.
Note: Calculations are configured in Designer Studio, using the Case Designer. This feature is not
available in Pega Express.
Follow these steps to configure calculations on the parent case:
1. In Designer Studio, select the parent case in the Case Explorer.
2. From the Edit case type screen, click the Settings tab.
3. Click Calculations. The Calculations properties are displayed in the right panel.
4. From the right panel, click the Add Calculation link to specify the properties for which you want to
calculate a total for the purchase order.
151
©2018 Pegasystems
5. From the right panel, press the Down Arrow key in Calculated property and select the property in
the parent case that will store the calculated sum. This property should be a single-value property
that is on a top-level page and stores an integer, decimal, or double.
6. From the right panel, click the Case type menu and select the child case. Then press the Down
Arrow key in Property and select the property whose value will be added to the sum. This property
should be a single-value property that is on a top-level page and is the same type as the calculated
property.
7. Optionally, you can add more child case values. Click + Add property to display another row where
you can enter the case type and property (as described in step 6).
152
©2018 Pegasystems
Caching data with data pages
Introduction to caching data with a data page
A data page loads data into memory and stores it on the clipboard, making the data accessible to an
application. By storing the information in a data page, you improve application performance since the
data remains on the clipboard for subsequent access. In addition to improving performance, data
pages also increase maintainability of an application by abstracting the data source.
After this lesson, you should be able to:
l Identify the role of data pages in managing data
l Explain how data pages abstract data from the source
l Explain the life cycle of a data page
l Explain the affects of the scope setting of a data page
l List the sourcing options for a data page
l List the options for refreshing a data page
l Configure a data page
153
©2018 Pegasystems
Data pages
When you create and process a case, you need data. Some data is collected from the user as part of
the case process, while other data is retrieved from the application or from external systems. For
example, if you want to see the claim history for a customer in a claims application, you retrieve
application data. If you need to display customer data held in a system of record, you retrieve data
from an external system.
You use a data page to retrieve data for your application, regardless of the source. Data pages cache
data on demand to a clipboard page and have a scope. The scope defines who can access the data
page. You can make the data retrieved accessible for all applications, or limited to the logged in user or
specific case only.
Every data page defines a refresh strategy. The refresh strategy defines when the data page is
considered stale and needs to be reloaded. Data pages are created and updated on demand. Even if a
data page is considered stale, the page is never reloaded until it is referenced. The available refresh
strategy options depend on the scope of the page.
Data pages can use a variety of sources to load data. A data page provides an abstraction between the
application and data layers. This means that you can use the data page in your application without
knowing the data source. Your application configuration does not need to change if the source does.
For example, you may configure a data page to look up customer data from a database table. If the
154
©2018 Pegasystems
interface to the customer data changes to a REST web service, you only need to change the data page
source and not the application code.
KNOWLEDGE CHECK
155
©2018 Pegasystems
How to configure a data page
Before you create a data page, remember to answer the following questions:
l What is the structure of the data page?
l What is the scope of the data page?
l How is the data page sourced?
l When does the data become stale?
You create a data page for a data type from the Data Explorer. The Data Explorer also shows data
pages already defined for the data type.
A data page rule defines the structure, scope, source, and refresh strategy of the cached data.
Structure
First, you need to specify the structure of your data page. The structure is either page or list. Choose
page if you want to load a single record (such as a single customer). Choose list if you want to load
multiple records (such as a list of insurance claims filed by a customer). The Object type defines the
class of the page or pages in the list.
A data page is typically read-only, but you can set the Edit mode to editable if you need to update the
data page after it has been loaded. Updates to the data page are only local and not propagated back to
the source.
Scope
Next, you need to decide on the scope. You have three options for the scope: thread, requestor, and
node.
l The thread level scope is useful when the data page is context-sensitive to a particular case. For
example, if a customer service representative (CSR) is working on several cases for different
customers, the data page must be defined as thread scope because the customer data should be
limited to a specific case. Setting the scope to thread ensures that the CSR sees only the data
relevant to an individual customer's case. If the data can be shared across cases, then a broader
scope, such as requester or node, should be chosen.
l The requestor scope lets you share data pages for a given user session and is often used when the
data page contains data associated with the logged-in operator. The work list or local weather
information are both examples of data associated with the logged-in operator.
156
©2018 Pegasystems
l The node option makes a single data page instance accessible by all users of the application and
other applications running on a given node. On a multinode system, each Java Virtual Machine
instance has one copy of the node level data page. Node level pages reduce the memory footprint
by storing only a single copy of the data available to all users. Node level pages are an excellent
option for storing common reference data such as currency exchange rates.
Data sources
Then, you need to configure the data sources. For list structures, the sourcing options include,
connector, data transform, report definition, or a load activity. For page structures, the lookup data
source replaces report definition as an option.
Source Description
Connector Use a connector to obtain data from an external data source as specified
by the connector type.
Data transform Use the data transform option to populate a data page using a data
transform.
Report definition Use a report definition to return a list of data objects mapped in the
application.
Look-up Use the look-up to return a specific data object mapped in the
application.
Load activity The activity can be used for special situations where none of the other
options are suitable.
The Request Data Transform and Response Data Transform allow you to map the outgoing and
incoming data to the application data structure.
157
©2018 Pegasystems
Refresh strategy
You configure the Refresh strategy on the Load Management tab. The available reload options
depend on the scope of the page. For requestor or thread pages, you can reload the data for each
interaction or by evaluating a when rule. The data page can also be marked for refresh based on an
elapsed time interval calculated from the last load time. If you combine the Do not reload when and
Reload if older than options, the data page refreshes as soon as either condition is met.
158
©2018 Pegasystems
The refresh strategy for a node level page reloads per interaction and does not reload when options
are not available. Notice the addition of the Load Authorization section prompting you for an Access
Group.
Node level data pages are not executed in the context of a logged-in operator because the data pages
are available for all applications on the node. Instead, an access group is specified to provide the
requestor context used by the system when loading the node level data page.
Data pages load to memory on demand. A data page remains, on the clipboard, in memory to serve
requests without reloading the data. If a data page is configured to reload if older than one hour, the
159
©2018 Pegasystems
page is marked for reload after one hour. It is not reloaded until the next request for the page occurs
following the configured time.
KNOWLEDGE CHECK
When you configure a data page, you define the structure as either a page or a list. What
other components do you need to define?
A data page rule defines the structure, scope, data source, and refresh strategy of the cached data.
160
©2018 Pegasystems
Configuring a data page
You create and configure a data page by creating the data page, configuring the data page definition,
and configuring the data source. The configuration varies depending on the requirements for the
application. In this example, you configure a data page that holds customer data for a claim case
handled by a customer service representative. The customer data is retrieved from a SOAP connector.
3. Enter a Label that is descriptive of the data. The system populates the Identifier based on the Label.
You can leave the default Identifier or change this value.
161
©2018 Pegasystems
4. Select a Context. The system uses default values in the Apply to and Add to ruleset fields.
5. Click Create and open. The Edit Data Page screen, where you configure the data page definition, is
displayed.
162
©2018 Pegasystems
4. Set the Scope to Thread because the customer data is specific to a case.
163
©2018 Pegasystems
7. Click Create data source. The data page is created in the Customer data type. When you refresh
the Data Explorer, the Customer data type will show the added data page.
164
©2018 Pegasystems
Managing reference data
Introduction to managing reference data
Applications often require access to reference data. Reference data is used in the case processing, but
is not directly part of the application. Reference data is often used in the user interface to provide
options for the user. For example, a drop-down list for a store can contain a list of store branches for
the user to select from.
Reference data is sometimes retrieved from external systems using connectors. However, in some
cases, the data needs to be stored and distributed as part of the application.
After this lesson, you should be able to:
l Explain the benefits of incorporating reference data into an application
l Explain how local data storage manages reference data in an application
l Incorporate reference data in an application with local data storage
l Configure database access using the External Database Class Mapping Wizard
165
©2018 Pegasystems
How to use reference data
Every application collects data. Sometimes the values for an input field are limited to a set of values.
For example, a customer can typically select standard, express, or next-day shipping options. However,
for a specific product the shipping option might be limited to standard. Reference data defines
permissible values for data fields. Limiting the input values to valid options reduces errors and allows
for automation. Reference data gains in value when it is widely reused and referenced.
Reference data should be distinguished from master data. Master data represents key business
entities, such as customers. Master data contains all the necessary detail — for example, an identifier,
name, address, and date of account creation for a customer. Reference data consists of a list of
permissible options with relevant metadata.
A change to the reference data values may need an associated change in the business process to
support the change. A change in master data is always as part of existing business processes. For
example, adding a new customer is part of the standard business process. Adding a new customer
level — for example, platinum — results in a modification to the business processes to manage
platinum customers.
There are several ways you can use reference data in a Pega application:
l Configure a static list for a limited set of values
l Configure local data storage to store data records for a data type, without having to create or
maintain database tables
l Connect to an external database to retrieve data
166
©2018 Pegasystems
Configure local data storage
A local data storage lets you store data records for a data type, without having to create or maintain
database tables. Reference data stored in local data storage can be packaged and distributed as part
of an application.
You can create local data storage for any data type in Pega Express or Designer Studio. In the selected
data type, you add the properties and specify a property to serve as the unique key for the record.
After you create the local data source, you can add records to the data source.
For example, in Pega Express, in the Office data type, in the Records tab, you can add a record for each
office location.
167
©2018 Pegasystems
The Database Table Class Mapping tool provides a wizard to generate all the artifacts needed to
interact with reference data in an external database. These artifacts include a data class, a database
table instance, and a link between those two artifacts.
The data mapping creates a pass-through from your application to the table in the external database.
When enabled, you can access data in the external database as if the data were within your
application. Using the Database Table Class Mapping tools is preferred when integrating with external
databases.
The SQL connector requires you to write SQL queries to interact with the data in the external database.
Use a SQL connector when you need to perform advanced queries (such as advanced joins), or when
you need to use vendor-specific SQL syntax. Setting up a SQL connector is a Senior System Architect or
a Lead System Architect task. In this course, you use the Database Table Class Mapping tool to set up
your integration.
KNOWLEDGE CHECK
You want to create a list of products and their attributes to distribute with an application.
Which method do you use to create the reference data?
Configure a local data storage and add your data records to the selected data type.
168
©2018 Pegasystems
Defining reference data for a data type
When you create a new data type in Pega Express, you are given the option to use Pega local storage to
store data.
4. Enter the data for the properties. The data persists when you leave the field.
5. Click the Trash Can icon at the end of a row to remove a record.
2. Use the property in a view to display the value. The property uses a data page to access the data
169
©2018 Pegasystems
from local storage.
170
©2018 Pegasystems
Using the external database mapping wizard
Sometimes your application requires access to reference data in an external database. For example, a
purchase application needs access to currency exchange rates. Exchange rate information is stored in
a table in an external database.
The Database Table Class Mapping wizard generates all the artifacts needed to interact with reference
data in an external database. These artifacts include a data class, a database table instance, and a link
between those two artifacts.
The data mapping creates a pass-through from your application to the table in the external database.
When enabled, you can access data in the external database as if the data were within your
application. Using the Database Table Class Mapping wizard is preferred when integrating with
external databases.
Take a look at how you can use the Database Table Class Mapping wizard. The wizard creates a data
class with the data mapping and a database table instance that references the external table.
171
©2018 Pegasystems
The Database Table Class Mapping wizard creates a class and properties. The External Mapping tab on
the class record contains the mapping details.
You can use this class with a data page to make the currency exchange rates available to your
application. In the data page, you can use the lookup feature to fetch an instance or use a report
definition to fetch a list of instances. You can also create additional data pages as needed to filter the
data. Alternatively, you can use the Obj-methods to open, save, and remove rows from the table.
172
©2018 Pegasystems
AUTOMATING BUSINESS POLICIES
173
©2018 Pegasystems
Configuring a service level agreement
174
©2018 Pegasystems
Introduction to configuring a service level
agreement
End users complete assignments and resolve cases to achieve performance milestones such as goals
and deadlines. These milestones are service level agreements (SLAs).
In this lesson, you will learn how to configure service level agreements for goals, deadlines,
notifications, and escalation actions.
After this lesson, you should be able to:
l Explain the purpose of service level agreements in Pega applications
l Identify where in a case life cycle a service level agreements can be applied
l Describe each interval of a service level agreement
l Explain how a service level agreement can trigger an escalation action
l Explain how service level agreements increase assignment urgency
l Configure a service level agreement for an assignment
175
©2018 Pegasystems
Service level rules in Pega Platform
Organizations often establish service level agreements to enforce on-time performance. These
obligations range from informal promises of response times to negotiated contracts. A service level
agreement (SLA) establishes a deadline for work completion. When you establish a goal and deadline
in Pega Express or the Case Designer in Designer Studio, Pega creates a service level agreement rule
for you.
An SLA contains three time interval milestones.
l A goal milestone defines how long the assignment should take. It is typically measured from when
the step or case begins.
l A deadline milestone defines the amount of time the step or case may take before it is late. The
deadline is also measured from when the step or case begins.
l A passed deadline milestone defines when to take further action because the step or case is past
the deadline. The passed deadline interval measures the time that has passed since the deadline
for a still-open assignment.
For example, a company requires that employees submit a record of hours worked within two days of
the end of the work week. This record of hours worked, called a time sheet, allows the Payroll
department to credit the employee for hours worked during the week. Until an employee submits their
time sheet, the Payroll department cannot pay the employee. The company reminds employees to
submit their time sheet, even after the deadline has passed in order to pay the employees.
Unlike the goal and deadline intervals, you can configure the passed deadline interval to repeat a fixed
number of times, or repeat indefinitely until the user completes the assignment. You can continue to
increase the assignment urgency and remind a user of a late assignment. Goal and deadlines intervals
do not repeat.
KNOWLEDGE CHECK
How does the passed deadline interval differ from the goal and deadline intervals?
176
©2018 Pegasystems
Goal and deadline intervals do not repeat. You can configure the passed deadline interval to repeat
a fixed number of times, or repeat indefinitely until users complete the assignment.
You define an urgency between 10 and 100 for each milestone. The higher the value, the higher the
urgency. Typically, the urgency increases as an assignment advances to the next milestone.
The following video describes how SLAs work in Pega.
Service level agreements for processes, stages, and case types often require only goal and deadline
intervals. You configure the goal and deadline intervals in Pega Express. Pega Platform automatically
creates the service level agreement rule based upon the goals and deadline intervals you configure.
Service level agreements for assignments are often more complex. A service level agreement for an
assignment may dictate actions to perform after a deadline passes. For example, a company
establishes a deadline to respond to a customer inquiry in 48 hours. The company notifies a customer
service manager every 24 hours until a representative responds to the customer for any inquiry open
after 48 hours.
A service level agreement for an assignment may also affect the start of the goal and deadline
intervals. For example, a stock brokerage establishes a deadline of two hours to price assets in
customer accounts. Associates cannot begin pricing assets until after the stock market closes for the
day. In this case, the start time for the service level agreement occurs after the stock market closes for
the day. If the stock market closes at 4:30 P.M., the deadline is 6:30 P.M., even if the case reaches the
assignment at 1 P.M..
You configure complex performance obligations using service level agreement rules in Designer
Studio.
KNOWLEDGE CHECK
What capabilities do you gain by configuring a service level agreement rule in Designer
Studio?
You can add behavior for late assignments, and determine when an assignment is ready for users to
perform.
177
©2018 Pegasystems
Adding a service level to a case
You can add service levels to entire cases and to steps within a case using Pega Express and Designer
Studio. The procedure for adding service levels to cases and steps is the same in Pega Express and
Designer Studio. The difference is you can access the service level rule in Designer Studio and change
the default timer start.
178
©2018 Pegasystems
6. Under Goal, in the Increase urgency by field, enter the amount by which you want to increase
urgency.
7. Under Perform actions, select the action for the case to perform, such as notifying the assignee or
manager.
8. Optional. Click the plus sign to the left of Add escalation action and select the additional action, if
an additional action is desired.
9. Under Deadline, in the Days field, enter the deadline in number of days.
10. Optionally, under Deadline, in the HH:MM:SS field, enter the time in HH:MM:SS format, if you
require a specific deadline resolution time.
11. Under Deadline, in the Increase urgency by field, enter the amount by which to increase the
urgency.
12. Under Perform actions, select the action for the case to perform.
13. Optionally click the plus sign to the left of Add escalation action and select the additional action, If
an additional action is desired.
14. Click Save to save your work.
179
©2018 Pegasystems
Assignment urgency
In Pega applications, assignment urgency indicates assignment priority.
Pega applications use the GetNextWork selection algorithm to identify the next user assignments.
GetNextWork takes into account assignment urgency (priority) when selecting the next assignment for
a user. Between two or more assignments that users can perform, GetNextWork favors the assignment
with the highest (greatest) urgency.
For example, a bank representative working in the fraud unit is ready for another assignment. Pega
assigns the representative the fraud task with the highest priority.
Pega caps urgency adjustments at 100. At an urgency value of 100, Pega ignores further urgency
adjustments and continues other actions. For example, If the deadline passes, Pega notifies the
assigned user. If the assignment urgency is 100 at deadline, Pega ignores the urgency increment and
still sends the notification.
You can configure a value to enable a user to increase the urgency of an assignment by running a local
action. For example, a bank representative runs a local action to increase the assignment urgency
when a customer reports a stolen credit card while on vacation.
180
©2018 Pegasystems
Property name Definition Example
assignment ages in a set to 10, which increases
workbasket or worklist, Pega .pxUrgencyAssign to 20. When each
increases the value of interval is exceeded, Pega increases
.pxUrgencyAssignSLA .pxUrgencyAssignSLA as directed by the
according to the service level agreement, which further
configuration of the service increases .pxUrgencyAssign.
level agreement.
.pyUrgencyAssignAdjust Manual adjustment for the A customer service representative (CSR)
assignment urgency. This runs a local action to increase the
value enables a user to urgency of an assignment if a customer
increase the urgency of an reports that their credit card was stolen
assignment by running a while on vacation. The CSR runs the local
local action. action, which increases the value of
.pyUrgencyAssignAdjust to 50. This
increases the overall assignment urgency,
.pxUrgencyAssign, by 50 to increase the
likelihood that the assignment is
completed before other assignments.
The following image illustrates how the urgency value increases as an assignment progresses toward
the goal and deadline. The top row shows the urgency values at each stage — the creation of the work
item — when the assignment is ready, the assignment goal date, the assignment deadline date and the
passed deadline date. The bottom row shows the urgency values at each stage. At work item creation,
the urgency value is 10. When the assignment is ready, the urgency value increases by 10 for a total of
20. At the goal date, the urgency increases by 15 for an urgency value of 35. At deadline, the urgency
increases by 20 for a new urgency value of 55. Finally, if the assignment state is passed deadline, the
urgency increases by 25 for a total value of 80.
181
©2018 Pegasystems
KNOWLEDGE CHECK
What are the three factors that influence assignment urgency value?
The three factors influencing assignment urgency value are the default urgency for the case type, the
urgency calculated from the service level rule, and manual adjustments (if enabled).
182
©2018 Pegasystems
Configuring a service level agreement rule
You add a service level rule to an assignment when you require a passed deadline interval.
183
©2018 Pegasystems
8. If the rule is new, the New Record form opens. Click Create and open to create the service level
agreement rule.
Follow these steps to configure the starting behavior for the service level agreement rule:
1. On the service level agreement rule form, in the Initial Urgency field, enter an initial urgency for
the service level. The assignment urgency increments by the entered value when the assignment is
ready for the user to perform.
2. From the Assignment Ready list, select when the assignment is considered available for a user to
perform.
184
©2018 Pegasystems
3. From the Calculate service levels list, select whether to track the service level intervals against a
fixed interval or against the value of a property. Use a property reference to adjust the intervals for
each case. Use fixed intervals to ensure that the intervals are the same length of time for each case.
Follow these steps to configure the behavior for the goal and deadline intervals:
1. Enter a time for the interval. Depending on the selection in the Calculate service levels list, either
specify the interval using the four fields labeled Days, Hrs, Mins, and Secs, or reference a property
that represents the length of the interval.
2. Optional: click the Only calculate using business days check box to only measure elapsed time for
the interval in business days. Enabling this option prevents Pega from counting non-work days, such
as weekends, against the interval limit. Pega determines non-work days from information in the
user's operator ID record.
3. In the Amount to increase urgency field, enter an urgency adjustment for the interval. The
assignment urgency increases by the specified amount until reaching 100.
4. Optional: click Select Action... to add an escalation action for the interval.
From the Perform Action list, select an escalation action to perform when the interval ends. If
necessary, use the When field to use a when condition or when rule to determine whether to
perform the escalation action.
185
©2018 Pegasystems
The following image illustrates the steps for configuring the behavior for passed deadline interval.
Follow these steps to configure the behavior for the passed deadline interval:
1. In the Limit passed deadline events to field, enter the number of passed deadline events to apply
to the assignment. To apply the passed deadline behavior indefinitely until the assignment is
completed, leave the field empty.
2. Enter a time for the interval. Depending on the selection in the Calculate service levels list, either
specify the interval using the four fields labeled Days, Hrs, Mins, and Secs, or reference a property
that represents the length of the interval.
3. Optional: click the Only calculate using business days check box to only measure elapsed time for
the interval in business days. Enabling this option prevents Pega from counting non-work days, such
as weekends, against the interval limit.
4. In the Amount to increase urgency field, enter an urgency adjustment for the interval. The
assignment urgency increases by this value each time a passed deadline cycle completes, until the
assignment urgency reaches 100. Once the assignment urgency reaches 100, further urgency
adjustments are ignored, though escalation actions are processed. The Passed Deadline interval
repeats if configured to do so.
5. Optional: click Select Action... to add an escalation action for the interval.
From the Perform Action list, select an escalation action to perform when the interval ends. If
necessary use the When field to use a when condition or when rule to determine whether to
perform the escalation action.
6. Click Save to save your configuration.
186
©2018 Pegasystems
Configuring and sending
correspondence
187
©2018 Pegasystems
Introduction to configuring and sending
correspondence
During a business process, organizations often need to communicate with parties associated with a
case. Pega allows you to automate and create timely and clear communication with participants in a
case. This communication ranges from simple notifications of assigned tasks to complex
communications that contain case-specific data and calls-to-action. Adding correspondence to a
business process keeps customers and case workers engaged throughout the case life cycle.
In Pega, you configure emails, letters, fax, and text messages with correspondence rules. You can
configure your application so that the system can send correspondence automatically or enable users
to send correspondence manually. Correspondence rules allow you to add case data to provide richer,
more relevant communication.
After this lesson, you should be able to:
l Explain how correspondence improves a process
l Describe the process for creating correspondence
l Add correspondence to a case type
l Send correspondence while processing a case
l Incorporate case content into correspondence
188
©2018 Pegasystems
Automating case communications
Common reasons for communicating with users
Organizations depend on timely communication to establish a shared understanding of transactions or
assignments.
For example, consider a requirement for an auto claims application in which customers must be
notified when their claims are successfully filed, or anytime the status of the claims changes.
Another common notification requirement is keeping case workers up-to-date. For example, you must
notify case workers when they have a new claim to process. Also, you may want to notify them on the
progress of the previous claim.
Finally, you may have a requirement to communicate with someone who is indirectly involved in the
case, such as an external agency.
To achieve effective communication, answer three simple questions. First, how will the communication
be sent? Second, who is the user that receives the communication? Third, when does the
communication need to be sent?
189
©2018 Pegasystems
Pega defines the following roles for a correspondence:
Role Description
Owner The person who created the case.
Customer The person on whose behalf the case is transacted. This
person may not process the case, but may want — or need
— notification of any changes.
Interested A person who tracks the progress of a case but does not
process the case.
The recipient is identified according to the channel selected, such as an email address for email
correspondence. You can also represent the roles of case participants as parties, such as customer,
owner or interested, and send correspondence to a specific role. Pega then identifies the recipient's
address from the party information.
You are not limited to specifying a single role for a correspondence. For example, you may want to send
a correspondence to the customer and all interested parties. To do this Pega uses something called a
party. A party identifies the recipient of the communication and may contain one or more of these
roles.
190
©2018 Pegasystems
Sending an email from a case
A common use case for sending a correspondence during a case is sending a confirmation email after
the user has completed a series of steps. You probably experienced this many times while completing
a purchase online.
You accomplish this in Pega by adding a Send Email step to your case and then configuring the step.
191
©2018 Pegasystems
How to configure correspondence
Create correspondence rules to define, in HTML, templates for the content of outgoing
correspondence. Each correspondence rule contains text for one type of correspondence such as
email, letter, SMS phone text, or fax. JavaServer Pages (JSP) tags or directives allow correspondence to
incorporate property values and calculations.
Informally, correspondence rules are sometimes called templates, as they define form letters for
property values.
For simple notifications, you might add text directly in the rule. For richer content, you can enter
dynamic fields that reference properties, or rules such as sections, paragraphs, or correspondence
fragments. During flow processing, the system uses the source content in the correspondence rule to
generate a customized message for the recipient.
192
©2018 Pegasystems
To add a Send Email step to the case life cycle, select Utilities > Send Email, and then click Select.
Note: In Designer Studio, the Notifications tab presents additional options to change the subject or
content of the assignment notification.
193
©2018 Pegasystems
Send other types of correspondence
Similar to the Send Email step, you can use a Utility shape in a process flow to automatically send
correspondence. A Utility shape configured with the CorrNew activity offers greater flexibility than the
Send Email step. You can use the activity to send all types of correspondence including mail, fax, and
text messages.
When you add a Utility shape to your process, open the properties panel and select CorrNew in the
Rule field. Select your correspondence rule in the CorrName field as shown in the following example.
When a case reaches the utility, the system sends the Thank you letter correspondence.
194
©2018 Pegasystems
l Click Source to view or update the source as HTML codes. In source mode, you can add HTML
elements and JSP tags directly. For example, you can add the when JSP tag to conditionalize a
portion of the HTML code.
Note: When the correspondence is an email, the outgoing email includes HTML formatting, even if
no HTML elements appear within the source. When the correspondence is phone text, the message
does not contain HTML formatting.
l Click the Insert Property icon to include properties in your application such as pyID, LastName,
and Department. For example, you may want to inform the recipient that the case is currently under
review by the auditing department. You can reference the property .pyID to insert the case ID into
the correspondence, rather than providing a generic message.
l Click the Insert Rule icon to include content in other rules such as paragraphs, sections, and
correspondence fragments. You can also include other correspondence rules.
Note: The Insert Rule icon is available only on the correspondence rule form.
Paragraphs present formatted text that can include colors, fonts, styles, and images. Paragraphs
allow you to reuse content that is used elsewhere. For example, you use a paragraph rule to present
instructions on a form. You can then use that paragraph rule in correspondence to describe the
action the recipient is expected to perform. Referencing shared content ensures that your
correspondence includes the most current version.
Sections allow you to reproduce part or all of a form in the correspondence. Use a section to achieve
greater control over the positioning of content in the correspondence.
Correspondence fragments are useful for reusing boilerplate content, such as a mandatory
disclosure or links to an organization's social media channels.
The editor uses angle << >> brackets to mark properties and rules. During flow processing, these
elements are replaced with the values. The following example shows how the inserted properties
.Office and .Employee.Manager are replaced with case data when the correspondence is sent.
When the correspondence is sent, the system replaces the properties with their values.
195
©2018 Pegasystems
Routing assignments
196
©2018 Pegasystems
Introduction to Routing Assignments
An efficient process design routes assignments to users who can best perform the work. Sometimes,
the correct user is an individual who has a specific role. At other times, anyone in a specific group of
users can perform the assignment. Design your process so that it routes assignments to the best
qualified users. This approach helps ensure that work is done correctly and completed on time.
After this lesson, you should be able to:
l Describe the role of routing in a case
l Explain the role of worklists in routing
l Explain the role of work queues in routing
l Explain the role of a router in routing assignments
l Route an assignment to the appropriate user
197
©2018 Pegasystems
Assignment routing
When processing a case, it is common for more than one person to complete work on the case. For
example, when creating an expense report, an employee creates the report, a manager approves it,
and payroll sends the money — three sets of people work on the same case.
As part of modeling a process you define where the work should go. Assignment steps define the work
to do. The question you need to ask yourself when designing your assignment is: who should do the
work?
You route an assignment to a single user if the current user should perform the task or you know
which user will do the work. For example, you would route to the current user if you have several data
collection screens since the current user would likely perform them all. You would route to a specific
user in the situation where you have an expense report approval process. The user who starts the
expense report can't approve their own expenses. Instead you route the approval task to the manager
of the employee to approve it.
198
©2018 Pegasystems
You route an assignment to a group of users if a set of users could complete the task and it does not
matter which user completes the task. For example, after a user completes an auto insurance claim, it
does not matter which claim processor reviews the claim. The task can be routed to a work queue
where claim processors go to get claims.
199
©2018 Pegasystems
Worklists and work queues
Users complete assignments as a case moves toward resolution. When you configure the router setting
in an assignment, you specify either a specific user or a work queue accessible to a group of users.
Worklists
A worklist is a list of all open assignments, ordered by urgency, for a specific user. For example, an
assignment that requires a human resources manager to approve employee time off requests routes
to the human resources manager's worklist.
Note: Managers can access and assign work to the worklists of users who report to the managers.
Work queues
A work queue is a list of all open assignments, ordered by urgency, for a group of users.
Assignments stay in the work queue until a user associated with the work queue selects an
assignment, or a manager sends an assignment in the work queue to a specific user. For example, any
user who belongs to the benefits work queue can update an employee's medical insurance policy. The
work queue for the employee benefits team receives employee benefit update requests. A user on the
benefits team selects an assignment from the work queue and begins working on the assignment.
The following image illustrates routing for assignment to update customer contact information. The
baskets represent work queues. The first column shows all of the open customer contact update
assignments in the work queue. The second column shows that two team members each took an
assignment from the work queue. The team has four remaining assignments in the work queue. The
last column shows one remaining open assignment in the work queue.
200
©2018 Pegasystems
KNOWLEDGE CHECK
A user accesses assignments from a ___________. Users in a work group access assignments
from a _________________.
worklist, work queue
201
©2018 Pegasystems
Configuring assignment routing
In Pega Express or Designer Studio, you configure routing in the case life cycle. When you configure
routing, you are accessing Pega router rules. Routers contain logic that determines the appropriate
user or work queue based on parameters that you define. Pega provides many standard routers to suit
your specific requirements.
You can assign a task to a user's worklist or to a work queue when you add an assignment step and an
Approve/Reject step. You can also leverage automated routing capabilities that enable you to route
tasks based on criteria that you specify.
The following table describes the routing options available in the Route to list.
202
©2018 Pegasystems
3. Click Save when you have completed your configuration.
3. In the Action field, select either Route to operator or Route to work queue.
4. In the Value field, select a user name or work queue from the list.
5. In the When area, in the Field, Comparator, and Value fields, enter values that define the decision
condition you want the system to evaluate. If the condition evaluates to true, the system assigns the
task to the user or work queue you specified in the Action and Value fields.
203
©2018 Pegasystems
6. In the otherwise area, in the Action and Value fields, enter the user or work queue you want to
assign the task to if the When condition is not true.
The following image shows business logic that routes a task to the Manager if the proposed salary is
greater than USD 100,000. If the proposed salary is less than that amount, the task is assigned to the
Recruiter.
204
©2018 Pegasystems
When you select the Custom option, do the following:
1. In the Assignment type field, select either Work queue or Worklist.
2. In the Router field, select the appropriate router. This displays the router's parameters in the
Parameters area. The available parameters depend upon the router you select.
In the following example, users in the Conduct Phone Screen step must be able to speak French.
The step is configured with a ToSkilledGroup router. For this router, you specify a workgroup that
includes users who are defined as having French as a skill.
205
©2018 Pegasystems
To specify approval process routing:
1. In the case life cycle, select an Approve/Reject step.
2. On the General tab of the contextual step property panel, in the Route to area, select either
Specific user or Work queue.
l If you select Specific user , select one of the following options.
l If you select Work queue, below the Route to field, select the work queue from the list.
3. Click Save to save the changes to the case life cycle.
206
©2018 Pegasystems
User's reporting structure — cascading approval
When you use a cascading approval process, assignments route to managers based on the current
user's reporting structure, or the results of an authority decision table.
To route assignments based on a reporting structure in a cascading approval process:
1. On an Approval Smart Shape, click to display the Approval properties panel to specify the routing
behavior.
2. Under General, in the Approval flow type field, select Cascading.
3. In the Approval based on field, select Reporting structure.
4. In the Approval to be completed by field, select the first person to review the case.
5. Expand the Approval Level section and click an option to indicate how many approvals are
required for each case.
207
©2018 Pegasystems
Approval Description
level option
One The manager specified in the Approval to be completed by field must approve
the case.
All The entire reporting structure, starting with the manager specified in the
Approval to be completed by field, must approve the case.
Custom A variable number of reviewers must approve the case, based on a list of when
conditions.
6. Optionally, if you select Custom, click Update custom levels to display the current custom levels.
7. Click +Add custom approval to display the condition entry window.
8. Enter values in the When and Levels of approval fields. For example, you can require approval by
two managers in the reporting structure when a purchase order exceeds USD 25,000.
9. Click Submit to record the new custom level.
10. Click Save to save the approval configuration.
208
©2018 Pegasystems
4. Optionally, if a decision table for the matrix is unavailable, populate the Page list property field
with the name of a page list that contains a list of reviewers. You can also populate the Approver
property field with a single-value property that provides a unique identity for the reviewers in the
page list.
5. Click Save to save your work.
209
©2018 Pegasystems
Delegating business rules
210
©2018 Pegasystems
Introduction to delegating business rules
Business applications exist to meet the needs of the business. However, business needs can change
frequently — and often unexpectedly. These changes manifest themselves as changes to business
policy, either as updates to internal procedures, or as evolving industry guidelines or government
regulations. Delegating business rules enables you to put a controlled set of business policies under
the control of the business. This enables your business applications to keep pace with changing
business conditions.
After this lesson, you should be able to:
l Explain the benefits of delegating business rules
l Explain the purpose of delegating business rules
l Identify the types of business rules best suited for delegation to business users
l Identify the necessary details for delegating business rules
l Delegate a business rule to one or more business users
211
©2018 Pegasystems
Business rule delegation
Business policies change — sometimes suddenly — in response to internal and external factors. Pega
Platform enables you to design and implement applications that respond to change with agility and
efficiency.
By recording business policies in rules rather than in code — a model-driven approach — an
application can provide a degree of modularity and transparency that can simplify maintenance.
An effective Build for Change® strategy requires application designers to go beyond maintenance
efficiencies. You can delegate responsibility for updating selected parts of each application to business
users. Delegating rule changes to business users helps promote an agile response to continuously
changing business conditions.
Rule delegation can also help reduce the workload for architects of minor, low risk maintenance items
and provide a degree of empowerment to those closest to the day-to-day operations.
This shared responsibility goes a long way towards the success of your applications.
Rule delegation applies to selected rules. For example, an expense report application that requires
additional approvals for amounts over USD 1,000. If the requirement changes to USD 500, someone
must update the appropriate decision logic. Adopting an appropriate delegation strategy improves the
business's ability to adapt an application to changing business conditions.
KNOWLEDGE CHECK
212
©2018 Pegasystems
Best practices for business rule delegation
Establishing guidelines and best practices for rule delegation is critical to a successful rule delegation
strategy.
Consider the following guidelines when adopting a rule delegation strategy:
l Establish a unique access group for the business users to whom you will delegate rules.
l Delegate rules for process items that change repeatedly.
l Delegate rules that are easy for the business user to change.
Rule selection
You determine which rules to delegate based on business needs and ease of business user access.
Selecting a specific rule type determines how to simplify the way a business user changes them. For
example, service level rules provide a set of choices for selection such as sending an email and
transferring an assignment to another user. Decision table rules describe criteria for whether an
action occurs. For example, a loan application processing decision table can indicate the levels of
underwriter review based on certain factors such as income level and credit score.
The Pega Platform rule types you can delegate to business users so that they can access the delegated
rules from their case manager portal are paragraph, decision table, data types that have data records,
correspondence types and service level agreement (SLAs).
The following image shows an example of how HR managers access a delegated course listing and
orientation plan SLA in the Case Manager portal.
213
©2018 Pegasystems
Note: You can delegate other rule types using the Add to favorites action, but managing rules
delegated the Add to favorites action can be cumbersome for business users due to the complexity
of the user experience. For more information about using Add to favorites, see Adding a rule as a
favorite.
KNOWLEDGE CHECK
Rule names
Choose rule names that are meaningful in the business context. A good test of a rule name is to build a
sentence using the rule name, the rule type, and the business logic. If the business users understand
the sentence, then the rule name is meaningful. For example, "Requires cosigner" describes a rule that
requires a loan cosigner with a "when" rule type stating that if a borrower's income is less than
USD32,000, the loan requires a cosigner.
KNOWLEDGE CHECK
Additional considerations
A Pega Business Architect should be aware of the following additional considerations in order to
participate in discussions.
l Consider the environment business users use to manage rules. Managing rules in the production
environment is risky if the rules are poorly structured. A compromise is to use an authoring
environment for rule management. Business users can update and test rules in an authoring
environment without affecting the production environment. You can use the migration wizard to
promote the rules into production.
l Consider providing appropriate training and documentation for future new business users and
current business users.
214
©2018 Pegasystems
How to delegate rules to business users
Rule delegation enables business users to change simple application logic without knowing all of the
related technical details and without involving IT. For example, you can delegate correspondence or
service level agreement rules to a business line manager. The business line manager views the
delegated rules and makes changes in the Case Manager portal.
Several parties collaborate to perform the tasks necessary to delegate rules. The following table lists
the tasks in a logical order to streamline the process.
Note: Task assignments may vary, depending on the business requirements, project team size, and
project location.
215
©2018 Pegasystems
Identify the rules to delegate
In Pega Platform, there are no restrictions on which rules to delegate. However, to be successful, your
rule delegation strategy must consider which rule types are best to delegate. In general, BAs work with
the business users to determine what components of the business logic (which rule types) they want to
maintain.
The best candidates for delegation are the rules most affected by frequently changing business
conditions such as correspondence, paragraphs, decision tables, service level agreements, or when
rules.
Start by delegating a small, focused set of decision rules and correspondence templates. As the
business users become more comfortable with delegation, you can expand the number and types of
delegated rules.
KNOWLEDGE CHECK
216
©2018 Pegasystems
Delegate the rule to the business user access group managing the delegated rule. For example, a
human resources (HR) department may send an email to a new employee prior to the employee's first
day of work. You can delegate the correspondence rule containing the email content to allow HR to
update the email with a revised new hire orientation procedure.
Provide a meaningful title and detailed information about how the delegated rule affects the
application. For example, if delegating a decision table, include a detailed description such as: The logic
in this decision table determines whether a travel request requires additional manager approval. Changing the
logic in this decision table may affect all subsequent travel requests submitted in this application.
Note: To delegate a rule, an operator ID must be assigned to an available role that has the
pxCanDelegateRules privilege. By default, this privilege extends to users assigned to the Administrator
or SysAdm4 access role. If you need to delegate a rule and cannot, contact your Pega Platform system
administrator to confirm that your operator ID has this privilege.
KNOWLEDGE CHECK
217
©2018 Pegasystems
Controlling the flow of a case life
cycle
218
©2018 Pegasystems
Introduction to controlling the flow of a case
life cycle
Pega Platform provides options to control the flow of a case life cycle using business logic. Using
business logic, you can skip stages or processes, run processes in parallel, or select multiple paths
based on information in the case. You can also add multiple outcomes to an assignment, allowing
users to select the appropriate path during case processing.
After this lesson, you should be able to:
l Identify how decision points affect case processing
l Define multiple processing paths in a case life cycle using a decision shape
l Define multiple processing paths in a case life cycle using an assignment shape
l Explain how to skip a process in the case life cycle
l Model parallel processes in a case life cycle
219
©2018 Pegasystems
Conditional paths in a case life cycle
The case life cycle workflow defines the order in which tasks must be completed to move a case closer
to resolution. In Pega Platform, these tasks are represented as steps, encapsulated in one or more
processes. Processes in a case life cycle are implemented as process flow rules.
The following image shows an example of a case life cycle view and a process flow view.
Process flow rules built using Pega Express or Case Designer represent a single, linear path of action
from the beginning of the flow to the end. The steps in a process execute in the order in which they
are defined in the process. If the case life cycle workflow is more complex and requires branching or
skipping of a step, you can add decision shapes to define conditional paths the case may take.
A conditional path is a branch in the life cycle of a case that is contingent upon run-time values. By
defining the business logic decisions that cause a case to follow different paths, you can improve the
flexibility of your application.
For example, you can evaluate an applicant’s credit score in a mortgage loan case to determine
whether the case begins the underwriting process or requires further investigation by a loan officer.
The following image shows the case life cycle view and process flow view for evaluating an applicant's
credit score in a mortgage loan case.
220
©2018 Pegasystems
Because conditional paths are steps in a process, you can quickly transition from the sequential view of
your case life cycle to a comprehensive view of shapes and connectors when you need to define a
decision. You can then use the view of your choice to add steps to each conditional path.
KNOWLEDGE CHECK
221
©2018 Pegasystems
How to model a decision point in a process
Pega Platform enables you to configure processes that follow steps executed in sequence. Some
processes are more complex. They need a decision to advance the case in one of several directions, or
to more than one possible next step. You can model these decision points as automated decisions in a
process flow rule.
Use automated decisions when configuring the application to evaluate business logic conditions by
using data elements defined in the case data model.
Add decision shapes in the Process Modeler by clicking the Plus icon in the diagram tab, then selecting
the decision flow shape.
222
©2018 Pegasystems
Configure the decision shape from its context panel. In Pega Express, define the when conditions that
direct the flow from the context panel. For each when condition, from the Go to drop-down, choose the
shape that achieves the desired flow branching.
KNOWLEDGE CHECK
For which type of decision is the following statement true? The case life cycle does not
differentiate between the branches that result from a decision.
The statement is true for both the automated and manual decisions.
223
©2018 Pegasystems
How to configuring processing for a case
You can configure processes in a case to run only when certain conditions are true, or to run
concurrently with other processes in the stage.
Start process conditions are configured by selecting the process and entering or selecting a condition
in the start when field of the properties panel.
You can add more than one condition. Two or more conditions can be logically joined using the logical
operators AND or OR.
224
©2018 Pegasystems
Note: By default, all processes are configured with the "Always" condition, which always returns a true
result. This default condition ensures that the process is always used in case processing.
If the IT Setup and Facilities Setup processes can run concurrently, they can be configured as parallel
processes. When an Onboarding case is executed, the IT Setup and the Facilities Setup processes run
concurrently. The active assignments in either process can be performed at the same time.
Note: When a user opens the case to perform an assignment in one process, the case may be locked,
preventing another user from performing an assignment in the other process.
Parallel processes can only be configured in Case Designer by adding the first process to the stage,
then selecting Add parallel process from the stage menu.
225
©2018 Pegasystems
KNOWLEDGE CHECK
What is the prime consideration for process order when configuring parallel processes?
Parallel processes do not have a configurable order. The processes you select for parallel processes
must be adaptable to any order.
226
©2018 Pegasystems
Circumstancing rules
Introduction to circumstancing rules
Applications often need to customize behavior to match the needs of a specific situation or
circumstance. For example, a call center may need to enforce one set of performance objectives for
clients with elite status, and a different set of performance objectives for clients without elite status.
In this lesson, you learn how to specialize case behavior through the use of circumstanced rules.
After this lesson, you should be able to:
l Explain how rule circumstancing supports rule specialization
l Differentiate between base rules and circumstanced rules
l Identify the types of circumstancing configurations supported by Pega Platform
l Circumstance a rule
227
©2018 Pegasystems
Situational processing
Business processes must account for exceptions to typical case behavior. Exceptions make a business
process more complex. This complexity makes processes difficult to maintain and update as business
conditions change.
For example, a company promises to respond to customer complaints within one business day. For
customers with silver status, the company promises a response in five hours. Reduced response times
for customers with elite status are exceptions to normal business processing.
Simple exceptions like these can be difficult or impossible to model with a single rule. For example, a
service level only defines one set of service expectations, and an assignment only applies one service
level. To apply three different response intervals, you might design a process with three assignments,
and apply the correct service level to each assignment. If the process changes, you need to update
three assignments instead of one.
Complex exceptions that depend on combinations of factors become difficult to maintain and update.
Consider a bank that offers different promotions that reduce or waive fees for customers who meet
specific conditions.
l A new customer receives 100 commission-free trades for the first three months after opening an
investment account.
l A customer receives a rebate on commissions as long as the daily balance in their investment
account exceeds certain thresholds—but the rebate amount, balance threshold, and number of
rebate tiers vary by account type and country.
l A customer who refers a friend to the bank receives 10 commission free trades per month for six
months.
228
©2018 Pegasystems
A rule that models these commission discounts according to account type, account balance, and
country can become complex. This complexity may lead to configuration errors and dissatisfied
customers.
In Pega applications, you model complex exceptions through circumstancing. With circumstancing,
you create a variant of a rule—such as a decision or a service level—tailored to a specific circumstance.
When an application uses a circumstanced rule, the system determines which rule variant best
satisfies the need. Circumstancing allows you to customize the behavior of your application to address
each exception condition you identify using a collection of targeted rules rather than one complex,
difficult-to-maintain rule.
KNOWLEDGE CHECK
229
©2018 Pegasystems
How to circumstance rules
Circumstancing establishes a baseline for expected case behavior and adds variants to address
exceptions to the behavior. The goal of circumstancing is to create a variant for each anticipated
situation. Pega selects the appropriate variant, or circumstance, to use based on the details of the case.
When you circumstance a rule, you create a set of focused rules to address exceptions to case
processing, rather than one all-encompassing rule. Since each rule focuses on a specific exception,
application maintenance and updates are easier and can delegate to business users. Reusing the rules
you create at the application or enterprise level is also easier.
230
©2018 Pegasystems
Types of circumstancing conditions
You can circumstance a rule according to the value of one or more conditions. You define a condition
based on one variable, multiple variables, or the processing date, then apply the condition to a variant
of the rule. When using the rule, the application evaluates the conditions defined on all the
circumstanced variants. If one of the circumstancing conditions is satisfied, the application uses the
corresponding rule variant. Otherwise, the application uses the base rule.
Pega supports the following types of circumstance conditions.
l Single value — the rule variant is effective whenever the value of a single property satisfies the
circumstancing condition. You specify the property to evaluate a comparison value when
circumstancing a rule. If the value of the property matches the specified value for a case, the
application applies the circumstanced variant of the rule, rather than the base rule.
l Multiple value — the rule variant is effective whenever a combination of property values satisfies
the circumstancing condition. Multiple value circumstances are based on a circumstance template
and circumstance definition. The circumstance template defines the properties on which to
circumstance a rule. The circumstance definition defines the combination of conditions in which
a property uses a variant of a rule. You apply the circumstance template and circumstance
definition to the rule variant. If the case matches a combination in the circumstance definition, the
application uses the circumstanced variant of the rule, rather than the base rule.
l Date property — the rule variant is effective whenever the value of a date property satisfies the
circumstancing condition. This condition can be either a single date or a range of dates. If the value
of the property is later than the specifies date or falls within the range of dates, the application uses
the circumstanced variant of the rule, rather than the base rule.
l As-of date — the rule variant is effective after a certain date, or during a range of dates. After the
specified date or during the specified range, the application applies the circumstanced variant of
the rule, rather than the base rule.
KNOWLEDGE CHECK
What type of circumstancing will a real estate firm use to display a disclosure statement that
varies by both the status and location of the listing?
The real estate firm will use multiple value circumstancing to display the appropriate disclosure for
each listing based on the circumstance template and definition.
231
©2018 Pegasystems
You use a multiple value circumstance to create a rule variant that is effective whenever a combination
of property values satisfies the circumstancing condition. For example, a bank waives account fees for
customers who maintain an account balance of EUR10000. But for customers in Germany, the account
balance must exceed EUR25000. In this situation, you use a circumstance template to define the
properties on which to circumstance the rule. You then use a circumstance definition to specify the
minimum balance and country for the exception — EUR25000 for customers in Germany.
You circumstance on a date property to create a rule variant that is effective whenever the value of a
specified date property satisfies the circumstancing condition. For example, companies often update a
business process in response to business conditions, but must process existing cases under the
previous version of the process. A process goes into effect on January 1 to reflect a more rigorous
review of loan applications. But cases created before this date are to be completed using the old
process. In this situation, you circumstance the updated process based upon the value of the
pxCreateDate property—the date a case was created. If the value of pxCreateDate is a date after
January 1, the application uses the updated process instead of the original process.
You circumstance a rule using an as-of date to create a rule that is effective after a certain date, or
during a range of dates. For example, during December, a retailer offers free shipping on any order
over USD50. During the other months of the year, only orders over USD100 receive free shipping. In
this situation, you apply a date range to the rule that calculates the shipping charge. If a customer
places an order in December, then the application applies the USD50 threshold for free shipping. If the
customer places an order in any other month, the application applies the USD100 threshold instead.
Each variant of a rule applies one type of circumstancing condition, though you can combine
conditions to circumstance a rule.
232
©2018 Pegasystems
Circumstancing a rule
To circumstance a rule, you first create a base rule and then create specialized versions of the rule.
Each version is tailored to a specific exception in case behavior.
Follow these steps to circumstance a rule:
1. Open the base rule.
2. On the base rule, open the pull-down menu on the Save button and select Specialize by
circumstance. The New Record form opens, with two circumstancing options: Template and
Property and Date.
3. On the New Record form, identify the type of circumstance. To circumstance on one variable, select
Property and Date. To circumstance on more than one variable, select Template.
233
©2018 Pegasystems
4. Specify the condition under which the rule is used. The following example shows a service level
circumstanced to run whenever the value of .CustomerStatus is "silver." The value must be entered
within quotation marks.
To circumstance by date, use the following table to configure the circumstancing condition to meet
various business requirements.
234
©2018 Pegasystems
To circumstance by more than one property, specify the circumstance definition and circumstance
template rules that define the combination of conditions. For each circumstanced rule, you must
provide a unique circumstance definition.
You can also review the circumstancing condition for a rule by clicking the Circumstanced link in the
rule header.
235
©2018 Pegasystems
DESIGNING A USER INTERFACE
236
©2018 Pegasystems
Configuring a user form
Introduction to configuring a user form
Good user interface (UI) design considers the impact of device size and how users interact with their
devices. Consider an application with a screen resolution fixed to accommodate a tablet device. Users
with tablets can easily use the application. Users accessing the application with laptops might find the
screen resolution too small to read. Users with mobile phones might not be able to use the application.
Effective UI accounts for all of these interactions.
In this lesson, you learn how to design responsive UI forms and model a user interface form.
After this lesson, you should be able to:
l Explain the role of a section in UI design
l Design responsive UI forms
l Create and configure a section record to model a user interface form
Section rules
Users interact with an application and perform tasks through user forms. A user form can be a data
entry form in which users provide information for filing an insurance claim, a display of the legal terms
and conditions users must accept before opening a bank account, or a list of bank account transactions
during the past month.
In Pega, you build user forms with sections. Sections group information and functionality by context
and purpose. Inside a section, you organize UI elements with layouts. Layouts contain rows and
columns, defining a set of cells. A cell can be empty or contain various fields and controls.
When you create a view in the Case Designer, you are using sections to build the view. By default, the
fields in the section are organized into a layout that contains a single column. When you add an
embedded field such as a field group (list), the list properties are organized into their own section.
The following picture shows several types of layouts. Different layouts arrange UI elements in different
fashions. A column layout arranges items in a set number of columns.
237
©2018 Pegasystems
KNOWLEDGE CHECK
238
©2018 Pegasystems
Design templates
You use design templates to configure section layouts. The templates provide a set of commonly used
UI designs. Using templates makes it easy to add the UI elements to a section without having to
manually configure the layouts. Dynamic layouts are often used in templates. The following image
contains some examples of design templates.
Structurally, a section consists of one or more layouts and embedded sections. These sections enable
you to logically group elements and reuse them in other layouts. The following image shows an
example of a two-column template that contains embedded sections and a field.
239
©2018 Pegasystems
KNOWLEDGE CHECK
As shown in the following example, you can apply a design template to organize fields into one column,
two columns of equal width, or two columns split 70/30 (one column is 70 percent of the available
width and the remaining column is 30 percent).
Note: Additional design templates are available but are not shown here.
240
©2018 Pegasystems
In Pega Express, you can change the design template when running a case by clicking Configure this
view in the upper right corner of the form. In Designer Studio, you can change the design template on
the Design tab of the section rule.
KNOWLEDGE CHECK
For more information on design templates, see the support article Designing sections by using design
templates on the PDN.
Note: After you convert the section, you do not have access to the design templates in the rule form.
Layouts
A layout is a container that governs the positioning of fields. Each design template consists of a single
layout that arranges fields in a specific manner. If a design template does not provide the desired
arrangement of fields, you can configure a section rule by adding layouts manually. Section rules
generally use two types of layouts: dynamic layouts and repeating layouts.
Dynamic layouts
Dynamic layouts arrange items in a flexible form, automatically adjusting to screen size. When the
layout width exceeds the width of the screen, a dynamic layout responds by wrapping controls to the
next line. Wrapping eliminates the need for horizontal scrolling by users viewing the form on smaller
screens, such as mobile devices. Many Pega design templates are built with dynamic layouts.
Note: You can see the dynamic layouts by converting the section to a full section editor.
For example, in a section displaying healthcare coverage for employees, below the Dynamic Layout, a
section defined in another class is included. This included section contains a dynamic layout that
displays the coverage plan information.
241
©2018 Pegasystems
In a dynamic layout, a single item is represented as tabular data. Item arrangement can be one of two
types: inline or inline-grid. The inline arrangement displays items in a row, like words in a sentence.
The inline-grid arrangement displays items in a multicolumn grid. The inline-grid with one column is
equivalent to a stacked format.
Several formats of dynamic layout styles are available, including Default, Stacked, Inline, Inline-grid
double, and Inline-grid triple. You can modify and create additional formats in the skin rule for the
application; however, changing the format in the skin automatically affects all sections using that
format. The following example demonstrates the use of multiple layouts in a single section to position
content for display.
242
©2018 Pegasystems
KNOWLEDGE CHECK
Repeating layouts
When you want to display a collection of data that belongs to a page list or a page group, you use a
repeating layout.
In a repeating layout, several configurations are available including Grid layout, Tree layout, Tree Grid
layout, Repeating dynamic layout, Column Repeat layout, and Tabbed Repeat layout. Data represented
in a linear table is a repeating layout.
However, a repeating dynamic layout is useful when you want to present content in a nonlinear, more
aesthetic format.
Repeating dynamic layouts help you create an interface for displaying data regardless of screen size.
243
©2018 Pegasystems
Controls
Once you create the section, add controls and map the controls to specific data elements. For example,
to book a listing, you can add a button. To set a True/False value, you can add a check box. To enter a
number, you can add a field. To set a date or time, you can add a calendar. For each control, you can
configure the presentation and add an action set as appropriate.
244
©2018 Pegasystems
For more information about dynamic layouts, see the PDN article Using dynamic layouts to create
responsive user interfaces.
245
©2018 Pegasystems
Note: Pega requires that the first (left-most) column be set to primary importance. The remaining
columns can be set to secondary or other importance in any order.
To configure the importance of a column, first click the circle above the column header.
Then, to the right of the column, select the Gear icon to open the Column Properties panel. Finally,
from the Importance drop-down, select the importance setting.
246
©2018 Pegasystems
KNOWLEDGE CHECK
247
©2018 Pegasystems
Creating dynamic content in user
views
Introduction to creating dynamic content in
user views
A simple and focused user interface (UI) is clear and intuitive for users. Users know exactly what to do
right away. Building a dynamic UI is a key component of interactive simplicity. For example, you can
control the display of information in user views. You can hide unneeded fields and reveal them when
required. Dynamic behavior in UI enhances usability and encourages interactivity.
After this lesson, you should be able to:
l Explain the impact of dynamic UI behavior on user experience
l Identify configuration options for dynamic behavior of fields
l Describe how actions sets define UI behavior
l Configure action sets to perform actions in response to user-driven events
248
©2018 Pegasystems
Dynamic UI behavior
In a dynamic user interface (UI), the UI content changes based on users interactions with the content.
These changes reduce the UI to the fields essential for greatest efficiency.
For example, while submitting a loan request, a bank's customers must state marital status. If
applicants select Married, the application displays user entry fields for the spouse or partner name.
Single applicants skip to the next step of the loan process, saving time and effort. The following image
illustrates two UIs. The UI on the left shows the Marital status in the default state of Single. The UI on
the right shows the Martial status set to Married, with additional fields to enter partner information.
Using a dynamic UI has many benefits that lead to a more compelling and modern user experience.
Dynamic UI benefits include the following:
l Real-time response to end-user behavior
l Robust functionality available for most user interactions
l Reduced visual clutter on the screen
l Fewer full page refreshes, resulting in improved UI responsiveness
Dynamic behavior enables application developers to hide portions of the UI until those portions are
needed, and then expose them in response to some trigger, such as a property value falling within an
allowed range, or when the user clicks a button.
Pega Platform automatically creates a section rule for each user view. You configure dynamic behavior
in section rules. You can also create and edit sections manually to meet UI requirements. For example,
configuring a pop-up window to display more information when users click a button.
Note: Dynamic UI design differs from responsive UI design. Dynamic UI relies on configuring what
elements appear on the form. Responsive UI controls how form elements align and shift to match the
display size.
249
©2018 Pegasystems
KNOWLEDGE CHECK
Event-action model
When designing a dynamic UI, you use an event-action model. Think of event and action as a cause-
and-effect pair. For example, an online shopping cart that requires users' shipping and billing
addresses. Users can select a box to indicate that their shipping and billing addresses are the same.
The section for the billing address disappears when users select the box. In this case, selecting the
check box is the event, and hiding the billing address section is the action.
Two types of events exist: property-based events and user events.
l Property-based events occur either when a data value changes or when a value meets specific
criteria.
l A user event occurs when an end user takes some action on the page, such as selecting an option or
clicking on a link.
The following image provides examples of events and actions.
Categorizing events into two types simplifies the event-action concept. In practice, these two event
types often overlap. For example, when a user clicks a button (a user event), the action is to set a
property to a value. That action then triggers a property change event.
250
©2018 Pegasystems
KNOWLEDGE CHECK
251
©2018 Pegasystems
How to configure field attributes for dynamic
display
Controlling the fields displayed on screen removes less important and irrelevant elements. Pega
Platform provides the ability to control how fields display. You can configure field attributes for
dynamic display using Visibility, Disable, and Required settings. Setting options for all three
attributes are similar. The following table defines the settings and their functions.
You use visible when conditions to hide or display data fields based on a value entered by users. In
the following example, users select their marital status from a list in a form. Marital status options are
single, married, and divorced. Depending on the value entered in the Marital Status field, additional
fields may populate the form.
If the user selects Single, no additional fields are displayed.
If the user selects Married, the Date of Marriage and Name of Spouse fields are displayed.
252
©2018 Pegasystems
If the user selects Divorced, the Date of Divorce field is displayed.
KNOWLEDGE CHECK
The Reserve space when hidden option keeps the space surrounding the control open. This
prevents the UI elements on the screen from repositioning when the visible content is displayed.
The Run visibility condition on client option is displayed when you use the If not blank, If not zero, or
Condition (expression) visibility options. When you select the Run visibility condition on client option,
the clipboard page includes all the possible data it can display. The application uses the data on the
page to refresh the section based on the visibility condition. If you do not select this option, the client
must communicate with the server to refresh the section. If the hidden content is not likely to change
during case processing, select Run visibility condition on client. This reduces the number of server
trips and avoids page refreshes.
For Disable conditions, the option Run disabled content on client provides the same benefit as Run
visibility condition on client for the Disable conditions.
KNOWLEDGE CHECK
What is the advantage of selecting Run visibility condition on client and Run disabled
content condition on client?
Configuring Visibility and Disable options to run on the client reduces the number of server trips and
avoids page refreshes.
253
©2018 Pegasystems
Configuring Visible and Disable conditions on a UI
element
Before you begin configuring dynamic attributes for UI elements, identify the UI element target that
you want to dynamically show, hide, or disable. Then, decide at which level (section, layout, or field) to
apply the condition.
Open the configuration panel for the cell containing the marriage date property. Click the Visibility
drop-down and select Condition (expression) to control the visibility of the marriage date property.
Configure the visibility expression for the marriage date property so that the expression value is driven
by the marital status value. Select Run visibility condition on client and then submit the
configuration and save the change.
254
©2018 Pegasystems
This configuration uses the Condition (expression) option. The configured expression for each field is a
value on the perferredcontact property. The following image shows how to configure the Condition
expression to disable the Mobile contact number field when users select Email.
The following image shows how to configure the Condition expression to disable the Email field when
users select Text.
KNOWLEDGE CHECK
What is your first consideration when configuring field attributes for dynamic display?
First identify the UI element target that you want to dynamically show and hide, enable and disable,
or make required before deciding at which level (section, layout, or field) to apply the visible when
condition.
255
©2018 Pegasystems
Action sets
In Pega Platform, you use action sets to configure dynamic UI changes based on the event-action
model.
An action set consists of an event, an action, and (optionally) conditions.
l Event – A trigger performed by users, such as clicking a button, hovering a pointer over a field, or
entering a value in a field.
l Action – A response performed by the system as a result of the user event. For example, when
users click a button, the application creates a case.
l Conditions – Restrictions such as when rules, which can be applied to an event and action
combination. For example, you can configure conditions so that hovering over a field displays a
smart tip message only if the field contains a property value.
Each action set requires at least one event and one action. For example, in an insurance claim
application, you want a text pop-up to display when users hover their pointer over the Date of loss
field explaining the purpose of that field.
The following image shows a smart tip pop-up on a Date of loss field.
You can also create multiple action sets for a single control or layout. Continuing the date of loss
example, depending on how long ago the loss occurred, you also want to change the expected
response time and a few date-related property values. When users change the value of the date field,
the change event triggers a data transform that sets the date-related property values.
You can define action sets for a single control or an entire layout. In most cases, you define action sets
on controls. You configure action sets on the Actions tab of the control's Cell Properties form. For
layouts, configure action sets on the Actions tab of the Layout Properties form.
Note: One or more events can trigger an action and an event can trigger more than one set of actions.
When configuring action sets, avoid configuring conflicting behavior for an event.
The following table shows a few examples of action sets.
Event Action
Click a control such as a Opens a new window
button, link, or icon
Double-click a row in the grid Opens the row in edit mode
Right-click the entire grid Shows a menu
Press the Escape key on the Closes the assignment and returns to the home page
256
©2018 Pegasystems
Event Action
keyboard
Select a value from the state Updates the list of counties
drop-down
Select a check box Unmasks the password
Enter a value in the quantity Calculates the total
field
KNOWLEDGE CHECK
257
©2018 Pegasystems
How to configure an action set for a field
You can configure an action set for common UI controls, such as fields, buttons, and drop boxes. If a
control has an Actions tab, then you can configure an action set for the control. In the following image,
a button control includes an action set. When users hover their pointers over the button, a SmartInfo
pop-up is displayed.
Before you begin, identify the UI control and which event and action to configure. Most events involve a
mouse, cursor, or keyboard. When selecting events, consider how users will interact with the
application. For example, users interacting through a mobile device cannot trigger a hover event.
A control can have more than one action set. Continuing the button control example, you can add an
action that refreshes the form when users click the button, as illustrated in the following image.
258
©2018 Pegasystems
When selecting an action, consider the desired result. You can configure an action to show users
relevant information or enter data in a field. You can also configure an action to start a new process.
KNOWLEDGE CHECK
What are the main considerations when preparing to configure an action set?
The UI control, and which event and action to configure to the control.
259
©2018 Pegasystems
KNOWLEDGE CHECK
How do you configure an action set to occur when the control is in read-only mode?
You use the Applicability drop-down list to configure whether the action set is processed if the
control is displayed in read-only mode, editable mode, or both.
For more information on action sets, see the Help topic Action sets.
260
©2018 Pegasystems
DESIGNING BUSINESS REPORTS
261
©2018 Pegasystems
Creating business reports
Introduction to creating reports
Well-organized and comprehensive reports help users gain insight into the effectiveness of an
application. In this lesson, you will learn how to use the Pega reporting features to assess application
performance against requirements.
After this lesson, you should be able to:
l Describe the role of reports in Pega applications
l Explain how columns and filters affect the results of reports
l Differentiate between business data and process data in reports
l Describe the types of reports for Pega applications
l Describe the symbolic options for report filtering
l Create a report to query and present data
262
©2018 Pegasystems
The role of reports
Pega reporting capabilities allow you to create reports that provide real-time information. Real-time
information is important for two reasons. First, business analysts and work managers use reports to
assess the performance of the application. And second, report information allows users to review or
select items from a list or table while working in an assignment.
When designing reports, knowing what information the user needs and how it will be used is
important. Business analysts can provide you with requirements that you use to create the required
reports. For example, business analysts may want a report that shows the number and dates of
resolved cases so managers can check process performance.
In another example, business analysts may need a report that contains a list of customers and their
purchase orders. So, when a customer calls a customer service representative (CSR) to file a complaint,
the CSR can view the customer's previous orders. To get this information, you create a report that
populates a grid on the user form to display the purchase history for that customer.
Once you have design requirements, you use a report definition to build the report.
Report definitions
Report definitions retrieve records from a database. You use the report definition to specify the data
from each record that you want to include in the report. The report definition retrieves the data from a
database and returns the results in a table of columns and rows. The rows represent records retrieved
from the database. The columns contain the data values in each record that you want users to see. In
the following example, a report definition returns the case ID, employee name, employee hire date, and
office location for onboarding cases.
263
©2018 Pegasystems
Report columns
Report columns define the report's contents. Each column corresponds to a single data element. The
value in the column can be a value property such as a case ID, last modified date, or work status. You
can format the data value in various ways, such as text, currency, or date. For example, you can format
currency properties to include a currency symbol.
You cannot display a page in a column. For instance, if you have an employee data object, you can
return specific properties on the page, but not an entire page.
The following example demonstrates how you would design report definition to support a report
request.
For example, a human resources application processes cases for onboarding newly hired employees.
The organization has three office locations. The facilities manager wants a report to monitor new hires.
The manager wants to see information about new employees so that office space can be prepared for
them. You design a report in the onboarding class that has four columns. Each column includes a
property — case ID, new hire name, date of hire, office location, and salary. When the manager
generates the report, the report populates a list of rows with values for each column.
Defining columns in report definitions is critical to designing reports users need.
Functions
You can use functions in columns to make reports more useful. Functions allow you to calculate
results derived from data in the database. For example, every new hire is evaluated 30, 60, and 90 days
from the start date. A manager wants to see the number of days remaining until each evaluation. The
function calculates the difference between the new hire date and the evaluation date.
Pega provides many standard functions you can use without having to create or customize functions.
The available functions appear in a drop-down list when you open the function option in the report
definition.
Report filters
By default, report queries return all the records that contain data from all the columns. You may want
to only show records that are relevant to your design requirement. For example, your onboarding
application collects information on all new hires. The facilities manager at each location needs a report
that shows when the new hire needs a work space. You use report filters to show only the records your
users need. In this case, the user needs new-hire start dates in the coming month.
A report filter compares a data value in the record against a defined condition. If the comparison
result is true, the report includes the record. If the comparison fails the filter tests, the record is not
included.
264
©2018 Pegasystems
Assume you work for a company with two locations, Atlanta and Boston. You want to create a report of
onboarding cases only for the Atlanta office location. You create a filter in the report that tests whether
the office location for each onboarding case is Atlanta. When you run the report, the filter returns only
cases for the Atlanta office. If the office is in Boston, that office is excluded.
In the previous example, you use a filter to determine an office location. To create the filter, you define
a filter condition in the report definition. A filtering condition is a logical expression that determines
whether a record is included in the report.
The comparison can be an explicit value or the value of a property. For instance, if you want to create a
report that returns open orders for a customer, you can use the .CustomerName property as the
comparison in the filter condition. The returned records show the open orders for each customer. In
the previous example, the filter condition uses a comparison that states "office location equals
Atlanta." Therefore, only records that contain the data value Atlanta are included.
265
©2018 Pegasystems
You can also use more complex conditions such as testing values that are greater than a specified
threshold, like a date. When you use date or date time column data in your filter, you can select time
periods using symbolic dates. Symbolic dates let you select time periods or dates without having to
build functions. For example, you may want to filter all cases created in the previous month. You can
select the Previous Month symbolic option rather than write a function to define the period.
Sometimes you may need to create a more complex filter to capture multiple filtering conditions. You
can use multiple filters by adding AND/OR conditions. For example, assume you want to filter out cases
with a status of Pending and for the manager Anne Walker. You create two filter conditions. One filter
states the cases equal status of Pending. The other filter states that the manager equals Anne Walker.
Use an AND condition so a record must pass both filters in order to be included in the report.
266
©2018 Pegasystems
Business and process reports
To reduce costs, business applications often target performance gains in time and efficiency. Poor
performance, such as long times to complete tasks, may show a poor application design. You need
ways of understanding how complex processes are functioning. For example, you will learn where
bottlenecks are, where there are opportunities to improve response time, and what emerging trends
need attention.
A business report that provides relevant information can show what is happening, what has happened
over a period of time, and how what is happening matches or differs from your plan.
Business reports
An organization can design business reports that describe and measure work. Organizations can use
these business metrics to make informed decisions about improving its business performance. The
application collects data and stores it in a database. The system retrieves the information when users
generate a report.
The following table gives examples of business report information and how the information can be
used in business decisions.
267
©2018 Pegasystems
What is being measured? What is the data? What is the business
decision?
Number of office desks shipped The number of orders shows an As a result, inventory
each week for the past month and upward trend. levels are unacceptably
how many are now in inventory low. The purchasing
department decides to
restock more desks on a
weekly basis.
Process reports
In Pega applications, process reports track statistics on how work is performed. Unlike business
metrics, the application automatically defines and generates process data. Process metrics operate on
Pega Platform parameters. Process reports focus on process metrics that are unique to your case.
Having this information enables business analysts and business managers to discover issues that may
affect processing performance.
The following table gives examples of process report information and how the information can be used
in process design decisions.
268
©2018 Pegasystems
KNOWLEDGE CHECK
A sales manager runs weekly reports on how long it takes to prepare a car for customer
delivery. Which type of report metrics apply to this report?
Business metrics, because how long it takes to prepare a car for customer delivery is not a metric
based on a Pega Platform parameter.
269
©2018 Pegasystems
The Report Browser
Work managers use the Report Browser to search for, organize, schedule, and run reports.
You use the Report Browser to review the library of available reports. Reports are grouped into public
and private categories.
l The public category group include standard process reports provided by Pega. Public category
reports are available to all managers in an application.
l The private category group includes reports that are created and saved for individual work
managers. Managers can share their reports with other managers by putting them into the public
categories group.
The Report Browser organizes the report categories into Private categories lists and Public categories
lists. The lists appear on the right side of the Report Browser.
When you select a category from a category list, the available reports within the report category appear
in a list on the left side of the Report Browser. The following screenshot shows the list of standard
reports when you select the Analyze Performance category in the Public categories list.
270
©2018 Pegasystems
Report category Information the reports provide
performance, quality reports analyze completed work to determine if
business processes are efficient and effective. For example, there is a
quality report that measures the average elapsed time per status.
Case Metrics The number of cases created each day for the last seven days and the time
per stage for resolved cases.
Monitor Assignments Assignments for open (or unresolved) cases in an application. The reports
tracks the work based on the user to whom the case is assigned. For
example, there is a report that measures time lines by task.
Monitor Processes Assignments for open (or unresolved) cases. The reports focus on the work
and not individual users. For example, there is a report that measures
throughput in the past week by work type.
Open Cases Case-level SLA status for open cases. This report focuses on the timeliness
of a case from the time a case is created to the time the case is resolved.
Service Level Assignment SLA status grouped by assignment or by operator.
Performance
Step Performance Assignment-level SLA status grouped by assignment, and an historical view
of the time it took an operator to complete a step.
271
©2018 Pegasystems
As shown in the following screenshot, check boxes at the top of the report list let you filter the list
based on how the reports are presented.
272
©2018 Pegasystems
How to create a report
Creating a report for your application is simple:
First, create the report definition rule. Second, add columns in the report definition form. Third, add a
filter to limit the records you want to display. The resulting report may also be made available to users
in the Report Browser.
The following steps explain the process for creating a report using the Case Manager or Designer
Studio.
273
©2018 Pegasystems
In Designer Studio, right-click the class in Application Explorer, then select Create > Reports > Report
Definition. Using the Create Report form, specify the class and name of the report. Give the report a
name that clearly describes the purpose of the report. For example, use Monthly New Employee Space
Allocation, not Facilities. This report name enables users to find and identify the report when they
search in the Report Browser.
To create the report, click Create and open. The system displays the Edit Report Definition form as
shown in the following example. The Query tab contains sections for specifying columns, creating
filters, and creating summary reports.
Note: When creating a report in Pega Express, you specify the name when you save the report, rather
than when you create the report.
Add columns
Columns define the contents in your report. Each column corresponds to a single data element.
274
©2018 Pegasystems
In the Case Manager portal, search for an item in the Data Explorer on the left and drag it to the
appropriate column heading in the report at the lower right. The report data updates immediately. For
example, search for Current stage and drag it to a location in the column heading.
Note: The data elements you use in your report can significantly impact the performance of your
application. Therefore, Data Explorer only shows you optimized data elements. Designer Studio
provides access to more data elements.
Hover your mouse cursor to the right of any column heading, A down arrow shows on the far right of
that column. Select the arrow to open a menu that displays editing options. . For example, you can
choose to Sort a column, Delete a column, a Summarize this column, and other actions.
In Designer Studio, in the Edit columns section of the report definition, click + Add column to add a
row to identify each column you want to include in the report. In each row, select the data element
used as the Column source and enter a descriptive Column name to display when you run the
report. The report retrieves values from the database for each of these data elements. You may also
use functions if you want to calculate values not found in the database. Order the columns in the order
in which you want them to appear in the report.
When you generate the report, the results display values for each of the column data elements you
defined.
275
©2018 Pegasystems
Add a filter
You may want to filter the results so the report definition retrieves a subset of the information. For
example, you would use a filter if you want to display only unresolved cases instead of all cases. You
create filter conditions in the Edit filters section.
In the Case Manager portal, filter the results of your report data by selecting an item in the Data
Explorer on the left and dragging it to the yellow box on the right.
To further refine the filter, click on the filter listed in Filtered by,then create a filter expression by
adding a relationship and a value. You may also add a function. Click Apply changes. In this example,
Case status does not start with Resolve displays in Filtered by as Unresolved Case.
In Designer Studio, in the Condition field, enter a capital letter to identity the filter. By default, the first
filter condition field is A. If you add filters, give each filter a unique Condition identifier. When you use
more than one filter, you can specify AND/OR conditions in the filter conditions field.
Name the filter in the Caption field. This name appears in the report header so users know that the
results are filtered.
In the Column source field, select a property reference for the condition.
Identify the data element you want to compare against a condition. In the Relationship field, specify a
relationship such as equals or greater than. In the Value field, specify the value you want to use in
the comparison test.
The following example shows a filter for showing only cases resolved by the user.
If you use a DateTime property in the Column source field, you can use the symbolic date feature to
select a value. The system calculates specific time periods and identifies them by name. You can also
use the feature to select specific dates from a calendar. To use the calendar feature, click Select
values.
276
©2018 Pegasystems
Make the report available in the Report Browser
By default, your report is available in the Report Browser when created in the Case Manager portal.
In Designer Studio, use a setting in the Report Viewer tab if you want to make the report available in
the Report Browser. In the following example, the setting allows users to generate business reports
they can use to monitor application performance.
In the User actions section on the Report Viewer tab, select Display in report browser. In the drop-
down list next to the setting, select the category that will contain a shortcut to your report. Categories
group reports according to the type of information the reports contain. Categories enable users to find
reports in a user portal Report Browser.
277
©2018 Pegasystems
How to organize report results
The way you format report results helps users find and analyze specific information. You can group
and summarize the information for effective business presentations. Additionally, you can display
reports as lists, charts, or graphs to create impact.
Summarizing results
Summarizing reports is useful when users must analyze a large amount of data. While list reports
contain the detailed information a user needs, summary reports allow users to quickly identify key
statistics.
When you generate a report, Pega returns the results as a list of records. You can convert list reports to
summary reports, which summarize one or more columns to calculate counts, totals, or averages. For
example, a user may ask for a count of cases handled by the manager who created them. A list report
could show the same data but would not provide the summary counts that are useful to the user.
In the Case Manager portal, a manager can click Edit report, right-click a column heading and select
Summary function, and then select how to summarize the results.
278
©2018 Pegasystems
Sorting values in the columns
Users who want to see a sequential ordering of data can sort values in ascending or descending order.
Text characters are sorted alphabetically, and numbers are sorted numerically. You can control which
column is sorted first by specifying the sort order.
For example, the facilities manager wants to sort the new hires by start date so that the manager can
prepare the office space. Assume the report orders the columns as Employee, Start Date, and Location.
First you select the start date as the column you want to sort first. Then you specify the column as the
first one in the sort order. When you generate the report, the employee with the most current start
date appears at the top of the list. The other employees are listed in descending order according their
start dates.
In the Case Manager portal, a manager can click Edit report, then right-click on the column heading,
and select Sort > Lowest to highest or Highest to Lowest.
279
©2018 Pegasystems
Grouping results
Grouping results helps users easily analyze trends or statistics found on large reports. You can group
report results so that records are grouped in a column you specify. When you group results, the
grouped column values appear once for each group. The rows that contain the column value are listed
under the group by value. For example, you want to show onboarding cases for each office location.
You specify office location as the one you want to group. When you run the report, each location name
appears once in the left column. The cases are grouped in rows next to the location name.
Note: Grouping can only be performed in Designer Studio, not in the Case Manager portal.
280
©2018 Pegasystems
Creating a report
When you create a report, you design the report by creating the report definition rule and adding
columns. Optionally, you can add filters and make the report available in the Report Browser.
4. Select the report type to create. If you are not sure what type of report to create, select List. You can
convert a list report to a summary report or a chart during configuration.
5. Click Submit to access the Report Editor to add columns and filters to your report.
Add columns
1. In the Data Explorer search field, search for the data element to add to the report.
2. Drag-and-drop the data element into the appropriate location in the report heading to add the
column to the report.
3. To open the column menu, hover your mouse cursor over the column heading and a down-arrow
281
©2018 Pegasystems
displays to the left of the next column on the right. Alternatively, left-click on the column heading.
4. Open the column menu to see what parameters you can change. For example, click Sort to sort the
column and put the contents of the column in ascending or descending alphabetical order.
3. As shown in the image in step 2, select a relationship such as is equal to build the filter expression.
4. Also as shown, enter an appropriate value to filter out the cases that do not meet these
requirements, such as the last 90 days.
5. Click Apply changes to save your filter. Other filters may already be included in Filtered by. The
report data updates immediately.
6. Click the Done editing button and the Save report as pane displays.
7. Enter a name for the report in the Title field.
8. The default category is My Reports so that your reports are available in the Private category of the
Report browser. You may also save the report the public category. Click Submit to save your report
and make it available in a private or public category.
282
©2018 Pegasystems
9. Close the Report Editor.
10. In the Report Browser, click the appropriate category to locate your report.
11. Verify that your report is in the list of available reports.
283
©2018 Pegasystems
Organizing report results
You built your basic report by adding columns and filtering the results. You can organize the results so
that users can easily find and analyze the information in the report.
You can organize report results in three ways:
l Summarize the values in one or more columns. When you summarize report results, you can also
graphically display the summary results.
l Group the results under a column that you specify.
l Sort values in columns.
3. In the form header, click Actions > Run to test the report.
Note: The results show the count of cases for each of the managers.
284
©2018 Pegasystems
Graphically display summary results
1. To display a summary report in a chart or graph, open the Chart tab.
2. In the Chart editor section, select Include Chart.
3. In the Chart editor, select the type of chart you want. In the following example, you choose a pie
chart.
285
©2018 Pegasystems
5. In the form header, click Actions > Run to test the report.
The chart looks like the following when you run the report.
286
©2018 Pegasystems
4. In the form header, click Actions > Run to test the report. The following image shows the results.
4. In the form header, click Actions > Run to test the report. The following example shows the results.
In the rows under the first column, Manager, the first letter in the first name begins with "F" and
ends with "T" — lowest to highest. The rows under the second column, Case ID, starts at the highest
287
©2018 Pegasystems
number for each manager per Office location.
288
©2018 Pegasystems
Optimizing report data
Introduction to optimizing report data
Pega Platform applications allow system architects to improve report performance through a process
called optimization. Optimizing properties allows Pega to extract report data without the need to open
each case.
In this lesson, you learn how Pega Platform stores case data and how data storage affects report
performance. You also learn how to optimize case data to improve report performance for users.
After this lesson, you should be able to:
l Explain the impact of property optimization on report performance
l Describe how Pega stores case data
l Explain how property optimization affects properties
l Optimize case data for reports
289
©2018 Pegasystems
Data Storage in Pega applications
Pega Platform applications store each case as a unique record in a relational database. Within each
record, Pega stores case data in a binary large object (BLOB) field. Each time an end user completes
an action by clicking OK or Submit, Pega writes the case data to the BLOB field.
Within the database, each record is a row in a database table. Each column in the table displays the
contents of a field from the case record, including the BLOB field. When an end user opens a case,
Pega locates the record in the correct table, then reads the contents of the BLOB column to extract the
case data.
290
©2018 Pegasystems
Property optimization
End users rarely need to retrieve an entire case when running a report. Rather, end users only need
the data elements required by the report. Extracting data from a BLOB impacts performance compared
to reading property values from a database table. This impact is most pronounced when extracting
data for report filters and sorting or grouping the content of a column.
To improve report performance, Pega offers a hybrid data storage model. This hybrid model allows
applications to store data both in dedicated indexed columns and in a BLOB field. To store property
values in indexed columns, you must optimize the property for reporting.
When you optimize a property, Pega creates a column for the property in a database table. Because the
value of the property is then visible in the table, or exposed, optimizing a property for reporting is also
called "exposing" the property.
When a case uses an optimized property, Pega writes data to both the property field and the BLOB
field. When a report uses optimized data, Pega reads from the property column, rather than the BLOB.
By not decompressing the BLOB field to read case data, optimization reduces the time and memory
needed to run the report.
By default, Pega optimizes properties that store process data such as:
l The creation date of a case
l The status of a case
l The case ID
Properties that store process data begin with the letters px, py, or pz.
Properties created by system architects to store business data are not optimized by default. Reports
that use an unoptimized property display a warning that states the potential impact on performance.
Performance warnings due to an unoptimized property are resolved by running the Property
Optimization tool.
291
©2018 Pegasystems
KNOWLEDGE CHECK
292
©2018 Pegasystems
Optimizing properties for reporting
Pega provides the Property Optimization tool to optimize properties for reporting.
When you use the Property Optimization tool on a property, Pega exposes the property as a database
column, and populates the new column by extracting values from the BLOB column. For an embedded
property in a page group or page list, the tool automatically creates a new database table for the
property, and the appropriate Index- class and Declare Index rule to update the new table.
To optimize a property:
1. Using the Application Explorer, expand the Data Model node.
2. Right-click a property name and click Optimize for reporting.
3. Select the tables in which you want to create a dedicated database column for this property. You
must select at least one table.
4. If the property is embedded, specify the ruleset and version that is to contain the new Index- class,
the properties in that class, and the Declare Index rule.
5. Select whether to optimize the property now or later. If you select later, click the calendar icon to
select a date within seven days of the current date to optimize the property.
6. Click Next.
7. Review the tables to which the property column will be added and the classes that will be mapped
to each table.
8. Click Next.
9. Click Finish.
Note: Background processing may take minutes or longer, depending on volume. Computations in
your applications involving the property value may fail or produce incorrect results until all
background processing is complete.
You can view the status of your background job by clicking Designer Studio > System > Database >
Column Population Jobs.
You can view the classes for which a property has been optimized on the Advanced tab of the
Property record.
293
©2018 Pegasystems
TESTING AND DEBUGGING
APPLICATIONS
294
©2018 Pegasystems
Unit testing application rules
Introduction to unit testing application rules
Unit testing supports the continuous delivery of applications by enabling quality testing of individual
rules. In this lesson, you learn how to unit test individual rules, and record tests to run as part of
automated tests.
After this lesson, you should be able to:
l Describe the role of unit testing in application development
l Unit test a rule with the Run Rule window
l Record a unit test to run at a later time
295
©2018 Pegasystems
Unit testing
An incorrect rule configuration in an application can cause delays in case processing. When an error
occurs, end users may need to reassign work, or a case may require repair by an administrator. For
example, consider a case that should route to the Fulfillment department. If the case routes instead to
the Accounting department, an accountant must reroute the case to Fulfillment. The accountant wastes
time rerouting the assignment, while the Fulfillment department is idle. The result is a delay to the
customer during case reassignment.
To avoid configuration errors such as incorrectly routed assignments, developers test their
applications. The most basic form of application testing is unit testing individual rules. The purpose of
unit testing is to verify that each element of the application — for example, a decision table or a report
definition — works as expected. Unit testing reduces the risk of a configuration error in one rule
propagating to other rules in the application, causing significant delays to case processing.
Use unit testing to reduce configuration errors. For example, consider a decision tree that evaluates a
property. As illustrated in the following image, the application reads the property from a data page
296
©2018 Pegasystems
sourced from a report definition. By unit testing the individual rules as you configure them, you know
that each rule works as expected. If the decision tree returns an incorrect result, but the data page
contains the correct data, you can isolate the error to the decision tree.
KNOWLEDGE CHECK
Unit testing is a key enabler of a DevOps culture for application development. DevOps relies on the
automation of release management and packaging tasks to support a continuous development and
continuous integration model of application development. Unit testing on a recurring basis can identify
issues quickly after introduction. Unit testing improves application quality because developers can fix
any issue before releasing an application.
297
©2018 Pegasystems
How to unit test a rule
You can unit test many of the rules used to configure application behavior.
Perform the following tasks to successfully unit test a rule:
l Open the Run Rule window from the rule form.
l Initialize the rule with test data.
l View the result returned by the rule.
298
©2018 Pegasystems
KNOWLEDGE CHECK
299
©2018 Pegasystems
For a decision table or decision tree, assign values to each input property and click Run Again. The
window displays the result of the decision table or tree. The following image shows the result of the
test when.ReferredByEmployee is set to true.
You can also review the result of the unit test by viewing the output of the test with the Clipboard tool.
The Run Rule window generates several pages on the clipboard. These pages provide information
about the rule test.
l RuleToRun is the clipboard representation of the rule you tested. If more than one version of the
rule is present in the application, view this page to identify the tested rule version.
l A temp_ page is created or copied when you test a rule. The names of these pages begin with the
string temp_. View this page to examine the data used to initialize the rule for the unit test.
KNOWLEDGE CHECK
300
©2018 Pegasystems
How to record a unit test for automated
testing
After you successfully unit test a rule, you can create a test case based on the result of the test. A test
case identifies one or more testable conditions used to determine whether a rule returns an expected
result. Creating a reusable test case supports the continuous delivery model, providing a means to test
rules on a recurring basis to identify impacts of new or modified rules.
KNOWLEDGE CHECK
You can run a saved unit test from the Test Cases tab of a rule. You can also run the unit test
automatically using the PegaUnit testing facility. However, configuring PegaUnit to run automated tests
is not addressed in this lesson.
301
©2018 Pegasystems
KNOWLEDGE CHECK
302
©2018 Pegasystems
Debugging application errors
Introduction to debugging Pega applications
Software applications are rarely written free of errors. Finding problems early on and giving system
architects the tools to find problems is instrumental to a successful development cycle.
Some errors in an application are easy to diagnose. Other errors can prove difficult to identify and
resolve. To help you identify and resolve errors in your applications, Pega provides the Tracer tool to
allow you to review application execution and identify the root cause of errors.
After this lesson, you should be able to:
l Identify the role of the Tracer in debugging applications
l Use the Tracer to investigate application errors
303
©2018 Pegasystems
The Tracer
When an error occurs in an application, you need to identify the cause of the error so you can correct
the application behavior. For example, a declare expression may return an unexpected value. If you
forget to add one of the input properties to a UI form, users cannot provide the missing value and the
declare expression returns an incorrect result. If you forget to make an entry required for an input
property, users can submit a form without providing a needed value.
Or, perhaps you use a data page to populate a drop-down list. If the contents of the drop-down list are
incorrect, you need to determine whether the control or the connection to the data source has an
improper configuration.
Identifying the root cause of an error is critical to correcting application behavior. You view the events
that led to the error and determine which behavior to address to fix the issue.
To view events such as those that occur when a case processes, you use the Tracer. In Pega, the Tracer
allows you to capture and view the events that occur during case processing. Unlike the Clipboard tool,
which presents the current value of properties in memory, the Tracer presents a complete log of the
events that occur during case processing. This allows you to identify the cause of execution errors,
such as Java exceptions or incorrect property values.
To help identify errors in case processing, the Tracer identifies processing steps that lead to an error.
In the Tracer log, most steps return a status of Good, indicating that the step completed successfully. If
a step returns a status of Fail, an error occurred and the step completed unsuccessfully. An error in an
application may only indicate the last step in a sequence of failed steps, but not the cause of the fail
sequence. Reviewing the sequence of events in the Tracer helps to identify the root cause that leads to
the error seen by users.
304
©2018 Pegasystems
How to investigate application errors with
the Tracer
To investigate an issue with the Tracer, you configure the Tracer to monitor application execution. As
your application executes, Pega logs all the processing events that result from application execution.
You then view the events logged by the Tracer to analyze processing errors and identify their cause.
To open the Tracer, on the Developer toolbar, click Tracer. The Tracer logs all the actions and events
that occur in a requestor session in Designer Studio. Each event is logged in order of occurrence and is
identified by thread, event type, and status.
Click a line in the Tracer to view details about the event. The step's details are displayed in a new
window. From this window, you can view the contents in memory at the time the event occurred. When
you finish reviewing the event properties, close the window to return to the Tracer.
305
©2018 Pegasystems
The events that occur as you use Designer Studio are logged and displayed in the Tracer. To suspend
the logging of events in the Tracer, click Pause on the toolbar that runs along the top of the Tracer
window.
While the Tracer is paused, Pause is replaced with Play. To resume the logging of events in the Tracer,
click Play on the toolbar.
When you use the Tracer, you may want to focus on specific parts of your application. The Tracer
provides several options to focus event logging, which are available on the toolbar.
Button Function
Settings Select the rule types, rulesets, and events to trace. Also, identify
when a step results in a Java exception or a status of Fail or
Warn.
Breakpoints Identify when the application reaches a specific step in an
activity.
Watch Monitor a variable to detect when its value changes.
306
©2018 Pegasystems
COURSE SUMMARY
307
©2018 Pegasystems
Course summary
System Architect Essentials summary
Now that you have completed this course, you should be able to:
l Explain the benefits of using the Pega model-driven application design and development approach
l Model the life cycle of a case that mirrors the way business people think about how work is
completed
l Identify the high-level responsibilities associated with Pega Platform for both Pega business
architects and system architects
l Describe Pega's Direct Capture of Objectives™ approach to increasing the speed and accuracy of
application delivery
l Explain the purpose and benefits of best practices and guardrails
l Validate case data to ensure that user entries match required patterns
l Configure a Wait shape to enforce a case processing dependency
l Configure user views and data elements during case life cycle creation
l Use the Clipboard tool to review case data in memory
l Set property values automatically using data transforms and declare expressions
l Configure and populate a work party with case data
l Create data classes and properties for use in a Pega application
l Automate decision-making to improve process efficiency
l Design responsive user forms for use on any platform or browser
l Design reports to deliver key insights to business users
l Incorporate and manage reference data to allow applications to adapt to changing business
conditions
l Test your application design to analyze rule behavior and identify configuration errors
Next steps
Completion of System Architect Essentials helps prepare students for the Certified System Architect
exam. To help you study for the exam, enroll in the CSA Practice Exam course in Pega Academy.
Register for the exam.
308
©2018 Pegasystems