doc.silverstripe.org/src/components/SearchBox.tsx

76 lines
2.2 KiB
TypeScript

import React from 'react'
import { StatelessComponent, ReactElement, useEffect, useState } from 'react';
import { navigateTo } from "gatsby-link"
import useHierarchy from '../hooks/useHierarchy';
import useDocContext from '../hooks/useDocContext';
import { useStaticQuery, graphql } from 'gatsby';
interface SearchBoxProps {
identifier: string;
}
const autocompleteSelected = (e) => {
e.stopPropagation()
// Use an anchor tag to parse the absolute url (from autocomplete.js) into a relative url
// eslint-disable-next-line no-undef
const a = document.createElement(`a`)
a.href = e._args[0].url
navigateTo(`${a.pathname}${a.hash}`)
};
const SearchBox: StatelessComponent<SearchBoxProps> = ({ identifier }): ReactElement|null => {
const { getCurrentVersion } = useHierarchy();
const [ isFocused, setFocus ] = useState(false);
const context = useDocContext();
useEffect(() => {
if (typeof window === 'undefined') return;
if (!process.env.GATSBY_DOCSEARCH_API_KEY) {
return;
}
window.addEventListener(
`autocomplete:selected`,
autocompleteSelected,
true
);
if(window.docsearch){
window.docsearch({
algoliaOptions: {
facetFilters: [
`version:${getCurrentVersion()}`,
//`context:${context}`,
],
hitsPerPage: 5,
},
apiKey: process.env.GATSBY_DOCSEARCH_API_KEY,
debug: true,
indexName: process.env.GATSBY_DOCSEARCH_INDEX,
inputSelector: `#${identifier}`,
});
}
}, []);
const handleFocus = () => setFocus(true);
const handleBlur = (e) => {
if (!e.target.value.trim()) {
setFocus(false);
}
};
return (
<>
<label className={ isFocused ? `hide` : `show` } htmlFor={identifier}>Search...</label>
<input
id={identifier}
type="search"
className="form-control search-input"
onFocus={handleFocus}
onBlur={handleBlur}
/>
</>
)
};
export default SearchBox;