AI-Studio/app/MindWork AI Studio/Chat/ContentBlockComponent.razor

69 lines
2.4 KiB
Plaintext
Raw Normal View History

@using MudBlazor
<MudCard Class="my-2 rounded-lg" Outlined="@true">
<MudCardHeader>
<CardHeaderAvatar>
2024-05-04 09:11:09 +00:00
<MudAvatar Color="@this.Role.ToColor()">
<MudIcon Icon="@this.Role.ToIcon()"/>
</MudAvatar>
</CardHeaderAvatar>
<CardHeaderContent>
2024-05-04 09:11:09 +00:00
<MudText Typo="Typo.body1">@this.Role.ToName() (@this.Time)</MudText>
</CardHeaderContent>
<CardHeaderActions>
2024-05-04 09:11:09 +00:00
<MudIconButton Icon="@Icons.Material.Filled.ContentCopy" Color="Color.Default" OnClick="@this.CopyToClipboard" />
</CardHeaderActions>
</MudCardHeader>
<MudCardContent>
2024-05-04 09:11:09 +00:00
@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"/>
}
2024-05-04 09:11:09 +00:00
}
}
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>