2018-01-05 18:26:57 -08:00
|
|
|
import React from 'react';
|
2018-01-19 12:11:38 -08:00
|
|
|
import ExpandingTextArea from 'components/ExpandingTextArea';
|
2018-01-05 18:26:57 -08:00
|
|
|
|
2018-01-17 10:49:57 -08:00
|
|
|
class PublishMetadataInputs extends React.Component {
|
2018-01-05 18:26:57 -08:00
|
|
|
constructor (props) {
|
|
|
|
super(props);
|
|
|
|
this.toggleShowInputs = this.toggleShowInputs.bind(this);
|
2018-01-19 16:03:49 -08:00
|
|
|
this.handleInput = this.handleInput.bind(this);
|
|
|
|
this.handleSelect = this.handleSelect.bind(this);
|
2018-01-05 18:26:57 -08:00
|
|
|
}
|
|
|
|
toggleShowInputs () {
|
2018-01-19 16:03:49 -08:00
|
|
|
this.props.onToggleMetadataInputs(!this.props.showMetadataInputs);
|
2018-01-05 18:26:57 -08:00
|
|
|
}
|
2018-01-19 16:03:49 -08:00
|
|
|
handleInput (event) {
|
|
|
|
const target = event.target;
|
|
|
|
const value = target.type === 'checkbox' ? target.checked : target.value;
|
|
|
|
const name = target.name;
|
2018-01-10 13:10:08 -08:00
|
|
|
this.props.onMetadataChange(name, value);
|
2018-01-08 09:39:59 -08:00
|
|
|
}
|
2018-01-19 16:03:49 -08:00
|
|
|
handleSelect (event) {
|
2018-01-10 13:10:08 -08:00
|
|
|
const name = event.target.name;
|
2018-01-08 17:06:31 -08:00
|
|
|
const selectedOption = event.target.selectedOptions[0].value;
|
2018-01-10 13:10:08 -08:00
|
|
|
this.props.onMetadataChange(name, selectedOption);
|
2018-01-08 17:06:31 -08:00
|
|
|
}
|
2018-01-05 18:26:57 -08:00
|
|
|
render () {
|
|
|
|
return (
|
2018-03-07 20:31:10 -08:00
|
|
|
<div id='publish-details' className='row row--padded row--no-top row--wide'>
|
|
|
|
{this.props.showMetadataInputs && (
|
|
|
|
<div>
|
|
|
|
<div className='row row--no-top'>
|
|
|
|
<div className='column column--3 column--med-10 align-content-top'>
|
|
|
|
<label htmlFor='publish-license' className='label'>Description:</label>
|
|
|
|
</div><div className='column column--7 column--sml-10'>
|
|
|
|
<ExpandingTextArea
|
|
|
|
id='publish-description'
|
|
|
|
className='textarea textarea--primary textarea--full-width'
|
|
|
|
rows={1}
|
|
|
|
maxLength={2000}
|
|
|
|
style={{ maxHeight: 200 }}
|
|
|
|
name='description'
|
|
|
|
placeholder='Optional description'
|
|
|
|
value={this.props.description}
|
|
|
|
onChange={this.handleInput} />
|
|
|
|
</div>
|
2018-01-08 09:39:59 -08:00
|
|
|
</div>
|
|
|
|
|
2018-03-07 20:31:10 -08:00
|
|
|
<div className='row row--no-top'>
|
|
|
|
<div className='column column--3 column--med-10'>
|
|
|
|
<label htmlFor='publish-license' className='label'>License:</label>
|
|
|
|
</div><div className='column column--7 column--sml-10'>
|
|
|
|
<select type='text' name='license' id='publish-license' className='select select--primary' onChange={this.handleSelect}>
|
|
|
|
<option value=' '>Unspecified</option>
|
|
|
|
<option value='Public Domain'>Public Domain</option>
|
|
|
|
<option value='Creative Commons'>Creative Commons</option>
|
|
|
|
</select>
|
|
|
|
</div>
|
2018-01-08 09:39:59 -08:00
|
|
|
</div>
|
|
|
|
|
2018-03-07 20:31:10 -08:00
|
|
|
<div className='row row--no-top'>
|
|
|
|
<div className='column column--3'>
|
|
|
|
<label htmlFor='publish-nsfw' className='label'>Mature:</label>
|
|
|
|
</div><div className='column column--7'>
|
|
|
|
<input className='input-checkbox' type='checkbox' id='publish-nsfw' name='nsfw' value={this.props.nsfw} onChange={this.handleInput} />
|
|
|
|
</div>
|
2018-01-08 09:39:59 -08:00
|
|
|
</div>
|
2018-01-05 18:26:57 -08:00
|
|
|
</div>
|
2018-03-07 20:31:10 -08:00
|
|
|
)}
|
|
|
|
<button className='button--secondary' onClick={this.toggleShowInputs}>{this.props.showMetadataInputs ? 'less' : 'more'}</button>
|
2018-01-05 18:26:57 -08:00
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-01-17 10:49:57 -08:00
|
|
|
export default PublishMetadataInputs;
|