Plugin.Maui.ChatGPT
1.0.2-preview1
dotnet add package Plugin.Maui.ChatGPT --version 1.0.2-preview1
NuGet\Install-Package Plugin.Maui.ChatGPT -Version 1.0.2-preview1
<PackageReference Include="Plugin.Maui.ChatGPT" Version="1.0.2-preview1" />
paket add Plugin.Maui.ChatGPT --version 1.0.2-preview1
#r "nuget: Plugin.Maui.ChatGPT, 1.0.2-preview1"
// Install Plugin.Maui.ChatGPT as a Cake Addin #addin nuget:?package=Plugin.Maui.ChatGPT&version=1.0.2-preview1&prerelease // Install Plugin.Maui.ChatGPT as a Cake Tool #tool nuget:?package=Plugin.Maui.ChatGPT&version=1.0.2-preview1&prerelease
Plugin.Maui.ChatGPT
Plugin.Maui.ChatGPT
provides text and voice communication with OpenAI's ChatGPT.
Install Plugin
Available on NuGet.
Install with the dotnet CLI: dotnet add package Plugin.Maui.ChatGPT
, or through the NuGet Package Manager in Visual Studio.
Supported Platforms
Platform | Minimum Version Supported |
---|---|
iOS | 11+ |
macOS | 10.15+ |
Android | 5.0 (API 21) |
Windows | 11 and 10 version 1809+ |
API Usage
Plugin.Maui.ChatGPT
is based on Plugin.Maui.Chat
and derives most of its properties and functionalities.
Go to Plugin.Maui.Chat
's documentation for more information about customization options.
Plugin.Maui.ChatGPT
utilizes OpenAI services for speech-to-text and text-to-speech conversion.
Permissions
Before you can start using Plugin.Maui.ChatGPT
, you will need to request the permissions for recording audio on each platform.
Dependency Injection
This NuGet depends on MAUI Community Toolkit
, so you will first need to chain up the MAUI Community Toolkit
in app builder.
builder.UseMauiCommunityToolkit();
XAML setup
To use Chat
you need to register Plugin.Maui.ChatGPT.Controls
namespace by adding below line to XAML file opening tag and provide an OpenAI's API key in OpenAiApiKey
property.
[!WARNING] Make sure you are adding
Plugin.Maui.ChatGPT.Controls
namespace, not thePlugin.Maui.ChatGPT
.
<ContentPage ...
xmlns:chat="clr-namespace:Plugin.Maui.ChatGPT.Controls;assembly=Plugin.Maui.ChatGPT"
...>
<chat:ChatGpt OpenAiApiKey="<your_api_key>"/>
And that's it. You can now communicate with ChatGPT.
Text messaging
Text messaging is enabled straight away. All you have to do is steps described above.
Voice messaging
Voice message related functionalites are utilizing OpenAI's whisper-1
for speech-to-text and tts-1
for text-to-speech.
Speech-to-text
To enable transcription of voice messages:
- Enable speech-to-text:
IsSpeechToTextEnabled="True"
. - Make audio recorder icon visible:
IsAudioRecorderVisible="True"
.
<ContentPage ...
xmlns:chat="clr-namespace:Plugin.Maui.ChatGPT.Controls;assembly=Plugin.Maui.ChatGPT"
...>
<chat:ChatGpt OpenAiApiKey="<your_api_key>"
IsSpeechToTextEnabled="True"
IsAudioRecorderVisible="True"/>
This will result in showing up the audio recorder button. Tapping it starts audio recording that will stop when user stops speaking or press audio recorder button one more time. After recording is done, it will transcribed to text.
[!WARNING] Silence detection works only on Android and Windows.
Text-to-speech
To enable text reading all that have to be done is setting IsTextReaderVisible="True"
.
<ContentPage ...
xmlns:chat="clr-namespace:Plugin.Maui.ChatGPT.Controls;assembly=Plugin.Maui.ChatGPT"
...>
<chat:ChatGpt OpenAiApiKey="<your_api_key>"
IsTextReaderVisible="True"/>
This will result in showing up a text reader icon in right-top of received message. Tap it and text will be read. Tap again to stop.
Hands-free mode
Hands-free mode provides automatization of transcription and reading. To make it work:
- Enable speech-to-text:
IsSpeechToTextEnabled="True"
. - Make hands-free mode icon visible:
IsHandsFreeModeVisible="True"
.
<ContentPage ...
xmlns:chat="clr-namespace:Plugin.Maui.ChatGPT.Controls;assembly=Plugin.Maui.ChatGPT"
...>
<chat:ChatGpt OpenAiApiKey="<your_api_key>"
IsSpeechToTextEnabled="True"
IsHandsFreeModeVisible="True"/>
This will result in showing up the hands-free mode icon. When pressed, audio recording will start, the the audio will be transcribed and send to ChatGPT. When response is received it will be read out loud and, after that, the loop goes back to recording user's message. The process continues until silence is detected or user manually turn off hands-free mode.
[!WARNING] Since silence detection works only on Android and Windows, hands-free mode is also available on those platforms.
Of course you can build combinations of above features. The ultimate XAML enabling all described above functionalities would look like this:
<?xml version="1.0" encoding="utf-8" ?>
<ContentPage xmlns="http://schemas.microsoft.com/dotnet/2021/maui"
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
xmlns:chatGpt="clr-namespace:Plugin.Maui.ChatGPT.Controls;assembly=Plugin.Maui.ChatGPT"
xmlns:viewModel="clr-namespace:Plugin.Maui.ChatGPT.Sample.ViewModels"
x:Class="Plugin.Maui.ChatGPT.Sample.Pages.AudioChatGptPage"
Title="AudioChatGptPage"
x:DataType="viewModel:AudioChatGptViewModel">
<chatGpt:ChatGpt OpenAiApiKey="{Binding OpenAiApiKey}"
IsSpeechToTextEnabled="True"
IsAudioRecorderVisible="True"
IsHandsFreeModeVisible="True"
IsTextReaderVisible="True"
Margin="10"/>
</ContentPage>
UI customization
Many properties of UI elements can be set as you wish.
For more comprehensive description go to Plugin.Maui.Chat
documentation.
Below you'll find list of all UI related properties:
Sent message
SentMessageBackgroundColor
- Sent message background color.IsSentMessageAuthorVisible
- Sent message author label visibility.SentMessageAuthorTextColor
- Sent message author text color.IsSentMessageTimestampVisible
- Sent message timestamp label visibility.SentMessageTimestampTextColor
- Sent message timestamp text color.SentMessageContentTextColor
- Sent message content text color.
Received message
UI properties
ReceivedMessageBackgroundColor
- Received message background color.IsReceivedMessageAuthorVisible
- Received message author label visibility.ReceivedMessageAuthorTextColor
- Received message author text color.IsReceivedMessageTimestampVisible
- Received message timestamp label visibility.ReceivedMessageTimestampTextColor
- Received message timestamp text color.ReceivedMessageContentTextColor
- Received message text color.ReceivedMessageAudioContentColor
- Received audio content button color.
Text reader
TextReaderIcon
- Text reader button icon.TextReaderColor
- Text reader button color.IsTextReaderVisible
- Determines whether text-to-speech is visible.
System message
SystemMessageBackgroundColor
- System message background color.SystemMessageTextColor
- System message text color.
Status label
Status
- Status shown just above the user message entry field e.g. "John Doe is typing..."IsStatusVisible
- Determines whether status label is visible.StatusTextColor
- Status text color.
Message contents entry
Text content
TextContent
- Message typed by user.TextContentColor
- Text content color.
Audio recorder
IsAudioRecorderVisible
- Determines whether start/stop record toggle button is visible.AudioRecorderIcon
- Start/stop record toggle button icon.AudioRecorderColor
- Start/stop record toggle button color.IsSpeechToTextEnabled
- Determines whether speech-to-text is enabled.
Hands-free mode button
IsHandsFreeModeVisible
- Determines whether hands-free mode toggle button is visible.HandsFreeModeIcon
- Hands-free mode toggle button icon.HandsFreeModeColor
- Hands-free mode toggle button color.
Background color
MessageEntryBackgroundColor
- Message entry background color.
Send message button
[!NOTE] Send message button is by default disabled if message is empty or
Plugin.Maui.ChatGPT
is recording, transcribing or hand-free mode is on.
IsSendMessageEnabled
- Determines whether send message button is enabled.IsSendMessageVisible
- Determines whether send message button is visible.SendMessageIcon
- Send message button icon.SendMessageColor
- Send message button color.
State properties
Those state properties are set by related services but can be overwritten if necessary.
IsRecording
- True when audio recording is on.IsTranscribing
- True when speech transcription is on.IsPlaying
- True when audio playing is on.IsReading
- True when text is being read.IsHandsFreeModeOn
- True when text is being read.
Chat messages
List of chat message is enabled in ChatMessage
property.
ChatMessages
- List of chat messages.
Credits
All icons comes from Flaticon Uicons series.
Icon was resized and coloured with Online PNG Tools.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net8.0-android34.0 is compatible. net8.0-ios17.5 is compatible. net8.0-maccatalyst17.5 is compatible. net8.0-windows10.0.19041 is compatible. |
-
net8.0-android34.0
- Azure.AI.OpenAI (>= 1.0.0-beta.14)
- CommunityToolkit.Maui (>= 9.1.0)
- Microsoft.Maui.Controls (>= 8.0.91)
- Microsoft.Maui.Controls.Compatibility (>= 8.0.91)
- Plugin.Maui.Chat (>= 2.0.1)
-
net8.0-ios17.5
- Azure.AI.OpenAI (>= 1.0.0-beta.14)
- CommunityToolkit.Maui (>= 9.1.0)
- Microsoft.Maui.Controls (>= 8.0.91)
- Microsoft.Maui.Controls.Compatibility (>= 8.0.91)
- Plugin.Maui.Chat (>= 2.0.1)
-
net8.0-maccatalyst17.5
- Azure.AI.OpenAI (>= 1.0.0-beta.14)
- CommunityToolkit.Maui (>= 9.1.0)
- Microsoft.Maui.Controls (>= 8.0.91)
- Microsoft.Maui.Controls.Compatibility (>= 8.0.91)
- Plugin.Maui.Chat (>= 2.0.1)
-
net8.0-windows10.0.19041
- Azure.AI.OpenAI (>= 1.0.0-beta.14)
- CommunityToolkit.Maui (>= 9.1.0)
- Microsoft.Maui.Controls (>= 8.0.91)
- Microsoft.Maui.Controls.Compatibility (>= 8.0.91)
- Plugin.Maui.Chat (>= 2.0.1)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
1.0.2-preview1 | 41 | 10/17/2024 |
1.0.1-preview1 | 46 | 10/16/2024 |
1.0.0-preview5 | 46 | 10/15/2024 |
1.0.0-preview4 | 44 | 10/15/2024 |