diff --git a/resources/chat-view/chat.js b/resources/chat-view/chat.js index cfbccfc1..94e35f8a 100644 --- a/resources/chat-view/chat.js +++ b/resources/chat-view/chat.js @@ -90,14 +90,15 @@ if (role === 'assistant') { messageDiv = chatMessages.querySelector('div[data-role="assistant"]:last-child') || - chatMessages.lastElementChild; + chatMessages.firstElementChild; if (!messageDiv || messageDiv.getAttribute('data-role') !== 'assistant') { messageDiv = document.createElement('div'); messageDiv.className = 'p-4 assistant'; messageDiv.setAttribute('data-role', 'assistant'); messageDiv.innerHTML = `

ZenML Assistant

`; - chatMessages.appendChild(messageDiv); + + chatMessages.insertBefore(messageDiv, chatMessages.firstChild); currentAssistantMessage = ''; } @@ -106,7 +107,7 @@ requestAnimationFrame(() => { contentDiv.innerHTML = marked.parse(currentAssistantMessage); - chatMessages.scrollTop = chatMessages.scrollHeight; + chatMessages.scrollTop = 0; }); } } diff --git a/src/views/chatView/ChatDataProvider.ts b/src/views/chatView/ChatDataProvider.ts index cc4f4b31..0e08765e 100644 --- a/src/views/chatView/ChatDataProvider.ts +++ b/src/views/chatView/ChatDataProvider.ts @@ -144,7 +144,7 @@ export class ChatDataProvider implements vscode.WebviewViewProvider { let convertedTreeData = treeData.map((item) => { let iconSvg = ''; let childrenEl = ''; - let title = '' + let title = ''; if (item.children) { iconSvg = ''; @@ -152,7 +152,7 @@ export class ChatDataProvider implements vscode.WebviewViewProvider { } if (item.title) { - title = item.title + title = item.title; } let checkboxEl = level < 2 ? `` : ''; @@ -218,7 +218,7 @@ export class ChatDataProvider implements vscode.WebviewViewProvider { this.streamingMessage.content += letter; this.sendMessageToWebview(letter); // Add a tiny delay between characters to simulate typing - await new Promise(resolve => setTimeout(resolve, 5)); // Adjust delay as needed + await new Promise(resolve => setTimeout(resolve, 1)); // Adjust delay as needed } } @@ -236,6 +236,7 @@ export class ChatDataProvider implements vscode.WebviewViewProvider { */ private renderChatLog(): string { const renderer = { + // @ts-ignore code({ text, lang, escaped, isInline }) { const code = text.replace(/\n$/, '') + (isInline ? '' : '\n'); @@ -249,9 +250,11 @@ export class ChatDataProvider implements vscode.WebviewViewProvider { } }; + // @ts-ignore marked.use({ renderer }); return this.messages.filter(msg => msg['role'] !== 'system') + .reverse() .map((message) => { let content = marked.parse(message.content); if (message.role === 'user') { @@ -273,6 +276,7 @@ export class ChatDataProvider implements vscode.WebviewViewProvider { if (!this.streamingMessage) {return '';} const renderer = { + // @ts-ignore code({ text, lang, escaped, isInline }) { const code = text.replace(/\n$/, '') + (isInline ? '' : '\n'); @@ -286,6 +290,7 @@ export class ChatDataProvider implements vscode.WebviewViewProvider { } }; + // @ts-ignore marked.use({ renderer }); let content = marked.parse(this.streamingMessage.content);