IconButton
Icon Buttons are buttons within Arc that only have an icon inside. These buttons are used sparingly, but are often required on complex screens.
data:image/s3,"s3://crabby-images/98433/984332d3098dbd52547847c6445af7d1e5843dc6" alt="IconButton"
Features
Pairs with a Tooltip to provide context around the functionalities of the IconButton.
#Import
import { IconButton } from '@wpmedia/ads-button'
interface IconButtonProps
Props | Description |
---|---|
label (optional) | undefined | string Optional label for the icon button |
position | undefined | "bottom" | "bottom left" | "bottom right" | "bottom start" | "bottom end" | "top" | "top left" | "top right" | "top start" | "top end" | "left" | "left top" | "left bottom" | "start" | "start top" | "start bottom" | "right" | "right top" | "right bottom" | "end" | "end top" | "end bottom" Position of the corresponding tooltip |
#Usage
#Component structure
data:image/s3,"s3://crabby-images/0d6ab/0d6ab7bee1c4430246e8efe943d79e444db7050b" alt="Icon Button component structure diagram. Icon Button component structure diagram"
- Background container - This is what makes up the body of the button. This also is the hitzone for the button, accomodating touch screen devices.
- Icon - The icon component within the icon button. Read more about icons.
#Usage
#Do
- Use the various button types & best practices.
- All icon buttons must be paired with a tooltip. This is critical for building our users’ visual vocabulary, while also providing context. Some icons may not be inherently understandable without the tooltip.
data:image/s3,"s3://crabby-images/38759/38759cea96c7a8ae2b8cb7335f640a214921437c" alt="Icon Button Tooltip"
- Use button states (ex. Using an icon button for delete should be red, since it is a destructive action). See button states.
- For the icons inside the button, do not detach the coupled
SVG title
. This is important for screen readers. Generally, theSVG title
should also match the tooltip.
#Don't
- Change any color of Icons. Icons inherit fill, hover, and other properties based on the parent element.