Skip to content

Commit

Permalink
Prevent tooltip from rendering with empty label (#1834)
Browse files Browse the repository at this point in the history
### Why is it needed?

The `label` prop for the `<Tooltip />` component is optional, but it
doesn't prevent the tooltip from rendering when it's missing.

![Screenshot 2024-12-12 alle 12 13
55](https://github.com/user-attachments/assets/079427a1-f1f0-4797-a814-5243dd233f6b)

### How to test it?

Create a tooltip with an empty `label` prop
  • Loading branch information
HichamELBSI authored Jan 13, 2025
2 parents 49fa898 + bf538d1 commit e15ca94
Show file tree
Hide file tree
Showing 3 changed files with 53 additions and 0 deletions.
5 changes: 5 additions & 0 deletions .changeset/three-eels-clap.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
'@strapi/design-system': patch
---

Prevent tooltip from rendering when the label property is not passed
46 changes: 46 additions & 0 deletions packages/design-system/src/components/Tooltip/Tooltip.test.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
import { render as renderHarness } from '@test/utils';

import { Button } from '../Button';

import { Tooltip, type TooltipProps } from './Tooltip';

const render = (props: Partial<TooltipProps> = {}) =>
renderHarness(
<Tooltip {...props}>
<Button>My button</Button>
</Tooltip>,
);

describe('Tooltip', () => {
it('should render and be accessible with a label', async () => {
const { user, getByRole, findByRole } = render({
label: 'My tooltip',
});

await user.hover(getByRole('button'));

expect(await findByRole('tooltip', { name: 'My tooltip' })).toBeInTheDocument();
});

it('should render the label and not the description if both are provided', async () => {
const { user, getByRole, findByRole, queryByRole } = render({
label: 'My tooltip label',
description: 'My tooltip description',
});

await user.hover(getByRole('button'));

expect(await findByRole('tooltip', { name: 'My tooltip label' })).toBeInTheDocument();
expect(queryByRole('tooltip', { name: 'My tooltip description' })).not.toBeInTheDocument();
});

it('should not render when the label is empty', async () => {
const { user, getByRole, queryByRole } = render({
label: '',
});

await user.hover(getByRole('button'));

expect(queryByRole('tooltip', { name: 'My tooltip' })).not.toBeInTheDocument();
});
});
2 changes: 2 additions & 0 deletions packages/design-system/src/components/Tooltip/Tooltip.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,8 @@ const TooltipImpl = React.forwardRef<TooltipElement, TooltipProps>(
},
forwardedRef,
) => {
if (!label && !description) return children;

return (
<Tooltip.Root
defaultOpen={defaultOpen}
Expand Down

0 comments on commit e15ca94

Please sign in to comment.