open-webui/src/lib/components/chat/Placeholder/FolderPlaceholder.svelte

83 lines
1.8 KiB
Svelte
Raw Normal View History

2025-07-19 10:29:08 +00:00
<script>
2025-09-27 02:16:34 +00:00
import { getContext, onMount } from 'svelte';
2025-07-19 10:29:08 +00:00
const i18n = getContext('i18n');
import { fade } from 'svelte/transition';
import ChatList from './ChatList.svelte';
import FolderKnowledge from './FolderKnowledge.svelte';
2025-09-27 02:16:34 +00:00
import Spinner from '$lib/components/common/Spinner.svelte';
import { getChatListByFolderId } from '$lib/apis/chats';
2025-07-19 10:29:08 +00:00
export let folder = null;
let selectedTab = 'chats';
2025-09-27 02:16:34 +00:00
let chats = null;
let page = 1;
const setChatList = async () => {
chats = null;
if (folder && folder.id) {
const res = await getChatListByFolderId(localStorage.token, folder.id, page);
if (res) {
chats = res;
} else {
chats = [];
}
} else {
chats = [];
}
};
$: if (folder) {
setChatList();
}
2025-07-19 10:29:08 +00:00
</script>
<div>
<!-- <div class="mb-1">
<div
class="flex gap-1 scrollbar-none overflow-x-auto w-fit text-center text-sm font-medium rounded-full bg-transparent py-1 touch-auto pointer-events-auto"
>
<button
class="min-w-fit p-1.5 {selectedTab === 'knowledge'
? ''
: 'text-gray-300 dark:text-gray-600 hover:text-gray-700 dark:hover:text-white'} transition"
type="button"
on:click={() => {
selectedTab = 'knowledge';
}}>{$i18n.t('Knowledge')}</button
>
<button
class="min-w-fit p-1.5 {selectedTab === 'chats'
? ''
: 'text-gray-300 dark:text-gray-600 hover:text-gray-700 dark:hover:text-white'} transition"
type="button"
on:click={() => {
selectedTab = 'chats';
}}
>
{$i18n.t('Chats')}
</button>
</div>
</div> -->
<div class="">
{#if selectedTab === 'knowledge'}
<FolderKnowledge />
{:else if selectedTab === 'chats'}
2025-09-27 02:16:34 +00:00
{#if chats !== null}
<ChatList {chats} />
{:else}
<div class="py-10">
<Spinner />
</div>
{/if}
2025-07-19 10:29:08 +00:00
{/if}
</div>
</div>