2019-09-11 08:06:26 +00:00
|
|
|
import React, { useEffect, useState } from 'react'
|
2019-01-23 17:04:22 +00:00
|
|
|
import emoji from 'react-easy-emoji'
|
2019-09-11 08:06:51 +00:00
|
|
|
import { Trans } from 'react-i18next'
|
2019-11-10 15:57:44 +00:00
|
|
|
import { useSelector } from 'react-redux'
|
2020-03-26 15:03:19 +00:00
|
|
|
import { parsedRulesSelector } from 'Selectors/analyseSelectors'
|
2018-01-30 14:52:25 +00:00
|
|
|
import Overlay from './Overlay'
|
2018-07-12 08:09:41 +00:00
|
|
|
import SearchBar from './SearchBar'
|
2018-01-30 14:52:25 +00:00
|
|
|
|
2019-11-10 15:57:44 +00:00
|
|
|
type SearchButtonProps = {
|
|
|
|
invisibleButton?: boolean
|
|
|
|
}
|
|
|
|
|
|
|
|
export default function SearchButton({ invisibleButton }: SearchButtonProps) {
|
2020-03-26 15:03:19 +00:00
|
|
|
const rules = useSelector(parsedRulesSelector)
|
2019-09-11 08:06:26 +00:00
|
|
|
const [visible, setVisible] = useState(false)
|
|
|
|
useEffect(() => {
|
2019-11-10 15:57:44 +00:00
|
|
|
const handleKeyDown = (e: KeyboardEvent) => {
|
2019-09-15 20:51:13 +00:00
|
|
|
if (!(e.ctrlKey && e.key === 'k')) return
|
|
|
|
setVisible(true)
|
2020-02-07 17:08:09 +00:00
|
|
|
|
2019-09-15 20:51:13 +00:00
|
|
|
e.preventDefault()
|
|
|
|
return false
|
|
|
|
}
|
2019-09-11 08:06:26 +00:00
|
|
|
window.addEventListener('keydown', handleKeyDown)
|
|
|
|
return () => {
|
|
|
|
window.removeEventListener('keydown', handleKeyDown)
|
2018-11-14 15:51:37 +00:00
|
|
|
}
|
2019-09-11 08:06:26 +00:00
|
|
|
}, [])
|
|
|
|
|
|
|
|
const close = () => setVisible(false)
|
|
|
|
|
|
|
|
return visible ? (
|
|
|
|
<Overlay onClose={close}>
|
2020-02-18 14:58:34 +00:00
|
|
|
<h1>
|
2019-09-11 08:06:26 +00:00
|
|
|
<Trans>Chercher dans la documentation</Trans>
|
2020-02-18 14:58:34 +00:00
|
|
|
</h1>
|
2020-03-26 15:03:19 +00:00
|
|
|
<SearchBar showDefaultList={false} finally={close} rules={rules} />
|
2019-09-11 08:06:26 +00:00
|
|
|
</Overlay>
|
|
|
|
) : invisibleButton ? null : (
|
|
|
|
<button
|
|
|
|
className="ui__ simple small button"
|
2019-11-10 15:57:44 +00:00
|
|
|
onClick={() => setVisible(true)}
|
|
|
|
>
|
2019-09-11 08:06:26 +00:00
|
|
|
{emoji('🔍')} <Trans>Rechercher</Trans>
|
|
|
|
</button>
|
|
|
|
)
|
2019-11-10 15:57:44 +00:00
|
|
|
}
|