2018-01-05 18:26:57 -08:00
import React from 'react' ;
2018-01-17 15:00:03 -08:00
import ChannelLoginForm from 'containers/ChannelLoginForm' ;
import ChannelCreateForm from 'containers/ChannelCreateForm' ;
2018-01-24 12:02:40 -08:00
import * as states from 'constants/publish_channel_select_states' ;
2018-01-05 18:26:57 -08:00
2018-01-17 10:49:57 -08:00
class ChannelSelect extends React . Component {
2018-01-05 18:26:57 -08:00
constructor ( props ) {
super ( props ) ;
this . toggleAnonymousPublish = this . toggleAnonymousPublish . bind ( this ) ;
2018-01-17 09:46:16 -08:00
this . handleSelection = this . handleSelection . bind ( this ) ;
2018-01-05 18:26:57 -08:00
}
toggleAnonymousPublish ( event ) {
const value = event . target . value ;
if ( value === 'anonymous' ) {
2018-01-09 18:49:26 -08:00
this . props . onPublishInChannelChange ( false ) ;
2018-01-05 18:26:57 -08:00
} else {
2018-01-09 18:49:26 -08:00
this . props . onPublishInChannelChange ( true ) ;
2018-01-05 18:26:57 -08:00
}
}
2018-01-17 09:46:16 -08:00
handleSelection ( event ) {
const selectedOption = event . target . selectedOptions [ 0 ] . value ;
2018-01-19 10:16:55 -08:00
this . props . onChannelSelect ( selectedOption ) ;
2018-01-17 09:46:16 -08:00
}
2018-01-05 18:26:57 -08:00
render ( ) {
return (
2018-01-17 09:46:16 -08:00
< div >
2018-01-24 12:32:24 -08:00
< p id = "input-error-channel-select" className = "info-message-placeholder info-message--failure" > { this . props . channelError } < / p >
2018-01-17 09:46:16 -08:00
< form >
< div className = "column column--3 column--med-10" >
< input type = "radio" name = "anonymous-or-channel" id = "anonymous-radio" className = "input-radio" value = "anonymous" checked = { ! this . props . publishInChannel } onChange = { this . toggleAnonymousPublish } / >
< label className = "label label--pointer" htmlFor = "anonymous-radio" > Anonymous < / label >
< / div >
< div className = "column column--7 column--med-10" >
< input type = "radio" name = "anonymous-or-channel" id = "channel-radio" className = "input-radio" value = "in a channel" checked = { this . props . publishInChannel } onChange = { this . toggleAnonymousPublish } / >
< label className = "label label--pointer" htmlFor = "channel-radio" > In a channel < / label >
< / div >
< / form >
{ this . props . publishInChannel && (
< div >
< div className = "column column--3" >
< label className = "label" htmlFor = "channel-name-select" > Channel : < / label >
< / div > < div className = "column column--7" >
2018-01-19 10:16:55 -08:00
< select type = "text" id = "channel-name-select" className = "select select--arrow" value = { this . props . selectedChannel } onChange = { this . handleSelection } >
2018-01-17 09:46:16 -08:00
{ this . props . loggedInChannelName && < option value = { this . props . loggedInChannelName } id = "publish-channel-select-channel-option" > { this . props . loggedInChannelName } < / option > }
2018-01-19 10:16:55 -08:00
< option value = { states . LOGIN } > Existing < / option >
< option value = { states . CREATE } > New < / option >
2018-01-17 09:46:16 -08:00
< / select >
< / div >
2018-01-19 10:16:55 -08:00
{ ( this . props . selectedChannel === states . LOGIN ) && < ChannelLoginForm / > }
{ ( this . props . selectedChannel === states . CREATE ) && < ChannelCreateForm / > }
2018-01-17 09:46:16 -08:00
< / div >
) }
< / div >
2018-01-05 18:26:57 -08:00
) ;
}
}
2018-01-17 10:49:57 -08:00
export default ChannelSelect ;