mirror of
https://github.com/MindWorkAI/AI-Studio.git
synced 2025-09-02 15:42:56 +00:00
Improved workspace handling (#540)
Some checks are pending
Build and Release / Read metadata (push) Waiting to run
Build and Release / Build app (${{ matrix.dotnet_runtime }}) (-aarch64-apple-darwin, osx-arm64, macos-latest, aarch64-apple-darwin, dmg updater) (push) Blocked by required conditions
Build and Release / Build app (${{ matrix.dotnet_runtime }}) (-aarch64-pc-windows-msvc.exe, win-arm64, windows-latest, aarch64-pc-windows-msvc, nsis updater) (push) Blocked by required conditions
Build and Release / Build app (${{ matrix.dotnet_runtime }}) (-aarch64-unknown-linux-gnu, linux-arm64, ubuntu-22.04-arm, aarch64-unknown-linux-gnu, appimage deb updater) (push) Blocked by required conditions
Build and Release / Build app (${{ matrix.dotnet_runtime }}) (-x86_64-apple-darwin, osx-x64, macos-latest, x86_64-apple-darwin, dmg updater) (push) Blocked by required conditions
Build and Release / Build app (${{ matrix.dotnet_runtime }}) (-x86_64-pc-windows-msvc.exe, win-x64, windows-latest, x86_64-pc-windows-msvc, nsis updater) (push) Blocked by required conditions
Build and Release / Build app (${{ matrix.dotnet_runtime }}) (-x86_64-unknown-linux-gnu, linux-x64, ubuntu-22.04, x86_64-unknown-linux-gnu, appimage deb updater) (push) Blocked by required conditions
Build and Release / Prepare & create release (push) Blocked by required conditions
Build and Release / Publish release (push) Blocked by required conditions
Some checks are pending
Build and Release / Read metadata (push) Waiting to run
Build and Release / Build app (${{ matrix.dotnet_runtime }}) (-aarch64-apple-darwin, osx-arm64, macos-latest, aarch64-apple-darwin, dmg updater) (push) Blocked by required conditions
Build and Release / Build app (${{ matrix.dotnet_runtime }}) (-aarch64-pc-windows-msvc.exe, win-arm64, windows-latest, aarch64-pc-windows-msvc, nsis updater) (push) Blocked by required conditions
Build and Release / Build app (${{ matrix.dotnet_runtime }}) (-aarch64-unknown-linux-gnu, linux-arm64, ubuntu-22.04-arm, aarch64-unknown-linux-gnu, appimage deb updater) (push) Blocked by required conditions
Build and Release / Build app (${{ matrix.dotnet_runtime }}) (-x86_64-apple-darwin, osx-x64, macos-latest, x86_64-apple-darwin, dmg updater) (push) Blocked by required conditions
Build and Release / Build app (${{ matrix.dotnet_runtime }}) (-x86_64-pc-windows-msvc.exe, win-x64, windows-latest, x86_64-pc-windows-msvc, nsis updater) (push) Blocked by required conditions
Build and Release / Build app (${{ matrix.dotnet_runtime }}) (-x86_64-unknown-linux-gnu, linux-x64, ubuntu-22.04, x86_64-unknown-linux-gnu, appimage deb updater) (push) Blocked by required conditions
Build and Release / Prepare & create release (push) Blocked by required conditions
Build and Release / Publish release (push) Blocked by required conditions
This commit is contained in:
parent
5d17dcc29b
commit
e931e28ab1
@ -2119,6 +2119,9 @@ UI_TEXT_CONTENT["AISTUDIO::COMPONENTS::WORKSPACES::T1016188706"] = "Are you sure
|
|||||||
-- Move chat
|
-- Move chat
|
||||||
UI_TEXT_CONTENT["AISTUDIO::COMPONENTS::WORKSPACES::T1133040906"] = "Move chat"
|
UI_TEXT_CONTENT["AISTUDIO::COMPONENTS::WORKSPACES::T1133040906"] = "Move chat"
|
||||||
|
|
||||||
|
-- Unnamed workspace
|
||||||
|
UI_TEXT_CONTENT["AISTUDIO::COMPONENTS::WORKSPACES::T1307384014"] = "Unnamed workspace"
|
||||||
|
|
||||||
-- Delete
|
-- Delete
|
||||||
UI_TEXT_CONTENT["AISTUDIO::COMPONENTS::WORKSPACES::T1469573738"] = "Delete"
|
UI_TEXT_CONTENT["AISTUDIO::COMPONENTS::WORKSPACES::T1469573738"] = "Delete"
|
||||||
|
|
||||||
@ -2164,6 +2167,9 @@ UI_TEXT_CONTENT["AISTUDIO::COMPONENTS::WORKSPACES::T3045856778"] = "Move Chat to
|
|||||||
-- Please enter a new or edit the name for your workspace '{0}':
|
-- Please enter a new or edit the name for your workspace '{0}':
|
||||||
UI_TEXT_CONTENT["AISTUDIO::COMPONENTS::WORKSPACES::T323280982"] = "Please enter a new or edit the name for your workspace '{0}':"
|
UI_TEXT_CONTENT["AISTUDIO::COMPONENTS::WORKSPACES::T323280982"] = "Please enter a new or edit the name for your workspace '{0}':"
|
||||||
|
|
||||||
|
-- Unnamed chat
|
||||||
|
UI_TEXT_CONTENT["AISTUDIO::COMPONENTS::WORKSPACES::T3310482275"] = "Unnamed chat"
|
||||||
|
|
||||||
-- Rename
|
-- Rename
|
||||||
UI_TEXT_CONTENT["AISTUDIO::COMPONENTS::WORKSPACES::T3355849203"] = "Rename"
|
UI_TEXT_CONTENT["AISTUDIO::COMPONENTS::WORKSPACES::T3355849203"] = "Rename"
|
||||||
|
|
||||||
@ -5692,5 +5698,8 @@ UI_TEXT_CONTENT["AISTUDIO::TOOLS::VALIDATION::PROVIDERVALIDATION::T497939286"] =
|
|||||||
-- Please select a model.
|
-- Please select a model.
|
||||||
UI_TEXT_CONTENT["AISTUDIO::TOOLS::VALIDATION::PROVIDERVALIDATION::T818893091"] = "Please select a model."
|
UI_TEXT_CONTENT["AISTUDIO::TOOLS::VALIDATION::PROVIDERVALIDATION::T818893091"] = "Please select a model."
|
||||||
|
|
||||||
|
-- Unnamed workspace
|
||||||
|
UI_TEXT_CONTENT["AISTUDIO::TOOLS::WORKSPACEBEHAVIOUR::T1307384014"] = "Unnamed workspace"
|
||||||
|
|
||||||
-- Delete Chat
|
-- Delete Chat
|
||||||
UI_TEXT_CONTENT["AISTUDIO::TOOLS::WORKSPACEBEHAVIOUR::T2244038752"] = "Delete Chat"
|
UI_TEXT_CONTENT["AISTUDIO::TOOLS::WORKSPACEBEHAVIOUR::T2244038752"] = "Delete Chat"
|
||||||
|
@ -112,9 +112,30 @@ public partial class Workspaces : MSGComponentBase
|
|||||||
// Enumerate the chat directories:
|
// Enumerate the chat directories:
|
||||||
foreach (var tempChatDirPath in Directory.EnumerateDirectories(temporaryDirectories))
|
foreach (var tempChatDirPath in Directory.EnumerateDirectories(temporaryDirectories))
|
||||||
{
|
{
|
||||||
// Read the `name` file:
|
// Read or create the `name` file (self-heal):
|
||||||
var chatNamePath = Path.Join(tempChatDirPath, "name");
|
var chatNamePath = Path.Join(tempChatDirPath, "name");
|
||||||
var chatName = await File.ReadAllTextAsync(chatNamePath, Encoding.UTF8);
|
string chatName;
|
||||||
|
try
|
||||||
|
{
|
||||||
|
if (!File.Exists(chatNamePath))
|
||||||
|
{
|
||||||
|
chatName = T("Unnamed chat");
|
||||||
|
await File.WriteAllTextAsync(chatNamePath, chatName, Encoding.UTF8);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
chatName = await File.ReadAllTextAsync(chatNamePath, Encoding.UTF8);
|
||||||
|
if (string.IsNullOrWhiteSpace(chatName))
|
||||||
|
{
|
||||||
|
chatName = T("Unnamed chat");
|
||||||
|
await File.WriteAllTextAsync(chatNamePath, chatName, Encoding.UTF8);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch
|
||||||
|
{
|
||||||
|
chatName = T("Unnamed chat");
|
||||||
|
}
|
||||||
|
|
||||||
// Read the last change time of the chat:
|
// Read the last change time of the chat:
|
||||||
var chatThreadPath = Path.Join(tempChatDirPath, "thread.json");
|
var chatThreadPath = Path.Join(tempChatDirPath, "thread.json");
|
||||||
@ -158,9 +179,30 @@ public partial class Workspaces : MSGComponentBase
|
|||||||
// Enumerate the workspace directories:
|
// Enumerate the workspace directories:
|
||||||
foreach (var workspaceDirPath in Directory.EnumerateDirectories(workspaceDirectories))
|
foreach (var workspaceDirPath in Directory.EnumerateDirectories(workspaceDirectories))
|
||||||
{
|
{
|
||||||
// Read the `name` file:
|
// Read or create the `name` file (self-heal):
|
||||||
var workspaceNamePath = Path.Join(workspaceDirPath, "name");
|
var workspaceNamePath = Path.Join(workspaceDirPath, "name");
|
||||||
var workspaceName = await File.ReadAllTextAsync(workspaceNamePath, Encoding.UTF8);
|
string workspaceName;
|
||||||
|
try
|
||||||
|
{
|
||||||
|
if (!File.Exists(workspaceNamePath))
|
||||||
|
{
|
||||||
|
workspaceName = T("Unnamed workspace");
|
||||||
|
await File.WriteAllTextAsync(workspaceNamePath, workspaceName, Encoding.UTF8);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
workspaceName = await File.ReadAllTextAsync(workspaceNamePath, Encoding.UTF8);
|
||||||
|
if (string.IsNullOrWhiteSpace(workspaceName))
|
||||||
|
{
|
||||||
|
workspaceName = T("Unnamed workspace");
|
||||||
|
await File.WriteAllTextAsync(workspaceNamePath, workspaceName, Encoding.UTF8);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch
|
||||||
|
{
|
||||||
|
workspaceName = T("Unnamed workspace");
|
||||||
|
}
|
||||||
|
|
||||||
workspaces.Add(new TreeItemData<ITreeItem>
|
workspaces.Add(new TreeItemData<ITreeItem>
|
||||||
{
|
{
|
||||||
@ -194,9 +236,30 @@ public partial class Workspaces : MSGComponentBase
|
|||||||
// Enumerate the workspace directory:
|
// Enumerate the workspace directory:
|
||||||
foreach (var chatPath in Directory.EnumerateDirectories(workspacePath))
|
foreach (var chatPath in Directory.EnumerateDirectories(workspacePath))
|
||||||
{
|
{
|
||||||
// Read the `name` file:
|
// Read or create the `name` file (self-heal):
|
||||||
var chatNamePath = Path.Join(chatPath, "name");
|
var chatNamePath = Path.Join(chatPath, "name");
|
||||||
var chatName = await File.ReadAllTextAsync(chatNamePath, Encoding.UTF8);
|
string chatName;
|
||||||
|
try
|
||||||
|
{
|
||||||
|
if (!File.Exists(chatNamePath))
|
||||||
|
{
|
||||||
|
chatName = T("Unnamed chat");
|
||||||
|
await File.WriteAllTextAsync(chatNamePath, chatName, Encoding.UTF8);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
chatName = await File.ReadAllTextAsync(chatNamePath, Encoding.UTF8);
|
||||||
|
if (string.IsNullOrWhiteSpace(chatName))
|
||||||
|
{
|
||||||
|
chatName = T("Unnamed chat");
|
||||||
|
await File.WriteAllTextAsync(chatNamePath, chatName, Encoding.UTF8);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch
|
||||||
|
{
|
||||||
|
chatName = T("Unnamed chat");
|
||||||
|
}
|
||||||
|
|
||||||
// Read the last change time of the chat:
|
// Read the last change time of the chat:
|
||||||
var chatThreadPath = Path.Join(chatPath, "thread.json");
|
var chatThreadPath = Path.Join(chatPath, "thread.json");
|
||||||
|
@ -2121,6 +2121,9 @@ UI_TEXT_CONTENT["AISTUDIO::COMPONENTS::WORKSPACES::T1016188706"] = "Möchten Sie
|
|||||||
-- Move chat
|
-- Move chat
|
||||||
UI_TEXT_CONTENT["AISTUDIO::COMPONENTS::WORKSPACES::T1133040906"] = "Chat verschieben"
|
UI_TEXT_CONTENT["AISTUDIO::COMPONENTS::WORKSPACES::T1133040906"] = "Chat verschieben"
|
||||||
|
|
||||||
|
-- Unnamed workspace
|
||||||
|
UI_TEXT_CONTENT["AISTUDIO::COMPONENTS::WORKSPACES::T1307384014"] = "Unbenannter Arbeitsbereich"
|
||||||
|
|
||||||
-- Delete
|
-- Delete
|
||||||
UI_TEXT_CONTENT["AISTUDIO::COMPONENTS::WORKSPACES::T1469573738"] = "Löschen"
|
UI_TEXT_CONTENT["AISTUDIO::COMPONENTS::WORKSPACES::T1469573738"] = "Löschen"
|
||||||
|
|
||||||
@ -2166,6 +2169,9 @@ UI_TEXT_CONTENT["AISTUDIO::COMPONENTS::WORKSPACES::T3045856778"] = "Chat in den
|
|||||||
-- Please enter a new or edit the name for your workspace '{0}':
|
-- Please enter a new or edit the name for your workspace '{0}':
|
||||||
UI_TEXT_CONTENT["AISTUDIO::COMPONENTS::WORKSPACES::T323280982"] = "Bitte geben Sie einen neuen Namen für ihren Arbeitsbereich „{0}“ ein oder bearbeiten Sie ihn:"
|
UI_TEXT_CONTENT["AISTUDIO::COMPONENTS::WORKSPACES::T323280982"] = "Bitte geben Sie einen neuen Namen für ihren Arbeitsbereich „{0}“ ein oder bearbeiten Sie ihn:"
|
||||||
|
|
||||||
|
-- Unnamed chat
|
||||||
|
UI_TEXT_CONTENT["AISTUDIO::COMPONENTS::WORKSPACES::T3310482275"] = "Unbenannter Chat"
|
||||||
|
|
||||||
-- Rename
|
-- Rename
|
||||||
UI_TEXT_CONTENT["AISTUDIO::COMPONENTS::WORKSPACES::T3355849203"] = "Umbenennen"
|
UI_TEXT_CONTENT["AISTUDIO::COMPONENTS::WORKSPACES::T3355849203"] = "Umbenennen"
|
||||||
|
|
||||||
@ -5694,5 +5700,8 @@ UI_TEXT_CONTENT["AISTUDIO::TOOLS::VALIDATION::PROVIDERVALIDATION::T497939286"] =
|
|||||||
-- Please select a model.
|
-- Please select a model.
|
||||||
UI_TEXT_CONTENT["AISTUDIO::TOOLS::VALIDATION::PROVIDERVALIDATION::T818893091"] = "Bitte wählen Sie ein Modell aus."
|
UI_TEXT_CONTENT["AISTUDIO::TOOLS::VALIDATION::PROVIDERVALIDATION::T818893091"] = "Bitte wählen Sie ein Modell aus."
|
||||||
|
|
||||||
|
-- Unnamed workspace
|
||||||
|
UI_TEXT_CONTENT["AISTUDIO::TOOLS::WORKSPACEBEHAVIOUR::T1307384014"] = "Unbenannter Arbeitsbereich"
|
||||||
|
|
||||||
-- Delete Chat
|
-- Delete Chat
|
||||||
UI_TEXT_CONTENT["AISTUDIO::TOOLS::WORKSPACEBEHAVIOUR::T2244038752"] = "Chat löschen"
|
UI_TEXT_CONTENT["AISTUDIO::TOOLS::WORKSPACEBEHAVIOUR::T2244038752"] = "Chat löschen"
|
||||||
|
@ -2121,6 +2121,9 @@ UI_TEXT_CONTENT["AISTUDIO::COMPONENTS::WORKSPACES::T1016188706"] = "Are you sure
|
|||||||
-- Move chat
|
-- Move chat
|
||||||
UI_TEXT_CONTENT["AISTUDIO::COMPONENTS::WORKSPACES::T1133040906"] = "Move chat"
|
UI_TEXT_CONTENT["AISTUDIO::COMPONENTS::WORKSPACES::T1133040906"] = "Move chat"
|
||||||
|
|
||||||
|
-- Unnamed workspace
|
||||||
|
UI_TEXT_CONTENT["AISTUDIO::COMPONENTS::WORKSPACES::T1307384014"] = "Unnamed workspace"
|
||||||
|
|
||||||
-- Delete
|
-- Delete
|
||||||
UI_TEXT_CONTENT["AISTUDIO::COMPONENTS::WORKSPACES::T1469573738"] = "Delete"
|
UI_TEXT_CONTENT["AISTUDIO::COMPONENTS::WORKSPACES::T1469573738"] = "Delete"
|
||||||
|
|
||||||
@ -2166,6 +2169,9 @@ UI_TEXT_CONTENT["AISTUDIO::COMPONENTS::WORKSPACES::T3045856778"] = "Move Chat to
|
|||||||
-- Please enter a new or edit the name for your workspace '{0}':
|
-- Please enter a new or edit the name for your workspace '{0}':
|
||||||
UI_TEXT_CONTENT["AISTUDIO::COMPONENTS::WORKSPACES::T323280982"] = "Please enter a new or edit the name for your workspace '{0}':"
|
UI_TEXT_CONTENT["AISTUDIO::COMPONENTS::WORKSPACES::T323280982"] = "Please enter a new or edit the name for your workspace '{0}':"
|
||||||
|
|
||||||
|
-- Unnamed chat
|
||||||
|
UI_TEXT_CONTENT["AISTUDIO::COMPONENTS::WORKSPACES::T3310482275"] = "Unnamed chat"
|
||||||
|
|
||||||
-- Rename
|
-- Rename
|
||||||
UI_TEXT_CONTENT["AISTUDIO::COMPONENTS::WORKSPACES::T3355849203"] = "Rename"
|
UI_TEXT_CONTENT["AISTUDIO::COMPONENTS::WORKSPACES::T3355849203"] = "Rename"
|
||||||
|
|
||||||
@ -5694,5 +5700,9 @@ UI_TEXT_CONTENT["AISTUDIO::TOOLS::VALIDATION::PROVIDERVALIDATION::T497939286"] =
|
|||||||
-- Please select a model.
|
-- Please select a model.
|
||||||
UI_TEXT_CONTENT["AISTUDIO::TOOLS::VALIDATION::PROVIDERVALIDATION::T818893091"] = "Please select a model."
|
UI_TEXT_CONTENT["AISTUDIO::TOOLS::VALIDATION::PROVIDERVALIDATION::T818893091"] = "Please select a model."
|
||||||
|
|
||||||
|
-- Unnamed workspace
|
||||||
|
UI_TEXT_CONTENT["AISTUDIO::TOOLS::WORKSPACEBEHAVIOUR::T1307384014"] = "Unnamed workspace"
|
||||||
|
|
||||||
-- Delete Chat
|
-- Delete Chat
|
||||||
UI_TEXT_CONTENT["AISTUDIO::TOOLS::WORKSPACEBEHAVIOUR::T2244038752"] = "Delete Chat"
|
UI_TEXT_CONTENT["AISTUDIO::TOOLS::WORKSPACEBEHAVIOUR::T2244038752"] = "Delete Chat"
|
||||||
|
|
||||||
|
@ -83,7 +83,33 @@ public static class WorkspaceBehaviour
|
|||||||
|
|
||||||
var workspacePath = Path.Join(SettingsManager.DataDirectory, "workspaces", workspaceId.ToString());
|
var workspacePath = Path.Join(SettingsManager.DataDirectory, "workspaces", workspaceId.ToString());
|
||||||
var workspaceNamePath = Path.Join(workspacePath, "name");
|
var workspaceNamePath = Path.Join(workspacePath, "name");
|
||||||
return await File.ReadAllTextAsync(workspaceNamePath, Encoding.UTF8);
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
// If the name file does not exist or is empty, self-heal with a default name.
|
||||||
|
if (!File.Exists(workspaceNamePath))
|
||||||
|
{
|
||||||
|
var defaultName = TB("Unnamed workspace");
|
||||||
|
Directory.CreateDirectory(workspacePath);
|
||||||
|
await File.WriteAllTextAsync(workspaceNamePath, defaultName, Encoding.UTF8);
|
||||||
|
return defaultName;
|
||||||
|
}
|
||||||
|
|
||||||
|
var name = await File.ReadAllTextAsync(workspaceNamePath, Encoding.UTF8);
|
||||||
|
if (string.IsNullOrWhiteSpace(name))
|
||||||
|
{
|
||||||
|
var defaultName = TB("Unnamed workspace");
|
||||||
|
await File.WriteAllTextAsync(workspaceNamePath, defaultName, Encoding.UTF8);
|
||||||
|
return defaultName;
|
||||||
|
}
|
||||||
|
|
||||||
|
return name;
|
||||||
|
}
|
||||||
|
catch
|
||||||
|
{
|
||||||
|
// On any error, return a localized default without throwing.
|
||||||
|
return TB("Unnamed workspace");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static async Task DeleteChat(IDialogService dialogService, Guid workspaceId, Guid chatId, bool askForConfirmation = true)
|
public static async Task DeleteChat(IDialogService dialogService, Guid workspaceId, Guid chatId, bool askForConfirmation = true)
|
||||||
@ -124,14 +150,31 @@ public static class WorkspaceBehaviour
|
|||||||
private static async Task EnsureWorkspace(Guid workspaceId, string workspaceName)
|
private static async Task EnsureWorkspace(Guid workspaceId, string workspaceName)
|
||||||
{
|
{
|
||||||
var workspacePath = Path.Join(SettingsManager.DataDirectory, "workspaces", workspaceId.ToString());
|
var workspacePath = Path.Join(SettingsManager.DataDirectory, "workspaces", workspaceId.ToString());
|
||||||
|
|
||||||
if(Path.Exists(workspacePath))
|
|
||||||
return;
|
|
||||||
|
|
||||||
Directory.CreateDirectory(workspacePath);
|
|
||||||
var workspaceNamePath = Path.Join(workspacePath, "name");
|
var workspaceNamePath = Path.Join(workspacePath, "name");
|
||||||
|
|
||||||
|
if(!Path.Exists(workspacePath))
|
||||||
|
Directory.CreateDirectory(workspacePath);
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
// When the name file is missing or empty, write it (self-heal).
|
||||||
|
// Otherwise, keep the existing name:
|
||||||
|
if (!File.Exists(workspaceNamePath))
|
||||||
|
{
|
||||||
await File.WriteAllTextAsync(workspaceNamePath, workspaceName, Encoding.UTF8);
|
await File.WriteAllTextAsync(workspaceNamePath, workspaceName, Encoding.UTF8);
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
var existing = await File.ReadAllTextAsync(workspaceNamePath, Encoding.UTF8);
|
||||||
|
if (string.IsNullOrWhiteSpace(existing))
|
||||||
|
await File.WriteAllTextAsync(workspaceNamePath, workspaceName, Encoding.UTF8);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch
|
||||||
|
{
|
||||||
|
// Ignore IO issues to avoid interrupting background initialization.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public static async Task EnsureBiasWorkspace() => await EnsureWorkspace(KnownWorkspaces.BIAS_WORKSPACE_ID, "Bias of the Day");
|
public static async Task EnsureBiasWorkspace() => await EnsureWorkspace(KnownWorkspaces.BIAS_WORKSPACE_ID, "Bias of the Day");
|
||||||
|
|
||||||
|
@ -6,3 +6,4 @@
|
|||||||
- Improved plugin management for configuration plugins so that hot reload detects when a provider or chat template has been removed.
|
- Improved plugin management for configuration plugins so that hot reload detects when a provider or chat template has been removed.
|
||||||
- Changed the configuration plugin setting name for how often to check for updates from `UpdateBehavior` to `UpdateInterval`.
|
- Changed the configuration plugin setting name for how often to check for updates from `UpdateBehavior` to `UpdateInterval`.
|
||||||
- Fixed a bug in various assistants where some text fields were not reset when resetting.
|
- Fixed a bug in various assistants where some text fields were not reset when resetting.
|
||||||
|
- Fixed a rare chat-related bug that could occur when a workspace was not created correctly. Thank you, Naomi, for reporting this issue.
|
Loading…
Reference in New Issue
Block a user