Files
khoj/src/interface/web/index.html
Debanjum Singh Solanky 31a221a76b Auto focus cursor on query input box to simplify, speed interactions
- Avoids having to click the query input box
- Just open page, type whatever and hit enter to do image search
  - For other search types select appropriate type from dropdown
2022-07-16 19:39:15 +04:00

124 lines
3.6 KiB
HTML

<html>
<head>
<meta charset="utf-8">
<title>Semantic Search</title>
</head>
<script>
function render_image(item) {
return `
<a href="${item.entry}" class="image-link">
<img id=${item.score} src="${item.entry}?${Math.random()}"
title="Effective Score: ${item.score}, Meta: ${item.metadata_score}, Image: ${item.image_score}"
class="image">
</a>`
}
function render_json(data) {
return `<pre id="json">${JSON.stringify(data, null, 2)}</pre>`
}
function search() {
query = document.getElementById("query").value;
type = document.getElementById("type").value;
console.log(query, type);
fetch(`/search?q=${query}&t=${type}&n=6`)
.then(response => response.json())
.then(data => {
console.log(data);
document.getElementById("results").innerHTML =
type == "image"
? data.map(render_image).join('')
: render_json(data);
});
}
function regenerate() {
type = document.getElementById("type").value;
fetch(`/regenerate?t=${type}`)
.then(response => response.json())
.then(data => {
console.log(data);
document.getElementById("results").innerHTML =
render_json(data);
});
}
function search_on_enter(event) {
if (event.key == 'Enter') {
search();
}
}
</script>
<body>
<h1>Semantic Search</h1>
<!--Add Text Box To Enter Query -->
<input id="query" type="text" placeholder="Search" onkeydown=search_on_enter(event) autofocus>
<!--Add Dropdown to Select Query Type.
Query Types can be: notes, ledger, images, music.
Set Default type to images-->
<select id="type">
<option value="image">Image</option>
<option value="notes">Notes</option>
<option value="ledger">Ledger</option>
<option value="music">Music</option>
</select>
<!--Add Button To Search -->
<button id="search" onclick="search()">Search</button>
<!--Add Button To Regenerate -->
<button id="regenerate" onclick="regenerate()">Regenerate</button>
<!-- Section to Render Results -->
<div id="results"></div>
</body>
<style>
body {
display: grid;
grid-template-columns: 1fr min(70vw, 100%) 1fr;
margin: 0px;
padding: 0px;
background: #eee;
color: #888;
text-align: center;
font-family: roboto, karma, segoe ui, sans-serif;
font-size: 20px;
font-weight: 300;
line-height: 1.5em;
}
body > * {
grid-column: 2;
padding: 10px;
margin: 10px;
}
h1 {
font-weight: 200;
color: #888;
}
button {
border-radius: 5px;
border: 1px solid #ccc;
}
#results {
display: grid;
grid-template-columns: repeat(3, 1fr);
}
.image-link {
place-self: center;
}
.image {
width: 20vw;
border-radius: 10px;
border: 1px solid #ccc;
}
#json {
white-space: pre-wrap;
}
</style>
</html>