+
{/if}
- {:else}
-
- {@html marked(message.content.replace('\\\\', '\\\\\\'))}
+ {/if}
- {#if message.done}
-
- {#if message.parentId !== null && message.parentId in history.messages && (history.messages[message.parentId]?.childrenIds.length ?? 0) > 1}
-
-
-
-
- {history.messages[message.parentId].childrenIds.indexOf(message.id) +
- 1} / {history.messages[message.parentId].childrenIds.length}
-
-
-
-
- {/if}
-
-
-
-
-
-
-
+ on:loadstart
+ />
-
-
- {#if messageIdx + 1 === messages.length}
+
+
+ {:else}
+
+ {@html marked(message.content.replace('\\\\', '\\\\\\'))}
+
+ {#if message.done}
+
+ {#if message.parentId !== null && message.parentId in history.messages && (history.messages[message.parentId]?.childrenIds.length ?? 0) > 1}
+
+
+
+
+ {history.messages[message.parentId].childrenIds.indexOf(
+ message.id
+ ) + 1} / {history.messages[message.parentId].childrenIds.length}
+
+
+
+
+ {/if}
+
+
+
+
+
+
+ class="w-4 h-4"
+ xmlns="http://www.w3.org/2000/svg"
+ >
+
+
+
+
+
+ {#if messageIdx + 1 === messages.length}
+
+ {/if}
+
{/if}
{/if}
diff --git a/src/routes/(app)/+page.svelte b/src/routes/(app)/+page.svelte
index f0a8a11ca..43cd35162 100644
--- a/src/routes/(app)/+page.svelte
+++ b/src/routes/(app)/+page.svelte
@@ -118,38 +118,11 @@
];
}
+ await tick();
+
window.scrollTo({ top: document.body.scrollHeight });
- const res = await fetch(`${$settings?.API_BASE_URL ?? OLLAMA_API_BASE_URL}/generate`, {
- method: 'POST',
- headers: {
- 'Content-Type': 'text/event-stream',
- ...($settings.authHeader && { Authorization: $settings.authHeader }),
- ...($user && { Authorization: `Bearer ${localStorage.token}` })
- },
- body: JSON.stringify({
- model: model,
- prompt: userPrompt,
- system: $settings.system ?? undefined,
- options: {
- seed: $settings.seed ?? undefined,
- temperature: $settings.temperature ?? undefined,
- repeat_penalty: $settings.repeat_penalty ?? undefined,
- top_k: $settings.top_k ?? undefined,
- top_p: $settings.top_p ?? undefined,
- num_ctx: $settings.num_ctx ?? undefined,
- ...($settings.options ?? {})
- },
- format: $settings.requestFormat ?? undefined,
- context:
- history.messages[parentId] !== null &&
- history.messages[parentId].parentId in history.messages
- ? history.messages[history.messages[parentId].parentId]?.context ?? undefined
- : undefined
- })
- });
-
- // const res = await fetch(`${$settings?.API_BASE_URL ?? OLLAMA_API_BASE_URL}/chat`, {
+ // const res = await fetch(`${$settings?.API_BASE_URL ?? OLLAMA_API_BASE_URL}/generate`, {
// method: 'POST',
// headers: {
// 'Content-Type': 'text/event-stream',
@@ -158,17 +131,8 @@
// },
// body: JSON.stringify({
// model: model,
- // messages: [
- // $settings.system
- // ? {
- // role: 'system',
- // content: $settings.system
- // }
- // : undefined,
- // ...messages
- // ]
- // .filter((message) => message)
- // .map((message) => ({ role: message.role, content: message.content })),
+ // prompt: userPrompt,
+ // system: $settings.system ?? undefined,
// options: {
// seed: $settings.seed ?? undefined,
// temperature: $settings.temperature ?? undefined,
@@ -178,10 +142,48 @@
// num_ctx: $settings.num_ctx ?? undefined,
// ...($settings.options ?? {})
// },
- // format: $settings.requestFormat ?? undefined
+ // format: $settings.requestFormat ?? undefined,
+ // context:
+ // history.messages[parentId] !== null &&
+ // history.messages[parentId].parentId in history.messages
+ // ? history.messages[history.messages[parentId].parentId]?.context ?? undefined
+ // : undefined
// })
// });
+ const res = await fetch(`${$settings?.API_BASE_URL ?? OLLAMA_API_BASE_URL}/chat`, {
+ method: 'POST',
+ headers: {
+ 'Content-Type': 'text/event-stream',
+ ...($settings.authHeader && { Authorization: $settings.authHeader }),
+ ...($user && { Authorization: `Bearer ${localStorage.token}` })
+ },
+ body: JSON.stringify({
+ model: model,
+ messages: [
+ $settings.system
+ ? {
+ role: 'system',
+ content: $settings.system
+ }
+ : undefined,
+ ...messages
+ ]
+ .filter((message) => message)
+ .map((message) => ({ role: message.role, content: message.content })),
+ options: {
+ seed: $settings.seed ?? undefined,
+ temperature: $settings.temperature ?? undefined,
+ repeat_penalty: $settings.repeat_penalty ?? undefined,
+ top_k: $settings.top_k ?? undefined,
+ top_p: $settings.top_p ?? undefined,
+ num_ctx: $settings.num_ctx ?? undefined,
+ ...($settings.options ?? {})
+ },
+ format: $settings.requestFormat ?? undefined
+ })
+ });
+
const reader = res.body
.pipeThrough(new TextDecoderStream())
.pipeThrough(splitStream('\n'))
@@ -189,12 +191,9 @@
while (true) {
const { value, done } = await reader.read();
- if (done || stopResponseFlag) {
- if (stopResponseFlag) {
- responseMessage.done = true;
- messages = messages;
- }
-
+ if (done || stopResponseFlag || _chatId !== $chatId) {
+ responseMessage.done = true;
+ messages = messages;
break;
}
@@ -205,18 +204,28 @@
if (line !== '') {
console.log(line);
let data = JSON.parse(line);
+
+ if ('detail' in data) {
+ throw data;
+ }
+
if (data.done == false) {
- if (responseMessage.content == '' && data.response == '\n') {
+ if (responseMessage.content == '' && data.message.content == '\n') {
continue;
} else {
- responseMessage.content += data.response;
+ responseMessage.content += data.message.content;
messages = messages;
}
- } else if ('detail' in data) {
- throw data;
} else {
responseMessage.done = true;
- responseMessage.context = data.context;
+ responseMessage.context = data.context ?? null;
+ responseMessage.info = {
+ total_duration: data.total_duration,
+ prompt_eval_count: data.prompt_eval_count,
+ prompt_eval_duration: data.prompt_eval_duration,
+ eval_count: data.eval_count,
+ eval_duration: data.eval_duration
+ };
messages = messages;
}
}
@@ -324,12 +333,9 @@
while (true) {
const { value, done } = await reader.read();
- if (done || stopResponseFlag) {
- if (stopResponseFlag) {
- responseMessage.done = true;
- messages = messages;
- }
-
+ if (done || stopResponseFlag || _chatId !== $chatId) {
+ responseMessage.done = true;
+ messages = messages;
break;
}
diff --git a/src/routes/(app)/c/[id]/+page.svelte b/src/routes/(app)/c/[id]/+page.svelte
index d9f437935..fd61a4dc8 100644
--- a/src/routes/(app)/c/[id]/+page.svelte
+++ b/src/routes/(app)/c/[id]/+page.svelte
@@ -152,38 +152,11 @@
];
}
+ await tick();
+
window.scrollTo({ top: document.body.scrollHeight });
- const res = await fetch(`${$settings?.API_BASE_URL ?? OLLAMA_API_BASE_URL}/generate`, {
- method: 'POST',
- headers: {
- 'Content-Type': 'text/event-stream',
- ...($settings.authHeader && { Authorization: $settings.authHeader }),
- ...($user && { Authorization: `Bearer ${localStorage.token}` })
- },
- body: JSON.stringify({
- model: model,
- prompt: userPrompt,
- system: $settings.system ?? undefined,
- options: {
- seed: $settings.seed ?? undefined,
- temperature: $settings.temperature ?? undefined,
- repeat_penalty: $settings.repeat_penalty ?? undefined,
- top_k: $settings.top_k ?? undefined,
- top_p: $settings.top_p ?? undefined,
- num_ctx: $settings.num_ctx ?? undefined,
- ...($settings.options ?? {})
- },
- format: $settings.requestFormat ?? undefined,
- context:
- history.messages[parentId] !== null &&
- history.messages[parentId].parentId in history.messages
- ? history.messages[history.messages[parentId].parentId]?.context ?? undefined
- : undefined
- })
- });
-
- // const res = await fetch(`${$settings?.API_BASE_URL ?? OLLAMA_API_BASE_URL}/chat`, {
+ // const res = await fetch(`${$settings?.API_BASE_URL ?? OLLAMA_API_BASE_URL}/generate`, {
// method: 'POST',
// headers: {
// 'Content-Type': 'text/event-stream',
@@ -192,17 +165,8 @@
// },
// body: JSON.stringify({
// model: model,
- // messages: [
- // $settings.system
- // ? {
- // role: 'system',
- // content: $settings.system
- // }
- // : undefined,
- // ...messages
- // ]
- // .filter((message) => message)
- // .map((message) => ({ role: message.role, content: message.content })),
+ // prompt: userPrompt,
+ // system: $settings.system ?? undefined,
// options: {
// seed: $settings.seed ?? undefined,
// temperature: $settings.temperature ?? undefined,
@@ -212,10 +176,48 @@
// num_ctx: $settings.num_ctx ?? undefined,
// ...($settings.options ?? {})
// },
- // format: $settings.requestFormat ?? undefined
+ // format: $settings.requestFormat ?? undefined,
+ // context:
+ // history.messages[parentId] !== null &&
+ // history.messages[parentId].parentId in history.messages
+ // ? history.messages[history.messages[parentId].parentId]?.context ?? undefined
+ // : undefined
// })
// });
+ const res = await fetch(`${$settings?.API_BASE_URL ?? OLLAMA_API_BASE_URL}/chat`, {
+ method: 'POST',
+ headers: {
+ 'Content-Type': 'text/event-stream',
+ ...($settings.authHeader && { Authorization: $settings.authHeader }),
+ ...($user && { Authorization: `Bearer ${localStorage.token}` })
+ },
+ body: JSON.stringify({
+ model: model,
+ messages: [
+ $settings.system
+ ? {
+ role: 'system',
+ content: $settings.system
+ }
+ : undefined,
+ ...messages
+ ]
+ .filter((message) => message)
+ .map((message) => ({ role: message.role, content: message.content })),
+ options: {
+ seed: $settings.seed ?? undefined,
+ temperature: $settings.temperature ?? undefined,
+ repeat_penalty: $settings.repeat_penalty ?? undefined,
+ top_k: $settings.top_k ?? undefined,
+ top_p: $settings.top_p ?? undefined,
+ num_ctx: $settings.num_ctx ?? undefined,
+ ...($settings.options ?? {})
+ },
+ format: $settings.requestFormat ?? undefined
+ })
+ });
+
const reader = res.body
.pipeThrough(new TextDecoderStream())
.pipeThrough(splitStream('\n'))
@@ -223,12 +225,9 @@
while (true) {
const { value, done } = await reader.read();
- if (done || stopResponseFlag) {
- if (stopResponseFlag) {
- responseMessage.done = true;
- messages = messages;
- }
-
+ if (done || stopResponseFlag || _chatId !== $chatId) {
+ responseMessage.done = true;
+ messages = messages;
break;
}
@@ -239,18 +238,28 @@
if (line !== '') {
console.log(line);
let data = JSON.parse(line);
+
+ if ('detail' in data) {
+ throw data;
+ }
+
if (data.done == false) {
- if (responseMessage.content == '' && data.response == '\n') {
+ if (responseMessage.content == '' && data.message.content == '\n') {
continue;
} else {
- responseMessage.content += data.response;
+ responseMessage.content += data.message.content;
messages = messages;
}
- } else if ('detail' in data) {
- throw data;
} else {
responseMessage.done = true;
- responseMessage.context = data.context;
+ responseMessage.context = data.context ?? null;
+ responseMessage.info = {
+ total_duration: data.total_duration,
+ prompt_eval_count: data.prompt_eval_count,
+ prompt_eval_duration: data.prompt_eval_duration,
+ eval_count: data.eval_count,
+ eval_duration: data.eval_duration
+ };
messages = messages;
}
}