|
@@ -5,6 +5,7 @@
|
|
|
import { documents, models } from '$lib/stores';
|
|
|
import { onMount, getContext } from 'svelte';
|
|
|
import { toast } from 'svelte-sonner';
|
|
|
+ import SensitiveInput from '$lib/components/common/SensitiveInput.svelte';
|
|
|
|
|
|
const i18n = getContext('i18n');
|
|
|
|
|
@@ -22,7 +23,6 @@
|
|
|
'tavily',
|
|
|
'jina'
|
|
|
];
|
|
|
- let showApiKey = false;
|
|
|
|
|
|
let youtubeLanguage = 'en';
|
|
|
let youtubeTranslation = null;
|
|
@@ -116,56 +116,7 @@
|
|
|
{$i18n.t('Google PSE API Key')}
|
|
|
</div>
|
|
|
|
|
|
- <div class="flex w-full">
|
|
|
- <div class="flex-1 flex">
|
|
|
- <input
|
|
|
- class="w-full rounded-l-lg py-2 pl-4 text-sm dark:text-gray-300 dark:bg-gray-850 outline-none"
|
|
|
- placeholder={$i18n.t('Enter Google PSE API Key')}
|
|
|
- bind:value={webConfig.search.google_pse_api_key}
|
|
|
- autocomplete="off"
|
|
|
- {...{ type: showApiKey ? 'text' : 'password' }}
|
|
|
- />
|
|
|
- <button
|
|
|
- class="px-2 transition rounded-r-lg bg-white dark:bg-gray-850"
|
|
|
- on:click={(e) => {
|
|
|
- e.preventDefault();
|
|
|
- showApiKey = !showApiKey;
|
|
|
- }}
|
|
|
- >
|
|
|
- {#if showApiKey}
|
|
|
- <svg
|
|
|
- xmlns="http://www.w3.org/2000/svg"
|
|
|
- viewBox="0 0 16 16"
|
|
|
- fill="currentColor"
|
|
|
- class="w-4 h-4"
|
|
|
- >
|
|
|
- <path
|
|
|
- fill-rule="evenodd"
|
|
|
- d="M3.28 2.22a.75.75 0 0 0-1.06 1.06l10.5 10.5a.75.75 0 1 0 1.06-1.06l-1.322-1.323a7.012 7.012 0 0 0 2.16-3.11.87.87 0 0 0 0-.567A7.003 7.003 0 0 0 4.82 3.76l-1.54-1.54Zm3.196 3.195 1.135 1.136A1.502 1.502 0 0 1 9.45 8.389l1.136 1.135a3 3 0 0 0-4.109-4.109Z"
|
|
|
- clip-rule="evenodd"
|
|
|
- />
|
|
|
- <path
|
|
|
- d="m7.812 10.994 1.816 1.816A7.003 7.003 0 0 1 1.38 8.28a.87.87 0 0 1 0-.566 6.985 6.985 0 0 1 1.113-2.039l2.513 2.513a3 3 0 0 0 2.806 2.806Z"
|
|
|
- />
|
|
|
- </svg>
|
|
|
- {:else}
|
|
|
- <svg
|
|
|
- xmlns="http://www.w3.org/2000/svg"
|
|
|
- viewBox="0 0 16 16"
|
|
|
- fill="currentColor"
|
|
|
- class="w-4 h-4"
|
|
|
- >
|
|
|
- <path d="M8 9.5a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3Z" />
|
|
|
- <path
|
|
|
- fill-rule="evenodd"
|
|
|
- d="M1.38 8.28a.87.87 0 0 1 0-.566 7.003 7.003 0 0 1 13.238.006.87.87 0 0 1 0 .566A7.003 7.003 0 0 1 1.379 8.28ZM11 8a3 3 0 1 1-6 0 3 3 0 0 1 6 0Z"
|
|
|
- clip-rule="evenodd"
|
|
|
- />
|
|
|
- </svg>
|
|
|
- {/if}
|
|
|
- </button>
|
|
|
- </div>
|
|
|
- </div>
|
|
|
+ <SensitiveInput placeholder={$i18n.t('Enter Google PSE API Key')} bind:value={webConfig.search.google_pse_api_key} />
|
|
|
</div>
|
|
|
<div class="mt-1.5">
|
|
|
<div class=" self-center text-xs font-medium mb-1">
|
|
@@ -190,56 +141,7 @@
|
|
|
{$i18n.t('Brave Search API Key')}
|
|
|
</div>
|
|
|
|
|
|
- <div class="flex w-full">
|
|
|
- <div class="flex-1 flex">
|
|
|
- <input
|
|
|
- class="w-full rounded-l-lg py-2 pl-4 text-sm dark:text-gray-300 dark:bg-gray-850 outline-none"
|
|
|
- placeholder={$i18n.t('Enter Brave Search API Key')}
|
|
|
- bind:value={webConfig.search.brave_search_api_key}
|
|
|
- autocomplete="off"
|
|
|
- {...{ type: showApiKey ? 'text' : 'password' }}
|
|
|
- />
|
|
|
- <button
|
|
|
- class="px-2 transition rounded-r-lg bg-white dark:bg-gray-850"
|
|
|
- on:click={(e) => {
|
|
|
- e.preventDefault();
|
|
|
- showApiKey = !showApiKey;
|
|
|
- }}
|
|
|
- >
|
|
|
- {#if showApiKey}
|
|
|
- <svg
|
|
|
- xmlns="http://www.w3.org/2000/svg"
|
|
|
- viewBox="0 0 16 16"
|
|
|
- fill="currentColor"
|
|
|
- class="w-4 h-4"
|
|
|
- >
|
|
|
- <path
|
|
|
- fill-rule="evenodd"
|
|
|
- d="M3.28 2.22a.75.75 0 0 0-1.06 1.06l10.5 10.5a.75.75 0 1 0 1.06-1.06l-1.322-1.323a7.012 7.012 0 0 0 2.16-3.11.87.87 0 0 0 0-.567A7.003 7.003 0 0 0 4.82 3.76l-1.54-1.54Zm3.196 3.195 1.135 1.136A1.502 1.502 0 0 1 9.45 8.389l1.136 1.135a3 3 0 0 0-4.109-4.109Z"
|
|
|
- clip-rule="evenodd"
|
|
|
- />
|
|
|
- <path
|
|
|
- d="m7.812 10.994 1.816 1.816A7.003 7.003 0 0 1 1.38 8.28a.87.87 0 0 1 0-.566 6.985 6.985 0 0 1 1.113-2.039l2.513 2.513a3 3 0 0 0 2.806 2.806Z"
|
|
|
- />
|
|
|
- </svg>
|
|
|
- {:else}
|
|
|
- <svg
|
|
|
- xmlns="http://www.w3.org/2000/svg"
|
|
|
- viewBox="0 0 16 16"
|
|
|
- fill="currentColor"
|
|
|
- class="w-4 h-4"
|
|
|
- >
|
|
|
- <path d="M8 9.5a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3Z" />
|
|
|
- <path
|
|
|
- fill-rule="evenodd"
|
|
|
- d="M1.38 8.28a.87.87 0 0 1 0-.566 7.003 7.003 0 0 1 13.238.006.87.87 0 0 1 0 .566A7.003 7.003 0 0 1 1.379 8.28ZM11 8a3 3 0 1 1-6 0 3 3 0 0 1 6 0Z"
|
|
|
- clip-rule="evenodd"
|
|
|
- />
|
|
|
- </svg>
|
|
|
- {/if}
|
|
|
- </button>
|
|
|
- </div>
|
|
|
- </div>
|
|
|
+ <SensitiveInput placeholder={$i18n.t('Enter Brave Search API Key')} bind:value={webConfig.search.brave_search_api_key} />
|
|
|
</div>
|
|
|
{:else if webConfig.search.engine === 'serpstack'}
|
|
|
<div>
|
|
@@ -247,56 +149,7 @@
|
|
|
{$i18n.t('Serpstack API Key')}
|
|
|
</div>
|
|
|
|
|
|
- <div class="flex w-full">
|
|
|
- <div class="flex-1 flex">
|
|
|
- <input
|
|
|
- class="w-full rounded-l-lg py-2 pl-4 text-sm dark:text-gray-300 dark:bg-gray-850 outline-none"
|
|
|
- placeholder={$i18n.t('Enter Serpstack API Key')}
|
|
|
- bind:value={webConfig.search.serpstack_api_key}
|
|
|
- autocomplete="off"
|
|
|
- {...{ type: showApiKey ? 'text' : 'password' }}
|
|
|
- />
|
|
|
- <button
|
|
|
- class="px-2 transition rounded-r-lg bg-white dark:bg-gray-850"
|
|
|
- on:click={(e) => {
|
|
|
- e.preventDefault();
|
|
|
- showApiKey = !showApiKey;
|
|
|
- }}
|
|
|
- >
|
|
|
- {#if showApiKey}
|
|
|
- <svg
|
|
|
- xmlns="http://www.w3.org/2000/svg"
|
|
|
- viewBox="0 0 16 16"
|
|
|
- fill="currentColor"
|
|
|
- class="w-4 h-4"
|
|
|
- >
|
|
|
- <path
|
|
|
- fill-rule="evenodd"
|
|
|
- d="M3.28 2.22a.75.75 0 0 0-1.06 1.06l10.5 10.5a.75.75 0 1 0 1.06-1.06l-1.322-1.323a7.012 7.012 0 0 0 2.16-3.11.87.87 0 0 0 0-.567A7.003 7.003 0 0 0 4.82 3.76l-1.54-1.54Zm3.196 3.195 1.135 1.136A1.502 1.502 0 0 1 9.45 8.389l1.136 1.135a3 3 0 0 0-4.109-4.109Z"
|
|
|
- clip-rule="evenodd"
|
|
|
- />
|
|
|
- <path
|
|
|
- d="m7.812 10.994 1.816 1.816A7.003 7.003 0 0 1 1.38 8.28a.87.87 0 0 1 0-.566 6.985 6.985 0 0 1 1.113-2.039l2.513 2.513a3 3 0 0 0 2.806 2.806Z"
|
|
|
- />
|
|
|
- </svg>
|
|
|
- {:else}
|
|
|
- <svg
|
|
|
- xmlns="http://www.w3.org/2000/svg"
|
|
|
- viewBox="0 0 16 16"
|
|
|
- fill="currentColor"
|
|
|
- class="w-4 h-4"
|
|
|
- >
|
|
|
- <path d="M8 9.5a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3Z" />
|
|
|
- <path
|
|
|
- fill-rule="evenodd"
|
|
|
- d="M1.38 8.28a.87.87 0 0 1 0-.566 7.003 7.003 0 0 1 13.238.006.87.87 0 0 1 0 .566A7.003 7.003 0 0 1 1.379 8.28ZM11 8a3 3 0 1 1-6 0 3 3 0 0 1 6 0Z"
|
|
|
- clip-rule="evenodd"
|
|
|
- />
|
|
|
- </svg>
|
|
|
- {/if}
|
|
|
- </button>
|
|
|
- </div>
|
|
|
- </div>
|
|
|
+ <SensitiveInput placeholder={$i18n.t('Enter Serpstack API Key')} bind:value={webConfig.search.serpstack_api_key} />
|
|
|
</div>
|
|
|
{:else if webConfig.search.engine === 'serper'}
|
|
|
<div>
|
|
@@ -304,56 +157,7 @@
|
|
|
{$i18n.t('Serper API Key')}
|
|
|
</div>
|
|
|
|
|
|
- <div class="flex w-full">
|
|
|
- <div class="flex-1 flex">
|
|
|
- <input
|
|
|
- class="w-full rounded-l-lg py-2 pl-4 text-sm dark:text-gray-300 dark:bg-gray-850 outline-none"
|
|
|
- placeholder={$i18n.t('Enter Serper API Key')}
|
|
|
- bind:value={webConfig.search.serper_api_key}
|
|
|
- autocomplete="off"
|
|
|
- {...{ type: showApiKey ? 'text' : 'password' }}
|
|
|
- />
|
|
|
- <button
|
|
|
- class="px-2 transition rounded-r-lg bg-white dark:bg-gray-850"
|
|
|
- on:click={(e) => {
|
|
|
- e.preventDefault();
|
|
|
- showApiKey = !showApiKey;
|
|
|
- }}
|
|
|
- >
|
|
|
- {#if showApiKey}
|
|
|
- <svg
|
|
|
- xmlns="http://www.w3.org/2000/svg"
|
|
|
- viewBox="0 0 16 16"
|
|
|
- fill="currentColor"
|
|
|
- class="w-4 h-4"
|
|
|
- >
|
|
|
- <path
|
|
|
- fill-rule="evenodd"
|
|
|
- d="M3.28 2.22a.75.75 0 0 0-1.06 1.06l10.5 10.5a.75.75 0 1 0 1.06-1.06l-1.322-1.323a7.012 7.012 0 0 0 2.16-3.11.87.87 0 0 0 0-.567A7.003 7.003 0 0 0 4.82 3.76l-1.54-1.54Zm3.196 3.195 1.135 1.136A1.502 1.502 0 0 1 9.45 8.389l1.136 1.135a3 3 0 0 0-4.109-4.109Z"
|
|
|
- clip-rule="evenodd"
|
|
|
- />
|
|
|
- <path
|
|
|
- d="m7.812 10.994 1.816 1.816A7.003 7.003 0 0 1 1.38 8.28a.87.87 0 0 1 0-.566 6.985 6.985 0 0 1 1.113-2.039l2.513 2.513a3 3 0 0 0 2.806 2.806Z"
|
|
|
- />
|
|
|
- </svg>
|
|
|
- {:else}
|
|
|
- <svg
|
|
|
- xmlns="http://www.w3.org/2000/svg"
|
|
|
- viewBox="0 0 16 16"
|
|
|
- fill="currentColor"
|
|
|
- class="w-4 h-4"
|
|
|
- >
|
|
|
- <path d="M8 9.5a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3Z" />
|
|
|
- <path
|
|
|
- fill-rule="evenodd"
|
|
|
- d="M1.38 8.28a.87.87 0 0 1 0-.566 7.003 7.003 0 0 1 13.238.006.87.87 0 0 1 0 .566A7.003 7.003 0 0 1 1.379 8.28ZM11 8a3 3 0 1 1-6 0 3 3 0 0 1 6 0Z"
|
|
|
- clip-rule="evenodd"
|
|
|
- />
|
|
|
- </svg>
|
|
|
- {/if}
|
|
|
- </button>
|
|
|
- </div>
|
|
|
- </div>
|
|
|
+ <SensitiveInput placeholder={$i18n.t('Enter Serper API Key')} bind:value={webConfig.search.serper_api_key} />
|
|
|
</div>
|
|
|
{:else if webConfig.search.engine === 'serply'}
|
|
|
<div>
|
|
@@ -361,56 +165,7 @@
|
|
|
{$i18n.t('Serply API Key')}
|
|
|
</div>
|
|
|
|
|
|
- <div class="flex w-full">
|
|
|
- <div class="flex-1 flex">
|
|
|
- <input
|
|
|
- class="w-full rounded-l-lg py-2 pl-4 text-sm dark:text-gray-300 dark:bg-gray-850 outline-none"
|
|
|
- placeholder={$i18n.t('Enter Serply API Key')}
|
|
|
- bind:value={webConfig.search.serply_api_key}
|
|
|
- autocomplete="off"
|
|
|
- {...{ type: showApiKey ? 'text' : 'password' }}
|
|
|
- />
|
|
|
- <button
|
|
|
- class="px-2 transition rounded-r-lg bg-white dark:bg-gray-850"
|
|
|
- on:click={(e) => {
|
|
|
- e.preventDefault();
|
|
|
- showApiKey = !showApiKey;
|
|
|
- }}
|
|
|
- >
|
|
|
- {#if showApiKey}
|
|
|
- <svg
|
|
|
- xmlns="http://www.w3.org/2000/svg"
|
|
|
- viewBox="0 0 16 16"
|
|
|
- fill="currentColor"
|
|
|
- class="w-4 h-4"
|
|
|
- >
|
|
|
- <path
|
|
|
- fill-rule="evenodd"
|
|
|
- d="M3.28 2.22a.75.75 0 0 0-1.06 1.06l10.5 10.5a.75.75 0 1 0 1.06-1.06l-1.322-1.323a7.012 7.012 0 0 0 2.16-3.11.87.87 0 0 0 0-.567A7.003 7.003 0 0 0 4.82 3.76l-1.54-1.54Zm3.196 3.195 1.135 1.136A1.502 1.502 0 0 1 9.45 8.389l1.136 1.135a3 3 0 0 0-4.109-4.109Z"
|
|
|
- clip-rule="evenodd"
|
|
|
- />
|
|
|
- <path
|
|
|
- d="m7.812 10.994 1.816 1.816A7.003 7.003 0 0 1 1.38 8.28a.87.87 0 0 1 0-.566 6.985 6.985 0 0 1 1.113-2.039l2.513 2.513a3 3 0 0 0 2.806 2.806Z"
|
|
|
- />
|
|
|
- </svg>
|
|
|
- {:else}
|
|
|
- <svg
|
|
|
- xmlns="http://www.w3.org/2000/svg"
|
|
|
- viewBox="0 0 16 16"
|
|
|
- fill="currentColor"
|
|
|
- class="w-4 h-4"
|
|
|
- >
|
|
|
- <path d="M8 9.5a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3Z" />
|
|
|
- <path
|
|
|
- fill-rule="evenodd"
|
|
|
- d="M1.38 8.28a.87.87 0 0 1 0-.566 7.003 7.003 0 0 1 13.238.006.87.87 0 0 1 0 .566A7.003 7.003 0 0 1 1.379 8.28ZM11 8a3 3 0 1 1-6 0 3 3 0 0 1 6 0Z"
|
|
|
- clip-rule="evenodd"
|
|
|
- />
|
|
|
- </svg>
|
|
|
- {/if}
|
|
|
- </button>
|
|
|
- </div>
|
|
|
- </div>
|
|
|
+ <SensitiveInput placeholder={$i18n.t('Enter Serply API Key')} bind:value={webConfig.search.serply_api_key} />
|
|
|
</div>
|
|
|
{:else if webConfig.search.engine === 'tavily'}
|
|
|
<div>
|
|
@@ -418,56 +173,7 @@
|
|
|
{$i18n.t('Tavily API Key')}
|
|
|
</div>
|
|
|
|
|
|
- <div class="flex w-full">
|
|
|
- <div class="flex-1 flex">
|
|
|
- <input
|
|
|
- class="w-full rounded-l-lg py-2 pl-4 text-sm dark:text-gray-300 dark:bg-gray-850 outline-none"
|
|
|
- placeholder={$i18n.t('Enter Tavily API Key')}
|
|
|
- bind:value={webConfig.search.tavily_api_key}
|
|
|
- autocomplete="off"
|
|
|
- {...{ type: showApiKey ? 'text' : 'password' }}
|
|
|
- />
|
|
|
- <button
|
|
|
- class="px-2 transition rounded-r-lg bg-white dark:bg-gray-850"
|
|
|
- on:click={(e) => {
|
|
|
- e.preventDefault();
|
|
|
- showApiKey = !showApiKey;
|
|
|
- }}
|
|
|
- >
|
|
|
- {#if showApiKey}
|
|
|
- <svg
|
|
|
- xmlns="http://www.w3.org/2000/svg"
|
|
|
- viewBox="0 0 16 16"
|
|
|
- fill="currentColor"
|
|
|
- class="w-4 h-4"
|
|
|
- >
|
|
|
- <path
|
|
|
- fill-rule="evenodd"
|
|
|
- d="M3.28 2.22a.75.75 0 0 0-1.06 1.06l10.5 10.5a.75.75 0 1 0 1.06-1.06l-1.322-1.323a7.012 7.012 0 0 0 2.16-3.11.87.87 0 0 0 0-.567A7.003 7.003 0 0 0 4.82 3.76l-1.54-1.54Zm3.196 3.195 1.135 1.136A1.502 1.502 0 0 1 9.45 8.389l1.136 1.135a3 3 0 0 0-4.109-4.109Z"
|
|
|
- clip-rule="evenodd"
|
|
|
- />
|
|
|
- <path
|
|
|
- d="m7.812 10.994 1.816 1.816A7.003 7.003 0 0 1 1.38 8.28a.87.87 0 0 1 0-.566 6.985 6.985 0 0 1 1.113-2.039l2.513 2.513a3 3 0 0 0 2.806 2.806Z"
|
|
|
- />
|
|
|
- </svg>
|
|
|
- {:else}
|
|
|
- <svg
|
|
|
- xmlns="http://www.w3.org/2000/svg"
|
|
|
- viewBox="0 0 16 16"
|
|
|
- fill="currentColor"
|
|
|
- class="w-4 h-4"
|
|
|
- >
|
|
|
- <path d="M8 9.5a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3Z" />
|
|
|
- <path
|
|
|
- fill-rule="evenodd"
|
|
|
- d="M1.38 8.28a.87.87 0 0 1 0-.566 7.003 7.003 0 0 1 13.238.006.87.87 0 0 1 0 .566A7.003 7.003 0 0 1 1.379 8.28ZM11 8a3 3 0 1 1-6 0 3 3 0 0 1 6 0Z"
|
|
|
- clip-rule="evenodd"
|
|
|
- />
|
|
|
- </svg>
|
|
|
- {/if}
|
|
|
- </button>
|
|
|
- </div>
|
|
|
- </div>
|
|
|
+ <SensitiveInput placeholder={$i18n.t('Enter Tavily API Key')} bind:value={webConfig.search.tavily_api_key} />
|
|
|
</div>
|
|
|
{/if}
|
|
|
</div>
|