2016-03-22 00:25:23 +01:00
|
|
|
import React from 'react';
|
2016-04-21 11:59:44 +02:00
|
|
|
import SilverStripeComponent from 'lib/SilverStripeComponent';
|
2016-03-22 00:25:23 +01:00
|
|
|
|
2016-04-21 11:59:44 +02:00
|
|
|
class TextField extends SilverStripeComponent {
|
2016-03-22 00:25:23 +01:00
|
|
|
|
2016-03-30 23:45:54 +02:00
|
|
|
constructor(props) {
|
|
|
|
super(props);
|
|
|
|
|
|
|
|
this.handleChange = this.handleChange.bind(this);
|
|
|
|
}
|
|
|
|
|
|
|
|
render() {
|
2016-04-12 06:47:24 +02:00
|
|
|
const labelText = this.props.leftTitle !== null
|
|
|
|
? this.props.leftTitle
|
|
|
|
: this.props.title;
|
|
|
|
|
2016-04-21 04:38:02 +02:00
|
|
|
let field = null;
|
|
|
|
if (this.props.readOnly) {
|
|
|
|
field = <div><i>{this.props.value}</i></div>;
|
|
|
|
} else {
|
|
|
|
field = <input {...this.getInputProps()} />;
|
|
|
|
}
|
|
|
|
|
2016-03-30 23:45:54 +02:00
|
|
|
return (
|
|
|
|
<div className="field text">
|
2016-04-12 06:47:24 +02:00
|
|
|
{labelText &&
|
2016-03-30 23:45:54 +02:00
|
|
|
<label className="left" htmlFor={`gallery_${this.props.name}`}>
|
2016-04-12 06:47:24 +02:00
|
|
|
{labelText}
|
2016-03-30 23:45:54 +02:00
|
|
|
</label>
|
2016-03-22 00:25:23 +01:00
|
|
|
}
|
2016-03-30 23:45:54 +02:00
|
|
|
<div className="middleColumn">
|
2016-04-21 04:38:02 +02:00
|
|
|
{field}
|
2016-03-30 23:45:54 +02:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
getInputProps() {
|
|
|
|
return {
|
|
|
|
className: ['text', this.props.extraClass].join(' '),
|
|
|
|
id: `gallery_${this.props.name}`,
|
|
|
|
name: this.props.name,
|
2016-04-12 06:47:24 +02:00
|
|
|
onChange: this.handleChange,
|
2016-03-30 23:45:54 +02:00
|
|
|
type: 'text',
|
|
|
|
value: this.props.value,
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2016-04-12 06:47:24 +02:00
|
|
|
/**
|
|
|
|
* Handles changes to the text field's value.
|
|
|
|
*
|
|
|
|
* @param object event
|
|
|
|
*/
|
|
|
|
handleChange(event) {
|
|
|
|
if (typeof this.props.handleFieldUpdate === 'undefined') {
|
2016-03-30 23:45:54 +02:00
|
|
|
return;
|
2016-03-22 00:25:23 +01:00
|
|
|
}
|
2016-03-30 23:45:54 +02:00
|
|
|
|
2016-04-12 06:47:24 +02:00
|
|
|
this.props.handleFieldUpdate(event, { id: this.props.id, value: event.target.value });
|
2016-03-30 23:45:54 +02:00
|
|
|
}
|
2016-03-22 00:25:23 +01:00
|
|
|
}
|
|
|
|
|
2016-04-21 11:59:44 +02:00
|
|
|
TextField.propTypes = {
|
2016-04-12 06:47:24 +02:00
|
|
|
leftTitle: React.PropTypes.string,
|
2016-03-30 23:45:54 +02:00
|
|
|
extraClass: React.PropTypes.string,
|
|
|
|
name: React.PropTypes.string.isRequired,
|
2016-04-12 06:47:24 +02:00
|
|
|
handleFieldUpdate: React.PropTypes.func,
|
2016-03-30 23:45:54 +02:00
|
|
|
value: React.PropTypes.string,
|
2016-04-21 04:38:02 +02:00
|
|
|
readOnly: React.PropTypes.bool,
|
2016-03-22 00:25:23 +01:00
|
|
|
};
|
|
|
|
|
2016-04-21 11:59:44 +02:00
|
|
|
export default TextField;
|