1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-06 00:07:44 +01:00

Add stragies should always be an option

This commit is contained in:
ivaosthu 2016-10-25 18:55:35 +02:00
parent fcf37e0afa
commit 9b7b487fdc
5 changed files with 111 additions and 26 deletions

View File

@ -2,7 +2,7 @@ import React, { Component, PropTypes } from 'react';
import Input from 'react-toolbox/lib/input'; import Input from 'react-toolbox/lib/input';
import Button from 'react-toolbox/lib/button'; import Button from 'react-toolbox/lib/button';
import Switch from 'react-toolbox/lib/switch'; import Switch from 'react-toolbox/lib/switch';
import SelectStrategies from './strategies-for-toggle'; import SelectStrategies from './strategies-for-toggle-container';
import SelectedStrategies from './selected-strategies'; import SelectedStrategies from './selected-strategies';
class AddFeatureToggleComponent extends Component { class AddFeatureToggleComponent extends Component {

View File

@ -0,0 +1,77 @@
import React, { PropTypes } from 'react';
import { Button, Input } from 'react-toolbox';
class AddStrategy extends React.Component {
constructor (props) {
super(props);
this.state = {
selectedStrategy: props.strategies[0],
};
}
static propTypes () {
return {
strategies: PropTypes.array.isRequired,
addStrategy: PropTypes.func.isRequired,
fetchStrategies: PropTypes.func.isRequired,
};
}
componentWillMount () {
// TODO: move somewhere appropriate?
this.props.fetchStrategies();
}
componentWillReceiveProps (nextProps) {
// this will fix async strategies list loading after mounted
if (!this.state.selectedStrategy && nextProps.strategies.length > 0) {
this.setState({ selectedStrategy: nextProps.strategies[0] });
}
}
handleChange = (evt) => {
const strategyName = evt.target.value;
const selectedStrategy = this.props.strategies.find(s => s.name === strategyName);
this.setState({ selectedStrategy });
}
addStrategy = (evt) => {
evt.preventDefault();
const selectedStrategy = this.state.selectedStrategy;
const parameters = {};
const keys = Object.keys(selectedStrategy.parametersTemplate || {});
keys.forEach(prop => { parameters[prop] = ''; });
this.props.addStrategy({
name: selectedStrategy.name,
parameters,
});
};
render () {
const strategies = this.props.strategies.map(s => (
<option key={s.name} value={s.name}>{s.name}</option>
));
const selectedStrategy = this.state.selectedStrategy || this.props.strategies[0];
if (!selectedStrategy) {
return <i>Strategies loading...</i>;
}
return (
<div>
<select value={selectedStrategy.name} onChange={this.handleChange}>
{strategies}
</select>
<Button icon="add" accent flat label="add strategy" onClick={this.addStrategy} />
<p><strong>Description:</strong> {selectedStrategy.description}</p>
</div>
);
}
}
export default AddStrategy;

View File

@ -1,8 +1,8 @@
import { connect } from 'react-redux'; import { connect } from 'react-redux';
import SelectStrategies from './select-strategies'; import AddStrategy from './add-strategy';
import { fetchStrategies } from '../../store/strategy-actions'; import { fetchStrategies } from '../../store/strategy-actions';
export default connect((state) => ({ export default connect((state) => ({
strategies: state.strategies.get('list').toArray(), strategies: state.strategies.get('list').toArray(),
}), { fetchStrategies })(SelectStrategies); }), { fetchStrategies })(AddStrategy);

View File

@ -0,0 +1,8 @@
import { connect } from 'react-redux';
import AddStrategy from './add-strategy';
import { fetchStrategies } from '../../store/strategy-actions';
export default connect((state) => ({
strategies: state.strategies.get('list').toArray(),
}), { fetchStrategies })(AddStrategy);

View File

@ -1,48 +1,48 @@
import React, { PropTypes } from 'react'; import React, { PropTypes } from 'react';
import SelectStrategies from './select-strategies-container';
import Button from 'react-toolbox/lib/button'; import Button from 'react-toolbox/lib/button';
class AddStrategiesToToggle extends React.Component { class AddStrategiesToToggle extends React.Component {
constructor () { constructor (props) {
super(); super(props);
this.state = { this.state = {
showConfigure: false, selectedStrategy: undefined,
}; };
} }
static propTypes () { static propTypes () {
return { return {
addStrategy: PropTypes.func.isRequired, addStrategy: PropTypes.func.isRequired,
strategies: PropTypes.array.isRequired,
fetchStrategies: PropTypes.func.isRequired,
}; };
} }
cancelConfig = () => { componentWillMount () {
this.setState({ showConfigure: false }); // TODO: move somewhere appropriate?
}; this.props.fetchStrategies();
}
addStrategy = (strategy) => { addStrategy = (strategy) => {
this.setState({ showConfigure: false }); this.setState({ selectedStrategy: undefined });
this.props.addStrategy(strategy); this.props.addStrategy(strategy);
} }
showConfigure = (evt) => {
evt.preventDefault();
this.setState({ showConfigure: true });
}
renderAddLink () {
return (
<div>
<Button icon="add" accent onClick={this.showConfigure}>Add strategy</Button>
</div>
);
}
render () { render () {
const selectedStrategy = this.state.selectedStrategy || this.props.strategies[0];
const strategies = this.props.strategies.map(s => (
<option key={s.name} value={s.name}>{s.name}</option>
));
return ( return (
this.state.showConfigure ? <div>
<SelectStrategies cancelConfig={this.cancelConfig} addStrategy={this.addStrategy} /> : <select value={selectedStrategy.name} onChange={this.handleChange}>
this.renderAddLink() {strategies}
</select>
<Button icon="add" accent onClick={this.showConfigure}>Add strategy</Button>
</div>
); );
} }
} }