mirror of
https://github.com/Unleash/unleash.git
synced 2025-01-01 00:08:27 +01:00
#12 post new features
This commit is contained in:
parent
8e6ed4d73b
commit
7cf5685eb1
@ -18,44 +18,72 @@
|
|||||||
|
|
||||||
var FeatureForm = React.createClass({
|
var FeatureForm = React.createClass({
|
||||||
|
|
||||||
|
getInitialState: function () {
|
||||||
|
return {name: '', description: '', strategy: 'Default'};
|
||||||
|
},
|
||||||
|
|
||||||
|
handleNameChange: function(e) { this.setState({name: e.target.value.trim()}); },
|
||||||
|
handleDescriptionChange: function(e) { this.setState({description: e.target.value.trim()}); },
|
||||||
|
handleStrategyChange: function(e) { this.setState({strategy: e.target.value.trim()}); },
|
||||||
|
|
||||||
|
handleSubmit: function(e) {
|
||||||
|
e.preventDefault();
|
||||||
|
this.props.onFeatureSubmit(this.state);
|
||||||
|
return;
|
||||||
|
},
|
||||||
|
|
||||||
render: function () {
|
render: function () {
|
||||||
return (
|
return (
|
||||||
<form className="form-horizontal">
|
<form className="form-horizontal" onSubmit={this.handleSubmit}>
|
||||||
<fieldset>
|
<fieldset>
|
||||||
|
|
||||||
<legend>Add a new feature</legend>
|
<legend>Add a new feature</legend>
|
||||||
|
|
||||||
<div className="control-group">
|
<div className="control-group">
|
||||||
<label className="control-label" for="name">Name </label>
|
<label className="control-label" htmlFor="name">Name </label>
|
||||||
<div className="controls">
|
<div className="controls">
|
||||||
<input id="name" name="name" type="text"
|
<input
|
||||||
placeholder="Superfeature" className="input-large" required="" />
|
id="name"
|
||||||
|
type="text"
|
||||||
|
placeholder="Superfeature"
|
||||||
|
className="input-large"
|
||||||
|
required=""
|
||||||
|
onChange={this.handleNameChange}
|
||||||
|
value={this.state.name} />
|
||||||
<p className="help-block">Give the feature a name</p>
|
<p className="help-block">Give the feature a name</p>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div className="control-group">
|
<div className="control-group">
|
||||||
<label className="control-label" for="description">Description</label>
|
<label className="control-label" htmlFor="description">Description</label>
|
||||||
<div className="controls">
|
<div className="controls">
|
||||||
<input id="description" name="description" type="text"
|
<input
|
||||||
placeholder="It does this and that " className="input-large" />
|
id="description"
|
||||||
|
type="text"
|
||||||
|
placeholder="It does this and that "
|
||||||
|
className="input-large"
|
||||||
|
onChange={this.handleDescriptionChange}
|
||||||
|
value={this.state.description} />
|
||||||
<p className="help-block">Describe the feature</p>
|
<p className="help-block">Describe the feature</p>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div className="control-group">
|
<div className="control-group">
|
||||||
<label className="control-label" for="strategy">Strategy</label>
|
<label className="control-label" htmlFor="strategy">Strategy</label>
|
||||||
<div className="controls">
|
<div className="controls">
|
||||||
<select id="strategy" name="strategy" className="input-large">
|
<select
|
||||||
<option>Default</option>
|
id="strategy"
|
||||||
|
className="input-large"
|
||||||
|
onChange={this.handleStrategyChange}
|
||||||
|
value={this.state.strategy}>
|
||||||
|
<option value="Default">Default</option>
|
||||||
</select>
|
</select>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div className="control-group">
|
<div className="control-group">
|
||||||
<label className="control-label" for="submit"></label>
|
|
||||||
<div className="controls">
|
<div className="controls">
|
||||||
<button id="submit" name="submit" className="btn btn-success">Submit</button>
|
<input type="submit" value="Save" className="btn btn-success" />
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
@ -152,7 +180,7 @@ var FeatureList = React.createClass({
|
|||||||
f[changeRequest.field] = changeRequest.value;
|
f[changeRequest.field] = changeRequest.value;
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
console.log(changeRequest);
|
|
||||||
reqwest({
|
reqwest({
|
||||||
url: 'features/' + changeRequest.name,
|
url: 'features/' + changeRequest.name,
|
||||||
method: 'patch',
|
method: 'patch',
|
||||||
@ -166,6 +194,20 @@ var FeatureList = React.createClass({
|
|||||||
}.bind(this));
|
}.bind(this));
|
||||||
},
|
},
|
||||||
|
|
||||||
|
createFeature: function (feature, callback) {
|
||||||
|
reqwest({
|
||||||
|
url: 'features',
|
||||||
|
method: 'post',
|
||||||
|
type: 'json',
|
||||||
|
contentType: 'application/json',
|
||||||
|
data: JSON.stringify(feature)
|
||||||
|
}).then(function() {
|
||||||
|
// how do we communicate success?
|
||||||
|
}.bind(this), function() {
|
||||||
|
window.alert('create failed');
|
||||||
|
}.bind(this));
|
||||||
|
},
|
||||||
|
|
||||||
render: function () {
|
render: function () {
|
||||||
var featureNodes = this.state.features.map(function (feature) {
|
var featureNodes = this.state.features.map(function (feature) {
|
||||||
return (
|
return (
|
||||||
@ -180,7 +222,7 @@ var FeatureList = React.createClass({
|
|||||||
</div>
|
</div>
|
||||||
<div className='panel-body'>
|
<div className='panel-body'>
|
||||||
{featureNodes}
|
{featureNodes}
|
||||||
<FeatureForm />
|
<FeatureForm onFeatureSubmit={this.createFeature}/>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
|
Loading…
Reference in New Issue
Block a user