mirror of
https://github.com/MindWorkAI/AI-Studio.git
synced 2025-02-05 19:49:06 +00:00
70 lines
2.5 KiB
Plaintext
70 lines
2.5 KiB
Plaintext
@using AIStudio.Tools
|
|
@using MudBlazor
|
|
|
|
<MudCard Class="@this.CardClasses" Outlined="@true">
|
|
<MudCardHeader>
|
|
<CardHeaderAvatar>
|
|
<MudAvatar Color="@this.Role.ToColor()">
|
|
<MudIcon Icon="@this.Role.ToIcon()"/>
|
|
</MudAvatar>
|
|
</CardHeaderAvatar>
|
|
<CardHeaderContent>
|
|
<MudText Typo="Typo.body1">@this.Role.ToName() (@this.Time)</MudText>
|
|
</CardHeaderContent>
|
|
<CardHeaderActions>
|
|
<MudIconButton Icon="@Icons.Material.Filled.ContentCopy" Color="Color.Default" OnClick="@this.CopyToClipboard" />
|
|
</CardHeaderActions>
|
|
</MudCardHeader>
|
|
<MudCardContent>
|
|
@if (!this.HideContent)
|
|
{
|
|
if (this.Content.IsStreaming)
|
|
{
|
|
<MudProgressLinear Color="Color.Primary" Indeterminate="true" Class="mb-6" />
|
|
}
|
|
|
|
switch (this.Type)
|
|
{
|
|
case ContentType.TEXT:
|
|
if (this.Content is ContentText textContent)
|
|
{
|
|
if (textContent.InitialRemoteWait)
|
|
{
|
|
<MudSkeleton Width="30%" Height="42px;"/>
|
|
<MudSkeleton Width="80%"/>
|
|
<MudSkeleton Width="100%"/>
|
|
}
|
|
else
|
|
{
|
|
@if (this.Content.IsStreaming)
|
|
{
|
|
<MudText Typo="Typo.body1" Style="white-space: pre-wrap;">
|
|
@textContent.Text
|
|
</MudText>
|
|
}
|
|
else
|
|
{
|
|
<MudMarkdown Value="@textContent.Text" OverrideHeaderTypo="@Markdown.OverrideHeaderTypo" CodeBlockTheme="@this.CodeColorPalette"/>
|
|
}
|
|
}
|
|
}
|
|
|
|
break;
|
|
|
|
case ContentType.IMAGE:
|
|
if (this.Content is ContentImage imageContent)
|
|
{
|
|
<MudImage Src="@imageContent.URL"/>
|
|
}
|
|
|
|
break;
|
|
|
|
default:
|
|
<MudText Typo="Typo.body2">
|
|
Cannot render content of type @this.Type yet.
|
|
</MudText>
|
|
break;
|
|
}
|
|
}
|
|
</MudCardContent>
|
|
</MudCard> |