2016-06-18 21:53:18 +02:00
|
|
|
'use strict';
|
|
|
|
const React = require('react');
|
2014-11-03 21:27:47 +01:00
|
|
|
|
2016-06-18 21:53:18 +02:00
|
|
|
const TextInput = React.createClass({
|
2014-11-03 21:27:47 +01:00
|
|
|
propTypes: {
|
|
|
|
name: React.PropTypes.string.isRequired,
|
|
|
|
label: React.PropTypes.string.isRequired,
|
|
|
|
id: React.PropTypes.string.isRequired,
|
|
|
|
placeholder: React.PropTypes.string,
|
|
|
|
value: React.PropTypes.string,
|
|
|
|
required: React.PropTypes.bool
|
|
|
|
},
|
|
|
|
|
2016-06-18 21:53:18 +02:00
|
|
|
getDefaultProps() {
|
2014-11-03 21:27:47 +01:00
|
|
|
return {
|
|
|
|
required: false
|
|
|
|
};
|
|
|
|
},
|
|
|
|
|
2016-06-18 21:53:18 +02:00
|
|
|
getInitialState() {
|
2014-11-03 21:27:47 +01:00
|
|
|
return {};
|
|
|
|
},
|
|
|
|
|
2016-06-18 21:53:18 +02:00
|
|
|
getValue() {
|
2014-11-03 21:27:47 +01:00
|
|
|
return this.refs.input.getDOMNode().value.trim();
|
|
|
|
},
|
|
|
|
|
|
|
|
|
2016-06-18 21:53:18 +02:00
|
|
|
render() {
|
2014-11-03 21:27:47 +01:00
|
|
|
return (
|
2014-11-03 21:37:40 +01:00
|
|
|
<div className="formelement required">
|
2014-12-03 14:19:28 +01:00
|
|
|
<label htmlFor={this.props.id} className="t4">{this.props.label}</label>
|
2014-11-03 21:27:47 +01:00
|
|
|
<div className="input">
|
|
|
|
<input type="text"
|
|
|
|
id={this.props.id}
|
|
|
|
name={this.props.name}
|
|
|
|
defaultValue={this.props.value}
|
|
|
|
placeholder={this.props.placeholder}
|
2014-11-29 11:43:41 +01:00
|
|
|
disabled={this.props.disabled}
|
2014-11-03 21:27:47 +01:00
|
|
|
ref="input" />
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
module.exports = TextInput;
|