Skip to content

Latest commit

 

History

History
executable file
·
827 lines (545 loc) · 41.2 KB

tutorial.md

File metadata and controls

executable file
·
827 lines (545 loc) · 41.2 KB
copyright lastupdated
years
2015, 2019
2019-04-08

{:shortdesc: .shortdesc} {:new_window: target="_blank"} {:tip: .tip} {:deprecated: .deprecated} {: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'} {:gif: data-image-type='gif'}

Tutorial: Building a complex dialog

{: #tutorial}

In this tutorial, you will use the {{site.data.keyword.conversationshort}} service to create a dialog for an assistant that helps users with inquiries about a fictitious restaurant called Truck Stop Gourmand. {: shortdesc}

This version of the {{site.data.keyword.conversationshort}} documentation is deprecated. Go here instead. {: deprecated}

Learning objectives

By the time you finish the tutorial, you will understand how to:

  • Plan a dialog
  • Define custom intents
  • Add dialog nodes that can handle your intents
  • Add entities to make your responses more specific
  • Add a pattern entity, and use it in the dialog to find patterns in user input
  • Set and reference context variables

Duration

This tutorial will take approximately 2 to 3 hours to complete.

Prerequisite

Before you begin, complete the Getting Started tutorial.

You will use the {{site.data.keyword.conversationshort}} tutorial workspace that you created, and add nodes to the simple dialog that you built as part of the getting started exercise.

If you do not have the workspace, you can add it to your instance by importing the watson_assistant_tutorial.json External link icon{: new_window} file.

Step 1: Plan the dialog

You are building an assistant for a restaurant named Truck Stop Gourmand that has one location and a thriving cake-baking business. You want the simple assistant to answer user questions about the restaurant, its menu, and to cancel customer cake orders. Therefore, you need to create intents that handle inquiries related to the following subjects:

  • Restaurant information
  • Menu details
  • Order cancelations

You'll start by creating intents that represent these subjects, and then build a dialog that responds to user questions about them.

Step 2: Answer questions about the restaurant

{: #add-about-intent}

Add an intent that recognizes when customers ask for details about the restaurant itself. An intent is the purpose or goal expressed in user input. The #General_About_You intent that is provided with the General content catalog serves a similar function, but its user examples are designed to focus on queries about the assistant as opposed to the business that is using the assistant to help its customers. So, you will add your own intent.

Add the #about_restaurant intent

  1. Click the Intents tab.

  2. Click Add intent.

    Shows the the Add Intent button on the Intents page.

  3. Enter about_restaurant in the Intent name field, and then click Create intent.

    Shows the #about_restaurant intent being added.

  4. Add the following user examples:

    Tell me about the restaurant
    i want to know about you
    who are the restaurant owners and what is their philosophy?
    What's your story?
    Where do you source your produce from?
    Who is your head chef and what is the chef's background?
    How many locations do you have?
    do you cater or host functions on site?
    Do you deliver?
    Are you open for breakfast?
    

    {: screen}

  5. Click the Close Close arrow icon to finish adding the #about_restaurant intent.

You added an intent and provided examples of utterances that real users might enter to trigger this intent.

Add a dialog node that is triggered by the #about_restaurant intent

{: #trigger-about-intent}

Add a dialog node that recognizes when the user input maps to the intent that you created in the previous step, meaning its condition checks whether the service recognized the #about_restaurant intent from the user input.

  1. Click the Dialogs tab.

  2. Find the #General_Greetings node in the dialog tree.

    You will add a node that checks for questions about the restaurant below this initial greeting node to reflect the flow you might expect to encounter in a normal conversation. For example, Hello. then Tell me about yourself.

  3. Click the More More options icon on the #General_Greetings node, and then select Add node below.

    Shows the Add node below menu opened from the #General_Greetings dialog node.

  4. Start to type #about_restaurant into the Enter a condition field of this node. Then select the #about_restaurant option.

  5. Add the following text as the response:

    Truck Stop Gourmand is the brain child of Gloria and Fred Smith. What started out as a food truck in 2004 has expanded into a thriving restaurant. We now have one brick and mortar restaurant in downtown Portland. The bigger kitchen brought with it new chefs, but each one is faithful to the philosophy that made the Smith food truck so popular to begin with: deliver fresh, local produce in inventive and delicious ways. Join us for lunch or dinner seven days a week. Or order a cake from our bakery.
    

    {: codeblock}

  6. Let's add an image to the response also.

    Click Add response type. Select Image from the drop-down list. In the Image source field, add https://www.ibmlearningcenter.com/wp-content/uploads/2018/02/IBM-Learning-Center-Food4.jpg.

  7. Move the image response type up, so it is displayed in the response before the text is displayed. Click the Move up arrow to reorder the two response types.

    Shows the image response type listed before the text response type.

  8. Click Close to close the edit view.

Test the #about_restaurant dialog node

{: #test-about-intent}

Test the intent by checking whether user utterances that are similar to, but not exactly the same as, the examples you added to the training data have successfully trained the service to recognize input with an #about_restaurant intent.

  1. Click the Try it icon to open the "Try it out" pane.

  2. Enter, I want to learn more about your restaurant.

    The service indicates that the #about_restaurant intent is recognized, and returns a response with the image and text that you specified for the dialog node.

    Shows the Try it out pane recognizing the #about_restaurant intent and showing the image and text response.

Congratulations! You have added a custom intent, and a dialog node that knows how to handle it.

The #about_restaurant intent is designed to recognize a variety of general questions about the restaurant. You added a single node to capture such questions. The response is long, but it is a single statement that can potentially answer questions about all of the following topics:

  • The restaurant owners
  • The restaurant history
  • The philosophy
  • The number of sites
  • The days of operation
  • The meals served
  • The fact that the restaurant bakes cakes to order

For general, low-hanging fruit types of questions, a single, general answer is suitable.

Step 3: Answer questions about the menu

{: #menu}

A key question from potential restaurant customers is about the menu. The Truck Stop Gourmand restaurant changes the menu daily. In addition to its standard menu, it has vegetarian and cake shop menus. When a user asks about the menu, the dialog needs to find out which menu to share, and then provide a hyperlink to the menu that is kept up to date daily on the restaurant's website. You never want to hard-code information into a dialog node if that information changes regularly.

Add a #menu intent

  1. Click the Intents tab.

  2. Click Add intent.

    Shows the the Add Intent button on the Intents page.

  3. Enter menu in the Intent name field, and then click Create intent.

    Shows the menu intent being added and the Create intent button.

  4. Add the following user examples:

    I want to see a menu
    What do you have for food?
    Are there any specials today?
    where can i find out about your cuisine?
    What dishes do you have?
    What are the choices for appetizers?
    do you serve desserts?
    What is the price range of your meals?
    How much does a typical dish cost?
    tell me the entree choices
    Do you offer a prix fixe option?
    

    {: screen}

  5. Click the Close Close arrow icon to finish adding the #menu intent.

Add a dialog node that is triggered by the #menu intent

{: #trigger-menu-intent}

Add a dialog node that recognizes when the user input maps to the intent that you created in the previous step, meaning its condition checks whether the service recognized the #menu intent from the user input.

  1. Click the Dialogs tab.

  2. Find the #about_restaurant node in the dialog tree.

    You will add a node that checks for questions about the menu below this node.

  3. Click the More More options icon on the #about_restaurant node, and then select Add node below.

    Shows a dialog node being added below the #about_restaurant node.

  4. Start to type #menu into the Enter a condition field of this node. Then select the #menu option.

    Shows the #menu intent being added as the condition for a dialog node.

  5. Add the following text as the response:

    In keeping with our commitment to giving you only fresh local ingredients, our menu changes daily to accommodate the produce we pick up in the morning. You can find today's menu on our website.

  6. Add an option response type that provides a list of options for the user to choose from. In this case, the list of options includes the different versions of the menu that are available.

    Click Add response type. Select Option from the drop-down list.

    Shows the option response type being added to the #menu dialog node response.

  7. In the Title field, add Which menu do you want to see?

    Shows the title field filled in and the Add option button.

  8. Click Add option.

  9. In the Label field, add Standard. The text you add as the label is displayed in the response to the user as a selectable option.

  10. In the Value field, add standard menu. The text you specify as the value is what gets sent to the service as new user input when a user chooses this option from the list, and clicks it.

  11. Repeat the previous two steps to add label and value information for the remaining menu types:

    Option response type details
    Label Value
    Vegetarian vegetarian menu
    Cake shop cake shop menu

    Shows the options list filled in with menu types.

  12. Click Close to close the edit view.

Add a @menu entity

{: #add-menu-entity}

To recognize the different types of menus that customers indicate they want to see, you will add a @menu entity. Entities represent a class of object or a data type that is relevant to a user's purpose. By checking for the presence of specific entities in the user input, you can add more responses, each one tailored to address a distinct user request. In this case, you will add a @menu entity that can distinguish between different menu types.

  1. Click the Entities tab.

    Shows the empty entities page with the Add entity button.

  2. Click Add entity.

  3. Enter menu into the entity name field.

    Shows the @menu entity being added and the Create entity button.

  4. Click Create entity.

  5. Add standard to the Value name field, and then add standard menu to the Synonyms field, and press Enter.

  6. Add the following additional synonyms:

    • bill of fare
    • cuisine
    • carte du jour

    Shows the standard value being added to the @menu entity.

  7. Click Add value to add the @menu:standard value.

  8. Add vegetarian to the Value name field, and then add vegetarian menu to the Synonyms field, and press Enter.

  9. Click Show recommendations, and then click the checkboxes for meatless diet, meatless, and vegan diet.

  10. Click Add selected.

  11. Click the empty Add synonym field, and then add these additional synonyms:

    • vegan
    • plants-only

    Shows the vegetarian value being added to the @menu entity.

  12. Click Add value to add the @menu:vegetarian value.

  13. Add cake to the Value name field, and then add cake menu to the Synonyms field, and press Enter.

  14. Add the following additional synonyms:

    • cake shop menu
    • dessert menu
    • bakery offerings

    Shows the cake value being added to the @menu entity.

  15. Click Add value to add the @menu:cake value.

  16. Click the Close Close arrow icon to finish adding the @menu entity.

Add child nodes that are triggered by the @menu entity types

{: #trigger-menu-entity}

In this step, you will add child nodes to the dialog node that checks for the #menu intent. Each child node will show a different response depending on the @menu entity type the user chooses from the options list.

  1. Click the Dialogs tab.

  2. Find the #menu node in the dialog tree.

    You will add a child node to handle each menu type option that you added to the #menu node.

  3. Click the More More options icon on the #menu node, and then select Add child node.

    Shows a child node being added to the #menu dialog node.

  4. Start to type @menu:standard into the Enter a condition field of this node. Then select the @menu:standard option.

  5. Add the following message in the response text field, To see our menu, go to the <a href="https://www.example.com/menu.html" target="blank">menu</a> page on our website.

    Shows an @menu:standard child node being added to the #menu dialog node.

  6. Click Close to close the edit view.

  7. Click the More More options icon on the @menu:standard node, and then select Add node below.

  8. Start to type @menu:vegetarian into the Enter a condition field of this node. Then select the @menu:vegetarian option.

  9. Add the following message in the response text field, To see our vegetarian menu, go to the <a href="https://www.example.com/vegetarian-menu.html" target="blank">vegetarian menu</a> page on our website.

    Shows an @menu:vegetarian child node being added to the #menu dialog node.

  10. Click Close to close the edit view.

  11. Click the More More options icon on the @menu:vegetarian node, and then select Add node below.

  12. Start to type @menu:cake into the Enter a condition field of this node. Then select the @menu:cake option.

  13. Add the following message in the response text field, To see our cake shop menu, go to the <a href="https://www.example.com/menu.html" target="blank">cake shop menu</a> page on our website.

    Shows an @menu:cake child node being added to the #menu dialog node.

  14. Click Close to close the edit view.

  15. The standard menu is likely to be requested most often, so move it to the bottom of the child nodes list. Placing it last can help prevent it from being triggered accidentally when someone asks for a specialty menu instead the standard menu.

  16. Click the More More options icon on the @menu:standard node, and then select Move.

    Shows the @menu:standard node being moved to come after the @menu:cake node.

  17. Select the @menu:cake node, and then choose Below node.

    Shows the child nodes below the #menu node after they are reordered.

You have added nodes that recognize user requests for menu details. Your response informs the user that there are three types of menus available, and asks them to choose one. When the user chooses a menu type, a response is displayed that provides a hypertext link to a web page with the requested menu details.

Test the menu options dialog nodes

{: #test-menu-options-intent}

Test the dialog nodes that you added to recognize menu questions.

  1. Click the Try it icon to open the "Try it out" pane.

  2. Enter, What type of food do you serve?

    The service indicates that the #menu intent is recognized, and displays the list of menu options for the user to choose from.

    Shows the Try it out pane when the user input triggers the #menu intent and the options response.

  3. Click the Cake shop option.

    The service recognizes the #menu intent and @menu:cake entity reference, and displays the response, To see our cake shop menu, go to the cake shop page on our website.

    Shows the Try it out pane after the user picks the cake shop option.

  4. Click the cake shop hyperlink in the response.

    A new web browser page opens and displays the example.com website.

  5. Close the web browser page.

Well done. You have succesfully added an intent and entity that can recognize user requests for menu details, and can direct users to the appropriate menu.

The #menu intent represents a common, key need of potential restaurant customers. Due to its importance and popularity, you added a more complex section to the dialog to address it well.

Step 4: Manage cake orders

{: #manage-orders}

Customers place orders in person, over the phone, or by using the order form on the website. After the order is placed, users can cancel the order through the virtual assistant. First, define an entity that can recognize order numbers. Then, add an intent that recognizes when users want to cancel a cake order.

Adding an order number pattern entity

{: add-pattern-entity}

You want the assistant to recognize order numbers, so you will create a pattern entity to recognize the unique format that the restaurant uses to identify its orders. The syntax of order numbers used by the restaurant's bakery is 2 upper-case letters followed by 5 numbers. For example, YR34663. Add an entity that can recognize this character pattern.

  1. Click the Entities tab.

  2. Click Add entity.

  3. Enter order_number into the entity name field.

  4. Click Create entity.

    Shows the field for adding values for the @order_number entity.

  5. Add order_syntax to the Value name field, and then click the down arrow next to Synonyms to change the type to Patterns.

    Shows the user choosing to add a pattern for the entity.

  6. Add the following regular expression to the Pattern field: [A-Z]{2}\d{5}

    Shows that one pattern has been specified for the @order-number entity.

  7. Click Add value.

    Shows that the pattern value was added.

  8. Click the Close Close arrow icon to finish adding the @order_number entity.

    Shows that the @order_number entity was added.

Add a cancel order intent

{: #cancel-order-intent}

  1. Click the Intents tab.

  2. Click Add intent.

  3. Enter cancel_order in the Intent name field, and then click Create intent.

  4. Add the following user examples:

    I want to cancel my cake order
    I need to cancel an order I just placed
    Can I cancel my cake order?
    I'd like to cancel my order
    There's been a change. I need to cancel my bakery order.
    please cancel the birthday cake order I placed last week
    The party theme changed; we don't need a cake anymore
    that order i placed, i need to cancel it.
    

    {: screen}

    Shows that the #cancel_order intent was added.

  5. Click the Close Close arrow icon to finish adding the #cancel_order intent.

Add a yes intent

{: #yes-intent}

Before you perform an action on the user's behalf, you must get confirmation that you are taking the proper action. Add a #yes intent to the dialog that can recognize when a user agrees with what the service is proposing.

  1. Click the Intents tab.

  2. Click Add intent.

  3. Enter yes in the Intent name field, and then click Create intent.

  4. Add the following user examples:

    Yes
    Correct
    Please do.
    You've got it right.
    Please do that.
    that is correct.
    That's right
    yeah
    Yup
    Yes, I'd like to go ahead with that.
    

    {: screen}

    Shows that the #yes intent was added.

  5. Click the Close Close arrow icon to finish adding the #yes intent.

Add dialog nodes that can manage requests to cancel an order

{: #cancel-order-dialog}

Now, add a dialog node that can handle requests to cancel a cake order.

  1. Click the Dialog tab.

  2. Find the #menu node. Click the More More options icon on the #menu node, and then select Add node below.

  3. Start to type #cancel_order into the Enter a condition field of this node. Then select the #cancel_order option.

  4. Add the following message in the response text field:

    If the pickup time is more than 48 hours from now, you can cancel your order.
    

    {: codeblock}

    Shows a dialog node that conditions on the #cancel_order intent and returns a text response.

    Before you can actually cancel the order, you need to know the order number. The user might specify the order number in the original request. So, to avoid asking for the order number again, check for a number with the order number pattern in the original input. To do so, define a context variable that would save the order number if it is specified.

  5. Open the context editor. Click the More More options icon, and select Open context editor.

    Shows the Open context editor menu option from the node edit view.

  6. Enter the following context variable name and value pair:

    Order number context variable details
    Variable Value
    $ordernumber

    The context variable value (<? @order_number.literal ?>) is a SpEL expression that captures the number that the user specifies that matches the pattern defined by the @order_number pattern entity. It saves it to the $ordernumber variable.

    Shows the $ordernumber context variable definition.

  7. Click Close to close the edit view.

    Now, add child nodes that either ask for the order number or get confirmation from the user that she wants to cancel an order with the detected order number.

  8. Click the More More options icon on the #cancel_order node, and then select Add child node.

    Shows the menu on the #cancel_order node with the Add child node menu option selected.

  9. Add a label to the node to distinguish it from other child nodes you will be adding. In the name field, add Ask for order number. Type true into the Enter a condition field of this node.

  10. Add the following message in the response text field:

    What is the order number?
    

    {: codeblock}

    Shows the Ask for order number node details.

  11. Click Close to close the edit view.

    Now, add another child node that informs the user that you are canceling the order.

  12. Click the More More options icon on the Ask for order number node, and then select Add child node.

  13. Type @order_number into the Enter a condition field of this node.

  14. Open the context editor. Click the More More options icon, and select Open context editor.

  15. Enter the following context variable name and value pair:

    Order number context variable details
    Variable Value
    $ordernumber

    The context variable value (<? @order_number.literal ?>) is a SpEL expression that captures the number that the user specifies that matches the pattern defined by the @order_number pattern entity. It saves it to the $ordernumber variable.

  16. Add the following message in the response text field:

    Ok. The order $ordernumber is canceled. We hope we get the opportunity to bake a cake for you sometime soon.
    

    {: codeblock}

    Shows the order number child node details.

  17. Click Close to close the edit view.

  18. Add another node to capture the case where a user provides a number, but it is not a valid order number. Click the More More options icon on the @order_number node, and then select Add node below.

  19. Type true into the Enter a condition field of this node.

  20. Add the following message in the response text field:

    I need the order number to cancel the order for you. If you don't know the order number, please call us at 958-234-3456 to cancel over the phone.
    

    {: codeblock}

    Shows the node that responds when the user does not provide a valid order number.

  21. Click Close to close the edit view.

  22. Add a node below the initial order cancelation request node that responds in the case where the user provides the order number in the initial request, so you don't have to ask for it again. Click the More More options icon on the #cancel_order node, and then select Add child node.

  23. Add a label to the node to distinguish it from other child nodes. In the name field, add Number provided. Type @order_number into the Enter a condition field of this node.

  24. Add the following message in the response text field:

    Just to confirm, you want to cancel order $ordernumber?
    

    {: codeblock}

    Shows the node that responds when the user does provide a valid order number.

  25. Click Close to close the edit view.

    You must add child nodes that check for the user's response to your confirmation question.

  26. Click the More More options icon on the Number provided node, and then select Add child node.

  27. Type #yes into the Enter a condition field of this node.

  28. Add the following message in the response text field:

    Ok. The order $ordernumber is canceled. We hope we get the opportunity to bake a cake for you sometime soon.
    

    {: codeblock}

    Shows the node that responds when the user confirms that they want to cancel the order.

  29. Click Close to close the edit view.

  30. Click the More More options icon on the #yes node, and then select Add node below.

  31. Type true into the Enter a condition field of this node.

    Do not add a response. Instead, you will redirect users to the branch that asks for the order number details that you created earlier.

  32. In the And finally section, choose Jump-to.

    Shows a true node that has no response, but has the jump-to menu option selected.

  33. Select the Ask for order number node's condition.

    Shows choosing the Ask for order number node condition as the jump-to target.

  34. Click Close to close the edit view.

  35. Move the Number provided node above the Ask for order number node. Click the More More options icon on the Number provided node, and then select Move. Select the Ask for order number node, and then click Above node.

    Shows moving the Number provided child node above the Ask for order number node.

  36. Force the conversation to evaluate the child nodes under the #cancel_order node at run time. Click to open the #cancel_order node in the edit view, and then, in the And finally section, select Skip user input.

    Shows setting the cancel order node being set to skip user input.

Test order cancelations

{: #test-cancel-order}

Test whether the service can recognize character patterns that match the pattern used for product order numbers in user input.

  1. Click the Try it icon to open the "Try it out" pane.

  2. Enter, i want to cancel my order number TW12345.

    The service recognizes both the #cancel_order intent and the @order_number entity. It responds with, If the pickup time is more than 48 hours from now, you can cancel your order. Just to confirm, you want to cancel order TW12345?

  3. Enter, Yes.

    The service recognizes the #yes intent and responds with, Ok. The order TW12345 is canceled. We hope we get the opportunity to bake a cake for you sometime soon.

    Shows the Try it out pane test of the cancel order number node when the user provides the order number in the initial input.

    Now, try it when you don't know the order number.

  4. Click Clear in the "Try it out" pane to start over. Enter, I want to cancel my order.

    The service recognizes the #cancel_order intent, and responds with, If the pickup time is more than 48 hours from now, you can cancel your order. What is the order number?

  5. Enter, I don't know.

    The service responds with, I need the order number to cancel the order for you. If you don't know the order number, please call us at 958-234-3456 to cancel over the phone.

    Shows the Try it out pane test of the cancel order number node when the user doesn't know the order number.

If you do more testing, you might find that the dialog isn't very helpful in scenarios where the user does not remember the order number format. The user might include only the numbers or the letters too, but forget that they are meant to be uppercase. So, it would be a nice touch to give them a hint in such cases, right? If you want to be kind, add another node to the dialog tree that checks for numbers in the user input.

  1. Find the @order-number node that is a child of the Ask order number node.

  2. Click the More More options icon on the @order-number node, and then select Add node below.

  3. In the condition field, add input.text.find('\d'), which is a SpEL expression that says if you find one or more numbers in the user input, trigger this response.

  4. In the text response field, add the following response:

    The correct format for our order numbers is AAnnnnn. The A's represents 2 upper-case letters, and the n's represents 5 numbers. Do you have an order number in that format?
    

    {: codeblock}

  5. Click Close to close the edit view.

  6. Click the More More options icon on the input.text.find('\d') node, and then select Add child node.

  7. Type true into the Enter a condition field of this node.

  8. Enable conditional responses by clicking Customize, and then switching the Multiple responses toggle to on.

  9. Click Apply.

  10. In the newly-added If bot recognizes field, type @order_number, and in the Respond with field, type:

    Ok. The order $ordernumber is canceled. We hope we get the opportunity to bake a cake for you sometime soon.
    

    {: codeblock}

  11. Click Add response.

  12. In the If bot recognizes field, type true, and in the Respond with field, type:

    I need the order number to cancel the order for you. If you don't know the order number, please call us at 958-234-3456 to cancel over the phone.
    

    {: codeblock}

    Shows the addition of a node that checks for numbers in the user input and responds with a hint about the order number format.

  13. Click Close to close the edit view.

Now, when you test, you can provide a set of number or a mix of numbers and text as input, and the dialog reminds you of the correct order number format. You have successfully tested your dialog, found a weakness in it, and corrected it.

Another way you can address this type of scenario is to add a node with slots. See the Adding a node with slots to a dialog tutorial to learn more about using slots. {:tip}

Step 5: Add the personal touch

{: #get-username}

If the user shows interest in the bot itself, you want the virtual assistant to recognize that curiosity and engage with the user in a more personal way. You might remember the #General_About_You intent, which is provided with the General content catalog, that we considered using earlier, before you added your own custom #about_restaurant intent. It is built to recognize just such questions from the user. Add a node that condition on this intent. In your response, you can ask for the user's name and save it to a $username variable that you can use elsewhere in the dialog, if available.

First, you need to make sure the service will recognize a name if the user provides one. So, you can enable the @sys-person entity, which is designed to recognize common first and last names (in English).

Add a person system entity

The service provides a number of system entities, which are common entities that you can use for any application.

  1. Click the Entities tab, and then click System entities.

  2. Find the @sys-person entity toggle, and then switch it On.

    Shows the @sys-person entity being enabled.

Add a node that handles questions about the bot

Now, add a dialog node that can recognize the user's interest in the bot, and respond.

  1. Click the Dialogs tab.

  2. Find the Welcome node in the dialog tree.

  3. Click the More More options icon on the Welcome node, and then select Add node below.

  4. Start to type #General_About_You into the Enter a condition field of this node. Then select the #General_About_You option.

  5. Add the following message in the response text field:

    I am a virtual assistant that is designed to answer your questions about the Truck Stop Gourmand restaurant. What's your name?
    

    {: codeblock}

    Shows the #General_About_You node being added.

  6. Click Close to close the edit view.

  7. Click the More More options icon on the #General_About_You node, and then select Add child node.

  8. Start to type @sys-person into the Enter a condition field of this node. Then select the @sys-person option.

  9. Add the following message in the response text field:

    Hello, <? @sys-person.literal ?>! It's lovely to meet you. How can I help you today.
    

    {: codeblock}

  10. To capture the name that the user provides, add a context variable to the node. Click the More More options icon, and select Open context editor.

  11. Enter the following context variable name and value pair:

    User name context variable details
    Variable Value
    $username

    The context variable value (<? @sys-person.literal ?>) is a SpEL expression that captures the user name as it is specified by the user, and then saves it to the $username context variable.

    Shows the @sys-person child node being added.

  12. Click Close to close the edit view.

  13. Click the More More options icon on the @sys-person node, and then select Add node below.

    You will add a node to capture user responses that do not include a name. If the user chooses not to share it, you want the bot to keep the conversation going anyhow.

  14. Type true into the Enter a condition field of this node.

  15. Add the following message in the response text field:

    How can I help you today?
    

    {: codeblock}

    Shows the true child node being added to capture input when the user does not provide a name.

  16. Click Close to close the edit view.

If, at run time, the user triggers this node and provides a name, then you will know the user's name. If you know it, you should use it! Add conditional responses to the greeting dialog node you added previously to include a conditional response that uses the user name, if it is known.

Add the user name to the greeting

{: #get-username}

If you know the user's name, you should include it in your greeting message. To do so, add conditional responses, and include a variation of the greeting that includes the user's name.

  1. Find the #General_Greetings node in the dialog tree, and click to open it in the edit view.

  2. Click Customize, and then switch the Multiple responses toggle to on.

    Shows that the conditional responses setting has been enabled.

  3. Click Apply.

    Shows the existing response is now part of a table of responses.

  4. Click Add response.

  5. In the If bot recognizes field, type $username, and in the Respond with field, type:

    Good day to you, $username!
    

    {: codeblock}

  6. Click the up arrow for response number 2 to move it so it is listed before response number 1 (Good day to you!).

    Shows the existing response is now part of a table of responses.

  7. Click Close to close the edit view.

Test personalization

{: #test-personalize}

Test whether the service can recognize and save a user's name, and then refer to the user by it later.

  1. Click the Try it icon to open the "Try it out" pane.

  2. Click Clear to restart the conversation session.

  3. Enter, Who are you?

    The service recognizes the #General_About_You intent. Its response ends with the question, What's your name?

  4. Enter, I am Jane Doe.

    The service recognizes Jane Doe as an @sys-person entity mention. It comments on your name, and then asks how it can help you.

  5. Enter, Hello.

    The service recognizes the #General_Greetings intent and says, Good day to you, Jane Doe! It uses the conditional response that includes the user's name because the $username context variable contains a value at the time that the greeting node is triggered.

    Shows the Try it out pane where the user asks Who are you, provides the name Jane Doe, says hello and is greeted by name.

You can add a conditional response that conditions on and includes the user's name for any other responses where personalization would add value to the conversation.

Next steps

{: #deploy}

Now that you have built and tested your workspace, you can deploy it by connecting it to a user interface. There are several ways you can do this.

Build your own front-end application

You can use the Watson SDKs to build your own front-end application that connects to your workspace using the {{site.data.keyword.conversationshort}} REST API.

Deploy to social media or messaging channels

You can use the Botkit framework to build a bot application that you can integrate with social media and messaging channels such as Slack, Facebook, and Twilio.