mirror of
https://github.com/explosion/spaCy.git
synced 2025-01-10 17:26:42 +03:00
55 lines
1.5 KiB
JavaScript
55 lines
1.5 KiB
JavaScript
import React, { useEffect, useState } from 'react'
|
|
import PropTypes from 'prop-types'
|
|
import { window } from 'browser-monads'
|
|
|
|
import Icon from './icon'
|
|
import classes from '../styles/search.module.sass'
|
|
|
|
const Search = ({ id, placeholder, settings }) => {
|
|
const { apiKey, indexName } = settings
|
|
if (!apiKey && !indexName) return null
|
|
const [initialized, setInitialized] = useState(false)
|
|
useEffect(() => {
|
|
if (!initialized) {
|
|
setInitialized(true)
|
|
window.docsearch({
|
|
apiKey,
|
|
indexName,
|
|
inputSelector: `#${id}`,
|
|
debug: false,
|
|
})
|
|
}
|
|
}, [initialized, apiKey, indexName, id])
|
|
return (
|
|
<form className={classes.root}>
|
|
<label htmlFor={id} className={classes.icon}>
|
|
<Icon name="search" width={20} />
|
|
</label>
|
|
<input
|
|
id={id}
|
|
className={classes.input}
|
|
type="search"
|
|
placeholder={placeholder}
|
|
aria-label={placeholder}
|
|
/>
|
|
</form>
|
|
)
|
|
}
|
|
|
|
Search.defaultProps = {
|
|
id: 'docsearch',
|
|
placeholder: 'Search docs',
|
|
settings: {},
|
|
}
|
|
|
|
Search.propTypes = {
|
|
settings: PropTypes.shape({
|
|
apiKey: PropTypes.string.isRequired,
|
|
indexName: PropTypes.string.isRequired,
|
|
}).isRequired,
|
|
id: PropTypes.string.isRequired,
|
|
placeholder: PropTypes.string.isRequired,
|
|
}
|
|
|
|
export default Search
|