aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMathieu Suen <mathieu.suen@sonarsource.com>2022-08-25 12:33:16 +0200
committersonartech <sonartech@sonarsource.com>2022-08-25 20:03:09 +0000
commitd2030207ca79237d596b3e452598ac455b8fdd5f (patch)
tree1c8e7e18bbbb76dbb121b6054ceaf84f9f16aacd
parent051bfcaaf9c148d2e845f204f86b4d2fc82aa726 (diff)
downloadsonarqube-d2030207ca79237d596b3e452598ac455b8fdd5f.tar.gz
sonarqube-d2030207ca79237d596b3e452598ac455b8fdd5f.zip
SONAR-16823 Buttons have same name but different actions
-rw-r--r--server/sonar-web/src/main/js/apps/coding-rules/components/Facet.tsx9
-rw-r--r--server/sonar-web/src/main/js/components/facet/FacetHeader.tsx30
-rw-r--r--server/sonar-web/src/main/js/components/facet/ListStyleFacet.tsx9
-rw-r--r--server/sonar-web/src/main/js/components/facet/__tests__/Facet-it.tsx2
-rw-r--r--server/sonar-web/src/main/js/components/facet/__tests__/__snapshots__/ListStyleFacet-test.tsx.snap68
-rw-r--r--sonar-core/src/main/resources/org/sonar/l10n/core.properties1
6 files changed, 38 insertions, 81 deletions
diff --git a/server/sonar-web/src/main/js/apps/coding-rules/components/Facet.tsx b/server/sonar-web/src/main/js/apps/coding-rules/components/Facet.tsx
index 7be20e1a1cb..f77224b01c7 100644
--- a/server/sonar-web/src/main/js/apps/coding-rules/components/Facet.tsx
+++ b/server/sonar-web/src/main/js/apps/coding-rules/components/Facet.tsx
@@ -20,7 +20,6 @@
import classNames from 'classnames';
import { orderBy, sortBy, without } from 'lodash';
import * as React from 'react';
-import Tooltip from '../../../components/controls/Tooltip';
import FacetBox from '../../../components/facet/FacetBox';
import FacetHeader from '../../../components/facet/FacetHeader';
import FacetItem from '../../../components/facet/FacetItem';
@@ -110,11 +109,9 @@ export default class Facet extends React.PureComponent<Props> {
className={classNames({ 'search-navigator-facet-box-forbidden': disabled })}
property={this.props.property}>
<FacetHeader
- name={
- <Tooltip overlay={disabled ? this.props.disabledHelper : undefined}>
- <span>{translate('coding_rules.facet', this.props.property)}</span>
- </Tooltip>
- }
+ name={translate('coding_rules.facet', this.props.property)}
+ disabled={disabled}
+ disabledHelper={this.props.disabledHelper}
onClear={this.handleClear}
onClick={disabled ? undefined : this.handleHeaderClick}
open={this.props.open && !disabled}
diff --git a/server/sonar-web/src/main/js/components/facet/FacetHeader.tsx b/server/sonar-web/src/main/js/components/facet/FacetHeader.tsx
index febd98b02ed..ee06de65751 100644
--- a/server/sonar-web/src/main/js/components/facet/FacetHeader.tsx
+++ b/server/sonar-web/src/main/js/components/facet/FacetHeader.tsx
@@ -23,12 +23,15 @@ import HelpTooltip from '../../components/controls/HelpTooltip';
import OpenCloseIcon from '../../components/icons/OpenCloseIcon';
import DeferredSpinner from '../../components/ui/DeferredSpinner';
import { translate, translateWithParameters } from '../../helpers/l10n';
+import Tooltip from '../controls/Tooltip';
interface Props {
children?: React.ReactNode;
fetching?: boolean;
helper?: string;
- name: React.ReactNode;
+ disabled?: boolean;
+ disabledHelper?: string;
+ name: string;
onClear?: () => void;
onClick?: () => void;
open: boolean;
@@ -66,9 +69,15 @@ export default class FacetHeader extends React.PureComponent<Props> {
}
render() {
- const showClearButton =
- this.props.values != null && this.props.values.length > 0 && this.props.onClear != null;
-
+ const { disabled, values, disabledHelper, name, open, children, fetching } = this.props;
+ const showClearButton = values != null && values.length > 0 && this.props.onClear != null;
+ const header = disabled ? (
+ <Tooltip overlay={disabledHelper}>
+ <span>{name}</span>
+ </Tooltip>
+ ) : (
+ name
+ );
return (
<div className="search-navigator-facet-header-wrapper display-flex-center">
{this.props.onClick ? (
@@ -77,27 +86,27 @@ export default class FacetHeader extends React.PureComponent<Props> {
className="button-link"
type="button"
onClick={this.handleClick}
- aria-expanded={this.props.open}
+ aria-expanded={open}
tabIndex={0}>
- <OpenCloseIcon className="little-spacer-right" open={this.props.open} />
- {this.props.name}
+ <OpenCloseIcon className="little-spacer-right" open={open} />
+ {header}
</button>
{this.renderHelper()}
</span>
) : (
<span className="search-navigator-facet-header display-flex-center">
- {this.props.name}
+ {header}
{this.renderHelper()}
</span>
)}
- {this.props.children}
+ {children}
<span className="search-navigator-facet-header-value spacer-left spacer-right ">
{this.renderValueIndicator()}
</span>
- {this.props.fetching && (
+ {fetching && (
<span className="little-spacer-right">
<DeferredSpinner />
</span>
@@ -106,6 +115,7 @@ export default class FacetHeader extends React.PureComponent<Props> {
{showClearButton && (
<Button
className="search-navigator-facet-header-button button-small button-red"
+ aria-label={translateWithParameters('clear_x_filter', name)}
onClick={this.props.onClear}>
{translate('clear')}
</Button>
diff --git a/server/sonar-web/src/main/js/components/facet/ListStyleFacet.tsx b/server/sonar-web/src/main/js/components/facet/ListStyleFacet.tsx
index d56bfd1b88c..206df6595be 100644
--- a/server/sonar-web/src/main/js/components/facet/ListStyleFacet.tsx
+++ b/server/sonar-web/src/main/js/components/facet/ListStyleFacet.tsx
@@ -22,7 +22,6 @@ import { sortBy, without } from 'lodash';
import * as React from 'react';
import ListFooter from '../../components/controls/ListFooter';
import SearchBox from '../../components/controls/SearchBox';
-import Tooltip from '../../components/controls/Tooltip';
import { Alert } from '../../components/ui/Alert';
import { translate } from '../../helpers/l10n';
import { formatMeasure } from '../../helpers/measures';
@@ -395,11 +394,9 @@ export default class ListStyleFacet<S> extends React.Component<Props<S>, State<S
property={this.props.property}>
<FacetHeader
fetching={this.props.fetching}
- name={
- <Tooltip overlay={disabled ? this.props.disabledHelper : undefined}>
- <span>{this.props.facetHeader}</span>
- </Tooltip>
- }
+ name={this.props.facetHeader}
+ disabled={disabled}
+ disabledHelper={this.props.disabledHelper}
onClear={this.handleClear}
onClick={disabled ? undefined : this.handleHeaderClick}
open={this.props.open && !disabled}
diff --git a/server/sonar-web/src/main/js/components/facet/__tests__/Facet-it.tsx b/server/sonar-web/src/main/js/components/facet/__tests__/Facet-it.tsx
index 8c86352db2a..0b1d70d7bf7 100644
--- a/server/sonar-web/src/main/js/components/facet/__tests__/Facet-it.tsx
+++ b/server/sonar-web/src/main/js/components/facet/__tests__/Facet-it.tsx
@@ -66,7 +66,7 @@ it('should correctly render a header with helper text', async () => {
it('should correctly render a header with value data', () => {
renderFacet(undefined, { values: ['value 1'] });
expect(screen.getByText('value 1')).toBeInTheDocument();
- screen.getByRole('button', { name: 'clear' }).click();
+ screen.getByRole('button', { name: 'clear_x_filter.foo' }).click();
expect(screen.queryByText('value 1')).not.toBeInTheDocument();
});
diff --git a/server/sonar-web/src/main/js/components/facet/__tests__/__snapshots__/ListStyleFacet-test.tsx.snap b/server/sonar-web/src/main/js/components/facet/__tests__/__snapshots__/ListStyleFacet-test.tsx.snap
index ba89dc13bb5..63f62b3484f 100644
--- a/server/sonar-web/src/main/js/components/facet/__tests__/__snapshots__/ListStyleFacet-test.tsx.snap
+++ b/server/sonar-web/src/main/js/components/facet/__tests__/__snapshots__/ListStyleFacet-test.tsx.snap
@@ -6,16 +6,10 @@ exports[`should be disabled 1`] = `
property="foo"
>
<FacetHeader
+ disabled={true}
+ disabledHelper="Disabled helper description"
fetching={false}
- name={
- <Tooltip
- overlay="Disabled helper description"
- >
- <span>
- facet header
- </span>
- </Tooltip>
- }
+ name="facet header"
onClear={[Function]}
open={false}
values={Array []}
@@ -30,13 +24,7 @@ exports[`should display all selected items 1`] = `
>
<FacetHeader
fetching={false}
- name={
- <Tooltip>
- <span>
- facet header
- </span>
- </Tooltip>
- }
+ name="facet header"
onClear={[Function]}
onClick={[Function]}
open={true}
@@ -118,13 +106,7 @@ exports[`should render 1`] = `
>
<FacetHeader
fetching={false}
- name={
- <Tooltip>
- <span>
- facet header
- </span>
- </Tooltip>
- }
+ name="facet header"
onClear={[Function]}
onClick={[Function]}
open={true}
@@ -193,13 +175,7 @@ exports[`should search 1`] = `
>
<FacetHeader
fetching={false}
- name={
- <Tooltip>
- <span>
- facet header
- </span>
- </Tooltip>
- }
+ name="facet header"
onClear={[Function]}
onClick={[Function]}
open={true}
@@ -259,13 +235,7 @@ exports[`should search 2`] = `
>
<FacetHeader
fetching={false}
- name={
- <Tooltip>
- <span>
- facet header
- </span>
- </Tooltip>
- }
+ name="facet header"
onClear={[Function]}
onClick={[Function]}
open={true}
@@ -336,13 +306,7 @@ exports[`should search 3`] = `
>
<FacetHeader
fetching={false}
- name={
- <Tooltip>
- <span>
- facet header
- </span>
- </Tooltip>
- }
+ name="facet header"
onClear={[Function]}
onClick={[Function]}
open={true}
@@ -411,13 +375,7 @@ exports[`should search 4`] = `
>
<FacetHeader
fetching={false}
- name={
- <Tooltip>
- <span>
- facet header
- </span>
- </Tooltip>
- }
+ name="facet header"
onClear={[Function]}
onClick={[Function]}
open={true}
@@ -451,13 +409,7 @@ exports[`should search 5`] = `
>
<FacetHeader
fetching={false}
- name={
- <Tooltip>
- <span>
- facet header
- </span>
- </Tooltip>
- }
+ name="facet header"
onClear={[Function]}
onClick={[Function]}
open={true}
diff --git a/sonar-core/src/main/resources/org/sonar/l10n/core.properties b/sonar-core/src/main/resources/org/sonar/l10n/core.properties
index 55fa7879a30..f11fd232448 100644
--- a/sonar-core/src/main/resources/org/sonar/l10n/core.properties
+++ b/sonar-core/src/main/resources/org/sonar/l10n/core.properties
@@ -251,6 +251,7 @@ assigned_to=Assigned to
bulk_change=Bulk Change
bulleted_point=Bulleted point
clear=Clear
+clear_x_filter=Clear {0} Filters
clear_all_filters=Clear All Filters
coding_rules=Rules
copy_to_clipboard=Click to copy to clipboard