Material 3 Layouts
The Anvil Material 3 theme comes with two predefined layouts, based on two different styles of Material 3 navigation regions.
data:image/s3,"s3://crabby-images/4b1a1/4b1a11d9df97f814d41cf0c62881d1c257ebbaa8" alt="The two predefined layouts:
NavigationDrawerLayout and NavigationRailLayout"
The two predefined layouts:
NavigationDrawerLayout and NavigationRailLayout
Layouts have properties that allow for greater interaction. These can be set from the Form that’s using the layout – either from code or from the Properties Panel. For example, both layouts have an optional side sheet, which can be controlled by setting the show_sidesheet
property to True
or False
.
def m3_button_click(self, **event_args):
"""This method is called when the component is clicked."""
self.layout.show_sidesheet = True
data:image/s3,"s3://crabby-images/4ae9d/4ae9d064dcd06f2932cc86e6b72067d066186c0c" alt="A Form with a side sheet"
A Form with a side sheet
Navigation Rail Layout
The Navigation Rail Layout uses the Material 3 navigation rail. Navigation rails are meant for displaying a small number of app destinations (see the Material 3 usage guidelines for more information).
data:image/s3,"s3://crabby-images/ef44f/ef44f563f14faab37ad71362d2d7ed218dadefa9" alt="A Form using the Navigation Rail Layout"
A Form using the Navigation Rail Layout
You can control the vertical alignment of the content of the navigation rail with the navigation_rail_vertical_align
property.
self.layout.navigation_rail_vertical_align = "center"
data:image/s3,"s3://crabby-images/4772f/4772f79be1c355aea059ed6da3562cc9e7de4148" alt=""
On smaller screens, the navigation rail can be collapsed into a modal drawer or an app bar. This can be controlled with the navigation_rail_collapse_to
property.
data:image/s3,"s3://crabby-images/bf2e0/bf2e017acca6bc0275183cdbd6ee1ed4c6895791" alt="A Navigation Rail collapsed
into an App Bar on mobile"
A Navigation Rail collapsed
into an App Bar on mobile
Visit the API documentation for more information about the Navigation Rail Layout.
Navigation Drawer Layout
The Navigation Drawer Layout uses the Material 3 navigation drawer. Navigation drawers are best suited when you want to display a longer list of app destinations. They’re also useful when you want to convey navigation hierarchys and groupings (see the Material 3 usage guidelines for more information).
data:image/s3,"s3://crabby-images/50be5/50be567c85138bf58313235d2c9243b73a4fb7d2" alt="A Form using the Navigation Drawer Layout"
A Form using the Navigation Drawer Layout
On smaller screens, the navigation drawer will always collapse into a modal drawer.
data:image/s3,"s3://crabby-images/9cfad/9cfad2d26d5ec94fea59d0c39427116dfb79306d" alt="Navigation Drawers always
collapse into a modal drawer"
Navigation Drawers always
collapse into a modal drawer
Visit the API documentation for more information about the Navigation Drawer Layout.
Do you still have questions?
Our Community Forum is full of helpful information and Anvil experts.