mirror of
https://github.com/Unleash/unleash.git
synced 2025-01-06 00:07:44 +01:00
More create feature toggle
This commit is contained in:
parent
e3dea0ad38
commit
fe96da3255
@ -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 />
|
||||||
|
@ -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;
|
@ -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;
|
||||||
|
@ -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;
|
Loading…
Reference in New Issue
Block a user