1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-01 00:08:27 +01:00

More create feature toggle

This commit is contained in:
ivaosthu 2016-10-22 13:28:25 +02:00
parent e3dea0ad38
commit fe96da3255
4 changed files with 158 additions and 63 deletions

View File

@ -2,7 +2,8 @@ import React, { PropTypes } from 'react';
import { connect } from 'react-redux'; import { connect } from 'react-redux';
import { Input, Switch, Button } from 'react-toolbox'; import { Input, Switch, Button } from 'react-toolbox';
import { createFeatureToggles } from '../../store/feature-actions'; import { createFeatureToggles } from '../../store/feature-actions';
import ConfigureStrategy from './ConfigureStrategy'; import AddFeatureToggleStrategy from './AddFeatureToggleStrategy';
import ConfiguredStrategies from './ConfiguredStrategies';
const mapStateToProps = (state) => ({ const mapStateToProps = (state) => ({
strategies: state.strategies.toJS(), strategies: state.strategies.toJS(),
@ -46,40 +47,17 @@ class AddFeatureToggle extends React.Component {
this.setState({ featureToggle: updatedFeatureToggle }); this.setState({ featureToggle: updatedFeatureToggle });
}; };
cancelConfig = () => { addStrategy = (strategy) => {
this.setState({ configureStrategy: undefined }); const strategies = this.state.featureToggle.strategies;
}; strategies.push(strategy);
const updatedFeatureToggle = Object.assign({}, this.state.featureToggle, { strategies });
renderAddStrategy () { this.setState({ featureToggle: updatedFeatureToggle });
if (this.state.configureStrategy) {
return (
<div>
<ConfigureStrategy strategy={this.state.configureStrategy} cancelConfig={this.cancelConfig} />
</div>
);
} else {
return (
<div>
<strong>Choose an activation strategy:</strong>
<ul>{this.renderPossibleStrategies()}</ul>
</div>
);
}
} }
renderPossibleStrategies () { removeStrategy = (strategy) => {
const configure = (strategy, evt) => { const strategies = this.state.featureToggle.strategies.filter(s => s !== strategy);
evt.preventDefault(); const updatedFeatureToggle = Object.assign({}, this.state.featureToggle, { strategies });
this.setState({ this.setState({ featureToggle: updatedFeatureToggle });
configureStrategy: strategy,
});
};
const configuredStrategies = this.state.featureToggle.strategies;
return this.props.strategies
.filter(s => !configuredStrategies.find(selected => selected.name === s.name))
.map((s) => (
<li key={s.name}><a href={`#configure-${s.name}`} onClick={configure.bind(this, s)}>{s.name}</a></li>
));
} }
render () { render () {
@ -114,9 +92,15 @@ class AddFeatureToggle extends React.Component {
</section> </section>
<section> <section>
<h3>Strategies</h3> <strong>Activation strategies</strong>
{this.renderAddStrategy()} <ConfiguredStrategies configuredStrategies={configuredStrategies} removeStrategy={this.removeStrategy} />
<p>Configured: {configuredStrategies.map(s => s.name).join(', ')}</p> </section>
<section>
<AddFeatureToggleStrategy
strategies={this.props.strategies}
addStrategy={this.addStrategy}
/>
</section> </section>
<br /> <br />

View File

@ -0,0 +1,51 @@
import React, { PropTypes } from 'react';
import ConfigureStrategy from './ConfigureStrategy';
class AddFeatureToggleStrategy extends React.Component {
constructor () {
super();
this.state = {
showConfigure: false,
};
}
static propTypes () {
return {
strategies: PropTypes.array.isRequired,
addStrategy: PropTypes.func.isRequired,
};
}
cancelConfig = () => {
this.setState({ showConfigure: false });
};
addStrategy = (strategy) => {
this.setState({ showConfigure: false });
this.props.addStrategy(strategy);
}
showConfigure = (evt) => {
evt.preventDefault();
this.setState({ showConfigure: true });
}
renderAddLink () {
return (
<div>
<a href="" onClick={this.showConfigure}>Add strategy</a>
</div>
);
}
render () {
return this.state.showConfigure ?
<ConfigureStrategy
strategies={this.props.strategies}
cancelConfig={this.cancelConfig}
addStrategy={this.addStrategy} /> :
this.renderAddLink();
}
}
export default AddFeatureToggleStrategy;

View File

@ -1,54 +1,78 @@
import React, { PropTypes } from 'react'; import React, { PropTypes } from 'react';
import { Button, Input } from 'react-toolbox'; import { Button, Input } from 'react-toolbox';
class ConfigureStrategy extends React.Component { class ConfigureStrategy extends React.Component {
constructor () { constructor (props) {
super(); super(props);
this.state = {}; this.state = {
selectedStrategy: props.strategies[0],
parameters: {},
};
} }
static propTypes () { static propTypes () {
return { return {
strategy: PropTypes.object.isRequired, strategies: PropTypes.array.isRequired,
cancelConfig: PropTypes.func.isRequired,
addStrategy: PropTypes.func.isRequired,
}; };
} }
handleChange = (evt) => {
const strategyName = evt.target.value;
const selectedStrategy = this.props.strategies.find(s => s.name === strategyName);
this.setState({ selectedStrategy, parameters: {} });
}
addStrategy = (evt) => { addStrategy = (evt) => {
evt.preventDefault(); evt.preventDefault();
} this.props.addStrategy({
name: this.state.selectedStrategy.name,
handleChange = (key, value) => { parameters: this.state.parameters,
const change = {}; });
change[key] = value;
const newState = Object.assign({}, this.state, change);
this.setState(newState);
}; };
renderInputFields () { handleConfigChange = (key, value) => {
const strategy = this.props.strategy; const parameters = this.state.parameters;
if (strategy.parametersTemplate) { parameters[key] = value;
return Object.keys(strategy.parametersTemplate).map(field => ( this.setState({ parameters });
<Input key={field} name={field} label={field} onChange={this.handleChange.bind(null, field)} /> };
renderInputFields (selectedStrategy) {
if (selectedStrategy.parametersTemplate) {
return Object.keys(selectedStrategy.parametersTemplate).map(field => (
<Input key={field} name={field} label={field} onChange={this.handleConfigChange.bind(this, field)} />
)); ));
} }
} }
render () { render () {
let inputFields = this.renderInputFields(); const strategies = this.props.strategies.map(s => (
<option key={s.name} value={s.name}>{s.name}</option>
));
const style = {
backgroundColor: '#ECE',
padding: '10px',
};
const selectedStrategy = this.state.selectedStrategy;
return ( return (
<div style={{ backgroundColor: '#ECECEC', padding: '10px' }}> <div style={style}>
<h4>{this.props.strategy.name}</h4> <select value={selectedStrategy.name} onChange={this.handleChange}>
<p>{this.props.strategy.description}</p> {strategies}
{inputFields} </select>
<Button raised label="add strategy" />
<Button raised accent label="cancel" onClick={this.props.cancelConfig} /> <p><strong>Description:</strong> {selectedStrategy.description}</p>
{this.renderInputFields(selectedStrategy)}
<Button raised mini accent label="cancel" onClick={this.props.cancelConfig} />
<Button raised mini label="add strategy" onClick={this.addStrategy} />
</div> </div>
); );
} }
} }
export default (ConfigureStrategy); export default ConfigureStrategy;

View File

@ -0,0 +1,36 @@
import React, { PropTypes } from 'react';
import { Chip } from 'react-toolbox';
class ConfiguredStrategies extends React.Component {
static propTypes () {
return {
configuredStrategies: PropTypes.array.isRequired,
removeStrategy: PropTypes.func.isRequired,
};
}
renderName (strategy) {
const params = Object.keys(strategy.parameters)
.map(param => `${param}=${strategy.parameters[param]}`);
return <span>{strategy.name} ({params})</span>;
}
render () {
const removeStrategy = this.props.removeStrategy;
const strategies = this.props.configuredStrategies.map((s, index) => (
<Chip
key={`${index}-${s.name}`}
deletable
onDeleteClick={() => removeStrategy(s)}>
{this.renderName(s)}
</Chip>
));
return (
<div>
{strategies.length > 0 ? strategies : <p>No activation strategies added</p>}
</div>
);
}
}
export default ConfiguredStrategies;