mirror of
https://github.com/Unleash/unleash.git
synced 2025-04-29 01:15:48 +02:00
84 lines
2.4 KiB
JavaScript
84 lines
2.4 KiB
JavaScript
import React, { PropTypes } from 'react';
|
|
import { Input, Switch, Button } from 'react-toolbox';
|
|
import AddFeatureToggleStrategy from './AddFeatureToggleStrategy';
|
|
import ConfiguredStrategies from './ConfiguredStrategies';
|
|
|
|
const AddFeatureToggleUI = ({
|
|
strategies,
|
|
featureToggle,
|
|
updateField,
|
|
addStrategy,
|
|
removeStrategy,
|
|
onSubmit,
|
|
onCancel,
|
|
editmode,
|
|
}) => {
|
|
const {
|
|
name, // eslint-disable-line
|
|
description,
|
|
enabled,
|
|
} = featureToggle;
|
|
const configuredStrategies = featureToggle.strategies;
|
|
|
|
return (
|
|
<form onSubmit={onSubmit}>
|
|
<section>
|
|
<Input
|
|
type="text"
|
|
label="Name"
|
|
name="name"
|
|
disabled={editmode}
|
|
required
|
|
value={name}
|
|
onChange={updateField.bind(this, 'name')} />
|
|
<Input
|
|
type="text"
|
|
multiline label="Description"
|
|
required
|
|
value={description}
|
|
onChange={updateField.bind(this, 'description')} />
|
|
|
|
<br />
|
|
|
|
<Switch
|
|
checked={enabled}
|
|
label="Enabled"
|
|
onChange={updateField.bind(this, 'enabled')} />
|
|
|
|
<br />
|
|
</section>
|
|
|
|
<section>
|
|
<strong>Activation strategies</strong>
|
|
<ConfiguredStrategies
|
|
configuredStrategies={configuredStrategies}
|
|
removeStrategy={removeStrategy} />
|
|
</section>
|
|
|
|
<section>
|
|
<AddFeatureToggleStrategy strategies={strategies} addStrategy={addStrategy} />
|
|
</section>
|
|
|
|
<br />
|
|
|
|
|
|
<Button type="submit" raised primary label={editmode ? 'Update' : 'Create'} />
|
|
|
|
<Button type="cancel" raised label="Cancel" onClick={onCancel} />
|
|
</form>
|
|
);
|
|
};
|
|
|
|
AddFeatureToggleUI.propTypes = {
|
|
strategies: PropTypes.array.required,
|
|
featureToggle: PropTypes.object,
|
|
updateField: PropTypes.func.required,
|
|
addStrategy: PropTypes.func.required,
|
|
removeStrategy: PropTypes.func.required,
|
|
onSubmit: PropTypes.func.required,
|
|
onCancel: PropTypes.func.required,
|
|
editmode: PropTypes.bool,
|
|
};
|
|
|
|
export default AddFeatureToggleUI;
|