1
0
mirror of https://github.com/BoostIo/Boostnote synced 2025-12-14 10:16:26 +00:00
Files
Boostnote/browser/main/Components/PlanetNavigator.jsx
2015-07-19 03:19:41 +09:00

68 lines
1.8 KiB
JavaScript

var React = require('react/addons')
var ModalBase = require('../Components/ModalBase')
var LaunchModal = require('../Components/LaunchModal')
var PlanetNavigator = React.createClass({
propTypes: {
currentPlanet: React.PropTypes.shape({
name: React.PropTypes.string
}),
currentUser: React.PropTypes.shape({
name: React.PropTypes.string
})
},
getInitialState: function () {
return {
isLaunchModalOpen: false
}
},
handleKeyDown: function (e) {
if (e.keyCode === 13 && e.metaKey) {
e.preventDefault()
this.openLaunchModal()
}
},
componentDidMount: function () {
document.addEventListener('keydown', this.handleKeyDown, false)
},
componentWillUnmount: function () {
document.removeEventListener('keydown', this.handleKeyDown, false)
},
openLaunchModal: function () {
this.setState({isLaunchModalOpen: true})
},
closeLaunchModal: function () {
this.setState({isLaunchModalOpen: false})
},
submitLaunchModal: function (ret) {
console.log(ret)
this.setState({isLaunchModalOpen: false})
},
render: function () {
return (
<div className='PlanetNavigator'>
<button onClick={this.openLaunchModal} className='btn-primary btn-block'>
<i className='fa fa-rocket fa-fw'/> Launch
</button>
<ModalBase isOpen={this.state.isLaunchModalOpen} close={this.closeLaunchModal}>
<LaunchModal submit={this.submitLaunchModal} close={this.closeLaunchModal}/>
</ModalBase>
<nav>
<a>
<i className='fa fa-home fa-fw'/> Home
</a>
<a>
<i className='fa fa-code fa-fw'/> Snippets
</a>
<a>
<i className='fa fa-file-text-o fa-fw'/> Blueprints
</a>
</nav>
</div>
)
}
})
module.exports = PlanetNavigator