(Marked this version for translation) |
(Updated via BpDeleteTranslateTags script) |
||
Line 1: | Line 1: | ||
− | + | = Scenario Example= | |
This section provides a fragment of an inbound voice scenario with Virtual Queue (VQ) related logic. This example scenario is based on the ''Virtual Queue (Callback)'' [[contact-center-administrator-guide/Voice|scenario template]]. You can open this template in the Scenario Builder application and review the settings of each block involved in this scenario. | This section provides a fragment of an inbound voice scenario with Virtual Queue (VQ) related logic. This example scenario is based on the ''Virtual Queue (Callback)'' [[contact-center-administrator-guide/Voice|scenario template]]. You can open this template in the Scenario Builder application and review the settings of each block involved in this scenario. | ||
− | |||
For more information on how to create a scenario from a template, refer to the ''Contact Center Administrator Guide'', section [[contact-center-administrator-guide/ScenariosOverview|Scenarios Overview]]. | For more information on how to create a scenario from a template, refer to the ''Contact Center Administrator Guide'', section [[contact-center-administrator-guide/ScenariosOverview|Scenarios Overview]]. | ||
− | |||
[[File:virtual-queue-tutorial-image4.PNG|center]] | [[File:virtual-queue-tutorial-image4.PNG|center]] | ||
[[File:Virtual-queue-tutorial-image7.PNG|center]] | [[File:Virtual-queue-tutorial-image7.PNG|center]] | ||
− | == Scenario Flow == | + | == Scenario Flow == |
A scenario is comprised of a series of actions that are initiated by scenario blocks. The main flow of blocks in this VQ-enabled scenario, from top to bottom, is briefly explained as follows. | A scenario is comprised of a series of actions that are initiated by scenario blocks. The main flow of blocks in this VQ-enabled scenario, from top to bottom, is briefly explained as follows. | ||
− | |||
'''The Play Prompt block greets the caller.''' | '''The Play Prompt block greets the caller.''' | ||
− | |||
The [[scenario-builder-reference-guide/PlayPrompt|Play Prompt]] block begins the scenario. The caller hears the initial announcement (i.e., a welcome message or a prompt for more information). | The [[scenario-builder-reference-guide/PlayPrompt|Play Prompt]] block begins the scenario. The caller hears the initial announcement (i.e., a welcome message or a prompt for more information). | ||
− | |||
[[File:Virtual-queue-tutorial-image4-1.png|800px|thumbnail|center|Play Prompt block]] | [[File:Virtual-queue-tutorial-image4-1.png|800px|thumbnail|center|Play Prompt block]] | ||
− | |||
'''The Find Agent block facilitates whether callers wait in queue or accept the callback option.''' | '''The Find Agent block facilitates whether callers wait in queue or accept the callback option.''' | ||
− | |||
The Virtual Queue option is offered in the [[scenario-builder-reference-guide/FindAgent|Find Agent]] block, as described in section [[virtual-queue-tutorial/Configuration|Configuration]] of this tutorial. | The Virtual Queue option is offered in the [[scenario-builder-reference-guide/FindAgent|Find Agent]] block, as described in section [[virtual-queue-tutorial/Configuration|Configuration]] of this tutorial. | ||
− | |||
Callers that prefer to wait online will remain in the Find Agent block until it is their turn to be connected. Callers that accept the Virtual Queue option will exit this block via the ''Callback'' exit. | Callers that prefer to wait online will remain in the Find Agent block until it is their turn to be connected. Callers that accept the Virtual Queue option will exit this block via the ''Callback'' exit. | ||
− | |||
[[File:Virtual-queue-tutorial-image4-3.png|800px|thumbnail|center|Find Agent block]] | [[File:Virtual-queue-tutorial-image4-3.png|800px|thumbnail|center|Find Agent block]] | ||
− | |||
'''The No Agents block gives the caller a way to exit the scenario if there are no agents available.''' | '''The No Agents block gives the caller a way to exit the scenario if there are no agents available.''' | ||
− | |||
If no agent is available to accept the call, the scenario will take the ''No Agents'' exit. | If no agent is available to accept the call, the scenario will take the ''No Agents'' exit. | ||
− | |||
[[File:Virtual-queue-tutorial-image4-4.png|800px|thumbnail|center|No Agents conditional exit]] | [[File:Virtual-queue-tutorial-image4-4.png|800px|thumbnail|center|No Agents conditional exit]] | ||
− | |||
'''Callback properties are handled by Set Variable and If blocks.''' | '''Callback properties are handled by Set Variable and If blocks.''' | ||
− | |||
Because virtual queue/callback is enabled for this scenario, the caller is given the option to receive a callback if no agents are available or if the caller does not want to wait in queue. A series of [[scenario-builder-reference-guide/SetVariable|Set Variable]] blocks and [[scenario-builder-reference-guide/If|If]] blocks determine how a callback should be handled. | Because virtual queue/callback is enabled for this scenario, the caller is given the option to receive a callback if no agents are available or if the caller does not want to wait in queue. A series of [[scenario-builder-reference-guide/SetVariable|Set Variable]] blocks and [[scenario-builder-reference-guide/If|If]] blocks determine how a callback should be handled. | ||
− | |||
Within the Callback exit, in the first Set Variable block, the callback number is initially set to the value of ''$(item.from)'', which is the caller ID of the original call. | Within the Callback exit, in the first Set Variable block, the callback number is initially set to the value of ''$(item.from)'', which is the caller ID of the original call. | ||
− | |||
'''If blocks determine whether there is a caller ID and whether the ID can be dialed.''' | '''If blocks determine whether there is a caller ID and whether the ID can be dialed.''' | ||
− | |||
The scenario then uses [[scenario-builder-reference-guide/If|If]] blocks to ensure that | The scenario then uses [[scenario-builder-reference-guide/If|If]] blocks to ensure that | ||
* there is a caller ID (ANI) to use for the callback (if there is no ANI, then a phone number is collected) | * there is a caller ID (ANI) to use for the callback (if there is no ANI, then a phone number is collected) | ||
Line 71: | Line 54: | ||
− | |||
[[File:Virtual-queue-tutorial-image4-5.png|800px|thumbnail|center|Callback > Set Variable > If]] | [[File:Virtual-queue-tutorial-image4-5.png|800px|thumbnail|center|Callback > Set Variable > If]] | ||
− | |||
'''The Menu block asks the caller to establish the callback number.''' | '''The Menu block asks the caller to establish the callback number.''' | ||
− | |||
The [[scenario-builder-reference-guide/Menu|Menu]] block that follows will ask the caller to choose the callback number. The caller can either use the current phone or enter a different callback phone number. | The [[scenario-builder-reference-guide/Menu|Menu]] block that follows will ask the caller to choose the callback number. The caller can either use the current phone or enter a different callback phone number. | ||
− | |||
[[File:Virtual-queue-tutorial-image4-6.png|800px|thumbnail|center|Menu block]] | [[File:Virtual-queue-tutorial-image4-6.png|800px|thumbnail|center|Menu block]] | ||
− | |||
'''The Collect Digits block gets a new callback number, if needed.''' | '''The Collect Digits block gets a new callback number, if needed.''' | ||
− | |||
If the caller selects a different callback phone number, the [[scenario-builder-reference-guide/CollectDigits|Collect Digits]] block is used next to collect the new number. | If the caller selects a different callback phone number, the [[scenario-builder-reference-guide/CollectDigits|Collect Digits]] block is used next to collect the new number. | ||
− | |||
[[File:Virtual-queue-tutorial-image7-1.png|800px|thumbnail|center|Collect Digits block]] | [[File:Virtual-queue-tutorial-image7-1.png|800px|thumbnail|center|Collect Digits block]] | ||
− | |||
'''If blocks determine whether the number can be dialed.''' | '''If blocks determine whether the number can be dialed.''' | ||
− | |||
Then If blocks are used to ensure that the entered number is dialable and is not a 1-900 number. Note that the ''length()'' function is used to check the number of digits. | Then If blocks are used to ensure that the entered number is dialable and is not a 1-900 number. Note that the ''length()'' function is used to check the number of digits. | ||
− | |||
Once the callback number is identified, the call is passed back to the [[scenario-builder-reference-guide/RequestCallback|Request Callback]] block. This block confirms the request, disconnects the original call, places the associated callback request in the virtual queue, waits for a matching agent, and makes the callback when either an agent becomes available or the estimated waiting time (EWT) expires. | Once the callback number is identified, the call is passed back to the [[scenario-builder-reference-guide/RequestCallback|Request Callback]] block. This block confirms the request, disconnects the original call, places the associated callback request in the virtual queue, waits for a matching agent, and makes the callback when either an agent becomes available or the estimated waiting time (EWT) expires. | ||
− | |||
'''The Menu block explains the callback to the party who answers the call.''' | '''The Menu block explains the callback to the party who answers the call.''' | ||
− | |||
The [[scenario-builder-reference-guide/Menu|Menu]] block that follows announces the purpose of the call to the party that answers the callback attempt. This is done to make sure the call is connected to the correct party. | The [[scenario-builder-reference-guide/Menu|Menu]] block that follows announces the purpose of the call to the party that answers the callback attempt. This is done to make sure the call is connected to the correct party. | ||
− | |||
The call is then handed over to the Find Agent block for distribution to an agent. Note that despite the EWT prediction that no agents are immediately available, the call will be placed in the first position in the service queue to be picked up by the next agent who becomes available. | The call is then handed over to the Find Agent block for distribution to an agent. Note that despite the EWT prediction that no agents are immediately available, the call will be placed in the first position in the service queue to be picked up by the next agent who becomes available. | ||
− | |||
[[File:Virtual-queue-tutorial-image7-2.png|800px|thumbnail|center|If and Set Variable blocks]] | [[File:Virtual-queue-tutorial-image7-2.png|800px|thumbnail|center|If and Set Variable blocks]] | ||
− | |||
'''The Connect Call block connects the caller to the agent.''' | '''The Connect Call block connects the caller to the agent.''' | ||
− | |||
As usual, the [[scenario-builder-reference-guide/ConnectCall|Connect Call]] block is used to connect the call to the agent identified by the Find Agent block. | As usual, the [[scenario-builder-reference-guide/ConnectCall|Connect Call]] block is used to connect the call to the agent identified by the Find Agent block. | ||
− | |||
[[File:Virtual-queue-tutorial-image7-3.png|800px|thumbnail|center|Connect Call block]] | [[File:Virtual-queue-tutorial-image7-3.png|800px|thumbnail|center|Connect Call block]] | ||
− | |||
− | |||
− | |||
− | |||
− |
Latest revision as of 04:04, 29 May 2024
Scenario Example
This section provides a fragment of an inbound voice scenario with Virtual Queue (VQ) related logic. This example scenario is based on the Virtual Queue (Callback) scenario template. You can open this template in the Scenario Builder application and review the settings of each block involved in this scenario.
For more information on how to create a scenario from a template, refer to the Contact Center Administrator Guide, section Scenarios Overview.
Scenario Flow
A scenario is comprised of a series of actions that are initiated by scenario blocks. The main flow of blocks in this VQ-enabled scenario, from top to bottom, is briefly explained as follows.
The Play Prompt block greets the caller.
The Play Prompt block begins the scenario. The caller hears the initial announcement (i.e., a welcome message or a prompt for more information).
The Find Agent block facilitates whether callers wait in queue or accept the callback option.
The Virtual Queue option is offered in the Find Agent block, as described in section Configuration of this tutorial.
Callers that prefer to wait online will remain in the Find Agent block until it is their turn to be connected. Callers that accept the Virtual Queue option will exit this block via the Callback exit.
The No Agents block gives the caller a way to exit the scenario if there are no agents available.
If no agent is available to accept the call, the scenario will take the No Agents exit.
Callback properties are handled by Set Variable and If blocks.
Because virtual queue/callback is enabled for this scenario, the caller is given the option to receive a callback if no agents are available or if the caller does not want to wait in queue. A series of Set Variable blocks and If blocks determine how a callback should be handled.
Within the Callback exit, in the first Set Variable block, the callback number is initially set to the value of $(item.from), which is the caller ID of the original call.
If blocks determine whether there is a caller ID and whether the ID can be dialed.
The scenario then uses If blocks to ensure that
- there is a caller ID (ANI) to use for the callback (if there is no ANI, then a phone number is collected)
- the caller ID is dialable and is not a 1-900 number (note that the length() function is used to check the number of digits in the phone number)
The Menu block asks the caller to establish the callback number.
The Menu block that follows will ask the caller to choose the callback number. The caller can either use the current phone or enter a different callback phone number.
The Collect Digits block gets a new callback number, if needed.
If the caller selects a different callback phone number, the Collect Digits block is used next to collect the new number.
If blocks determine whether the number can be dialed.
Then If blocks are used to ensure that the entered number is dialable and is not a 1-900 number. Note that the length() function is used to check the number of digits.
Once the callback number is identified, the call is passed back to the Request Callback block. This block confirms the request, disconnects the original call, places the associated callback request in the virtual queue, waits for a matching agent, and makes the callback when either an agent becomes available or the estimated waiting time (EWT) expires.
The Menu block explains the callback to the party who answers the call.
The Menu block that follows announces the purpose of the call to the party that answers the callback attempt. This is done to make sure the call is connected to the correct party.
The call is then handed over to the Find Agent block for distribution to an agent. Note that despite the EWT prediction that no agents are immediately available, the call will be placed in the first position in the service queue to be picked up by the next agent who becomes available.
The Connect Call block connects the caller to the agent.
As usual, the Connect Call block is used to connect the call to the agent identified by the Find Agent block.