[UI] Fix small issues generating console errors (#8622)

* Checkbox should use onChange, not onClick

This fixes react console errors:

You provided a `checked` prop to a form field without an `onChange` handler. This will render a read-only field. If the field should be mutable use `defaultChecked`. Otherwise, set either `onChange` or `readOnly`.

Signed-off-by: Łukasz Mierzwa <l.mierzwa@gmail.com>

* Correctly pass key in metrics exporer

Instead of passing metric variable we pass 'metric' string, which causes console errors due to duplicated keys.

Signed-off-by: Łukasz Mierzwa <l.mierzwa@gmail.com>

* Update tests

Signed-off-by: Łukasz Mierzwa <l.mierzwa@gmail.com>
pull/8627/head
Łukasz Mierzwa 2021-03-19 12:20:04 +00:00 committed by GitHub
parent e246670193
commit e4f076f813
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 13 additions and 15 deletions

View File

@ -23,17 +23,19 @@ describe('AlertsContent', () => {
{ selector: '#firing-toggler', propName: 'firing' },
].forEach(testCase => {
it(`toggles the ${testCase.propName} checkbox from true to false when clicked and back to true when clicked again`, () => {
wrapper.find(testCase.selector).invoke('onClick')(testCase.propName);
expect(wrapper.find(testCase.selector).prop('checked')).toBe(true);
wrapper.find(testCase.selector).simulate('change', { target: { checked: false } });
expect(wrapper.find(testCase.selector).prop('checked')).toBe(false);
wrapper.find(testCase.selector).invoke('onClick')(testCase.propName);
wrapper.find(testCase.selector).simulate('change', { target: { checked: true } });
expect(wrapper.find(testCase.selector).prop('checked')).toBe(true);
});
});
it('toggles the "annotations" checkbox from false to true when clicked and back to false when clicked again', () => {
wrapper.find('#show-annotations-toggler').invoke('onClick')();
expect(wrapper.find('#show-annotations-toggler').prop('checked')).toBe(false);
wrapper.find('#show-annotations-toggler').simulate('change', { target: { checked: true } });
expect(wrapper.find('#show-annotations-toggler').prop('checked')).toBe(true);
wrapper.find('#show-annotations-toggler').invoke('onClick')();
wrapper.find('#show-annotations-toggler').simulate('change', { target: { checked: false } });
expect(wrapper.find('#show-annotations-toggler').prop('checked')).toBe(false);
});
});

View File

@ -55,10 +55,6 @@ const AlertsContent: FC<AlertsProps> = ({ groups = [], statsCount }) => {
});
};
const toggleAnnotations = () => {
setShowAnnotations({ checked: !showAnnotations.checked });
};
return (
<>
<div className="d-flex togglers-wrapper">
@ -69,7 +65,7 @@ const AlertsContent: FC<AlertsProps> = ({ groups = [], statsCount }) => {
wrapperStyles={{ marginRight: 10 }}
checked={filter[state]}
id={`${state}-toggler`}
onClick={toggleFilter(state)}
onChange={toggleFilter(state)}
>
<Badge color={color} className="text-capitalize">
{state} ({statsCount[state]})
@ -81,7 +77,7 @@ const AlertsContent: FC<AlertsProps> = ({ groups = [], statsCount }) => {
wrapperStyles={{ marginLeft: 'auto' }}
checked={showAnnotations.checked}
id="show-annotations-toggler"
onClick={() => toggleAnnotations()}
onChange={({ target }) => setShowAnnotations({ checked: target.checked })}
>
<span style={{ fontSize: '0.9rem', lineHeight: 1.9 }}>Show annotations</span>
</Checkbox>

View File

@ -9,7 +9,7 @@ exports[`AlertsContent matches a snapshot 1`] = `
checked={true}
id="inactive-toggler"
key="inactive"
onClick={[Function]}
onChange={[Function]}
wrapperStyles={
Object {
"marginRight": 10,
@ -32,7 +32,7 @@ exports[`AlertsContent matches a snapshot 1`] = `
checked={true}
id="pending-toggler"
key="pending"
onClick={[Function]}
onChange={[Function]}
wrapperStyles={
Object {
"marginRight": 10,
@ -55,7 +55,7 @@ exports[`AlertsContent matches a snapshot 1`] = `
checked={true}
id="firing-toggler"
key="firing"
onClick={[Function]}
onChange={[Function]}
wrapperStyles={
Object {
"marginRight": 10,
@ -77,7 +77,7 @@ exports[`AlertsContent matches a snapshot 1`] = `
<Memo(Checkbox)
checked={false}
id="show-annotations-toggler"
onClick={[Function]}
onChange={[Function]}
wrapperStyles={
Object {
"marginLeft": "auto",

View File

@ -25,7 +25,7 @@ class MetricsExplorer extends Component<Props, {}> {
<ModalHeader toggle={this.toggle}>Metrics Explorer</ModalHeader>
<ModalBody>
{this.props.metrics.map(metric => (
<p className="metric" key="metric" onClick={this.handleMetricClick.bind(this, metric)}>
<p key={metric} className="metric" onClick={this.handleMetricClick.bind(this, metric)}>
{metric}
</p>
))}