copyright | lastupdated | subcollection | ||
---|---|---|---|---|
|
2019-04-12 |
assistant |
{:shortdesc: .shortdesc} {:new_window: target="_blank"} {:deprecated: .deprecated} {:important: .important} {:note: .note} {:tip: .tip} {:pre: .pre} {:codeblock: .codeblock} {:screen: .screen} {:javascript: .ph data-hd-programlang='javascript'} {:java: .ph data-hd-programlang='java'} {:python: .ph data-hd-programlang='python'} {:swift: .ph data-hd-programlang='swift'}
{: #tutorial-digressions}
In this tutorial, you will see firsthand how digressions work. {: shortdesc}
{: #tutorial-digressions-objectives}
By the time you finish the tutorial, you will understand how:
- digressions are designed to work
- digression settings impact the flow of the dialog
- to test digression settings for a dialog
{: #tutorial-digressions-duration}
This tutorial will take approximately 20 minutes to complete.
{: #tutorial-digressions-prereqs}
If you do not have a {{site.data.keyword.conversationshort}} instance, complete the Before you begin step from the Getting Started tutorial to create one.
{: #tutorial-digressions-import-json}
First you will need to import the Digression showcase dialog skill into your {{site.data.keyword.conversationshort}} instance.
- Download the digression-showcase.json file.
- In your {{site.data.keyword.conversationshort}} instance, click the icon.
- Click Choose a file, and then select the digression-showcase.json file that you downloaded earlier.
- Click Import to finish importing the dialog skill.
{: #tutorial-digressions-temporarily-digress-away}
Digressions allow for the user to break away from a dialog branch in order to temporarily change the topic before returning to the original dialog flow. In this step, you will start to book a restaurant reservation, then digress away to ask for the restaurant's hours. After providing the opening hours information, your assistant will return back to the restaurant booking dialog flow.
-
Click Dialog to switch from the page with intents to a view of the dialog tree.
-
Type
Book me a restaurant
into the text field.Your assistant responds with a prompt for the day to reserve,
When do you want to go?
-
Click the Location icon next to the response to highlight the node that triggered the response, the Restaurant booking node, in the dialog tree.
-
Type
Tomorrow
.Your assistant responds with a prompt for the time to reserve,
What time do you want to go?
-
You do not know when the restaurant closes, so you ask,
What time do you close?
The bot digresses away from the restaurant booking node to process the Restaurant opening hours node. It responds with,
The restaurant is open from 8:00 AM to 10:00 PM.
Your assistant then returns to the restaurant booking node, and prompts you again for the reservation time. -
Optional: To complete the dialog flow, type
8pm
for the reservation time and2
for the number of guests.
Congratulations! You have successfully digressed away from and returned to a dialog flow.
{: #tutorial-digressions-disable-slot}
In this step, you will edit the digression settting for the restaurant booking node to prevent users from digressing away from it, and see how the setting change impacts the dialog flow.
-
Let's look at the current digression settings for the Restaurant booking node. Click the node to open it in edit view.
-
Click Customize, and then click the Digressions tab.
-
Change the Allow digressions away toggle from on to off, and then click Apply.
-
Click Clear in the "Try it out" pane to reset the dialog.
-
Type
Book me a restaurant
.Your assistant responds with a prompt for the day to reserve,
When do you want to go?
-
Type
Tomorrow
.Your assistant responds with a prompt for the time to reserve,
What time do you want to go?
-
Ask,
What time do you close?
Your assistant recognizes that the question triggers the #restaurant_opening_hours intent, but ignores it and displays the prompt associated with the @sys-time slot again instead.
You successfully prevented the user from digressing away from the restaurant booking process.
{: #tutorial-digressions-digress-without-return}
You can configure a dialog node to not go back to the node that your assistant digressed away from for the current node to be processed. To demonstrate this, you will change the digression setting for the restaurant hours node. In Step 2, you saw that after digressing away from the restaurant booking node to go to the restaurant opening hours node, your assistant went back to the restaurant booking node to continue with the reservation process. In this exercise, after you change the setting, you will digress away from the Job opportunities dialog to ask about restaurant opening hours and see that your assistant does not return to where it left off.
-
Click to open the Restaurant opening hours node.
-
Click Customize, and then click the Digressions tab.
-
Expand the Digressions can come into this node section, and deselect the Return after digression checkbox. Click Apply, and then click to close the node edit view.
-
Click Clear in the "Try it out" pane to reset the dialog.
-
To engage the Job opportunities dialog node, type
I'm looking for a job
.Your assistant responds by saying,
We are always looking for talented people to add to our team. What type of job are you interested in?
-
Instead of answering this question, ask the bot an unrelated question. Type
What time do you open?
Your assistant digresses away from the Job opportunities node to the Restaurant opening hours node to answer your question. Your assistant responds with
The restaurant is open from 8:00 AM to 10:00 PM.
Unlike in the previous test, this time the dialog does not pick up where it left off in the Job opportunities node. Your assistant does not return to the dialog that was in progress because you changed the setting on the Restaurant opening hours node to not return.
Congratulations! You have successfully digressed away from a dialog without returning.
{: #tutorial-digressions-summary}
In this tutorial you experienced how digressions work, and saw how individual dialog node settings can impact the digressions behavior.
{: #tutorial-digressions-next-steps}
For help as you configure digressions for your own dialog, see Digressions.