Develop a component for Virtual Agent
Create a custom Virtual Agent component to gather input or display information in the Virtual Agent client interface.
Types of Virtual Agent components
To develop a component for Virtual Agent, add specific properties and actions to interact with the Virtual Agent client interface. The properties required depend on the type of component you are creating.
- Response component
-
A response component only provides information to the user, and does not gather input or handle user interaction. For example, a card control that does not require user input and is only in the conversation once.
Add a property to your response component to handle the data sent by the Virtual Agent server.
표 1. Output component properties Property Description controlData Initial data that the Virtual Agent server sends to your component as the topic runs. Data type: JSON Object
- Input component
-
An input component displays information and/or gathers user input. It includes the same property as the output component to handle data sent by the server, but has more possible states and requires user interaction.
표 2. Input component properties Property Description controlData Initial data that the Virtual Agent server sends to your component as the topic runs. Data type: JSON Object
responseValue Data sent to the component from the user's response, either from the client directly, or from the server if there is a refresh. Only use in components that require user input. Data type: JSON Object
forceCloseControl Flag that indicates whether the component can accept input. When true, the control closes and the user cannot interact with it. Monitor changes on the client to update this value. Only use in components that require user input. Data type: Boolean
Use this action to emit data from user interaction.
표 3. Input component actions Action Description VA_CONTROL#VALUE_SENT Response data from the client to send to the server. Only use in components that require user input. Data type: JSON Object
Input component states
Because they accept data, input components must handle multiple states. The state flow is generally as follows:
- Virtual Agent shows the custom component in the waiting for input state.
- The user interacts with the component to provide input.
- The component closes and sends the
responseValueproperty to the server. - The server runs the server-side logic and sends the component with the user's input back to the client.
- Waiting for Input
-
The initial state of a component waiting for user interaction. The
controlDataproperty is set, but theforceControlClosedproperty is false. This example shows a slider component in the waiting for input state.In this example, if the user has not provided a
responseValueand the control is not closed, the slider and the input button display.const {controlClosed, sliderVal, sliderMin, sliderMax} = state; return (<div class={{"slider-chat": true}}> {responseValue ? null : <Fragment> <div class={{"slider-label": true}}>{label}</div> {controlClosed ? null : <Fragment> <div class={{"slider-container": true}}> <input on-change={onSliderChange} type="range" min={sliderMin} max={sliderMax} value={sliderVal} class={{"slider": true}} /> <div class={{"slider-value": true}}> {unitIcon && <div class={{"unit-icon": true}}><img src={unitIcon} /></div> } {sliderVal} {unitName} </div> <div class={{"button-container":true}}> <now-button variant="primary" label={buttonText || 'Confirm'} /> </div></div></Fragment>} - Handling Input
-
In the previous example, the slider uses a
now-buttoncomponent, which the user clicks to confirm input and send it to the server. When the user clicks the button, theVA_CONTROL#VALUE_SENTaction fires with theresponseValuepayload.'NOW_BUTTON#CLICKED': (data) => { const {updateState, dispatch, state: {sliderVal}} = data; updateState({controlClosed: true}); dispatch('VA_CONTROL#VALUE_SENT', { value: { sliderVal } }); } - Closed
-
A component that is closed can no longer accept user input. Components are generally closed because:
- The user responded to the component. The component closes and the conversation continues.
- The user ended the chat. The server does not wait for a response.
For example, the slider component only renders the original prompt when in the closed state.
- Sending response
-
After the user responds, the control is rendered again on the user's side of the conversation with the value of the
responseValueproperty.For example, the slider control uses this snippet to render the response.
{responseValue && <div className="response-container slider-value"> {unitIcon && <div className="unit-icon"><img src={unitIcon} /></div> } {returnVal} {unitName} </div>}
Adding the component to Virtual Agent Designer
After developing the component and deploying it to your instance, add it to Virtual Agent Designer using a custom control and definition. For more information, see Virtual Agent custom controls.