-
Notifications
You must be signed in to change notification settings - Fork 83
/
Copy pathTooltip.tsx
100 lines (94 loc) · 4.04 KB
/
Tooltip.tsx
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
import React, { useState, useId } from 'react';
import classNames from 'classnames';
import { Collapse } from '@sb1/ffe-collapse-react';
import { Icon } from '@sb1/ffe-icons-react';
export interface TooltipProps
extends Pick<
React.ComponentProps<'button'>,
| 'aria-controls'
| 'aria-label'
| 'children'
| 'className'
| 'onClick'
| 'tabIndex'
> {
containerProps?: React.ComponentPropsWithoutRef<'div'>;
isOpen?: boolean;
/** @deprecated as part of update to Semantic Colors
*
* Use the `ffe-accent-color` class on the component or on the container of the component instead
* [Read more in the upgrade guide](https://sparebank1.github.io/designsystem/?path=/docs/introduksjon-changelog--docs#2025---februar---semantiske-farger) */
onColoredBg?: never;
}
export const Tooltip = React.forwardRef<HTMLButtonElement, TooltipProps>(
(
{
isOpen: initialIsOpen,
'aria-controls': ariaControls,
'aria-label': ariaLabel = 'Vis hjelpetekst',
children,
className,
onClick,
tabIndex,
containerProps,
},
ref,
) => {
const tooltipButtonId = useId();
const tooltipId = useId();
const [isOpen, setIsOpen] = useState(!!initialIsOpen);
const handleClick = (
evt: React.MouseEvent<HTMLButtonElement, MouseEvent>,
) => {
setIsOpen(prev => !prev);
if (onClick) {
onClick(evt);
}
};
const helpIcon =
'';
return (
<div
{...containerProps}
className={classNames('ffe-tooltip', {
'ffe-tooltip--open': isOpen,
})}
>
<button
ref={ref}
aria-expanded={isOpen}
aria-controls={children ? tooltipId : ariaControls}
aria-label={ariaLabel}
className="ffe-tooltip__icon"
onClick={handleClick}
type="button"
tabIndex={tabIndex}
id={tooltipButtonId}
>
<span aria-hidden={true}>
<Icon
className="ffe-button__icon"
fileUrl={helpIcon}
size="md"
ariaLabel="?"
/>
</span>
</button>
{children && (
<Collapse
className="ffe-tooltip__text"
id={tooltipId}
isOpen={isOpen}
>
<span
className={classNames('ffe-small-text', className)}
role={isOpen ? 'status' : 'none'}
>
{children}
</span>
</Collapse>
)}
</div>
);
},
);