import React, { Component } from 'react' import { Trans, translate } from 'react-i18next' import { connect } from 'react-redux' import { flatRulesSelector } from 'Selectors/analyseSelectors' import { LinkButton } from 'Ui/Button' import Overlay from './Overlay' import SearchBar from './SearchBar' import './SearchButton.css' @connect(state => ({ flatRules: flatRulesSelector(state) })) @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 === 'k')) 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 this.state.visible ? (

Chercher une règle

) : ( this.setState({ visible: true })} className={this.props.className} style={this.props.style}>