Created
July 10, 2015 05:33
-
-
Save anonymous/a53a8a46ccad3e33a148 to your computer and use it in GitHub Desktop.
JS Bin // source http://jsbin.com/cecaqa
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<!DOCTYPE html> | |
<html> | |
<head> | |
<script src="http://fb.me/react-0.13.1.js"></script> | |
<link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/css/bootstrap.min.css" rel="stylesheet" type="text/css" /> | |
<meta charset="utf-8"> | |
<title>JS Bin</title> | |
</head> | |
<body> | |
<script id="jsbin-javascript"> | |
var TweetBox = React.createClass({displayName: 'TweetBox', | |
getInitialState: function() { | |
return { | |
text: "", | |
photoAdded: false | |
}; | |
}, | |
handleChange: function(event) { | |
this.setState({ text: event.target.value }); | |
}, | |
togglePhoto: function(){ | |
this.setState({photoAdded: !this.state.photoAdded }); | |
}, | |
remainingCharacters: function(){ | |
if (this.state.photoAdded){ | |
return 140-23-this.state.text.length; | |
} else { | |
return 140-this.state.text.length; | |
} | |
}, | |
render: function() { | |
return ( | |
React.createElement("div", {className: "well clearfix"}, | |
React.createElement("textarea", {className: "form-control", | |
onChange: this.handleChange} | |
), | |
React.createElement("br", null), | |
React.createElement("span", null, this.remainingCharacters() ), | |
React.createElement("button", {className: "btn btn-primary pull-right", | |
disabled: this.state.text.length === 0 && !this.state.photoAdded}, "Tweet "), | |
React.createElement("button", {className: "btn btn-default pull-right", onClick: this.togglePhoto}, | |
this.state.photoAdded ? "Photo Added" : "Add Photo" | |
) | |
) | |
); | |
} | |
}); | |
React.render( | |
React.createElement(TweetBox, null), | |
document.body | |
); | |
</script> | |
<script id="jsbin-source-html" type="text/html"><!DOCTYPE html> | |
<html> | |
<head> | |
<script src="//fb.me/react-0.13.1.js"><\/script> | |
<link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/css/bootstrap.min.css" rel="stylesheet" type="text/css" /> | |
<meta charset="utf-8"> | |
<title>JS Bin</title> | |
</head> | |
<body> | |
</body> | |
</html></script> | |
<script id="jsbin-source-javascript" type="text/javascript">var TweetBox = React.createClass({ | |
getInitialState: function() { | |
return { | |
text: "", | |
photoAdded: false | |
}; | |
}, | |
handleChange: function(event) { | |
this.setState({ text: event.target.value }); | |
}, | |
togglePhoto: function(){ | |
this.setState({photoAdded: !this.state.photoAdded }); | |
}, | |
remainingCharacters: function(){ | |
if (this.state.photoAdded){ | |
return 140-23-this.state.text.length; | |
} else { | |
return 140-this.state.text.length; | |
} | |
}, | |
render: function() { | |
return ( | |
<div className="well clearfix"> | |
<textarea className="form-control" | |
onChange={this.handleChange}> | |
</textarea> | |
<br/> | |
<span>{this.remainingCharacters() }</span> | |
<button className="btn btn-primary pull-right" | |
disabled={this.state.text.length === 0 && !this.state.photoAdded}>Tweet </button> | |
<button className="btn btn-default pull-right" onClick={this.togglePhoto}> | |
{this.state.photoAdded ? "Photo Added" : "Add Photo" } | |
</button> | |
</div> | |
); | |
} | |
}); | |
React.render( | |
<TweetBox />, | |
document.body | |
); | |
</script></body> | |
</html> |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
var TweetBox = React.createClass({displayName: 'TweetBox', | |
getInitialState: function() { | |
return { | |
text: "", | |
photoAdded: false | |
}; | |
}, | |
handleChange: function(event) { | |
this.setState({ text: event.target.value }); | |
}, | |
togglePhoto: function(){ | |
this.setState({photoAdded: !this.state.photoAdded }); | |
}, | |
remainingCharacters: function(){ | |
if (this.state.photoAdded){ | |
return 140-23-this.state.text.length; | |
} else { | |
return 140-this.state.text.length; | |
} | |
}, | |
render: function() { | |
return ( | |
React.createElement("div", {className: "well clearfix"}, | |
React.createElement("textarea", {className: "form-control", | |
onChange: this.handleChange} | |
), | |
React.createElement("br", null), | |
React.createElement("span", null, this.remainingCharacters() ), | |
React.createElement("button", {className: "btn btn-primary pull-right", | |
disabled: this.state.text.length === 0 && !this.state.photoAdded}, "Tweet "), | |
React.createElement("button", {className: "btn btn-default pull-right", onClick: this.togglePhoto}, | |
this.state.photoAdded ? "Photo Added" : "Add Photo" | |
) | |
) | |
); | |
} | |
}); | |
React.render( | |
React.createElement(TweetBox, null), | |
document.body | |
); |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Tweet box with React