1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-06 00:07:44 +01:00
unleash.unleash/public/js/components/feature/FeatureForm.jsx

104 lines
3.1 KiB
JavaScript

var React = require('react');
var strategyStore = require('../../stores/StrategyStore');
var FeatureForm = React.createClass({
getInitialState: function() {
return {strategyOptions: []};
},
componentWillMount: function() {
strategyStore.getStrategies().then(this.handleStrategyResponse);
},
handleStrategyResponse: function(response) {
var strategyNames = response.strategies.map(function(s) { return s.name; });
this.setState({strategyOptions: strategyNames});
},
render: function() {
var feature = this.props.feature || {
name: '',
strategy: 'default',
enabled: false
};
return (
<form ref="form" className="bg-blue-xlt">
<div className="line mal ptl pbl">
<div className="unit prl r-size1of6">
<input ref="enabled" type="checkbox" defaultChecked={feature.enabled} />
</div>
<div className="unit r-size2of5">
<input
type="text"
className="mbs"
id="name"
ref="name"
disabled={feature.name.length}
defaultValue={feature.name}
placeholder="Enter name" />
<input className=""
type="text"
ref="description"
defaultValue={feature.description}
placeholder="Enter description" />
</div>
<div className="unit r-size2of6 plm">
<select id="strategy"
ref="strategy"
className=""
defaultValue={feature.strategy}>
{this.renderStrategyOptions()}
</select>
</div>
<div className="unit r-size1of6 rightify">
<button className="primary mrs" onClick={this.saveFeature}>
Save
</button>
<button className="" onClick={this.cancelFeature}>
Cancel
</button>
</div>
</div>
</form>
);
},
renderStrategyOptions: function() {
var currentStrategy = this.props.feature ? this.props.feature.strategy : "default";
return this.state.strategyOptions.map(function(name) {
return (
<option key={name} value={name} selected={name === currentStrategy}>
{name}
</option>
);
});
},
saveFeature: function(e) {
e.preventDefault();
var feature = {
name: this.refs.name.getDOMNode().value,
description: this.refs.description.getDOMNode().value,
strategy: this.refs.strategy.getDOMNode().value,
enabled: this.refs.enabled.getDOMNode().checked
};
this.props.onSubmit(feature);
},
cancelFeature: function(e) {
e.preventDefault();
this.props.onCancel();
}
});
module.exports = FeatureForm;