2016-11-10 14:26:24 +01:00
|
|
|
import { connect } from 'react-redux';
|
|
|
|
import { hashHistory } from 'react-router';
|
|
|
|
|
|
|
|
import { requestUpdateFeatureToggle } from '../../store/feature-actions';
|
|
|
|
import { createMapper, createActions } from '../input-helpers';
|
|
|
|
import FormComponent from './form';
|
|
|
|
|
|
|
|
const ID = 'edit-feature-toggle';
|
|
|
|
function getId (props) {
|
2016-11-16 00:15:57 +01:00
|
|
|
return [ID, props.featureToggle.name];
|
2016-11-10 14:26:24 +01:00
|
|
|
}
|
|
|
|
// TODO: need to scope to the active featureToggle
|
|
|
|
// best is to emulate the "input-storage"?
|
|
|
|
const mapStateToProps = createMapper({
|
|
|
|
id: getId,
|
2016-11-16 00:15:57 +01:00
|
|
|
getDefault: (state, ownProps) => ownProps.featureToggle,
|
2016-11-10 14:26:24 +01:00
|
|
|
prepare: (props) => {
|
|
|
|
props.editmode = true;
|
|
|
|
return props;
|
|
|
|
},
|
|
|
|
});
|
|
|
|
|
|
|
|
const prepare = (methods, dispatch) => {
|
|
|
|
methods.onSubmit = (input) => (
|
|
|
|
(e) => {
|
|
|
|
e.preventDefault();
|
|
|
|
// TODO: should add error handling
|
|
|
|
requestUpdateFeatureToggle(input)(dispatch)
|
|
|
|
.then(() => methods.clear())
|
|
|
|
.then(() => window.history.back());
|
|
|
|
}
|
|
|
|
);
|
|
|
|
|
|
|
|
methods.onCancel = (evt) => {
|
|
|
|
evt.preventDefault();
|
2016-11-16 21:58:30 +01:00
|
|
|
methods.clear();
|
2016-11-10 14:26:24 +01:00
|
|
|
hashHistory.push('/features');
|
|
|
|
};
|
|
|
|
|
|
|
|
methods.addStrategy = (v) => {
|
|
|
|
methods.pushToList('strategies', v);
|
|
|
|
};
|
|
|
|
|
2016-11-16 21:20:41 +01:00
|
|
|
methods.removeStrategy = (index) => {
|
|
|
|
methods.removeFromList('strategies', index);
|
2016-11-10 14:26:24 +01:00
|
|
|
};
|
|
|
|
|
2016-11-16 21:20:41 +01:00
|
|
|
methods.updateStrategy = (index, n) => {
|
|
|
|
methods.updateInList('strategies', index, n);
|
2016-11-10 14:26:24 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
methods.validateName = () => {};
|
|
|
|
|
|
|
|
return methods;
|
|
|
|
};
|
|
|
|
|
|
|
|
const actions = createActions({
|
|
|
|
id: getId,
|
|
|
|
prepare,
|
|
|
|
});
|
|
|
|
|
|
|
|
export default connect(mapStateToProps, actions)(FormComponent);
|