@fluentui/react-tooltip 9.1.2 → 9.1.3
Sign up to get free protection for your applications and to get access to all the features.
- package/CHANGELOG.json +40 -1
- package/CHANGELOG.md +15 -2
- package/package.json +5 -5
- package/MIGRATION.md +0 -68
- package/Spec.md +0 -374
package/CHANGELOG.json
CHANGED
@@ -2,7 +2,46 @@
|
|
2
2
|
"name": "@fluentui/react-tooltip",
|
3
3
|
"entries": [
|
4
4
|
{
|
5
|
-
"date": "
|
5
|
+
"date": "Mon, 05 Dec 2022 18:25:36 GMT",
|
6
|
+
"tag": "@fluentui/react-tooltip_v9.1.3",
|
7
|
+
"version": "9.1.3",
|
8
|
+
"comments": {
|
9
|
+
"patch": [
|
10
|
+
{
|
11
|
+
"author": "tristan.watanabe@gmail.com",
|
12
|
+
"package": "@fluentui/react-tooltip",
|
13
|
+
"commit": "3fdfc72488fe30b83f665c7267c5e8cb802682ff",
|
14
|
+
"comment": "chore: Migrate to new package structure."
|
15
|
+
},
|
16
|
+
{
|
17
|
+
"author": "beachball",
|
18
|
+
"package": "@fluentui/react-tooltip",
|
19
|
+
"comment": "Bump @fluentui/react-portal to v9.0.12",
|
20
|
+
"commit": "4c29542a51bf068e171690cc8e59c14489883912"
|
21
|
+
},
|
22
|
+
{
|
23
|
+
"author": "beachball",
|
24
|
+
"package": "@fluentui/react-tooltip",
|
25
|
+
"comment": "Bump @fluentui/react-positioning to v9.3.3",
|
26
|
+
"commit": "4c29542a51bf068e171690cc8e59c14489883912"
|
27
|
+
},
|
28
|
+
{
|
29
|
+
"author": "beachball",
|
30
|
+
"package": "@fluentui/react-tooltip",
|
31
|
+
"comment": "Bump @fluentui/react-shared-contexts to v9.1.2",
|
32
|
+
"commit": "4c29542a51bf068e171690cc8e59c14489883912"
|
33
|
+
},
|
34
|
+
{
|
35
|
+
"author": "beachball",
|
36
|
+
"package": "@fluentui/react-tooltip",
|
37
|
+
"comment": "Bump @fluentui/react-theme to v9.1.3",
|
38
|
+
"commit": "4c29542a51bf068e171690cc8e59c14489883912"
|
39
|
+
}
|
40
|
+
]
|
41
|
+
}
|
42
|
+
},
|
43
|
+
{
|
44
|
+
"date": "Thu, 17 Nov 2022 23:05:30 GMT",
|
6
45
|
"tag": "@fluentui/react-tooltip_v9.1.2",
|
7
46
|
"version": "9.1.2",
|
8
47
|
"comments": {
|
package/CHANGELOG.md
CHANGED
@@ -1,12 +1,25 @@
|
|
1
1
|
# Change Log - @fluentui/react-tooltip
|
2
2
|
|
3
|
-
This log was last generated on
|
3
|
+
This log was last generated on Mon, 05 Dec 2022 18:25:36 GMT and should not be manually modified.
|
4
4
|
|
5
5
|
<!-- Start content -->
|
6
6
|
|
7
|
+
## [9.1.3](https://github.com/microsoft/fluentui/tree/@fluentui/react-tooltip_v9.1.3)
|
8
|
+
|
9
|
+
Mon, 05 Dec 2022 18:25:36 GMT
|
10
|
+
[Compare changes](https://github.com/microsoft/fluentui/compare/@fluentui/react-tooltip_v9.1.2..@fluentui/react-tooltip_v9.1.3)
|
11
|
+
|
12
|
+
### Patches
|
13
|
+
|
14
|
+
- chore: Migrate to new package structure. ([PR #25818](https://github.com/microsoft/fluentui/pull/25818) by tristan.watanabe@gmail.com)
|
15
|
+
- Bump @fluentui/react-portal to v9.0.12 ([PR #25798](https://github.com/microsoft/fluentui/pull/25798) by beachball)
|
16
|
+
- Bump @fluentui/react-positioning to v9.3.3 ([PR #25798](https://github.com/microsoft/fluentui/pull/25798) by beachball)
|
17
|
+
- Bump @fluentui/react-shared-contexts to v9.1.2 ([PR #25798](https://github.com/microsoft/fluentui/pull/25798) by beachball)
|
18
|
+
- Bump @fluentui/react-theme to v9.1.3 ([PR #25798](https://github.com/microsoft/fluentui/pull/25798) by beachball)
|
19
|
+
|
7
20
|
## [9.1.2](https://github.com/microsoft/fluentui/tree/@fluentui/react-tooltip_v9.1.2)
|
8
21
|
|
9
|
-
Thu, 17 Nov 2022 23:
|
22
|
+
Thu, 17 Nov 2022 23:05:30 GMT
|
10
23
|
[Compare changes](https://github.com/microsoft/fluentui/compare/@fluentui/react-tooltip_v9.1.1..@fluentui/react-tooltip_v9.1.2)
|
11
24
|
|
12
25
|
### Patches
|
package/package.json
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
{
|
2
2
|
"name": "@fluentui/react-tooltip",
|
3
|
-
"version": "9.1.
|
3
|
+
"version": "9.1.3",
|
4
4
|
"description": "React components for building web experiences",
|
5
5
|
"main": "lib-commonjs/index.js",
|
6
6
|
"module": "lib/index.js",
|
@@ -32,10 +32,10 @@
|
|
32
32
|
},
|
33
33
|
"dependencies": {
|
34
34
|
"@fluentui/keyboard-keys": "^9.0.1",
|
35
|
-
"@fluentui/react-portal": "^9.0.
|
36
|
-
"@fluentui/react-positioning": "^9.3.
|
37
|
-
"@fluentui/react-shared-contexts": "^9.1.
|
38
|
-
"@fluentui/react-theme": "^9.1.
|
35
|
+
"@fluentui/react-portal": "^9.0.12",
|
36
|
+
"@fluentui/react-positioning": "^9.3.3",
|
37
|
+
"@fluentui/react-shared-contexts": "^9.1.2",
|
38
|
+
"@fluentui/react-theme": "^9.1.3",
|
39
39
|
"@fluentui/react-utilities": "^9.2.2",
|
40
40
|
"@griffel/react": "^1.4.2",
|
41
41
|
"tslib": "^2.1.0"
|
package/MIGRATION.md
DELETED
@@ -1,68 +0,0 @@
|
|
1
|
-
# Tooltip Migration
|
2
|
-
|
3
|
-
## STATUS: WIP 🚧
|
4
|
-
|
5
|
-
This Migration guide is a work in progress and is not yet ready for use.
|
6
|
-
|
7
|
-
## Migration from v8
|
8
|
-
|
9
|
-
TooltipHost is replaced by Tooltip itself, as the wrapper around the element that should receive a tooltip.
|
10
|
-
|
11
|
-
- `Tooltip`
|
12
|
-
- `calloutProps`
|
13
|
-
- `isBeakVisible` => `withArrow`
|
14
|
-
- `beakWidth` => Not supported.
|
15
|
-
- `gapSpace` => Not supported.
|
16
|
-
- `doNotLayer` => Not supported. Tooltips are always layered by rendering in a Portal.
|
17
|
-
- `setInitialFocus` => Not supported. Tooltips can't be focused, by design.
|
18
|
-
- `componentRef` => Not supported. Tooltips can be controlled declaratively with props like `visible`, instead of using an imperative API like `componentRef`.
|
19
|
-
- `delay` => `showDelay`
|
20
|
-
- `directionalHint` => `positioning`
|
21
|
-
- `topLeftEdge` => `positioning="above-start"`
|
22
|
-
- `topCenter` => `positioning="above"`
|
23
|
-
- `topRightEdge` => `positioning="above-end"`
|
24
|
-
- `topAutoEdge` => Not supported
|
25
|
-
- `bottomLeftEdge` => `positioning="below-start"`
|
26
|
-
- `bottomCenter` => `positioning="below"`
|
27
|
-
- `bottomRightEdge` => `positioning="below-end"`
|
28
|
-
- `bottomAutoEdge` => Not supported
|
29
|
-
- `leftTopEdge` => `positioning="before-top"`
|
30
|
-
- `leftCenter` => `positioning="before"`
|
31
|
-
- `leftBottomEdge` => `positioning="before-bottom"`
|
32
|
-
- `rightTopEdge` => `positioning="after-top"`
|
33
|
-
- `rightCenter` => `positioning="after"`
|
34
|
-
- `rightBottomEdge` => `positioning="after-bottom"`
|
35
|
-
- `directionalHintForRTL` => Automatic based on whether the element is in an RTL context according to `FluentProvider`.
|
36
|
-
- `maxWidth` => Supported only through CSS styling of the `content` slot.
|
37
|
-
- `onRenderContent` => Set the `content` slot to a custom render function.
|
38
|
-
- `TooltipHost` => The tooltip itself is the "host".
|
39
|
-
- `closeDelay` => `hideDelay`
|
40
|
-
- `hostClassName` => Not needed because there is no element rendered inline by Tooltip
|
41
|
-
- `onTooltipToggle` => `onVisibleChange`
|
42
|
-
- `overflowMode` => Not supported. If this behavior is needed, the tooltip's visibility can be controlled using the `visible` prop and `onVisibleChange` event.
|
43
|
-
|
44
|
-
## Migration from v0
|
45
|
-
|
46
|
-
The v9 Tooltip swaps the meaning of children between content and trigger. In v0, Tooltip's children is the tooltip content, and its trigger is a prop. In v9, that is swapped: Tooltip's children is the trigger, and its content is a prop.
|
47
|
-
|
48
|
-
- `Tooltip`
|
49
|
-
- children => `content`
|
50
|
-
- `trigger` => children
|
51
|
-
- `defaultOpen` => Not supported. The tooltip's visibility can be controlled using the `visible` prop and `onVisibleChange` event.
|
52
|
-
- `mountNode` => Not supported
|
53
|
-
- `open` => `visible`
|
54
|
-
- `onOpenChange` => `onVisibleChange`
|
55
|
-
- `pointing` => `withArrow`
|
56
|
-
- `mouseEnterDelay` => `showDelay`
|
57
|
-
- `mouseLeaveDelay` => `hideDelay`
|
58
|
-
- `subtle={true}` = `appearance="normal"` (default)
|
59
|
-
- `subtle={false}` => `appearance="inverted"`
|
60
|
-
- Positioning props are now attributes of the `positioning` prop:
|
61
|
-
- `flipBoundary` => `positioning.flipBoundary`
|
62
|
-
- `offset` => `positioning.offset`
|
63
|
-
- `overflowBoundary` => `positioning.overflowBoundary`
|
64
|
-
- `popperRef` => `positioning.popperRef`
|
65
|
-
- `position` => `positioning.position`
|
66
|
-
- `align` => `positioning.align`
|
67
|
-
- `positionFixed` => `positioning.positionFixed`
|
68
|
-
- `target` => `positioning.target`
|
package/Spec.md
DELETED
@@ -1,374 +0,0 @@
|
|
1
|
-
# Tooltip Spec
|
2
|
-
|
3
|
-
Tooltips provide additional information about an element when hovering or focusing on the element.
|
4
|
-
|
5
|
-
## Prior Art
|
6
|
-
|
7
|
-
- OpenUI Tooltip resarch: https://open-ui.org/components/tooltip.research
|
8
|
-
- GitHub Epic issue: [Tooltip Convergence #16735](https://github.com/microsoft/fluentui/issues/16735)
|
9
|
-
|
10
|
-
### Tooltips in v8/Fabric
|
11
|
-
|
12
|
-
v8 tooltips use a `TooltipHost` wrapped around the target element to provide tooltip functionality. This creates a `div` around the element that listens for mouse and focus events.
|
13
|
-
|
14
|
-
The `Tooltip` component renders as a `Callout`, and supports all `Callout` props.
|
15
|
-
|
16
|
-
```tsx
|
17
|
-
<TooltipHost
|
18
|
-
content="This is the tooltip content"
|
19
|
-
// This id is used on the tooltip itself, not the host
|
20
|
-
// (so an element with this id only exists when the tooltip is shown)
|
21
|
-
id={tooltipId}
|
22
|
-
calloutProps={calloutProps}
|
23
|
-
styles={hostStyles}
|
24
|
-
>
|
25
|
-
<DefaultButton aria-describedby={tooltipId}>Hover over me</DefaultButton>
|
26
|
-
</TooltipHost>
|
27
|
-
```
|
28
|
-
|
29
|
-
#### Drawbacks
|
30
|
-
|
31
|
-
There are a few drawbacks with this approach to adding tooltips, which are outlined in [☂ Tooltip: open issues to resolve in converged approach #15102](https://github.com/microsoft/fluentui/issues/15102), and summarized below:
|
32
|
-
|
33
|
-
- The wrapper `div` created by `TooltipHost` can cause layout issues for the component. It also doesn't always result in proper positioning for the tooltip.
|
34
|
-
- The API is overly complex.
|
35
|
-
- There's no coordination between tooltips on a page. For example, moving the mouse between two elements with tooltips should cause the second tooltip to appear immediately without fading in/out.
|
36
|
-
|
37
|
-
### Tooltips in v0/Northstar
|
38
|
-
|
39
|
-
v0 tooltips use a `trigger` property to render the tooltip's target component. However, unlike v8 it does not create a wrapper `div` around the target component, but instead adds listeners to the target component's props.
|
40
|
-
|
41
|
-
```tsx
|
42
|
-
<Tooltip content="Example tooltip" trigger={<Button content="A button" />} />
|
43
|
-
```
|
44
|
-
|
45
|
-
# Sample Code
|
46
|
-
|
47
|
-
Label tooltip for an icon-only button:
|
48
|
-
|
49
|
-
```tsx
|
50
|
-
<Tooltip content="Copy" relationship="label">
|
51
|
-
<Button icon={<CopyRegular />} />
|
52
|
-
</Tooltip>
|
53
|
-
```
|
54
|
-
|
55
|
-
Description tooltip for a link:
|
56
|
-
|
57
|
-
```tsx
|
58
|
-
<Tooltip content="This is an example" relationship="description">
|
59
|
-
<a href="http://example.com">A link</a>
|
60
|
-
</Tooltip>
|
61
|
-
```
|
62
|
-
|
63
|
-
Tooltip with custom JSX content:
|
64
|
-
|
65
|
-
```tsx
|
66
|
-
<Tooltip content={<b>The content can be JSX</b>} relationship="label">
|
67
|
-
<Button />
|
68
|
-
</Tooltip>
|
69
|
-
```
|
70
|
-
|
71
|
-
Custom component as a trigger:
|
72
|
-
|
73
|
-
```tsx
|
74
|
-
<Tooltip content="Supports any component that accepts HTML attributes" relationship="label">
|
75
|
-
<FancyButton />
|
76
|
-
</Tooltip>
|
77
|
-
```
|
78
|
-
|
79
|
-
Render function for the trigger:
|
80
|
-
|
81
|
-
```tsx
|
82
|
-
<Tooltip content="The child can be a render function" relationship="description">
|
83
|
-
{triggerProps => (
|
84
|
-
<>
|
85
|
-
<div>
|
86
|
-
<button {...triggerProps}>The trigger element</button>
|
87
|
-
</div>
|
88
|
-
</>
|
89
|
-
)}
|
90
|
-
</Tooltip>
|
91
|
-
```
|
92
|
-
|
93
|
-
```tsx
|
94
|
-
<Tooltip
|
95
|
-
content="It can target an element other than its trigger"
|
96
|
-
relationship="description"
|
97
|
-
positioning={{ target: targetElement }}
|
98
|
-
>
|
99
|
-
<button>
|
100
|
-
Custom target: <div ref={setTargetElement} />
|
101
|
-
</button>
|
102
|
-
</Tooltip>
|
103
|
-
```
|
104
|
-
|
105
|
-
# Variants
|
106
|
-
|
107
|
-
- The tooltip supports higher contrast colors with `appearance="inverted"`.
|
108
|
-
- The tooltip supports rendering an arrow pointing to the target element, using `withArrow`.
|
109
|
-
|
110
|
-
# API
|
111
|
-
|
112
|
-
To attach a tooltip to an element, wrap it with a `Tooltip`. There is a `content` slot for the text of the tooltip itself.
|
113
|
-
|
114
|
-
Unlike most components, Tooltip doesn't have a root slot and doesn't allow native DOM props on the Tooltip itself. This is because it doesn't render any nodes inline around its trigger (it does _not_ wrap the element with a `<div>` for example). Instead, it attaches listeners to the child by cloning the JSX object and adding `onPointerEnter`, etc. listeners.
|
115
|
-
|
116
|
-
Tooltip only supports a single child element, which can be either:
|
117
|
-
|
118
|
-
- A native element or component that supports DOM attributes (the child can't be a string, for example).
|
119
|
-
- A render function that takes the extra props to be added to the trigger element.
|
120
|
-
- It is allowed to have a tooltip without a child (trigger) element, in which case it _must_ have a target set via the `positioning` prop, and its visibility must be controlled with the `visible` prop.
|
121
|
-
|
122
|
-
_A note about the terminology used for the elements that the tooltip is attached to:_
|
123
|
-
|
124
|
-
- _The **trigger** is the element that causes the tooltip to open._
|
125
|
-
- _The **target** is the element that the tooltip is anchored to (and the arrow points to)._
|
126
|
-
- _Almost always, these will both be the same element, but it is possible to specify them separately, so the tooltip can show up adjacent to a different element than the one that triggered it._
|
127
|
-
|
128
|
-
## Types
|
129
|
-
|
130
|
-
### `Tooltip`
|
131
|
-
|
132
|
-
From [Tooltip.types.tsx](https://github.com/microsoft/fluentui/blob/master/packages/react-tooltip/src/components/Tooltip/Tooltip.types.tsx) in `@fluentui/react-tooltip`:
|
133
|
-
|
134
|
-
```ts
|
135
|
-
/**
|
136
|
-
* Slot properties for Tooltip
|
137
|
-
*/
|
138
|
-
export type TooltipSlots = {
|
139
|
-
/**
|
140
|
-
* The text or JSX content of the tooltip.
|
141
|
-
*/
|
142
|
-
content: NonNullable<Slot<'div'>>;
|
143
|
-
};
|
144
|
-
|
145
|
-
/**
|
146
|
-
* Properties for Tooltip
|
147
|
-
*/
|
148
|
-
export type TooltipProps = ComponentProps<TooltipSlots> & {
|
149
|
-
/**
|
150
|
-
* (Required) Specifies whether this tooltip is acting as the description or label of its trigger element.
|
151
|
-
*
|
152
|
-
* * `label` - The tooltip sets the trigger's aria-label or aria-labelledby attribute. This is useful for buttons
|
153
|
-
* displaying only an icon, for example.
|
154
|
-
* * `description` - The tooltip sets the trigger's aria-description or aria-describedby attribute.
|
155
|
-
* * `inaccessible` - No aria attributes are set on the trigger. This makes the tooltip's content inaccessible to
|
156
|
-
* screen readers, and should only be used if the tooltip's text is available by some other means.
|
157
|
-
*/
|
158
|
-
relationship: 'label' | 'description' | 'inaccessible';
|
159
|
-
|
160
|
-
/**
|
161
|
-
* The tooltip can have a single JSX child, or a render function that accepts TooltipTriggerProps.
|
162
|
-
*
|
163
|
-
* If no child is provided, the tooltip's target must be set with the `positioning` prop, and its
|
164
|
-
* visibility must be controlled with the `visible` prop.
|
165
|
-
*/
|
166
|
-
children?:
|
167
|
-
| (React.ReactElement & { ref?: React.Ref<unknown> })
|
168
|
-
| ((props: TooltipTriggerProps) => React.ReactElement | null)
|
169
|
-
| null;
|
170
|
-
|
171
|
-
/**
|
172
|
-
* The tooltip's visual appearance.
|
173
|
-
* * `normal` - Uses the theme's background and text colors.
|
174
|
-
* * `inverted` - Higher contrast variant that uses the theme's inverted colors.
|
175
|
-
*
|
176
|
-
* @defaultvalue normal
|
177
|
-
*/
|
178
|
-
appearance?: 'normal' | 'inverted';
|
179
|
-
|
180
|
-
/**
|
181
|
-
* Render an arrow pointing to the target element
|
182
|
-
*
|
183
|
-
* @defaultvalue false
|
184
|
-
*/
|
185
|
-
withArrow?: boolean;
|
186
|
-
|
187
|
-
/**
|
188
|
-
* Configure the positioning of the tooltip
|
189
|
-
*
|
190
|
-
* @defaultvalue above
|
191
|
-
*/
|
192
|
-
positioning?: PositioningShorthand;
|
193
|
-
|
194
|
-
/**
|
195
|
-
* Control the tooltip's visibility programatically.
|
196
|
-
*
|
197
|
-
* This can be used in conjunction with onVisibleChange to modify the tooltip's show and hide behavior.
|
198
|
-
*
|
199
|
-
* If not provided, the visibility will be controlled by the tooltip itself, based on hover and focus events on the
|
200
|
-
* trigger (child) element.
|
201
|
-
*/
|
202
|
-
visible?: boolean;
|
203
|
-
|
204
|
-
/**
|
205
|
-
* Notification when the visibility of the tooltip is changing
|
206
|
-
*/
|
207
|
-
onVisibleChange?: (
|
208
|
-
event: React.PointerEvent<HTMLElement> | React.FocusEvent<HTMLElement> | undefined,
|
209
|
-
data: OnVisibleChangeData,
|
210
|
-
) => void;
|
211
|
-
|
212
|
-
/**
|
213
|
-
* Delay before the tooltip is shown, in milliseconds.
|
214
|
-
*
|
215
|
-
* @defaultvalue 250
|
216
|
-
*/
|
217
|
-
showDelay?: number;
|
218
|
-
|
219
|
-
/**
|
220
|
-
* Delay before the tooltip is hidden, in milliseconds.
|
221
|
-
*
|
222
|
-
* @defaultvalue 250
|
223
|
-
*/
|
224
|
-
hideDelay?: number;
|
225
|
-
};
|
226
|
-
|
227
|
-
/**
|
228
|
-
* The properties that are added to the trigger of the Tooltip
|
229
|
-
*/
|
230
|
-
export type TooltipTriggerProps = {
|
231
|
-
ref?: React.Ref<never>;
|
232
|
-
} & Pick<
|
233
|
-
React.HTMLAttributes<HTMLElement>,
|
234
|
-
'onPointerEnter' | 'onPointerLeave' | 'onFocus' | 'onBlur' | 'aria-describedby' | 'aria-labelledby' | 'aria-label'
|
235
|
-
>;
|
236
|
-
|
237
|
-
/**
|
238
|
-
* Data for the Tooltip's onVisibleChange event.
|
239
|
-
*/
|
240
|
-
export type OnVisibleChangeData = {
|
241
|
-
visible: boolean;
|
242
|
-
};
|
243
|
-
```
|
244
|
-
|
245
|
-
### `TooltipContext`
|
246
|
-
|
247
|
-
The context is included at the app root on `FluentProvider` and is used by `Tooltip` to ensure that only one is visible at once.
|
248
|
-
|
249
|
-
From [TooltipContext.ts](https://github.com/microsoft/fluentui/blob/master/packages/react-shared-contexts/src/TooltipContext/TooltipContext.ts) in `@fluentui/react-shared-contexts`:
|
250
|
-
|
251
|
-
```ts
|
252
|
-
/**
|
253
|
-
* The context provided by TooltipProvider
|
254
|
-
*/
|
255
|
-
export type TooltipContextType = {
|
256
|
-
/**
|
257
|
-
* When a tooltip is shown, it sets itself as the visibleTooltip.
|
258
|
-
* The next tooltip to become visible can use it to hide the previous tooltip immediately.
|
259
|
-
*/
|
260
|
-
visibleTooltip?: {
|
261
|
-
hide: () => void;
|
262
|
-
};
|
263
|
-
};
|
264
|
-
|
265
|
-
/**
|
266
|
-
* Context shared by all of the tooltips in the app
|
267
|
-
*/
|
268
|
-
export const TooltipContext = React.createContext<TooltipContextType>({});
|
269
|
-
```
|
270
|
-
|
271
|
-
# Structure
|
272
|
-
|
273
|
-
## Tooltip as a label
|
274
|
-
|
275
|
-
### JSX tree
|
276
|
-
|
277
|
-
```tsx
|
278
|
-
<Tooltip content="Example" relationship="label">
|
279
|
-
<button>
|
280
|
-
<svg>...</svg>
|
281
|
-
</button>
|
282
|
-
</Tooltip>
|
283
|
-
```
|
284
|
-
|
285
|
-
### DOM
|
286
|
-
|
287
|
-
Tooltip with `relationship="label"` is not rendered when it is not visible. Its content is used as the `aria-label` of the control. The Tooltip will be rendered once it is visible; see the next example for what the DOM structure looks like in that case.
|
288
|
-
|
289
|
-
```html
|
290
|
-
<body>
|
291
|
-
<!-- App root -->
|
292
|
-
<div>
|
293
|
-
<button aria-label="Example" onPointerEnter="{...}" onPointerLeave="{...}" onFocus="{...}" onBlur="{...}">
|
294
|
-
<svg>...</svg>
|
295
|
-
</button>
|
296
|
-
</div>
|
297
|
-
</body>
|
298
|
-
```
|
299
|
-
|
300
|
-
## Tooltip as a description
|
301
|
-
|
302
|
-
### JSX tree
|
303
|
-
|
304
|
-
```tsx
|
305
|
-
<Tooltip content="Example description of the button" relationship="description" withArrow>
|
306
|
-
<button>The Button</button>
|
307
|
-
</Tooltip>
|
308
|
-
```
|
309
|
-
|
310
|
-
### DOM
|
311
|
-
|
312
|
-
Tooltip with `relationship="description"` is always rendered because it's used as the `aria-describedby` of the control, which always has to point to a valid DOM element even if it's not visible.
|
313
|
-
|
314
|
-
```html
|
315
|
-
<body>
|
316
|
-
<!-- App root -->
|
317
|
-
<div>
|
318
|
-
<button aria-describedby="tooltip-2" onPointerEnter="{...}" onPointerLeave="{...}" onFocus="{...}" onBlur="{...}">
|
319
|
-
The Button
|
320
|
-
</button>
|
321
|
-
</div>
|
322
|
-
|
323
|
-
<!-- Portal for Tooltip -->
|
324
|
-
<div>
|
325
|
-
<div role="tooltip" id="tooltip-2" class="{tooltip}">
|
326
|
-
<div class="{arrow}"></div>
|
327
|
-
Example description of the button
|
328
|
-
</div>
|
329
|
-
</div>
|
330
|
-
</body>
|
331
|
-
```
|
332
|
-
|
333
|
-
# Migration
|
334
|
-
|
335
|
-
See [MIGRATION.md](./MIGRATION.md).
|
336
|
-
|
337
|
-
# Behaviors
|
338
|
-
|
339
|
-
## Visibility
|
340
|
-
|
341
|
-
- The tooltip shows:
|
342
|
-
- After `showDelay` (250ms default) from when the mouse/pointer enters the trigger.
|
343
|
-
- After `showDelay` (250ms default) from when the trigger gets keyboard focus.
|
344
|
-
- _Immediately_ (ignoring `showDelay`) if it is triggered while another tooltip is currently visible.
|
345
|
-
- The tooltip hides:
|
346
|
-
- After `hideDelay` (250ms default) from when the mouse/pointer leaves BOTH the trigger AND the tooltip itself.
|
347
|
-
- _Immediately_ when the trigger loses keyboard focus.
|
348
|
-
- _Immediately_ when the ESC key is pressed.
|
349
|
-
- _Immediately_ when another tooltip is shown.
|
350
|
-
|
351
|
-
There is only ever one tooltip visible at once (coordinated using `TooltipContext`). If another tooltip is triggered while there's one currently visible, the previous one hides and the new one shows immediately, without delay.
|
352
|
-
|
353
|
-
### Placement
|
354
|
-
|
355
|
-
The tooltip is placed relative to its target element based on the `positioning` prop. The placement is handled by the `@fluentui/react-positioning` package, which uses PopperJS.
|
356
|
-
|
357
|
-
### Focus
|
358
|
-
|
359
|
-
Content within the tooltip is not focusable, and can't be interacted with directly by keyboard or mouse.
|
360
|
-
|
361
|
-
# Accessibility
|
362
|
-
|
363
|
-
- ARIA design pattern: https://www.w3.org/TR/wai-aria-practices-1.2/#tooltip.
|
364
|
-
- The Tooltip content element has `role="tooltip"`.
|
365
|
-
- If Tooltip has `relationship="label"` with simple string content:
|
366
|
-
- The content is set as the trigger's `aria-label`.
|
367
|
-
- The tooltip is only rendered while it is visible.
|
368
|
-
- If Tooltip has `relationship="label"` with JSX content, OR `relationship="description"` (string or JSX):
|
369
|
-
- The tooltip's ID is set as the trigger's `aria-labelledby` or `aria-describedby` (an ID is generated if not provided).
|
370
|
-
- The tooltip is always rendered, even while hidden.
|
371
|
-
- While hidden, the tooltip itself is styled with `display: none`.
|
372
|
-
- The Tooltip itself can never receive focus.
|
373
|
-
- The Tooltip should never contain focusable elements.
|
374
|
-
- The trigger for the Tooltip should be focusable.
|