Use the Icon
component to render a visual icon within other components. It can generally be used inside most components, excluding ones that don't support child components (e.g., the Input
component does not support icons).
x
import { Alert, Button, Flex, Icon, Text } from '@hubspot/ui-extensions';
const Extension = () => {
return (
<Flex direction="column" gap="small">
<Alert title="AlertTitle">
<Icon name="download" /> Icon inside an Alert
</Alert>
<Button>
<Icon name="download" /> Icon inside a button
</Button>
<Text>
<Icon name="download" /> Icon with text
</Text>
</Flex>
);
};
Prop | Type | Description |
---|---|---|
name Required | String | Sets the icon to display. See all available icons. |
size | 'small' | 'medium' | 'large' | By default, the size of the icon is set automatically based on the parent component. If you need to override the default size, you can specify one to use instead. |
screenReaderText | String | Sets the text that screen readers will read for the icon. |
By default, spacing is not added around the icon. However, there may be times when you want more space between the icon and neighboring text. You can do this by manually adding a space to the text string, or by using
or {" "}
as shown below.
xxxxxxxxxx
17
import { Alert, Flex, Icon, Tile, Text } from '@hubspot/ui-extensions';
const Extension = () => {
return (
<Flex direction="column" gap="small">
<Alert title="AlertTitle">
<Icon name="warning" /> Icon inside an alert
</Alert>
<Tile>
<Icon name="robot" /> Icon inside a tile
</Tile>
<Text>
<Icon name="faceHappy" /> Icon with text
</Text>
</Flex>
);
};
Below are the currently available icons and their name
values.
data:image/s3,"s3://crabby-images/5f176/5f1769d2f05812004f2c4451269e995f60cc7ea8" alt="uie-components-icons-add"
add
data:image/s3,"s3://crabby-images/5b9e6/5b9e6c59001e9967787e100a5e0b305cf18d2800" alt="uie-components-icons_33"
attach
data:image/s3,"s3://crabby-images/687de/687deea8fefe3d56c8a75f598646f89ab070f230" alt="uie-components-icons_bulb"
bulb
data:image/s3,"s3://crabby-images/6cdc0/6cdc0056ac70b48c50f729c657b331145af6b6dc" alt="uie-components-icons_32"
clock
data:image/s3,"s3://crabby-images/d411a/d411a75915c36e82ceed8b1aa8cb8dccc4dbe618" alt="uie-components-icons_1"
comment
data:image/s3,"s3://crabby-images/d04f1/d04f184e75b8e60c69742e698dd1c4bc596d9c81" alt="uie-components-icons_31"
contact
data:image/s3,"s3://crabby-images/13f0d/13f0ddf4ddc643f046fda12281a3fd0adfc9d5a2" alt="uie-components-icons_copy"
copy
data:image/s3,"s3://crabby-images/bc654/bc6542e550b06283e3a68124a69ce51f2a8d1f4d" alt="uie-components-icons_30"
dataSync
data:image/s3,"s3://crabby-images/afb9d/afb9da40c28a8c043ebccf90c816dbc2beba5610" alt="uie-components-icons_29"
date
data:image/s3,"s3://crabby-images/ee8ce/ee8ce5d7cbbce6a97a9d106850adc0a538a818c6" alt="uie-components-icons_28"
delete
data:image/s3,"s3://crabby-images/0c3d9/0c3d95ee077e16398e6a39092d869d7d7bacb24f" alt="uie-components-icons_27"
downCarat
data:image/s3,"s3://crabby-images/809e6/809e619da3d10d2e709271cd7207ac65d717a925" alt="uie-component-icon-in-button-download"
download
data:image/s3,"s3://crabby-images/b4249/b424999f099fe11dc529e6b396f7f1a1a949ef78" alt="uie-components-icons_25"
edit
data:image/s3,"s3://crabby-images/ef11c/ef11c71deb7d96d0de196c5ef0b4c4bad9937a14" alt="uie-components-icons_24"
email
data:image/s3,"s3://crabby-images/d6ceb/d6cebe38553ca41e06a1189eb8e4943161957566" alt="uie-components-icons_23"
exclamation
data:image/s3,"s3://crabby-images/5943f/5943fea2986467fa56d01df1bbba7528aeb55f50" alt="uie-components-icons_22"
faceHappy
data:image/s3,"s3://crabby-images/5bcb6/5bcb6e9d10101a586fcf53dc0e0683f9a1aaacea" alt="ui-extension-icon-faceneutral"
faceNeutral
data:image/s3,"s3://crabby-images/ad2ed/ad2ed97df42ca93cefa0c30b5b1e70ca310c7af7" alt="uie-components-icons_21"
faceSad
data:image/s3,"s3://crabby-images/df33b/df33b18dcd7054fde21d9438868a6a0aeea289a5" alt="uie-components-icons_20"
file
data:image/s3,"s3://crabby-images/8f1d5/8f1d56d22e40a5565a05eb861fbe90769628ef25" alt="uie-components-icons_home"
home
data:image/s3,"s3://crabby-images/37e6e/37e6e77ca608d8e9c3d18ee50d43efdbda948d50" alt="uie-components-icons_19"
imageGallery
data:image/s3,"s3://crabby-images/16f48/16f48973e65520868593782a1c7733a4d85c6af5" alt="uie-components-icons_18"
left
data:image/s3,"s3://crabby-images/9897d/9897da72a14395aa6a7b8a950f14751294a74c92" alt="uie-components-icons_17"
location
data:image/s3,"s3://crabby-images/9ac01/9ac01f99f5c948a134f335628802989a50d7a435" alt="uie-component-icon-in-button-notification2"
notification
data:image/s3,"s3://crabby-images/78ab4/78ab45d98a1950018a9601ba587f6366b52b25b5" alt="uie-component-icon-in-button-question"
question
data:image/s3,"s3://crabby-images/28570/28570897e04903e94dbdec3da100cba094069198" alt="uie-components-icons_15"
refresh
data:image/s3,"s3://crabby-images/02795/02795a81fd7ef5440267c6d1e0d2b019be5a8547" alt="uie-components-icons_14"
remove
data:image/s3,"s3://crabby-images/0262f/0262f05c206ba6b6d737e8d1bcb0607211b18421" alt="uie-components-icons_13"
reports
data:image/s3,"s3://crabby-images/1df7d/1df7dfb8802071a43b0c6549ddd9d493e93735f0" alt="uie-components-icons_12"
right
data:image/s3,"s3://crabby-images/4e110/4e110e49f98f35d7d86e0c56816d711e878a75ab" alt="uie-components-icons_11"
robot
data:image/s3,"s3://crabby-images/d91b6/d91b6f46d47546f3e9635f6ea4ac7400f5e7e61d" alt="uie-components-icons_10"
save
data:image/s3,"s3://crabby-images/47752/47752a2d2f70355498dfd5463577a0c80ae15900" alt="uie-components-icons_9"
search
data:image/s3,"s3://crabby-images/c7a1b/c7a1b1064c3ab4d6f5fd2f90b23efef23d52215a" alt="uie-components-icons_settings"
settings
data:image/s3,"s3://crabby-images/67527/67527e27927d82ac8d13489723c321cab277c605" alt="uie-components-icons_8"
shoppingCart
data:image/s3,"s3://crabby-images/54cca/54cca9d74ce7fa87de885991e89a930dcaa7240a" alt="uie-components-icons_7"
star
data:image/s3,"s3://crabby-images/dc163/dc16389d8b167f69347da826145ba568eef7e21f" alt="uie-components-icons_6"
success
data:image/s3,"s3://crabby-images/5087b/5087b5c72ebe213fdc0d79d6a2c4057e5c81c22c" alt="uie-components-icons_5"
upCarat
data:image/s3,"s3://crabby-images/5de24/5de24b78b1fab1fa1e537f391ca50c8a64869c7c" alt="uie-components-icons_4"
upload
data:image/s3,"s3://crabby-images/bddcc/bddcca1a6fbea2cd2f0f32ea4eea0678169b1fc6" alt="uie-components-icons_3"
video
data:image/s3,"s3://crabby-images/a102f/a102f16f304fca61bcd83db042c505911782cb9c" alt="uie-components-icons_2"
warning
Always pair icons with text. If that is not possible, include the screenReaderText
prop to convey the icon's meaning for users with screen readers.