open-webui/src/lib/components/chat/Settings/Tools/Connection.svelte

88 lines
2.1 KiB
Svelte
Raw Normal View History

<script lang="ts">
import { getContext, tick } from 'svelte';
const i18n = getContext('i18n');
import Tooltip from '$lib/components/common/Tooltip.svelte';
import SensitiveInput from '$lib/components/common/SensitiveInput.svelte';
import Cog6 from '$lib/components/icons/Cog6.svelte';
import ConfirmDialog from '$lib/components/common/ConfirmDialog.svelte';
2025-09-23 06:03:26 +00:00
import AddToolServerModal from '$lib/components/AddToolServerModal.svelte';
export let onDelete = () => {};
export let onSubmit = () => {};
2025-04-03 03:42:23 +00:00
export let connection = null;
2025-04-05 10:05:52 +00:00
export let direct = false;
let showConfigModal = false;
let showDeleteConfirmDialog = false;
</script>
2025-09-23 06:03:26 +00:00
<AddToolServerModal
edit
2025-04-05 10:40:01 +00:00
{direct}
bind:show={showConfigModal}
2025-04-03 03:42:23 +00:00
{connection}
onDelete={() => {
showDeleteConfirmDialog = true;
}}
2025-04-03 03:42:23 +00:00
onSubmit={(c) => {
connection = c;
onSubmit(c);
}}
/>
<ConfirmDialog
bind:show={showDeleteConfirmDialog}
on:confirm={() => {
onDelete();
showConfigModal = false;
}}
/>
<div class="flex w-full gap-2 items-center">
<Tooltip
className="w-full relative"
2025-04-05 10:05:52 +00:00
content={$i18n.t(`WebUI will make requests to "{{url}}"`, {
url: `${connection?.url}/${connection?.path ?? 'openapi.json'}`
})}
placement="top-start"
>
<div class="flex w-full">
<div class="flex-1 relative">
<input
2025-09-22 18:46:47 +00:00
class=" outline-hidden w-full bg-transparent {!(connection?.config?.enable ?? true)
? 'opacity-50'
: ''}"
placeholder={$i18n.t('API Base URL')}
2025-04-03 03:42:23 +00:00
bind:value={connection.url}
autocomplete="off"
/>
</div>
2025-04-03 03:42:23 +00:00
{#if (connection?.auth_type ?? 'bearer') === 'bearer'}
<SensitiveInput
inputClassName=" outline-hidden bg-transparent w-full"
placeholder={$i18n.t('API Key')}
bind:value={connection.key}
required={false}
/>
{/if}
</div>
</Tooltip>
<div class="flex gap-1">
<Tooltip content={$i18n.t('Configure')} className="self-start">
<button
class="self-center p-1 bg-transparent hover:bg-gray-100 dark:bg-gray-900 dark:hover:bg-gray-850 rounded-lg transition"
on:click={() => {
showConfigModal = true;
}}
type="button"
>
<Cog6 />
</button>
</Tooltip>
</div>
</div>