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

fix: Update feature toggle description. (#196)

Currently it is always in edit mode which can be a bit confusing.
Usually one do not want to edit a toggle descirption and if one
do it should be OK to enter edit mode.

Now it alos stores changes in local state on the component so any
updates from the server should not affect the local value currently
beeing edited by the user.

fixes #168
This commit is contained in:
Ivar Conradi Østhus 2019-10-26 22:55:52 +02:00 committed by GitHub
parent 24c616ec38
commit b8eda9599a
3 changed files with 102 additions and 47 deletions

View File

@ -13,7 +13,6 @@ exports[`renders correctly with one feature 1`] = `
<react-mdl-CardTitle <react-mdl-CardTitle
style={ style={
Object { Object {
"paddingTop": "24px",
"wordBreak": "break-all", "wordBreak": "break-all",
} }
} }
@ -21,20 +20,14 @@ exports[`renders correctly with one feature 1`] = `
Another Another
</react-mdl-CardTitle> </react-mdl-CardTitle>
<react-mdl-CardText> <react-mdl-CardText>
<react-mdl-Textfield another's description
floatingLabel={true}  
label="Description" <a
onBlur={[Function]} href="#edit"
onChange={[Function]} onClick={[Function]}
required={true} >
rows={1} edit
style={ </a>
Object {
"width": "100%",
}
}
value="another's description"
/>
</react-mdl-CardText> </react-mdl-CardText>
<react-mdl-CardActions <react-mdl-CardActions
border={true} border={true}

View File

@ -0,0 +1,83 @@
import React from 'react';
import PropTypes from 'prop-types';
import { Button, CardText, Textfield } from 'react-mdl';
import { UPDATE_FEATURE } from '../../../permissions';
export default class UpdateDescriptionComponent extends React.Component {
constructor(props) {
super(props);
this.state = { editMode: false };
}
static propTypes = {
isFeatureView: PropTypes.bool.isRequired,
update: PropTypes.func,
featureToggle: PropTypes.object,
hasPermission: PropTypes.func.isRequired,
};
onEditMode = (description, evt) => {
evt.preventDefault();
this.setState({ editMode: true, description });
};
updateValue = evt => {
evt.preventDefault();
this.setState({ description: evt.target.value });
};
onSave = evt => {
evt.preventDefault();
this.props.update(this.state.description);
this.setState({ editMode: false, description: undefined });
};
onCancel = evt => {
evt.preventDefault();
this.setState({ editMode: false, description: undefined });
};
renderRead({ description, isFeatureView, hasPermission }) {
return (
<CardText>
{description}&nbsp;
{isFeatureView && hasPermission(UPDATE_FEATURE) ? (
<a href="#edit" onClick={this.onEditMode.bind(this, description)}>
edit
</a>
) : null}
</CardText>
);
}
renderEdit() {
const { description } = this.state;
return (
<CardText>
<Textfield
floatingLabel
style={{ width: '100%' }}
label="Description"
required
value={description}
onChange={this.updateValue}
/>
<div>
<Button type="submit" raised accent onClick={this.onSave}>
Save
</Button>
&nbsp;
<Button type="cancel" raised onClick={this.onCancel}>
Cancel
</Button>
</div>
</CardText>
);
}
render() {
const { editMode } = this.state;
return editMode ? this.renderEdit(this.props) : this.renderRead(this.props);
}
}

View File

@ -1,6 +1,6 @@
import React from 'react'; import React from 'react';
import PropTypes from 'prop-types'; import PropTypes from 'prop-types';
import { Tabs, Tab, ProgressBar, Button, Card, CardText, CardTitle, CardActions, Textfield, Switch } from 'react-mdl'; import { Tabs, Tab, ProgressBar, Button, Card, CardTitle, CardActions, Switch } from 'react-mdl';
import { Link } from 'react-router-dom'; import { Link } from 'react-router-dom';
import HistoryComponent from '../history/history-list-toggle-container'; import HistoryComponent from '../history/history-list-toggle-container';
@ -8,6 +8,7 @@ import MetricComponent from './metric-container';
import EditFeatureToggle from './form/form-update-feature-container'; import EditFeatureToggle from './form/form-update-feature-container';
import EditVariants from './variant/update-variant-container'; import EditVariants from './variant/update-variant-container';
import ViewFeatureToggle from './form/form-view-feature-container'; import ViewFeatureToggle from './form/form-view-feature-container';
import UpdateDescriptionComponent from './form/update-description-component';
import { styles as commonStyles } from '../common'; import { styles as commonStyles } from '../common';
import { CREATE_FEATURE, DELETE_FEATURE, UPDATE_FEATURE } from '../../permissions'; import { CREATE_FEATURE, DELETE_FEATURE, UPDATE_FEATURE } from '../../permissions';
@ -133,8 +134,8 @@ export default class ViewFeatureToggleComponent extends React.Component {
revive(featureToggle.name); revive(featureToggle.name);
this.props.history.push('/features'); this.props.history.push('/features');
}; };
const updateFeatureToggle = e => { const updateDescription = description => {
let feature = { ...featureToggle, description: e.target.value }; let feature = { ...featureToggle, description };
if (Array.isArray(feature.strategies)) { if (Array.isArray(feature.strategies)) {
feature.strategies.forEach(s => { feature.strategies.forEach(s => {
delete s.id; delete s.id;
@ -143,38 +144,16 @@ export default class ViewFeatureToggleComponent extends React.Component {
this.props.editFeatureToggle(feature); this.props.editFeatureToggle(feature);
}; };
const setValue = (v, event) => {
featureToggle[v] = event.target.value;
this.forceUpdate();
};
return ( return (
<Card shadow={0} className={commonStyles.fullwidth} style={{ overflow: 'visible' }}> <Card shadow={0} className={commonStyles.fullwidth} style={{ overflow: 'visible' }}>
<CardTitle style={{ paddingTop: '24px', wordBreak: 'break-all' }}>{featureToggle.name}</CardTitle> <CardTitle style={{ wordBreak: 'break-all' }}>{featureToggle.name}</CardTitle>
<CardText> <UpdateDescriptionComponent
{this.isFeatureView && hasPermission(UPDATE_FEATURE) ? ( isFeatureView={this.isFeatureView}
<Textfield description={featureToggle.description}
floatingLabel update={updateDescription}
style={{ width: '100%' }} hasPermission={hasPermission}
rows={1} />
label="Description"
required
value={featureToggle.description}
onChange={v => setValue('description', v)}
onBlur={updateFeatureToggle}
/>
) : (
<Textfield
disabled
floatingLabel
style={{ width: '100%' }}
rows={1}
label="Description"
required
value={featureToggle.description}
/>
)}
</CardText>
<CardActions <CardActions
border border