mirror of https://github.com/prometheus/prometheus
[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
parent
e246670193
commit
e4f076f813
|
@ -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);
|
||||
});
|
||||
});
|
||||
|
|
|
@ -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>
|
||||
|
|
|
@ -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",
|
||||
|
|
|
@ -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>
|
||||
))}
|
||||
|
|
Loading…
Reference in New Issue