mirror of
https://github.com/open-webui/open-webui
synced 2025-06-09 07:56:42 +00:00
commit
bc29d5d3c3
19
CHANGELOG.md
19
CHANGELOG.md
@ -5,6 +5,25 @@ All notable changes to this project will be documented in this file.
|
|||||||
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.1.0/),
|
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.1.0/),
|
||||||
and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
|
and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
|
||||||
|
|
||||||
|
## [0.3.32] - 2024-10-06
|
||||||
|
|
||||||
|
### Added
|
||||||
|
|
||||||
|
- **🔢 Workspace Enhancements**: Added a display count for models, prompts, tools, and functions in the workspace, providing a clear overview and easier management.
|
||||||
|
|
||||||
|
### Fixed
|
||||||
|
|
||||||
|
- **🖥️ Web and YouTube Attachment Fix**: Resolved an issue where attaching web links and YouTube videos was malfunctioning, ensuring seamless integration and display within chats.
|
||||||
|
- **📞 Call Mode Activation on Landing Page**: Fixed a bug where call mode was not operational from the landing page.
|
||||||
|
|
||||||
|
### Changed
|
||||||
|
|
||||||
|
- **🔄 URL Parameter Refinement**: Updated the 'tool_ids' URL parameter to 'tools' or 'tool-ids' for more intuitive and consistent user experience.
|
||||||
|
- **🎨 Floating Buttons Styling Update**: Refactored the styling of floating buttons to intelligently adjust to the left side when there isn't enough room on the right, improving interface usability and aesthetic.
|
||||||
|
- **🔧 Enhanced Accessibility for Floating Buttons**: Implemented the ability to close floating buttons with the 'Esc' key, making workflow smoother and more efficient for users navigating via keyboard.
|
||||||
|
- **🖇️ Updated Information URL**: Information URLs now direct users to a general release page rather than a version-specific URL, ensuring access to the latest and relevant details all in one place.
|
||||||
|
- **📦 Library Dependencies Update**: Upgraded dependencies to ensure compatibility and performance optimization for pip installs.
|
||||||
|
|
||||||
## [0.3.31] - 2024-10-06
|
## [0.3.31] - 2024-10-06
|
||||||
|
|
||||||
### Added
|
### Added
|
||||||
|
4
package-lock.json
generated
4
package-lock.json
generated
@ -1,12 +1,12 @@
|
|||||||
{
|
{
|
||||||
"name": "open-webui",
|
"name": "open-webui",
|
||||||
"version": "0.3.31",
|
"version": "0.3.32",
|
||||||
"lockfileVersion": 3,
|
"lockfileVersion": 3,
|
||||||
"requires": true,
|
"requires": true,
|
||||||
"packages": {
|
"packages": {
|
||||||
"": {
|
"": {
|
||||||
"name": "open-webui",
|
"name": "open-webui",
|
||||||
"version": "0.3.31",
|
"version": "0.3.32",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@codemirror/lang-javascript": "^6.2.2",
|
"@codemirror/lang-javascript": "^6.2.2",
|
||||||
"@codemirror/lang-python": "^6.1.6",
|
"@codemirror/lang-python": "^6.1.6",
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "open-webui",
|
"name": "open-webui",
|
||||||
"version": "0.3.31",
|
"version": "0.3.32",
|
||||||
"private": true,
|
"private": true,
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"dev": "npm run pyodide:fetch && vite dev --host",
|
"dev": "npm run pyodide:fetch && vite dev --host",
|
||||||
|
@ -8,7 +8,7 @@ license = { file = "LICENSE" }
|
|||||||
dependencies = [
|
dependencies = [
|
||||||
"fastapi==0.111.0",
|
"fastapi==0.111.0",
|
||||||
"uvicorn[standard]==0.30.6",
|
"uvicorn[standard]==0.30.6",
|
||||||
"pydantic==2.8.2",
|
"pydantic==2.9.2",
|
||||||
"python-multipart==0.0.9",
|
"python-multipart==0.0.9",
|
||||||
|
|
||||||
"Flask==3.0.3",
|
"Flask==3.0.3",
|
||||||
@ -19,7 +19,7 @@ dependencies = [
|
|||||||
"passlib[bcrypt]==1.7.4",
|
"passlib[bcrypt]==1.7.4",
|
||||||
|
|
||||||
"requests==2.32.3",
|
"requests==2.32.3",
|
||||||
"aiohttp==3.10.5",
|
"aiohttp==3.10.8",
|
||||||
|
|
||||||
"sqlalchemy==2.0.32",
|
"sqlalchemy==2.0.32",
|
||||||
"alembic==1.13.2",
|
"alembic==1.13.2",
|
||||||
@ -43,7 +43,7 @@ dependencies = [
|
|||||||
|
|
||||||
"langchain==0.2.15",
|
"langchain==0.2.15",
|
||||||
"langchain-community==0.2.12",
|
"langchain-community==0.2.12",
|
||||||
"langchain-chroma==0.1.2",
|
"langchain-chroma==0.1.4",
|
||||||
|
|
||||||
"fake-useragent==1.5.1",
|
"fake-useragent==1.5.1",
|
||||||
"chromadb==0.5.9",
|
"chromadb==0.5.9",
|
||||||
@ -62,7 +62,7 @@ dependencies = [
|
|||||||
"nltk==3.9.1",
|
"nltk==3.9.1",
|
||||||
"Markdown==3.7",
|
"Markdown==3.7",
|
||||||
"pypandoc==1.13",
|
"pypandoc==1.13",
|
||||||
"pandas==2.2.2",
|
"pandas==2.2.3",
|
||||||
"openpyxl==3.1.5",
|
"openpyxl==3.1.5",
|
||||||
"pyxlsb==1.0.10",
|
"pyxlsb==1.0.10",
|
||||||
"xlrd==2.0.1",
|
"xlrd==2.0.1",
|
||||||
@ -87,10 +87,10 @@ dependencies = [
|
|||||||
|
|
||||||
"extract_msg",
|
"extract_msg",
|
||||||
"pydub",
|
"pydub",
|
||||||
"duckduckgo-search~=6.2.11",
|
"duckduckgo-search~=6.2.13",
|
||||||
|
|
||||||
"docker~=7.1.0",
|
"docker~=7.1.0",
|
||||||
"pytest~=8.2.2",
|
"pytest~=8.3.2",
|
||||||
"pytest-docker~=3.1.1"
|
"pytest-docker~=3.1.1"
|
||||||
]
|
]
|
||||||
readme = "README.md"
|
readme = "README.md"
|
||||||
|
@ -352,16 +352,22 @@
|
|||||||
webSearchEnabled = true;
|
webSearchEnabled = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($page.url.searchParams.get('q')) {
|
if ($page.url.searchParams.get('tools')) {
|
||||||
prompt = $page.url.searchParams.get('q') ?? '';
|
selectedToolIds = $page.url.searchParams
|
||||||
selectedToolIds = (
|
.get('tools')
|
||||||
$page.url.searchParams.get('tools') ??
|
?.split(',')
|
||||||
$page.url.searchParams.get('tool-ids') ??
|
|
||||||
''
|
|
||||||
)
|
|
||||||
.split(',')
|
|
||||||
.map((id) => id.trim())
|
.map((id) => id.trim())
|
||||||
.filter((id) => id);
|
.filter((id) => id);
|
||||||
|
} else if ($page.url.searchParams.get('tool-ids')) {
|
||||||
|
selectedToolIds = $page.url.searchParams
|
||||||
|
.get('tool-ids')
|
||||||
|
?.split(',')
|
||||||
|
.map((id) => id.trim())
|
||||||
|
.filter((id) => id);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($page.url.searchParams.get('q')) {
|
||||||
|
prompt = $page.url.searchParams.get('q') ?? '';
|
||||||
|
|
||||||
if (prompt) {
|
if (prompt) {
|
||||||
await tick();
|
await tick();
|
||||||
|
@ -83,7 +83,7 @@
|
|||||||
document.removeEventListener('mouseup', onMouseUp);
|
document.removeEventListener('mouseup', onMouseUp);
|
||||||
});
|
});
|
||||||
|
|
||||||
$: if (!chatId) {
|
const closeHandler = () => {
|
||||||
showControls.set(false);
|
showControls.set(false);
|
||||||
showOverview.set(false);
|
showOverview.set(false);
|
||||||
showArtifacts.set(false);
|
showArtifacts.set(false);
|
||||||
@ -91,6 +91,10 @@
|
|||||||
if ($showCallOverlay) {
|
if ($showCallOverlay) {
|
||||||
showCallOverlay.set(false);
|
showCallOverlay.set(false);
|
||||||
}
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
$: if (!chatId) {
|
||||||
|
closeHandler();
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
|
@ -21,11 +21,7 @@
|
|||||||
LATEST_VERSION: version.latest
|
LATEST_VERSION: version.latest
|
||||||
})}
|
})}
|
||||||
|
|
||||||
<a
|
<a href="https://github.com/open-webui/open-webui/releases" target="_blank" class="underline">
|
||||||
href="https://github.com/open-webui/open-webui/releases/tag/v{version.latest}"
|
|
||||||
target="_blank"
|
|
||||||
class="underline"
|
|
||||||
>
|
|
||||||
{$i18n.t('Update for the latest features and improvements.')}</a
|
{$i18n.t('Update for the latest features and improvements.')}</a
|
||||||
>
|
>
|
||||||
</div>
|
</div>
|
||||||
|
@ -174,8 +174,14 @@
|
|||||||
</title>
|
</title>
|
||||||
</svelte:head>
|
</svelte:head>
|
||||||
|
|
||||||
<div class="mb-3 flex justify-between items-center">
|
<div class="mb-3">
|
||||||
<div class=" text-lg font-semibold self-center">{$i18n.t('Functions')}</div>
|
<div class="flex justify-between items-center">
|
||||||
|
<div class="flex md:self-center text-lg font-medium px-0.5">
|
||||||
|
{$i18n.t('Functions')}
|
||||||
|
<div class="flex self-center w-[1px] h-6 mx-2.5 bg-gray-200 dark:bg-gray-700" />
|
||||||
|
<span class="text-lg font-medium text-gray-500 dark:text-gray-300">{$functions.length}</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class=" flex w-full space-x-2">
|
<div class=" flex w-full space-x-2">
|
||||||
@ -219,7 +225,7 @@
|
|||||||
</a>
|
</a>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<hr class=" dark:border-gray-850 my-2.5" />
|
<hr class=" border-gray-50 dark:border-gray-850 my-2.5" />
|
||||||
|
|
||||||
<div class="my-3 mb-5">
|
<div class="my-3 mb-5">
|
||||||
{#each $functions.filter((f) => query === '' || f.name
|
{#each $functions.filter((f) => query === '' || f.name
|
||||||
|
@ -294,7 +294,15 @@
|
|||||||
}}
|
}}
|
||||||
/>
|
/>
|
||||||
|
|
||||||
<div class=" text-lg font-semibold mb-3">{$i18n.t('Models')}</div>
|
<div class="mb-3">
|
||||||
|
<div class="flex justify-between items-center">
|
||||||
|
<div class="flex md:self-center text-lg font-medium px-0.5">
|
||||||
|
{$i18n.t('Models')}
|
||||||
|
<div class="flex self-center w-[1px] h-6 mx-2.5 bg-gray-200 dark:bg-gray-700" />
|
||||||
|
<span class="text-lg font-medium text-gray-500 dark:text-gray-300">{$models.length}</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
<div class=" flex w-full space-x-2">
|
<div class=" flex w-full space-x-2">
|
||||||
<div class="flex flex-1">
|
<div class="flex flex-1">
|
||||||
@ -337,9 +345,10 @@
|
|||||||
</a>
|
</a>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<hr class=" dark:border-gray-850 my-2.5" />
|
|
||||||
|
|
||||||
<a class=" flex space-x-4 cursor-pointer w-full mb-2 px-3 py-2" href="/workspace/models/create">
|
<hr class=" border-gray-50 dark:border-gray-850 my-2.5" />
|
||||||
|
|
||||||
|
<a class=" flex space-x-4 cursor-pointer w-full mb-2 px-3 py-1" href="/workspace/models/create">
|
||||||
<div class=" self-center w-10 flex-shrink-0">
|
<div class=" self-center w-10 flex-shrink-0">
|
||||||
<div
|
<div
|
||||||
class="w-full h-10 flex justify-center rounded-full bg-transparent dark:bg-gray-700 border border-dashed border-gray-200"
|
class="w-full h-10 flex justify-center rounded-full bg-transparent dark:bg-gray-700 border border-dashed border-gray-200"
|
||||||
@ -360,7 +369,7 @@
|
|||||||
</div>
|
</div>
|
||||||
</a>
|
</a>
|
||||||
|
|
||||||
<hr class=" dark:border-gray-850" />
|
<hr class=" border-gray-50 dark:border-gray-850 my-2.5" />
|
||||||
|
|
||||||
<div class=" my-2 mb-5" id="model-list">
|
<div class=" my-2 mb-5" id="model-list">
|
||||||
{#each _models.filter((m) => searchValue === '' || m.name
|
{#each _models.filter((m) => searchValue === '' || m.name
|
||||||
|
@ -64,8 +64,14 @@
|
|||||||
</title>
|
</title>
|
||||||
</svelte:head>
|
</svelte:head>
|
||||||
|
|
||||||
<div class="mb-3 flex justify-between items-center">
|
<div class="mb-3">
|
||||||
<div class=" text-lg font-semibold self-center">{$i18n.t('Prompts')}</div>
|
<div class="flex justify-between items-center">
|
||||||
|
<div class="flex md:self-center text-lg font-medium px-0.5">
|
||||||
|
{$i18n.t('Prompts')}
|
||||||
|
<div class="flex self-center w-[1px] h-6 mx-2.5 bg-gray-200 dark:bg-gray-700" />
|
||||||
|
<span class="text-lg font-medium text-gray-500 dark:text-gray-300">{$prompts.length}</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class=" flex w-full space-x-2">
|
<div class=" flex w-full space-x-2">
|
||||||
@ -109,7 +115,8 @@
|
|||||||
</a>
|
</a>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<hr class=" dark:border-gray-850 my-2.5" />
|
|
||||||
|
<hr class=" border-gray-50 dark:border-gray-850 my-2.5" />
|
||||||
|
|
||||||
<div class="my-3 mb-5">
|
<div class="my-3 mb-5">
|
||||||
{#each $prompts.filter((p) => query === '' || p.command.includes(query)) as prompt}
|
{#each $prompts.filter((p) => query === '' || p.command.includes(query)) as prompt}
|
||||||
|
@ -146,8 +146,14 @@
|
|||||||
</title>
|
</title>
|
||||||
</svelte:head>
|
</svelte:head>
|
||||||
|
|
||||||
<div class="mb-3 flex justify-between items-center">
|
<div class="mb-3">
|
||||||
<div class=" text-lg font-semibold self-center">{$i18n.t('Tools')}</div>
|
<div class="flex justify-between items-center">
|
||||||
|
<div class="flex md:self-center text-lg font-medium px-0.5">
|
||||||
|
{$i18n.t('Tools')}
|
||||||
|
<div class="flex self-center w-[1px] h-6 mx-2.5 bg-gray-200 dark:bg-gray-700" />
|
||||||
|
<span class="text-lg font-medium text-gray-500 dark:text-gray-300">{$tools.length}</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class=" flex w-full space-x-2">
|
<div class=" flex w-full space-x-2">
|
||||||
@ -191,7 +197,8 @@
|
|||||||
</a>
|
</a>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<hr class=" dark:border-gray-850 my-2.5" />
|
|
||||||
|
<hr class=" border-gray-50 dark:border-gray-850 my-2.5" />
|
||||||
|
|
||||||
<div class="my-3 mb-5">
|
<div class="my-3 mb-5">
|
||||||
{#each $tools.filter((t) => query === '' || t.name
|
{#each $tools.filter((t) => query === '' || t.name
|
||||||
|
Loading…
Reference in New Issue
Block a user