'use strict'; const React = require('react'); const TextInput = require('../form/TextInput'); const FeatureForm = React.createClass({ getInitialState() { return { strategyOptions: this.props.strategies, requiredParams: [], currentStrategy: this.props.feature ? this.props.feature.strategy : 'default', }; }, componentWillMount() { if (this.props.feature) { this.setSelectedStrategy(this.props.feature.strategy); } }, onStrategyChange(e) { this.setSelectedStrategy(e.target.value); this.setState({ currentStrategy: e.target.value }); }, getParameterValue(name) { if (this.props.feature && this.props.feature.parameters) { return this.props.feature.parameters[name]; } return ''; }, setSelectedStrategy(name) { const selectedStrategy = this.props.strategies.filter(strategy => strategy.name === name)[0]; if (selectedStrategy) { this.setStrategyParams(selectedStrategy); } else { this.setState({ currentStrategy: 'default', requiredParams: [], }); } }, setStrategyParams(strategy) { const requiredParams = []; let key; for (key in strategy.parametersTemplate) { if (Object.hasOwnProperty.call(strategy.parametersTemplate, key)) { requiredParams.push({ name: key, value: this.getParameterValue(key) }); } } this.setState({ requiredParams }); }, render() { const feature = this.props.feature || { name: '', strategy: 'default', enabled: false, }; const idPrefix = this.props.feature ? this.props.feature.name : 'new'; return (
{this.props.feature ? '' : Create new toggle}
{this.renderStrategyProperties()}
); }, renderStrategyOptions() { return this.props.strategies.map(strategy => ); }, renderStrategyProperties() { return this.state.requiredParams.map(param => ); }, saveFeature(e) { e.preventDefault(); const feature = { name: this.refs.name.getValue(), description: this.refs.description.getValue(), strategy: this.state.currentStrategy, enabled: this.refs.enabled.getDOMNode().checked, parameters: this.getParameters(), }; this.props.onSubmit(feature); }, cancelFeature(e) { e.preventDefault(); this.props.onCancel(); }, getParameters() { const parameters = {}; this.state.requiredParams.forEach(param => { parameters[param.name] = this.refs[param.name].getValue(); }); return parameters; }, }); module.exports = FeatureForm;