Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[material-ui][docs] Add Connect-related content #40848

Merged
merged 78 commits into from
Apr 12, 2024
Merged
Show file tree
Hide file tree
Changes from 71 commits
Commits
Show all changes
78 commits
Select commit Hold shift + click to select a range
8b7db60
add Connect-related content on the documentation
danilo-leal Jan 29, 2024
8ab0f54
update content and image
danilo-leal Feb 13, 2024
55d31ba
update border color on dark mode
danilo-leal Feb 13, 2024
7e94a1a
iterate on the Design kits paragraph
danilo-leal Feb 13, 2024
36db8ab
Merge branch 'master' into connect-documentation-content
danilo-leal Feb 13, 2024
8e0ce99
add first skeleton of the documentation
danilo-leal Feb 15, 2024
fbffcd9
run pnpm docs:i18n
danilo-leal Feb 15, 2024
d2885a7
add image to the top of the page
danilo-leal Feb 15, 2024
66ca88b
continue iterating on it
danilo-leal Feb 15, 2024
b902cc1
iterating on the existing tokens section
danilo-leal Feb 16, 2024
119888c
trigger CI checks
danilo-leal Feb 19, 2024
52fba0e
add the Material UI design kit docs
danilo-leal Feb 21, 2024
28a3ff9
Merge branch 'master' into connect-documentation-content
danilo-leal Feb 21, 2024
7c8f7f8
run docs:i18n
danilo-leal Feb 21, 2024
e9a8c44
reordering the pages
danilo-leal Feb 21, 2024
db30f41
run docs:i18n
danilo-leal Feb 21, 2024
6ed171b
remove the MUI prefix from Connect
danilo-leal Feb 28, 2024
7241d3b
remove markdown image element changes from this PR
danilo-leal Feb 28, 2024
6073fb5
run docs:i18n
danilo-leal Feb 28, 2024
b8a9d49
Merge branch 'master' into connect-documentation-content
danilo-leal Feb 28, 2024
917be65
Merge branch 'master' into connect-documentation-content
danilo-leal Mar 1, 2024
0650865
update links to remove the "mui" prefix
danilo-leal Mar 1, 2024
4422995
remove dash from "plugin"
danilo-leal Mar 1, 2024
9d1ce9d
fix error regarding the muiMarkdown import
danilo-leal Mar 4, 2024
a0eaa96
add YouTube videos embeds for the design kits
danilo-leal Mar 4, 2024
bb0dcf0
update Connect images
danilo-leal Mar 4, 2024
b55e401
remove the new chip from the design kit page
danilo-leal Mar 4, 2024
43c6070
iterating on the wording
danilo-leal Mar 8, 2024
c4d320d
Sam's first pass
danilo-leal Mar 25, 2024
63d75a7
Merge branch 'next' into connect-documentation-content
danilo-leal Mar 25, 2024
4821dd4
fix Vale brand name CI check
danilo-leal Mar 25, 2024
e5a6857
Merge branch 'next' into connect-documentation-content
danilo-leal Mar 27, 2024
8000746
add beta chip on the nav drawer item
danilo-leal Mar 28, 2024
baf0238
update the Connect page description
danilo-leal Mar 29, 2024
83ec809
lint: fix non-breaking space
danilo-leal Mar 29, 2024
06f85dc
added getting started section
DavidCnoops Apr 4, 2024
cabb22d
Vale lint: non-breaking space
danilo-leal Apr 4, 2024
8dbe6a2
formatting and adjustments
danilo-leal Apr 4, 2024
5702773
edit the design resources page
danilo-leal Apr 4, 2024
4179064
update to the design kits page
danilo-leal Apr 4, 2024
d22046d
Merge branch 'next' into connect-documentation-content
danilo-leal Apr 4, 2024
0acbe09
Vale lint: fix non-breaking space
danilo-leal Apr 4, 2024
f1d2bce
iterate and fix things on the content + add images
danilo-leal Apr 5, 2024
53b589c
add video about component customization
danilo-leal Apr 5, 2024
e0ea786
extra: fix Demo border styles
danilo-leal Apr 5, 2024
7f6457a
add content about code customizations
danilo-leal Apr 5, 2024
6ffb992
rerun CI checks again
danilo-leal Apr 5, 2024
1199a00
rerun CI checks again
danilo-leal Apr 5, 2024
e549426
Sam's Connect page review
danilo-leal Apr 5, 2024
3d28b19
Sam's review of the Material UI Design Kit page
danilo-leal Apr 5, 2024
bd6f6a6
Design Resources page review
danilo-leal Apr 5, 2024
1891e88
ensure there's non-breaking space
danilo-leal Apr 5, 2024
446741c
follow-up edits
danilo-leal Apr 5, 2024
0198a40
update the Connect page
danilo-leal Apr 8, 2024
f54724a
update the Material UI for Figma page
danilo-leal Apr 9, 2024
31e4bc5
update the Design resources page
danilo-leal Apr 9, 2024
41a8875
slightly revise the Material UI for Figma page
danilo-leal Apr 9, 2024
42f81a0
Vale lint: non-breakable space
danilo-leal Apr 9, 2024
1dfc377
various changes and tweaks
DavidCnoops Apr 9, 2024
53de30a
updated connect docs
DavidCnoops Apr 10, 2024
f2b83d9
updates to the Connect page
danilo-leal Apr 10, 2024
77516db
updates to the Material UI page
danilo-leal Apr 10, 2024
2bc570d
remove unused video
danilo-leal Apr 10, 2024
eee0ae0
compress all images
danilo-leal Apr 10, 2024
33852e8
Vale lint: non-breaking space
danilo-leal Apr 10, 2024
e0f36ee
remove changes on the Demo component
danilo-leal Apr 10, 2024
42050a3
rerun CI checks
danilo-leal Apr 10, 2024
ef9506f
small tweaks
DavidCnoops Apr 11, 2024
27c7b4e
fix linting error
DavidCnoops Apr 11, 2024
dfbee60
has selector clarification + removal of last example
DavidCnoops Apr 11, 2024
34b792a
fix linting error
DavidCnoops Apr 11, 2024
6eac877
Connect page updates
danilo-leal Apr 11, 2024
c2819b5
Material UI for Figma updates
danilo-leal Apr 11, 2024
f891ea5
Design Resources updates
danilo-leal Apr 11, 2024
f41058a
additional edits
danilo-leal Apr 11, 2024
6e53321
Vale lint: non-breakable space
danilo-leal Apr 11, 2024
b3df62e
fine-tune images
danilo-leal Apr 11, 2024
7f47327
Vale lint: non-breakable space
danilo-leal Apr 11, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
296 changes: 296 additions & 0 deletions docs/data/material/design-resources/connect/connect.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,296 @@
# Connect plugin

<p class="description">Connect is a Figma plugin that generates Material UI themes directly from design to code.</p>

## Introduction

[Connect](https://www.figma.com/community/plugin/1336346114713490235/) is a Figma plugin that lets you generate a theme from the [Material UI for Figma Design Kit](https://www.figma.com/community/file/912837788133317724/material-ui-for-figma-and-mui-x/).

:::warning
Connect works in combination with the [Material UI for Figma Design Kit v5.16.0](/~https://github.com/mui/mui-design-kits/releases) and later.
Other kits, such as the Joy UI Design Kit, are not supported yet.
:::

<img src="/static/material-ui/design-resources/connect.png" style="width: 814px;" alt="Customizing the Material UI Switch component in Figma with the Connect plugin running." width="1628" height="400" />

## Running the plugin

If you don't have the [complete and latest version](/store/items/figma-react/) of the Material UI for Figma Design Kit installed, you can test the plugin by using the [Community version](https://www.figma.com/community/file/912837788133317724/material-ui-for-figma-and-mui-x/) instead.

After installing and opening it in Figma, head over to the [Connect plugin page](https://www.figma.com/community/plugin/1336346114713490235/) on the Community tab and click on **Open in...** and select the Material UI for Figma Design Kit.

<img src="/static/material-ui/design-resources/connect-access.png" style="width: 814px;" alt="Accessing Connect via the Resources menu in Figma." width="1628" height="400" />

## Customizing design tokens

Design tokens are defined in the Design Kit's [local variable collections](https://help.figma.com/hc/en-us/articles/15145852043927-Create-and-manage-variables) and include color palettes, breakpoints, shapes, and spacing tokens.
Typography and shadow-related tokens are found in the [local styles collection](https://help.figma.com/hc/en-us/articles/360039820134-Manage-and-share-styles#:~:text=Local%20styles%20are%20styles%20that,or%20from%20the%20style%20picker.).

### Altering existing tokens

The Material UI for Figma Design Kit comes fully loaded with design tokens that map out to the [default theme of the Material UI React library](/material-ui/customization/default-theme/).

To customize existing tokens, open the [local variable modal](https://help.figma.com/hc/en-us/articles/15145852043927-Create-and-manage-variables) by clicking on the filter icon as shown below.
Tweak any of the variables available in the various collections (palette, breakpoints, shapes & spacing) as you see fit.
danilo-leal marked this conversation as resolved.
Show resolved Hide resolved

<img src="/static/material-ui/design-resources/connect-variables.png" style="width: 814px; margin-bottom: 8px;" alt="The Locals variables menu in Figma, where all design tokens are stored and new ones can be added." width="1628" height="400" />
danilo-leal marked this conversation as resolved.
Show resolved Hide resolved

Then open the Connect plugin and click on **Generate theme**.

<img src="/static/material-ui/design-resources/connect-generate.png" style="width: 814px; margin-bottom: 8px;" alt="The Generate theme button in the Connect plugin UI." width="1628" height="400" />

A theme containing the altered tokens is generated and displayed in the plugin's Theme tab.

<img src="/static/material-ui/design-resources/connect-code-editor.png" style="width: 814px; margin-bottom: 8px;" alt="The generated theme displayed in the Connect plugin UI." width="1628" height="400" />

You can also preview the generated theme and the customized tokens by navigating to the Storybook preview tab.

<img src="/static/material-ui/design-resources/connect-storybook.png" style="width: 814px" alt="The generated theme previewed in Storybook in the Connect plugin UI." width="1628" height="400" />

### Adding new tokens

Extend the existing tokens set with your own by either adding new variables to the existing local variable collections, or by adding new elevation and typography styles to the local style collections.
danilo-leal marked this conversation as resolved.
Show resolved Hide resolved
After you've added your custom tokens, click on **Regenerate theme** to includes these tokens in your theme.
danilo-leal marked this conversation as resolved.
Show resolved Hide resolved

<img src="/static/material-ui/design-resources/connect-regenerate.png" style="width: 814px" alt="The 'Regenerate button' in the Connect plugin UI." width="1628" height="400" />
danilo-leal marked this conversation as resolved.
Show resolved Hide resolved

## Customizing components

Connect can also generate theme styles for customized components, enabling you to completely change their look and feel and from within Figma create your custom design system.
danilo-leal marked this conversation as resolved.
Show resolved Hide resolved

:::info
This feature is currently limited to the Button and Switch components.
Support for more components is coming soon.
:::

To demonstrate, let's customize a Switch's checked state, medium size, with primary color, so it looks closer to the iOS design.

Check warning on line 66 in docs/data/material/design-resources/connect/connect.md

View workflow job for this annotation

GitHub Actions / runner / vale

[vale] reported by reviewdog 🐶 [Google.We] Try to avoid using first-person plural like 'let's'. Raw Output: {"message": "[Google.We] Try to avoid using first-person plural like 'let's'.", "location": {"path": "docs/data/material/design-resources/connect/connect.md", "range": {"start": {"line": 66, "column": 17}}}, "severity": "WARNING"}
danilo-leal marked this conversation as resolved.
Show resolved Hide resolved

Note that the Design Kit's component layer hierarchy and layer names should remain unaltered in order for Connect to correctly extract the custom component styles and generate a theme for them.
danilo-leal marked this conversation as resolved.
Show resolved Hide resolved

<img src="/static/material-ui/design-resources/connect-component-variant.png" style="width: 814px; margin-bottom: 8px;" alt="A specific variant of the Switch component selected in the Design Kit" width="1628" height="400" />
danilo-leal marked this conversation as resolved.
Show resolved Hide resolved

Connect generates the following theme code for our customized Switch:

Check warning on line 72 in docs/data/material/design-resources/connect/connect.md

View workflow job for this annotation

GitHub Actions / runner / vale

[vale] reported by reviewdog 🐶 [Google.We] Try to avoid using first-person plural like 'our'. Raw Output: {"message": "[Google.We] Try to avoid using first-person plural like 'our'.", "location": {"path": "docs/data/material/design-resources/connect/connect.md", "range": {"start": {"line": 72, "column": 48}}}, "severity": "WARNING"}
danilo-leal marked this conversation as resolved.
Show resolved Hide resolved

```js
{
components: {
MuiSwitch: {
styleOverrides: {
root: {
'&.MuiSwitch-sizeMedium:has(.MuiSwitch-colorPrimary)': {
'&:has(.Mui-checked):not(:has(.Mui-disabled)):not(:has(.Mui-focusVisible))':
{
width: '40px',
height: '21px',
padding: '0',
'& .MuiSwitch-switchBase': {
transform: 'translateX(19px) translateY(2px)',
padding: '0',
'& .MuiSwitch-thumb': {
width: '17px',
height: '17px',
background: '#FAFAFA',
},
'& + .MuiSwitch-track': {
width: '38px',
height: '21px',
background: 'var(--mui-palette-success-light)',
opacity: '1',
},
},
},
},
},
},
},
},
}
```

The generated theme targets classes that correspond to the specific Switch configuration defined above, so styles are only applied when the Material UI component's props and state match those of the customized Figma component.
danilo-leal marked this conversation as resolved.
Show resolved Hide resolved

To customize the other states, you need to apply the desired design chances to each variant in Figma. To efficiently do this follow these steps:
danilo-leal marked this conversation as resolved.
Show resolved Hide resolved

1. Customize a single "base" variant. For example, a Switch component in the checked state, of medium size, and primary color.
danilo-leal marked this conversation as resolved.
Show resolved Hide resolved
2. Clone this variant and rename it to target the next variant you'd like to customize. For example, rename the cloned version of `Checked=True, Size=Medium, Color=Primary, State=Enabled` to `Checked=False, Size=Medium, Color=Primary, State=Enabled`).
danilo-leal marked this conversation as resolved.
Show resolved Hide resolved
3. Delete the old versions of the same variant.
4. Move the new version to the correct square in the variant grid.
5. Make the necessary style adjustments to the variant's child layers.

Repeat this process for each variant you want to customize.
Below you can see what the result can look like.
danilo-leal marked this conversation as resolved.
Show resolved Hide resolved

<img src="/static/material-ui/design-resources/connect-switch-component-customized.png" style="width: 814px; margin-bottom: 8px;" alt="A fully customized Switch component in the Material UI Design Kit" width="1628" height="400" />
danilo-leal marked this conversation as resolved.
Show resolved Hide resolved

You can run Connect to generate a new theme.
For the example shown above, this the generated theme:
danilo-leal marked this conversation as resolved.
Show resolved Hide resolved

```js
{
components: {
MuiSwitch: {
styleOverrides: {
root: {
"&.MuiSwitch-sizeMedium:has(.MuiSwitch-colorPrimary)": {
width: "40px",
height: "21px",
padding: "0",
"& .MuiSwitch-switchBase": {
padding: "0",
"& .MuiSwitch-thumb": {
width: "17px",
height: "17px",
background: "#FAFAFA",
},
"& + .MuiSwitch-track": {
width: "38px",
height: "21px",
borderRadius: "100px",
opacity: "1",
},
},
"&:not(:has(.Mui-checked)):not(:has(.Mui-disabled)):not(:has(.Mui-focusVisible))": {
"& .MuiSwitch-switchBase": {
transform: "translateX(3px) translateY(2px)",
"& + .MuiSwitch-track": {
background: "#BDBDBD",
},
},
},
"&:not(:has(.Mui-checked)):has(.Mui-disabled):not(:has(.Mui-focusVisible))": {
"& .MuiSwitch-switchBase": {
transform: "translateX(3px) translateY(2px)",
"& + .MuiSwitch-track": {
background: "rgba(229, 229, 229, 0.99)",
},
},
},
"&:not(:has(.Mui-checked)):not(:has(.Mui-disabled)):has(.Mui-focusVisible)": {
"& .MuiSwitch-switchBase": {
transform: "translateX(3px) translateY(2px)",
"& + .MuiSwitch-track": {
border: "1px solid #000",
background: "#BDBDBD",
},
},
},
"&:has(.Mui-checked):has(.Mui-disabled):not(:has(.Mui-focusVisible))": {
"& .MuiSwitch-switchBase": {
transform: "translateX(19px) translateY(2px)",
"& + .MuiSwitch-track": {
background: "rgba(187, 231, 188, 0.99)",
},
},
},
"&:not(:has(.Mui-checked)):not(:has(.Mui-disabled)):not(:has(.Mui-focusVisible)):hover": {
"& .MuiSwitch-switchBase": {
transform: "translateX(3px) translateY(2px)",
"& + .MuiSwitch-track": {
background: "#616161",
},
},
},
"&:has(.Mui-checked):not(:has(.Mui-disabled)):not(:has(.Mui-focusVisible))": {
"& .MuiSwitch-switchBase": {
transform: "translateX(19px) translateY(2px)",
"& + .MuiSwitch-track": {
background: "var(--mui-palette-success-light)",
},
},
},
"&:has(.Mui-checked):not(:has(.Mui-disabled)):not(:has(.Mui-focusVisible)):hover": {
"& .MuiSwitch-switchBase": {
transform: "translateX(19px) translateY(2px)",
"& + .MuiSwitch-track": {
background: "var(--mui-palette-success-dark)",
},
},
},
"&:has(.Mui-checked):not(:has(.Mui-disabled)):has(.Mui-focusVisible)": {
"& .MuiSwitch-switchBase": {
transform: "translateX(19px) translateY(2px)",
"& + .MuiSwitch-track": {
border: "1px solid #000",
background: "var(--mui-palette-success-light)",
},
},
},
},
},
},
},
},
}
```

:::info
The generated theme may contain the CSS `has()` selector, which is used to target specific child classes. This selector is not used by other theme-related examples in the docs because up until recently it had limited browser support. However, since the release of Firefox v124, the selector is [supported by all modern browsers](https://caniuse.com/css-has).
danilo-leal marked this conversation as resolved.
Show resolved Hide resolved
:::

You can also check out the Storybook preview to test the Material UI version of your component.

<img src="/static/material-ui/design-resources/connect-switch-component-customized-storybook.png" style="width: 814px" alt="A fully customized Switch component in Storybook" width="1628" height="400" />
danilo-leal marked this conversation as resolved.
Show resolved Hide resolved

## Using the generated theme

The theme generated by Connect should be used in combination with Material UI's [CssVarsProvider](/material-ui/experimental-api/css-theme-variables/migration/).
The default [ThemeProvider](/material-ui/customization/theming/#theme-provider) is currently not supported.
danilo-leal marked this conversation as resolved.
Show resolved Hide resolved

Here's an example of how you can add the Connect-generated theme to your codebase:
danilo-leal marked this conversation as resolved.
Show resolved Hide resolved

```tsx title="_app.tsx"
import {
experimental_extendTheme as extendTheme,
Experimental_CssVarsProvider as CssVarsProvider,
} from '@mui/material/styles';

export default function MyApp({ Component, pageProps }) {
const theme = extendTheme({
shape: {
borderRadiusRound: 999,
},
components: {
MuiSwitch: {
styleOverrides: {
root: {
'&.MuiSwitch-sizeMedium:has(.MuiSwitch-colorPrimary)': {
'&:has(.Mui-checked):not(:has(.Mui-disabled)):not(:has(.Mui-focusVisible))':
{
width: '40px',
height: '21px',
padding: '0',
'& .MuiSwitch-switchBase': {
transform: 'translateX(19px) translateY(2px)',
padding: '0',
'& .MuiSwitch-thumb': {
width: '17px',
height: '17px',
background: '#FAFAFA',
},
'& + .MuiSwitch-track': {
width: '38px',
height: '21px',
background: 'var(--mui-palette-success-light)',
borderRadius: 'var(--mui-shape-borderRadiusRound)',
opacity: '1',
},
},
},
},
},
},
},
},
});

return (
<CssVarsProvider theme={theme}>
<Component {...pageProps} />
</CssVarsProvider>
);
}
```

## Feedback and bug reports

Use [the dedicated Connect feedback board](https://mui-connect.canny.io/feedback) to share feedback, report bugs, or drop feature requests.
Original file line number Diff line number Diff line change
@@ -0,0 +1,89 @@
# Material UI for Figma

<p class="description">Enhance designer-developer collaboration between Material UI and Figma.</p>

## Getting started

Material UI for Figma consists of representations of the library's React components in Figma so designers and developers can communicate and iterate more efficiently.
In Figma, you will see:

Check warning on line 8 in docs/data/material/design-resources/material-ui-for-figma/material-ui-for-figma.md

View workflow job for this annotation

GitHub Actions / runner / vale

[vale] reported by reviewdog 🐶 [Google.Will] Avoid using 'will'. Raw Output: {"message": "[Google.Will] Avoid using 'will'.", "location": {"path": "docs/data/material/design-resources/material-ui-for-figma/material-ui-for-figma.md", "range": {"start": {"line": 8, "column": 15}}}, "severity": "WARNING"}
danilo-leal marked this conversation as resolved.
Show resolved Hide resolved

- extra components and features that aren't covered in Material Design
- components with the same design as Material UI
- closely mirroed terminology for props, variables, design tokens, and other values
danilo-leal marked this conversation as resolved.
Show resolved Hide resolved

### Community vs. full version

The Material UI design kit is available in the [community (free) version](https://www.figma.com/community/file/912837788133317724/material-ui-for-figma-and-mui-x) and the [full (paid) version](https://mui.com/store/items/figma-react/).

| | Community | Full version |
| :-------------------------------- | --------: | -----------: |
| Components without customizations | All | All |
| Components with customizations | 4 | All |
| Figma variables | - | ✅ |

### Installing the full version

Start by extracting the `.zip` archive which contains the `.fig` files.
Then you can either follow [Figma's import guide](https://help.figma.com/hc/en-us/articles/360041003114-Import-files-into-Figma) or [add it to your team library](https://help.figma.com/hc/en-us/articles/360041051154-Getting-Started-with-Team-Library).

## Theme

### Local variables

The design kit uses Figma's local variables to create a collection of styles that is comparable to the theme structure of the Material UI code.
danilo-leal marked this conversation as resolved.
Show resolved Hide resolved
Follow the steps shown in the video to see all of the variables available:
danilo-leal marked this conversation as resolved.
Show resolved Hide resolved

<iframe width="100%" height="490" src="https://www.youtube.com/embed/u3zR6p-OjKQ?si=DDVEsedwmJQeik3T" title="YouTube video player" frameborder="0" allowfullscreen></iframe>

### Customizing colors

Make sure you use the variables panel to customize colors, as shown in the video below:
danilo-leal marked this conversation as resolved.
Show resolved Hide resolved

<iframe width="100%" height="490" src="https://www.youtube.com/embed/YuzkWFm0-bA?si=XvgPR0vNGtiBPqKY" title="YouTube video player" frameborder="0" allowfullscreen></iframe>

### Customizing typography

On the other hand, typography styles are not available as local variables but as local styles.
danilo-leal marked this conversation as resolved.
Show resolved Hide resolved
The customization experience is similar to modifying colors, though, as shown in the video below:
danilo-leal marked this conversation as resolved.
Show resolved Hide resolved

<iframe width="100%" height="490" src="https://www.youtube.com/embed/HepVDfrLmak?si=gklG_3ZZyxDWzlPM" title="YouTube video player" frameborder="0" allowfullscreen></iframe>

### Switching between light and dark modes

The design kits leverage Figma's local variables to quickly offer you a way to toggle the variable mode to either light or dark, as shown in the video below:
danilo-leal marked this conversation as resolved.
Show resolved Hide resolved

<iframe width="100%" height="490" src="https://www.youtube.com/embed/ydTF1HhLnJM?si=1Fj4CFLgVavfg4Fz" title="YouTube video player" frameborder="0" allowfullscreen></iframe>

## Components

### Editing the main components

The Material UI for Figma Design Kit uses a plugin called [Similayer](https://www.figma.com/community/plugin/735733267883397781/Similayer) to create multiple variants of a given component that essentially build up to the main component.
danilo-leal marked this conversation as resolved.
Show resolved Hide resolved

<iframe width="100%" height="490" src="https://www.youtube.com/embed/eHBk0FbS0P8?si=QbOiMU2F1yvGB6s8" title="YouTube video player" frameborder="0" allowfullscreen></iframe>

### Table component

#### Adding new columns
danilo-leal marked this conversation as resolved.
Show resolved Hide resolved

<iframe src="https://www.loom.com/embed/6dd71cc374bc4d84af35ebb75d107d38?sid=1d3a4790-4c28-433e-94ce-97dd969601dd" frameborder="0" webkitallowfullscreen mozallowfullscreen allowfullscreen style="width: 100%; height: 500px;"></iframe>

#### Adding new columns in the main component
danilo-leal marked this conversation as resolved.
Show resolved Hide resolved

<iframe width="100%" height="490" src="https://www.youtube.com/embed/s_n3LHm1daI?si=_QbXvtYPkc8EBd5d" title="YouTube video player" frameborder="0" allowfullscreen></iframe>

## Code sync

You can export theme tokens and component customizations to code if paired with [the Connect Figma plugin](/material-ui/design-resources/connect/).
danilo-leal marked this conversation as resolved.
Show resolved Hide resolved
Material UI for Figma has been built to be as close to the React components as possible, making it for a fluid integration with code.

Learn more about the Material UI theme structure by visiting the [Theming](https://mui.com/material-ui/customization/theming/) and [Default theme viewer](https://mui.com/material-ui/customization/theming/) pages.

## Using new design kit versions

We generally don't release breaking changes in the updates—we add new content instead.

Check warning on line 84 in docs/data/material/design-resources/material-ui-for-figma/material-ui-for-figma.md

View workflow job for this annotation

GitHub Actions / runner / vale

[vale] reported by reviewdog 🐶 [Google.We] Try to avoid using first-person plural like 'We'. Raw Output: {"message": "[Google.We] Try to avoid using first-person plural like 'We'.", "location": {"path": "docs/data/material/design-resources/material-ui-for-figma/material-ui-for-figma.md", "range": {"start": {"line": 84, "column": 1}}}, "severity": "WARNING"}

Check warning on line 84 in docs/data/material/design-resources/material-ui-for-figma/material-ui-for-figma.md

View workflow job for this annotation

GitHub Actions / runner / vale

[vale] reported by reviewdog 🐶 [Google.We] Try to avoid using first-person plural like 'we'. Raw Output: {"message": "[Google.We] Try to avoid using first-person plural like 'we'.", "location": {"path": "docs/data/material/design-resources/material-ui-for-figma/material-ui-for-figma.md", "range": {"start": {"line": 84, "column": 60}}}, "severity": "WARNING"}
If you need to replace a single component that's been updated, there are a couple of options:

1. Add the new version of the design kit as a library and use [the new Figma library swap feature](https://www.youtube.com/watch?v=GQ2jztKpxLk). The components must have the same names in both libraries.
2. Observe the new component and re-apply the changes to the existing projects. This is the recommended approach when you need to update multiple projects.
3. Copy and paste the new component into your existing project, give it a different temporary name, then re-link tokens to the new component. When using [Select Similar plugins](https://www.figma.com/community/plugin/792767780551514994/Select-Similar) this shouldn't take more than five minutes. Then you can remove the old component and update the new component name.
Loading
Loading