Material Design for Angular
This is the home for the Angular team's Material Design components built for and with Angular.
Quick links
Documentation, demos, and guides | Google group | Contributing | Plunker Template | StackBlitz Template
Getting started
See our Getting Started Guide if you're building your first project with Angular Material.
Check out our directory of design documents for more insight into our process.
If you'd like to contribute, you must follow our contributing guidelines.
You can look through the issues (which should be up-to-date on who is working on which features
and which pieces are blocked) and make a comment.
Also see our help wanted
label.
High level stuff planned for Q2 2018 (April - June):
- Implementing cdk virtual-scroll
- Implementing cdk drag-and-drop
- Ongoing migration to bazel
- Table feature improvements
- Improve docs for cdk
- Accessibility improvements for select, autocomplete, button-toggle, and chips.
Available features
Feature | Notes | Docs |
---|---|---|
autocomplete | Docs | |
button | Docs | |
button-toggle | Docs | |
cards | Docs | |
checkbox | Docs | |
chips | Docs | |
data-table | More features coming in 2018 | Docs |
datepicker | Docs | |
dialog | Docs | |
divider | Docs | |
expansion-panel | Docs | |
grid-list | Docs | |
icon | Docs | |
input | Docs | |
list | Action list planned 2018 | Docs |
menu | Docs | |
paginator | Docs | |
progress-bar | Docs | |
progress-spinner | Docs | |
radio | Docs | |
ripples | Docs | |
select | Docs | |
sidenav | Docs | |
slide-toggle | Docs | |
slider | Docs | |
snackbar / toast | Docs | |
sort-header | Docs | |
stepper | Docs | |
tabs | Docs | |
textarea | Docs | |
toolbar | Docs | |
tooltip | Docs | |
---------------- | ------------------------------------------------------ | ------------ |
theming | Guide | |
typography | Guide | |
layout | See angular/flex-layout | Wiki |
cdk | Docs |
In progress, planned, and non-planned features
Feature | Status | Docs | Issue |
---|---|---|---|
tree | Releasing with 6.0.0 | - | #3175 |
sticky-header | In-progress, planned Q2 2018 | - | #474 |
virtual-repeat | Prototyping, planned Q2 2018 | - | #823 |
badge | Releasing with 6.0.0 | - | #3085 |
fab speed-dial | Not started, not planned | - | #860 |
fab toolbar | Not started, not planned | - | - |
bottom-sheet | Releasing with 6.0.0 | - | #8113 |
bottom-nav | Not started, not planned | - | #408 |
The goal of Angular Material
Our goal is to build a set of high-quality UI components built with Angular and TypeScript, following the Material Design spec. These components will serve as an example of how to write Angular code following best practices.
What do we mean by "high-quality"?
- Internationalized and accessible so that all users can use them.
- Straightforward APIs that don't confuse developers.
- Behave as expected across a wide variety of use-cases without bugs.
- Behavior is well-tested with both unit and integration tests.
- Customizable within the bounds of the Material Design specification.
- Performance cost is minimized.
- Code is clean and well-documented to serve as an example for Angular devs.
Browser and screen reader support
Angular Material supports the most recent two versions of all major browsers: Chrome (including Android), Firefox, Safari (including iOS), and IE11 / Edge
We also aim for great user experience with the following screen readers:
- NVDA and JAWS with IE / FF / Chrome (on Windows).
- VoiceOver with Safari on iOS and Safari / Chrome on OSX.
- TalkBack with Chrome on Android.