// Package imports. import PropTypes from 'prop-types'; import React from 'react'; import ImmutablePropTypes from 'react-immutable-proptypes'; import classNames from 'classnames'; // Actions. import { openModal } from 'flavours/glitch/actions/modal'; import { changeSearch, clearSearch, showSearch, submitSearch, } from 'flavours/glitch/actions/search'; import { cycleElefriendCompose } from 'flavours/glitch/actions/compose'; // Components. import Composer from 'flavours/glitch/features/composer'; import DrawerAccount from './account'; import DrawerHeader from './header'; import DrawerResults from './results'; import DrawerSearch from './search'; // Utils. import { me } from 'flavours/glitch/util/initial_state'; import { wrap } from 'flavours/glitch/util/redux_helpers'; // State mapping. const mapStateToProps = state => ({ account: state.getIn(['accounts', me]), columns: state.getIn(['settings', 'columns']), elefriend: state.getIn(['compose', 'elefriend']), results: state.getIn(['search', 'results']), searchHidden: state.getIn(['search', 'hidden']), searchValue: state.getIn(['search', 'value']), submitted: state.getIn(['search', 'submitted']), }); // Dispatch mapping. const mapDispatchToProps = { onChange: changeSearch, onClear: clearSearch, onClickElefriend: cycleElefriendCompose, onShow: showSearch, onSubmit: submitSearch, onOpenSettings: openModal.bind(null, 'SETTINGS', {}), }; // The component. class Drawer extends React.Component { // Constructor. constructor (props) { super(props); } // Rendering. render () { const { account, columns, elefriend, intl, multiColumn, onChange, onClear, onClickElefriend, onOpenSettings, onShow, onSubmit, results, searchHidden, searchValue, submitted, } = this.props; const computedClass = classNames('drawer', `mbstobon-${elefriend}`); // The result. return (