2014-11-09 18:12:03 +00:00
|
|
|
/*jshint browser:true */
|
2014-11-08 17:52:36 +00:00
|
|
|
/*globals App, React */
|
|
|
|
|
|
|
|
(function () {
|
|
|
|
'use strict';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sidebar controls
|
|
|
|
*
|
|
|
|
* @prop {playing: bool} Whether a song is playing or not
|
|
|
|
* @prop {opened: bool} Whether a file is opened
|
|
|
|
* @prop {speed: number} Current speed rate
|
|
|
|
* @prop {play: function} Called to start playback
|
|
|
|
* @prop {pause: function} Called to pause playback
|
2014-12-21 20:21:43 +00:00
|
|
|
* @prop {halt: function} Called to temporarily halt playback
|
|
|
|
* @prop {resume: function} Called to resume halted playback
|
2014-11-08 17:52:36 +00:00
|
|
|
* @prop {showChannelsModal: function} Called to show channels manager
|
|
|
|
* @prop {setPlaySpeed: function} Called to set play speed
|
|
|
|
* @prop {close: function} Called to close
|
|
|
|
*/
|
|
|
|
App.components.create({
|
|
|
|
displayName: 'Control',
|
|
|
|
mixins: [React.addons.PureRenderMixin],
|
|
|
|
|
|
|
|
propTypes: {
|
|
|
|
playing: React.PropTypes.bool,
|
|
|
|
opened: React.PropTypes.bool,
|
|
|
|
speed: React.PropTypes.number,
|
|
|
|
|
|
|
|
play: React.PropTypes.func,
|
|
|
|
pause: React.PropTypes.func,
|
2014-12-21 20:21:43 +00:00
|
|
|
halt: React.PropTypes.func,
|
|
|
|
resume: React.PropTypes.func,
|
|
|
|
|
2014-11-08 17:52:36 +00:00
|
|
|
showChannelsModal: React.PropTypes.func,
|
|
|
|
setPlaySpeed: React.PropTypes.func,
|
|
|
|
close: React.PropTypes.func
|
|
|
|
},
|
|
|
|
|
|
|
|
getDefaultProps: function () {
|
|
|
|
return {
|
|
|
|
playing: false,
|
|
|
|
opened: false,
|
|
|
|
|
|
|
|
play: function () {},
|
|
|
|
pause: function () {},
|
2014-12-21 20:21:43 +00:00
|
|
|
halt: function () {},
|
|
|
|
resume: function () {},
|
|
|
|
|
2014-11-08 17:52:36 +00:00
|
|
|
showChannelsModal: function () {},
|
|
|
|
setPlaySpeed: function () {},
|
|
|
|
close: function () {}
|
|
|
|
};
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Keyboard shortcuts
|
|
|
|
*/
|
|
|
|
componentDidMount: function () {
|
|
|
|
window.addEventListener('keyup', this.keyUp);
|
|
|
|
},
|
|
|
|
|
|
|
|
componentWillUnmount: function () {
|
|
|
|
window.removeEventListener('keyup', this.keyUp);
|
|
|
|
},
|
|
|
|
|
|
|
|
keyUp: function (e) {
|
|
|
|
var code = e.keyCode, index;
|
|
|
|
|
|
|
|
// space: switch state
|
|
|
|
if (code === 32) {
|
|
|
|
this.switchPlayState();
|
|
|
|
e.preventDefault();
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Delegates
|
|
|
|
*/
|
|
|
|
switchPlayState: function () {
|
|
|
|
if (this.props.playing) {
|
|
|
|
this.props.pause();
|
|
|
|
} else {
|
|
|
|
this.props.play();
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Render control
|
|
|
|
*/
|
|
|
|
render: function () {
|
|
|
|
var controls = [];
|
|
|
|
|
|
|
|
if (this.props.opened) {
|
|
|
|
controls.push(React.DOM.button({
|
|
|
|
key: 'switchPlayState',
|
2014-11-09 21:59:46 +00:00
|
|
|
className: 'bt icon ' + ((this.props.playing) ?
|
|
|
|
'switch-play-state pause' : 'switch-play-state'),
|
2014-11-08 17:52:36 +00:00
|
|
|
onClick: this.switchPlayState
|
|
|
|
}, 'Play/pause'));
|
|
|
|
|
|
|
|
controls.push(React.DOM.button({
|
|
|
|
key: 'openChannelsWindow',
|
2014-11-09 21:59:46 +00:00
|
|
|
className: 'bt icon open-channels-window',
|
2014-11-08 17:52:36 +00:00
|
|
|
onClick: this.props.showChannelsModal
|
|
|
|
}, 'Ouvrir le gestionnaire de canaux'));
|
|
|
|
|
|
|
|
controls.push(App.components.UI.Selector({
|
|
|
|
key: 'setPlaySpeed',
|
2014-12-21 20:21:43 +00:00
|
|
|
className: 'bt set-play-speed',
|
2014-11-08 17:52:36 +00:00
|
|
|
|
|
|
|
values: [1, 0.5, 0.3, 1, 2, 3],
|
|
|
|
value: this.props.speed,
|
|
|
|
|
|
|
|
onChange: this.props.setPlaySpeed
|
|
|
|
}));
|
|
|
|
|
|
|
|
controls.push(React.DOM.button({
|
|
|
|
key: 'close',
|
2014-11-09 21:59:46 +00:00
|
|
|
className: 'bt icon close',
|
2014-11-08 17:52:36 +00:00
|
|
|
|
|
|
|
onClick: this.props.close
|
|
|
|
}));
|
|
|
|
} else {
|
|
|
|
controls.push(React.DOM.button({
|
|
|
|
key: 'close',
|
2014-11-09 21:59:46 +00:00
|
|
|
className: 'bt icon close',
|
2014-11-08 17:52:36 +00:00
|
|
|
|
|
|
|
onClick: window.close
|
|
|
|
}));
|
|
|
|
}
|
|
|
|
|
|
|
|
return React.DOM.div({
|
|
|
|
className: 'control'
|
|
|
|
}, controls);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}());
|