open-webui/src/lib/components/channel/Messages.svelte

65 lines
1.6 KiB
Svelte
Raw Normal View History

2024-12-22 11:49:24 +00:00
<script lang="ts">
import { v4 as uuidv4 } from 'uuid';
import { chats, config, settings, user as _user, mobile, currentChatPage } from '$lib/stores';
import { tick, getContext, onMount, createEventDispatcher } from 'svelte';
const dispatch = createEventDispatcher();
import { toast } from 'svelte-sonner';
import Message from './Messages/Message.svelte';
import Loader from '../common/Loader.svelte';
import Spinner from '../common/Spinner.svelte';
2024-12-23 02:40:01 +00:00
import { getChannelMessages } from '$lib/apis/channels';
2024-12-22 11:49:24 +00:00
const i18n = getContext('i18n');
2024-12-23 02:40:01 +00:00
export let messages = [];
export let top = false;
2024-12-22 11:49:24 +00:00
2024-12-23 02:40:01 +00:00
export let onLoad: Function = () => {};
2024-12-22 11:49:24 +00:00
let messagesLoading = false;
const loadMoreMessages = async () => {
// scroll slightly down to disable continuous loading
const element = document.getElementById('messages-container');
element.scrollTop = element.scrollTop + 100;
messagesLoading = true;
2024-12-23 02:40:01 +00:00
await onLoad();
2024-12-22 11:49:24 +00:00
2024-12-23 02:40:01 +00:00
await tick();
2024-12-22 11:49:24 +00:00
messagesLoading = false;
};
</script>
2024-12-23 02:40:01 +00:00
{#if messages}
<div class="h-full w-full flex-1 flex">
<div class="w-full pt-2">
2024-12-22 11:49:24 +00:00
<div class="w-full">
2024-12-23 02:40:01 +00:00
{#if !top}
2024-12-22 11:49:24 +00:00
<Loader
on:visible={(e) => {
console.log('visible');
if (!messagesLoading) {
loadMoreMessages();
}
}}
>
<div class="w-full flex justify-center py-1 text-xs animate-pulse items-center gap-2">
<Spinner className=" size-4" />
<div class=" ">Loading...</div>
</div>
</Loader>
{/if}
{#each messages as message, messageIdx (message.id)}
2024-12-23 02:40:01 +00:00
<Message {message} />
2024-12-22 11:49:24 +00:00
{/each}
</div>
2024-12-23 02:40:01 +00:00
<div class="pb-6" />
</div>
2024-12-22 11:49:24 +00:00
</div>
2024-12-23 02:40:01 +00:00
{/if}