Add tooltips built entirely in CSS to nearly any element. Just add a few classes and an aria-label attribute.
This repository is a module of the full primer repository.
$ npm install --save primer-tooltips
The source files included are written in Sass (
scss) You can simply point your sass
include-path at your
node_modules directory and import it like this.
You can also import specific portions of the module by importing those partials from the
/lib/ folder. Make sure you import any requirements along with the modules.
For a compiled css version of this module, a npm script is included that will output a css version to
build/build.css The built css file is also included in the npm package.
$ npm run build
Add tooltips built entirely in CSS to nearly any element.
Attention: we use
aria-label for tooltips instead of something like
data-tooltip because it is crucial that the tooltip content is available for screen reader users as well. However,
aria-label replaces the text content of an element for screen reader users, so only use tooltip if there is no better way to present the information, or consider using
title for supplement information.
Note: Tooltip classes will conflict with Octicon styles, and as such, must be applied to the parent element instead of the icon.
Specify the direction of a tooltip with north, south, east, and west directions:
Tooltip NorthTooltip North EastTooltip EastTooltip South EastTooltip SouthTooltip South WestTooltip WestTooltip North West
Align tooltips to the left or right of an element, combined with a directional class to specify north or south.
Tooltip North East align left 1Tooltip North East align left 2Tooltip South East align left 1Tooltip South East align left 2Tooltip North West align right 1Tooltip North West align right 2Tooltip South West align right 1Tooltip South West align right 2
.tooltipped-multiline when you have long content. This style has some limitations: you cannot pre-format the text with newlines, and tooltips are limited to a max-width of
Tooltip with multiple lines
By default the tooltips have a slight delay before appearing. This is to keep multiple tooltips in the UI from being distracting. There is a modifier class you can use to override this.
Tooltip no delay