From 8f31b6d74af2e144d471f8080bd3b229687e4bb0 Mon Sep 17 00:00:00 2001 From: D <157692623+dh4340@users.noreply.github.com> Date: Tue, 29 Apr 2025 09:14:23 +0100 Subject: [PATCH 01/75] Fix: Use dynamic Python command to run uvicorn and support pyenv setups. Updated the uvicorn startup command to dynamically detect and use either 'python3' or 'python', ensuring compatibility across different environments and pyenv setups. This avoids issues where only one of the commands is available. --- backend/start.sh | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/backend/start.sh b/backend/start.sh index 4588e4c348..84d5ec8958 100755 --- a/backend/start.sh +++ b/backend/start.sh @@ -65,4 +65,6 @@ if [ -n "$SPACE_ID" ]; then export WEBUI_URL=${SPACE_HOST} fi -WEBUI_SECRET_KEY="$WEBUI_SECRET_KEY" exec uvicorn open_webui.main:app --host "$HOST" --port "$PORT" --forwarded-allow-ips '*' --workers "${UVICORN_WORKERS:-1}" +PYTHON_CMD=$(command -v python3 || command -v python) + +WEBUI_SECRET_KEY="$WEBUI_SECRET_KEY" exec "$PYTHON_CMD" -m uvicorn open_webui.main:app --host "$HOST" --port "$PORT" --forwarded-allow-ips '*' --workers "${UVICORN_WORKERS:-1}" From bfdcc12cdcf917ccf7f6ee7398e49c680f315341 Mon Sep 17 00:00:00 2001 From: Panda Date: Tue, 6 May 2025 08:30:28 +0200 Subject: [PATCH 02/75] i18n: zh-cn --- src/lib/i18n/locales/zh-CN/translation.json | 82 ++++++++++----------- 1 file changed, 41 insertions(+), 41 deletions(-) diff --git a/src/lib/i18n/locales/zh-CN/translation.json b/src/lib/i18n/locales/zh-CN/translation.json index 50421f2d4e..74db6a0e03 100644 --- a/src/lib/i18n/locales/zh-CN/translation.json +++ b/src/lib/i18n/locales/zh-CN/translation.json @@ -4,7 +4,7 @@ "(e.g. `sh webui.sh --api --api-auth username_password`)": "(例如 `sh webui.sh --api --api-auth username_password`)", "(e.g. `sh webui.sh --api`)": "(例如 `sh webui.sh --api`)", "(latest)": "(最新版)", - "(leave blank for Azure Commercial URL auto-generation)": "", + "(leave blank for Azure Commercial URL auto-generation)": "(留空以便 Azure Commercial URL 自动生成)", "(Ollama)": "(Ollama)", "{{ models }}": "{{ models }}", "{{COUNT}} Available Tools": "{{COUNT}} 个可用工具", @@ -105,7 +105,7 @@ "Are you sure you want to delete this channel?": "是否确认删除此频道?", "Are you sure you want to delete this message?": "是否确认删除此消息?", "Are you sure you want to unarchive all archived chats?": "是否确认取消所有已归档的对话?", - "Are you sure you want to update this user's role to **{{ROLE}}**?": "", + "Are you sure you want to update this user's role to **{{ROLE}}**?": "您确定要将此用户的角色更新为 **{{ROLE}}** 吗?", "Are you sure?": "是否确定?", "Arena Models": "启用竞技场匿名评价模型", "Artifacts": "Artifacts", @@ -140,7 +140,7 @@ "Bad Response": "点踩此回答", "Banners": "公告横幅", "Base Model (From)": "基础模型 (来自)", - "Base URL": "", + "Base URL": "基础 URL", "Batch Size (num_batch)": "批大小 (num_batch)", "before": "对话", "Being lazy": "懒惰", @@ -149,7 +149,7 @@ "Bing Search V7 Subscription Key": "Bing 搜索 V7 订阅密钥", "Bocha Search API Key": "Bocha Search API 密钥", "Boosting or penalizing specific tokens for constrained responses. Bias values will be clamped between -100 and 100 (inclusive). (Default: none)": "为受限响应提升或惩罚特定标记。偏置值将被限制在 -100 到 100(包括两端)之间。(默认:无)", - "Both Docling OCR Engine and Language(s) must be provided or both left empty.": "", + "Both Docling OCR Engine and Language(s) must be provided or both left empty.": "必须提供 Docling OCR Engine 和语言,或者都留空。", "Brave Search API Key": "Brave Search API 密钥", "By {{name}}": "由 {{name}} 提供", "Bypass Embedding and Retrieval": "绕过嵌入和检索", @@ -160,7 +160,7 @@ "Cancel": "取消", "Capabilities": "能力", "Capture": "截图", - "Capture Audio": "", + "Capture Audio": "录制音频", "Certificate Path": "证书路径", "Change Password": "更改密码", "Channel Name": "频道名称", @@ -270,8 +270,8 @@ "Create Knowledge": "创建知识", "Create new key": "创建新密钥", "Create new secret key": "创建新安全密钥", - "Create Note": "", - "Create your first note by clicking on the plus button below.": "", + "Create Note": "创建笔记", + "Create your first note by clicking on the plus button below.": "单击下面的加号按钮创建您的第一个笔记。", "Created at": "创建于", "Created At": "创建于", "Created by": "作者", @@ -309,7 +309,7 @@ "Delete function?": "删除函数?", "Delete Message": "删除消息", "Delete message?": "删除消息?", - "Delete note?": "", + "Delete note?": "删除笔记?", "Delete prompt?": "删除提示词?", "delete this link": "此处删除这个链接", "Delete tool?": "删除工具?", @@ -365,7 +365,7 @@ "Download Database": "下载数据库", "Drag and drop a file to upload or select a file to view": "拖动文件上传或选择文件查看", "Draw": "平局", - "Drop any files here to upload": "", + "Drop any files here to upload": "将任何文件拖放到此处进行上传", "e.g. '30s','10m'. Valid time units are 's', 'm', 'h'.": "例如 '30s','10m'。有效的时间单位是秒:'s',分:'m',时:'h'。", "e.g. \"json\" or a JSON schema": "例如 \"json\" 或一个 JSON schema", "e.g. 60": "例如 '60'", @@ -375,7 +375,7 @@ "e.g. my_filter": "例如:my_filter", "e.g. my_tools": "例如:my_tools", "e.g. Tools for performing various operations": "例如:用于执行各种操作的工具", - "e.g., 3, 4, 5 (leave blank for default)": "", + "e.g., 3, 4, 5 (leave blank for default)": "例如:3、4、5(留空为默认值)", "e.g., en-US,ja-JP (leave blank for auto-detect)": "例如,'en-US,ja-JP'(留空以便自动检测)", "Edit": "编辑", "Edit Arena Model": "编辑竞技场模型", @@ -405,7 +405,7 @@ "Enable New Sign Ups": "允许新用户注册", "Enabled": "启用", "Enforce Temporary Chat": "强制临时聊天", - "Enhance": "", + "Enhance": "增强", "Ensure your CSV file includes 4 columns in this order: Name, Email, Password, Role.": "确保您的 CSV 文件按以下顺序包含 4 列: 姓名、电子邮箱、密码、角色。", "Enter {{role}} message here": "在此处输入 {{role}} 的对话内容", "Enter a detail about yourself for your LLMs to recall": "输入一个关于你自己的详细信息,方便你的大语言模型记住这些内容", @@ -422,8 +422,8 @@ "Enter Chunk Size": "输入块大小 (Chunk Size)", "Enter comma-separated \"token:bias_value\" pairs (example: 5432:100, 413:-100)": "输入以逗号分隔的“token:bias_value”对(例如:5432:100, 413:-100)", "Enter description": "输入简介描述", - "Enter Docling OCR Engine": "", - "Enter Docling OCR Language(s)": "", + "Enter Docling OCR Engine": "输入 Docling OCR Engine", + "Enter Docling OCR Language(s)": "输入 Docling OCR 语言", "Enter Docling Server URL": "输入 Docling 服务器 URL", "Enter Document Intelligence Endpoint": "输入 Document Intelligence 端点", "Enter Document Intelligence Key": "输入 Document Intelligence 密钥", @@ -450,7 +450,7 @@ "Enter Model ID": "输入模型 ID", "Enter model tag (e.g. {{modelTag}})": "输入模型标签 (例如:{{modelTag}})", "Enter Mojeek Search API Key": "输入 Mojeek Search API 密钥", - "Enter New Password": "", + "Enter New Password": "输入新密码", "Enter Number of Steps (e.g. 50)": "输入步骤数 (Steps) (例如:50)", "Enter Perplexity API Key": "输入 Perplexity API 密钥", "Enter Playwright Timeout": "输入 Playwright 超时时间", @@ -487,15 +487,15 @@ "Enter Top K Reranker": "输入 Top K Reranker", "Enter URL (e.g. http://127.0.0.1:7860/)": "输入地址 (例如:http://127.0.0.1:7860/)", "Enter URL (e.g. http://localhost:11434)": "输入地址 (例如:http://localhost:11434)", - "Enter Yacy Password": "", - "Enter Yacy URL (e.g. http://yacy.example.com:8090)": "", - "Enter Yacy Username": "", + "Enter Yacy Password": "输入 Yacy 密码", + "Enter Yacy URL (e.g. http://yacy.example.com:8090)": "输入 Yacy URL(例如:http://yacy.example.com:8090)", + "Enter Yacy Username": "输入 Yacy 用户名", "Enter your current password": "输入当前密码", "Enter Your Email": "输入您的电子邮箱", "Enter Your Full Name": "输入您的名称", "Enter your message": "输入您的消息", "Enter your name": "输入您的名称", - "Enter Your Name": "", + "Enter Your Name": "输入你的名称", "Enter your new password": "输入新的密码", "Enter Your Password": "输入您的密码", "Enter Your Role": "输入您的权限组", @@ -504,8 +504,8 @@ "Error": "错误", "ERROR": "错误", "Error accessing Google Drive: {{error}}": "访问 Google 云端硬盘 出错: {{error}}", - "Error accessing media devices.": "", - "Error starting recording.": "", + "Error accessing media devices.": "访问媒体设备时出错。", + "Error starting recording.": "开始录制时出错。", "Error uploading file: {{error}}": "上传文件时出错: {{error}}", "Evaluations": "竞技场评估", "Exa API Key": "Exa API 密钥", @@ -544,7 +544,7 @@ "Failed to add file.": "添加文件失败。", "Failed to connect to {{URL}} OpenAPI tool server": "无法连接到 {{URL}} OpenAPI 工具服务器", "Failed to create API Key.": "无法创建 API 密钥。", - "Failed to delete note": "", + "Failed to delete note": "删除笔记失败", "Failed to fetch models": "无法获取模型", "Failed to load file content.": "无法加载文件内容。", "Failed to read clipboard contents": "无法读取剪贴板内容", @@ -602,12 +602,12 @@ "Gemini API Config": "Gemini API 配置", "Gemini API Key is required.": "需要 Gemini API 密钥。", "General": "通用", - "Generate": "", + "Generate": "生成", "Generate an image": "生成图像", "Generate Image": "生成图像", "Generate prompt pair": "生成提示对", "Generating search query": "生成搜索查询", - "Generating...": "", + "Generating...": "生成中...", "Get started": "开始使用", "Get started with {{WEBUI_NAME}}": "开始使用 {{WEBUI_NAME}}", "Global": "全局", @@ -654,7 +654,7 @@ "Import Config from JSON File": "导入 JSON 文件中的配置信息", "Import Functions": "导入函数", "Import Models": "导入模型", - "Import Notes": "", + "Import Notes": "导入笔记", "Import Presets": "导入预设", "Import Prompts": "导入提示词", "Import Tools": "导入工具", @@ -669,7 +669,7 @@ "Instant Auto-Send After Voice Transcription": "语音转录文字后即时自动发送", "Integration": "集成", "Interface": "界面", - "Invalid file content": "", + "Invalid file content": "无效的文件内容", "Invalid file format.": "无效文件格式。", "Invalid JSON schema": "无效的 JSON schema", "Invalid Tag": "无效标签", @@ -740,7 +740,7 @@ "Manage Pipelines": "管理 Pipeline", "Manage Tool Servers": "管理工具服务器", "March": "三月", - "Max Speakers": "", + "Max Speakers": "最大扬声器数量", "Max Tokens (num_predict)": "最大 Token 数量 (num_predict)", "Max Upload Count": "最大上传数量", "Max Upload Size": "最大上传大小", @@ -792,16 +792,16 @@ "Mojeek Search API Key": "Mojeek Search API 密钥", "more": "更多", "More": "更多", - "My Notes": "", + "My Notes": "我的笔记", "Name": "名称", "Name your knowledge base": "为您的知识库命名", "Native": "原生", "New Chat": "新对话", "New Folder": "新文件夹", - "New Note": "", + "New Note": "新笔记", "New Password": "新密码", "new-channel": "新频道", - "No content": "", + "No content": "没有内容", "No content found": "未发现内容", "No content found in file.": "文件中未找到内容", "No content to speak": "没有内容可朗读", @@ -816,7 +816,7 @@ "No model IDs": "没有模型 ID", "No models found": "未找到任何模型", "No models selected": "未选择任何模型", - "No Notes": "", + "No Notes": "没有笔记", "No results found": "未找到结果", "No search query generated": "未生成搜索查询", "No source available": "没有可用来源", @@ -825,7 +825,7 @@ "None": "无", "Not factually correct": "事实并非如此", "Not helpful": "无帮助", - "Note deleted successfully": "", + "Note deleted successfully": "笔记删除成功", "Note: If you set a minimum score, the search will only return documents with a score greater than or equal to the minimum score.": "注意:如果设置了最低分数,搜索只会返回分数大于或等于最低分数的文档。", "Notes": "笔记", "Notification Sound": "通知提示音", @@ -848,7 +848,7 @@ "Only alphanumeric characters and hyphens are allowed": "只允许使用英文字母,数字 (0-9) 以及连字符 (-)", "Only alphanumeric characters and hyphens are allowed in the command string.": "命令字符串中只允许使用英文字母,数字 (0-9) 以及连字符 (-)。", "Only collections can be edited, create a new knowledge base to edit/add documents.": "只能编辑文件集,创建一个新的知识库来编辑/添加文件。", - "Only markdown files are allowed": "", + "Only markdown files are allowed": "仅允许使用 markdown 文件", "Only select users and groups with permission can access": "只有具有权限的用户和组才能访问", "Oops! Looks like the URL is invalid. Please double-check and try again.": "此链接似乎为无效链接。请检查后重试。", "Oops! There are files still uploading. Please wait for the upload to complete.": "稍等!还有文件正在上传。请等待上传完成。", @@ -894,8 +894,8 @@ "Pipelines": "Pipeline", "Pipelines Not Detected": "未检测到 Pipeline", "Pipelines Valves": "Pipeline 值", - "Plain text (.md)": "", - "Plain text (.txt)": "TXT 文档 (.txt)", + "Plain text (.md)": "纯文本文档(.md)", + "Plain text (.txt)": "纯文本文档 (.txt)", "Playground": "AI 对话游乐场", "Playwright Timeout (ms)": "Playwright 超时时间 (ms)", "Playwright WebSocket URL": "Playwright WebSocket URL", @@ -937,7 +937,7 @@ "Read": "只读", "Read Aloud": "朗读", "Reasoning Effort": "推理努力", - "Record": "", + "Record": "录制", "Record voice": "录音", "Redirecting you to Open WebUI Community": "正在将您重定向到 OpenWebUI 社区", "Reduces the probability of generating nonsense. A higher value (e.g. 100) will give more diverse answers, while a lower value (e.g. 10) will be more conservative.": "降低生成无意义内容的概率。较高的值(如100)将产生更多样化的回答,而较低的值(如10)则更加保守。", @@ -1007,7 +1007,7 @@ "Searched {{count}} sites": "已搜索 {{count}} 个网站", "Searching \"{{searchQuery}}\"": "搜索 \"{{searchQuery}}\" 中", "Searching Knowledge for \"{{searchQuery}}\"": "检索有关 \"{{searchQuery}}\" 的知识中", - "Searching the web...": "", + "Searching the web...": "正在搜索网络...", "Searxng Query URL": "Searxng 查询 URL", "See readme.md for instructions": "查看 readme.md 以获取说明", "See what's new": "查阅最新更新内容", @@ -1210,7 +1210,7 @@ "Unpin": "取消置顶", "Unravel secrets": "解开秘密", "Untagged": "无标签", - "Untitled": "", + "Untitled": "无标题", "Update": "更新", "Update and Copy Link": "更新和复制链接", "Update for the latest features and improvements.": "更新来获得最新功能与改进。", @@ -1221,7 +1221,7 @@ "Upgrade to a licensed plan for enhanced capabilities, including custom theming and branding, and dedicated support.": "升级到授权计划以获得增强功能,包括自定义主题与品牌以及专属支持。", "Upload": "上传", "Upload a GGUF model": "上传一个 GGUF 模型", - "Upload Audio": "", + "Upload Audio": "上传音频", "Upload directory": "上传目录", "Upload files": "上传文件", "Upload Files": "上传文件", @@ -1295,9 +1295,9 @@ "Write a summary in 50 words that summarizes [topic or keyword].": "用 50 个字写一个总结 [主题或关键词]。", "Write something...": "单击以键入内容...", "Write your model template content here": "在此写入模型模板内容", - "Yacy Instance URL": "", - "Yacy Password": "", - "Yacy Username": "", + "Yacy Instance URL": "Yacy Instance URL", + "Yacy Password": "Yacy 密码", + "Yacy Username": "Yacy 用户名", "Yesterday": "昨天", "You": "你", "You are currently using a trial license. Please contact support to upgrade your license.": "当前为试用许可证,请联系支持人员升级许可证。", From de182ddec24a37ae37481f080684b98701b631b9 Mon Sep 17 00:00:00 2001 From: tth37 Date: Tue, 6 May 2025 18:38:42 +0800 Subject: [PATCH 03/75] fix(katex): Allow Chinese characters adjacent to math delimiters --- src/lib/utils/marked/katex-extension.ts | 14 +++++++++++--- 1 file changed, 11 insertions(+), 3 deletions(-) diff --git a/src/lib/utils/marked/katex-extension.ts b/src/lib/utils/marked/katex-extension.ts index f679a6b221..b648440d89 100644 --- a/src/lib/utils/marked/katex-extension.ts +++ b/src/lib/utils/marked/katex-extension.ts @@ -10,6 +10,9 @@ const DELIMITER_LIST = [ { left: '\\begin{equation}', right: '\\end{equation}', display: true } ]; +// Defines characters that are allowed to immediately precede or follow a math delimiter. +const ALLOWED_SURROUNDING_CHARS = '\\s?。,!-\\/:-@\\[-`{-~\\p{Script=Han}'; + // const DELIMITER_LIST = [ // { left: '$$', right: '$$', display: false }, // { left: '$', right: '$', display: false }, @@ -44,10 +47,13 @@ function generateRegexRules(delimiters) { // Math formulas can end in special characters const inlineRule = new RegExp( - `^(${inlinePatterns.join('|')})(?=[\\s?。,!-\/:-@[-\`{-~]|$)`, + `^(${inlinePatterns.join('|')})(?=[${ALLOWED_SURROUNDING_CHARS}]|$)`, + 'u' + ); + const blockRule = new RegExp( + `^(${blockPatterns.join('|')})(?=[${ALLOWED_SURROUNDING_CHARS}]|$)`, 'u' ); - const blockRule = new RegExp(`^(${blockPatterns.join('|')})(?=[\\s?。,!-\/:-@[-\`{-~]|$)`, 'u'); return { inlineRule, blockRule }; } @@ -91,7 +97,9 @@ function katexStart(src, displayMode: boolean) { // Check if the delimiter is preceded by a special character. // If it does, then it's potentially a math formula. - const f = index === 0 || indexSrc.charAt(index - 1).match(/[\s?。,!-\/:-@[-`{-~]/); + const f = + index === 0 || + indexSrc.charAt(index - 1).match(new RegExp(`[${ALLOWED_SURROUNDING_CHARS}]`, 'u')); if (f) { const possibleKatex = indexSrc.substring(index); From 0889dd3a510993b83adf0aaa521e3d29b1151dcd Mon Sep 17 00:00:00 2001 From: Sine Jespersen Date: Tue, 6 May 2025 14:24:19 +0200 Subject: [PATCH 04/75] add close label to close button in changelog modal, only accessible for screen readers --- src/lib/components/ChangelogModal.svelte | 1 + 1 file changed, 1 insertion(+) diff --git a/src/lib/components/ChangelogModal.svelte b/src/lib/components/ChangelogModal.svelte index fd727c2c44..2e7dfa1993 100644 --- a/src/lib/components/ChangelogModal.svelte +++ b/src/lib/components/ChangelogModal.svelte @@ -43,6 +43,7 @@ fill="currentColor" class="w-5 h-5" > +

{$i18n.t('Close')}

From 86ce111edde71e59c59b277b7406f9c9fb4cde46 Mon Sep 17 00:00:00 2001 From: Sine Jespersen Date: Tue, 6 May 2025 14:30:01 +0200 Subject: [PATCH 05/75] Add aria-labelledby to icon-button to make assistive tech able to give info on what user can expect from button --- src/lib/components/OnBoarding.svelte | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/lib/components/OnBoarding.svelte b/src/lib/components/OnBoarding.svelte index 1976e5c6e2..ef3b0b451f 100644 --- a/src/lib/components/OnBoarding.svelte +++ b/src/lib/components/OnBoarding.svelte @@ -87,6 +87,7 @@
-
{$i18n.t(`Get started`)}
+
{$i18n.t(`Get started`)}
- {/if} From 8c6f4f6579bfd148555ce04494eb7fd800cb80c0 Mon Sep 17 00:00:00 2001 From: Sine Jespersen Date: Tue, 6 May 2025 14:33:26 +0200 Subject: [PATCH 06/75] change divs to labels, as this is what they semantically are --- src/routes/auth/+page.svelte | 13 ++++++++----- 1 file changed, 8 insertions(+), 5 deletions(-) diff --git a/src/routes/auth/+page.svelte b/src/routes/auth/+page.svelte index fc7e4c53a8..247fa11996 100644 --- a/src/routes/auth/+page.svelte +++ b/src/routes/auth/+page.svelte @@ -248,10 +248,11 @@
{#if mode === 'signup'}
-
{$i18n.t('Name')}
+ -
{$i18n.t('Username')}
+
{:else}
-
{$i18n.t('Email')}
+ -
{$i18n.t('Password')}
- + Date: Tue, 6 May 2025 14:37:05 +0200 Subject: [PATCH 07/75] fix text-contrast from 3.71 to 7.55 on dark mode --- src/routes/auth/+page.svelte | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/routes/auth/+page.svelte b/src/routes/auth/+page.svelte index 247fa11996..57db1e58db 100644 --- a/src/routes/auth/+page.svelte +++ b/src/routes/auth/+page.svelte @@ -235,7 +235,7 @@
{#if $config?.onboarding ?? false} -
+
ⓘ {$WEBUI_NAME} {$i18n.t( 'does not make any external connections, and your data stays securely on your locally hosted server.' From 9d8d4393a6277984d45fe5fed3bd076fdc213674 Mon Sep 17 00:00:00 2001 From: Sine Jespersen Date: Tue, 6 May 2025 14:37:35 +0200 Subject: [PATCH 08/75] remove alt text from logo, as this is decorative and provides no value for assistive tech users --- src/routes/auth/+page.svelte | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/routes/auth/+page.svelte b/src/routes/auth/+page.svelte index 57db1e58db..30bc890de7 100644 --- a/src/routes/auth/+page.svelte +++ b/src/routes/auth/+page.svelte @@ -188,7 +188,7 @@ crossorigin="anonymous" src="{WEBUI_BASE_URL}/static/splash.png" class=" w-6 rounded-full" - alt="logo" + alt="" />
From 8e14372dd830e7d3291b32fcefed15a07d2865f5 Mon Sep 17 00:00:00 2001 From: tth37 Date: Tue, 6 May 2025 21:26:09 +0800 Subject: [PATCH 09/75] enh: Support more languages --- src/lib/utils/marked/katex-extension.ts | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/lib/utils/marked/katex-extension.ts b/src/lib/utils/marked/katex-extension.ts index b648440d89..02a52b651e 100644 --- a/src/lib/utils/marked/katex-extension.ts +++ b/src/lib/utils/marked/katex-extension.ts @@ -11,7 +11,8 @@ const DELIMITER_LIST = [ ]; // Defines characters that are allowed to immediately precede or follow a math delimiter. -const ALLOWED_SURROUNDING_CHARS = '\\s?。,!-\\/:-@\\[-`{-~\\p{Script=Han}'; +const ALLOWED_SURROUNDING_CHARS = + '\\s?。,、;!-\\/:-@\\[-`{-~\\p{Script=Han}\\p{Script=Hiragana}\\p{Script=Katakana}\\p{Script=Hangul}'; // const DELIMITER_LIST = [ // { left: '$$', right: '$$', display: false }, From 500f4d73e110d957a2885b10c97380a7ac55f9b7 Mon Sep 17 00:00:00 2001 From: Chris Kanich Date: Tue, 6 May 2025 11:00:35 -0500 Subject: [PATCH 10/75] refresh oauth profile picture --- backend/open_webui/config.py | 6 ++ backend/open_webui/utils/oauth.py | 98 ++++++++++++++++++++----------- 2 files changed, 70 insertions(+), 34 deletions(-) diff --git a/backend/open_webui/config.py b/backend/open_webui/config.py index a6cffeecd9..c0afed4b16 100644 --- a/backend/open_webui/config.py +++ b/backend/open_webui/config.py @@ -552,6 +552,12 @@ OAUTH_ALLOWED_DOMAINS = PersistentConfig( ], ) +OAUTH_UPDATE_PICTURE_ON_LOGIN = PersistentConfig( + "OAUTH_UPDATE_PICTURE_ON_LOGIN", + "oauth.update_picture_on_login", + os.environ.get("OAUTH_UPDATE_PICTURE_ON_LOGIN", "False").lower() == "true", +) + def load_oauth_providers(): OAUTH_PROVIDERS.clear() diff --git a/backend/open_webui/utils/oauth.py b/backend/open_webui/utils/oauth.py index 283bc3b5c7..744e0cc7d8 100644 --- a/backend/open_webui/utils/oauth.py +++ b/backend/open_webui/utils/oauth.py @@ -34,6 +34,7 @@ from open_webui.config import ( OAUTH_ALLOWED_ROLES, OAUTH_ADMIN_ROLES, OAUTH_ALLOWED_DOMAINS, + OAUTH_UPDATE_PICTURE_ON_LOGIN, WEBHOOK_URL, JWT_EXPIRES_IN, AppConfig, @@ -72,6 +73,7 @@ auth_manager_config.OAUTH_ADMIN_ROLES = OAUTH_ADMIN_ROLES auth_manager_config.OAUTH_ALLOWED_DOMAINS = OAUTH_ALLOWED_DOMAINS auth_manager_config.WEBHOOK_URL = WEBHOOK_URL auth_manager_config.JWT_EXPIRES_IN = JWT_EXPIRES_IN +auth_manager_config.OAUTH_UPDATE_PICTURE_ON_LOGIN = OAUTH_UPDATE_PICTURE_ON_LOGIN class OAuthManager: @@ -276,6 +278,49 @@ class OAuthManager: id=group_model.id, form_data=update_form, overwrite=False ) + async def _process_picture_url( + self, picture_url: str, access_token: str = None + ) -> str: + """Process a picture URL and return a base64 encoded data URL. + + Args: + picture_url: The URL of the picture to process + access_token: Optional OAuth access token for authenticated requests + + Returns: + A data URL containing the base64 encoded picture, or "/user.png" if processing fails + """ + if not picture_url: + return "/user.png" + + try: + get_kwargs = {} + if access_token: + get_kwargs["headers"] = { + "Authorization": f"Bearer {access_token}", + } + async with aiohttp.ClientSession() as session: + async with session.get(picture_url, **get_kwargs) as resp: + if resp.ok: + picture = await resp.read() + base64_encoded_picture = base64.b64encode(picture).decode( + "utf-8" + ) + guessed_mime_type = mimetypes.guess_type(picture_url)[0] + if guessed_mime_type is None: + guessed_mime_type = "image/jpeg" + return ( + f"data:{guessed_mime_type};base64,{base64_encoded_picture}" + ) + else: + log.warning( + f"Failed to fetch profile picture from {picture_url}" + ) + return "/user.png" + except Exception as e: + log.error(f"Error processing profile picture '{picture_url}': {e}") + return "/user.png" + async def handle_login(self, request, provider): if provider not in OAUTH_PROVIDERS: raise HTTPException(404) @@ -376,6 +421,22 @@ class OAuthManager: if user.role != determined_role: Users.update_user_role_by_id(user.id, determined_role) + # Update profile picture if enabled and different from current + if auth_manager_config.OAUTH_UPDATE_PICTURE_ON_LOGIN: + picture_claim = auth_manager_config.OAUTH_PICTURE_CLAIM + if picture_claim: + new_picture_url = user_data.get( + picture_claim, OAUTH_PROVIDERS[provider].get("picture_url", "") + ) + processed_picture_url = await self._process_picture_url( + new_picture_url, token.get("access_token") + ) + if processed_picture_url != user.profile_image_url: + Users.update_user_profile_image_url_by_id( + user.id, processed_picture_url + ) + log.debug(f"Updated profile picture for user {user.email}") + if not user: user_count = Users.get_num_users() @@ -391,40 +452,9 @@ class OAuthManager: picture_url = user_data.get( picture_claim, OAUTH_PROVIDERS[provider].get("picture_url", "") ) - if picture_url: - # Download the profile image into a base64 string - try: - access_token = token.get("access_token") - get_kwargs = {} - if access_token: - get_kwargs["headers"] = { - "Authorization": f"Bearer {access_token}", - } - async with aiohttp.ClientSession(trust_env=True) as session: - async with session.get( - picture_url, **get_kwargs - ) as resp: - if resp.ok: - picture = await resp.read() - base64_encoded_picture = base64.b64encode( - picture - ).decode("utf-8") - guessed_mime_type = mimetypes.guess_type( - picture_url - )[0] - if guessed_mime_type is None: - # assume JPG, browsers are tolerant enough of image formats - guessed_mime_type = "image/jpeg" - picture_url = f"data:{guessed_mime_type};base64,{base64_encoded_picture}" - else: - picture_url = "/user.png" - except Exception as e: - log.error( - f"Error downloading profile image '{picture_url}': {e}" - ) - picture_url = "/user.png" - if not picture_url: - picture_url = "/user.png" + picture_url = await self._process_picture_url( + picture_url, token.get("access_token") + ) else: picture_url = "/user.png" From 9c760ace80c44e5123a62b4af6ff12548edf34b6 Mon Sep 17 00:00:00 2001 From: acters Date: Tue, 6 May 2025 15:36:17 -0600 Subject: [PATCH 11/75] Improve Default Code Interpreter Prompt The change to the default "Code Interpreter" prompt makes it more clear to the LLM to not wrap the code in markdown's code block formatting. This improves the reliability of having code generated in the XML tags that will run properly. --- backend/open_webui/config.py | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/backend/open_webui/config.py b/backend/open_webui/config.py index 5c617f1906..db4f56658c 100644 --- a/backend/open_webui/config.py +++ b/backend/open_webui/config.py @@ -1699,7 +1699,8 @@ DEFAULT_CODE_INTERPRETER_PROMPT = """ 1. **Code Interpreter**: `` - You have access to a Python shell that runs directly in the user's browser, enabling fast execution of code for analysis, calculations, or problem-solving. Use it in this response. - The Python code you write can incorporate a wide array of libraries, handle data manipulation or visualization, perform API calls for web-related tasks, or tackle virtually any computational challenge. Use this flexibility to **think outside the box, craft elegant solutions, and harness Python's full potential**. - - To use it, **you must enclose your code within `` XML tags** and stop right away. If you don't, the code won't execute. Do NOT use triple backticks. + - To use it, **you must enclose your code within `` XML tags** and stop right away. If you don't, the code won't execute. + - When writing code in the code_interpreter XML tag, Do NOT use the triple backticks code block for markdown formatting, example: ```py # python code ``` will cause an error because it is markdown formatting, it is not python code. - When coding, **always aim to print meaningful outputs** (e.g., results, tables, summaries, or visuals) to better interpret and verify the findings. Avoid relying on implicit outputs; prioritize explicit and clear print statements so the results are effectively communicated to the user. - After obtaining the printed output, **always provide a concise analysis, interpretation, or next steps to help the user understand the findings or refine the outcome further.** - If the results are unclear, unexpected, or require validation, refine the code and execute it again as needed. Always aim to deliver meaningful insights from the results, iterating if necessary. From d62353c140c7a49f10056b0ca34fd4faff20e0f4 Mon Sep 17 00:00:00 2001 From: Serkan Sakar Date: Wed, 7 May 2025 00:56:20 +0200 Subject: [PATCH 12/75] enh: add presence_penalty parameter to openai --- backend/open_webui/utils/middleware.py | 3 +++ backend/open_webui/utils/payload.py | 1 + 2 files changed, 4 insertions(+) diff --git a/backend/open_webui/utils/middleware.py b/backend/open_webui/utils/middleware.py index ec29496772..2ab73292cc 100644 --- a/backend/open_webui/utils/middleware.py +++ b/backend/open_webui/utils/middleware.py @@ -672,6 +672,9 @@ def apply_params_to_form_data(form_data, model): if "frequency_penalty" in params and params["frequency_penalty"] is not None: form_data["frequency_penalty"] = params["frequency_penalty"] + if "presence_penalty" in params and params["presence_penalty"] is not None: + form_data["presence_penalty"] = params["presence_penalty"] + if "reasoning_effort" in params and params["reasoning_effort"] is not None: form_data["reasoning_effort"] = params["reasoning_effort"] diff --git a/backend/open_webui/utils/payload.py b/backend/open_webui/utils/payload.py index 5f8aafb785..d43dfd7890 100644 --- a/backend/open_webui/utils/payload.py +++ b/backend/open_webui/utils/payload.py @@ -59,6 +59,7 @@ def apply_model_params_to_body_openai(params: dict, form_data: dict) -> dict: "top_p": float, "max_tokens": int, "frequency_penalty": float, + "presence_penalty": float, "reasoning_effort": str, "seed": lambda x: x, "stop": lambda x: [bytes(s, "utf-8").decode("unicode_escape") for s in x], From 263086aa91f51e6a41e72476f4bfedac93a1b154 Mon Sep 17 00:00:00 2001 From: Sine Jespersen Date: Wed, 7 May 2025 09:21:04 +0200 Subject: [PATCH 13/75] break and indent divs --- src/lib/components/OnBoarding.svelte | 5 +++-- src/routes/auth/+page.svelte | 16 ++++++++++++---- 2 files changed, 15 insertions(+), 6 deletions(-) diff --git a/src/lib/components/OnBoarding.svelte b/src/lib/components/OnBoarding.svelte index ef3b0b451f..f0a4a52dc1 100644 --- a/src/lib/components/OnBoarding.svelte +++ b/src/lib/components/OnBoarding.svelte @@ -95,11 +95,12 @@ > -
{$i18n.t(`Get started`)}
+
+ {$i18n.t(`Get started`)} +
- {/if} diff --git a/src/routes/auth/+page.svelte b/src/routes/auth/+page.svelte index 30bc890de7..81b9fbd306 100644 --- a/src/routes/auth/+page.svelte +++ b/src/routes/auth/+page.svelte @@ -248,7 +248,9 @@
{#if mode === 'signup'}
- + - + {:else}
- + - + Date: Wed, 7 May 2025 12:52:55 +0400 Subject: [PATCH 14/75] refac --- src/lib/components/chat/Chat.svelte | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/src/lib/components/chat/Chat.svelte b/src/lib/components/chat/Chat.svelte index d578f3d63b..5d11ce9409 100644 --- a/src/lib/components/chat/Chat.svelte +++ b/src/lib/components/chat/Chat.svelte @@ -440,8 +440,10 @@ } } - loading = false; - await tick(); + if (!chatIdProp) { + loading = false; + await tick(); + } showControls.subscribe(async (value) => { if (controlPane && !$mobile) { From b1fb298bee709b71371a3d9625902351c99178f1 Mon Sep 17 00:00:00 2001 From: Timothy Jaeryang Baek Date: Wed, 7 May 2025 13:09:41 +0400 Subject: [PATCH 15/75] enh: contributions stats script --- Caddyfile.localhost | 64 ------------------------------------- contribution_stats.py | 74 +++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 74 insertions(+), 64 deletions(-) delete mode 100644 Caddyfile.localhost create mode 100644 contribution_stats.py diff --git a/Caddyfile.localhost b/Caddyfile.localhost deleted file mode 100644 index 80728eedf6..0000000000 --- a/Caddyfile.localhost +++ /dev/null @@ -1,64 +0,0 @@ -# Run with -# caddy run --envfile ./example.env --config ./Caddyfile.localhost -# -# This is configured for -# - Automatic HTTPS (even for localhost) -# - Reverse Proxying to Ollama API Base URL (http://localhost:11434/api) -# - CORS -# - HTTP Basic Auth API Tokens (uncomment basicauth section) - - -# CORS Preflight (OPTIONS) + Request (GET, POST, PATCH, PUT, DELETE) -(cors-api) { - @match-cors-api-preflight method OPTIONS - handle @match-cors-api-preflight { - header { - Access-Control-Allow-Origin "{http.request.header.origin}" - Access-Control-Allow-Methods "GET, POST, PUT, PATCH, DELETE, OPTIONS" - Access-Control-Allow-Headers "Origin, Accept, Authorization, Content-Type, X-Requested-With" - Access-Control-Allow-Credentials "true" - Access-Control-Max-Age "3600" - defer - } - respond "" 204 - } - - @match-cors-api-request { - not { - header Origin "{http.request.scheme}://{http.request.host}" - } - header Origin "{http.request.header.origin}" - } - handle @match-cors-api-request { - header { - Access-Control-Allow-Origin "{http.request.header.origin}" - Access-Control-Allow-Methods "GET, POST, PUT, PATCH, DELETE, OPTIONS" - Access-Control-Allow-Headers "Origin, Accept, Authorization, Content-Type, X-Requested-With" - Access-Control-Allow-Credentials "true" - Access-Control-Max-Age "3600" - defer - } - } -} - -# replace localhost with example.com or whatever -localhost { - ## HTTP Basic Auth - ## (uncomment to enable) - # basicauth { - # # see .example.env for how to generate tokens - # {env.OLLAMA_API_ID} {env.OLLAMA_API_TOKEN_DIGEST} - # } - - handle /api/* { - # Comment to disable CORS - import cors-api - - reverse_proxy localhost:11434 - } - - # Same-Origin Static Web Server - file_server { - root ./build/ - } -} diff --git a/contribution_stats.py b/contribution_stats.py new file mode 100644 index 0000000000..efd3f55675 --- /dev/null +++ b/contribution_stats.py @@ -0,0 +1,74 @@ +import os +import subprocess +from collections import Counter + +CONFIG_FILE_EXTENSIONS = (".json", ".yml", ".yaml", ".ini", ".conf", ".toml") + + +def is_text_file(filepath): + # Check for binary file by scanning for null bytes. + try: + with open(filepath, "rb") as f: + chunk = f.read(4096) + if b"\0" in chunk: + return False + return True + except Exception: + return False + + +def should_skip_file(path): + base = os.path.basename(path) + # Skip dotfiles and dotdirs + if base.startswith("."): + return True + # Skip config files by extension + if base.lower().endswith(CONFIG_FILE_EXTENSIONS): + return True + return False + + +def get_tracked_files(): + try: + output = subprocess.check_output(["git", "ls-files"], text=True) + files = output.strip().split("\n") + files = [f for f in files if f and os.path.isfile(f)] + return files + except subprocess.CalledProcessError: + print("Error: Are you in a git repository?") + return [] + + +def main(): + files = get_tracked_files() + email_counter = Counter() + total_lines = 0 + + for file in files: + if should_skip_file(file): + continue + if not is_text_file(file): + continue + try: + blame = subprocess.check_output( + ["git", "blame", "-e", file], text=True, errors="replace" + ) + for line in blame.splitlines(): + # The email always inside <> + if "<" in line and ">" in line: + try: + email = line.split("<")[1].split(">")[0].strip() + except Exception: + continue + email_counter[email] += 1 + total_lines += 1 + except subprocess.CalledProcessError: + continue + + for email, lines in email_counter.most_common(): + percent = (lines / total_lines * 100) if total_lines else 0 + print(f"{email}: {lines} {percent:.2f}%") + + +if __name__ == "__main__": + main() From a38f3c7617caad7af2a13c75bcea2eb9e247b813 Mon Sep 17 00:00:00 2001 From: Timothy Jaeryang Baek Date: Wed, 7 May 2025 13:10:24 +0400 Subject: [PATCH 16/75] refac --- contribution_stats.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/contribution_stats.py b/contribution_stats.py index efd3f55675..3caa4738ec 100644 --- a/contribution_stats.py +++ b/contribution_stats.py @@ -67,7 +67,7 @@ def main(): for email, lines in email_counter.most_common(): percent = (lines / total_lines * 100) if total_lines else 0 - print(f"{email}: {lines} {percent:.2f}%") + print(f"{email}: {lines}/{total_lines} {percent:.2f}%") if __name__ == "__main__": From 3a553f7208ad80fa0f451fae574820dd9d7677b9 Mon Sep 17 00:00:00 2001 From: Mabeck Date: Wed, 7 May 2025 14:06:30 +0200 Subject: [PATCH 17/75] Updated danish translations --- src/lib/i18n/locales/da-DK/translation.json | 552 ++++++++++---------- 1 file changed, 276 insertions(+), 276 deletions(-) diff --git a/src/lib/i18n/locales/da-DK/translation.json b/src/lib/i18n/locales/da-DK/translation.json index 00291ea104..06bfafbe7a 100644 --- a/src/lib/i18n/locales/da-DK/translation.json +++ b/src/lib/i18n/locales/da-DK/translation.json @@ -26,7 +26,7 @@ "Accurate information": "Profilinformation", "Actions": "Handlinger", "Activate": "Aktiver", - "Activate this command by typing \"/{{COMMAND}}\" to chat input.": "", + "Activate this command by typing \"/{{COMMAND}}\" to chat input.": "Aktiver denne kommando ved at skrive \"/{{COMMAND}}\" til chat input.", "Active Users": "Aktive brugere", "Add": "Tilføj", "Add a model ID": "Tilføj en model-ID", @@ -41,7 +41,7 @@ "Add Group": "Tilføj gruppe", "Add Memory": "Tilføj hukommelse", "Add Model": "Tilføj model", - "Add Reaction": "", + "Add Reaction": "Tilføj reaktion", "Add Tag": "Tilføj tag", "Add Tags": "Tilføj tags", "Add text content": "Tilføj tekst", @@ -63,8 +63,8 @@ "Allow Chat Delete": "Tillad sletning af chats", "Allow Chat Deletion": "Tillad sletning af chats", "Allow Chat Edit": "Tillad redigering af chats", - "Allow Chat Export": "", - "Allow Chat Share": "", + "Allow Chat Export": "Tillad eksport af chats", + "Allow Chat Share": "Tillad deling af chats", "Allow File Upload": "Tillad upload af fil", "Allow Multiple Models in Chat": "Tillad flere modeller i chats", "Allow non-local voices": "Tillad ikke-lokale stemmer", @@ -95,7 +95,7 @@ "API keys": "API nøgler", "Application DN": "", "Application DN Password": "", - "applies to all users with the \"user\" role": "", + "applies to all users with the \"user\" role": "gælder for alle brugere med \"bruger\" rolle", "April": "April", "Archive": "Arkiv", "Archive All Chats": "Arkiver alle chats", @@ -125,7 +125,7 @@ "Auto-Copy Response to Clipboard": "Automatisk kopiering af svar til udklipsholder", "Auto-playback response": "Automatisk afspil svar", "Autocomplete Generation": "Genere automatisk fuldførsel", - "Autocomplete Generation Input Max Length": "", + "Autocomplete Generation Input Max Length": "Maksimal længde for genereret autofuldførsel", "Automatic1111": "Automatic1111", "AUTOMATIC1111 Api Auth String": "AUTOMATIC1111 Api Auth String", "AUTOMATIC1111 Base URL": "AUTOMATIC1111 Base URL", @@ -165,7 +165,7 @@ "Channel Name": "Kanalnavn", "Channels": "Kanaler", "Character": "Karakterer", - "Character limit for autocomplete generation input": "", + "Character limit for autocomplete generation input": "Karaktergrænse for genereret autofuldførsel", "Chart new frontiers": "", "Chat": "Chat", "Chat Background Image": "Chat baggrundsbillede", @@ -173,8 +173,8 @@ "Chat Controls": "Chat indstillinger", "Chat direction": "Chat retning", "Chat Overview": "Chat overblik", - "Chat Permissions": "", - "Chat Tags Auto-Generation": "", + "Chat Permissions": "Chat tilladelser", + "Chat Tags Auto-Generation": "Chat tags automatisk generering", "Chats": "Chats", "Check Again": "Tjek igen", "Check for updates": "Søg efter opdateringer", @@ -182,17 +182,17 @@ "Choose a model before saving...": "Vælg en model før du gemmer", "Chunk Overlap": "Chunk overlap", "Chunk Size": "Chunk størrelse", - "Ciphers": "", + "Ciphers": "Ciphers", "Citation": "Citat", "Clear memory": "Slet hukommelse", - "Clear Memory": "", - "click here": "", - "Click here for filter guides.": "", + "Clear Memory": "Slet hukommelse", + "click here": "klik her", + "Click here for filter guides.": "Klik her for filter guider", "Click here for help.": "Klik her for hjælp", "Click here to": "Klik her for at", "Click here to download user import template file.": "Klik her for at downloade bruger import template fil.", - "Click here to learn more about faster-whisper and see the available models.": "", - "Click here to see available models.": "", + "Click here to learn more about faster-whisper and see the available models.": "Klik her for at lære mere om faster-whisper og se tilgængelige modeller.", + "Click here to see available models.": "Klik her for at se tilgængelige modeller.", "Click here to select": "Klik her for at vælge", "Click here to select a csv file.": "Klik her for at vælge en csv fil", "Click here to select a py file.": "Klik her for at vælge en py fil", @@ -201,40 +201,40 @@ "Click on the user role button to change a user's role.": "Klik på bruger ikonet for at ændre brugerens rolle.", "Clipboard write permission denied. Please check your browser settings to grant the necessary access.": "Skriveadgang til udklipsholderen ikke tilladt. Tjek venligst indstillingerne i din browser for at give adgang.", "Clone": "Klon", - "Clone Chat": "", - "Clone of {{TITLE}}": "", + "Clone Chat": "Klon chat", + "Clone of {{TITLE}}": "Klon af {{TITLE}}", "Close": "Luk", - "Code execution": "", - "Code Execution": "", - "Code Execution Engine": "", - "Code Execution Timeout": "", + "Code execution": "Kode kørsel", + "Code Execution": "Kode kørsel", + "Code Execution Engine": "Kode kørsel engine", + "Code Execution Timeout": "Kode kørsel timeout", "Code formatted successfully": "Kode formateret korrekt", - "Code Interpreter": "", - "Code Interpreter Engine": "", - "Code Interpreter Prompt Template": "", - "Collapse": "", + "Code Interpreter": "Kode interpreter", + "Code Interpreter Engine": "Kode interpreter engine", + "Code Interpreter Prompt Template": "Kode interpreter prompt template", + "Collapse": "Kollapse", "Collection": "Samling", - "Color": "", + "Color": "Farve", "ComfyUI": "ComfyUI", - "ComfyUI API Key": "", + "ComfyUI API Key": "ComfyUI API Key", "ComfyUI Base URL": "ComfyUI Base URL", "ComfyUI Base URL is required.": "ComfyUI Base URL er påkrævet.", "ComfyUI Workflow": "ComfyUI Workflow", "ComfyUI Workflow Nodes": "ComfyUI Workflow Nodes", "Command": "Kommando", - "Completions": "", + "Completions": "Completions", "Concurrent Requests": "Concurrent requests", - "Configure": "", + "Configure": "Konfigurer", "Confirm": "Bekræft", "Confirm Password": "Bekræft password", "Confirm your action": "Bekræft din handling", - "Confirm your new password": "", - "Connect to your own OpenAI compatible API endpoints.": "", + "Confirm your new password": "Bekræft dit nye password", + "Connect to your own OpenAI compatible API endpoints.": "Opret forbindelse til din egen OpenAI kompatible API endpoints.", "Connect to your own OpenAPI compatible external tool servers.": "", - "Connection failed": "", - "Connection successful": "", + "Connection failed": "Forbindelse mislykkedes", + "Connection successful": "Forbindelse lykkedes", "Connections": "Forbindelser", - "Connections saved successfully": "", + "Connections saved successfully": "Forbindelser gemt", "Constrains effort on reasoning for reasoning models. Only applicable to reasoning models from specific providers that support reasoning effort.": "", "Contact Admin for WebUI Access": "Kontakt din administrator for adgang til WebUI", "Content": "Indhold", @@ -242,8 +242,8 @@ "Context Length": "Kontekst længde", "Continue Response": "Fortsæt svar", "Continue with {{provider}}": "Fortsæt med {{provider}}", - "Continue with Email": "", - "Continue with LDAP": "", + "Continue with Email": "Fortsæt med Email", + "Continue with LDAP": "Fortsæt med LDAP", "Control how message text is split for TTS requests. 'Punctuation' splits into sentences, 'paragraphs' splits into paragraphs, and 'none' keeps the message as a single string.": "Kontroller hvordan beskedens tekst bliver splittet til TTS requests. 'Punctuation' (tegnsætning) splitter i sætninger, 'paragraphs' splitter i paragraffer, og 'none' beholder beskeden som en samlet streng.", "Control the repetition of token sequences in the generated text. A higher value (e.g., 1.5) will penalize repetitions more strongly, while a lower value (e.g., 1.1) will be more lenient. At 1, it is disabled.": "", "Controls": "Indstillinger", @@ -252,34 +252,34 @@ "Copied shared chat URL to clipboard!": "Link til deling kopieret til udklipsholder", "Copied to clipboard": "Kopieret til udklipsholder", "Copy": "Kopier", - "Copy Formatted Text": "", + "Copy Formatted Text": "Kopier formateret tekst", "Copy last code block": "Kopier seneste kode", "Copy last response": "Kopier senester svar", "Copy Link": "Kopier link", - "Copy to clipboard": "", + "Copy to clipboard": "Kopier til udklipsholder", "Copying to clipboard was successful!": "Kopieret til udklipsholder!", "CORS must be properly configured by the provider to allow requests from Open WebUI.": "", - "Create": "", - "Create a knowledge base": "", + "Create": "Opret", + "Create a knowledge base": "Opret en videnbase", "Create a model": "Lav en model", "Create Account": "Opret profil", - "Create Admin Account": "", - "Create Channel": "", - "Create Group": "", + "Create Admin Account": "Opret administrator profil", + "Create Channel": "Opret kanal", + "Create Group": "Opret gruppe", "Create Knowledge": "Opret Viden", "Create new key": "Opret en ny nøgle", "Create new secret key": "Opret en ny hemmelig nøgle", - "Create Note": "", - "Create your first note by clicking on the plus button below.": "", + "Create Note": "Opret note", + "Create your first note by clicking on the plus button below.": "Opret din første note ved at klikke på plus knappen nedenfor.", "Created at": "Oprettet", "Created At": "Oprettet", "Created by": "Oprettet af", "CSV Import": "Importer CSV", - "Ctrl+Enter to Send": "", + "Ctrl+Enter to Send": "Ctrl+Enter til at sende", "Current Model": "Nuværende model", "Current Password": "Nuværende password", "Custom": "Custom", - "Danger Zone": "", + "Danger Zone": "Danger Zone", "Dark": "Mørk", "Database": "Database", "December": "december", @@ -289,41 +289,41 @@ "Default mode works with a wider range of models by calling tools once before execution. Native mode leverages the model’s built-in tool-calling capabilities, but requires the model to inherently support this feature.": "", "Default Model": "Standard model", "Default model updated": "Standard model opdateret", - "Default Models": "", - "Default permissions": "", - "Default permissions updated successfully": "", + "Default Models": "Standard modeller", + "Default permissions": "Standard tilladelser", + "Default permissions updated successfully": "Standard tilladelser opdateret", "Default Prompt Suggestions": "Standardforslag til prompt", "Default to 389 or 636 if TLS is enabled": "", - "Default to ALL": "", + "Default to ALL": "Standard til ALLE", "Default to segmented retrieval for focused and relevant content extraction, this is recommended for most cases.": "", "Default User Role": "Brugers rolle som standard", "Delete": "Slet", "Delete a model": "Slet en model", "Delete All Chats": "Slet alle chats", - "Delete All Models": "", + "Delete All Models": "Slet alle modeller", "Delete chat": "Slet chat", "Delete Chat": "Slet chat", "Delete chat?": "Slet chat?", - "Delete folder?": "", + "Delete folder?": "Slet mappe?", "Delete function?": "Slet funktion?", - "Delete Message": "", - "Delete message?": "", - "Delete note?": "", + "Delete Message": "Slet besked", + "Delete message?": "Slet besked?", + "Delete note?": "Slet note?", "Delete prompt?": "Slet prompt?", "delete this link": "slet dette link", "Delete tool?": "Slet værktøj?", "Delete User": "Slet bruger", "Deleted {{deleteModelTag}}": "Slettede {{deleteModelTag}}", "Deleted {{name}}": "Slettede {{name}}", - "Deleted User": "", - "Describe your knowledge base and objectives": "", + "Deleted User": "Slettede bruger", + "Describe your knowledge base and objectives": "Beskriv din videnbase og mål", "Description": "Beskrivelse", - "Detect Artifacts Automatically": "", + "Detect Artifacts Automatically": "Genkend artifakter automatisk", "Didn't fully follow instructions": "Fulgte ikke instruktioner", - "Direct": "", - "Direct Connections": "", - "Direct Connections allow users to connect to their own OpenAI compatible API endpoints.": "", - "Direct Connections settings updated": "", + "Direct": "Direkte", + "Direct Connections": "Direkte forbindelser", + "Direct Connections allow users to connect to their own OpenAI compatible API endpoints.": "Direkte forbindelser tillader brugere at oprette forbindelse til deres egen OpenAI kompatible API endpoints.", + "Direct Connections settings updated": "Direkte forbindelser indstillinger opdateret", "Direct Tool Servers": "", "Disabled": "Inaktiv", "Discover a function": "Find en funktion", @@ -337,11 +337,11 @@ "Discover, download, and explore custom tools": "Find, download og udforsk unikke værktøjer", "Discover, download, and explore model presets": "Find, download og udforsk modelindstillinger", "Dismissible": "Kan afvises", - "Display": "", + "Display": "Vis", "Display Emoji in Call": "Vis emoji i chat", "Display the username instead of You in the Chat": "Vis brugernavn i stedet for Dig i chatten", - "Displays citations in the response": "", - "Dive into knowledge": "", + "Displays citations in the response": "Vis citat i svaret", + "Dive into knowledge": "Undersøg viden", "Do not install functions from sources you do not fully trust.": "Lad være med at installere funktioner fra kilder, som du ikke stoler på.", "Do not install tools from sources you do not fully trust.": "Lad være med at installere værktøjer fra kilder, som du ikke stoler på.", "Docling": "", @@ -352,22 +352,22 @@ "Documentation": "Dokumentation", "Documents": "Dokumenter", "does not make any external connections, and your data stays securely on your locally hosted server.": "laver ikke eksterne kald, og din data bliver sikkert på din egen lokalt hostede server.", - "Domain Filter List": "", + "Domain Filter List": "Domæne filterliste", "Don't have an account?": "Har du ikke en profil?", "don't install random functions from sources you don't trust.": "lad være med at installere tilfældige funktioner fra kilder, som du ikke stoler på.", "don't install random tools from sources you don't trust.": "lad være med at installere tilfældige værktøjer fra kilder, som du ikke stoler på.", "Don't like the style": "Kan du ikke lide stilen", "Done": "Færdig", "Download": "Download", - "Download as SVG": "", + "Download as SVG": "Download som SVG", "Download canceled": "Download afbrudt", "Download Database": "Download database", - "Drag and drop a file to upload or select a file to view": "", - "Draw": "", - "Drop any files here to upload": "", + "Drag and drop a file to upload or select a file to view": "Træk og slip en fil for at uploade eller vælg en fil for at se", + "Draw": "Tegn", + "Drop any files here to upload": "Drop nogen filer her for at uploade", "e.g. '30s','10m'. Valid time units are 's', 'm', 'h'.": "f.eks. '30s', '10m'. Tilladte værdier er 's', 'm', 'h'.", - "e.g. \"json\" or a JSON schema": "", - "e.g. 60": "", + "e.g. \"json\" or a JSON schema": "f.eks. \"json\" eller en JSON schema", + "e.g. 60": "f.eks. 60", "e.g. A filter to remove profanity from text": "", "e.g. My Filter": "", "e.g. My Tools": "", @@ -378,17 +378,17 @@ "e.g., en-US,ja-JP (leave blank for auto-detect)": "", "e.g., westus (leave blank for eastus)": "", "Edit": "Rediger", - "Edit Arena Model": "", - "Edit Channel": "", - "Edit Connection": "", - "Edit Default Permissions": "", + "Edit Arena Model": "Rediger Arena Model", + "Edit Channel": "Rediger kanal", + "Edit Connection": "Rediger forbindelse", + "Edit Default Permissions": "Rediger standard tilladelser", "Edit Memory": "Rediger hukommelse", "Edit User": "Rediger bruger", - "Edit User Group": "", + "Edit User Group": "Rediger brugergruppe", "ElevenLabs": "ElevenLabs", "Email": "Email", - "Embark on adventures": "", - "Embedding": "", + "Embark on adventures": "Udforsk eventyr", + "Embedding": "Embedding", "Embedding Batch Size": "Embedding Batch størrelse", "Embedding Model": "Embedding Model", "Embedding Model Engine": "Embedding Model engine", @@ -406,8 +406,8 @@ "Enabled": "Aktiveret", "Endpoint URL": "", "Enforce Temporary Chat": "", - "Enhance": "", - "Ensure your CSV file includes 4 columns in this order: Name, Email, Password, Role.": "Sørg for at din CSV-fil indeholder 4 kolonner in denne rækkefølge: Name, Email, Password, Role.", + "Enhance": "Forbedre", + "Ensure your CSV file includes 4 columns in this order: Name, Email, Password, Role.": "Sørg for at din CSV-fil indeholder 4 kolonner i denne rækkefølge: Name, Email, Password, Role.", "Enter {{role}} message here": "Indtast {{role}} besked her", "Enter a detail about yourself for your LLMs to recall": "Indtast en detalje om dig selv, som dine LLMs kan huske", "Enter api auth string (e.g. username:password)": "Indtast api-godkendelsesstreng (f.eks. brugernavn:adgangskode)", @@ -422,7 +422,7 @@ "Enter Chunk Overlap": "Indtast overlapning af tekststykker", "Enter Chunk Size": "Indtast størrelse af tekststykker", "Enter comma-separated \"token:bias_value\" pairs (example: 5432:100, 413:-100)": "", - "Enter description": "", + "Enter description": "Indtast beskrivelse", "Enter Docling OCR Engine": "", "Enter Docling OCR Language(s)": "", "Enter Docling Server URL": "", @@ -464,28 +464,28 @@ "Enter SearchApi API Key": "Indtast SearchApi API-nøgle", "Enter SearchApi Engine": "Indtast SearchApi-engine", "Enter Searxng Query URL": "Indtast Searxng-forespørgsels-URL", - "Enter Seed": "", - "Enter SerpApi API Key": "", - "Enter SerpApi Engine": "", + "Enter Seed": "Indtast seed", + "Enter SerpApi API Key": "Indtast SerpApi API-nøgle", + "Enter SerpApi Engine": "Indtast SerpApi-engine", "Enter Serper API Key": "Indtast Serper API-nøgle", "Enter Serply API Key": "Indtast Serply API-nøgle", "Enter Serpstack API Key": "Indtast Serpstack API-nøgle", - "Enter server host": "", - "Enter server label": "", - "Enter server port": "", - "Enter Sougou Search API sID": "", - "Enter Sougou Search API SK": "", + "Enter server host": "Indtast server-host", + "Enter server label": "Indtast server-label", + "Enter server port": "Indtast server-port", + "Enter Sougou Search API sID": "Indtast Sougou Search API sID", + "Enter Sougou Search API SK": "Indtast Sougou Search API SK", "Enter stop sequence": "Indtast stopsekvens", "Enter system prompt": "Indtast systemprompt", - "Enter system prompt here": "", + "Enter system prompt here": "Indtast systemprompt her", "Enter Tavily API Key": "Indtast Tavily API-nøgle", - "Enter Tavily Extract Depth": "", + "Enter Tavily Extract Depth": "Indtast Tavily Extract Depth", "Enter the public URL of your WebUI. This URL will be used to generate links in the notifications.": "", "Enter Tika Server URL": "Indtast Tika Server URL", - "Enter timeout in seconds": "", - "Enter to Send": "", + "Enter timeout in seconds": "Indtast timeout i sekunder", + "Enter to Send": "Indtast for at sende", "Enter Top K": "Indtast Top K", - "Enter Top K Reranker": "", + "Enter Top K Reranker": "Indtast Top K Reranker", "Enter URL (e.g. http://127.0.0.1:7860/)": "Indtast URL (f.eks. http://127.0.0.1:7860/)", "Enter URL (e.g. http://localhost:11434)": "Indtast URL (f.eks. http://localhost:11434)", "Enter Yacy Password": "", @@ -495,69 +495,69 @@ "Enter Your Email": "Indtast din e-mail", "Enter Your Full Name": "Indtast dit fulde navn", "Enter your message": "Indtast din besked", - "Enter your name": "", - "Enter Your Name": "", - "Enter your new password": "", + "Enter your name": "Indtast dit navn", + "Enter Your Name": "Indtast dit navn", + "Enter your new password": "Indtast din nye adgangskode", "Enter Your Password": "Indtast din adgangskode", "Enter Your Role": "Indtast din rolle", - "Enter Your Username": "", - "Enter your webhook URL": "", + "Enter Your Username": "Indtast dit brugernavn", + "Enter your webhook URL": "Indtast din webhook URL", "Error": "Fejl", - "ERROR": "", - "Error accessing Google Drive: {{error}}": "", - "Error accessing media devices.": "", - "Error starting recording.": "", - "Error uploading file: {{error}}": "", - "Evaluations": "", - "Exa API Key": "", - "Example: (&(objectClass=inetOrgPerson)(uid=%s))": "", - "Example: ALL": "", - "Example: mail": "", - "Example: ou=users,dc=foo,dc=example": "", - "Example: sAMAccountName or uid or userPrincipalName": "", - "Exceeded the number of seats in your license. Please contact support to increase the number of seats.": "", - "Exclude": "", + "ERROR": "FEJL", + "Error accessing Google Drive: {{error}}": "Fejl ved adgang til Google Drive: {{error}}", + "Error accessing media devices.": "Fejl ved adgang til medieenheder.", + "Error starting recording.": "Fejl ved start af optagelse.", + "Error uploading file: {{error}}": "Fejl ved upload af fil: {{error}}", + "Evaluations": "Evalueringer", + "Exa API Key": "Exa API-nøgle", + "Example: (&(objectClass=inetOrgPerson)(uid=%s))": "Eksempel: (&(objectClass=inetOrgPerson)(uid=%s))", + "Example: ALL": "Eksempel: ALL", + "Example: mail": "Eksempel: mail", + "Example: ou=users,dc=foo,dc=example": "Eksempel: ou=users,dc=foo,dc=example", + "Example: sAMAccountName or uid or userPrincipalName": "Eksempel: sAMAccountName eller uid eller userPrincipalName", + "Exceeded the number of seats in your license. Please contact support to increase the number of seats.": "Du har overskredet antallet af pladser i din licens. Kontakt support for at øge antallet af pladser.", + "Exclude": "Ekskluder", "Execute code for analysis": "", - "Executing **{{NAME}}**...": "", - "Expand": "", + "Executing **{{NAME}}**...": "Kører **{{NAME}}**...", + "Expand": "Udvid", "Experimental": "Eksperimentel", - "Explain": "", - "Explain this section to me in more detail": "", + "Explain": "Forklar", + "Explain this section to me in more detail": "Forklar dette afsnit for mig i mere detalje", "Explore the cosmos": "", "Export": "Eksportér", - "Export All Archived Chats": "", + "Export All Archived Chats": "Eksportér alle arkiverede chats", "Export All Chats (All Users)": "Eksportér alle chats (alle brugere)", "Export chat (.json)": "Eksportér chat (.json)", "Export Chats": "Eksportér chats", "Export Config to JSON File": "Eksportér konfiguration til JSON-fil", "Export Functions": "Eksportér funktioner", "Export Models": "Eksportér modeller", - "Export Presets": "", + "Export Presets": "Eksportér indstillinger", "Export Prompts": "Eksportér prompts", - "Export to CSV": "", + "Export to CSV": "Eksportér til CSV", "Export Tools": "Eksportér værktøjer", - "External": "", + "External": "Ekstern", "External Models": "Eksterne modeller", - "External Web Loader API Key": "", - "External Web Loader URL": "", - "External Web Search API Key": "", - "External Web Search URL": "", - "Failed to add file.": "", - "Failed to connect to {{URL}} OpenAPI tool server": "", + "External Web Loader API Key": "Ekstern Web Loader API-nøgle", + "External Web Loader URL": "Ekstern Web Loader URL", + "External Web Search API Key": "Ekstern Web Search API-nøgle", + "External Web Search URL": "Ekstern Web Search URL", + "Failed to add file.": "Kunne ikke tilføje fil.", + "Failed to connect to {{URL}} OpenAPI tool server": "Kunne ikke forbinde til {{URL}} OpenAPI tool server", "Failed to create API Key.": "Kunne ikke oprette API-nøgle.", - "Failed to delete note": "", - "Failed to fetch models": "", - "Failed to load file content.": "", + "Failed to delete note": "Kunne ikke slette note", + "Failed to fetch models": "Kunne ikke hente modeller", + "Failed to load file content.": "Kunne ikke indlæse filindhold.", "Failed to read clipboard contents": "Kunne ikke læse indholdet af udklipsholderen", - "Failed to save connections": "", - "Failed to save models configuration": "", + "Failed to save connections": "Kunne ikke gemme forbindelser", + "Failed to save models configuration": "Kunne ikke gemme modeller konfiguration", "Failed to update settings": "Kunne ikke opdatere indstillinger", "Failed to upload file.": "Kunne ikke uploade fil.", - "Features": "", + "Features": "Features", "Features Permissions": "", "February": "Februar", "Feedback History": "", - "Feedbacks": "", + "Feedbacks": "Feedback", "Feel free to add specific details": "Du er velkommen til at tilføje specifikke detaljer", "File": "Fil", "File added successfully.": "Fil tilføjet.", @@ -566,7 +566,7 @@ "File not found.": "Filen blev ikke fundet.", "File removed successfully.": "Fil fjernet.", "File size should not exceed {{maxSize}} MB.": "Filstørrelsen må ikke overstige {{maxSize}} MB.", - "File uploaded successfully": "", + "File uploaded successfully": "Fil uploadet.", "Files": "Filer", "Filter is now globally disabled": "Filter er nu globalt deaktiveret", "Filter is now globally enabled": "Filter er nu globalt aktiveret", @@ -576,13 +576,13 @@ "Firecrawl API Key": "", "Fluidly stream large external response chunks": "Stream store eksterne svar chunks flydende", "Focus chat input": "Fokuser på chatinput", - "Folder deleted successfully": "", - "Folder name cannot be empty.": "", - "Folder name updated successfully": "", + "Folder deleted successfully": "Mappe fjernet.", + "Folder name cannot be empty.": "Mappenavn kan ikke være tom.", + "Folder name updated successfully": "Mappenavn opdateret.", "Followed instructions perfectly": "Fulgte instruktionerne perfekt", "Forge new paths": "", "Form": "Formular", - "Format your variables using brackets like this:": "", + "Format your variables using brackets like this:": "Formater dine variable ved hjælp af klammer som dette:", "Forwards system user session credentials to authenticate": "", "Frequency Penalty": "Hyppighedsstraf", "Full Context Mode": "", @@ -603,63 +603,63 @@ "Gemini API Config": "", "Gemini API Key is required.": "", "General": "Generelt", - "Generate": "", - "Generate an image": "", + "Generate": "Generer", + "Generate an image": "Generer et billede", "Generate Image": "Generer billede", - "Generate prompt pair": "", + "Generate prompt pair": "Generer prompt par", "Generating search query": "Genererer søgeforespørgsel", - "Generating...": "", - "Get started": "", - "Get started with {{WEBUI_NAME}}": "", + "Generating...": "Genererer...", + "Get started": "Kom i gang", + "Get started with {{WEBUI_NAME}}": "Kom i gang med {{WEBUI_NAME}}", "Global": "Global", "Good Response": "Godt svar", - "Google Drive": "", + "Google Drive": "Google Drive", "Google PSE API Key": "Google PSE API-nøgle", "Google PSE Engine Id": "Google PSE Engine-ID", - "Group created successfully": "", - "Group deleted successfully": "", - "Group Description": "", - "Group Name": "", - "Group updated successfully": "", - "Groups": "", + "Group created successfully": "Gruppe oprettet.", + "Group deleted successfully": "Gruppe slettet.", + "Group Description": "Gruppe beskrivelse", + "Group Name": "Gruppenavn", + "Group updated successfully": "Gruppe opdateret.", + "Groups": "Grupper", "Haptic Feedback": "Haptisk feedback", "has no conversations.": "har ingen samtaler.", "Hello, {{name}}": "Hej {{name}}", "Help": "Hjælp", - "Help us create the best community leaderboard by sharing your feedback history!": "", - "Hex Color": "", - "Hex Color - Leave empty for default color": "", + "Help us create the best community leaderboard by sharing your feedback history!": "Hjælp os med at oprette det bedste community-lederboard ved at dele din feedback-historik!", + "Hex Color": "Hex farve", + "Hex Color - Leave empty for default color": "Hex farve - Lad stå tomt for standard farve", "Hide": "Skjul", - "Hide Model": "", - "Home": "", - "Host": "", + "Hide Model": "Skjul model", + "Home": "Hjem", + "Host": "Vært", "How can I help you today?": "Hvordan kan jeg hjælpe dig i dag?", - "How would you rate this response?": "", + "How would you rate this response?": "Hvordan vurderer du dette svar?", "Hybrid Search": "Hybrid søgning", "I acknowledge that I have read and I understand the implications of my action. I am aware of the risks associated with executing arbitrary code and I have verified the trustworthiness of the source.": "Jeg anerkender, at jeg har læst og forstået konsekvenserne af min handling. Jeg er opmærksom på de risici, der er forbundet med at udføre vilkårlig kode, og jeg har verificeret kildens troværdighed.", "ID": "", "iframe Sandbox Allow Forms": "", "iframe Sandbox Allow Same Origin": "", "Ignite curiosity": "", - "Image": "", - "Image Compression": "", - "Image Generation": "", + "Image": "Billede", + "Image Compression": "Billedkomprimering", + "Image Generation": "Billedgenerering", "Image Generation (Experimental)": "Billedgenerering (eksperimentel)", "Image Generation Engine": "Billedgenereringsengine", "Image Max Compression Size": "", - "Image Prompt Generation": "", - "Image Prompt Generation Prompt": "", + "Image Prompt Generation": "Billedpromptgenerering", + "Image Prompt Generation Prompt": "Billedpromptgenerering prompt", "Image Settings": "Billedindstillinger", "Images": "Billeder", "Import Chats": "Importer chats", "Import Config from JSON File": "Importer konfiguration fra JSON-fil", "Import Functions": "Importer funktioner", "Import Models": "Importer modeller", - "Import Notes": "", - "Import Presets": "", + "Import Notes": "Importer noter", + "Import Presets": "Importer Presets", "Import Prompts": "Importer prompts", "Import Tools": "Importer værktøjer", - "Include": "", + "Include": "Inkluder", "Include `--api-auth` flag when running stable-diffusion-webui": "Inkluder `--api-auth` flag, når du kører stable-diffusion-webui", "Include `--api` flag when running stable-diffusion-webui": "Inkluder `--api` flag, når du kører stable-diffusion-webui", "Influences how quickly the algorithm responds to feedback from the generated text. A lower learning rate will result in slower adjustments, while a higher learning rate will make the algorithm more responsive.": "", @@ -668,15 +668,15 @@ "Input commands": "Inputkommandoer", "Install from Github URL": "Installer fra Github URL", "Instant Auto-Send After Voice Transcription": "Øjeblikkelig automatisk afsendelse efter stemmetransskription", - "Integration": "", + "Integration": "Integration", "Interface": "Grænseflade", - "Invalid file content": "", - "Invalid file format.": "", - "Invalid JSON schema": "", + "Invalid file content": "Ugyldigt filindhold", + "Invalid file format.": "Ugyldigt filformat.", + "Invalid JSON schema": "Ugyldigt JSON-schema", "Invalid Tag": "Ugyldigt tag", - "is typing...": "", + "is typing...": "er i gang med at skrive...", "January": "Januar", - "Jina API Key": "", + "Jina API Key": "Jina API-nøgle", "join our Discord for help.": "tilslut dig vores Discord for at få hjælp.", "JSON": "JSON", "JSON Preview": "JSON-forhåndsvisning", @@ -688,16 +688,16 @@ "JWT Token": "JWT-token", "Kagi Search API Key": "", "Keep Alive": "Hold i live", - "Key": "", + "Key": "Nøgle", "Keyboard shortcuts": "Tastaturgenveje", "Knowledge": "Viden", - "Knowledge Access": "", + "Knowledge Access": "Videnadgang", "Knowledge created successfully.": "Viden oprettet.", "Knowledge deleted successfully.": "Viden slettet.", - "Knowledge Public Sharing": "", + "Knowledge Public Sharing": "Viden offentlig deling", "Knowledge reset successfully.": "Viden nulstillet.", "Knowledge updated successfully": "Viden opdateret.", - "Kokoro.js (Browser)": "", + "Kokoro.js (Browser)": "Kokoro.js (Browser)", "Kokoro.js Dtype": "", "Label": "", "Landing Page Mode": "Landing Page-tilstand", @@ -705,7 +705,7 @@ "Language Locales": "", "Last Active": "Sidst aktiv", "Last Modified": "Sidst ændret", - "Last reply": "", + "Last reply": "Sidste svar", "LDAP": "", "LDAP server updated": "", "Leaderboard": "", @@ -716,28 +716,28 @@ "Leave empty to include all models or select specific models": "", "Leave empty to use the default prompt, or enter a custom prompt": "Lad stå tomt for at bruge standardprompten, eller indtast en brugerdefineret prompt", "Leave model field empty to use the default model.": "", - "License": "", + "License": "Licens", "Light": "Lys", "Listening...": "Lytter...", - "Llama.cpp": "", + "Llama.cpp": "Llama.cpp", "LLMs can make mistakes. Verify important information.": "LLM'er kan lave fejl. Bekræft vigtige oplysninger.", - "Loader": "", - "Loading Kokoro.js...": "", - "Local": "", + "Loader": "Loader", + "Loading Kokoro.js...": "Indlæser Kokoro.js...", + "Local": "Lokal", "Local Models": "Lokale modeller", - "Location access not allowed": "", - "Logit Bias": "", - "Lost": "", + "Location access not allowed": "Adgang til placering ikke tilladt", + "Logit Bias": "Logit Bias", + "Lost": "Tabt", "LTR": "LTR", "Made by Open WebUI Community": "Lavet af OpenWebUI Community", "Make sure to enclose them with": "Sørg for at omslutte dem med", "Make sure to export a workflow.json file as API format from ComfyUI.": "Sørg for at eksportere en workflow.json-fil som API-format fra ComfyUI.", "Manage": "Administrer", - "Manage Direct Connections": "", - "Manage Models": "", - "Manage Ollama": "", - "Manage Ollama API Connections": "", - "Manage OpenAI API Connections": "", + "Manage Direct Connections": "Administrer direkte forbindelser", + "Manage Models": "Administrer modeller", + "Manage Ollama": "Administrer Ollama", + "Manage Ollama API Connections": "Administrer Ollama API forbindelser", + "Manage OpenAI API Connections": "Administrer OpenAI API forbindelser", "Manage Pipelines": "Administrer pipelines", "Manage Tool Servers": "", "March": "Marts", @@ -779,8 +779,8 @@ "Model filesystem path detected. Model shortname is required for update, cannot continue.": "Model filsystemsti registreret. Modelkortnavn er påkrævet til opdatering, kan ikke fortsætte.", "Model Filtering": "", "Model ID": "Model-ID", - "Model IDs": "", - "Model Name": "", + "Model IDs": "Model-ID'er", + "Model Name": "Modelnavn", "Model not selected": "Model ikke valgt", "Model Params": "Modelparametre", "Model Permissions": "", @@ -791,45 +791,45 @@ "Models configuration saved successfully": "", "Models Public Sharing": "", "Mojeek Search API Key": "", - "more": "", + "more": "mere", "More": "Mere", - "My Notes": "", + "My Notes": "Mine noter", "Name": "Navn", - "Name your knowledge base": "", + "Name your knowledge base": "Nanvgiv din videnbase", "Native": "", "New Chat": "Ny chat", - "New Folder": "", - "New Note": "", + "New Folder": "Ny mappe", + "New Note": "Ny note", "New Password": "Ny adgangskode", "new-channel": "", - "No content": "", - "No content found": "", - "No content found in file.": "", + "No content": "Intet indhold", + "No content found": "Intet indhold fundet", + "No content found in file.": "Intet indhold fundet i fil.", "No content to speak": "Intet indhold at tale", "No distance available": "", - "No feedbacks found": "", + "No feedbacks found": "Ingen feedback fundet", "No file selected": "Ingen fil valgt", - "No groups with access, add a group to grant access": "", + "No groups with access, add a group to grant access": "Ingen grupper med adgang, tilføj en gruppe for at give adgang", "No HTML, CSS, or JavaScript content found.": "Intet HTML-, CSS- eller JavaScript-indhold fundet.", - "No inference engine with management support found": "", + "No inference engine with management support found": "Ingen inference-engine med støtte til administration fundet", "No knowledge found": "Ingen viden fundet", - "No memories to clear": "", - "No model IDs": "", - "No models found": "", - "No models selected": "", - "No Notes": "", + "No memories to clear": "Ingen hukommelser at ryde", + "No model IDs": "Ingen model-ID'er", + "No models found": "Ingen modeller fundet", + "No models selected": "Ingen modeller valgt", + "No Notes": "Ingen noter", "No results found": "Ingen resultater fundet", "No search query generated": "Ingen søgeforespørgsel genereret", "No source available": "Ingen kilde tilgængelig", - "No users were found.": "", + "No users were found.": "Ingen brugere blev fundet.", "No valves to update": "Ingen ventiler at opdatere", "None": "Ingen", "Not factually correct": "Ikke faktuelt korrekt", - "Not helpful": "", - "Note deleted successfully": "", + "Not helpful": "Ikke hjælpsom", + "Note deleted successfully": "Note slettet", "Note: If you set a minimum score, the search will only return documents with a score greater than or equal to the minimum score.": "Bemærk: Hvis du angiver en minimumscore, returnerer søgningen kun dokumenter med en score, der er større end eller lig med minimumscoren.", - "Notes": "", - "Notification Sound": "", + "Notes": "Noter", + "Notification Sound": "Notifikationslyd", "Notification Webhook": "", "Notifications": "Notifikationer", "November": "November", @@ -845,21 +845,21 @@ "Ollama API settings updated": "", "Ollama Version": "Ollama-version", "On": "Til", - "OneDrive": "", - "Only alphanumeric characters and hyphens are allowed": "", + "OneDrive": "OneDrive", + "Only alphanumeric characters and hyphens are allowed": "Kun alfanumeriske tegn og bindestreger er tilladt", "Only alphanumeric characters and hyphens are allowed in the command string.": "Kun alfanumeriske tegn og bindestreger er tilladt i kommandostrengen.", "Only collections can be edited, create a new knowledge base to edit/add documents.": "Kun samlinger kan redigeres, opret en ny vidensbase for at redigere/tilføje dokumenter.", - "Only markdown files are allowed": "", - "Only select users and groups with permission can access": "", + "Only markdown files are allowed": "Kun markdown-filer er tilladt", + "Only select users and groups with permission can access": "Kun valgte brugere og grupper med tilladelse kan tilgå", "Oops! Looks like the URL is invalid. Please double-check and try again.": "Ups! URL'en ser ud til at være ugyldig. Tjek den igen, og prøv igen.", - "Oops! There are files still uploading. Please wait for the upload to complete.": "", - "Oops! There was an error in the previous response.": "", + "Oops! There are files still uploading. Please wait for the upload to complete.": "Ups! Der er filer, der stadig uploades. Vent, til uploaden er færdig.", + "Oops! There was an error in the previous response.": "Ups! Der var en fejl i det tidligere svar.", "Oops! You're using an unsupported method (frontend only). Please serve the WebUI from the backend.": "Ups! Du bruger en metode, der ikke understøttes (kun frontend). Kør WebUI fra backend.", "Open file": "Åbn fil", "Open in full screen": "Åbn i fuld skærm", "Open new chat": "Åbn ny chat", "Open WebUI can use tools provided by any OpenAPI server.": "", - "Open WebUI uses faster-whisper internally.": "", + "Open WebUI uses faster-whisper internally.": "Open WebUI bruger faster-whisper internt.", "Open WebUI uses SpeechT5 and CMU Arctic speaker embeddings.": "", "Open WebUI version (v{{OPEN_WEBUI_VERSION}}) is lower than required version (v{{REQUIRED_VERSION}})": "Open WebUI-version (v{{OPEN_WEBUI_VERSION}}) er lavere end den krævede version (v{{REQUIRED_VERSION}})", "OpenAI": "OpenAI", @@ -872,19 +872,19 @@ "or": "eller", "Organize your users": "", "Other": "Andet", - "OUTPUT": "", + "OUTPUT": "OUTPUT", "Output format": "Outputformat", "Overview": "Oversigt", "page": "side", "Password": "Adgangskode", - "Paste Large Text as File": "", + "Paste Large Text as File": "Indsæt store tekster som fil", "PDF document (.pdf)": "PDF-dokument (.pdf)", "PDF Extract Images (OCR)": "Udtræk billeder fra PDF (OCR)", "pending": "afventer", "Permission denied when accessing media devices": "Tilladelse nægtet ved adgang til medieenheder", "Permission denied when accessing microphone": "Tilladelse nægtet ved adgang til mikrofon", "Permission denied when accessing microphone: {{error}}": "Tilladelse nægtet ved adgang til mikrofon: {{error}}", - "Permissions": "", + "Permissions": "Tilladelser", "Perplexity API Key": "", "Personalization": "Personalisering", "Pin": "Fastgør", @@ -895,50 +895,50 @@ "Pipelines": "Pipelines", "Pipelines Not Detected": "Pipelines ikke registreret", "Pipelines Valves": "Pipelines-ventiler", - "Plain text (.md)": "", + "Plain text (.md)": "Almindelig tekst (.md)", "Plain text (.txt)": "Almindelig tekst (.txt)", "Playground": "Legeplads", "Playwright Timeout (ms)": "", "Playwright WebSocket URL": "", "Please carefully review the following warnings:": "Gennemgå omhyggeligt følgende advarsler:", - "Please do not close the settings page while loading the model.": "", - "Please enter a prompt": "", - "Please enter a valid path": "", - "Please enter a valid URL": "", + "Please do not close the settings page while loading the model.": "Luk ikke indstillingerne, mens modellen indlæses.", + "Please enter a prompt": "Indtast en prompt", + "Please enter a valid path": "Indtast en gyldig sti", + "Please enter a valid URL": "Indtast en gyldig URL", "Please fill in all fields.": "Udfyld alle felter.", - "Please select a model first.": "", - "Please select a model.": "", + "Please select a model first.": "Vælg en model først.", + "Please select a model.": "Vælg en model.", "Please select a reason": "Vælg en årsag", - "Port": "", + "Port": "Port", "Positive attitude": "Positiv holdning", - "Prefix ID": "", - "Prefix ID is used to avoid conflicts with other connections by adding a prefix to the model IDs - leave empty to disable": "", + "Prefix ID": "Prefix ID", + "Prefix ID is used to avoid conflicts with other connections by adding a prefix to the model IDs - leave empty to disable": "Prefix ID bruges til at undgå konflikter med andre forbindelser ved at tilføje et prefix til model-ID'erne - lad være tom for at deaktivere", "Presence Penalty": "", "Previous 30 days": "Seneste 30 dage", "Previous 7 days": "Seneste 7 dage", "Private": "Privat", "Profile Image": "Profilbillede", - "Prompt": "", - "Prompt (e.g. Tell me a fun fact about the Roman Empire)": "Prompt (f.eks. Fortæl mig en sjov kendsgerning om Romerriget)", + "Prompt": "Prompt", + "Prompt (e.g. Tell me a fun fact about the Roman Empire)": "Prompt (f.eks. Fortæl mig en sjov fakta om Romerriget)", "Prompt Autocompletion": "", "Prompt Content": "Promptindhold", - "Prompt created successfully": "", + "Prompt created successfully": "Prompt oprettet", "Prompt suggestions": "Promptforslag", - "Prompt updated successfully": "", + "Prompt updated successfully": "Prompt opdateret", "Prompts": "Prompts", - "Prompts Access": "", - "Prompts Public Sharing": "", - "Public": "", + "Prompts Access": "Prompts adgang", + "Prompts Public Sharing": "Prompts offentlig deling", + "Public": "Offentlig", "Pull \"{{searchValue}}\" from Ollama.com": "Hent \"{{searchValue}}\" fra Ollama.com", "Pull a model from Ollama.com": "Hent en model fra Ollama.com", "Query Generation Prompt": "", "RAG Template": "RAG-skabelon", - "Rating": "", + "Rating": "Rating", "Re-rank models by topic similarity": "", "Read": "Læs", "Read Aloud": "Læs højt", "Reasoning Effort": "", - "Record": "", + "Record": "Optag", "Record voice": "Optag stemme", "Redirecting you to Open WebUI Community": "Omdirigerer dig til OpenWebUI Community", "Reduces the probability of generating nonsense. A higher value (e.g. 100) will give more diverse answers, while a lower value (e.g. 10) will be more conservative.": "", @@ -954,22 +954,22 @@ "Remove": "Fjern", "Remove Model": "Fjern model", "Rename": "Omdøb", - "Reorder Models": "", + "Reorder Models": "Omarranger modeller", "Repeat Last N": "Gentag sidste N", "Repeat Penalty (Ollama)": "", - "Reply in Thread": "", + "Reply in Thread": "Svar i tråd", "Request Mode": "Forespørgselstilstand", "Reranking Model": "Omarrangeringsmodel", "Reranking model disabled": "Omarrangeringsmodel deaktiveret", "Reranking model set to \"{{reranking_model}}\"": "Omarrangeringsmodel sat til \"{{reranking_model}}\"", "Reset": "Nulstil", - "Reset All Models": "", + "Reset All Models": "Nulstil alle modeller", "Reset Upload Directory": "Nulstil uploadmappe", "Reset Vector Storage/Knowledge": "", - "Reset view": "", + "Reset view": "Nulstil visning", "Response notifications cannot be activated as the website permissions have been denied. Please visit your browser settings to grant the necessary access.": "Svarnotifikationer kan ikke aktiveres, da webstedets tilladelser er blevet nægtet. Besøg dine browserindstillinger for at give den nødvendige adgang.", "Response splitting": "Svaropdeling", - "Result": "", + "Result": "Resultat", "Retrieval": "", "Retrieval Query Generation": "", "Rich Text Input for Chat": "", @@ -993,7 +993,7 @@ "Search Base": "", "Search Chats": "Søg i chats", "Search Collection": "Søg i samling", - "Search Filters": "", + "Search Filters": "Søg i filtre", "search for tags": "", "Search Functions": "Søg i funktioner", "Search Knowledge": "Søg i viden", @@ -1005,10 +1005,10 @@ "Search Tools": "Søg i værktøjer", "SearchApi API Key": "SearchApi API-nøgle", "SearchApi Engine": "SearchApi-engine", - "Searched {{count}} sites": "", + "Searched {{count}} sites": "Søgte {{count}} sider", "Searching \"{{searchQuery}}\"": "Søger efter \"{{searchQuery}}\"", "Searching Knowledge for \"{{searchQuery}}\"": "Søger i viden efter \"{{searchQuery}}\"", - "Searching the web...": "", + "Searching the web...": "Søger på internettet...", "Searxng Query URL": "Searxng forespørgsels-URL", "See readme.md for instructions": "Se readme.md for instruktioner", "See what's new": "Se, hvad der er nyt", @@ -1065,17 +1065,17 @@ "Share": "Del", "Share Chat": "Del chat", "Share to Open WebUI Community": "Del til OpenWebUI Community", - "Sharing Permissions": "", + "Sharing Permissions": "Delingstilladelser", "Show": "Vis", "Show \"What's New\" modal on login": "", "Show Admin Details in Account Pending Overlay": "Vis administratordetaljer i overlay for ventende konto", - "Show Model": "", + "Show Model": "Vis model", "Show shortcuts": "Vis genveje", "Show your support!": "Vis din støtte!", "Showcased creativity": "Udstillet kreativitet", "Sign in": "Log ind", "Sign in to {{WEBUI_NAME}}": "Log ind på {{WEBUI_NAME}}", - "Sign in to {{WEBUI_NAME}} with LDAP": "", + "Sign in to {{WEBUI_NAME}} with LDAP": "Log ind på {{WEBUI_NAME}} med LDAP", "Sign Out": "Log ud", "Sign up": "Tilmeld dig", "Sign up to {{WEBUI_NAME}}": "Tilmeld dig {{WEBUI_NAME}}", @@ -1087,7 +1087,7 @@ "Speech Playback Speed": "Talehastighed", "Speech recognition error: {{error}}": "Talegenkendelsesfejl: {{error}}", "Speech-to-Text Engine": "Tale-til-tekst-engine", - "Stop": "", + "Stop": "Stop", "Stop Sequence": "Stopsekvens", "Stream Chat Response": "Stream chatsvar", "STT Model": "STT-model", @@ -1106,7 +1106,7 @@ "Tags Generation": "", "Tags Generation Prompt": "", "Tail free sampling is used to reduce the impact of less probable tokens from the output. A higher value (e.g., 2.0) will reduce the impact more, while a value of 1.0 disables this setting.": "", - "Talk to model": "", + "Talk to model": "Tal til model", "Tap to interrupt": "Tryk for at afbryde", "Tasks": "", "Tavily API Key": "Tavily API-nøgle", @@ -1134,18 +1134,18 @@ "Theme": "Tema", "Thinking...": "Tænker...", "This action cannot be undone. Do you wish to continue?": "Denne handling kan ikke fortrydes. Vil du fortsætte?", - "This channel was created on {{createdAt}}. This is the very beginning of the {{channelName}} channel.": "", - "This chat won’t appear in history and your messages will not be saved.": "", + "This channel was created on {{createdAt}}. This is the very beginning of the {{channelName}} channel.": "Denne kanal blev oprettet den {{createdAt}}. Dette er det helt første i kanalen {{channelName}}.", + "This chat won’t appear in history and your messages will not be saved.": "Denne chat vil ikke vises i historikken, og dine beskeder vil ikke blive gemt.", "This ensures that your valuable conversations are securely saved to your backend database. Thank you!": "Dette sikrer, at dine værdifulde samtaler gemmes sikkert i din backend-database. Tak!", "This is an experimental feature, it may not function as expected and is subject to change at any time.": "Dette er en eksperimentel funktion, den fungerer muligvis ikke som forventet og kan ændres når som helst.", "This option controls how many tokens are preserved when refreshing the context. For example, if set to 2, the last 2 tokens of the conversation context will be retained. Preserving context can help maintain the continuity of a conversation, but it may reduce the ability to respond to new topics.": "", "This option sets the maximum number of tokens the model can generate in its response. Increasing this limit allows the model to provide longer answers, but it may also increase the likelihood of unhelpful or irrelevant content being generated.": "", "This option will delete all existing files in the collection and replace them with newly uploaded files.": "Denne indstilling sletter alle eksisterende filer i samlingen og erstatter dem med nyligt uploadede filer.", - "This response was generated by \"{{model}}\"": "", + "This response was generated by \"{{model}}\"": "Dette svar blev genereret af \"{{model}}\"", "This will delete": "Dette vil slette", - "This will delete {{NAME}} and all its contents.": "", - "This will delete all models including custom models": "", - "This will delete all models including custom models and cannot be undone.": "", + "This will delete {{NAME}} and all its contents.": "Dette vil slette {{NAME}} og alt dens indhold.", + "This will delete all models including custom models": "Dette vil slette alle modeller, inklusive brugerdefinerede modeller", + "This will delete all models including custom models and cannot be undone.": "Dette vil slette alle modeller, inklusive brugerdefinerede modeller og kan ikke fortrydes.", "This will reset the knowledge base and sync all files. Do you wish to continue?": "Dette vil nulstille vidensbasen og synkronisere alle filer. Vil du fortsætte?", "Thorough explanation": "Grundig forklaring", "Thought for {{DURATION}}": "Tanker for {{DURATION}}", @@ -1219,10 +1219,10 @@ "Updated": "Opdateret", "Updated at": "Opdateret kl.", "Updated At": "Opdateret Klokken.", - "Upgrade to a licensed plan for enhanced capabilities, including custom theming and branding, and dedicated support.": "", + "Upgrade to a licensed plan for enhanced capabilities, including custom theming and branding, and dedicated support.": "Opgrader til en betalingsplan for at få adgang til udvidede funktioner, herunder tilpasning af tema og branding samt dedikeret support.", "Upload": "Upload", "Upload a GGUF model": "Upload en GGUF-model", - "Upload Audio": "", + "Upload Audio": "Upload lyd", "Upload directory": "Uploadmappe", "Upload files": "Upload filer", "Upload Files": "Upload filer", @@ -1232,9 +1232,9 @@ "URL Mode": "URL-tilstand", "Use '#' in the prompt input to load and include your knowledge.": "Brug '#' i promptinput for at indlæse og inkludere din viden.", "Use Gravatar": "Brug Gravatar", - "Use groups to group your users and assign permissions.": "", + "Use groups to group your users and assign permissions.": "Brug grupper til at gruppere dine brugere og tildele rettigheder.", "Use Initials": "Brug initialer", - "Use no proxy to fetch page contents.": "", + "Use no proxy to fetch page contents.": "Brug ingen proxy til at hente sideindhold.", "Use proxy designated by http_proxy and https_proxy environment variables to fetch page contents.": "", "use_mlock (Ollama)": "use_mlock (Ollama)", "use_mmap (Ollama)": "use_mmap (Ollama)", @@ -1244,7 +1244,7 @@ "User Webhooks": "Bruger Webhooks", "Username": "Brugernavn", "Users": "Brugere", - "Using the default arena model with all models. Click the plus button to add custom models.": "", + "Using the default arena model with all models. Click the plus button to add custom models.": "Brug den standard Arena-model med alle modeller. Klik på plusknappen for at tilføje brugerdefinerede modeller.", "Utilize": "Anvend", "Valid time units:": "Gyldige tidsenheder:", "Valves": "Ventiler", @@ -1252,26 +1252,26 @@ "Valves updated successfully": "Ventiler opdateret.", "variable": "variabel", "variable to have them replaced with clipboard content.": "variabel for at få dem erstattet med indholdet af udklipsholderen.", - "Verify Connection": "", - "Verify SSL Certificate": "", + "Verify Connection": "Verificer forbindelse", + "Verify SSL Certificate": "Verificer SSL-certifikat", "Version": "Version", "Version {{selectedVersion}} of {{totalVersions}}": "Version {{selectedVersion}} af {{totalVersions}}", - "View Replies": "", - "View Result from **{{NAME}}**": "", + "View Replies": "Vis svar", + "View Result from **{{NAME}}**": "Vis resultat fra **{{NAME}}**", "Visibility": "Synlighed", "Voice": "Stemme", "Voice Input": "Stemme Input", "Warning": "Advarsel", "Warning:": "Advarsel:", - "Warning: Enabling this will allow users to upload arbitrary code on the server.": "", + "Warning: Enabling this will allow users to upload arbitrary code on the server.": "Advarsel: Hvis du aktiverer dette, vil brugerne kunne uploade vilkårlig kode på serveren.", "Warning: If you update or change your embedding model, you will need to re-import all documents.": "Advarsel: Hvis du opdaterer eller ændrer din indlejringsmodel, skal du importere alle dokumenter igen.", - "Warning: Jupyter execution enables arbitrary code execution, posing severe security risks—proceed with extreme caution.": "", + "Warning: Jupyter execution enables arbitrary code execution, posing severe security risks—proceed with extreme caution.": "Advarsel: Jupyter-udførelse gør det muligt at udføre vilkårlig kode, hvilket udfordrer alvorlige sikkerhedsrisici - fortsæt med ekstremt omhyggelighed.", "Web": "Web", "Web API": "Web API", "Web Loader Engine": "", "Web Search": "Websøgning", "Web Search Engine": "Websøgemaskine", - "Web Search in Chat": "", + "Web Search in Chat": "Websøgning i chat", "Web Search Query Generation": "", "Webhook URL": "Webhook-URL", "WebUI Settings": "WebUI-indstillinger", From f56983632f11cfd29ab4966020e6b5d4c8e719fa Mon Sep 17 00:00:00 2001 From: Sine Jespersen Date: Wed, 7 May 2025 14:20:06 +0200 Subject: [PATCH 18/75] add npm package svelte-focus-trap --- package-lock.json | 16 ++++++++++++++++ package.json | 1 + 2 files changed, 17 insertions(+) diff --git a/package-lock.json b/package-lock.json index b5145a90b9..d58b11bf19 100644 --- a/package-lock.json +++ b/package-lock.json @@ -65,6 +65,7 @@ "pyodide": "^0.27.3", "socket.io-client": "^4.2.0", "sortablejs": "^1.15.2", + "svelte-focus-trap": "^1.2.0", "svelte-sonner": "^0.3.19", "tippy.js": "^6.3.7", "turndown": "^7.2.0", @@ -8856,6 +8857,12 @@ "pathe": "^2.0.1" } }, + "node_modules/mousetrap": { + "version": "1.6.5", + "resolved": "https://registry.npmjs.org/mousetrap/-/mousetrap-1.6.5.tgz", + "integrity": "sha512-QNo4kEepaIBwiT8CDhP98umTetp+JNfQYBWvC1pc6/OAibuXtRcxZ58Qz8skvEHYvURne/7R8T5VoOI7rDsEUA==", + "license": "Apache-2.0 WITH LLVM-exception" + }, "node_modules/mri": { "version": "1.2.0", "resolved": "https://registry.npmjs.org/mri/-/mri-1.2.0.tgz", @@ -11410,6 +11417,15 @@ } } }, + "node_modules/svelte-focus-trap": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/svelte-focus-trap/-/svelte-focus-trap-1.2.0.tgz", + "integrity": "sha512-/hIUHgKcFlewsQreq8v7DYNBkQe7rR0c94PNBOCsmeUwoIYAy6iXJ1pH0k3rWpjwZHKtUxeXbX1iRFlFhipbeg==", + "license": "MIT", + "dependencies": { + "mousetrap": "^1.6.5" + } + }, "node_modules/svelte-hmr": { "version": "0.16.0", "resolved": "https://registry.npmjs.org/svelte-hmr/-/svelte-hmr-0.16.0.tgz", diff --git a/package.json b/package.json index ce1cb25454..3b86462231 100644 --- a/package.json +++ b/package.json @@ -108,6 +108,7 @@ "pyodide": "^0.27.3", "socket.io-client": "^4.2.0", "sortablejs": "^1.15.2", + "svelte-focus-trap": "^1.2.0", "svelte-sonner": "^0.3.19", "tippy.js": "^6.3.7", "turndown": "^7.2.0", From 54b30e0b7fb1ede93420c65a39332f5c9684d8f9 Mon Sep 17 00:00:00 2001 From: Sine Jespersen Date: Wed, 7 May 2025 14:21:56 +0200 Subject: [PATCH 19/75] use svelte-focus-trap in modal --- src/lib/components/common/Modal.svelte | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/lib/components/common/Modal.svelte b/src/lib/components/common/Modal.svelte index 07f5c46af4..9f1ac371d5 100644 --- a/src/lib/components/common/Modal.svelte +++ b/src/lib/components/common/Modal.svelte @@ -3,7 +3,7 @@ import { fade } from 'svelte/transition'; import { flyAndScale } from '$lib/utils/transitions'; - + import { focusTrap } from 'svelte-focus-trap' export let show = true; export let size = 'md'; export let containerClassName = 'p-3'; @@ -66,6 +66,7 @@ From ba72d4625fa44439c51c6f4e3abe1d97cb0e6359 Mon Sep 17 00:00:00 2001 From: Timothy Jaeryang Baek Date: Sat, 10 May 2025 18:36:45 +0400 Subject: [PATCH 67/75] refac --- .../admin/Settings/Documents.svelte | 90 +------------------ 1 file changed, 1 insertion(+), 89 deletions(-) diff --git a/src/lib/components/admin/Settings/Documents.svelte b/src/lib/components/admin/Settings/Documents.svelte index a3a5299bcf..97f5927db5 100644 --- a/src/lib/components/admin/Settings/Documents.svelte +++ b/src/lib/components/admin/Settings/Documents.svelte @@ -123,35 +123,6 @@ } }; - const rerankingModelUpdateHandler = async () => { - console.log('Update reranking model attempt:', rerankingModel); - - updateRerankingModelLoading = true; - const res = await updateRerankingConfig(localStorage.token, { - reranking_model: rerankingModel - }).catch(async (error) => { - toast.error(`${error}`); - await setRerankingConfig(); - return null; - }); - updateRerankingModelLoading = false; - - if (res) { - console.log('rerankingModelUpdateHandler:', res); - if (res.status === true) { - if (rerankingModel === '') { - toast.success($i18n.t('Reranking model disabled', res), { - duration: 1000 * 10 - }); - } else { - toast.success($i18n.t('Reranking model set to "{{reranking_model}}"', res), { - duration: 1000 * 10 - }); - } - } - } - }; - const submitHandler = async () => { if (RAGConfig.CONTENT_EXTRACTION_ENGINE === 'tika' && RAGConfig.TIKA_SERVER_URL === '') { toast.error($i18n.t('Tika Server URL required.')); @@ -190,10 +161,6 @@ if (!RAGConfig.BYPASS_EMBEDDING_AND_RETRIEVAL) { await embeddingModelUpdateHandler(); - - if (RAGConfig.ENABLE_RAG_HYBRID_SEARCH) { - await rerankingModelUpdateHandler(); - } } const res = await updateRAGConfig(localStorage.token, RAGConfig); @@ -673,7 +640,7 @@
@@ -694,61 +661,6 @@ bind:value={RAGConfig.RAG_RERANKING_MODEL} />
- {#if RAGConfig.RAG_RERANKING_ENGINE === ''} - - {/if}
From a515a5df1a582ae8bb3b2f99cdc84df5d1c0db1e Mon Sep 17 00:00:00 2001 From: Timothy Jaeryang Baek Date: Sat, 10 May 2025 18:38:30 +0400 Subject: [PATCH 68/75] refac --- src/lib/components/admin/Settings/Documents.svelte | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/src/lib/components/admin/Settings/Documents.svelte b/src/lib/components/admin/Settings/Documents.svelte index 97f5927db5..cc56356fa7 100644 --- a/src/lib/components/admin/Settings/Documents.svelte +++ b/src/lib/components/admin/Settings/Documents.svelte @@ -622,6 +622,13 @@ class="dark:bg-gray-900 w-fit pr-8 rounded-sm px-2 p-1 text-xs bg-transparent outline-hidden text-right" bind:value={RAGConfig.RAG_RERANKING_ENGINE} placeholder="Select a reranking model engine" + on:change={(e) => { + if (e.target.value === 'external') { + RAGConfig.RAG_RERANKING_MODEL = ''; + } else if (e.target.value === '') { + RAGConfig.RAG_RERANKING_MODEL = 'BAAI/bge-reranker-v2-m3'; + } + }} > From 3a79840a87e60f7b809bc31384dd93820df1197d Mon Sep 17 00:00:00 2001 From: Timothy Jaeryang Baek Date: Sat, 10 May 2025 18:59:04 +0400 Subject: [PATCH 69/75] feat: unstylized pdf export --- .../components/chat/Settings/Interface.svelte | 35 ++++ src/lib/components/layout/Navbar/Menu.svelte | 165 ++++++++++++------ .../components/layout/Sidebar/ChatMenu.svelte | 164 +++++++++++------ 3 files changed, 248 insertions(+), 116 deletions(-) diff --git a/src/lib/components/chat/Settings/Interface.svelte b/src/lib/components/chat/Settings/Interface.svelte index f78fa55930..f17c8b40d9 100644 --- a/src/lib/components/chat/Settings/Interface.svelte +++ b/src/lib/components/chat/Settings/Interface.svelte @@ -54,6 +54,9 @@ height: '' }; + // chat export + let stylizedPdfExport = true; + // Admin - Show Update Available Toast let showUpdateToast = true; let showChangelog = true; @@ -152,6 +155,11 @@ saveSettings({ hapticFeedback: hapticFeedback }); }; + const toggleStylizedPdfExport = async () => { + stylizedPdfExport = !stylizedPdfExport; + saveSettings({ stylizedPdfExport: stylizedPdfExport }); + }; + const toggleUserLocation = async () => { userLocation = !userLocation; @@ -302,6 +310,11 @@ notificationSound = $settings?.notificationSound ?? true; notificationSoundAlways = $settings?.notificationSoundAlways ?? false; + iframeSandboxAllowSameOrigin = $settings?.iframeSandboxAllowSameOrigin ?? false; + iframeSandboxAllowForms = $settings?.iframeSandboxAllowForms ?? false; + + stylizedPdfExport = $settings?.stylizedPdfExport ?? true; + hapticFeedback = $settings.hapticFeedback ?? false; ctrlEnterToSend = $settings.ctrlEnterToSend ?? false; @@ -964,6 +977,28 @@ +
+
+
+ {$i18n.t('Stylized PDF Export')} +
+ + +
+
+
{$i18n.t('Voice')}
diff --git a/src/lib/components/layout/Navbar/Menu.svelte b/src/lib/components/layout/Navbar/Menu.svelte index 8ae3b2d0ae..1118f3e3db 100644 --- a/src/lib/components/layout/Navbar/Menu.svelte +++ b/src/lib/components/layout/Navbar/Menu.svelte @@ -19,7 +19,8 @@ mobile, temporaryChatEnabled, theme, - user + user, + settings } from '$lib/stores'; import { flyAndScale } from '$lib/utils/transitions'; @@ -63,76 +64,124 @@ }; const downloadPdf = async () => { - const containerElement = document.getElementById('messages-container'); + if ($settings?.stylizedPdfExport ?? true) { + const containerElement = document.getElementById('messages-container'); - if (containerElement) { - try { - const isDarkMode = document.documentElement.classList.contains('dark'); - const virtualWidth = 800; // Fixed width in px - const pagePixelHeight = 1200; // Each slice height (adjust to avoid canvas bugs; generally 2–4k is safe) + if (containerElement) { + try { + const isDarkMode = document.documentElement.classList.contains('dark'); + const virtualWidth = 800; // Fixed width in px + const pagePixelHeight = 1200; // Each slice height (adjust to avoid canvas bugs; generally 2–4k is safe) - // Clone & style once - const clonedElement = containerElement.cloneNode(true); - clonedElement.classList.add('text-black'); - clonedElement.classList.add('dark:text-white'); - clonedElement.style.width = `${virtualWidth}px`; - clonedElement.style.position = 'absolute'; - clonedElement.style.left = '-9999px'; // Offscreen - clonedElement.style.height = 'auto'; - document.body.appendChild(clonedElement); + // Clone & style once + const clonedElement = containerElement.cloneNode(true); + clonedElement.classList.add('text-black'); + clonedElement.classList.add('dark:text-white'); + clonedElement.style.width = `${virtualWidth}px`; + clonedElement.style.position = 'absolute'; + clonedElement.style.left = '-9999px'; // Offscreen + clonedElement.style.height = 'auto'; + document.body.appendChild(clonedElement); - // Get total height after attached to DOM - const totalHeight = clonedElement.scrollHeight; - let offsetY = 0; - let page = 0; + // Get total height after attached to DOM + const totalHeight = clonedElement.scrollHeight; + let offsetY = 0; + let page = 0; - // Prepare PDF - const pdf = new jsPDF('p', 'mm', 'a4'); - const imgWidth = 210; // A4 mm - const pageHeight = 297; // A4 mm + // Prepare PDF + const pdf = new jsPDF('p', 'mm', 'a4'); + const imgWidth = 210; // A4 mm + const pageHeight = 297; // A4 mm - while (offsetY < totalHeight) { - // For each slice, adjust scrollTop to show desired part - clonedElement.scrollTop = offsetY; + while (offsetY < totalHeight) { + // For each slice, adjust scrollTop to show desired part + clonedElement.scrollTop = offsetY; - // Optionally: mask/hide overflowing content via CSS if needed - clonedElement.style.maxHeight = `${pagePixelHeight}px`; - // Only render the visible part - const canvas = await html2canvas(clonedElement, { - backgroundColor: isDarkMode ? '#000' : '#fff', - useCORS: true, - scale: 2, - width: virtualWidth, - height: Math.min(pagePixelHeight, totalHeight - offsetY), - // Optionally: y offset for correct region? - windowWidth: virtualWidth - //windowHeight: pagePixelHeight, - }); - const imgData = canvas.toDataURL('image/png'); - // Maintain aspect ratio - const imgHeight = (canvas.height * imgWidth) / canvas.width; - const position = 0; // Always first line, since we've clipped vertically + // Optionally: mask/hide overflowing content via CSS if needed + clonedElement.style.maxHeight = `${pagePixelHeight}px`; + // Only render the visible part + const canvas = await html2canvas(clonedElement, { + backgroundColor: isDarkMode ? '#000' : '#fff', + useCORS: true, + scale: 2, + width: virtualWidth, + height: Math.min(pagePixelHeight, totalHeight - offsetY), + // Optionally: y offset for correct region? + windowWidth: virtualWidth + //windowHeight: pagePixelHeight, + }); + const imgData = canvas.toDataURL('image/png'); + // Maintain aspect ratio + const imgHeight = (canvas.height * imgWidth) / canvas.width; + const position = 0; // Always first line, since we've clipped vertically - if (page > 0) pdf.addPage(); + if (page > 0) pdf.addPage(); - // Set page background for dark mode - if (isDarkMode) { - pdf.setFillColor(0, 0, 0); - pdf.rect(0, 0, imgWidth, pageHeight, 'F'); // black bg + // Set page background for dark mode + if (isDarkMode) { + pdf.setFillColor(0, 0, 0); + pdf.rect(0, 0, imgWidth, pageHeight, 'F'); // black bg + } + + pdf.addImage(imgData, 'PNG', 0, position, imgWidth, imgHeight); + + offsetY += pagePixelHeight; + page++; } - pdf.addImage(imgData, 'PNG', 0, position, imgWidth, imgHeight); + document.body.removeChild(clonedElement); - offsetY += pagePixelHeight; - page++; + pdf.save(`chat-${chat.chat.title}.pdf`); + } catch (error) { + console.error('Error generating PDF', error); } - - document.body.removeChild(clonedElement); - - pdf.save(`chat-${chat.chat.title}.pdf`); - } catch (error) { - console.error('Error generating PDF', error); } + } else { + console.log('Downloading PDF'); + + const chatText = await getChatAsText(); + + const doc = new jsPDF(); + + // Margins + const left = 15; + const top = 20; + const right = 15; + const bottom = 20; + + const pageWidth = doc.internal.pageSize.getWidth(); + const pageHeight = doc.internal.pageSize.getHeight(); + const usableWidth = pageWidth - left - right; + const usableHeight = pageHeight - top - bottom; + + // Font size and line height + const fontSize = 8; + doc.setFontSize(fontSize); + const lineHeight = fontSize * 1; // adjust if needed + + // Split the markdown into lines (handles \n) + const paragraphs = chatText.split('\n'); + + let y = top; + + for (let paragraph of paragraphs) { + // Wrap each paragraph to fit the width + const lines = doc.splitTextToSize(paragraph, usableWidth); + + for (let line of lines) { + // If the line would overflow the bottom, add a new page + if (y + lineHeight > pageHeight - bottom) { + doc.addPage(); + y = top; + } + doc.text(line, left, y); + y += lineHeight * 0.5; + } + // Add empty line at paragraph breaks + y += lineHeight * 0.1; + } + + doc.save(`chat-${chat.chat.title}.pdf`); } }; diff --git a/src/lib/components/layout/Sidebar/ChatMenu.svelte b/src/lib/components/layout/Sidebar/ChatMenu.svelte index 6634e9c774..04623502ec 100644 --- a/src/lib/components/layout/Sidebar/ChatMenu.svelte +++ b/src/lib/components/layout/Sidebar/ChatMenu.svelte @@ -26,7 +26,7 @@ getChatPinnedStatusById, toggleChatPinnedStatusById } from '$lib/apis/chats'; - import { chats, theme, user } from '$lib/stores'; + import { chats, settings, theme, user } from '$lib/stores'; import { createMessagesList } from '$lib/utils'; import { downloadChatAsPDF } from '$lib/apis/utils'; import Download from '$lib/components/icons/Download.svelte'; @@ -81,76 +81,124 @@ const downloadPdf = async () => { const chat = await getChatById(localStorage.token, chatId); - const containerElement = document.getElementById('messages-container'); + if ($settings?.stylizedPdfExport ?? true) { + const containerElement = document.getElementById('messages-container'); - if (containerElement) { - try { - const isDarkMode = document.documentElement.classList.contains('dark'); - const virtualWidth = 800; // Fixed width in px - const pagePixelHeight = 1200; // Each slice height (adjust to avoid canvas bugs; generally 2–4k is safe) + if (containerElement) { + try { + const isDarkMode = document.documentElement.classList.contains('dark'); + const virtualWidth = 800; // Fixed width in px + const pagePixelHeight = 1200; // Each slice height (adjust to avoid canvas bugs; generally 2–4k is safe) - // Clone & style once - const clonedElement = containerElement.cloneNode(true); - clonedElement.classList.add('text-black'); - clonedElement.classList.add('dark:text-white'); - clonedElement.style.width = `${virtualWidth}px`; - clonedElement.style.position = 'absolute'; - clonedElement.style.left = '-9999px'; // Offscreen - clonedElement.style.height = 'auto'; - document.body.appendChild(clonedElement); + // Clone & style once + const clonedElement = containerElement.cloneNode(true); + clonedElement.classList.add('text-black'); + clonedElement.classList.add('dark:text-white'); + clonedElement.style.width = `${virtualWidth}px`; + clonedElement.style.position = 'absolute'; + clonedElement.style.left = '-9999px'; // Offscreen + clonedElement.style.height = 'auto'; + document.body.appendChild(clonedElement); - // Get total height after attached to DOM - const totalHeight = clonedElement.scrollHeight; - let offsetY = 0; - let page = 0; + // Get total height after attached to DOM + const totalHeight = clonedElement.scrollHeight; + let offsetY = 0; + let page = 0; - // Prepare PDF - const pdf = new jsPDF('p', 'mm', 'a4'); - const imgWidth = 210; // A4 mm - const pageHeight = 297; // A4 mm + // Prepare PDF + const pdf = new jsPDF('p', 'mm', 'a4'); + const imgWidth = 210; // A4 mm + const pageHeight = 297; // A4 mm - while (offsetY < totalHeight) { - // For each slice, adjust scrollTop to show desired part - clonedElement.scrollTop = offsetY; + while (offsetY < totalHeight) { + // For each slice, adjust scrollTop to show desired part + clonedElement.scrollTop = offsetY; - // Optionally: mask/hide overflowing content via CSS if needed - clonedElement.style.maxHeight = `${pagePixelHeight}px`; - // Only render the visible part - const canvas = await html2canvas(clonedElement, { - backgroundColor: isDarkMode ? '#000' : '#fff', - useCORS: true, - scale: 2, - width: virtualWidth, - height: Math.min(pagePixelHeight, totalHeight - offsetY), - // Optionally: y offset for correct region? - windowWidth: virtualWidth - //windowHeight: pagePixelHeight, - }); - const imgData = canvas.toDataURL('image/png'); - // Maintain aspect ratio - const imgHeight = (canvas.height * imgWidth) / canvas.width; - const position = 0; // Always first line, since we've clipped vertically + // Optionally: mask/hide overflowing content via CSS if needed + clonedElement.style.maxHeight = `${pagePixelHeight}px`; + // Only render the visible part + const canvas = await html2canvas(clonedElement, { + backgroundColor: isDarkMode ? '#000' : '#fff', + useCORS: true, + scale: 2, + width: virtualWidth, + height: Math.min(pagePixelHeight, totalHeight - offsetY), + // Optionally: y offset for correct region? + windowWidth: virtualWidth + //windowHeight: pagePixelHeight, + }); + const imgData = canvas.toDataURL('image/png'); + // Maintain aspect ratio + const imgHeight = (canvas.height * imgWidth) / canvas.width; + const position = 0; // Always first line, since we've clipped vertically - if (page > 0) pdf.addPage(); + if (page > 0) pdf.addPage(); - // Set page background for dark mode - if (isDarkMode) { - pdf.setFillColor(0, 0, 0); - pdf.rect(0, 0, imgWidth, pageHeight, 'F'); // black bg + // Set page background for dark mode + if (isDarkMode) { + pdf.setFillColor(0, 0, 0); + pdf.rect(0, 0, imgWidth, pageHeight, 'F'); // black bg + } + + pdf.addImage(imgData, 'PNG', 0, position, imgWidth, imgHeight); + + offsetY += pagePixelHeight; + page++; } - pdf.addImage(imgData, 'PNG', 0, position, imgWidth, imgHeight); + document.body.removeChild(clonedElement); - offsetY += pagePixelHeight; - page++; + pdf.save(`chat-${chat.chat.title}.pdf`); + } catch (error) { + console.error('Error generating PDF', error); } - - document.body.removeChild(clonedElement); - - pdf.save(`chat-${chat.chat.title}.pdf`); - } catch (error) { - console.error('Error generating PDF', error); } + } else { + console.log('Downloading PDF'); + + const chatText = await getChatAsText(chat); + + const doc = new jsPDF(); + + // Margins + const left = 15; + const top = 20; + const right = 15; + const bottom = 20; + + const pageWidth = doc.internal.pageSize.getWidth(); + const pageHeight = doc.internal.pageSize.getHeight(); + const usableWidth = pageWidth - left - right; + const usableHeight = pageHeight - top - bottom; + + // Font size and line height + const fontSize = 8; + doc.setFontSize(fontSize); + const lineHeight = fontSize * 1; // adjust if needed + + // Split the markdown into lines (handles \n) + const paragraphs = chatText.split('\n'); + + let y = top; + + for (let paragraph of paragraphs) { + // Wrap each paragraph to fit the width + const lines = doc.splitTextToSize(paragraph, usableWidth); + + for (let line of lines) { + // If the line would overflow the bottom, add a new page + if (y + lineHeight > pageHeight - bottom) { + doc.addPage(); + y = top; + } + doc.text(line, left, y); + y += lineHeight; + } + // Add empty line at paragraph breaks + y += lineHeight * 0.5; + } + + doc.save(`chat-${chat.chat.title}.pdf`); } }; From c61790b355dc61d8716cbc9e315e89aa95421d77 Mon Sep 17 00:00:00 2001 From: Timothy Jaeryang Baek Date: Sat, 10 May 2025 19:00:01 +0400 Subject: [PATCH 70/75] chore: format --- .../open_webui/retrieval/vector/dbs/milvus.py | 124 ++++++++++++------ .../retrieval/vector/dbs/pinecone.py | 50 ++++--- backend/open_webui/utils/code_interpreter.py | 8 +- .../chat/MessageInput/InputMenu.svelte | 8 +- src/lib/i18n/locales/ar-BH/translation.json | 6 +- src/lib/i18n/locales/ar/translation.json | 6 +- src/lib/i18n/locales/bg-BG/translation.json | 6 +- src/lib/i18n/locales/bn-BD/translation.json | 6 +- src/lib/i18n/locales/bo-TB/translation.json | 6 +- src/lib/i18n/locales/ca-ES/translation.json | 6 +- src/lib/i18n/locales/ceb-PH/translation.json | 6 +- src/lib/i18n/locales/cs-CZ/translation.json | 6 +- src/lib/i18n/locales/da-DK/translation.json | 6 +- src/lib/i18n/locales/de-DE/translation.json | 6 +- src/lib/i18n/locales/dg-DG/translation.json | 6 +- src/lib/i18n/locales/el-GR/translation.json | 6 +- src/lib/i18n/locales/en-GB/translation.json | 6 +- src/lib/i18n/locales/en-US/translation.json | 6 +- src/lib/i18n/locales/es-ES/translation.json | 6 +- src/lib/i18n/locales/et-EE/translation.json | 6 +- src/lib/i18n/locales/eu-ES/translation.json | 6 +- src/lib/i18n/locales/fa-IR/translation.json | 6 +- src/lib/i18n/locales/fi-FI/translation.json | 6 +- src/lib/i18n/locales/fr-CA/translation.json | 6 +- src/lib/i18n/locales/fr-FR/translation.json | 6 +- src/lib/i18n/locales/he-IL/translation.json | 6 +- src/lib/i18n/locales/hi-IN/translation.json | 6 +- src/lib/i18n/locales/hr-HR/translation.json | 6 +- src/lib/i18n/locales/hu-HU/translation.json | 6 +- src/lib/i18n/locales/id-ID/translation.json | 6 +- src/lib/i18n/locales/ie-GA/translation.json | 6 +- src/lib/i18n/locales/it-IT/translation.json | 8 +- src/lib/i18n/locales/ja-JP/translation.json | 6 +- src/lib/i18n/locales/ka-GE/translation.json | 6 +- src/lib/i18n/locales/ko-KR/translation.json | 6 +- src/lib/i18n/locales/lt-LT/translation.json | 6 +- src/lib/i18n/locales/ms-MY/translation.json | 6 +- src/lib/i18n/locales/nb-NO/translation.json | 6 +- src/lib/i18n/locales/nl-NL/translation.json | 6 +- src/lib/i18n/locales/pa-IN/translation.json | 6 +- src/lib/i18n/locales/pl-PL/translation.json | 6 +- src/lib/i18n/locales/pt-BR/translation.json | 6 +- src/lib/i18n/locales/pt-PT/translation.json | 6 +- src/lib/i18n/locales/ro-RO/translation.json | 6 +- src/lib/i18n/locales/ru-RU/translation.json | 6 +- src/lib/i18n/locales/sk-SK/translation.json | 6 +- src/lib/i18n/locales/sr-RS/translation.json | 6 +- src/lib/i18n/locales/sv-SE/translation.json | 6 +- src/lib/i18n/locales/th-TH/translation.json | 6 +- src/lib/i18n/locales/tk-TW/translation.json | 6 +- src/lib/i18n/locales/tr-TR/translation.json | 6 +- src/lib/i18n/locales/uk-UA/translation.json | 6 +- src/lib/i18n/locales/ur-PK/translation.json | 6 +- src/lib/i18n/locales/vi-VN/translation.json | 6 +- src/lib/i18n/locales/zh-CN/translation.json | 9 +- src/lib/i18n/locales/zh-TW/translation.json | 6 +- src/lib/utils/onedrive-file-picker.ts | 9 +- 57 files changed, 344 insertions(+), 172 deletions(-) diff --git a/backend/open_webui/retrieval/vector/dbs/milvus.py b/backend/open_webui/retrieval/vector/dbs/milvus.py index 336dc056ae..a4bad13d00 100644 --- a/backend/open_webui/retrieval/vector/dbs/milvus.py +++ b/backend/open_webui/retrieval/vector/dbs/milvus.py @@ -24,6 +24,7 @@ from open_webui.env import SRC_LOG_LEVELS log = logging.getLogger(__name__) log.setLevel(SRC_LOG_LEVELS["RAG"]) + class MilvusClient(VectorDBBase): def __init__(self): self.collection_prefix = "open_webui" @@ -113,12 +114,15 @@ class MilvusClient(VectorDBBase): # Use configurations from config.py index_type = MILVUS_INDEX_TYPE.upper() metric_type = MILVUS_METRIC_TYPE.upper() - + log.info(f"Using Milvus index type: {index_type}, metric type: {metric_type}") index_creation_params = {} if index_type == "HNSW": - index_creation_params = {"M": MILVUS_HNSW_M, "efConstruction": MILVUS_HNSW_EFCONSTRUCTION} + index_creation_params = { + "M": MILVUS_HNSW_M, + "efConstruction": MILVUS_HNSW_EFCONSTRUCTION, + } log.info(f"HNSW params: {index_creation_params}") elif index_type == "IVF_FLAT": index_creation_params = {"nlist": MILVUS_IVF_FLAT_NLIST} @@ -146,8 +150,9 @@ class MilvusClient(VectorDBBase): schema=schema, index_params=index_params, ) - log.info(f"Successfully created collection '{self.collection_prefix}_{collection_name}' with index type '{index_type}' and metric '{metric_type}'.") - + log.info( + f"Successfully created collection '{self.collection_prefix}_{collection_name}' with index type '{index_type}' and metric '{metric_type}'." + ) def has_collection(self, collection_name: str) -> bool: # Check if the collection exists based on the collection name. @@ -184,7 +189,9 @@ class MilvusClient(VectorDBBase): # Construct the filter string for querying collection_name = collection_name.replace("-", "_") if not self.has_collection(collection_name): - log.warning(f"Query attempted on non-existent collection: {self.collection_prefix}_{collection_name}") + log.warning( + f"Query attempted on non-existent collection: {self.collection_prefix}_{collection_name}" + ) return None filter_string = " && ".join( [ @@ -200,47 +207,62 @@ class MilvusClient(VectorDBBase): # For now, if limit is None, we'll fetch in batches up to a very large number. # This part could be refined based on expected use cases for "get all". # For this function signature, None implies "as many as possible" up to Milvus limits. - limit = 16384 * 10 # A large number to signify fetching many, will be capped by actual data or max_limit per call. - log.info(f"Limit not specified for query, fetching up to {limit} results in batches.") - + limit = ( + 16384 * 10 + ) # A large number to signify fetching many, will be capped by actual data or max_limit per call. + log.info( + f"Limit not specified for query, fetching up to {limit} results in batches." + ) # Initialize offset and remaining to handle pagination offset = 0 remaining = limit - + try: - log.info(f"Querying collection {self.collection_prefix}_{collection_name} with filter: '{filter_string}', limit: {limit}") + log.info( + f"Querying collection {self.collection_prefix}_{collection_name} with filter: '{filter_string}', limit: {limit}" + ) # Loop until there are no more items to fetch or the desired limit is reached while remaining > 0: - current_fetch = min(max_limit, remaining if isinstance(remaining, int) else max_limit) - log.debug(f"Querying with offset: {offset}, current_fetch: {current_fetch}") - + current_fetch = min( + max_limit, remaining if isinstance(remaining, int) else max_limit + ) + log.debug( + f"Querying with offset: {offset}, current_fetch: {current_fetch}" + ) + results = self.client.query( collection_name=f"{self.collection_prefix}_{collection_name}", filter=filter_string, - output_fields=["id", "data", "metadata"], # Explicitly list needed fields. Vector not usually needed in query. + output_fields=[ + "id", + "data", + "metadata", + ], # Explicitly list needed fields. Vector not usually needed in query. limit=current_fetch, offset=offset, ) - + if not results: log.debug("No more results from query.") break - + all_results.extend(results) results_count = len(results) log.debug(f"Fetched {results_count} results in this batch.") if isinstance(remaining, int): remaining -= results_count - + offset += results_count - + # Break the loop if the results returned are less than the requested fetch count (means end of data) if results_count < current_fetch: - log.debug("Fetched less than requested, assuming end of results for this query.") + log.debug( + "Fetched less than requested, assuming end of results for this query." + ) break - + log.info(f"Total results from query: {len(all_results)}") return self._result_to_get_result([all_results]) except Exception as e: @@ -252,27 +274,36 @@ class MilvusClient(VectorDBBase): def get(self, collection_name: str) -> Optional[GetResult]: # Get all the items in the collection. This can be very resource-intensive for large collections. collection_name = collection_name.replace("-", "_") - log.warning(f"Fetching ALL items from collection '{self.collection_prefix}_{collection_name}'. This might be slow for large collections.") + log.warning( + f"Fetching ALL items from collection '{self.collection_prefix}_{collection_name}'. This might be slow for large collections." + ) # Using query with a trivial filter to get all items. # This will use the paginated query logic. return self.query(collection_name=collection_name, filter={}, limit=None) - def insert(self, collection_name: str, items: list[VectorItem]): # Insert the items into the collection, if the collection does not exist, it will be created. collection_name = collection_name.replace("-", "_") if not self.client.has_collection( collection_name=f"{self.collection_prefix}_{collection_name}" ): - log.info(f"Collection {self.collection_prefix}_{collection_name} does not exist. Creating now.") + log.info( + f"Collection {self.collection_prefix}_{collection_name} does not exist. Creating now." + ) if not items: - log.error(f"Cannot create collection {self.collection_prefix}_{collection_name} without items to determine dimension.") - raise ValueError("Cannot create Milvus collection without items to determine vector dimension.") + log.error( + f"Cannot create collection {self.collection_prefix}_{collection_name} without items to determine dimension." + ) + raise ValueError( + "Cannot create Milvus collection without items to determine vector dimension." + ) self._create_collection( collection_name=collection_name, dimension=len(items[0]["vector"]) ) - - log.info(f"Inserting {len(items)} items into collection {self.collection_prefix}_{collection_name}.") + + log.info( + f"Inserting {len(items)} items into collection {self.collection_prefix}_{collection_name}." + ) return self.client.insert( collection_name=f"{self.collection_prefix}_{collection_name}", data=[ @@ -292,15 +323,23 @@ class MilvusClient(VectorDBBase): if not self.client.has_collection( collection_name=f"{self.collection_prefix}_{collection_name}" ): - log.info(f"Collection {self.collection_prefix}_{collection_name} does not exist for upsert. Creating now.") + log.info( + f"Collection {self.collection_prefix}_{collection_name} does not exist for upsert. Creating now." + ) if not items: - log.error(f"Cannot create collection {self.collection_prefix}_{collection_name} for upsert without items to determine dimension.") - raise ValueError("Cannot create Milvus collection for upsert without items to determine vector dimension.") + log.error( + f"Cannot create collection {self.collection_prefix}_{collection_name} for upsert without items to determine dimension." + ) + raise ValueError( + "Cannot create Milvus collection for upsert without items to determine vector dimension." + ) self._create_collection( collection_name=collection_name, dimension=len(items[0]["vector"]) ) - - log.info(f"Upserting {len(items)} items into collection {self.collection_prefix}_{collection_name}.") + + log.info( + f"Upserting {len(items)} items into collection {self.collection_prefix}_{collection_name}." + ) return self.client.upsert( collection_name=f"{self.collection_prefix}_{collection_name}", data=[ @@ -323,11 +362,15 @@ class MilvusClient(VectorDBBase): # Delete the items from the collection based on the ids or filter. collection_name = collection_name.replace("-", "_") if not self.has_collection(collection_name): - log.warning(f"Delete attempted on non-existent collection: {self.collection_prefix}_{collection_name}") + log.warning( + f"Delete attempted on non-existent collection: {self.collection_prefix}_{collection_name}" + ) return None if ids: - log.info(f"Deleting items by IDs from {self.collection_prefix}_{collection_name}. IDs: {ids}") + log.info( + f"Deleting items by IDs from {self.collection_prefix}_{collection_name}. IDs: {ids}" + ) return self.client.delete( collection_name=f"{self.collection_prefix}_{collection_name}", ids=ids, @@ -339,19 +382,24 @@ class MilvusClient(VectorDBBase): for key, value in filter.items() ] ) - log.info(f"Deleting items by filter from {self.collection_prefix}_{collection_name}. Filter: {filter_string}") + log.info( + f"Deleting items by filter from {self.collection_prefix}_{collection_name}. Filter: {filter_string}" + ) return self.client.delete( collection_name=f"{self.collection_prefix}_{collection_name}", filter=filter_string, ) else: - log.warning(f"Delete operation on {self.collection_prefix}_{collection_name} called without IDs or filter. No action taken.") + log.warning( + f"Delete operation on {self.collection_prefix}_{collection_name} called without IDs or filter. No action taken." + ) return None - def reset(self): # Resets the database. This will delete all collections and item entries that match the prefix. - log.warning(f"Resetting Milvus: Deleting all collections with prefix '{self.collection_prefix}'.") + log.warning( + f"Resetting Milvus: Deleting all collections with prefix '{self.collection_prefix}'." + ) collection_names = self.client.list_collections() deleted_collections = [] for collection_name_full in collection_names: diff --git a/backend/open_webui/retrieval/vector/dbs/pinecone.py b/backend/open_webui/retrieval/vector/dbs/pinecone.py index 2f44e70e7d..c921089b6d 100644 --- a/backend/open_webui/retrieval/vector/dbs/pinecone.py +++ b/backend/open_webui/retrieval/vector/dbs/pinecone.py @@ -48,7 +48,9 @@ class PineconeClient(VectorDBBase): self.cloud = PINECONE_CLOUD # Initialize Pinecone gRPC client for improved performance - self.client = PineconeGRPC(api_key=self.api_key, environment=self.environment, cloud=self.cloud) + self.client = PineconeGRPC( + api_key=self.api_key, environment=self.environment, cloud=self.cloud + ) # Persistent executor for batch operations self._executor = concurrent.futures.ThreadPoolExecutor(max_workers=5) @@ -222,7 +224,9 @@ class PineconeClient(VectorDBBase): raise elapsed = time.time() - start_time log.debug(f"Insert of {len(points)} vectors took {elapsed:.2f} seconds") - log.info(f"Successfully inserted {len(points)} vectors in parallel batches into '{collection_name_with_prefix}'") + log.info( + f"Successfully inserted {len(points)} vectors in parallel batches into '{collection_name_with_prefix}'" + ) def upsert(self, collection_name: str, items: List[VectorItem]) -> None: """Upsert (insert or update) vectors into a collection.""" @@ -251,7 +255,9 @@ class PineconeClient(VectorDBBase): raise elapsed = time.time() - start_time log.debug(f"Upsert of {len(points)} vectors took {elapsed:.2f} seconds") - log.info(f"Successfully upserted {len(points)} vectors in parallel batches into '{collection_name_with_prefix}'") + log.info( + f"Successfully upserted {len(points)} vectors in parallel batches into '{collection_name_with_prefix}'" + ) async def insert_async(self, collection_name: str, items: List[VectorItem]) -> None: """Async version of insert using asyncio and run_in_executor for improved performance.""" @@ -259,16 +265,19 @@ class PineconeClient(VectorDBBase): log.warning("No items to insert") return - collection_name_with_prefix = self._get_collection_name_with_prefix(collection_name) + collection_name_with_prefix = self._get_collection_name_with_prefix( + collection_name + ) points = self._create_points(items, collection_name_with_prefix) # Create batches - batches = [points[i : i + BATCH_SIZE] for i in range(0, len(points), BATCH_SIZE)] + batches = [ + points[i : i + BATCH_SIZE] for i in range(0, len(points), BATCH_SIZE) + ] loop = asyncio.get_event_loop() tasks = [ loop.run_in_executor( - None, - functools.partial(self.index.upsert, vectors=batch) + None, functools.partial(self.index.upsert, vectors=batch) ) for batch in batches ] @@ -277,7 +286,9 @@ class PineconeClient(VectorDBBase): if isinstance(result, Exception): log.error(f"Error in async insert batch: {result}") raise result - log.info(f"Successfully async inserted {len(points)} vectors in batches into '{collection_name_with_prefix}'") + log.info( + f"Successfully async inserted {len(points)} vectors in batches into '{collection_name_with_prefix}'" + ) async def upsert_async(self, collection_name: str, items: List[VectorItem]) -> None: """Async version of upsert using asyncio and run_in_executor for improved performance.""" @@ -285,16 +296,19 @@ class PineconeClient(VectorDBBase): log.warning("No items to upsert") return - collection_name_with_prefix = self._get_collection_name_with_prefix(collection_name) + collection_name_with_prefix = self._get_collection_name_with_prefix( + collection_name + ) points = self._create_points(items, collection_name_with_prefix) # Create batches - batches = [points[i : i + BATCH_SIZE] for i in range(0, len(points), BATCH_SIZE)] + batches = [ + points[i : i + BATCH_SIZE] for i in range(0, len(points), BATCH_SIZE) + ] loop = asyncio.get_event_loop() tasks = [ loop.run_in_executor( - None, - functools.partial(self.index.upsert, vectors=batch) + None, functools.partial(self.index.upsert, vectors=batch) ) for batch in batches ] @@ -303,7 +317,9 @@ class PineconeClient(VectorDBBase): if isinstance(result, Exception): log.error(f"Error in async upsert batch: {result}") raise result - log.info(f"Successfully async upserted {len(points)} vectors in batches into '{collection_name_with_prefix}'") + log.info( + f"Successfully async upserted {len(points)} vectors in batches into '{collection_name_with_prefix}'" + ) def streaming_upsert(self, collection_name: str, items: List[VectorItem]) -> None: """Perform a streaming upsert over gRPC for performance testing.""" @@ -311,7 +327,9 @@ class PineconeClient(VectorDBBase): log.warning("No items to upsert via streaming") return - collection_name_with_prefix = self._get_collection_name_with_prefix(collection_name) + collection_name_with_prefix = self._get_collection_name_with_prefix( + collection_name + ) points = self._create_points(items, collection_name_with_prefix) # Open a streaming upsert channel @@ -322,7 +340,9 @@ class PineconeClient(VectorDBBase): stream.send(point) # close the stream to finalize stream.close() - log.info(f"Successfully streamed upsert of {len(points)} vectors into '{collection_name_with_prefix}'") + log.info( + f"Successfully streamed upsert of {len(points)} vectors into '{collection_name_with_prefix}'" + ) except Exception as e: log.error(f"Error during streaming upsert: {e}") raise diff --git a/backend/open_webui/utils/code_interpreter.py b/backend/open_webui/utils/code_interpreter.py index 99567e1153..f3dcbb81fb 100644 --- a/backend/open_webui/utils/code_interpreter.py +++ b/backend/open_webui/utils/code_interpreter.py @@ -50,8 +50,8 @@ class JupyterCodeExecuter: self.password = password self.timeout = timeout self.kernel_id = "" - if self.base_url[-1] != '/': - self.base_url += '/' + if self.base_url[-1] != "/": + self.base_url += "/" self.session = aiohttp.ClientSession(trust_env=True, base_url=self.base_url) self.params = {} self.result = ResultModel() @@ -103,9 +103,7 @@ class JupyterCodeExecuter: self.params.update({"token": self.token}) async def init_kernel(self) -> None: - async with self.session.post( - url="api/kernels", params=self.params - ) as response: + async with self.session.post(url="api/kernels", params=self.params) as response: response.raise_for_status() kernel_data = await response.json() self.kernel_id = kernel_data["id"] diff --git a/src/lib/components/chat/MessageInput/InputMenu.svelte b/src/lib/components/chat/MessageInput/InputMenu.svelte index 829c4c87fb..6a024af512 100644 --- a/src/lib/components/chat/MessageInput/InputMenu.svelte +++ b/src/lib/components/chat/MessageInput/InputMenu.svelte @@ -142,7 +142,7 @@ {/each}
- {#if Object.keys(tools).length > 3} + {#if Object.keys(tools).length > 3} - {/if} + {/if}
{/if} diff --git a/src/lib/i18n/locales/ar-BH/translation.json b/src/lib/i18n/locales/ar-BH/translation.json index 97e3392ce8..0de51c2a7b 100644 --- a/src/lib/i18n/locales/ar-BH/translation.json +++ b/src/lib/i18n/locales/ar-BH/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "", "Reply in Thread": "", "Request Mode": "وضع الطلب", + "Reranking Engine": "", "Reranking Model": "إعادة تقييم النموذج", - "Reranking model disabled": "تم تعطيل نموذج إعادة الترتيب", - "Reranking model set to \"{{reranking_model}}\"": "تم ضبط نموذج إعادة الترتيب على \"{{reranking_model}}\"", "Reset": "", "Reset All Models": "", "Reset Upload Directory": "", @@ -1069,6 +1068,8 @@ "Show": "عرض", "Show \"What's New\" modal on login": "", "Show Admin Details in Account Pending Overlay": "", + "Show All": "", + "Show Less": "", "Show Model": "", "Show shortcuts": "إظهار الاختصارات", "Show your support!": "", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "", "STT Model": "", "STT Settings": "STT اعدادات", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "(e.g. about the Roman Empire) الترجمة", "Success": "نجاح", "Successfully updated.": "تم التحديث بنجاح", diff --git a/src/lib/i18n/locales/ar/translation.json b/src/lib/i18n/locales/ar/translation.json index 735171b1f2..7ae8bc5947 100644 --- a/src/lib/i18n/locales/ar/translation.json +++ b/src/lib/i18n/locales/ar/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "عقوبة التكرار (Ollama)", "Reply in Thread": "الرد داخل سلسلة الرسائل", "Request Mode": "وضع الطلب", + "Reranking Engine": "", "Reranking Model": "إعادة تقييم النموذج", - "Reranking model disabled": "تم تعطيل نموذج إعادة الترتيب", - "Reranking model set to \"{{reranking_model}}\"": "تم ضبط نموذج إعادة الترتيب على \"{{reranking_model}}\"", "Reset": "إعادة تعيين", "Reset All Models": "إعادة تعيين جميع النماذج", "Reset Upload Directory": "إعادة تعيين مجلد التحميل", @@ -1069,6 +1068,8 @@ "Show": "عرض", "Show \"What's New\" modal on login": "عرض نافذة \"ما الجديد\" عند تسجيل الدخول", "Show Admin Details in Account Pending Overlay": "عرض تفاصيل المشرف في نافذة \"الحساب قيد الانتظار\"", + "Show All": "", + "Show Less": "", "Show Model": "", "Show shortcuts": "إظهار الاختصارات", "Show your support!": "أظهر دعمك!", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "بث استجابة الدردشة", "STT Model": "نموذج تحويل الصوت إلى نص (STT)", "STT Settings": "STT اعدادات", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "(e.g. about the Roman Empire) الترجمة", "Success": "نجاح", "Successfully updated.": "تم التحديث بنجاح", diff --git a/src/lib/i18n/locales/bg-BG/translation.json b/src/lib/i18n/locales/bg-BG/translation.json index f72bb308cc..110a300444 100644 --- a/src/lib/i18n/locales/bg-BG/translation.json +++ b/src/lib/i18n/locales/bg-BG/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "Наказание за повторение (Ollama)", "Reply in Thread": "Отговори в тред", "Request Mode": "Режим на заявка", + "Reranking Engine": "", "Reranking Model": "Модел за преподреждане", - "Reranking model disabled": "Моделът за преподреждане е деактивиран", - "Reranking model set to \"{{reranking_model}}\"": "Моделът за преподреждане е зададен на \"{{reranking_model}}\"", "Reset": "Нулиране", "Reset All Models": "Нулиране на всички модели", "Reset Upload Directory": "Нулиране на директорията за качване", @@ -1069,6 +1068,8 @@ "Show": "Покажи", "Show \"What's New\" modal on login": "Покажи модалния прозорец \"Какво е ново\" при вписване", "Show Admin Details in Account Pending Overlay": "Покажи детайлите на администратора в наслагването на изчакващ акаунт", + "Show All": "", + "Show Less": "", "Show Model": "", "Show shortcuts": "Покажи преки пътища", "Show your support!": "Покажете вашата подкрепа!", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "Поточен чат отговор", "STT Model": "STT Модел", "STT Settings": "STT Настройки", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "Подтитул (напр. за Римска империя)", "Success": "Успех", "Successfully updated.": "Успешно обновено.", diff --git a/src/lib/i18n/locales/bn-BD/translation.json b/src/lib/i18n/locales/bn-BD/translation.json index 08e5d82b13..1a73820177 100644 --- a/src/lib/i18n/locales/bn-BD/translation.json +++ b/src/lib/i18n/locales/bn-BD/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "", "Reply in Thread": "", "Request Mode": "রিকোয়েস্ট মোড", + "Reranking Engine": "", "Reranking Model": "রির্যাক্টিং মডেল", - "Reranking model disabled": "রির্যাক্টিং মডেল নিষ্ক্রিয় করা", - "Reranking model set to \"{{reranking_model}}\"": "রির ্যাঙ্কিং মডেল \"{{reranking_model}}\" -এ সেট করা আছে", "Reset": "", "Reset All Models": "", "Reset Upload Directory": "", @@ -1069,6 +1068,8 @@ "Show": "দেখান", "Show \"What's New\" modal on login": "", "Show Admin Details in Account Pending Overlay": "", + "Show All": "", + "Show Less": "", "Show Model": "", "Show shortcuts": "শর্টকাটগুলো দেখান", "Show your support!": "", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "", "STT Model": "", "STT Settings": "STT সেটিংস", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "সাবটাইটল (রোমান ইম্পার্টের সম্পর্কে)", "Success": "সফল", "Successfully updated.": "সফলভাবে আপডেট হয়েছে", diff --git a/src/lib/i18n/locales/bo-TB/translation.json b/src/lib/i18n/locales/bo-TB/translation.json index 6f40b29b0a..fc36c59539 100644 --- a/src/lib/i18n/locales/bo-TB/translation.json +++ b/src/lib/i18n/locales/bo-TB/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "བསྐྱར་ཟློས་ཀྱི་ཆད་པ། (Ollama)", "Reply in Thread": "བརྗོད་གཞིའི་ནང་ལན་འདེབས།", "Request Mode": "རེ་ཞུའི་མ་དཔེ།", + "Reranking Engine": "", "Reranking Model": "བསྐྱར་སྒྲིག་དཔེ་དབྱིབས།", - "Reranking model disabled": "བསྐྱར་སྒྲིག་དཔེ་དབྱིབས་ནུས་མེད་བཏང་།", - "Reranking model set to \"{{reranking_model}}\"": "བསྐྱར་སྒྲིག་དཔེ་དབྱིབས་ \"{{reranking_model}}\" ལ་བཀོད་སྒྲིག་བྱས།", "Reset": "སླར་སྒྲིག", "Reset All Models": "དཔེ་དབྱིབས་ཡོངས་རྫོགས་སླར་སྒྲིག", "Reset Upload Directory": "སྤར་བའི་ཐོ་འཚོལ་སླར་སྒྲིག", @@ -1069,6 +1068,8 @@ "Show": "སྟོན་པ།", "Show \"What's New\" modal on login": "ནང་འཛུལ་སྐབས་ \"གསར་པ་ཅི་ཡོད\" modal སྟོན་པ།", "Show Admin Details in Account Pending Overlay": "རྩིས་ཁྲ་སྒུག་བཞིན་པའི་གཏོགས་ངོས་སུ་དོ་དམ་པའི་ཞིབ་ཕྲ་སྟོན་པ།", + "Show All": "", + "Show Less": "", "Show Model": "དཔེ་དབྱིབས་སྟོན་པ།", "Show shortcuts": "མྱུར་ལམ་སྟོན་པ།", "Show your support!": "ཁྱེད་ཀྱི་རྒྱབ་སྐྱོར་སྟོན་པ།", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "ཁ་བརྡའི་ལན་རྒྱུག་པ།", "STT Model": "STT དཔེ་དབྱིབས།", "STT Settings": "STT སྒྲིག་འགོད།", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "ཁ་བྱང་ཕལ་པ། (དཔེར་ན། རོམ་མའི་གོང་མའི་རྒྱལ་ཁབ་སྐོར།)", "Success": "ལེགས་འགྲུབ།", "Successfully updated.": "ལེགས་པར་གསར་སྒྱུར་བྱས།", diff --git a/src/lib/i18n/locales/ca-ES/translation.json b/src/lib/i18n/locales/ca-ES/translation.json index 8afeee176a..09a8b559b5 100644 --- a/src/lib/i18n/locales/ca-ES/translation.json +++ b/src/lib/i18n/locales/ca-ES/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "Penalització per repetició (Ollama)", "Reply in Thread": "Respondre al fil", "Request Mode": "Mode de sol·licitud", + "Reranking Engine": "", "Reranking Model": "Model de reavaluació", - "Reranking model disabled": "Model de reavaluació desactivat", - "Reranking model set to \"{{reranking_model}}\"": "Model de reavaluació establert a \"{{reranking_model}}\"", "Reset": "Restableix", "Reset All Models": "Restablir tots els models", "Reset Upload Directory": "Restableix el directori de pujades", @@ -1069,6 +1068,8 @@ "Show": "Mostrar", "Show \"What's New\" modal on login": "Veure 'Què hi ha de nou' a l'entrada", "Show Admin Details in Account Pending Overlay": "Mostrar els detalls de l'administrador a la superposició del compte pendent", + "Show All": "", + "Show Less": "", "Show Model": "Mostrar el model", "Show shortcuts": "Mostrar dreceres", "Show your support!": "Mostra el teu suport!", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "Fer streaming de la resposta del xat", "STT Model": "Model SST", "STT Settings": "Preferències de STT", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "Subtítol (per exemple, sobre l'Imperi Romà)", "Success": "Èxit", "Successfully updated.": "Actualitzat correctament.", diff --git a/src/lib/i18n/locales/ceb-PH/translation.json b/src/lib/i18n/locales/ceb-PH/translation.json index a126b71b5f..94d7da4526 100644 --- a/src/lib/i18n/locales/ceb-PH/translation.json +++ b/src/lib/i18n/locales/ceb-PH/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "", "Reply in Thread": "", "Request Mode": "Query mode", + "Reranking Engine": "", "Reranking Model": "", - "Reranking model disabled": "", - "Reranking model set to \"{{reranking_model}}\"": "", "Reset": "", "Reset All Models": "", "Reset Upload Directory": "", @@ -1069,6 +1068,8 @@ "Show": "Pagpakita", "Show \"What's New\" modal on login": "", "Show Admin Details in Account Pending Overlay": "", + "Show All": "", + "Show Less": "", "Show Model": "", "Show shortcuts": "Ipakita ang mga shortcut", "Show your support!": "", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "", "STT Model": "", "STT Settings": "Mga setting sa STT", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "", "Success": "Kalampusan", "Successfully updated.": "Malampuson nga na-update.", diff --git a/src/lib/i18n/locales/cs-CZ/translation.json b/src/lib/i18n/locales/cs-CZ/translation.json index ff1adb4add..c3c08d807e 100644 --- a/src/lib/i18n/locales/cs-CZ/translation.json +++ b/src/lib/i18n/locales/cs-CZ/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "", "Reply in Thread": "", "Request Mode": "Režim žádosti", + "Reranking Engine": "", "Reranking Model": "Model pro přehodnocení pořadí", - "Reranking model disabled": "Přeřazovací model je deaktivován", - "Reranking model set to \"{{reranking_model}}\"": "Model pro přeřazení nastaven na \"{{reranking_model}}\"", "Reset": "režim Reset", "Reset All Models": "", "Reset Upload Directory": "Resetovat adresář nahrávání", @@ -1069,6 +1068,8 @@ "Show": "Zobrazit", "Show \"What's New\" modal on login": "", "Show Admin Details in Account Pending Overlay": "Zobrazit podrobnosti administrátora v překryvném okně s čekajícím účtem", + "Show All": "", + "Show Less": "", "Show Model": "", "Show shortcuts": "Zobrazit klávesové zkratky", "Show your support!": "Vyjadřete svou podporu!", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "Odezva chatu Stream", "STT Model": "Model rozpoznávání řeči na text (STT)", "STT Settings": "Nastavení STT (Rozpoznávání řeči)", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "Titulky (např. o Římské říši)", "Success": "Úspěch", "Successfully updated.": "Úspěšně aktualizováno.", diff --git a/src/lib/i18n/locales/da-DK/translation.json b/src/lib/i18n/locales/da-DK/translation.json index 06bfafbe7a..45ebbb431f 100644 --- a/src/lib/i18n/locales/da-DK/translation.json +++ b/src/lib/i18n/locales/da-DK/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "", "Reply in Thread": "Svar i tråd", "Request Mode": "Forespørgselstilstand", + "Reranking Engine": "", "Reranking Model": "Omarrangeringsmodel", - "Reranking model disabled": "Omarrangeringsmodel deaktiveret", - "Reranking model set to \"{{reranking_model}}\"": "Omarrangeringsmodel sat til \"{{reranking_model}}\"", "Reset": "Nulstil", "Reset All Models": "Nulstil alle modeller", "Reset Upload Directory": "Nulstil uploadmappe", @@ -1069,6 +1068,8 @@ "Show": "Vis", "Show \"What's New\" modal on login": "", "Show Admin Details in Account Pending Overlay": "Vis administratordetaljer i overlay for ventende konto", + "Show All": "", + "Show Less": "", "Show Model": "Vis model", "Show shortcuts": "Vis genveje", "Show your support!": "Vis din støtte!", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "Stream chatsvar", "STT Model": "STT-model", "STT Settings": "STT-indstillinger", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "Undertitel (f.eks. om Romerriget)", "Success": "Succes", "Successfully updated.": "Opdateret.", diff --git a/src/lib/i18n/locales/de-DE/translation.json b/src/lib/i18n/locales/de-DE/translation.json index 7452630e66..3a42f4edaa 100644 --- a/src/lib/i18n/locales/de-DE/translation.json +++ b/src/lib/i18n/locales/de-DE/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "Wiederholungsstrafe (Ollama)", "Reply in Thread": "Im Thread antworten", "Request Mode": "Anforderungsmodus", + "Reranking Engine": "", "Reranking Model": "Reranking-Modell", - "Reranking model disabled": "Reranking-Modell deaktiviert", - "Reranking model set to \"{{reranking_model}}\"": "Reranking-Modell \"{{reranking_model}}\" fesgelegt", "Reset": "Zurücksetzen", "Reset All Models": "Alle Modelle zurücksetzen", "Reset Upload Directory": "Upload-Verzeichnis zurücksetzen", @@ -1069,6 +1068,8 @@ "Show": "Anzeigen", "Show \"What's New\" modal on login": "\"Was gibt's Neues\"-Modal beim Anmelden anzeigen", "Show Admin Details in Account Pending Overlay": "Admin-Details im Account-Pending-Overlay anzeigen", + "Show All": "", + "Show Less": "", "Show Model": "Modell anzeigen", "Show shortcuts": "Verknüpfungen anzeigen", "Show your support!": "Zeigen Sie Ihre Unterstützung!", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "Chat-Antwort streamen", "STT Model": "STT-Modell", "STT Settings": "STT-Einstellungen", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "Untertitel (z. B. über das Römische Reich)", "Success": "Erfolg", "Successfully updated.": "Erfolgreich aktualisiert.", diff --git a/src/lib/i18n/locales/dg-DG/translation.json b/src/lib/i18n/locales/dg-DG/translation.json index 3551342942..b6a5349d8e 100644 --- a/src/lib/i18n/locales/dg-DG/translation.json +++ b/src/lib/i18n/locales/dg-DG/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "", "Reply in Thread": "", "Request Mode": "Request Bark", + "Reranking Engine": "", "Reranking Model": "", - "Reranking model disabled": "", - "Reranking model set to \"{{reranking_model}}\"": "", "Reset": "", "Reset All Models": "", "Reset Upload Directory": "", @@ -1069,6 +1068,8 @@ "Show": "Show much show", "Show \"What's New\" modal on login": "", "Show Admin Details in Account Pending Overlay": "", + "Show All": "", + "Show Less": "", "Show Model": "", "Show shortcuts": "Show shortcuts much shortcut", "Show your support!": "", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "", "STT Model": "", "STT Settings": "STT Settings very settings", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "", "Success": "Success very success", "Successfully updated.": "Successfully updated. Very updated.", diff --git a/src/lib/i18n/locales/el-GR/translation.json b/src/lib/i18n/locales/el-GR/translation.json index 62cd6c9c74..350eba785e 100644 --- a/src/lib/i18n/locales/el-GR/translation.json +++ b/src/lib/i18n/locales/el-GR/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "", "Reply in Thread": "", "Request Mode": "Λειτουργία Αιτήματος", + "Reranking Engine": "", "Reranking Model": "Μοντέλο Επαναταξινόμησης", - "Reranking model disabled": "Το μοντέλο επαναταξινόμησης απενεργοποιήθηκε", - "Reranking model set to \"{{reranking_model}}\"": "Το μοντέλο επαναταξινόμησης ορίστηκε σε \"{{reranking_model}}\"", "Reset": "Επαναφορά", "Reset All Models": "Επαναφορά Όλων των Μοντέλων", "Reset Upload Directory": "Επαναφορά Καταλόγου Ανεβάσματος", @@ -1069,6 +1068,8 @@ "Show": "Εμφάνιση", "Show \"What's New\" modal on login": "Εμφάνιση του παράθυρου \"Τι νέο υπάρχει\" κατά την είσοδο", "Show Admin Details in Account Pending Overlay": "Εμφάνιση Λεπτομερειών Διαχειριστή στο Υπέρθεση Εκκρεμής Λογαριασμού", + "Show All": "", + "Show Less": "", "Show Model": "", "Show shortcuts": "Εμφάνιση συντομεύσεων", "Show your support!": "Δείξτε την υποστήριξή σας!", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "Συνομιλία Ροής Απάντησης", "STT Model": "Μοντέλο STT", "STT Settings": "Ρυθμίσεις STT", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "Υπότιτλος (π.χ. για την Ρωμαϊκή Αυτοκρατορία)", "Success": "Επιτυχία", "Successfully updated.": "Επιτυχώς ενημερώθηκε.", diff --git a/src/lib/i18n/locales/en-GB/translation.json b/src/lib/i18n/locales/en-GB/translation.json index 306bcc7cd5..76c1b27579 100644 --- a/src/lib/i18n/locales/en-GB/translation.json +++ b/src/lib/i18n/locales/en-GB/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "", "Reply in Thread": "", "Request Mode": "", + "Reranking Engine": "", "Reranking Model": "", - "Reranking model disabled": "", - "Reranking model set to \"{{reranking_model}}\"": "", "Reset": "", "Reset All Models": "", "Reset Upload Directory": "", @@ -1069,6 +1068,8 @@ "Show": "", "Show \"What's New\" modal on login": "", "Show Admin Details in Account Pending Overlay": "", + "Show All": "", + "Show Less": "", "Show Model": "", "Show shortcuts": "", "Show your support!": "", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "", "STT Model": "", "STT Settings": "", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "", "Success": "", "Successfully updated.": "", diff --git a/src/lib/i18n/locales/en-US/translation.json b/src/lib/i18n/locales/en-US/translation.json index 306bcc7cd5..76c1b27579 100644 --- a/src/lib/i18n/locales/en-US/translation.json +++ b/src/lib/i18n/locales/en-US/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "", "Reply in Thread": "", "Request Mode": "", + "Reranking Engine": "", "Reranking Model": "", - "Reranking model disabled": "", - "Reranking model set to \"{{reranking_model}}\"": "", "Reset": "", "Reset All Models": "", "Reset Upload Directory": "", @@ -1069,6 +1068,8 @@ "Show": "", "Show \"What's New\" modal on login": "", "Show Admin Details in Account Pending Overlay": "", + "Show All": "", + "Show Less": "", "Show Model": "", "Show shortcuts": "", "Show your support!": "", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "", "STT Model": "", "STT Settings": "", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "", "Success": "", "Successfully updated.": "", diff --git a/src/lib/i18n/locales/es-ES/translation.json b/src/lib/i18n/locales/es-ES/translation.json index 4a1d4a4c70..b02c660c9c 100644 --- a/src/lib/i18n/locales/es-ES/translation.json +++ b/src/lib/i18n/locales/es-ES/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "Penalización Repetición (Ollama)", "Reply in Thread": "Responder en Hilo", "Request Mode": "Modo de Petición", + "Reranking Engine": "", "Reranking Model": "Modelo de Reclasificación", - "Reranking model disabled": "Modelo de reclasificacioń deshabilitado", - "Reranking model set to \"{{reranking_model}}\"": "Modelo de reclasificación establecido a \"{{reranking_model}}\"", "Reset": "Reiniciar", "Reset All Models": "Reiniciar Todos los Modelos", "Reset Upload Directory": "Reiniciar Directorio de Subidas", @@ -1069,6 +1068,8 @@ "Show": "Mostrar", "Show \"What's New\" modal on login": "Mostrar modal \"Qué hay de Nuevo\" al iniciar sesión", "Show Admin Details in Account Pending Overlay": "Mostrar Detalles Admin en la sobrecapa de 'Cuenta Pendiente'", + "Show All": "", + "Show Less": "", "Show Model": "Mostrar Modelo", "Show shortcuts": "Mostrar Atajos", "Show your support!": "¡Muestra tu apoyo!", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "Transmisión Directa de la Respuesta del Chat", "STT Model": "Modelo STT", "STT Settings": "Ajustes Voz a Texto (STT)", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "Subtítulo (p.ej. sobre el Imperio Romano)", "Success": "Correcto", "Successfully updated.": "Actualizado correctamente.", diff --git a/src/lib/i18n/locales/et-EE/translation.json b/src/lib/i18n/locales/et-EE/translation.json index 282c341fd2..f3fdc051e6 100644 --- a/src/lib/i18n/locales/et-EE/translation.json +++ b/src/lib/i18n/locales/et-EE/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "Korduse karistus (Ollama)", "Reply in Thread": "Vasta lõimes", "Request Mode": "Päringu režiim", + "Reranking Engine": "", "Reranking Model": "Ümberjärjestamise mudel", - "Reranking model disabled": "Ümberjärjestamise mudel keelatud", - "Reranking model set to \"{{reranking_model}}\"": "Ümberjärjestamise mudel määratud kui \"{{reranking_model}}\"", "Reset": "Lähtesta", "Reset All Models": "Lähtesta kõik mudelid", "Reset Upload Directory": "Lähtesta üleslaadimiste kataloog", @@ -1069,6 +1068,8 @@ "Show": "Näita", "Show \"What's New\" modal on login": "Näita \"Mis on uut\" modaalakent sisselogimisel", "Show Admin Details in Account Pending Overlay": "Näita administraatori üksikasju konto ootel kattekihil", + "Show All": "", + "Show Less": "", "Show Model": "", "Show shortcuts": "Näita otseteid", "Show your support!": "Näita oma toetust!", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "Voogedasta vestluse vastust", "STT Model": "STT mudel", "STT Settings": "STT seaded", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "Alampealkiri (nt Rooma impeeriumi kohta)", "Success": "Õnnestus", "Successfully updated.": "Edukalt uuendatud.", diff --git a/src/lib/i18n/locales/eu-ES/translation.json b/src/lib/i18n/locales/eu-ES/translation.json index ffa420ec98..9b364dfe40 100644 --- a/src/lib/i18n/locales/eu-ES/translation.json +++ b/src/lib/i18n/locales/eu-ES/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "", "Reply in Thread": "", "Request Mode": "Eskaera modua", + "Reranking Engine": "", "Reranking Model": "Berrantolatze modeloa", - "Reranking model disabled": "Berrantolatze modeloa desgaituta", - "Reranking model set to \"{{reranking_model}}\"": "Berrantolatze modeloa \"{{reranking_model}}\"-era ezarrita", "Reset": "Berrezarri", "Reset All Models": "", "Reset Upload Directory": "Berrezarri karga direktorioa", @@ -1069,6 +1068,8 @@ "Show": "Erakutsi", "Show \"What's New\" modal on login": "Erakutsi \"Berritasunak\" modala saioa hastean", "Show Admin Details in Account Pending Overlay": "Erakutsi administratzaile xehetasunak kontu zain geruzan", + "Show All": "", + "Show Less": "", "Show Model": "", "Show shortcuts": "Erakutsi lasterbideak", "Show your support!": "Erakutsi zure babesa!", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "Transmititu txat erantzuna", "STT Model": "STT modeloa", "STT Settings": "STT ezarpenak", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "Azpititulua (adib. Erromatar Inperioari buruz)", "Success": "Arrakasta", "Successfully updated.": "Ongi eguneratu da.", diff --git a/src/lib/i18n/locales/fa-IR/translation.json b/src/lib/i18n/locales/fa-IR/translation.json index b298a61395..39d15f046f 100644 --- a/src/lib/i18n/locales/fa-IR/translation.json +++ b/src/lib/i18n/locales/fa-IR/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "جریمه تکرار (ollama)", "Reply in Thread": "پاسخ در رشته", "Request Mode": "حالت درخواست", + "Reranking Engine": "", "Reranking Model": "مدل ری\u200cشناسی مجدد غیرفعال است", - "Reranking model disabled": "مدل ری\u200cشناسی مجدد غیرفعال است", - "Reranking model set to \"{{reranking_model}}\"": "مدل ری\u200cشناسی مجدد به \"{{reranking_model}}\" تنظیم شده است", "Reset": "بازنشانی", "Reset All Models": "بازنشانی همه مدل\u200cها", "Reset Upload Directory": "بازنشانی پوشه آپلود", @@ -1069,6 +1068,8 @@ "Show": "نمایش", "Show \"What's New\" modal on login": "نمایش مودال \"موارد جدید\" هنگام ورود", "Show Admin Details in Account Pending Overlay": "نمایش جزئیات مدیر در پوشش حساب در انتظار", + "Show All": "", + "Show Less": "", "Show Model": "نمایش مدل", "Show shortcuts": "نمایش میانبرها", "Show your support!": "حمایت خود را نشان دهید!", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "پاسخ چت جریانی", "STT Model": "مدل تبدیل صدا به متن", "STT Settings": "تنظیمات تبدیل صدا به متن", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "زیرنویس (برای مثال: درباره رمانی)", "Success": "موفقیت", "Successfully updated.": "با موفقیت به\u200cروز شد", diff --git a/src/lib/i18n/locales/fi-FI/translation.json b/src/lib/i18n/locales/fi-FI/translation.json index fae02283a1..bb8b409800 100644 --- a/src/lib/i18n/locales/fi-FI/translation.json +++ b/src/lib/i18n/locales/fi-FI/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "Toisto rangaistus (Ollama)", "Reply in Thread": "Vastauksia ", "Request Mode": "Pyyntötila", + "Reranking Engine": "", "Reranking Model": "Uudelleenpisteytymismalli", - "Reranking model disabled": "Uudelleenpisteytymismalli poistettu käytöstä", - "Reranking model set to \"{{reranking_model}}\"": "\"{{reranking_model}}\" valittu uudelleenpisteytysmalliksi", "Reset": "Palauta", "Reset All Models": "Palauta kaikki mallit", "Reset Upload Directory": "Palauta latauspolku", @@ -1069,6 +1068,8 @@ "Show": "Näytä", "Show \"What's New\" modal on login": "Näytä \"Mitä uutta\" -modaali kirjautumisen yhteydessä", "Show Admin Details in Account Pending Overlay": "Näytä ylläpitäjän tiedot odottavan tilin päällä", + "Show All": "", + "Show Less": "", "Show Model": "Näytä malli", "Show shortcuts": "Näytä pikanäppäimet", "Show your support!": "Osoita tukesi!", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "Streamaa keskusteluvastaus", "STT Model": "Puheentunnistusmalli", "STT Settings": "Puheentunnistuksen asetukset", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "Alaotsikko (esim. Rooman valtakunta)", "Success": "Onnistui", "Successfully updated.": "Päivitetty onnistuneesti.", diff --git a/src/lib/i18n/locales/fr-CA/translation.json b/src/lib/i18n/locales/fr-CA/translation.json index 9902ce1e83..28f49a42ad 100644 --- a/src/lib/i18n/locales/fr-CA/translation.json +++ b/src/lib/i18n/locales/fr-CA/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "", "Reply in Thread": "", "Request Mode": "Mode de Requête", + "Reranking Engine": "", "Reranking Model": "Modèle de ré-ranking", - "Reranking model disabled": "Modèle de ré-ranking désactivé", - "Reranking model set to \"{{reranking_model}}\"": "Modèle de ré-ranking défini sur « {{reranking_model}} »", "Reset": "Réinitialiser", "Reset All Models": "", "Reset Upload Directory": "Répertoire de téléchargement réinitialisé", @@ -1069,6 +1068,8 @@ "Show": "Montrer", "Show \"What's New\" modal on login": "", "Show Admin Details in Account Pending Overlay": "Afficher les détails de l'administrateur dans la superposition en attente du compte", + "Show All": "", + "Show Less": "", "Show Model": "", "Show shortcuts": "Afficher les raccourcis", "Show your support!": "Montre ton soutien !", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "", "STT Model": "Modèle de STT", "STT Settings": "Paramètres de STT", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "Sous-titres (par ex. sur l'Empire romain)", "Success": "Réussite", "Successfully updated.": "Mise à jour réussie.", diff --git a/src/lib/i18n/locales/fr-FR/translation.json b/src/lib/i18n/locales/fr-FR/translation.json index e7140249ff..5bc788b500 100644 --- a/src/lib/i18n/locales/fr-FR/translation.json +++ b/src/lib/i18n/locales/fr-FR/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "Pénalité de répétition (Ollama)", "Reply in Thread": "Répondre dans le fil de discussion", "Request Mode": "Mode de requête", + "Reranking Engine": "", "Reranking Model": "Modèle de ré-ranking", - "Reranking model disabled": "Modèle de ré-ranking désactivé", - "Reranking model set to \"{{reranking_model}}\"": "Modèle de ré-ranking défini sur « {{reranking_model}} »", "Reset": "Réinitialiser", "Reset All Models": "Réinitialiser tous les modèles", "Reset Upload Directory": "Réinitialiser le répertoire de téléchargement", @@ -1069,6 +1068,8 @@ "Show": "Afficher", "Show \"What's New\" modal on login": "Afficher la fenêtre modale \"Quoi de neuf\" lors de la connexion", "Show Admin Details in Account Pending Overlay": "Afficher les coordonnées de l'administrateur aux comptes en attente", + "Show All": "", + "Show Less": "", "Show Model": "Afficher le model", "Show shortcuts": "Afficher les raccourcis", "Show your support!": "Montrez votre soutien !", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "Streamer la réponse de la conversation", "STT Model": "Modèle de Speech-to-Text", "STT Settings": "Paramètres de Speech-to-Text", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "Sous-titres (par ex. sur l'Empire romain)", "Success": "Réussite", "Successfully updated.": "Mise à jour réussie.", diff --git a/src/lib/i18n/locales/he-IL/translation.json b/src/lib/i18n/locales/he-IL/translation.json index ff425d4df1..7cb8477e0b 100644 --- a/src/lib/i18n/locales/he-IL/translation.json +++ b/src/lib/i18n/locales/he-IL/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "", "Reply in Thread": "", "Request Mode": "מצב בקשה", + "Reranking Engine": "", "Reranking Model": "מודל דירוג מחדש", - "Reranking model disabled": "מודל דירוג מחדש מושבת", - "Reranking model set to \"{{reranking_model}}\"": "מודל דירוג מחדש הוגדר ל-\"{{reranking_model}}\"", "Reset": "", "Reset All Models": "", "Reset Upload Directory": "", @@ -1069,6 +1068,8 @@ "Show": "הצג", "Show \"What's New\" modal on login": "", "Show Admin Details in Account Pending Overlay": "", + "Show All": "", + "Show Less": "", "Show Model": "", "Show shortcuts": "הצג קיצורי דרך", "Show your support!": "", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "", "STT Model": "", "STT Settings": "הגדרות חקירה של TTS", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "תחקור (לדוגמה: על מעמד הרומי)", "Success": "הצלחה", "Successfully updated.": "עדכון הצלחה.", diff --git a/src/lib/i18n/locales/hi-IN/translation.json b/src/lib/i18n/locales/hi-IN/translation.json index 8b5c9c6dc7..5fae05898b 100644 --- a/src/lib/i18n/locales/hi-IN/translation.json +++ b/src/lib/i18n/locales/hi-IN/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "", "Reply in Thread": "", "Request Mode": "अनुरोध मोड", + "Reranking Engine": "", "Reranking Model": "रीरैकिंग मोड", - "Reranking model disabled": "पुनर्रैंकिंग मॉडल अक्षम किया गया", - "Reranking model set to \"{{reranking_model}}\"": "रीरैंकिंग मॉडल को \"{{reranking_model}}\" पर \u200b\u200bसेट किया गया", "Reset": "", "Reset All Models": "", "Reset Upload Directory": "", @@ -1069,6 +1068,8 @@ "Show": "दिखाओ", "Show \"What's New\" modal on login": "", "Show Admin Details in Account Pending Overlay": "", + "Show All": "", + "Show Less": "", "Show Model": "", "Show shortcuts": "शॉर्टकट दिखाएँ", "Show your support!": "", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "", "STT Model": "", "STT Settings": "STT सेटिंग्स ", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "उपशीर्षक (जैसे रोमन साम्राज्य के बारे में)", "Success": "संपन्न", "Successfully updated.": "सफलतापूर्वक उत्परिवर्तित।", diff --git a/src/lib/i18n/locales/hr-HR/translation.json b/src/lib/i18n/locales/hr-HR/translation.json index dd22b57f41..44034bf7d0 100644 --- a/src/lib/i18n/locales/hr-HR/translation.json +++ b/src/lib/i18n/locales/hr-HR/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "", "Reply in Thread": "", "Request Mode": "Način zahtjeva", + "Reranking Engine": "", "Reranking Model": "Model za ponovno rangiranje", - "Reranking model disabled": "Model za ponovno rangiranje onemogućen", - "Reranking model set to \"{{reranking_model}}\"": "Model za ponovno rangiranje postavljen na \"{{reranking_model}}\"", "Reset": "", "Reset All Models": "", "Reset Upload Directory": "Poništi upload direktorij", @@ -1069,6 +1068,8 @@ "Show": "Pokaži", "Show \"What's New\" modal on login": "", "Show Admin Details in Account Pending Overlay": "", + "Show All": "", + "Show Less": "", "Show Model": "", "Show shortcuts": "Pokaži prečace", "Show your support!": "", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "", "STT Model": "STT model", "STT Settings": "STT postavke", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "Podnaslov (npr. o Rimskom carstvu)", "Success": "Uspjeh", "Successfully updated.": "Uspješno ažurirano.", diff --git a/src/lib/i18n/locales/hu-HU/translation.json b/src/lib/i18n/locales/hu-HU/translation.json index 2de08218be..bc97fcc6c0 100644 --- a/src/lib/i18n/locales/hu-HU/translation.json +++ b/src/lib/i18n/locales/hu-HU/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "Ismétlési büntetés (Ollama)", "Reply in Thread": "Válasz szálban", "Request Mode": "Kérési mód", + "Reranking Engine": "", "Reranking Model": "Újrarangsoroló modell", - "Reranking model disabled": "Újrarangsoroló modell letiltva", - "Reranking model set to \"{{reranking_model}}\"": "Újrarangsoroló modell beállítva erre: \"{{reranking_model}}\"", "Reset": "Visszaállítás", "Reset All Models": "Minden modell visszaállítása", "Reset Upload Directory": "Feltöltési könyvtár visszaállítása", @@ -1069,6 +1068,8 @@ "Show": "Mutat", "Show \"What's New\" modal on login": "\"Mi újság\" modal megjelenítése bejelentkezéskor", "Show Admin Details in Account Pending Overlay": "Admin részletek megjelenítése a függő fiók átfedésben", + "Show All": "", + "Show Less": "", "Show Model": "Modell megjelenítése", "Show shortcuts": "Gyorsbillentyűk megjelenítése", "Show your support!": "Mutassa meg támogatását!", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "Chat válasz streamelése", "STT Model": "STT modell", "STT Settings": "STT beállítások", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "Alcím (pl. a Római Birodalomról)", "Success": "Siker", "Successfully updated.": "Sikeresen frissítve.", diff --git a/src/lib/i18n/locales/id-ID/translation.json b/src/lib/i18n/locales/id-ID/translation.json index a4b4e6ce43..d294873e94 100644 --- a/src/lib/i18n/locales/id-ID/translation.json +++ b/src/lib/i18n/locales/id-ID/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "", "Reply in Thread": "", "Request Mode": "Mode Permintaan", + "Reranking Engine": "", "Reranking Model": "Model Pemeringkatan Ulang", - "Reranking model disabled": "Model pemeringkatan ulang dinonaktifkan", - "Reranking model set to \"{{reranking_model}}\"": "Model pemeringkatan diatur ke \"{{reranking_model}}\"", "Reset": "Atur Ulang", "Reset All Models": "", "Reset Upload Directory": "Setel Ulang Direktori Unggahan", @@ -1069,6 +1068,8 @@ "Show": "Tampilkan", "Show \"What's New\" modal on login": "", "Show Admin Details in Account Pending Overlay": "Tampilkan Detail Admin di Hamparan Akun Tertunda", + "Show All": "", + "Show Less": "", "Show Model": "", "Show shortcuts": "Tampilkan pintasan", "Show your support!": "Tunjukkan dukungan Anda!", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "", "STT Model": "Model STT", "STT Settings": "Pengaturan STT", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "Subtitle (misalnya tentang Kekaisaran Romawi)", "Success": "Berhasil", "Successfully updated.": "Berhasil diperbarui.", diff --git a/src/lib/i18n/locales/ie-GA/translation.json b/src/lib/i18n/locales/ie-GA/translation.json index 099526511f..b52118dd60 100644 --- a/src/lib/i18n/locales/ie-GA/translation.json +++ b/src/lib/i18n/locales/ie-GA/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "Pionós Athrá (Ollama)", "Reply in Thread": "Freagra i Snáithe", "Request Mode": "Mód Iarratais", + "Reranking Engine": "", "Reranking Model": "Múnla Athrangú", - "Reranking model disabled": "Samhail athrangú faoi mhíchumas", - "Reranking model set to \"{{reranking_model}}\"": "Samhail athrangú socraithe go \"{{reranking_model}}\"", "Reset": "Athshocraigh", "Reset All Models": "Athshocraigh Gach Múnla", "Reset Upload Directory": "Athshocraigh Eolaire Uas", @@ -1069,6 +1068,8 @@ "Show": "Taispeáin", "Show \"What's New\" modal on login": "Taispeáin módúil \"Cad atá Nua\" ar logáil isteach", "Show Admin Details in Account Pending Overlay": "Taispeáin Sonraí Riaracháin sa Chuntas ar Feitheamh Forleagan", + "Show All": "", + "Show Less": "", "Show Model": "Taispeáin Múnla", "Show shortcuts": "Taispeáin aicearraí", "Show your support!": "Taispeáin do thacaíocht!", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "Freagra Comhrá Sruth", "STT Model": "Múnla STT", "STT Settings": "Socruithe STT", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "Fotheideal (m.sh. faoin Impireacht Rómhánach)", "Success": "Rath", "Successfully updated.": "Nuashonraithe go rathúil.", diff --git a/src/lib/i18n/locales/it-IT/translation.json b/src/lib/i18n/locales/it-IT/translation.json index ce9c940088..1167a7b977 100644 --- a/src/lib/i18n/locales/it-IT/translation.json +++ b/src/lib/i18n/locales/it-IT/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "Penalità per ripetizione (Ollama)", "Reply in Thread": "Rispondi nel thread", "Request Mode": "Modalità richiesta", + "Reranking Engine": "", "Reranking Model": "Modello di riclassificazione", - "Reranking model disabled": "Modello di riclassificazione disabilitato", - "Reranking model set to \"{{reranking_model}}\"": "Modello di riclassificazione impostato su \"{{reranking_model}}\"", "Reset": "Ripristina", "Reset All Models": "Ripristina tutti i modelli", "Reset Upload Directory": "Ripristina directory di caricamento", @@ -1069,6 +1068,8 @@ "Show": "Mostra", "Show \"What's New\" modal on login": "Mostra il modulo \"Novità\" al login", "Show Admin Details in Account Pending Overlay": "Mostra i dettagli dell'amministratore nella sovrapposizione dell'account in attesa", + "Show All": "", + "Show Less": "", "Show Model": "Mostra modello", "Show shortcuts": "Mostra", "Show your support!": "Mostra il tuo supporto!", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "Stream risposta chat", "STT Model": "", "STT Settings": "Impostazioni STT", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "Sottotitolo (ad esempio sull'Impero Romano)", "Success": "Successo", "Successfully updated.": "Aggiornato con successo.", @@ -1314,5 +1316,5 @@ "Your entire contribution will go directly to the plugin developer; Open WebUI does not take any percentage. However, the chosen funding platform might have its own fees.": "Il tuo intero contributo andrà direttamente allo sviluppatore del plugin; Open WebUI non prende alcuna percentuale. Tuttavia, la piattaforma di finanziamento scelta potrebbe avere le proprie commissioni.", "Youtube": "Youtube", "Youtube Language": "Lingua Youtube", - "Youtube Proxy URL": "URL proxy Youtube", + "Youtube Proxy URL": "URL proxy Youtube" } diff --git a/src/lib/i18n/locales/ja-JP/translation.json b/src/lib/i18n/locales/ja-JP/translation.json index 9995aff6ae..6efb6a3c91 100644 --- a/src/lib/i18n/locales/ja-JP/translation.json +++ b/src/lib/i18n/locales/ja-JP/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "", "Reply in Thread": "", "Request Mode": "リクエストモード", + "Reranking Engine": "", "Reranking Model": "モデルの再ランキング", - "Reranking model disabled": "再ランキングモデルが無効です", - "Reranking model set to \"{{reranking_model}}\"": "再ランキングモデルを \"{{reranking_model}}\" に設定しました", "Reset": "", "Reset All Models": "", "Reset Upload Directory": "アップロードディレクトリをリセット", @@ -1069,6 +1068,8 @@ "Show": "表示", "Show \"What's New\" modal on login": "", "Show Admin Details in Account Pending Overlay": "", + "Show All": "", + "Show Less": "", "Show Model": "", "Show shortcuts": "表示", "Show your support!": "", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "", "STT Model": "STTモデル", "STT Settings": "STT設定", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "タイトル (例: ローマ帝国)", "Success": "成功", "Successfully updated.": "正常に更新されました。", diff --git a/src/lib/i18n/locales/ka-GE/translation.json b/src/lib/i18n/locales/ka-GE/translation.json index 48a68bfe98..b9772e8c48 100644 --- a/src/lib/i18n/locales/ka-GE/translation.json +++ b/src/lib/i18n/locales/ka-GE/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "", "Reply in Thread": "ნაკადში პასუხი", "Request Mode": "მოთხოვნის რეჟიმი", + "Reranking Engine": "", "Reranking Model": "Reranking მოდელი", - "Reranking model disabled": "Reranking მოდელი გათიშულია", - "Reranking model set to \"{{reranking_model}}\"": "Reranking model set to \"{{reranking_model}}\"", "Reset": "ჩამოყრა", "Reset All Models": "", "Reset Upload Directory": "", @@ -1069,6 +1068,8 @@ "Show": "ჩვენება", "Show \"What's New\" modal on login": "", "Show Admin Details in Account Pending Overlay": "", + "Show All": "", + "Show Less": "", "Show Model": "", "Show shortcuts": "მალსახმობების ჩვენება", "Show your support!": "", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "", "STT Model": "", "STT Settings": "STT-ის მორგება", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "სუბტიტრები (მაგ. რომის იმპერიის შესახებ)", "Success": "წარმატება", "Successfully updated.": "წარმატებით განახლდა.", diff --git a/src/lib/i18n/locales/ko-KR/translation.json b/src/lib/i18n/locales/ko-KR/translation.json index d4198d4b5a..efb6c57744 100644 --- a/src/lib/i18n/locales/ko-KR/translation.json +++ b/src/lib/i18n/locales/ko-KR/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "", "Reply in Thread": "스레드에 답글 달기", "Request Mode": "요청 모드", + "Reranking Engine": "", "Reranking Model": "Reranking 모델", - "Reranking model disabled": "Reranking 모델 비활성화", - "Reranking model set to \"{{reranking_model}}\"": "Reranking 모델을 \"{{reranking_model}}\"로 설정", "Reset": "초기화", "Reset All Models": "모든 모델 초기화", "Reset Upload Directory": "업로드 디렉토리 초기화", @@ -1069,6 +1068,8 @@ "Show": "보기", "Show \"What's New\" modal on login": "로그인시 \"새로운 기능\" 모달 보기", "Show Admin Details in Account Pending Overlay": "사용자용 계정 보류 설명창에, 관리자 상세 정보 노출", + "Show All": "", + "Show Less": "", "Show Model": "", "Show shortcuts": "단축키 보기", "Show your support!": "당신의 응원을 보내주세요!", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "스트림 채팅 응답", "STT Model": "STT 모델", "STT Settings": "STT 설정", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "자막 (예: 로마 황제)", "Success": "성공", "Successfully updated.": "성공적으로 업데이트되었습니다.", diff --git a/src/lib/i18n/locales/lt-LT/translation.json b/src/lib/i18n/locales/lt-LT/translation.json index 9446c6676e..a4cba47ffc 100644 --- a/src/lib/i18n/locales/lt-LT/translation.json +++ b/src/lib/i18n/locales/lt-LT/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "", "Reply in Thread": "", "Request Mode": "Užklausos rėžimas", + "Reranking Engine": "", "Reranking Model": "Reranking modelis", - "Reranking model disabled": "Reranking modelis neleidžiamas", - "Reranking model set to \"{{reranking_model}}\"": "Nustatytas rereanking modelis: \"{{reranking_model}}\"", "Reset": "Atkurti", "Reset All Models": "", "Reset Upload Directory": "Atkurti įkėlimų direktoiją", @@ -1069,6 +1068,8 @@ "Show": "Rodyti", "Show \"What's New\" modal on login": "", "Show Admin Details in Account Pending Overlay": "Rodyti administratoriaus duomenis laukiant paskyros patvirtinimo", + "Show All": "", + "Show Less": "", "Show Model": "", "Show shortcuts": "Rodyti trumpinius", "Show your support!": "Palaikykite", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "", "STT Model": "STT modelis", "STT Settings": "STT nustatymai", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "Subtitras", "Success": "Sėkmingai", "Successfully updated.": "Sėkmingai atnaujinta.", diff --git a/src/lib/i18n/locales/ms-MY/translation.json b/src/lib/i18n/locales/ms-MY/translation.json index 438df17085..7c406f41f1 100644 --- a/src/lib/i18n/locales/ms-MY/translation.json +++ b/src/lib/i18n/locales/ms-MY/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "", "Reply in Thread": "", "Request Mode": "Mod Permintaan", + "Reranking Engine": "", "Reranking Model": "Model 'Reranking'", - "Reranking model disabled": "Model 'Reranking' dilumpuhkan", - "Reranking model set to \"{{reranking_model}}\"": "Model 'Reranking' ditetapkan kepada \"{{reranking_model}}\"", "Reset": "Tetapkan Semula", "Reset All Models": "", "Reset Upload Directory": "Tetapkan Semula Direktori Muat Naik", @@ -1069,6 +1068,8 @@ "Show": "Tunjukkan", "Show \"What's New\" modal on login": "", "Show Admin Details in Account Pending Overlay": "Tunjukkan Butiran Pentadbir dalam Akaun Menunggu Tindanan", + "Show All": "", + "Show Less": "", "Show Model": "", "Show shortcuts": "Tunjukkan pintasan", "Show your support!": "Tunjukkan sokongan anda!", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "", "STT Model": "Model STT", "STT Settings": "Tetapan STT", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "Sari kata (cth tentang Kesultanan Melaka)", "Success": "Berjaya", "Successfully updated.": "Berjaya Dikemaskini", diff --git a/src/lib/i18n/locales/nb-NO/translation.json b/src/lib/i18n/locales/nb-NO/translation.json index 130fb9496d..c2fbc0635e 100644 --- a/src/lib/i18n/locales/nb-NO/translation.json +++ b/src/lib/i18n/locales/nb-NO/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "Gjenta straff (Ollama)", "Reply in Thread": "Svar i tråd", "Request Mode": "Forespørselsmodus", + "Reranking Engine": "", "Reranking Model": "Omrangeringsmodell", - "Reranking model disabled": "Omrangeringsmodell deaktivert", - "Reranking model set to \"{{reranking_model}}\"": "Omrangeringsmodell er angitt til \"{{reranking_model}}\"", "Reset": "Tilbakestill", "Reset All Models": "Tilbakestill alle modeller", "Reset Upload Directory": "Tilbakestill opplastingskatalog", @@ -1069,6 +1068,8 @@ "Show": "Vis", "Show \"What's New\" modal on login": "Vis \"Hva er nytt\"-modal ved innlogging", "Show Admin Details in Account Pending Overlay": "Vis administratordetaljer i ventende kontovisning", + "Show All": "", + "Show Less": "", "Show Model": "", "Show shortcuts": "Vis snarveier", "Show your support!": "Vis din støtte!", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "Strømme chat-svar", "STT Model": "STT-modell", "STT Settings": "STT-innstillinger", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "Undertittel (f.eks. om romerriket)", "Success": "Suksess", "Successfully updated.": "Oppdatert.", diff --git a/src/lib/i18n/locales/nl-NL/translation.json b/src/lib/i18n/locales/nl-NL/translation.json index a2ceab8c79..5ed6f165bf 100644 --- a/src/lib/i18n/locales/nl-NL/translation.json +++ b/src/lib/i18n/locales/nl-NL/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "Herhalingsstraf (Ollama)", "Reply in Thread": "Antwoord in draad", "Request Mode": "Request Modus", + "Reranking Engine": "", "Reranking Model": "Reranking Model", - "Reranking model disabled": "Reranking model uitgeschakeld", - "Reranking model set to \"{{reranking_model}}\"": "Reranking model ingesteld op \"{{reranking_model}}\"", "Reset": "Herstellen", "Reset All Models": "Herstel alle modellen", "Reset Upload Directory": "Herstel Uploadmap", @@ -1069,6 +1068,8 @@ "Show": "Toon", "Show \"What's New\" modal on login": "Toon \"Wat is nieuw\" bij inloggen", "Show Admin Details in Account Pending Overlay": "Admin-details weergeven in overlay in afwachting van account", + "Show All": "", + "Show Less": "", "Show Model": "Toon model", "Show shortcuts": "Toon snelkoppelingen", "Show your support!": "Toon je steun", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "Stream chat-antwoord", "STT Model": "STT Model", "STT Settings": "STT Instellingen", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "Ondertitel (bijv. over de Romeinse Empire)", "Success": "Succes", "Successfully updated.": "Succesvol bijgewerkt.", diff --git a/src/lib/i18n/locales/pa-IN/translation.json b/src/lib/i18n/locales/pa-IN/translation.json index fb03157bde..d843775f14 100644 --- a/src/lib/i18n/locales/pa-IN/translation.json +++ b/src/lib/i18n/locales/pa-IN/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "", "Reply in Thread": "", "Request Mode": "ਬੇਨਤੀ ਮੋਡ", + "Reranking Engine": "", "Reranking Model": "ਮਾਡਲ ਮੁੜ ਰੈਂਕਿੰਗ", - "Reranking model disabled": "ਮਾਡਲ ਮੁੜ ਰੈਂਕਿੰਗ ਅਯੋਗ ਕੀਤਾ ਗਿਆ", - "Reranking model set to \"{{reranking_model}}\"": "ਮਾਡਲ ਮੁੜ ਰੈਂਕਿੰਗ ਨੂੰ \"{{reranking_model}}\" 'ਤੇ ਸੈੱਟ ਕੀਤਾ ਗਿਆ", "Reset": "", "Reset All Models": "", "Reset Upload Directory": "", @@ -1069,6 +1068,8 @@ "Show": "ਦਿਖਾਓ", "Show \"What's New\" modal on login": "", "Show Admin Details in Account Pending Overlay": "", + "Show All": "", + "Show Less": "", "Show Model": "", "Show shortcuts": "ਸ਼ਾਰਟਕਟ ਦਿਖਾਓ", "Show your support!": "", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "", "STT Model": "", "STT Settings": "STT ਸੈਟਿੰਗਾਂ", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "ਉਪਸਿਰਲੇਖ (ਉਦਾਹਰਣ ਲਈ ਰੋਮਨ ਸਾਮਰਾਜ ਬਾਰੇ)", "Success": "ਸਫਲਤਾ", "Successfully updated.": "ਸਫਲਤਾਪੂਰਵਕ ਅੱਪਡੇਟ ਕੀਤਾ ਗਿਆ।", diff --git a/src/lib/i18n/locales/pl-PL/translation.json b/src/lib/i18n/locales/pl-PL/translation.json index 7c99f677ac..346c00f549 100644 --- a/src/lib/i18n/locales/pl-PL/translation.json +++ b/src/lib/i18n/locales/pl-PL/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "Powtórzona kara (Ollama)", "Reply in Thread": "Odpowiedz w wątku", "Request Mode": "Tryb żądania", + "Reranking Engine": "", "Reranking Model": "Poprawa rankingu modelu", - "Reranking model disabled": "Ponowny ranking modeli wyłączony", - "Reranking model set to \"{{reranking_model}}\"": "Ponowny ranking modeli ustawiony na \"{{reranking_model}}\".", "Reset": "Resetuj", "Reset All Models": "Resetuj wszystkie modele", "Reset Upload Directory": "Resetuj katalog pobierania", @@ -1069,6 +1068,8 @@ "Show": "Wyświetl", "Show \"What's New\" modal on login": "Wyświetl okno dialogowe \"What's New\" podczas logowania", "Show Admin Details in Account Pending Overlay": "Wyświetl szczegóły administratora w okienu informacyjnym o potrzebie zatwierdzenia przez administratora konta użytkownika", + "Show All": "", + "Show Less": "", "Show Model": "", "Show shortcuts": "Wyświetl skróty", "Show your support!": "Wyraź swoje poparcie!", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "Strumieniowanie odpowiedzi z czatu", "STT Model": "Model STT", "STT Settings": "Ustawienia STT", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "Podtytuł (np. o Imperium Rzymskim)", "Success": "Sukces", "Successfully updated.": "Uaktualniono pomyślnie.", diff --git a/src/lib/i18n/locales/pt-BR/translation.json b/src/lib/i18n/locales/pt-BR/translation.json index 796a161277..0078ed9be7 100644 --- a/src/lib/i18n/locales/pt-BR/translation.json +++ b/src/lib/i18n/locales/pt-BR/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "", "Reply in Thread": "", "Request Mode": "Modo de Solicitação", + "Reranking Engine": "", "Reranking Model": "Modelo de Reclassificação", - "Reranking model disabled": "Modelo de Reclassificação desativado", - "Reranking model set to \"{{reranking_model}}\"": "Modelo de Reclassificação definido como \"{{reranking_model}}\"", "Reset": "Redefinir", "Reset All Models": "", "Reset Upload Directory": "Redefinir Diretório de Upload", @@ -1069,6 +1068,8 @@ "Show": "Mostrar", "Show \"What's New\" modal on login": "Mostrar \"O que há de Novo\" no login", "Show Admin Details in Account Pending Overlay": "Mostrar Detalhes do Administrador na Sobreposição de Conta Pendentes", + "Show All": "", + "Show Less": "", "Show Model": "", "Show shortcuts": "Mostrar atalhos", "Show your support!": "Mostre seu apoio!", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "Stream Resposta do Chat", "STT Model": "Modelo STT", "STT Settings": "Configurações STT", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "Subtítulo (por exemplo, sobre o Império Romano)", "Success": "Sucesso", "Successfully updated.": "Atualizado com sucesso.", diff --git a/src/lib/i18n/locales/pt-PT/translation.json b/src/lib/i18n/locales/pt-PT/translation.json index 7d5fd4c1d0..7758552d48 100644 --- a/src/lib/i18n/locales/pt-PT/translation.json +++ b/src/lib/i18n/locales/pt-PT/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "", "Reply in Thread": "", "Request Mode": "Modo de Pedido", + "Reranking Engine": "", "Reranking Model": "Modelo de Reranking", - "Reranking model disabled": "Modelo de Reranking desativado", - "Reranking model set to \"{{reranking_model}}\"": "Modelo de Reranking definido como \"{{reranking_model}}\"", "Reset": "", "Reset All Models": "", "Reset Upload Directory": "Limpar Pasta de Carregamento", @@ -1069,6 +1068,8 @@ "Show": "Mostrar", "Show \"What's New\" modal on login": "", "Show Admin Details in Account Pending Overlay": "Mostrar Detalhes do Administrador na sobreposição de Conta Pendente", + "Show All": "", + "Show Less": "", "Show Model": "", "Show shortcuts": "Mostrar atalhos", "Show your support!": "", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "", "STT Model": "Modelo STT", "STT Settings": "Configurações STT", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "Subtítulo (ex.: sobre o Império Romano)", "Success": "Sucesso", "Successfully updated.": "Atualizado com sucesso.", diff --git a/src/lib/i18n/locales/ro-RO/translation.json b/src/lib/i18n/locales/ro-RO/translation.json index 9fc741b8a7..30c95fd37d 100644 --- a/src/lib/i18n/locales/ro-RO/translation.json +++ b/src/lib/i18n/locales/ro-RO/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "", "Reply in Thread": "", "Request Mode": "Mod de Cerere", + "Reranking Engine": "", "Reranking Model": "Model de Rearanjare", - "Reranking model disabled": "Modelul de Rearanjare este dezactivat", - "Reranking model set to \"{{reranking_model}}\"": "Modelul de Rearanjare setat la \"{{reranking_model}}\"", "Reset": "Resetează", "Reset All Models": "", "Reset Upload Directory": "Resetează Directorul de Încărcare", @@ -1069,6 +1068,8 @@ "Show": "Afișează", "Show \"What's New\" modal on login": "", "Show Admin Details in Account Pending Overlay": "Afișează Detaliile Administratorului în Suprapunerea Contului În Așteptare", + "Show All": "", + "Show Less": "", "Show Model": "", "Show shortcuts": "Afișează scurtături", "Show your support!": "Arată-ți susținerea!", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "Răspuns Stream Chat", "STT Model": "Model STT", "STT Settings": "Setări STT", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "Subtitlu (de ex. despre Imperiul Roman)", "Success": "Succes", "Successfully updated.": "Actualizat cu succes.", diff --git a/src/lib/i18n/locales/ru-RU/translation.json b/src/lib/i18n/locales/ru-RU/translation.json index 2a049b9cf1..74e5e53b0e 100644 --- a/src/lib/i18n/locales/ru-RU/translation.json +++ b/src/lib/i18n/locales/ru-RU/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "Повторить наказание (Ollama)", "Reply in Thread": "Ответить в обсуждении", "Request Mode": "Режим запроса", + "Reranking Engine": "", "Reranking Model": "Модель реранжирования", - "Reranking model disabled": "Модель реранжирования отключена", - "Reranking model set to \"{{reranking_model}}\"": "Модель реранжирования установлена на \"{{reranking_model}}\"", "Reset": "Сбросить", "Reset All Models": "Сбросить все модели", "Reset Upload Directory": "Сбросить каталог загрузок", @@ -1069,6 +1068,8 @@ "Show": "Показать", "Show \"What's New\" modal on login": "Показывать окно «Что нового» при входе в систему", "Show Admin Details in Account Pending Overlay": "Показывать данные администратора в оверлее ожидающей учетной записи", + "Show All": "", + "Show Less": "", "Show Model": "Показать модель", "Show shortcuts": "Показать горячие клавиши", "Show your support!": "Поддержите нас!", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "Потоковый вывод ответа", "STT Model": "Модель распознавания речи", "STT Settings": "Настройки распознавания речи", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "Подзаголовок (напр., о Римской империи)", "Success": "Успех", "Successfully updated.": "Успешно обновлено.", diff --git a/src/lib/i18n/locales/sk-SK/translation.json b/src/lib/i18n/locales/sk-SK/translation.json index 0393e13496..a22c0dc442 100644 --- a/src/lib/i18n/locales/sk-SK/translation.json +++ b/src/lib/i18n/locales/sk-SK/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "", "Reply in Thread": "", "Request Mode": "Režim žiadosti", + "Reranking Engine": "", "Reranking Model": "Model na prehodnotenie poradia", - "Reranking model disabled": "Model na prehodnotenie poradia je deaktivovaný", - "Reranking model set to \"{{reranking_model}}\"": "Model na prehodnotenie poradia nastavený na \"{{reranking_model}}\"", "Reset": "režim Reset", "Reset All Models": "", "Reset Upload Directory": "Resetovať adresár nahrávania", @@ -1069,6 +1068,8 @@ "Show": "Zobraziť", "Show \"What's New\" modal on login": "", "Show Admin Details in Account Pending Overlay": "Zobraziť podrobnosti administrátora v prekryvnom okne s čakajúcim účtom", + "Show All": "", + "Show Less": "", "Show Model": "", "Show shortcuts": "Zobraziť klávesové skratky", "Show your support!": "Vyjadrite svoju podporu!", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "Odozva chatu Stream", "STT Model": "Model rozpoznávania reči na text (STT)", "STT Settings": "Nastavenia STT (Rozpoznávanie reči)", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "Titulky (napr. o Rímskej ríši)", "Success": "Úspech", "Successfully updated.": "Úspešne aktualizované.", diff --git a/src/lib/i18n/locales/sr-RS/translation.json b/src/lib/i18n/locales/sr-RS/translation.json index b75cadcd70..1ff5084376 100644 --- a/src/lib/i18n/locales/sr-RS/translation.json +++ b/src/lib/i18n/locales/sr-RS/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "", "Reply in Thread": "", "Request Mode": "Режим захтева", + "Reranking Engine": "", "Reranking Model": "Модел поновног рангирања", - "Reranking model disabled": "Модел поновног рангирања онемогућен", - "Reranking model set to \"{{reranking_model}}\"": "Модел поновног рангирања подешен на \"{{reranking_model}}\"", "Reset": "Поврати", "Reset All Models": "Поврати све моделе", "Reset Upload Directory": "", @@ -1069,6 +1068,8 @@ "Show": "Прикажи", "Show \"What's New\" modal on login": "Прикажи \"Погледај шта је ново\" прозорче при пријави", "Show Admin Details in Account Pending Overlay": "", + "Show All": "", + "Show Less": "", "Show Model": "", "Show shortcuts": "Прикажи пречице", "Show your support!": "", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "", "STT Model": "STT модел", "STT Settings": "STT подешавања", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "Поднаслов (нпр. о Римском царству)", "Success": "Успех", "Successfully updated.": "Успешно ажурирано.", diff --git a/src/lib/i18n/locales/sv-SE/translation.json b/src/lib/i18n/locales/sv-SE/translation.json index 6565fc5f7e..d8413d42f1 100644 --- a/src/lib/i18n/locales/sv-SE/translation.json +++ b/src/lib/i18n/locales/sv-SE/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "", "Reply in Thread": "", "Request Mode": "Frågeläge", + "Reranking Engine": "", "Reranking Model": "Reranking modell", - "Reranking model disabled": "Reranking modell inaktiverad", - "Reranking model set to \"{{reranking_model}}\"": "Reranking modell inställd på \"{{reranking_model}}\"", "Reset": "", "Reset All Models": "", "Reset Upload Directory": "Återställ uppladdningskatalog", @@ -1069,6 +1068,8 @@ "Show": "Visa", "Show \"What's New\" modal on login": "", "Show Admin Details in Account Pending Overlay": "Visa administratörsinformation till väntande konton", + "Show All": "", + "Show Less": "", "Show Model": "", "Show shortcuts": "Visa genvägar", "Show your support!": "Visa ditt stöd!", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "", "STT Model": "Tal-till-text-modell", "STT Settings": "Tal-till-text-inställningar", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "Undertext (t.ex. om Romerska Imperiet)", "Success": "Framgång", "Successfully updated.": "Uppdaterades framgångsrikt.", diff --git a/src/lib/i18n/locales/th-TH/translation.json b/src/lib/i18n/locales/th-TH/translation.json index 8d4fc86a68..9af6f484fb 100644 --- a/src/lib/i18n/locales/th-TH/translation.json +++ b/src/lib/i18n/locales/th-TH/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "", "Reply in Thread": "", "Request Mode": "โหมดคำขอ", + "Reranking Engine": "", "Reranking Model": "จัดอันดับใหม่โมเดล", - "Reranking model disabled": "ปิดการใช้งานโมเดลการจัดอันดับใหม่", - "Reranking model set to \"{{reranking_model}}\"": "ตั้งค่าโมเดลการจัดอันดับใหม่เป็น \"{{reranking_model}}\"", "Reset": "รีเซ็ต", "Reset All Models": "", "Reset Upload Directory": "รีเซ็ตไดเร็กทอรีการอัปโหลด", @@ -1069,6 +1068,8 @@ "Show": "แสดง", "Show \"What's New\" modal on login": "", "Show Admin Details in Account Pending Overlay": "แสดงรายละเอียดผู้ดูแลระบบในหน้าจอรอการอนุมัติบัญชี", + "Show All": "", + "Show Less": "", "Show Model": "", "Show shortcuts": "แสดงทางลัด", "Show your support!": "แสดงการสนับสนุนของคุณ!", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "", "STT Model": "โมเดลแปลงเสียงเป็นข้อความ", "STT Settings": "การตั้งค่าแปลงเสียงเป็นข้อความ", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "คำบรรยาย (เช่น เกี่ยวกับจักรวรรดิโรมัน)", "Success": "สำเร็จ", "Successfully updated.": "อัปเดตเรียบร้อยแล้ว", diff --git a/src/lib/i18n/locales/tk-TW/translation.json b/src/lib/i18n/locales/tk-TW/translation.json index 363afaaf7c..190ce78fb4 100644 --- a/src/lib/i18n/locales/tk-TW/translation.json +++ b/src/lib/i18n/locales/tk-TW/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "", "Reply in Thread": "", "Request Mode": "", + "Reranking Engine": "", "Reranking Model": "", - "Reranking model disabled": "", - "Reranking model set to \"{{reranking_model}}\"": "", "Reset": "", "Reset All Models": "", "Reset Upload Directory": "", @@ -1069,6 +1068,8 @@ "Show": "", "Show \"What's New\" modal on login": "", "Show Admin Details in Account Pending Overlay": "", + "Show All": "", + "Show Less": "", "Show Model": "", "Show shortcuts": "", "Show your support!": "", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "", "STT Model": "", "STT Settings": "", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "", "Success": "", "Successfully updated.": "", diff --git a/src/lib/i18n/locales/tr-TR/translation.json b/src/lib/i18n/locales/tr-TR/translation.json index 1b4d25f4ca..6ddfae5868 100644 --- a/src/lib/i18n/locales/tr-TR/translation.json +++ b/src/lib/i18n/locales/tr-TR/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "", "Reply in Thread": "Konuya Yanıtla", "Request Mode": "İstek Modu", + "Reranking Engine": "", "Reranking Model": "Yeniden Sıralama Modeli", - "Reranking model disabled": "Yeniden sıralama modeli devre dışı bırakıldı", - "Reranking model set to \"{{reranking_model}}\"": "Yeniden sıralama modeli \"{{reranking_model}}\" olarak ayarlandı", "Reset": "Sıfırla", "Reset All Models": "Tüm Modelleri Sıfırla", "Reset Upload Directory": "Yükleme Dizinini Sıfırla", @@ -1069,6 +1068,8 @@ "Show": "Göster", "Show \"What's New\" modal on login": "Girişte \"Yenilikler\" modalını göster", "Show Admin Details in Account Pending Overlay": "Yönetici Ayrıntılarını Hesap Bekliyor Ekranında Göster", + "Show All": "", + "Show Less": "", "Show Model": "", "Show shortcuts": "Kısayolları göster", "Show your support!": "Desteğinizi gösterin!", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "SAkış Sohbet Yanıtı", "STT Model": "STT Modeli", "STT Settings": "STT Ayarları", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "Alt başlık (örn. Roma İmparatorluğu hakkında)", "Success": "Başarılı", "Successfully updated.": "Başarıyla güncellendi.", diff --git a/src/lib/i18n/locales/uk-UA/translation.json b/src/lib/i18n/locales/uk-UA/translation.json index 851b9cc32b..4b29c3b3a5 100644 --- a/src/lib/i18n/locales/uk-UA/translation.json +++ b/src/lib/i18n/locales/uk-UA/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "Штраф за повторення (Ollama)", "Reply in Thread": "Відповісти в потоці", "Request Mode": "Режим запиту", + "Reranking Engine": "", "Reranking Model": "Модель переранжування", - "Reranking model disabled": "Модель переранжування вимкнена", - "Reranking model set to \"{{reranking_model}}\"": "Модель переранжування встановлено на \"{{reranking_model}}\"", "Reset": "Скидання", "Reset All Models": "Скинути усі моделі", "Reset Upload Directory": "Скинути каталог завантажень", @@ -1069,6 +1068,8 @@ "Show": "Показати", "Show \"What's New\" modal on login": "Показати модальне вікно \"Що нового\" під час входу", "Show Admin Details in Account Pending Overlay": "Відобразити дані адміна у вікні очікування облікового запису", + "Show All": "", + "Show Less": "", "Show Model": "Показати модель", "Show shortcuts": "Показати клавіатурні скорочення", "Show your support!": "Підтримайте нас!", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "Відповідь стрім-чату", "STT Model": "Модель STT ", "STT Settings": "Налаштування STT", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "Підзаголовок (напр., про Римську імперію)", "Success": "Успіх", "Successfully updated.": "Успішно оновлено.", diff --git a/src/lib/i18n/locales/ur-PK/translation.json b/src/lib/i18n/locales/ur-PK/translation.json index f49abcc18f..8c66931ef4 100644 --- a/src/lib/i18n/locales/ur-PK/translation.json +++ b/src/lib/i18n/locales/ur-PK/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "", "Reply in Thread": "", "Request Mode": "درخواست کا موڈ", + "Reranking Engine": "", "Reranking Model": "دوبارہ درجہ بندی کا ماڈل", - "Reranking model disabled": "دوبارہ درجہ بندی کا ماڈل غیر فعال کر دیا گیا", - "Reranking model set to \"{{reranking_model}}\"": "دوبارہ درجہ بندی کا ماڈل \"{{reranking_model}}\" پر مقرر کر دیا گیا ہے", "Reset": "ری سیٹ", "Reset All Models": "", "Reset Upload Directory": "اپلوڈ ڈائریکٹری کو ری سیٹ کریں", @@ -1069,6 +1068,8 @@ "Show": "دکھائیں", "Show \"What's New\" modal on login": "", "Show Admin Details in Account Pending Overlay": "اکاؤنٹ پینڈنگ اوورلے میں ایڈمن کی تفصیلات دکھائیں", + "Show All": "", + "Show Less": "", "Show Model": "", "Show shortcuts": "شارٹ کٹ دکھائیں", "Show your support!": "اپنی حمایت دکھائیں!", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "اسٹریم چیٹ جواب", "STT Model": "ایس ٹی ٹی ماڈل", "STT Settings": "ایس ٹی ٹی ترتیبات", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "ذیلی عنوان (جیسے رومن سلطنت کے بارے میں)", "Success": "کامیابی", "Successfully updated.": "کامیابی سے تازہ کاری ہو گئی", diff --git a/src/lib/i18n/locales/vi-VN/translation.json b/src/lib/i18n/locales/vi-VN/translation.json index b4a9204785..05f8dd2eb0 100644 --- a/src/lib/i18n/locales/vi-VN/translation.json +++ b/src/lib/i18n/locales/vi-VN/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "Hình phạt Lặp lại (Ollama)", "Reply in Thread": "Trả lời trong Luồng", "Request Mode": "Chế độ Yêu cầu", + "Reranking Engine": "", "Reranking Model": "Reranking Model", - "Reranking model disabled": "Đã tắt mô hình reranking", - "Reranking model set to \"{{reranking_model}}\"": "Reranking model được đặt thành \"{{reranking_model}}\"", "Reset": "Xóa toàn bộ", "Reset All Models": "Đặt lại Tất cả Mô hình", "Reset Upload Directory": "Xóa toàn bộ thư mục Upload", @@ -1069,6 +1068,8 @@ "Show": "Hiển thị", "Show \"What's New\" modal on login": "Hiển thị cửa sổ \"Có gì mới\" khi đăng nhập", "Show Admin Details in Account Pending Overlay": "Hiển thị thông tin của Quản trị viên trên màn hình hiển thị Tài khoản đang chờ xử lý", + "Show All": "", + "Show Less": "", "Show Model": "Hiển thị Mô hình", "Show shortcuts": "Hiển thị phím tắt", "Show your support!": "Thể hiện sự ủng hộ của bạn!", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "Truyền trực tiếp Phản hồi Chat", "STT Model": "Mô hình STT", "STT Settings": "Cài đặt Nhận dạng Giọng nói", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "Phụ đề (ví dụ: về Đế chế La Mã)", "Success": "Thành công", "Successfully updated.": "Đã cập nhật thành công.", diff --git a/src/lib/i18n/locales/zh-CN/translation.json b/src/lib/i18n/locales/zh-CN/translation.json index df00810f89..d25166f1d3 100644 --- a/src/lib/i18n/locales/zh-CN/translation.json +++ b/src/lib/i18n/locales/zh-CN/translation.json @@ -4,7 +4,7 @@ "(e.g. `sh webui.sh --api --api-auth username_password`)": "(例如 `sh webui.sh --api --api-auth username_password`)", "(e.g. `sh webui.sh --api`)": "(例如 `sh webui.sh --api`)", "(latest)": "(最新版)", - "(leave blank for Azure Commercial URL auto-generation)": "(留空以便 Azure Commercial URL 自动生成)", + "(leave blank for to use commercial endpoint)": "", "(Ollama)": "(Ollama)", "{{ models }}": "{{ models }}", "{{COUNT}} Available Tools": "{{COUNT}} 个可用工具", @@ -140,7 +140,6 @@ "Bad Response": "点踩此回答", "Banners": "公告横幅", "Base Model (From)": "基础模型 (来自)", - "Base URL": "基础 URL", "Batch Size (num_batch)": "批大小 (num_batch)", "before": "对话", "Being lazy": "懒惰", @@ -960,9 +959,8 @@ "Repeat Penalty (Ollama)": "重复惩罚 (Ollama)", "Reply in Thread": "在主题中回复", "Request Mode": "请求模式", + "Reranking Engine": "", "Reranking Model": "重排模型", - "Reranking model disabled": "重排模型已禁用", - "Reranking model set to \"{{reranking_model}}\"": "重排模型设置为 \"{{reranking_model}}\"", "Reset": "重置", "Reset All Models": "重置所有模型", "Reset Upload Directory": "重置上传目录", @@ -1070,6 +1068,8 @@ "Show": "显示", "Show \"What's New\" modal on login": "在登录时显示“更新内容”弹窗", "Show Admin Details in Account Pending Overlay": "在用户待激活界面中显示管理员邮箱等详细信息", + "Show All": "", + "Show Less": "", "Show Model": "显示模型", "Show shortcuts": "显示快捷方式", "Show your support!": "表达你的支持!", @@ -1093,6 +1093,7 @@ "Stream Chat Response": "以流式返回对话响应", "STT Model": "语音转文本模型", "STT Settings": "语音转文本设置", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "副标题(例如:关于罗马帝国的副标题)", "Success": "成功", "Successfully updated.": "成功更新。", diff --git a/src/lib/i18n/locales/zh-TW/translation.json b/src/lib/i18n/locales/zh-TW/translation.json index 6ca49ce76d..5246307c90 100644 --- a/src/lib/i18n/locales/zh-TW/translation.json +++ b/src/lib/i18n/locales/zh-TW/translation.json @@ -959,9 +959,8 @@ "Repeat Penalty (Ollama)": "重複懲罰 (Ollama)", "Reply in Thread": "在討論串中回覆", "Request Mode": "請求模式", + "Reranking Engine": "", "Reranking Model": "重新排序模型", - "Reranking model disabled": "已停用重新排序模型", - "Reranking model set to \"{{reranking_model}}\"": "重新排序模型已設定為 \"{{reranking_model}}\"", "Reset": "重設", "Reset All Models": "重設所有模型", "Reset Upload Directory": "重設上傳目錄", @@ -1069,6 +1068,8 @@ "Show": "顯示", "Show \"What's New\" modal on login": "登入時顯示「新功能」對話框", "Show Admin Details in Account Pending Overlay": "在帳號待審覆蓋層中顯示管理員詳細資訊", + "Show All": "", + "Show Less": "", "Show Model": "顯示模型", "Show shortcuts": "顯示快捷鍵", "Show your support!": "表達您的支持!", @@ -1092,6 +1093,7 @@ "Stream Chat Response": "串流式對話回應", "STT Model": "語音轉文字 (STT) 模型", "STT Settings": "語音轉文字 (STT) 設定", + "Stylized PDF Export": "", "Subtitle (e.g. about the Roman Empire)": "副標題(例如:關於羅馬帝國)", "Success": "成功", "Successfully updated.": "更新成功。", diff --git a/src/lib/utils/onedrive-file-picker.ts b/src/lib/utils/onedrive-file-picker.ts index 59ac524734..7840ee869d 100644 --- a/src/lib/utils/onedrive-file-picker.ts +++ b/src/lib/utils/onedrive-file-picker.ts @@ -40,7 +40,7 @@ class OneDriveConfig { headers, credentials: 'include' }); - + if (!response.ok) { throw new Error('Failed to fetch OneDrive credentials'); } @@ -66,9 +66,10 @@ class OneDriveConfig { await this.ensureInitialized(authorityType); if (!this.msalInstance) { - const authorityEndpoint = this.currentAuthorityType === 'organizations' - ? (this.sharepointTenantId || 'common') - : 'consumers'; + const authorityEndpoint = + this.currentAuthorityType === 'organizations' + ? this.sharepointTenantId || 'common' + : 'consumers'; const msalParams = { auth: { authority: `https://login.microsoftonline.com/${authorityEndpoint}`, From 1c665592e4d716f883ff1ec9ba54c759e27f9624 Mon Sep 17 00:00:00 2001 From: Timothy Jaeryang Baek Date: Sat, 10 May 2025 19:01:12 +0400 Subject: [PATCH 71/75] chore: bump --- package-lock.json | 4 ++-- package.json | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/package-lock.json b/package-lock.json index 52b9724d9a..de4902c16f 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,12 +1,12 @@ { "name": "open-webui", - "version": "0.6.7", + "version": "0.6.8", "lockfileVersion": 3, "requires": true, "packages": { "": { "name": "open-webui", - "version": "0.6.7", + "version": "0.6.8", "dependencies": { "@azure/msal-browser": "^4.5.0", "@codemirror/lang-javascript": "^6.2.2", diff --git a/package.json b/package.json index f5e6571527..7fa6ac5a5f 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "open-webui", - "version": "0.6.7", + "version": "0.6.8", "private": true, "scripts": { "dev": "npm run pyodide:fetch && vite dev --host", From 549989e9ec2babff7156a5515b6085d4abe79a98 Mon Sep 17 00:00:00 2001 From: Timothy Jaeryang Baek Date: Sat, 10 May 2025 19:04:40 +0400 Subject: [PATCH 72/75] refac --- backend/open_webui/routers/audio.py | 1 - 1 file changed, 1 deletion(-) diff --git a/backend/open_webui/routers/audio.py b/backend/open_webui/routers/audio.py index a810cc586c..445857c88e 100644 --- a/backend/open_webui/routers/audio.py +++ b/backend/open_webui/routers/audio.py @@ -544,7 +544,6 @@ def transcribe(request: Request, file_path): elif request.app.state.config.STT_ENGINE == "openai": convert_format = get_audio_convert_format(file_path) - print(f"convert_format: {convert_format}") if convert_format: ext = convert_format.split(".")[-1] From 6f635d8b7dcc56ad54f651038f24a5220f0b1053 Mon Sep 17 00:00:00 2001 From: Timothy Jaeryang Baek Date: Sat, 10 May 2025 19:16:09 +0400 Subject: [PATCH 73/75] refac --- backend/open_webui/routers/retrieval.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/backend/open_webui/routers/retrieval.py b/backend/open_webui/routers/retrieval.py index 26a26c7eca..efefa12fcd 100644 --- a/backend/open_webui/routers/retrieval.py +++ b/backend/open_webui/routers/retrieval.py @@ -1607,7 +1607,7 @@ async def process_web_search( urls = [] try: logging.info( - f"trying to web search with {request.app.state.config.WEB_SEARCH_ENGINE, form_data.query}" + f"trying to web search with {request.app.state.config.WEB_SEARCH_ENGINE, form_data.queries}" ) search_tasks = [ From b81a5833c74646929f43200ccfa3c98c94d5121c Mon Sep 17 00:00:00 2001 From: Timothy Jaeryang Baek Date: Sat, 10 May 2025 19:25:42 +0400 Subject: [PATCH 74/75] doc: changelog --- CHANGELOG.md | 35 +++++++++++++++++++++++++++++++++++ 1 file changed, 35 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index 5c0c4de1ad..ff848e33aa 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -5,6 +5,41 @@ 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/), and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html). +## [0.6.8] - 2025-05-10 + +### Added + +- 🏆 **External Reranker Support for Knowledge Base Search**: Supercharge your Retrieval-Augmented Generation (RAG) workflows with the new External Reranker integration; easily plug in advanced reranking services via the UI to deliver sharper and more relevant search results, accelerating research and insight discovery. +- 📤 **Unstylized PDF Export Option (Reduced File Size)**: When exporting chat transcripts or documents, you can now choose an unstylized PDF export for snappier downloads, minimal file size, and clean data archiving—perfect for large-scale storage or sharing. +- 📝 **Vazirmatn Font for Persian & Arabic**: Arabic and Persian users will now see their text beautifully rendered with the specialized Vazirmatn font for an improved localized reading experience. +- 🏷️ **SharePoint Tenant ID Support for OneDrive**: You can now specify a SharePoint tenant ID in OneDrive settings for seamless authentication and granular enterprise integration. +- 👤 **Refresh OAuth Profile Picture**: Your OAuth profile picture now updates in real-time, ensuring your presence and avatar always match your latest identity across integrated platforms. +- 🔧 **Milvus Configuration Improvements**: Configure index and metric types for Milvus directly within settings; take full control of your vector database for more accurate and robust AI search experiences. +- 🛡️ **S3 Tagging Toggle for Compatibility**: Optional S3 tagging via an environment toggle grants full compatibility with all storage backends—including those that don’t support tagging like Cloudflare R2—ensuring error-free attachment and document management. +- 👨‍🦯 **Icon Button Accessibility Improvements**: Key interactive icon-buttons now include aria-labels and ARIA descriptions, so screen readers provide precise guidance about what action each button performs for improved accessibility. +- ♿ **Enhanced Accessibility with Modal Focus Trap**: Modal dialogs and pop-ups now feature a focus trap and improved ARIA roles, ensuring seamless navigation and screen reader support—making the interface friendlier for everyone, including keyboard and assistive tech users. +- 🏃 **Improved Admin User List Loading Indicator**: The user list loading experience is now clearer and more responsive in the admin panel. +- 🧑‍🤝‍🧑 **Larger Admin User List Page Size**: Admins can now manage up to 30 users per page in the admin interface, drastically reducing pagination and making large user teams easier and faster to manage. +- 🌠 **Default Code Interpreter Prompt Clarified**: The built-in code interpreter prompt is now more explicit, preventing AI from wrapping code in Markdown blocks when not needed—ensuring properly formatted code runs as intended every time. +- 🧾 **Improved Default Title Generation Prompt Template**: Title generation now uses a robust template for reliable JSON output, improving chat organization and searchability. +- 🔗 **Support Jupyter Notebooks with Non-Root Base URLs**: Notebook-based code execution now supports non-root deployed Jupyter servers, granting full flexibility for hybrid or multi-user setups. +- 📰 **UI Scrollbar Always Visible for Overflow Tools**: When available tools overflow the display, the scrollbar is now always visible and there’s a handy "show all" toggle, making navigation of large toolsets snappier and more intuitive. +- 🛠️ **General Backend Refactoring for Stability**: Multiple under-the-hood improvements have been made across backend components, ensuring smoother performance, fewer errors, and a more reliable overall experience for all users. +- 🚀 **Optimized Web Search for Faster Results**: Web search speed and performance have been significantly enhanced, delivering answers and sources in record time to accelerate your research-heavy workflows. +- 💡 **More Supported Languages**: Expanded language support ensures an even wider range of users can enjoy an intuitive and natural interface in their native tongue. + +### Fixed + +- 🏃‍♂️ **Exhausting Workers in Nginx Reverse Proxy Due to Websocket Fix**: Websocket sessions are now fully compatible behind Nginx, eliminating worker exhaustion and restoring 24/7 reliability for real-time chats even in complex deployments. +- 🎤 **Audio Transcription Issue with OpenAI Resolved**: OpenAI-based audio transcription now handles WebM and newer formats without error, ensuring seamless voice-to-text workflows every time. +- 👉 **Message Input RTL Issue Fixed**: The chat message input now displays correctly for right-to-left languages, creating a flawless typing and reading experience for Arabic, Hebrew, and more. +- 🀄 **Katex: Proper Rendering of Chinese Characters Next to Math**: Math formulas now render perfectly even when directly adjacent to Chinese (CJK) characters, improving visual clarity for multilingual teams and cross-language documents. +- 🔂 **Duplicate Web Search URLs Eliminated**: Search results now reliably filter out URL duplicates, so your knowledge and search citations are always clean, trimmed, and easy to review. +- 📄 **Markdown Rendering Fixed in Knowledge Bases**: Markdown is now displayed correctly within knowledge bases, enabling better formatting and clarity of information-rich files. +- 🧮 **Correct Handling for Milvus Index Type in Standalone Mode**: Search and indexing now work seamlessly in all Milvus environments, whether running as a standalone instance or clustered. +- 🗂️ **LDAP Import/Loading Issue Resolved**: LDAP user imports process correctly, ensuring smooth onboarding and access without interruption. +- 🌎 **Pinecone Batch Operations and Async Safety**: All Pinecone operations (batch insert, upsert, delete) now run efficiently and safely in an async environment, boosting performance and preventing slowdowns in large-scale RAG jobs. + ## [0.6.7] - 2025-05-07 ### Added From 32b27749ef3cb8ef10ba9419a453517ade49ef23 Mon Sep 17 00:00:00 2001 From: Timothy Jaeryang Baek Date: Sat, 10 May 2025 19:29:02 +0400 Subject: [PATCH 75/75] Update CHANGELOG.md --- CHANGELOG.md | 1 - 1 file changed, 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index ff848e33aa..acb280f5f1 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -36,7 +36,6 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 - 🀄 **Katex: Proper Rendering of Chinese Characters Next to Math**: Math formulas now render perfectly even when directly adjacent to Chinese (CJK) characters, improving visual clarity for multilingual teams and cross-language documents. - 🔂 **Duplicate Web Search URLs Eliminated**: Search results now reliably filter out URL duplicates, so your knowledge and search citations are always clean, trimmed, and easy to review. - 📄 **Markdown Rendering Fixed in Knowledge Bases**: Markdown is now displayed correctly within knowledge bases, enabling better formatting and clarity of information-rich files. -- 🧮 **Correct Handling for Milvus Index Type in Standalone Mode**: Search and indexing now work seamlessly in all Milvus environments, whether running as a standalone instance or clustered. - 🗂️ **LDAP Import/Loading Issue Resolved**: LDAP user imports process correctly, ensuring smooth onboarding and access without interruption. - 🌎 **Pinecone Batch Operations and Async Safety**: All Pinecone operations (batch insert, upsert, delete) now run efficiently and safely in an async environment, boosting performance and preventing slowdowns in large-scale RAG jobs.