Commit df47c496 authored by Jonathan Rohde's avatar Jonathan Rohde
Browse files

Merge branch 'refs/heads/dev' into feat/sqlalchemy-instead-of-peewee

# Conflicts:
#	backend/apps/webui/models/functions.py
#	backend/apps/webui/routers/chats.py
parents 827b1e58 cd9170ed
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
import { v4 as uuidv4 } from 'uuid'; import { v4 as uuidv4 } from 'uuid';
import { toast } from 'svelte-sonner'; import { toast } from 'svelte-sonner';
import { goto } from '$app/navigation'; import { goto } from '$app/navigation';
import { settings, user, config, models, tools } from '$lib/stores'; import { settings, user, config, models, tools, functions } from '$lib/stores';
import TurndownService from 'turndown'; import TurndownService from 'turndown';
...@@ -17,6 +17,7 @@ ...@@ -17,6 +17,7 @@
import ToolsSelector from '$lib/components/workspace/Models/ToolsSelector.svelte'; import ToolsSelector from '$lib/components/workspace/Models/ToolsSelector.svelte';
import { stringify } from 'postcss'; import { stringify } from 'postcss';
import { parseFile } from '$lib/utils/characters'; import { parseFile } from '$lib/utils/characters';
import FiltersSelector from '$lib/components/workspace/Models/FiltersSelector.svelte';
const i18n = getContext('i18n'); const i18n = getContext('i18n');
...@@ -61,6 +62,7 @@ ...@@ -61,6 +62,7 @@
let toolIds = []; let toolIds = [];
let knowledge = []; let knowledge = [];
let filterIds = [];
$: if (name) { $: if (name) {
id = name id = name
...@@ -105,6 +107,14 @@ ...@@ -105,6 +107,14 @@
} }
} }
if (filterIds.length > 0) {
info.meta.filterIds = filterIds;
} else {
if (info.meta.filterIds) {
delete info.meta.filterIds;
}
}
info.params.stop = params.stop ? params.stop.split(',').filter((s) => s.trim()) : null; info.params.stop = params.stop ? params.stop.split(',').filter((s) => s.trim()) : null;
Object.keys(info.params).forEach((key) => { Object.keys(info.params).forEach((key) => {
if (info.params[key] === '' || info.params[key] === null) { if (info.params[key] === '' || info.params[key] === null) {
...@@ -173,6 +183,10 @@ ...@@ -173,6 +183,10 @@
capabilities = { ...capabilities, ...(model?.info?.meta?.capabilities ?? {}) }; capabilities = { ...capabilities, ...(model?.info?.meta?.capabilities ?? {}) };
toolIds = model?.info?.meta?.toolIds ?? []; toolIds = model?.info?.meta?.toolIds ?? [];
if (model?.info?.meta?.filterIds) {
filterIds = [...model?.info?.meta?.filterIds];
}
info = { info = {
...info, ...info,
...model.info ...model.info
...@@ -604,6 +618,13 @@ ...@@ -604,6 +618,13 @@
<ToolsSelector bind:selectedToolIds={toolIds} tools={$tools} /> <ToolsSelector bind:selectedToolIds={toolIds} tools={$tools} />
</div> </div>
<div class="my-2">
<FiltersSelector
bind:selectedFilterIds={filterIds}
filters={$functions.filter((func) => func.type === 'filter')}
/>
</div>
<div class="my-1"> <div class="my-1">
<div class="flex w-full justify-between mb-1"> <div class="flex w-full justify-between mb-1">
<div class=" self-center text-sm font-semibold">{$i18n.t('Capabilities')}</div> <div class=" self-center text-sm font-semibold">{$i18n.t('Capabilities')}</div>
......
...@@ -45,6 +45,10 @@ ...@@ -45,6 +45,10 @@
console.log(tool); console.log(tool);
}); });
if (window.opener ?? false) {
window.opener.postMessage('loaded', '*');
}
if (sessionStorage.tool) { if (sessionStorage.tool) {
tool = JSON.parse(sessionStorage.tool); tool = JSON.parse(sessionStorage.tool);
sessionStorage.removeItem('tool'); sessionStorage.removeItem('tool');
...@@ -58,14 +62,16 @@ ...@@ -58,14 +62,16 @@
</script> </script>
{#if mounted} {#if mounted}
<ToolkitEditor {#key tool?.content}
id={tool?.id ?? ''} <ToolkitEditor
name={tool?.name ?? ''} id={tool?.id ?? ''}
meta={tool?.meta ?? { description: '' }} name={tool?.name ?? ''}
content={tool?.content ?? ''} meta={tool?.meta ?? { description: '' }}
{clone} content={tool?.content ?? ''}
on:save={(e) => { {clone}
saveHandler(e.detail); on:save={(e) => {
}} saveHandler(e.detail);
/> }}
/>
{/key}
{/if} {/if}
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment