mirror of
https://github.com/ikawrakow/ik_llama.cpp.git
synced 2026-04-24 00:19:19 +00:00
webui: add system message in export conversation, support upload conversation with system message Webui: show upload only when in new conversation Webui: Add model name webui: increase height of chat message window when clicking editing Webui: autoclose settings dialog dropdown and maximze screen width when zoom in webui: fix date issues and add more dates webui: change error to toast.error. server: add n_past and slot_id in props_simple webui: add cache tokens, context and prompt speed in chat webui: modernize ui webui: change welcome message webui: change speed display webui: change run python icon webui: add config to use server defaults for sampler webui: put speed on left and context on right webui: recognize AsciiDoc files as valid text files (#16850) * webui: recognize AsciiDoc files as valid text files * webui: add an updated static webui build * webui: add the updated dependency list * webui: re-add an updated static webui build Add a setting to display message generation statistics (#16901) * feat: Add setting to display message generation statistics * chore: build static webui output webui: add HTML/JS preview support to MarkdownContent with sandboxed iframe (#16757) * webui: add HTML/JS preview support to MarkdownContent with sandboxed iframe dialog Extended MarkdownContent to flag previewable code languages, add a preview button alongside copy controls, manage preview dialog state, and share styling for the new button group Introduced CodePreviewDialog.svelte, a sandboxed iframe modal for rendering HTML/JS previews with consistent dialog controls * webui: fullscreen HTML preview dialog using bits-ui * Update tools/server/webui/src/lib/components/app/misc/CodePreviewDialog.svelte Co-authored-by: Aleksander Grygier <aleksander.grygier@gmail.com> * Update tools/server/webui/src/lib/components/app/misc/MarkdownContent.svelte Co-authored-by: Aleksander Grygier <aleksander.grygier@gmail.com> * webui: pedantic style tweak for CodePreviewDialog close button * webui: remove overengineered preview language logic * chore: update webui static build --------- Co-authored-by: Aleksander Grygier <aleksander.grygier@gmail.com> webui: auto-refresh /props on inference start to resync model metadata (#16784) * webui: auto-refresh /props on inference start to resync model metadata - Add no-cache headers to /props and /slots - Throttle slot checks to 30s - Prevent concurrent fetches with promise guard - Trigger refresh from chat streaming for legacy and ModelSelector - Show dynamic serverWarning when using cached data * fix: restore proper legacy behavior in webui by using unified /props refresh Updated assistant message bubbles to show each message's stored model when available, falling back to the current server model only when the per-message value is missing When the model selector is disabled, now fetches /props and prioritizes that model name over chunk metadata, then persists it with the streamed message so legacy mode properly reflects the backend configuration * fix: detect first valid SSE chunk and refresh server props once * fix: removed the slots availability throttle constant and state * webui: purge ai-generated cruft * chore: update webui static build feat(webui): improve LaTeX rendering with currency detection (#16508) * webui : Revised LaTeX formula recognition * webui : Further examples containg amounts * webui : vitest for maskInlineLaTeX * webui: Moved preprocessLaTeX to lib/utils * webui: LaTeX in table-cells * chore: update webui build output (use theirs) * webui: backslash in LaTeX-preprocessing * chore: update webui build output * webui: look-behind backslash-check * chore: update webui build output * Apply suggestions from code review Code maintenance (variable names, code formatting, string handling) Co-authored-by: Aleksander Grygier <aleksander.grygier@gmail.com> * webui: Moved constants to lib/constants. * webui: package woff2 inside base64 data * webui: LaTeX-line-break in display formula * chore: update webui build output * webui: Bugfix (font embedding) * webui: Bugfix (font embedding) * webui: vite embeds assets * webui: don't suppress 404 (fonts) * refactor: KaTeX integration with SCSS Moves KaTeX styling to SCSS for better customization and font embedding. This change includes: - Adding `sass` as a dev dependency. - Introducing a custom SCSS file to override KaTeX variables and disable TTF/WOFF fonts, relying solely on WOFF2 for embedding. - Adjusting the Vite configuration to resolve `katex-fonts` alias and inject SCSS variables. * fix: LaTeX processing within blockquotes * webui: update webui build output --------- Co-authored-by: Aleksander Grygier <aleksander.grygier@gmail.com> server : add props.model_alias (#16943) * server : add props.model_alias webui: fix keyboard shortcuts for new chat & edit chat title (#17007) Better UX for handling multiple attachments in WebUI (#17246) webui: add OAI-Compat Harmony tool-call streaming visualization and persistence in chat UI (#16618) * webui: add OAI-Compat Harmony tool-call live streaming visualization and persistence in chat UI - Purely visual and diagnostic change, no effect on model context, prompt construction, or inference behavior - Captured assistant tool call payloads during streaming and non-streaming completions, and persisted them in chat state and storage for downstream use - Exposed parsed tool call labels beneath the assistant's model info line with graceful fallback when parsing fails - Added tool call badges beneath assistant responses that expose JSON tooltips and copy their payloads when clicked, matching the existing model badge styling - Added a user-facing setting to toggle tool call visibility to the Developer settings section directly under the model selector option * webui: remove scroll listener causing unnecessary layout updates (model selector) * Update tools/server/webui/src/lib/components/app/chat/ChatMessages/ChatMessageAssistant.svelte Co-authored-by: Aleksander Grygier <aleksander.grygier@gmail.com> * Update tools/server/webui/src/lib/components/app/chat/ChatMessages/ChatMessageAssistant.svelte Co-authored-by: Aleksander Grygier <aleksander.grygier@gmail.com> * chore: npm run format & update webui build output * chore: update webui build output --------- Co-authored-by: Aleksander Grygier <aleksander.grygier@gmail.com> webui: Fix clickability around chat processing statistics UI (#17278) * fix: Better pointer events handling in chat processing info elements * chore: update webui build output Fix merge error webui: Add a "Continue" Action for Assistant Message (#16971) * feat: Add "Continue" action for assistant messages * feat: Continuation logic & prompt improvements * chore: update webui build output * feat: Improve logic for continuing the assistant message * chore: update webui build output * chore: Linting * chore: update webui build output * fix: Remove synthetic prompt logic, use the prefill feature by sending the conversation payload ending with assistant message * chore: update webui build output * feat: Enable "Continue" button based on config & non-reasoning model type * chore: update webui build output * chore: Update packages with `npm audit fix` * fix: Remove redundant error * chore: update webui build output * chore: Update `.gitignore` * fix: Add missing change * feat: Add auto-resizing for Edit Assistant/User Message textareas * chore: update webui build output Improved file naming & structure for UI components (#17405) * refactor: Component iles naming & structure * chore: update webui build output * refactor: Dialog titles + components namig * chore: update webui build output * refactor: Imports * chore: update webui build output webui: hide border of button webui: update webui: update webui: update add vision webui: minor settings reorganization and add disable autoscroll option (#17452) * webui: added a dedicated 'Display' settings section that groups visualization options * webui: added a Display setting to toggle automatic chat scrolling * chore: update webui build output Co-authored-by: firecoperana <firecoperana>
181 lines
4.9 KiB
Svelte
181 lines
4.9 KiB
Svelte
<script lang="ts">
|
|
import '../app.css';
|
|
import { page } from '$app/state';
|
|
import { ChatSidebar, DialogConversationTitleUpdate } from '$lib/components/app';
|
|
import {
|
|
activeMessages,
|
|
isLoading,
|
|
setTitleUpdateConfirmationCallback
|
|
} from '$lib/stores/chat.svelte';
|
|
import * as Sidebar from '$lib/components/ui/sidebar/index.js';
|
|
import { serverStore } from '$lib/stores/server.svelte';
|
|
import { config, settingsStore } from '$lib/stores/settings.svelte';
|
|
import { ModeWatcher } from 'mode-watcher';
|
|
import { Toaster } from 'svelte-sonner';
|
|
import { goto } from '$app/navigation';
|
|
|
|
let { children } = $props();
|
|
|
|
let isChatRoute = $derived(page.route.id === '/chat/[id]');
|
|
let isHomeRoute = $derived(page.route.id === '/');
|
|
let isNewChatMode = $derived(page.url.searchParams.get('new_chat') === 'true');
|
|
let showSidebarByDefault = $derived(activeMessages().length > 0 || isLoading());
|
|
let sidebarOpen = $state(false);
|
|
let innerHeight = $state<number | undefined>();
|
|
let chatSidebar:
|
|
| { activateSearchMode?: () => void; editActiveConversation?: () => void }
|
|
| undefined = $state();
|
|
|
|
// Conversation title update dialog state
|
|
let titleUpdateDialogOpen = $state(false);
|
|
let titleUpdateCurrentTitle = $state('');
|
|
let titleUpdateNewTitle = $state('');
|
|
let titleUpdateResolve: ((value: boolean) => void) | null = null;
|
|
|
|
// Global keyboard shortcuts
|
|
function handleKeydown(event: KeyboardEvent) {
|
|
const isCtrlOrCmd = event.ctrlKey || event.metaKey;
|
|
|
|
if (isCtrlOrCmd && event.key === 'k') {
|
|
event.preventDefault();
|
|
if (chatSidebar?.activateSearchMode) {
|
|
chatSidebar.activateSearchMode();
|
|
sidebarOpen = true;
|
|
}
|
|
}
|
|
|
|
if (isCtrlOrCmd && event.shiftKey && event.key === 'O') {
|
|
event.preventDefault();
|
|
goto('?new_chat=true#/');
|
|
}
|
|
|
|
if (event.shiftKey && isCtrlOrCmd && event.key === 'E') {
|
|
event.preventDefault();
|
|
|
|
if (chatSidebar?.editActiveConversation) {
|
|
chatSidebar.editActiveConversation();
|
|
}
|
|
}
|
|
}
|
|
|
|
function handleTitleUpdateCancel() {
|
|
titleUpdateDialogOpen = false;
|
|
if (titleUpdateResolve) {
|
|
titleUpdateResolve(false);
|
|
titleUpdateResolve = null;
|
|
}
|
|
}
|
|
|
|
function handleTitleUpdateConfirm() {
|
|
titleUpdateDialogOpen = false;
|
|
if (titleUpdateResolve) {
|
|
titleUpdateResolve(true);
|
|
titleUpdateResolve = null;
|
|
}
|
|
}
|
|
|
|
$effect(() => {
|
|
if (isHomeRoute && !isNewChatMode) {
|
|
// Auto-collapse sidebar when navigating to home route (but not in new chat mode)
|
|
sidebarOpen = false;
|
|
} else if (isHomeRoute && isNewChatMode) {
|
|
// Keep sidebar open in new chat mode
|
|
sidebarOpen = true;
|
|
} else if (isChatRoute) {
|
|
// On chat routes, show sidebar by default
|
|
sidebarOpen = true;
|
|
} else {
|
|
// Other routes follow default behavior
|
|
sidebarOpen = showSidebarByDefault;
|
|
}
|
|
});
|
|
|
|
// Initialize server properties on app load
|
|
$effect(() => {
|
|
serverStore.fetchServerProps();
|
|
});
|
|
|
|
// Sync settings when server props are loaded
|
|
$effect(() => {
|
|
const serverProps = serverStore.serverProps;
|
|
|
|
if (serverProps?.default_generation_settings?.params) {
|
|
settingsStore.syncWithServerDefaults();
|
|
}
|
|
});
|
|
|
|
// Monitor API key changes and redirect to error page if removed or changed when required
|
|
$effect(() => {
|
|
const apiKey = config().apiKey;
|
|
|
|
if (
|
|
(page.route.id === '/' || page.route.id === '/chat/[id]') &&
|
|
page.status !== 401 &&
|
|
page.status !== 403
|
|
) {
|
|
const headers: Record<string, string> = {
|
|
'Content-Type': 'application/json'
|
|
};
|
|
|
|
if (apiKey && apiKey.trim() !== '') {
|
|
headers.Authorization = `Bearer ${apiKey.trim()}`;
|
|
}
|
|
|
|
fetch(`./props`, { headers })
|
|
.then((response) => {
|
|
if (response.status === 401 || response.status === 403) {
|
|
window.location.reload();
|
|
}
|
|
})
|
|
.catch((e) => {
|
|
console.error('Error checking API key:', e);
|
|
});
|
|
}
|
|
});
|
|
|
|
// Set up title update confirmation callback
|
|
$effect(() => {
|
|
setTitleUpdateConfirmationCallback(async (currentTitle: string, newTitle: string) => {
|
|
return new Promise<boolean>((resolve) => {
|
|
titleUpdateCurrentTitle = currentTitle;
|
|
titleUpdateNewTitle = newTitle;
|
|
titleUpdateResolve = resolve;
|
|
titleUpdateDialogOpen = true;
|
|
});
|
|
});
|
|
});
|
|
</script>
|
|
|
|
<ModeWatcher />
|
|
|
|
<Toaster richColors />
|
|
|
|
<DialogConversationTitleUpdate
|
|
bind:open={titleUpdateDialogOpen}
|
|
currentTitle={titleUpdateCurrentTitle}
|
|
newTitle={titleUpdateNewTitle}
|
|
onConfirm={handleTitleUpdateConfirm}
|
|
onCancel={handleTitleUpdateCancel}
|
|
/>
|
|
|
|
<Sidebar.Provider bind:open={sidebarOpen}>
|
|
<div class="flex h-screen w-full" style:height="{innerHeight}px">
|
|
<Sidebar.Root class="h-full">
|
|
<ChatSidebar bind:this={chatSidebar} />
|
|
</Sidebar.Root>
|
|
|
|
<Sidebar.Trigger
|
|
class="transition-left absolute left-0 z-[900] h-8 w-8 duration-200 ease-linear {sidebarOpen
|
|
? 'md:left-[var(--sidebar-width)]'
|
|
: ''}"
|
|
style="translate: 1rem 1rem;"
|
|
/>
|
|
|
|
<Sidebar.Inset class="flex flex-1 flex-col overflow-hidden">
|
|
{@render children?.()}
|
|
</Sidebar.Inset>
|
|
</div>
|
|
</Sidebar.Provider>
|
|
|
|
<svelte:window onkeydown={handleKeydown} bind:innerHeight />
|