-
-
Notifications
You must be signed in to change notification settings - Fork 32.4k
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][mui-system] Stabilize Grid v2 and deprecate Grid v1 #43054
Conversation
Sorry for the large amount of files changed 😅 most of them are -Unstable_Grid2
+Grid2 |
Netlify deploy preview
Grid2: parsed: +Infinity% , gzip: +Infinity% Bundle size reportDetails of bundle changes (Toolpad) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Just some very small comments. Looks great.
Co-authored-by: Aarón García Hervás <aaron.garcia.hervas@gmail.com> Signed-off-by: Diego Andai <diego@mui.com>
Co-authored-by: Aarón García Hervás <aaron.garcia.hervas@gmail.com> Signed-off-by: Diego Andai <diego@mui.com>
@@ -1,7 +1,7 @@ | |||
import * as React from 'react'; | |||
import Avatar from '@mui/material/Avatar'; | |||
import Box from '@mui/material/Box'; | |||
import Grid from '@mui/material/Unstable_Grid2'; | |||
import Grid from '@mui/material/Grid2'; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Not related to this PR but I still see deprecated system props used in this demo. I found that there is no Unstable_Grid2
in the list of removeSystemProps
codemod, it should be added along with Grid2
to the list.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'll open a separate PR for this after we merge this one 👌🏼
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
PR: #43302
- The spacing mechanism was reworked to use the `gap` CSS property. | ||
|
||
This brings some breaking changes described in the following sections. | ||
|
||
#### Stabilized API |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
#### Stabilized API |
I think this heading is not necessary.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I added sections because they're different breaking changes so providing structure makes it easier to follow, IMO. The other sections are for the size and offset props, and for the removal of disableEqualOverflow
.
|
||
- The previous size and offset props were replaced with the `size` and `offset` props | ||
- The previous size (`xs`, `sm`, `md`, ...) and offset (`xsOffset`, `smOffset`, `mdOffset`, ...) props, which were named after the theme's breakpoints, were replaced with the `size` and `offset` props. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can you add diff snippet to quickly show the migration?
@siriwatknp about this comment:
The diff snippets and details on how to migrate are on the "Size and offset props" section below, this is a summary of the changes. Do you think we shouldn't have the summary? |
My bad, the diff is already in the section below that. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
🛳️ it.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Great that we are consolidating on one approach. I imagine that Pigment CSS Grid is identical to Grid2, developers don't even need to know about it.
Thoughts:
- https://deploy-preview-43054--material-ui.netlify.app/material-ui/react-grid/ How about adding (deprecated) in the H1 to replicate the side nav? This would ensure Google and Algolia searches are clear.
- Do we have an issue to migrate the codebase away from the deprecated Grid? I think we will need one, e.g. for the community to help. Otherwise, it's an issue about removing the old API that we need, but same, to coordinate the work toward it.
- Continuing on 2. It feels like we should only add a runtime deprecation once we have migrated all our codebase. At that point, we would have a high confidence level that Grid v2 superset Grid v1.
- I'm confused about the names. Are
@mui/material/Grid2
and@mui/system/Grid
both Grid v2? If yes, then, please, please, let's make the name match. First because the different should only be about either the default theme is preset or not. And second because we are moving to a place where@mui/material/Grid2
and@mui/material/Grid
don't exist as exports from this npm package.
Initially, I planned to change the Grid v1 name to DeprecatedGrid, but this defeats the purpose of deprecation as it introduces a breaking change (changing the import) instead of offering a deprecation period for users to adjust. We can remove the Grid v2 in v7 and finally rename the Grid v2 to Grid
- Interesting challenge, I didn't look close, I could have seen us go for a straight rename because 1. it's easy to handle for people 2. the API is almost the same, and we can have prop deprecation + props mapping when using the wrong imports to still get most of the behavior right + a clear migration message.
``` | ||
|
||
Alongside the stabilization, the API has been improved. | ||
You can see the changes and further details of how to migrate in the [Material UI v6 migration guide](/material-ui/migrating-to-v6/). |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This link doesn't work.
You can see the changes and further details of how to migrate in the [Material UI v6 migration guide](/material-ui/migrating-to-v6/). | |
You can see the changes and further details on how to migrate in the [Material UI v6 migration guide](/material-ui/migration/migrating-to-v6/). |
Fixed in e36c897
- import { Unstable_Grid2 as Grid2 } from '@mui/material'; | ||
+ import { Grid2 } from '@mui/material'; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Extra line break
- import { Unstable_Grid2 as Grid2 } from '@mui/material'; | |
+ import { Grid2 } from '@mui/material'; | |
-import { Unstable_Grid2 as Grid2 } from '@mui/material'; | |
+import { Grid2 } from '@mui/material'; |
Handled in: #43021
@oliviertassinari, thanks for the feedback. This is the exact debate I went through in my head when deciding not to rename them as it "defeats the purpose of deprecation as it introduces a breaking change (changing the import) instead of offering a deprecation period for users to adjust.". I still think the actual implementation is the correct one, and we're very close to stable, so I don't want to introduce a new change. As the original |
@DiegoAndai Fair points, I guess the main thing I'm trying to get is make progress with #40594 and go to the point where Grid is never exported from @mui/material but only from @mui/system. I could see us supporting In any cases, issue created: #43437, we need to keep track of this for the future. |
Closes: #42761
Stabilize Grid v2 in the
material-ui
andmui-system
packages. This means:Unstable_
prefix from the importsFinally, deprecate the Grid v1 component.
Notes
Initially, I planned to change the Grid v1 name to
DeprecatedGrid,
but this defeats the purpose of deprecation as it introduces a breaking change (changing the import) instead of offering a deprecation period for users to adjust. We can remove the Grid v2 in v7 and finally rename the Grid v2 toGrid
I also planned to reroute the docs as such:
material-ui/deprecated-react-grid
material-ui/react-grid
But this is a pain to do without changing the component's names. I don't think it's critical to make this change so I didn't do it.