Skip to main content

AI Chat (AI Assistant)

The Chat widget, part of the AI Assistant Apps, enables interaction with AI models using the Appsmith AI datasource. It automatically creates an Appsmith AI query, which you can configure as needed.

info

Currently, the Chat widget only supports the Appsmith AI datasource and does not support other datasources or queries.

Image

Content Properties

These properties are customizable options present in the property pane of the widget, allowing users to modify the widget according to their preferences.

Data

Chat Query

When the Chat widget is added to the canvas, a default AI Chat Query is automatically created to process messages. This query contains the main logic and data required for the Chat widget to function. You can change this query by selecting a different one from the Chat Query dropdown in the widget's property pane.

General

Description

The Description property allows you to add text that guides users on how to use the Chat widget. This section can include instructions, context, or any additional information to help users interact with the chat effectively. You can also use {{}} to dynamically display data from JavaScript functions or queries.

When users click on the info icon in the Chat widget, a modal is displayed showing this description, providing additional guidance or context.

Placeholder

The Placeholder property allows you to add placeholder text to the message input box of the Chat widget. This text serves as a hint or example to guide users on what type of input is expected. The placeholder disappears when users start typing in the input box.

You can also use {{}} to dynamically generate placeholder text based on data from JavaScript functions or queries.

Initial Assistant Suggestions

The Initial Assistant Suggestions property allows you to define a set of suggested messages that appear when the chat starts. These suggestions are displayed as quick replies, helping users know what to ask or interact with next. Each suggestion consists of a label (the text shown to the user) and a value (the underlying data that triggers actions or responses).

When a user clicks on a prompt, the associated value is sent to the AI to initiate a response.

[
{ "label": "Create support dashboard", "value": "How do I build a support dashboard?" },
{ "label": "View account settings", "value": "How can I update my account information?" }
]

You can use JavaScript to dynamically generate these suggestions. For example, the map() function can be used to create suggestions from an array of data.

{{usersAPI.data.map(suggestion => ({
label: suggestion.title,
value: suggestion.description
}))}}

Visible boolean

Controls the visibility of the widget. If you turn off this property, the widget is not visible in View Mode. Additionally, you can use JavaScript by clicking on JS next to the Visible property to control the widget's visibility conditionally.

For example, if you want to make the widget visible only when the user selects "Yes" from a Select widget, you can use the following JavaScript expression:

{{Select1.selectedOptionValue === "Yes"}}

Assistant

Assistant Name

The Assistant Name property allows you to define the name displayed for the AI Assistant in the chat widget. This name appears at the top of the chat interface, helping users identify the assistant they are interacting with.

Initial message

The Initial Message property sets the default message displayed to users when the chat widget is loaded. This message appears below the chat title and provides context or a starting point for the user.

You can use static text or bind dynamic data using {{}} to tailor the message.

Hello, {{appsmith.user.email}}. How can we help you today?

Style properties

Style properties allow you to change the look and feel of the widget.

General

General properties are essential configurations that provide overall control over the widget's behavior and appearance.

Height

Controls the vertical size of the Chat widget.

  • Medium: Standard height.
  • Large: Taller layout for extended conversations.
  • Fit to Page: Adjusts height to fill the available page space.

Reference properties

Reference properties are properties that are not available in the property pane but can be accessed using the dot operator in other widgets or JavaScript functions. They provide additional information or allow interaction with the widget programmatically. For instance, to get the visibility status, you can use AIChat1.isVisible.

isVisible boolean

The isVisible property indicates the visibility state of a widget, with true indicating it is visible and false indicating it is hidden.

Example:

{{AIChat1.isVisible}}

Methods

Widget property setters enable you to modify the values of widget properties at runtime, eliminating the need to manually update properties in the editor.

These methods are asynchronous, and you can use the .then() block to ensure execution and sequencing of subsequent lines of code in Appsmith.

setVisibility boolean

Sets the visibility of the widget.

Example:

AIChat1.setVisibility(true).then(() => {
// code to be executed after visibility is set
})