From 712dab5c8cd8933d9cdb63d4c833940c461a09da Mon Sep 17 00:00:00 2001
From: Jacky Zhao <j.zhao2k19@gmail.com>
Date: Tue, 31 Jan 2023 19:00:28 +0000
Subject: [PATCH] docs: remove broken links from showcase
---
assets/js/semantic-search.js | 66 ++++++++++++++++++++------------
1 files changed, 41 insertions(+), 25 deletions(-)
diff --git a/assets/js/semantic-search.js b/assets/js/semantic-search.js
index 4382817..fca2851 100644
--- a/assets/js/semantic-search.js
+++ b/assets/js/semantic-search.js
@@ -1,38 +1,54 @@
-const apiKey = "{{$.Site.Data.config.operandApiKey}}"
+// Note: Currently, we use the REST API for Operand because of some unpkg/webpack issues.
+// In the future, we'd like to use the SDK (https://github.com/operandinc/typescript-sdk).
+// If someone knows how to do this w/o breaking the Operand typescript-sdk for npm users,
+// please let Morgan (@morgallant) and/or (@_jzhao) know! <3
+
+const apiKey = "{{$.Site.Data.config.search.operandApiKey}}"
+const indexId = "{{$.Site.Data.config.search.operandIndexId}}"
+
+function parseSearchResults(searchResults) {
+ return searchResults.matches.map((m) => ({
+ content: m.content,
+ title: searchResults.objects[m.objectId].properties.properties._title.text,
+ url: searchResults.objects[m.objectId].properties.properties._url.text,
+ }))
+}
async function searchContents(query) {
- const response = await fetch('https://prod.operand.ai/v3/search/objects', {
- method: 'POST',
+ const result = await fetch("https://api.operand.ai/operand.v1.ObjectService/SearchWithin", {
+ method: "POST",
headers: {
- 'Content-Type': 'application/json',
- Authorization: apiKey,
+ "Content-Type": "application/json",
+ Authorization: `${apiKey}`,
+ "Operand-Index-ID": `${indexId}`,
},
body: JSON.stringify({
- query,
- max: 10
+ query: query,
+ limit: 10,
}),
- });
- return (await response.json());
+ })
+ if (result.ok) {
+ return parseSearchResults(await result.json())
+ } else {
+ console.error(result)
+ }
}
function debounce(func, timeout = 200) {
- let timer;
+ let timer
return (...args) => {
clearTimeout(timer)
- timer = setTimeout(() => { func.apply(this, args); }, timeout)
- };
+ timer = setTimeout(() => {
+ func.apply(this, args)
+ }, timeout)
+ }
}
-registerHandlers(debounce((e) => {
- term = e.target.value
- if (term !== "") {
- searchContents(term)
- .then((res) => res.results.map(entry => ({
- url: entry.object.properties.url,
- content: entry.snippet,
- title: entry.object.metadata.title
- })
- ))
- .then(results => displayResults(results))
- }
-}))
+registerHandlers(
+ debounce((e) => {
+ let term = e.target.value
+ if (term !== "") {
+ searchContents(term).then((results) => displayResults(term, results))
+ }
+ }),
+)
--
Gitblit v1.10.0