From 41b7296cdfb3ceb24fe29a2f97bcb195a19a254c Mon Sep 17 00:00:00 2001 From: kevcenteno Date: Wed, 9 Oct 2024 16:58:35 -0400 Subject: [PATCH] Replace custom search with vertex search widget --- assets/js/GoogleSearch.ts | 49 ------------- assets/js/search-results.ts | 106 ---------------------------- assets/js/search.ts | 26 ------- assets/scss/_search-results.scss | 116 ------------------------------- assets/scss/_search.scss | 54 +------------- assets/scss/index.scss | 1 - content/search-results.md | 5 -- layouts/_default/baseof.html | 10 ++- layouts/page/search-results.html | 26 ------- layouts/partials/header.html | 19 +---- static/_headers | 2 +- 11 files changed, 13 insertions(+), 401 deletions(-) delete mode 100644 assets/js/GoogleSearch.ts delete mode 100644 assets/js/search-results.ts delete mode 100644 assets/js/search.ts delete mode 100644 assets/scss/_search-results.scss delete mode 100644 content/search-results.md delete mode 100644 layouts/page/search-results.html diff --git a/assets/js/GoogleSearch.ts b/assets/js/GoogleSearch.ts deleted file mode 100644 index ee7a54552..000000000 --- a/assets/js/GoogleSearch.ts +++ /dev/null @@ -1,49 +0,0 @@ -interface IItems { - cacheId: string; - link: string; - snippet: string; - title: string; -} - -interface IQuery { - count: number; - startIndex: number; - totalResults: string; -} - -export interface ISearchResults { - items?: IItems[]; - queries: { - nextPage?: IQuery[]; - previousPage?: IQuery[]; - request: IQuery[]; - }; - spelling?: { - correctedQuery: string; - }; -} - -const cx = "cde039a7678700a13"; -const key = "AIzaSyAI4atAz3I5ujXCjoEXRvdwqcYn3AIsCA8"; -const url = `https://www.googleapis.com/customsearch/v1/siterestrict?cx=${cx}&key=${key} `; - -const GoogleSearch = async ( - query: string, - startIndex: string | null -): Promise => { - let requestUrl = `${url}&q=${query}`; - - if (startIndex) { - requestUrl = requestUrl + `&start=${startIndex}`; - } - - const response = await fetch(requestUrl); - - if (!response.ok) { - throw new Error(`There was an error searching for ${query}`); - } - - return (await response.json()) as ISearchResults; -}; - -export default GoogleSearch; diff --git a/assets/js/search-results.ts b/assets/js/search-results.ts deleted file mode 100644 index a191c5630..000000000 --- a/assets/js/search-results.ts +++ /dev/null @@ -1,106 +0,0 @@ -import GoogleSearch from "./GoogleSearch"; - -window.addEventListener("DOMContentLoaded", () => { - const loading = document.querySelector(".loading"); - const resultsCount = ( - document.querySelector(".search-results__count") - ); - const resultsHeading = ( - document.querySelector(".search-results__heading") - ); - const resultsList = ( - document.querySelector(".search-results__list") - ); - const searchNext = document.querySelector(".search__next"); - const searchPrev = ( - document.querySelector(".search__previous") - ); - - const searchProperty = window.location.search; - const urlSearchParams = new URLSearchParams(searchProperty); - const query = urlSearchParams.get("query") ?? ""; - const startIndex = urlSearchParams.get("start"); - - const fetchResults = async () => { - try { - const results = await GoogleSearch(query, startIndex); - loading.style.display = "none"; - - if (results.items) { - resultsHeading.textContent = `Search results for ${query}`; - resultsCount.textContent = `Displaying results - ${results.queries.request[0].startIndex} - - - ${ - results.queries.request[0].startIndex + - results.queries.request[0].count - - 1 - } - of - ${results.queries.request[0].totalResults}`; - - results.items.forEach((result) => { - const article = document.createElement("article"); - article.className = "search__result-list-item"; - - const a = document.createElement("a"); - a.className = "search__result-title"; - a.href = `${result.link}`; - a.textContent = `${result.title}`; - - const small = document.createElement("small"); - small.className = "search__result-url"; - small.textContent = `${result.link}`; - - const p = document.createElement("p"); - p.className = "search__result-description"; - p.textContent = `${result.snippet}`; - - resultsList.appendChild(article); - article.appendChild(a); - article.appendChild(small); - article.appendChild(p); - }); - - if (results.queries.nextPage) { - searchNext.style.display = "block"; - - const nextUrl = new URL(document.location.href); - nextUrl.search = new URLSearchParams({ - query: query, - start: results.queries.nextPage[0].startIndex.toString(), - }).toString(); - searchNext.href = nextUrl.toString(); - } - - if (results.queries.previousPage) { - searchPrev.style.display = "block"; - - const prevUrl = new URL(document.location.href); - prevUrl.search = new URLSearchParams({ - query: query, - start: results.queries.previousPage[0].startIndex.toString(), - }).toString(); - searchPrev.href = prevUrl.toString(); - } - } else { - resultsHeading.textContent = `No results found for ${query}`; - } - } catch { - loading.style.display = "none"; - - const p = document.createElement("p"); - p.textContent = "Please try again."; - - resultsHeading.textContent = "There was an issue performing the search."; - resultsHeading.insertAdjacentElement("afterend", p); - } - }; - - if (query.trim() === "") { - loading.style.display = "none"; - resultsHeading.textContent = "Please enter a search query"; - } else { - fetchResults(); - } -}); diff --git a/assets/js/search.ts b/assets/js/search.ts deleted file mode 100644 index e8fd1b262..000000000 --- a/assets/js/search.ts +++ /dev/null @@ -1,26 +0,0 @@ -window.addEventListener('DOMContentLoaded', () => { - const $searchBtn = ( - document.querySelector('.search__button') - ); - const $searchBar = document.querySelector('.searchbar'); - const $searchBarInput = ( - document.querySelector('.searchbar .input') - ); - - $searchBtn.addEventListener('click', () => { - $searchBar.classList.add('searchbar__open'); - $searchBarInput.focus(); - }); - - const showSearchBar = () => { - if ($searchBarInput === document.activeElement) { - $searchBar.classList.add('searchbar__open'); - $searchBtn.style.display = 'none'; - } else { - $searchBar.classList.remove('searchbar__open'); - $searchBtn.style.display = 'block'; - } - }; - - document.body.addEventListener('click', showSearchBar); -}); diff --git a/assets/scss/_search-results.scss b/assets/scss/_search-results.scss deleted file mode 100644 index 9e6e4b897..000000000 --- a/assets/scss/_search-results.scss +++ /dev/null @@ -1,116 +0,0 @@ -/* stylelint-disable no-descending-specificity */ -@use 'variables'; - -@media only screen and (max-width: 992px) { - .search-results__heading { - font-size: 20px; - } -} - -@media only screen and (min-width: 992px) { - .search-results__heading { - font-size: 30px; - } -} - -.search-results { - margin: auto; - max-width: 800px; - padding: 0 var(--mm-spacing) 0; -} - -.search-results__header { - margin-bottom: calc(var(--mm-spacing) / 2); - - .search-results__heading { - color: #00374c; - font-family: var(--mm-font-stack-display); - font-weight: 700; - line-height: 1.2em; - margin: 0; - position: relative; - scroll-margin-top: calc(var(--page-header-height) + var(--mm-spacing)); - } - - .search-results__count { - font-size: 14px; - } - - a { - border-bottom: 2px dotted var(--mm-color-display-text); - color: var(--mm-color-display-text); - - &:hover { - border-bottom-style: solid; - text-decoration: none; - } - } -} - -.search__result-list-item { - margin-bottom: calc(var(--mm-spacing) / 1.5); - -} - -.search__result-title { - color: var(--mm-color-display-text); - display: inline-block; - font-size: 20px; - font-weight: 500; - margin-bottom: 3px; - text-decoration: none; - - &:hover { - cursor: pointer; - text-decoration: underline; - } -} - -.search__result-url { - display: block; - font-size: 12px; - margin-bottom: 3px; -} - -.search__result-description { - font-size: 16px; - font-weight: 400; - margin: 0; -} - -.search__result-heading { - border-top: 1px dashed var(--mm-color-border); - color: #00374c; - font-family: var(--mm-font-stack-display); - font-size: 20px; - font-weight: 500; - line-height: 1.2em; - margin: var(--mm-spacing) 0 calc(var(--mm-spacing) / 2) 0; - padding-top: var(--mm-spacing); -} - -.search__pagination { - padding-bottom: calc(var(--mm-spacing) * 2); - - .search__next, - .search__previous { - color: var(--mm-color-display-text); - font-size: 18px; - text-decoration: none; - - &:hover { - border-bottom: 2px solid var(--mm-color-display-text) !important; - } - } - - .search__next { - display: none; - float: right; - } - - .search__previous { - display: none; - float: left; - } -} - diff --git a/assets/scss/_search.scss b/assets/scss/_search.scss index f204a48d7..d60d504df 100644 --- a/assets/scss/_search.scss +++ b/assets/scss/_search.scss @@ -1,32 +1,5 @@ @use 'mixins'; -.searchbar { - display: none; - position: relative; -} - -.mag { - svg { - color: var(--mm-color-primary-text); - left: calc(var(--mm-spacing) / 2); - position: absolute; - top: 50%; - transform: translateY(-50%); - } -} - -.searchbar__open { - display: inline-block; - left: calc(50% - 20px); - margin: 0 calc(var(--mm-spacing) / 2); - max-width: calc(var(--mm-max-content-width) - var(--mm-spacing) ); - position: absolute; - top: calc(50% + 5px); - transform: translate(-50%, -50%); - width: calc(100% - (var(--mm-spacing))); - z-index: 100; -} - .search { position: relative; } @@ -34,30 +7,9 @@ .search__button { @include mixins.menu-button; float: right; - - svg { - margin-top: 3px; - } -} - -.input { - appearance: none !important; - border: 1px solid var(--mm-color-border); - border-radius: var(--mm-border-radius); - color: var(--mm-color-primary-text); - padding: 12px 10px 12px calc(var(--mm-spacing) + 15px); - width: 100%; - - &::placeholder { - opacity: 0.5; - } - - &:focus { - box-shadow: 0 0 0 2px var(--mm-color-logo-blue-light); - outline: none; - } } -.hidden { - display: none; +.search__button svg { + margin-top: 3px; + pointer-events: none; } diff --git a/assets/scss/index.scss b/assets/scss/index.scss index b1234563f..77ce82af3 100644 --- a/assets/scss/index.scss +++ b/assets/scss/index.scss @@ -6,7 +6,6 @@ @import 'pre'; @import 'loading'; @import 'search'; -@import 'search-results'; @import 'sidebar'; @import 'table'; @import 'variables'; diff --git a/content/search-results.md b/content/search-results.md deleted file mode 100644 index 1e88d0dc2..000000000 --- a/content/search-results.md +++ /dev/null @@ -1,5 +0,0 @@ ---- -title: "Search results" -description: "MaxMind Developer Portal search results page" -layout: "search-results" ---- diff --git a/layouts/_default/baseof.html b/layouts/_default/baseof.html index df5ce085d..d07aba352 100644 --- a/layouts/_default/baseof.html +++ b/layouts/_default/baseof.html @@ -27,11 +27,17 @@ defer src="//js.hs-scripts.com/21266834.js" > + + + + + {{ $codeset := resources.Get "js/codeset.ts" | js.Build }} {{ $geoipCrontab := resources.Get "js/geoip-crontab.ts" | js.Build }} - {{ $search := resources.Get "js/search.ts" | js.Build }} {{ $sidebar := resources.Get "js/sidebar.ts" | js.Build }} - {{ $js := slice $codeset $geoipCrontab $search $sidebar | resources.Concat "js/bundle.js" }} + {{ $js := slice $codeset $geoipCrontab $sidebar | resources.Concat "js/bundle.js" }} diff --git a/layouts/page/search-results.html b/layouts/page/search-results.html deleted file mode 100644 index 6cda36625..000000000 --- a/layouts/page/search-results.html +++ /dev/null @@ -1,26 +0,0 @@ -{{ define "main" }} -
-
- {{ partial "sidebar.html" . }} -
-
-
- {{ partial "loading" . }} -
-

-

- -
-
-
- -
- {{ $searchResults := resources.Get "js/search-results.ts" | js.Build }} - -
-
-{{ end }} - diff --git a/layouts/partials/header.html b/layouts/partials/header.html index 8590c9e5e..92adbf1e1 100644 --- a/layouts/partials/header.html +++ b/layouts/partials/header.html @@ -15,25 +15,8 @@ Developers