Salesforce Flow to Send Custom Notification to Case Owner

This article will show you how to create a flow to send a custom notification to the owner when the Case owner is changed.

 

Custom Notification

This notification appears in the bell icon in the upper right corner of the screen. Normally, you will be notified when you are mentioned in Chatter or when you request and receive approval in the approval process.

 

This time, we will create a flow to send a custom notification "Assigned to Case Owner" to the case owner when the Case owner is changed.

 

By clicking on the notification, go to the case record page.

 

 

Flow Process Overview

This is the overall picture of the flow.

 

1. Get Custom Notification

Get the custom notification type Id.

2. Assign Recipients

Assign the case owner to a collection variable.

3. Send Custom Notification to Owner

Send the custom notification to the case owner.

 

 

Create the Custom Notification

Click the "Setup".

 

Enter "noti" in the search box and click "Custom Notifications". Click the "New" button on the Custom Notification screen.

 

Set the following and click the "Save" button. Here, select the desktop and mobile for the notification.

Custom Notification Name: Case Owner Assignment

API Name: CaseOwnerAssignment

Desktop: Check on

Mobile: Check on

 

A custom notification is created.

 

 

Create the Flow

Enter "Flow" in the search box on the left sidebar and click "Flows". Click the "New Flow" button.

 

Select "Record-Triggered Flow" and click the "Create" button.

 

Set the properties.

Object: Case

Trigger the Flow When: A record is created or updated

 

Condition Requirements: Formula Evaluates to True

Formula:

(IsNew() || IsChanged({!$Record.OwnerId}))

&& CASESAFEID({!$User.Id}) != CASESAFEID({!$Record.OwnerId})

 

The first line of the condition is "new or owner changed".

The second line of the condition is "and the logged-in user is not the owner. User.Id and Record.OwnerId are compared with the 18-digit Id in the CASESAFEID function.

 

When to Run the Flow for Updated Records: Every time a record is updated and meets the condition requirements

Optimize the Flow for: Actions and Related Records

 

Click the "X" button in the upper right corner to close the editing screen.

 

Note

Under the condition "Logged-in user is not the owner", initially, {! $User.Id}) != {! $Record.OwnerId}.

When debugging, it should not always match the start condition since it was running by myself, but it was going through the start condition.

I assigned it to a variable and confirmed that User.Id is retrieved with 15 digits and Record.OwnerId is retrieved with 18 digits.

 

 

Create variables

First, the variables to be used in the flow are created first. Here is a list of variables.

API Name

Description

varRecipients

Recipient Id List

textNotificationBody

Text body of the notification

 

Click the "Toggle Toolbox" button in the upper left corner of the screen, then click the "New Resource" button.

 

Create the Recipient Id variable. After setting, click the "Done" button.

Resource Type: Variable

API Name: varRecipients

Data Type: Text

Available for input: check on

 

Create the Notification Body text variable. After setting, click the "Done" button.

Resource Type: Text Template

API Name: textNotificationBody

Body: After selecting "View as Plain Text", set the body text.

Case Number: {!$Record.CaseNumber}

Subject: {!$Record.Subject}

Priority: {!$Record.Priority}

*After selecting "View as Plain Text", set the body text. If you select "View as Rich Text", the custom notification will include extra <p> tags, etc.

 

First, save the flow. Click the "Save" button.

 

Save the Flow under any name. Here it is saved as follows.

Flow Label: Send Custom Notifications To Case Owner

Flow API Name: SendCustomNotificationsToCaseOwner

Description: Send custom notifications to the owner when a case is created or the owner is changed.

 

 

1. Get the custom notification

Place the cursor over the "" under "Screen Flow" and click the "+" mark.

 

Select "Get Records".

 

Set the properties.

Label: Get Custom Notification

API Name: Get_Custom_Notification

Object: Custom Notification Type

Condition Requirements: All Conditions Are Met (AND)

Field/Operator/Value: "DeveloperName" Equals "CaseOwnerAssignment"

*Set the value to the API Name of the custom notification created in the previous step.

 

Sort Order: Not Sorted

How Many Records to Store: Only the first record

How to Store Record Data: Choose fields and let Salesforce do the rest

 

 

2. Assign Recipients

Click the "+" mark under "Get Custom Notification" and select "Assignment".

 

Set the properties.

Label: Assign Recipients

API Name: Assign_Recipients

Variable: {!varRecipients}

Operator: Add

Value: {!$Record.OwnerId}

*Since single records cannot be assigned to collection variables, the operator is set with "Add".

 

 

3. Send Custom Notification to Owner

Click the "+" mark under "Assign Recipients" and select "Action".

 

Click "Notifications" on the left sidebar and select "Send Custom Notification".

 

Set the properties.

Label: Send Custom Notification to Owner

API Name: Send_Custom_Notification_to_Owner

Custom Notification Type ID: {!Get_Custom_Notification.Id}

Notification Body: {!textNotificationBody}

Notification Title: Assigned to the case owner

Recipient IDs: {!varRecipients}

Target ID: {!$Record.Id}

 

Flow creation is complete.

 

Click the "Save" button.

 

 

Debug the Flow

Create a case record for testing from the Records screen.

 

Click the "Debug" button.

 

Record trigger flows are always debugged in rollback mode. It is not possible to check by actually sending custom notifications. This time, we will debug to make sure that the flow proceeds without error to the end when creating and updating a case.

 

 

Create Case (by myself)

First, check the behavior when creating a case.

Select "Created" for "Run the Flow As If the Record Is" and select the test case record. Click the "Run" button.

 

Debugging by the logged-in user himself, so it does not match the start condition. Ensure that the flow exits without processing.

 

 

Create Case (by another user)

Click the "Debug Again" button.

 

Check on "Run flow as another user" and select another user. Click the "Run" button.

 

Ensure that the flow proceeds to the end without error.

 

 

Update Case (No Change Owner)

Next, check the behavior when updating the case. Click the "Debug Again" button.

 

Select "Updated" for "Run the Flow As If the Record Is". Click the "Run" button.

 

The owner has not changed, so the start condition is not met. Ensure that the flow ends without processing.

 

 

Update Case (Skip start conditions)

Click the "Debug Again" button.

 

Check on "Skip start condition requirements". Click the "Run" button.

 

Ensure that the flow proceeds to the end without error.

 

Click the "Activate" button.

 

 

Send actual custom notifications

Change the case owner to another user by proxy login with another user in the Sandbox environment. A custom notification will be sent to the case owner.

 

 

When creating a case record from the screen, it is not possible to set an owner other than yourself. Test when creating a case by using the Dataloader. Or, if you are a system administrator with access to the developer console, run the following Apex to assign any user as the owner when creating a new case.

 

Case cs = new Case(

    Subject = 'Test',

    OwnerId = '005xxxxxxxxxxxx'

);

insert cs;

 

 

Copied title and URL