mirror of
https://github.com/ascribe/onion.git
synced 2024-11-15 17:45:10 +01:00
509aa111ab
Conflicts: gulpfile.js added notifications cleaned up proptypes
46 lines
1.2 KiB
JavaScript
46 lines
1.2 KiB
JavaScript
'use strict';
|
|
|
|
import React from 'react';
|
|
|
|
import AlertMixin from '../../mixins/alert_mixin';
|
|
|
|
let InputText = React.createClass({
|
|
propTypes: {
|
|
submitted: React.PropTypes.bool,
|
|
onBlur: React.PropTypes.func,
|
|
type: React.PropTypes.string,
|
|
required: React.PropTypes.string,
|
|
placeHolder: React.PropTypes.string
|
|
},
|
|
|
|
mixins: [AlertMixin],
|
|
|
|
getInitialState() {
|
|
return {value: null,
|
|
alerts: null // needed in AlertMixin
|
|
};
|
|
},
|
|
|
|
handleChange(event) {
|
|
this.setState({value: event.target.value});
|
|
},
|
|
|
|
render() {
|
|
let className = 'form-control input-text-ascribe';
|
|
let alerts = (this.props.submitted) ? null : this.state.alerts;
|
|
return (
|
|
<div className="form-group">
|
|
{alerts}
|
|
<input className={className}
|
|
placeholder={this.props.placeHolder}
|
|
required={this.props.required}
|
|
type={this.props.type}
|
|
onChange={this.handleChange}
|
|
onBlur={this.props.onBlur}/>
|
|
</div>
|
|
);
|
|
|
|
}
|
|
});
|
|
|
|
export default InputText; |