import React, { PropTypes } from 'react' import ReactDOM from 'react-dom' import linkState from 'boost/linkState' import { createFolder } from 'boost/actions' import store from 'boost/store' import FolderMark from 'boost/components/FolderMark' export default class CreateNewFolder extends React.Component { constructor (props) { super(props) this.state = { name: '', color: Math.round(Math.random() * 7), alert: null } } componentDidMount () { ReactDOM.findDOMNode(this.refs.folderName).focus() } handleCloseButton (e) { this.props.close() } handleConfirmButton (e) { this.setState({alert: null}, () => { let { close } = this.props let { name, color } = this.state let input = { name, color } try { store.dispatch(createFolder(input)) } catch (e) { this.setState({alert: { type: 'error', message: e.message }}) return } close() }) } handleColorClick (colorIndex) { return e => { this.setState({ color: colorIndex }) } } handleKeyDown (e) { if (e.keyCode === 13) { this.handleConfirmButton() } } render () { let alert = this.state.alert let alertElement = alert != null ? (

{alert.message}

) : null let colorIndexes = [] for (let i = 0; i < 8; i++) { colorIndexes.push(i) } let colorElements = colorIndexes.map(index => { let className = 'option' if (index === this.state.color) className += ' active' return ( this.handleColorClick(index)(e)}> ) }) return (
Create new folder
this.handleKeyDown(e)} className='ipt' type='text' valueLink={this.linkState('name')} placeholder='Enter folder name'/>
{colorElements}
{alertElement}
) } } CreateNewFolder.propTypes = { close: PropTypes.func } CreateNewFolder.prototype.linkState = linkState