Hello and welcome to the Flutter AI Toolkit!
The AI Toolkit is a set of AI chat-related widgets to make it easy to add an AI chat window to your Flutter app. The AI Toolkit is organized around an abstract LLM provider API that makes it easy to swap out the LLM provider that you'd like your chat provider to use. Out of the box, it comes with support for one LLM provider integration: Firebase AI.
- Multi-turn chat: Maintains context across multiple interactions.
- Streaming responses: Displays AI responses in real-time as they're generated.
- Rich text display: Supports formatted text in chat messages.
- Voice input: Allows users to input prompts using speech.
- Multimedia attachments: Enables sending and receiving various media types.
- Custom styling: Offers extensive customization to match your app's design.
- Chat serialization/deserialization: Store and retrieve conversations between app sessions.
- Pluggable LLM support: Implement a simple interface to plug in your own LLM.
- Cross-platform support: Compatible with the Android, iOS, web, and macOS platforms.
The v0.9.0 release marks the first real breaking change since the initial
release of the Flutter AI Toolkit. This change was brought on by the migration
from the google_generative_ai and firebase_vertexai packages to the new
firebase_ai package.
One change is that there is now a single FirebaseProvider that works for both
Gemini and Vertex. Both of these providers served up the same models in the
past, e.g. gemini-2.0-flash, but did so via different mechanisms; one was via
an API key and the other was via a Firebase project. The other real difference
was the billing model. When using the firebase_ai package, API key support has
been dropped in favor of always requiring a Firebase project. The only remaining
difference is the billing model, which you can read about in the Firebase
docs.
To migrate, the following code using the GeminiProvider:
    class ChatPage extends StatelessWidget {
      const ChatPage({super.key, required this.title});
      final String title;
      @override
      Widget build(BuildContext context) {
        return Scaffold(
          appBar: AppBar(title: Text(title)),
          body: LlmChatView(
            provider: GeminiProvider( // this changes
              model: GenerativeModel( // and this changes
                model: 'gemini-2.0-flash',
                apiKey: 'GEMINI-API-KEY', // and this changes
              ),
            ),
          ),
        );
      }
    }now becomes code that uses googleAI():
class ChatPage extends StatelessWidget {
  const ChatPage({super.key});
  @override
  Widget build(BuildContext context) => Scaffold(
    appBar: AppBar(title: const Text(App.title)),
    body: LlmChatView(
      provider: FirebaseProvider( // use FirebaseProvider and googleAI()
        model: FirebaseAI.googleAI().generativeModel(model: 'gemini-2.0-flash'),
      ),
    ),
  );
}And the following code using the VertexProvider:
class ChatPage extends StatelessWidget {
  const ChatPage({super.key});
  @override
  Widget build(BuildContext context) => Scaffold(
        appBar: AppBar(title: const Text(App.title)),
        body: LlmChatView(
          provider: VertexProvider( // this changes
            chatModel: FirebaseVertexAI.instance.generativeModel( // and this
              model: 'gemini-2.0-flash',
            ),
          ),
        ),
      );
}becomes code that uses vertexAI():
class ChatPage extends StatelessWidget {
  const ChatPage({super.key});
  @override
  Widget build(BuildContext context) => Scaffold(
    appBar: AppBar(title: const Text(App.title)),
    body: LlmChatView(
      provider: FirebaseProvider( // use FirebaseProvider and vertexAI()
        model: FirebaseAI.vertexAI().generativeModel(model: 'gemini-2.0-flash'),
      ),
    ),
  );
}Also, all projects must now be initialized as Firebase projects, even those
using googleAI():
import 'package:firebase_ai/firebase_ai.dart';
import 'package:firebase_core/firebase_core.dart';
import 'package:flutter_ai_toolkit/flutter_ai_toolkit.dart';
// from `flutterfire config`: https://firebase.google.com/docs/flutter/setup
import '../firebase_options.dart';
void main() async {
  WidgetsFlutterBinding.ensureInitialized();
  await Firebase.initializeApp(options: DefaultFirebaseOptions.currentPlatform);
  runApp(const App());
}
// now you can use FirebaseAI.googleAI() or FirebaseAI.vertexAI()- 
Installation Add the following dependencies to your pubspec.yamlfile:$ flutter pub add flutter_ai_toolkit firebase_ai firebase_core 
- 
Configuration To use Firebase AI in your project, follow the steps described in Get started with the Gemini API using the Firebase AI Logic SDKs . After following these instructions, you're ready to use Firebase AI in your Flutter app. Start by initializing Firebase: import 'package:firebase_core/firebase_core.dart'; import 'package:firebase_vertexai/firebase_ai.dart'; import 'package:flutter_ai_toolkit/flutter_ai_toolkit.dart'; // Other app imports... import 'firebase_options.dart'; // Generated by `flutterfire config`. void main() async { WidgetsFlutterBinding.ensureInitialized(); await Firebase.initializeApp(options: DefaultFirebaseOptions.currentPlatform); runApp(const App()); } // Implementation of App and other widgets... With Firebase properly initialized in your Flutter app, you're now ready to create an instance of the Firebase provider: class ChatPage extends StatelessWidget { const ChatPage({super.key}); @override Widget build(BuildContext context) => Scaffold( appBar: AppBar(title: const Text(App.title)), body: LlmChatView( provider: FirebaseProvider( model: FirebaseAI.vertexAI().generativeModel( model: 'gemini-2.0-flash' ), ), ), ); } The FirebaseAIclass comes from thefirebase_aipackage. The AI Toolkit provides theFirebaseProviderclass to expose Firebase AI to theLlmChatView. Note that you provide a model name that corresponds to one of the available model names.For a complete usage example, check out the vertex.dartsample.
- 
Set up device permissions 
To enable your users to take advantage of features like voice input and media attachments, ensure that your app has the necessary permissions:
- Network access:
To enable network access on macOS, add the following to your *.entitlements
files:
<plist version="1.0">
    <dict>
      ...
      <key>com.apple.security.network.client</key>
      <true/>
    </dict>
</plist>To enable network access on Android, ensure that your AndroidManifest.xml file contains the following:
<manifest xmlns:android="http://schemas.android.com/apk/res/android">
    ...
    <uses-permission android:name="android.permission.INTERNET"/>
</manifest>- 
Microphone access: To enable voice input for users, update configs according to the permission and setup instructions for package:record.
- 
File selection: To enable users to select and attach files, follow the usage instructions for package:file_selector.
- 
Image selection: To enable users to take or select a picture from their device, refer to the installation instructions for package:image_picker.
To run the example apps in the example/lib directory, first replace the
example/lib/firebase_options.dart file by running flutterfire config (you
may need to manually delete this file first). The provided
firebase_options.dart file is a placeholder for configuration needed by the
examples.
As you use this package, please log issues and feature requests as well as submit any code you'd like to contribute. We want your feedback and contributions to ensure that the AI Toolkit is as robust and useful as it can be for your real-world apps.