Class ChartAIController
- All Implemented Interfaces:
AIController
This controller provides tools that allow the LLM to query database schemas
and create or update chart visualizations based on natural language requests.
Attach it to an AIOrchestrator via
AIOrchestrator.Builder.withController(AIController) to expose its
tools to the LLM. Workflow instructions are delivered through the description
of the get_chart_instructions tool, which the LLM reads as part of
the tool manifest.
var controller = new ChartAIController(chart, databaseProvider);
AIOrchestrator orchestrator = AIOrchestrator
.builder(llmProvider, systemPrompt).withController(controller)
.withMessageList(messageList).build();
State changes requested by the LLM are deferred and applied in
onResponse(Throwable) on the success path, avoiding partial state
and multiple redraws during a multi-tool LLM turn. The chart state is stored
directly on the Chart component, so it survives serialization.
If the LLM turn fails, onResponse(Throwable) fires with the cause —
pending changes are discarded and the chart keeps its last
successfully-rendered state.
Data conversion from SQL query results to chart series is handled by a
DataConverter. A default implementation is used unless overridden via
setDataConverter(DataConverter).
Serialization: This controller is not serialized with the
orchestrator. After deserialization, create a new controller and restore
transient dependencies via reconnect(provider) .withController(controller).apply(). The chart
data can be captured via getState() and re-applied via
restoreState(ChartState):
var controller = new ChartAIController(chart, databaseProvider);
orchestrator.reconnect(llmProvider).withController(controller).apply();
if (savedState != null) {
controller.restoreState(savedState);
}
Register a listener via addStateChangeListener(SerializableConsumer)
to be notified when the chart state changes, for example to persist
getState() after each successful AI request.
Provider compatibility: The chart tools use optional properties in
their parameter schemas, which are incompatible with OpenAI's strict
tool-calling mode (strict mode requires every property listed under
properties to also appear in required). Strict tool calling
is off by default in both LangChain4J and Spring AI; only users who
explicitly opt in (e.g. strictTools(true) on LangChain4J's
OpenAiStreamingChatModel builder) are affected.
- Author:
- Vaadin Ltd
- See Also:
-
Constructor Summary
ConstructorsConstructorDescriptionChartAIController(Chart chart, DatabaseProvider databaseProvider) Creates a new AI chart controller. -
Method Summary
Modifier and TypeMethodDescriptionaddStateChangeListener(SerializableConsumer<ChartState> listener) Adds a listener that is notified when the chart state changes after an AI request completes successfully.getState()Returns the current chart state, including the SQL queries and configuration.getTools()Returns the tools this controller exposes to the LLM.voidonResponse(Throwable error) Called on the UI thread under the session lock when the LLM stream has completed — either successfully or with an error.voidrestoreState(ChartState state) Restores a previously saved chart state.voidsetDataConverter(DataConverter dataConverter) Sets a custom data converter for transforming query results into chart series data.Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface com.vaadin.flow.component.ai.orchestrator.AIController
onRequest
-
Constructor Details
-
ChartAIController
Creates a new AI chart controller.- Parameters:
chart- the chart component to update, notnulldatabaseProvider- the database provider for schema and query execution, notnull
-
-
Method Details
-
setDataConverter
Sets a custom data converter for transforming query results into chart series data. Replaces the default converter used to produce series points from the rows returned by the configured SQL queries.- Parameters:
dataConverter- the data converter to use, notnull
-
getTools
Description copied from interface:AIControllerReturns the tools this controller exposes to the LLM.- Specified by:
getToolsin interfaceAIController- Returns:
- list of tools, or empty list if controller provides no tools
-
getState
Returns the current chart state, including the SQL queries and configuration. Returnsnullif the chart has no data queries.- Returns:
- the current state, or
null
-
restoreState
Restores a previously saved chart state. Applies the configuration, sets the queries, and re-renders the chart.Does not fire state change listeners.
- Parameters:
state- the state to restore, notnull
-
addStateChangeListener
Adds a listener that is notified when the chart state changes after an AI request completes successfully. This is typically used to persist the chart state — for example by callinggetState()and saving the result so that it can be reapplied withrestoreState(ChartState)after deserialization.The listener is not fired by
restoreState(ChartState).- Parameters:
listener- the listener, notnull- Returns:
- a registration for removing the listener
-
onResponse
Description copied from interface:AIControllerCalled on the UI thread under the session lock when the LLM stream has completed — either successfully or with an error. Every turn fires this exactly once.On success
errorisnull; use the call to commit staged state or run deferred UI updates. On failureerrorcarries the cause (stream error, timeout, or any throw betweenAIController.onRequest()and the start of the stream); release per-turn state captured inonRequest(locks, pending writes, snapshots) and discard the staged work.The default does nothing. Exceptions thrown from the hook are caught and logged; Errors propagate.
- Specified by:
onResponsein interfaceAIController- Parameters:
error- the cause of failure, ornullon success
-