React implementation for figma-plugin-ds by Tom Lowry
Playground β play with the library in Storybook
- react-figma-plugin-ds by Alexandr Tovmach
- Figma Styled Components by Jared
- figma-ui-components by lessmess
- Figma React UI Kit by Liam Martens
First, install the library in your project by npm:
$ npm install react-figma-ui
Or Yarn:
$ yarn add react-figma-ui
To use the button, use the following component. Each button has a destructive option. Tertiary buttons are styled like hyperlinks.
import { Button } from 'react-figma-ui';
// Primary
<Button tint="primary">Label</Button>
<Button tint="primary" destructive>Label</Button>
<Button tint="primary" disabled>Label</Button>
// Secondary
<Button tint="secondary">Label</Button>
<Button tint="secondary" destructive>Label</Button>
<Button tint="secondary" disabled>Label</Button>
// Tertiary (Hyperlink style button)
<Button tint="tertiary">Label</Button>
<Button tint="tertiary" destructive>Label</Button>
<Button tint="tertiary" disabled>Label</Button>
HTML button element props and dedicated params
Param | Description |
---|---|
tint |
Display style for button: primary (filled), secondary (outlined), tertiary (hyperlink) |
destructive |
Add red destructive variant for actions such as deleting something |
To use the checkbox, use the following component. Remember each checkbox should get a unique ID.
import { Checkbox } from 'react-figma-ui';
// Checkbox unchecked
<Checkbox id="uniqueId">Label</Checkbox>
// Checkbox checked
<Checkbox id="uniqueId" checked>Label</Checkbox>
// Checkbox disabled
<Checkbox id="uniqueId" disabled>Label</Checkbox>
HTML input element props and dedicated params
Param | Description |
---|---|
containerProps |
Props for checkbox container |
labelProps |
Props for label element |
To use a disclosure panel, you must use the following component.
import { Disclosure, DisclosureItem } from 'react-figma-ui';
// Example items
const items = [
{ heading: 'Heading 1', content: 'Content 1', id: 1 },
{ heading: 'Heading 2', content: 'Content 2', id: 2 },
{ heading: 'Heading 3', content: 'Content 3', id: 3 },
];
<Disclosure
items={items}
render={({ heading, content, id }, index) => (
<DisclosureItem
heading={heading}
content={content}
section={index % 2 === 0}
expanded={index % 2 === 1}
key={id}
/>
)}
/>
Disclosure
HTML ul element props and dedicated params
Param | Description |
---|---|
items |
Array with disclosure items |
render |
Render props for DisclosureItem |
DisclosureItem
HTML li element props and dedicated params
Param | Description |
---|---|
heading |
Heading text value |
content |
Content text value |
section |
Style label like a heading |
expanded |
Add this option to have item expanded on load |
labelProps |
Props for label element |
contentProps |
Props for content element |
To use the icon, use the following component. Apply the appropriate icon name to select the item you wish to use, you can also add option to change the color, or even spin the icon. You can also specify no icon name to use a text character as an icon (for example, like found in the width + height icon inputs in Figma)
import { Icon } from 'react-figma-ui';
// Icon
<Icon iconName="theme" />
// Icon with blue colorName to change color
<Icon iconName="theme" colorName="blue" />
// Spinner Icon with spinning animation
<Icon iconName="spinner" spin />
// Text Icon
<Icon>W</Icon>
HTML div element props and dedicated params
Param | Description |
---|---|
iconName |
Specify which icon to use (e.g.: alert , draft , settings ) |
spin |
Causes the icon to spin in an endless loop (e.g.: loader used with spinner icon) |
colorName * |
Pass the name of any Figma color var to this prop (e.g.: blue , black3 ) |
*Colors accepted: blue
, purple
, purple4
, hot-pink
, green
, red
, yellow
, black
, black8
, black3
, white
, white8
, white4
The icon button is essentially a wrapper for the icon component.
import { IconButton } from 'react-figma-ui';
// Icon button with a blend icon
<IconButton iconProps={{ iconName: 'blend' }} />
// Icon button with selected option
<IconButton iconProps={{ iconName: 'blend' }} selected />
HTML div element props and dedicated params
Param | Description |
---|---|
selected |
Add this option to have selected style for button |
iconProps |
Props for icon component |
To use the input, use the following component.
import { Input } from 'react-figma-ui';
// Input with placeholder
<Input placeholder="Placeholder" />
// Input with initial value
<Input value="Initial value" />
// Disabled input
<Input value="Initial value" disabled />
// Input with icon
<Input value="Value" iconProps={{ iconName: 'angle' }} />
HTML input element props and dedicated params
Param | Description |
---|---|
containerProps |
Props for switch container |
iconProps |
Props for icon component |
To use a label or section, use following components.
import { Label, SectionTitle } from 'react-figma-ui';
// Label
<Label>Label</Label>
// Section title
<SectionTitle>Section title</SectionTitle>
To create an onboarding tip, use the following component.
import { OnboardingTip } from 'react-figma-ui';
<OnboardingTip iconProps={{ iconName: 'styles' }}>
Onboarding tip goes here.
</OnboardingTip>
HTML div element props and dedicated params
Param | Description |
---|---|
containerProps |
Props for switch container |
iconProps |
Props for icon component |
To create an radio button, use the following component. Remember each group of radio buttons must share the same name so that they are related to one another. Each button should have a unique id so that its label is associated with it and remains part of the clickable hit area.
import { Radio } from 'react-figma-ui';
// Radio button
<Radio value="Value" id="radioButton1" name="radioGroup">Radio button</Radio>
// Radio button checked
<Radio value="Value" id="radioButton2" name="radioGroup" checked>Radio button</Radio>
// Radio button disabled
<Radio value="Value" id="radioButton3" name="radioGroup" disabled>Radio button</Radio>
HTML input element props and dedicated params
Param | Description |
---|---|
containerProps |
Props for radio container |
labelProps |
Props for label element |
To create an select menu, use following components.
The select menu will open and position the menu to the selected object. If there is no vertical room inside your plugin's iFrame, the position of the menu will be moved to ensure it fits inside the iframe. If you have a select menu with too many options to fit within the iFrame, the menu will scroll vertically.
import { SelectMenu, SelectMenuOption } from 'react-figma-ui';
// Example options
const options = [
{ value: 1, label: 'Option 1' },
{ value: 2, label: 'Option 2' },
{ value: 3, label: 'Option 3' },
];
() => (
<SelectMenu
options={options}
render={({ value, label }) => (
<SelectMenuOption value={value} key={value}>
{label}
</SelectMenuOption>
)}
/>
);
SelectMenu
HTML select element props and dedicated params
Param | Description |
---|---|
options |
Array with select menu options |
render |
Render props for SelectMenuOption |
SelectMenuOption
To use the switch, use the following component. Remember each switch should get a unique ID that is referenced in the label. This ensures the switch and the entire label are clickable.
import { Switch } from 'react-figma-ui';
// Switch
<Switch id="uniqueId">Label</Switch>
// Switch checked
<Switch id="uniqueId" checked>Label</Switch>
// Switch disabled
<Switch id="uniqueId" disabled>Label</Switch>
HTML input element props and dedicated params
Param | Description |
---|---|
containerProps |
Props for switch container |
labelProps |
Props for label element |
To use the textarea, use the following component.
import { Textarea } from 'react-figma-ui';
// Textarea
<Textarea value="Initial value" rows={2} />
// Textarea disabled
<Textarea value="Initial value" rows={2} disabled />
To use the typography that is styled like it is in the Figma UI, use the following component plus additional options to modify the size, weight, and letterspacing that is optimized for positive (dark text on light background) and negative (light text on dark background) applications.
import { Type } from 'react-figma-ui';
<Type>UI11, size: xsmall (default) weight: normal, positive</Type>
<Type>UI13, size: large, weight: bold, positive</Type>
<Type size="large" weight="medium" inverse>UI12, size: large, weight: medium, negative</Type>
HTML div element props and dedicated params
Param | Description |
---|---|
size |
Font size: small - 12px, large - 13px, xlarge - 14px |
weight |
Font weight: medium, bold |
inverse |
Inverted (negative) application where light text is on dark background with increased letterspacing |
Defaults: Font size 11px, normal weight, positive application
This project is licensed under the MIT License Β© 2020-present Jakub Biesiada