mirror of
https://github.com/Unleash/unleash.git
synced 2025-07-12 13:48:35 +02:00
91 lines
2.9 KiB
JavaScript
91 lines
2.9 KiB
JavaScript
import React, { Component } from 'react';
|
|
import PropTypes from 'prop-types';
|
|
import { Textfield, Switch } from 'react-mdl';
|
|
import StrategiesSection from './strategies-section-container';
|
|
|
|
import { FormButtons } from '../../common';
|
|
|
|
class AddFeatureToggleComponent extends Component {
|
|
componentWillMount() {
|
|
// TODO unwind this stuff
|
|
if (this.props.initCallRequired === true) {
|
|
this.props.init(this.props.input);
|
|
}
|
|
}
|
|
|
|
render() {
|
|
const {
|
|
input,
|
|
setValue,
|
|
addStrategy,
|
|
removeStrategy,
|
|
updateStrategy,
|
|
moveStrategy,
|
|
onSubmit,
|
|
onCancel,
|
|
editmode = false,
|
|
} = this.props;
|
|
|
|
const { description, enabled } = input;
|
|
const configuredStrategies = input.strategies || [];
|
|
|
|
return (
|
|
<form onSubmit={onSubmit(input)}>
|
|
<section style={{ padding: '16px' }}>
|
|
<Textfield
|
|
floatingLabel
|
|
style={{ width: '100%' }}
|
|
rows={1}
|
|
label="Description"
|
|
required
|
|
value={description}
|
|
onChange={v => setValue('description', v.target.value)}
|
|
/>
|
|
|
|
{!editmode && (
|
|
<div>
|
|
<br />
|
|
<Switch
|
|
checked={enabled}
|
|
onChange={() => {
|
|
setValue('enabled', !enabled);
|
|
}}
|
|
>
|
|
Enabled
|
|
</Switch>
|
|
<hr />
|
|
</div>
|
|
)}
|
|
<StrategiesSection
|
|
configuredStrategies={configuredStrategies}
|
|
addStrategy={addStrategy}
|
|
updateStrategy={updateStrategy}
|
|
moveStrategy={moveStrategy}
|
|
removeStrategy={removeStrategy}
|
|
/>
|
|
|
|
<br />
|
|
<FormButtons submitText={editmode ? 'Update' : 'Create'} onCancel={onCancel} />
|
|
</section>
|
|
</form>
|
|
);
|
|
}
|
|
}
|
|
|
|
AddFeatureToggleComponent.propTypes = {
|
|
input: PropTypes.object,
|
|
setValue: PropTypes.func.isRequired,
|
|
addStrategy: PropTypes.func.isRequired,
|
|
removeStrategy: PropTypes.func.isRequired,
|
|
moveStrategy: PropTypes.func.isRequired,
|
|
updateStrategy: PropTypes.func.isRequired,
|
|
onSubmit: PropTypes.func.isRequired,
|
|
onCancel: PropTypes.func.isRequired,
|
|
validateName: PropTypes.func.isRequired,
|
|
editmode: PropTypes.bool,
|
|
initCallRequired: PropTypes.bool,
|
|
init: PropTypes.func,
|
|
};
|
|
|
|
export default AddFeatureToggleComponent;
|