mon-entreprise/source/components/SearchButton.js

59 lines
1.5 KiB
JavaScript
Raw Normal View History

import React, { Component } from 'react'
2018-03-29 13:53:52 +00:00
import { Trans, translate } from 'react-i18next'
import { connect } from 'react-redux'
import './SearchButton.css'
import Overlay from './Overlay'
import { SearchBar } from './pages/RulesList'
import withColours from 'Components/withColours'
@connect(
state => ({
flatRules: state.flatRules
})
)
@withColours
2018-03-29 13:53:52 +00:00
@translate()
export default class SearchButton extends Component {
componentDidMount() {
// removeEventListener will need the exact same function instance
this.boundHandleKeyDown = this.handleKeyDown.bind(this)
window.addEventListener('keydown', this.boundHandleKeyDown)
}
handleKeyDown(e) {
if (!(e.ctrlKey && e.key === 'p')) return
this.setState({ visible: true })
e.preventDefault()
e.stopPropagation()
return false
}
componentWillUnmount() {
window.removeEventListener('keydown', this.boundHandleKeyDown)
}
state = {
visible: false
}
close = () => this.setState({ visible: false })
render() {
let { flatRules } = this.props
return (
<div id="searchButton">
{this.state.visible ? (
<Overlay onOuterClick={this.close}>
2018-03-29 13:53:52 +00:00
<h2><Trans>Chercher une règle</Trans></h2>
<SearchBar showDefaultList={false} finally={this.close} rules={flatRules} />
</Overlay>
) : (
<button
onClick={() => this.setState({ visible: true })}
style={{ color: this.props.colours.colour }}
>
2018-04-24 13:09:36 +00:00
<i className="fa fa-search" aria-hidden="true" />
<span> <Trans>Recherche</Trans></span>
</button>
)}
</div>
)
}
}