mirror of
https://github.com/khoj-ai/khoj.git
synced 2024-11-28 01:45:07 +01:00
UX Improvement: Keyboard Shortcuts for Recent Messages (#804)
* added keyboard shortcuts to access old queries
This commit is contained in:
parent
2dcfb3c2f0
commit
35715096f4
2 changed files with 65 additions and 3 deletions
|
@ -1,4 +1,4 @@
|
||||||
# Generated by Django 4.2.10 on 2024-05-29 19:56
|
# Generated by Django 4.2.11 on 2024-06-14 04:36
|
||||||
|
|
||||||
from django.db import migrations, models
|
from django.db import migrations, models
|
||||||
|
|
||||||
|
|
|
@ -541,6 +541,13 @@ To get started, just start typing below. You can also type / to see a list of co
|
||||||
if (query.length === 0)
|
if (query.length === 0)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
// if the query is not empty then update userMessages array. keep the size of the array to 10
|
||||||
|
if (userMessages.length >= 10) {
|
||||||
|
userMessages.shift();
|
||||||
|
}
|
||||||
|
userMessages.push(query);
|
||||||
|
resetUserMessageIndex();
|
||||||
|
|
||||||
// Add message by user to chat body
|
// Add message by user to chat body
|
||||||
renderMessage(query, "you");
|
renderMessage(query, "you");
|
||||||
document.getElementById("chat-input").value = "";
|
document.getElementById("chat-input").value = "";
|
||||||
|
@ -1114,6 +1121,12 @@ To get started, just start typing below. You can also type / to see a list of co
|
||||||
var query = document.getElementById("chat-input").value.trim();
|
var query = document.getElementById("chat-input").value.trim();
|
||||||
console.log(`Query: ${query}`);
|
console.log(`Query: ${query}`);
|
||||||
|
|
||||||
|
if (userMessages.length >= 10) {
|
||||||
|
userMessages.shift();
|
||||||
|
}
|
||||||
|
userMessages.push(query);
|
||||||
|
resetUserMessageIndex();
|
||||||
|
|
||||||
// Add message by user to chat body
|
// Add message by user to chat body
|
||||||
renderMessage(query, "you");
|
renderMessage(query, "you");
|
||||||
document.getElementById("chat-input").value = "";
|
document.getElementById("chat-input").value = "";
|
||||||
|
@ -1155,7 +1168,8 @@ To get started, just start typing below. You can also type / to see a list of co
|
||||||
rawQuery: query,
|
rawQuery: query,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
var userMessages = [];
|
||||||
|
var userMessageIndex = -1;
|
||||||
function loadChat() {
|
function loadChat() {
|
||||||
let chatBody = document.getElementById("chat-body");
|
let chatBody = document.getElementById("chat-body");
|
||||||
chatBody.innerHTML = "";
|
chatBody.innerHTML = "";
|
||||||
|
@ -1262,9 +1276,15 @@ To get started, just start typing below. You can also type / to see a list of co
|
||||||
}, {rootMargin: '0px 0px 0px 0px'});
|
}, {rootMargin: '0px 0px 0px 0px'});
|
||||||
|
|
||||||
const fullChatLog = response.chat || [];
|
const fullChatLog = response.chat || [];
|
||||||
|
userMessages = [];
|
||||||
|
userMessageIndex = 0;
|
||||||
fullChatLog.forEach((chat_log, index) => {
|
fullChatLog.forEach((chat_log, index) => {
|
||||||
// Render the last 10 messages immediately
|
// Render the last 10 messages immediately
|
||||||
|
// also cache user messages into array for shortcut access
|
||||||
if (chat_log.message != null) {
|
if (chat_log.message != null) {
|
||||||
|
if(chat_log.by !== "khoj") {
|
||||||
|
userMessages.push(chat_log.message);
|
||||||
|
}
|
||||||
let messageElement = renderMessageWithReference(
|
let messageElement = renderMessageWithReference(
|
||||||
chat_log.message,
|
chat_log.message,
|
||||||
chat_log.by,
|
chat_log.by,
|
||||||
|
@ -1284,6 +1304,7 @@ To get started, just start typing below. You can also type / to see a list of co
|
||||||
}
|
}
|
||||||
loadingScreen.style.height = chatBody.scrollHeight + 'px';
|
loadingScreen.style.height = chatBody.scrollHeight + 'px';
|
||||||
});
|
});
|
||||||
|
userMessageIndex = userMessages.length;
|
||||||
|
|
||||||
// Scroll to bottom of chat-body element
|
// Scroll to bottom of chat-body element
|
||||||
chatBody.scrollTop = chatBody.scrollHeight;
|
chatBody.scrollTop = chatBody.scrollHeight;
|
||||||
|
@ -2068,11 +2089,35 @@ To get started, just start typing below. You can also type / to see a list of co
|
||||||
console.error("Error loading file filters:", error);
|
console.error("Error loading file filters:", error);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function inputAutoFiller(key){
|
||||||
|
var chatInput = document.getElementById("chat-input");
|
||||||
|
console.log(key, userMessageIndex)
|
||||||
|
if (key === "up") {
|
||||||
|
if (userMessageIndex > 0) {
|
||||||
|
userMessageIndex -= 1;
|
||||||
|
chatInput.value = userMessages[userMessageIndex];
|
||||||
|
} else {
|
||||||
|
userMessageIndex = -1;
|
||||||
|
chatInput.value = "";
|
||||||
|
}
|
||||||
|
} else if (key === "down") {
|
||||||
|
if (userMessageIndex < userMessages.length - 1) {
|
||||||
|
userMessageIndex += 1;
|
||||||
|
chatInput.value = userMessages[userMessageIndex];
|
||||||
|
} else if (userMessageIndex === userMessages.length - 1) {
|
||||||
|
userMessageIndex += 1;
|
||||||
|
chatInput.value = "";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
function resetUserMessageIndex(){
|
||||||
|
userMessageIndex = userMessages.length;
|
||||||
|
}
|
||||||
</script>
|
</script>
|
||||||
<body>
|
<body>
|
||||||
<div id="khoj-empty-container" class="khoj-empty-container">
|
<div id="khoj-empty-container" class="khoj-empty-container">
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<!--Add Header Logo and Nav Pane-->
|
<!--Add Header Logo and Nav Pane-->
|
||||||
{% import 'utils.html' as utils %}
|
{% import 'utils.html' as utils %}
|
||||||
{{ utils.heading_pane(user_photo, username, is_active, has_documents) }}
|
{{ utils.heading_pane(user_photo, username, is_active, has_documents) }}
|
||||||
|
@ -2143,6 +2188,7 @@ To get started, just start typing below. You can also type / to see a list of co
|
||||||
fileList.style.display = 'none';
|
fileList.style.display = 'none';
|
||||||
selectedFileList.style.display = 'block';
|
selectedFileList.style.display = 'block';
|
||||||
}
|
}
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
fileInput.addEventListener('click', function(event) {
|
fileInput.addEventListener('click', function(event) {
|
||||||
|
@ -2199,6 +2245,22 @@ To get started, just start typing below. You can also type / to see a list of co
|
||||||
</svg>
|
</svg>
|
||||||
</button>
|
</button>
|
||||||
<textarea id="chat-input" class="option" oninput="onChatInput()" onkeydown=incrementalChat(event) autofocus="autofocus" placeholder="Type / to see a list of commands"></textarea>
|
<textarea id="chat-input" class="option" oninput="onChatInput()" onkeydown=incrementalChat(event) autofocus="autofocus" placeholder="Type / to see a list of commands"></textarea>
|
||||||
|
<!-- Shortcut Handler for Accessing Old Messages -->
|
||||||
|
<script>
|
||||||
|
let chatInput = document.getElementById('chat-input');
|
||||||
|
chatInput.addEventListener('keydown', function(event) {
|
||||||
|
if (event.key === 'ArrowUp') {
|
||||||
|
inputAutoFiller('up');
|
||||||
|
} else if (event.key === 'ArrowDown') {
|
||||||
|
inputAutoFiller('down');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
document.addEventListener('click', function(event) {
|
||||||
|
if (document.activeElement !== document.getElementById('chat-input')) {
|
||||||
|
resetUserMessageIndex();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
</script>
|
||||||
<button id="speak-button" class="input-row-button"
|
<button id="speak-button" class="input-row-button"
|
||||||
ontouchstart="speechToText(event)" ontouchend="speechToText(event)" ontouchcancel="speechToText(event)" onmousedown="speechToText(event)">
|
ontouchstart="speechToText(event)" ontouchend="speechToText(event)" ontouchcancel="speechToText(event)" onmousedown="speechToText(event)">
|
||||||
<svg id="speak-button-img" class="input-row-button-img" alt="Transcribe" xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill="currentColor" viewBox="0 0 16 16">
|
<svg id="speak-button-img" class="input-row-button-img" alt="Transcribe" xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill="currentColor" viewBox="0 0 16 16">
|
||||||
|
|
Loading…
Reference in a new issue