2024-04-22 16:56:18 +00:00
|
|
|
@page "/chat"
|
|
|
|
@using AIStudio.Chat
|
2024-05-04 09:11:09 +00:00
|
|
|
@using AIStudio.Settings
|
2024-04-22 16:56:18 +00:00
|
|
|
|
2024-05-04 09:11:09 +00:00
|
|
|
<MudText Typo="Typo.h3" Class="mb-2">Chats</MudText>
|
|
|
|
<MudSelect T="Provider" @bind-Value="@this.selectedProvider" Adornment="Adornment.Start" AdornmentIcon="@Icons.Material.Filled.Apps" Margin="Margin.Dense" Label="Provider" Class="mb-2 rounded-lg" Variant="Variant.Outlined">
|
|
|
|
@foreach (var provider in this.SettingsManager.ConfigurationData.Providers)
|
|
|
|
{
|
|
|
|
<MudSelectItem Value="@provider"/>
|
|
|
|
}
|
|
|
|
</MudSelect>
|
2024-04-22 16:56:18 +00:00
|
|
|
|
2024-05-04 09:11:09 +00:00
|
|
|
<div class="d-flex flex-column" style="height: calc(100vh - 12.3em);">
|
2024-04-22 16:56:18 +00:00
|
|
|
<div class="flex-auto overflow-auto">
|
2024-05-04 09:11:09 +00:00
|
|
|
@if (this.chatThread is not null)
|
|
|
|
{
|
|
|
|
foreach (var block in this.chatThread.Blocks.OrderBy(n => n.Time))
|
|
|
|
{
|
|
|
|
<ContentBlockComponent Role="@block.Role" Type="@block.ContentType" Time="@block.Time" Content="@block.Content"/>
|
|
|
|
}
|
|
|
|
}
|
2024-04-22 16:56:18 +00:00
|
|
|
</div>
|
|
|
|
|
|
|
|
<MudPaper Style="flex: 0 0 auto;">
|
2024-06-01 17:55:12 +00:00
|
|
|
<MudTextField T="string" @ref="@this.inputField" @bind-Text="@this.userInput" Variant="Variant.Outlined" AutoGrow="@true" Lines="3" MaxLines="12" Label="@this.InputLabel" Placeholder="@this.ProviderPlaceholder" Adornment="Adornment.End" AdornmentIcon="@Icons.Material.Filled.Send" OnAdornmentClick="() => this.SendMessage()" ReadOnly="!this.IsProviderSelected || this.isStreaming" Immediate="@true" OnKeyUp="this.InputKeyEvent" UserAttributes="@USER_INPUT_ATTRIBUTES"/>
|
2024-04-22 16:56:18 +00:00
|
|
|
</MudPaper>
|
|
|
|
</div>
|