Icon Button
<sl-icon-button> | SlIconButton
Icons buttons are simple, icon-only buttons that can be used for actions and in toolbars.
Examples
Basic Icon Button
For a full list of icons that come bundled with Shoelace, refer to the icon component.
<sl-icon-button name="cog-6-tooth" label="Settings"></sl-icon-button>
sl-icon-button name="cog-6-tooth" label="Settings"
import SlIconButton from '@teamshares/shoelace/dist/react/icon-button'; const App = () => <SlIconButton name="cog-6-tooth" label="Settings" />;
Sizes
Icon buttons inherit their parent element’s font-size
.
<sl-icon-button name="pencil" label="Edit" style="font-size: 1.5rem;"></sl-icon-button> <sl-icon-button name="pencil" label="Edit" style="font-size: 2rem;"></sl-icon-button> <sl-icon-button name="pencil" label="Edit" style="font-size: 2.5rem;"></sl-icon-button>
sl-icon-button name="pencil" label="Edit" style="font-size: 1.5rem;" sl-icon-button name="pencil" label="Edit" style="font-size: 2rem;" sl-icon-button name="pencil" label="Edit" style="font-size: 2.5rem;"
import SlIconButton from '@teamshares/shoelace/dist/react/icon-button'; const App = () => ( <> <SlIconButton name="pencil" label="Edit" style={{ fontSize: '1.5rem' }} /> <SlIconButton name="pencil" label="Edit" style={{ fontSize: '2rem' }} /> <SlIconButton name="pencil" label="Edit" style={{ fontSize: '2.5rem' }} /> </> );
Colors
Icon buttons are designed to have a uniform appearance, so their color is not inherited. However, you can
still customize them by styling the base
part.
<div class="icon-button-color"> <sl-icon-button name="at-symbol" label="Bold"></sl-icon-button> <sl-icon-button name="bolt" label="Italic"></sl-icon-button> <sl-icon-button name="no-symbol" label="Underline"></sl-icon-button> </div> <style> .icon-button-color sl-icon-button::part(base) { color: #b00091; } .icon-button-color sl-icon-button::part(base):hover, .icon-button-color sl-icon-button::part(base):focus { color: #c913aa; } .icon-button-color sl-icon-button::part(base):active { color: #960077; } </style>
div.icon-button-color sl-icon-button name="at-symbol" label="Bold" sl-icon-button name="bolt" label="Italic" sl-icon-button name="no-symbol" label="Underline" css: .icon-button-color sl-icon-button::part(base) { color: #b00091; } .icon-button-color sl-icon-button::part(base):hover, .icon-button-color sl-icon-button::part(base):focus { color: #c913aa; } .icon-button-color sl-icon-button::part(base):active { color: #960077; }
import SlIconButton from '@teamshares/shoelace/dist/react/icon-button'; const css = ` .icon-button-color sl-icon-button::part(base) { color: #b00091; } .icon-button-color sl-icon-button::part(base):hover, .icon-button-color sl-icon-button::part(base):focus { color: #c913aa; } .icon-button-color sl-icon-button::part(base):active { color: #960077; } `; const App = () => ( <> <div className="icon-button-color"> <SlIconButton name="at-symbol" label="Bold" /> <SlIconButton name="bolt" label="Italic" /> <SlIconButton name="no-symbol" label="Underline" /> </div> <style>{css}</style> </> );
Link Buttons
Use the href
attribute to convert the button to a link.
<sl-icon-button name="cog-6-tooth" label="Settings" href="https://example.com" target="_blank"></sl-icon-button>
sl-icon-button name="cog-6-tooth" label="Settings" href="https://example.com" target="_blank"
import SlIconButton from '@teamshares/shoelace/dist/react/icon-button'; const App = () => <SlIconButton name="cog-6-tooth" label="Settings" href="https://example.com" target="_blank" />;
Icon Button with Tooltip
Wrap a tooltip around an icon button to provide contextual information to the user.
<sl-tooltip content="Settings"> <sl-icon-button name="cog-6-tooth" label="Settings"></sl-icon-button> </sl-tooltip>
sl-tooltip content="Settings" sl-icon-button name="cog-6-tooth" label="Settings"
import SlIconButton from '@teamshares/shoelace/dist/react/icon-button'; import SlTooltip from '@teamshares/shoelace/dist/react/tooltip'; const App = () => ( <SlTooltip content="Settings"> <SlIconButton name="cog-6-tooth" label="Settings" /> </SlTooltip> );
Disabled
Use the disabled
attribute to disable the icon button.
<sl-icon-button name="cog-6-tooth" label="Settings" disabled></sl-icon-button>
sl-icon-button name="cog-6-tooth" label="Settings" disabled="true"
import SlIconButton from '@teamshares/shoelace/dist/react/icon-button'; const App = () => <SlIconButton name="cog-6-tooth" label="Settings" disabled />;
Component Props
Property | Default | Details |
---|---|---|
name
|
— |
The name of the icon to draw. Available names depend on the icon library being used. |
library
|
— |
The name of a registered custom icon library. |
src
|
— |
An external URL of an SVG file. Be sure you trust the content you are including, as it will be executed as code and can result in XSS attacks. |
href
|
— |
When set, the underlying button will be rendered as an |
target
|
— |
Tells the browser where to open the link. Only used when |
download
|
— |
Tells the browser to download the linked file as this filename. Only used when
|
label
|
''
|
A description that gets read by assistive devices. For optimal accessibility, you should always include a label that describes what the icon button does. |
disabled
|
false
|
Disables the button. |
updateComplete
|
A read-only promise that resolves when the component has finished updating. |
Learn more about attributes and properties.
Events
Name | Name | React Event | Details | |
---|---|---|---|---|
sl-blur
|
sl-blur
|
onSlBlur
|
Emitted when the icon button loses focus. |
|
sl-focus
|
sl-focus
|
onSlFocus
|
Emitted when the icon button gains focus. |
Learn more about events.
Methods
Name | Details |
---|---|
click()
|
Simulates a click on the icon button. |
focus()
|
Sets focus on the icon button. |
blur()
|
Removes focus from the icon button. |
Learn more about methods.
CSS Parts
Name | Description |
---|---|
base
|
The component’s base wrapper. |
Learn more about customizing CSS parts.
Dependencies
This component automatically imports the following dependencies.
-
<sl-icon>