Material Components widgets
Visual, behavioral, and motion-rich widgets implementing the Material Design guidelines.
- App structure and navigation
- Buttons
- Input and selections
- Dialogs, alerts, and panels
- Information displays
- Layout
See more widgets in the widget catalog.
App structure and navigation
data:image/s3,"s3://crabby-images/f3146/f3146acfd7da081dd6de85fc6dc7b75e48236137" alt=""
A Material Design app bar. An app bar consists of a toolbar and potentially other widgets, such as a TabBar and a FlexibleSpaceBar.
data:image/s3,"s3://crabby-images/14a5c/14a5cc9d206301ce441faa69262d64a70a5ad69c" alt=""
Bottom navigation bars make it easy to explore and switch between top-level views in a single tap. The BottomNavigationBar widget implements this component.
data:image/s3,"s3://crabby-images/41dd2/41dd261acaa580d79614ecdd4c6869e6a754f1a9" alt=""
A Material Design panel that slides in horizontally from the edge of a Scaffold to show navigation links in an application.
data:image/s3,"s3://crabby-images/670bf/670bfb2d9afe7dd63846ad404bb92ef8ec57b9bb" alt=""
A convenience widget that wraps a number of widgets that are commonly required for applications implementing Material Design.
data:image/s3,"s3://crabby-images/3021e/3021e6bf1eb1265364609bd94c0e9c060ffcae95" alt=""
Implements the basic Material Design visual layout structure. This class provides APIs for showing drawers, snack bars, and bottom sheets.
data:image/s3,"s3://crabby-images/f3146/f3146acfd7da081dd6de85fc6dc7b75e48236137" alt=""
A material design app bar that integrates with a CustomScrollView.
data:image/s3,"s3://crabby-images/5e7d1/5e7d12aa1a9fe901615d01d4fc4886b119bd0446" alt=""
A Material Design widget that displays a horizontal row of tabs.
data:image/s3,"s3://crabby-images/5e7d1/5e7d12aa1a9fe901615d01d4fc4886b119bd0446" alt=""
A page view that displays the widget which corresponds to the currently selected tab. Typically used in conjunction with a TabBar.
data:image/s3,"s3://crabby-images/5e7d1/5e7d12aa1a9fe901615d01d4fc4886b119bd0446" alt=""
Coordinates tab selection between a TabBar and a TabBarView.
data:image/s3,"s3://crabby-images/5e7d1/5e7d12aa1a9fe901615d01d4fc4886b119bd0446" alt=""
Displays a row of small circular indicators, one per tab. The selected tab's indicator is highlighted. Often used in conjunction with a TabBarView.
data:image/s3,"s3://crabby-images/535f0/535f02868bd1291e29b77ae7ba0be9be289d9feb" alt=""
A convenience class that wraps a number of widgets that are commonly required for an application.
Buttons
data:image/s3,"s3://crabby-images/48e49/48e498efac6c9e4882e9b3272cf23343c99a63b4" alt=""
Shows the currently selected item and an arrow that opens a menu for selecting another item.
data:image/s3,"s3://crabby-images/b6514/b6514bb5d783516995975da5c28c6e9609bb9cde" alt=""
A Material Design elevated button. A filled button whose material elevates when pressed.
data:image/s3,"s3://crabby-images/aabdc/aabdc6a2850796eb2969ba739c1cf1da715dcca7" alt=""
A floating action button is a circular icon button that hovers over content to promote a primary action in the application. Floating action buttons are...
data:image/s3,"s3://crabby-images/bdad8/bdad8e3e8195b63f7ad32bbc2336f59916446663" alt=""
An icon button is a picture printed on a Material widget that reacts to touches by filling with color (ink).
data:image/s3,"s3://crabby-images/e4c1d/e4c1d886fac183b76d3f121669d4081777cbf0f2" alt=""
A Material Design outlined button, essentially a TextButton with an outlined border.
data:image/s3,"s3://crabby-images/30c67/30c6726ea0ec4b60505d16a1729e03a4986368a7" alt=""
Displays a menu when pressed and calls onSelected when the menu is dismissed because an item was selected.
data:image/s3,"s3://crabby-images/2cd91/2cd9179056a957b8ab05be4f376c1931cff06235" alt=""
A Material Design text button. A simple flat button without a border outline.
Input and selections
data:image/s3,"s3://crabby-images/04a7c/04a7ca7de56ba814f718eba64b543c3421392fe0" alt=""
Checkboxes allow the user to select multiple options from a set. The Checkbox widget implements this component.
data:image/s3,"s3://crabby-images/0e853/0e8532d4bf3a2e17c47f7d1cbe5074bda7958409" alt=""
Date pickers use a dialog window to select a single date on mobile. Time pickers use a dialog to select a single time (in the...
data:image/s3,"s3://crabby-images/38c4a/38c4aba1695b29a1988e27f91935171fd4834848" alt=""
Radio buttons allow the user to select one option from a set. Use radio buttons for exclusive selection if you think that the user needs...
data:image/s3,"s3://crabby-images/28d39/28d394cfab48bd8318f73ba7264d7b54de88c88d" alt=""
Sliders let users select from a range of values by moving the slider thumb.
data:image/s3,"s3://crabby-images/7e6b3/7e6b3966aaab2554f3a5fde89eb533dbb979c935" alt=""
On/off switches toggle the state of a single settings option. The Switch widget implements this component.
data:image/s3,"s3://crabby-images/fa59f/fa59f83dc6081eac39d4eb45832b1fd0e0e4d0f1" alt=""
Touching a text field places the cursor and displays the keyboard. The TextField widget implements this component.
Dialogs, alerts, and panels
data:image/s3,"s3://crabby-images/7ff24/7ff24ecdf61c06e09696dec4932c9c1a3fc69f80" alt=""
Alerts are urgent interruptions requiring acknowledgement that inform the user about a situation. The AlertDialog widget implements this component.
data:image/s3,"s3://crabby-images/098c3/098c31cc903b47ffe3d4e3aef35a0f215b785620" alt=""
Bottom sheets slide up from the bottom of the screen to reveal more content. You can call showBottomSheet() to implement a persistent bottom sheet or...
data:image/s3,"s3://crabby-images/00bca/00bca02e89e6174128409c31e638127ea6560d3b" alt=""
Expansion panels contain creation flows and allow lightweight editing of an element. The ExpansionPanel widget implements this component.
data:image/s3,"s3://crabby-images/cbda1/cbda1ac7089c2f2c8537a99ad864933cf21124e5" alt=""
Simple dialogs can provide additional details or actions about a list item. For example they can display avatars icons clarifying subtext or orthogonal actions (such...
data:image/s3,"s3://crabby-images/de6d7/de6d7d9225a52f3bced1f7cfd7700cc671e62bbd" alt=""
A lightweight message with an optional action which briefly displays at the bottom of the screen.
Information displays
data:image/s3,"s3://crabby-images/e4623/e46238e6516ad0335ae3c78cee2dd510f4bfcf3a" alt=""
A Material Design card. A card has slightly rounded corners and a shadow.
data:image/s3,"s3://crabby-images/50125/501258d1f2a5e3b23fa1cb0d8829b151fc3b1b92" alt=""
A Material Design chip. Chips represent complex entities in small blocks, such as a contact.
data:image/s3,"s3://crabby-images/81517/815174dfa70882b6e3fb6f3b4ffc2e33c2a79dbb" alt=""
A material design circular progress indicator, which spins to indicate that the application is busy.
data:image/s3,"s3://crabby-images/93207/932077cfef0d8e217bb8bd5842b59a50abd90320" alt=""
Data tables display sets of raw data. They usually appear in desktop enterprise products. The DataTable widget implements this component.
data:image/s3,"s3://crabby-images/5151e/5151e5631eb121dc8dec6549de77e2fad09a3f3c" alt=""
A grid list consists of a repeated pattern of cells arrayed in a vertical and horizontal layout. The GridView widget implements this component.
data:image/s3,"s3://crabby-images/184c8/184c8adfdeb1d22e11a99451d494bc61d4d39262" alt=""
A Material Design icon.
A widget that displays an image.
data:image/s3,"s3://crabby-images/f839b/f839b79faee75c3a957a725b69c1573a09017c41" alt=""
A material design linear progress indicator, also known as a progress bar.
data:image/s3,"s3://crabby-images/3ab55/3ab552e5d3ca00e1deed2e84bf976de8f3bf40a7" alt=""
Tooltips provide text labels that help explain the function of a button or other user interface action. Wrap the button in a Tooltip widget to...
Layout
data:image/s3,"s3://crabby-images/d898d/d898d1a5ccc23294fff19c2ba5429145bc7294ed" alt=""
A one logical pixel thick horizontal line, with padding on either side.
data:image/s3,"s3://crabby-images/81f00/81f007a9995dd6c70c7667cc37417bf43e5f8b24" alt=""
A single fixed-height row that typically contains some text as well as a leading or trailing icon.
data:image/s3,"s3://crabby-images/fdb2e/fdb2eebad059ed868d8c27cbf06a7d0032a4f877" alt=""
A Material Design stepper widget that displays progress through a sequence of steps.
See more widgets in the widget catalog.