Legacy - Formula override example
Use the following formula override example to craft your own formula overrides.
Conversational Analytics dashboard is being prepared for future deprecation. It will be supported until deprecation but will no longer be available for installation. A new Conversational Analytics dashboard in Platform Analytics experience, which meets the compliance requirements of Government Community Cloud (GCC), and thus FedRAMP authorized, is available. See Conversational Analytics dashboard in Platform Analytics experience.
For details on the deprecation process, see the Deprecation Process [KB0867184] article in the Now Support Knowledge Base.
If you are an existing user of this dashboard and want to migrate analytics data to the new dashboard, see Migrate data to Conversational Analytics dashboard in Platform Analytics experience [KB1651556].
Group End State definitions
- VA closed the chat session
- System Closed VA – User No Response
- System Closed VA – Topic Complete
- System Closed VA – Left With AI Search
- System closed VA – Auto Closed
- System Closed VA – User Never Engaged
- Live agent closed the chat session
- System Closed LA – User No Response
- System Closed LA – Chat Complete
- Agent Closed LA – Clicked End/X
- System Closed LA – Before Agent Engagement
- User closed the chat session
- User Closed LA – Clicked End/X
- User Closed VA – Clicked End/X
- User Closed LA - Before Agent Engagement
To create these groupings of the 12 end states, follow the instructions for creating a formula override and use the following script.
(function calc(convGr) {
// Returns 'System Closed VA', 'System Closed LA', 'User Closed' states.
function getFinalEndState(state) {
var arrayUtil = new global.ArrayUtil();
VA_END_STATE = ['System Closed VA – User No Response',
'System Closed VA – Topic Complete',
'System Closed VA – Left With AI Search',
'System closed VA – Auto Closed',
'System Closed VA – User Never Engaged'
];
LA_END_STATE = ['System Closed LA – User No Response',
'System Closed LA – Chat Complete',
'Agent Closed LA – Clicked End/X',
'System Closed LA – Before Agent Engagement'
];
USER_CLOSED_END_STATE = ['User Closed LA – Clicked End/X',
'User Closed VA – Clicked End/X',
'User Closed LA - Before Agent Engagement'
];
if (state) {
if (arrayUtil.contains(VA_END_STATE, state))
return 'System Closed VA';
if (arrayUtil.contains(LA_END_STATE, state))
return 'System Closed LA';
if (arrayUtil.contains(USER_CLOSED_END_STATE, state))
return 'User Closed';
}
return state;
}
var conversationId = convGr.getValue('sys_id');
var interactionGr = new GlideRecord('interaction');
interactionGr.addQuery('channel_metadata_document', conversationId);
interactionGr.addQuery('channel_metadata_table', 'sys_cs_conversation');
interactionGr.query();
if (interactionGr.next()) {
var state = interactionGr.getValue('state');
var reason = interactionGr.getValue('state_reason');
var isVAChat = interactionGr.getValue('virtual_agent');
var isLAChat = interactionGr.getValue('agent_chat');
var endState = new CAUtil().getEndState(state, reason, isVAChat, isLAChat);
return getFinalEndState(endState);
}
})(convGr);