2024-08-21 06:30:01 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								@attribute [Route(Routes.CHAT)]
							 
						 
					
						
							
								
									
										
										
										
											2024-07-28 09:20:00 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								@using AIStudio.Settings.DataModel
							 
						 
					
						
							
								
									
										
										
										
											2024-07-14 19:46:17 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								@inherits MSGComponentBase
							 
						 
					
						
							
								
									
										
										
										
											2024-07-13 08:37:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2025-01-21 12:40:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								<div class="inner-scrolling-context">
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    
							 
						 
					
						
							
								
									
										
										
										
											2025-05-25 13:41:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    <MudStack Row="true" AlignItems="AlignItems.Center" Class="mb-2" StretchItems="StretchItems.Start">
							 
						 
					
						
							
								
									
										
										
										
											2025-05-21 18:23:44 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        <MudText Typo="Typo.h3">
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            @if (this.chatThread is not null && this.chatThread.WorkspaceId != Guid.Empty)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                @(T("Chat in Workspace") + $" \"{this.currentWorkspaceName}\"")
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            else
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                @T("Disappearing Chat")
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        </MudText>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        
							 
						 
					
						
							
								
									
										
										
										
											2025-05-25 13:41:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        <MudTooltip Text="@T("Show the chat options")" Placement="@TOOLBAR_TOOLTIP_PLACEMENT">
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            <MudIconButton Variant="Variant.Text" Icon="@Icons.Material.Filled.Settings" Color="Color.Default" OnClick="@this.OpenChatSettingsDialog"/>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        </MudTooltip>
							 
						 
					
						
							
								
									
										
										
										
											2025-05-21 18:23:44 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    </MudStack>
							 
						 
					
						
							
								
									
										
										
										
											2025-01-21 12:40:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    <ProviderSelection @bind-ProviderSettings="@this.providerSettings"/>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    @if (this.AreWorkspacesVisible)
							 
						 
					
						
							
								
									
										
										
										
											2024-07-13 08:37:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    {
							 
						 
					
						
							
								
									
										
										
										
											2025-01-21 12:40:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        <MudSplitter Dimension="@this.ReadSplitterPosition" DimensionChanged="this.SplitterChanged" EnableSlide="@this.AreWorkspacesVisible" EnableMargin="@false" StartContentStyle="margin-right: 1em;" BarStyle="" EndContentStyle="margin-left: 1em;">
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            <StartContent>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                @if (this.SettingsManager.ConfigurationData.Workspace.DisplayBehavior is WorkspaceDisplayBehavior.TOGGLE_SIDEBAR && this.SettingsManager.ConfigurationData.Workspace.IsSidebarVisible)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    // Case: Sidebar can be toggled and is currently visible
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    <InnerScrolling FillEntireHorizontalSpace="@true" Class="border border-solid rounded-lg mb-3" MinWidth="26em">
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        <HeaderContent>
							 
						 
					
						
							
								
									
										
										
										
											2025-05-25 13:41:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                            <MudStack Row="true" AlignItems="AlignItems.Center" StretchItems="StretchItems.Start" Wrap="Wrap.NoWrap" Spacing="1" Class="mb-0 ms-6 mt-2">
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                <MudText Typo="Typo.h6">
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                    @T("Your workspaces")
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                </MudText>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                <MudTooltip Text="@T("Configure your workspaces")" Placement="@TOOLBAR_TOOLTIP_PLACEMENT">
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                    <MudIconButton Icon="@Icons.Material.Filled.Settings" Size="Size.Medium" OnClick="async () => await this.OpenWorkspacesSettingsDialog()"/>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                </MudTooltip>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                <MudTooltip Text="@T("Hide your workspaces")" Placement="@TOOLBAR_TOOLTIP_PLACEMENT">
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                    <MudIconButton Size="Size.Medium" Icon="@this.WorkspaceSidebarToggleIcon" Class="me-1" OnClick="() => this.ToggleWorkspaceSidebar()"/>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                </MudTooltip>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            </MudStack>
							 
						 
					
						
							
								
									
										
										
										
											2025-01-21 12:40:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        </HeaderContent>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        <ChildContent>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            <Workspaces @ref="this.workspaces" @bind-CurrentChatThread="@this.chatThread"/>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        </ChildContent>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    </InnerScrolling>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                else
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    // Case: Sidebar is always visible
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    <InnerScrolling FillEntireHorizontalSpace="@true" Class="border border-solid rounded-lg mb-3" MinWidth="26em">
							 
						 
					
						
							
								
									
										
										
										
											2025-05-25 13:41:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        <HeaderContent>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            <MudStack Row="true" AlignItems="AlignItems.Center" StretchItems="StretchItems.Start" Wrap="Wrap.NoWrap" Class="d-flex mb-0 ms-6 mt-2">
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                <MudText Typo="Typo.h6">
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                    @T("Your workspaces")
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                </MudText>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                <MudSpacer/>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                <MudTooltip Text="@T("Configure your workspaces")" Placement="@TOOLBAR_TOOLTIP_PLACEMENT">
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                    <MudIconButton Icon="@Icons.Material.Filled.Settings" Size="Size.Medium" OnClick="async () => await this.OpenWorkspacesSettingsDialog()"/>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                                </MudTooltip>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            </MudStack>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        </HeaderContent>
							 
						 
					
						
							
								
									
										
										
										
											2025-01-21 12:40:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        <ChildContent>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                            <Workspaces @ref="this.workspaces" @bind-CurrentChatThread="@this.chatThread"/>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        </ChildContent>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    </InnerScrolling>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            </StartContent>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            <EndContent>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                <ChatComponent
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    @bind-ChatThread="@this.chatThread"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    @bind-Provider="@this.providerSettings"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    Workspaces="@this.workspaces"
							 
						 
					
						
							
								
									
										
										
										
											2025-01-21 17:58:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    WorkspaceName="name => this.UpdateWorkspaceName(name)"/>
							 
						 
					
						
							
								
									
										
										
										
											2025-01-21 12:40:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            </EndContent>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        </MudSplitter>
							 
						 
					
						
							
								
									
										
										
										
											2024-07-13 08:37:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    }
							 
						 
					
						
							
								
									
										
										
										
											2025-01-21 12:40:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    else if (this.SettingsManager.ConfigurationData.Workspace.StorageBehavior is not WorkspaceStorageBehavior.DISABLE_WORKSPACES && this.SettingsManager.ConfigurationData.Workspace.DisplayBehavior is WorkspaceDisplayBehavior.TOGGLE_SIDEBAR)
							 
						 
					
						
							
								
									
										
										
										
											2024-07-13 08:37:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    {
							 
						 
					
						
							
								
									
										
										
										
											2025-01-21 12:40:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        // Case: Sidebar can be toggled and is currently hidden
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        <MudStack Row="@true" Style="width: 100%; overflow: hidden; height: 100%; flex-grow: 1; min-height: 0;">
							 
						 
					
						
							
								
									
										
										
										
											2025-05-25 13:41:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            <MudPaper Class="border border-solid rounded-lg mb-3 d-flex">
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                <MudStack Row="false" AlignItems="AlignItems.Center" StretchItems="StretchItems.Middle" Wrap="Wrap.NoWrap">
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    <MudTooltip Text="@T("Show your workspaces")" Placement="@TOOLBAR_TOOLTIP_PLACEMENT">
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        <MudIconButton Size="Size.Medium" Icon="@this.WorkspaceSidebarToggleIcon" OnClick="() => this.ToggleWorkspaceSidebar()"/>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    </MudTooltip>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    <MudText Typo="Typo.h6" Style="writing-mode: vertical-lr; word-spacing: 0.5em;">
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        @T("Your workspaces")
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    </MudText>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    <MudTooltip Text="@T("Configure your workspaces")" Placement="@TOOLBAR_TOOLTIP_PLACEMENT">
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        <MudIconButton Icon="@Icons.Material.Filled.Settings" Size="Size.Medium" OnClick="async () => await this.OpenWorkspacesSettingsDialog()"/>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    </MudTooltip>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                </MudStack>
							 
						 
					
						
							
								
									
										
										
										
											2025-01-21 12:40:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            </MudPaper>
							 
						 
					
						
							
								
									
										
										
										
											2024-07-13 08:37:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2025-01-02 12:16:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            <ChatComponent
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                @bind-ChatThread="@this.chatThread"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                @bind-Provider="@this.providerSettings"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                Workspaces="@this.workspaces"
							 
						 
					
						
							
								
									
										
										
										
											2025-01-21 17:58:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                WorkspaceName="name => this.UpdateWorkspaceName(name)"/>
							 
						 
					
						
							
								
									
										
										
										
											2025-01-21 12:40:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        </MudStack>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    else
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // Case: Workspaces are disabled or shown in an overlay
							 
						 
					
						
							
								
									
										
										
										
											2025-01-02 12:16:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        <ChatComponent
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            @bind-ChatThread="@this.chatThread"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            @bind-Provider="@this.providerSettings"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            Workspaces="@this.workspaces"
							 
						 
					
						
							
								
									
										
										
										
											2025-01-21 17:58:20 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            WorkspaceName="name => this.UpdateWorkspaceName(name)"/>
							 
						 
					
						
							
								
									
										
										
										
											2025-01-21 12:40:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    }
							 
						 
					
						
							
								
									
										
										
										
											2024-07-13 08:37:57 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2025-01-21 12:40:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    @if (
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        this.SettingsManager.ConfigurationData.Workspace.StorageBehavior != WorkspaceStorageBehavior.DISABLE_WORKSPACES
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        && this.SettingsManager.ConfigurationData.Workspace.DisplayBehavior is WorkspaceDisplayBehavior.TOGGLE_OVERLAY)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        <MudDrawer @bind-Open="@this.workspaceOverlayVisible" Width="40em" Height="100%" Anchor="Anchor.Start" Variant="DrawerVariant.Temporary" Elevation="1">
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            <MudDrawerHeader>
							 
						 
					
						
							
								
									
										
										
										
											2025-05-25 13:41:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                <MudStack Row="true" AlignItems="AlignItems.Center" StretchItems="StretchItems.Start" Wrap="Wrap.NoWrap" Style="width: 100%;">
							 
						 
					
						
							
								
									
										
										
										
											2025-01-21 12:40:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    <MudText Typo="Typo.h6" Class="mr-3">
							 
						 
					
						
							
								
									
										
										
										
											2025-04-24 11:50:14 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                        @T("Your workspaces")
							 
						 
					
						
							
								
									
										
										
										
											2025-01-21 12:40:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    </MudText>
							 
						 
					
						
							
								
									
										
										
										
											2025-05-25 13:41:55 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    <MudTooltip Text="@T("Configure your workspaces")" Placement="@TOOLBAR_TOOLTIP_PLACEMENT">
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        <MudIconButton Icon="@Icons.Material.Filled.Settings" Size="Size.Medium" OnClick="async () => await this.OpenWorkspacesSettingsDialog()"/>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    </MudTooltip>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    <MudIconButton Icon="@Icons.Material.Filled.Close" Color="Color.Error" Size="Size.Medium" OnClick="() => this.ToggleWorkspacesOverlay()"/>
							 
						 
					
						
							
								
									
										
										
										
											2025-01-21 12:40:47 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                </MudStack>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            </MudDrawerHeader>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            <MudDrawerContainer Class="ml-6">
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                <Workspaces @ref="this.workspaces" @bind-CurrentChatThread="@this.chatThread"/>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            </MudDrawerContainer>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        </MudDrawer>
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								</div>