Skip to content

Latest commit

 

History

History
2997 lines (2517 loc) · 405 KB

CHANGELOG.md

File metadata and controls

2997 lines (2517 loc) · 405 KB

6.0.0-beta.5 (2018-03-23)

This release contains many breaking changes due to the deletion of deprecated targets. We are currently working on a tool that will help migrate your app if you are affected by these changes. We expect to have the tool ready when we release version 6.0.0.

BREAKING CHANGES

  • typography: The $mat-font-family variable has been removed. Use the Material typography or redeclare in your project $mat-font-family: Roboto, 'Helvetica Neue', sans-serif;.
  • datepicker: MatDatePicker now requires an animations module to be loaded
  • datepicker: selectedChanged has been removed. Use dateChange or dateInput from MatDatepickerInput.
  • button-toggle: selected is no longer an input and is now readonly.
  • snack-bar: SHOW_ANIMATION has been removed.
  • HIDE_ANIMATION has been removed.
  • icon: The _document parameter in the MatIconRegistry constructor is now required.
  • list: selectionChange on the MatListOption, which was deprecated in 5.0.0 has been removed. Use selectionChange on the MatSelectionList instead.
  • MatListOptionChange which was deprecated in 5.0.0 has been removed.
  • slider: thumb-label which was deprecated in 5.0.0 has been removed. Use thumbLabel instead.
  • tick-interval which was deprecated in 5.0.0 has been removed. Use tickInterval instead.
  • tooltip: tooltip-position which was deprecated in 5.0.0 has been removed. Use matTooltipPosition instead.
  • The _defaultOptions parameter in the MatTooltip constructor is now required.
  • select: onOpen, which was deprecated in 5.0.0, has been removed.
  • onClose, which was deprecated in 5.0.0, has been removed.
  • change, which was deprecated in 5.0.0, has been removed.
  • chips: remove which was deprecated in 5.0.0 has been removed. Use removed instead.
  • destroy which was deprecated in 5.0.0 has been removed. Use destroyed instead.
  • text-field: The _ngZone parameter in the CdkTextareaAutosize constructor is now required.
  • sidenav: The MatDrawerToggleResult class has been turned into an type.
  • The promise returned from open, close and toggle now resolves with the MatDrawerToggleResult type rather than the class.
  • align which was deprecated in 5.0.0 has been removed. Use position instead.
  • open which was deprecated in 5.0.0 has been removed. Use opened instead.
  • close which was deprecated in 5.0.0 has been removed. Use closed instead.
  • align-changed which was deprecated in 5.0.0 has been removed. Use positionChanged.
  • form-field: - dividerColor which was deprecated in 5.0.0 has been removed. Use color instead.
  • floatPlaceholder which was deprecated in 5.0.0 has been removed. Use floatLabel instead.
  • overlay: ConnectedOverlayDirective which was deprecated in 5.0.0 has been removed. Use CdkConnectedOverlay instead.
  • OverlayOrigin which was deprecated in 5.0.0 has been removed. Use CdkOverlayOrigin instead.
  • hasBackdrop which was deprecated in 5.0.0 has been removed. Use cdkConnectedOverlayHasBackdrop instead.
  • open which was deprecated in 5.0.0 has been removed. Use cdkConnectedOverlayOpen instead.
  • scrollStrategy which was deprecated in 5.0.0 has been removed. Use cdkConnectedOverlayScrollStrategy instead.
  • backdropClass which was deprecated in 5.0.0 has been removed. Use cdkConnectedOverlayBackdropClass instead.
  • minHeight which was deprecated in 5.0.0 has been removed. Use cdkConnectedOverlayMinHeight instead.
  • minWidth which was deprecated in 5.0.0 has been removed. Use cdkConnectedOverlayMinWidth instead.
  • height which was deprecated in 5.0.0 has been removed. Use cdkConnectedOverlayHeight instead.
  • width which was deprecated in 5.0.0 has been removed. Use cdkConnectedOverlayWidth instead.
  • offsetX which was deprecated in 5.0.0 has been removed. Use cdkConnectedOverlayOffsetX instead.
  • offsetY which was deprecated in 5.0.0 has been removed. Use cdkConnectedOverlayOffsetY instead.
  • positions which was deprecated in 5.0.0 has been removed. Use cdkConnectedOverlayPositions instead.
  • origin which was deprecated in 5.0.0 has been removed. Use cdkConnectedOverlayOrigin instead.
  • tabs: mat-dynamic-height which was deprecated in 5.0.0 has been removed. Use dynamicHeight instead.
  • selectChange which was deprecated in 5.0.0 has been removed. Use selectedTabChange.
  • checkbox: align which was deprecated in 5.0.0 has been removed. Use labelPosition instead. Note that the values are different.
  • form-field: - The following deprecated CSS classes have been removed:
    • mat-input-container instead use mat-form-field
    • mat-input-invalid instead use mat-form-field-invalid
    • mat-input-wrapper instead use mat-form-field-wrapper
    • mat-input-flex instead use mat-form-field-flex
    • mat-input-prefix instead use mat-form-field-prefix
    • mat-input-infix instead use mat-form-field-infix
    • mat-input-placeholder-wrapper instead use mat-form-field-label-wrapper
    • mat-input-placeholder instead use mat-form-field-label
    • mat-input-suffix instead use mat-form-field-suffix
    • mat-input-underline instead use mat-form-field-underline
    • mat-input-ripple instead use mat-form-field-ripple
    • mat-input-subscript-wrapper instead use mat-form-field-subscript-wrapper
    • mat-input-hint-wrapper instead use mat-form-field-hint-wrapper
    • mat-input-hint-spacer instead use mat-form-field-hint-spacer
    • mat-form-field-placeholder-wrapper instead use mat-form-field-label-wrapper
    • mat-form-field-placeholder instead use mat-form-field-label
  • a11y: The renderer parameter in FocusMonitor.monitor has been removed.
  • cdk-focus-trap which was deprecated in 5.0.0 has been removed. Use cdkTrapFocus instead.
  • autocomplete: The defaults parameter in the MatAutocomplete constructor is now required.
  • form-field: MatFormFieldControl.shouldPlaceholderFloat which was deprecated in 5.0.0 has been removed. * MatFormFieldControl.shouldLabelFloat is no longer optional and should be used instead.
  • FloatPlaceholderType which was deprecated in 5.0.0 has been removed. Use FloatLabelType instead.
  • PlaceholderOptions which was deprecated in 5.0.0 has been removed. Use LabelOptions instead.
  • MAT_PLACEHOLDER_GLOBAL_OPTIONS which was deprecated in 5.0.0 has been removed. Use MAT_LABEL_GLOBAL_OPTIONS instead.
  • snack-bar: extraClasses which was deprecated in 5.0.0 has been removed. Use panelClass instead.
  • portal: The portalHost and cdkPortalHost inputs which were deprecated in 5.0.0 have been removed. Use cdkPortalOutlet instead.

Features

Bug Fixes

  • badge: invalid style declaration and too broad transition (#10433) (c14cf7c)
  • bottom-sheet: error when attempting to open multiple instances quickly (#10147) (34e96f5)
  • button: theme font color being overwritten (#9771) (c3a8d0c), closes #4614 #9231 #9634
  • checkbox: setting blank aria-label by default (#10281) (c12d7c4)
  • chip-list: set key manager active index to -1 when blurred (#10335) (b10fff4)
  • chips: form field label pointing to non-existing elements (#9908) (9337ae1)
  • datepicker: server-side rendering error for disabled input (#10249) (af4fc9b), closes #10248
  • icon: namespace error when registering an icon on the server (#10175) (498534b), closes #10170
  • input: setting blank placeholder by default (#10277) (889a9f2)
  • overlay: clear last calculated position when new set of positions is provided (#10462) (cdb6e40), closes #10457
  • overlay: incorrect bounding box bottom position when page is scrolled and content is flowing upwards (#10463) (1dd8a27)
  • overlay: incorrect bounding box styles if position is exactly zero (#10470) (eefa9c4)
  • overlay: opaque backdrop appearing solid in high contrast mode (#10252) (8366ec6)
  • select: scroll strategy token cannot inject overlay (#10535) (3eb71c2)
  • table: move padding from rows to cells (#10499) (e0321db)
  • tree: fix mat-tree paddings (#10349) (d065aea)
  • tree: invalid style declaration during server-side rendering (#10326) (c205749), closes #10131

Code Refactoring

6.0.0-beta.4 (2018-03-05)

Highlights

  • New tree component! The base behavior lives in @angular/cdk with Material Design flavors in @angular/material.

Bug Fixes

  • button: hide overflow of buttons to prevent overflow of hover/ripple (#9424) (915a2b7)
  • avoid layout jumping on elements with ripples in RTL (#10026) (900716a)
  • chips: Update chips in chip list, and add margin to chip input (#8579) (67e710c)
  • datepicker: improve native adapter DST handling (#10068) (2fad732)
  • dialog: actions not being pulled down when trapping focus (#10007) (8a402d0), closes #9722
  • dialog: don't provide directionality if user injector has one already (#10004) (e3d7aec)
  • expansion-panel: entire body content being shown on animation start (#10138) (b4b76bd), closes #10134
  • grid-list: default to LTR when Directionality value is empty (#10111) (64ef3a8)
  • grid-list: invalid style declaration during server-side rendering (#10131) (a27d9df)
  • list: align avatar size in dense list with spec (#10028) (d4a4f61), closes #10019
  • list-key-manager: not ignoring vertical key events in horizontal-only mode (#10075) (ffbb425)
  • menu: detach lazily-rendered content when the menu is closed (#10005) (bb1803d), closes #9915
  • overlay: hide overlay container when there are no attached overlays (#10139) (4b528f6), closes #6882 #10033
  • paginator: first/last icons being thrown off on IE and Edge; simplify icon setup (#9776) (dd082cb)
  • select: animation jumping on IE11 (#10050) (a5909db)
  • selection-list: improve accessibility of selection list (#10137) (51fce51), closes #9995
  • selection-list: repeated preselected items not appearing as selected with OnPush parent (#10100) (cdd224a), closes #10090
  • tree: fix type error in tree (#10095) (6d94aec)

Features

6.0.0-beta.3 (2018-02-27)

Bug Fixes

Features

6.0.0-beta.2 (2018-02-21)

Bug Fixes

  • badge: AoT and server-side rendering errors (#9935) (06b4017)
  • badge: hard to see in high contrast mode (#9973) (1b2f90c)
  • badge: incorrectly setting aria-describedby (#9957) (aed7e8a)
  • badge: move styles into the theme mixin (#9999) (00a6c90)
  • badge: remove top-level ampersand selectors from theme mixin (#9991) (bd7a408), closes #9990
  • bottom-sheet: inject correct directionality in child components (#9996) (9d784a0)
  • button: inconsistent overflow value between browsers (#9933) (9d19291)
  • chips: Fix chip and chip list selectable (#9955) (949a69b)
  • expansion-panel,menu,select: nested animations not working (#9134) (1e2b79a), closes #8814 #8953
  • input: AutofillMonitor stream not being completed when stopping monitoring (#9886) (87bbfc5)
  • overlay: default to global directionality (#9994) (47674f1), closes #9817
  • tooltip: memory leak in _setTooltipMessage (#6782) (66a01fb)

Features

6.0.0-beta.1 (2018-02-12)

  • Fix typo in version name (using a dash instead of a dot)
  • Update Angular peer dependency to 6.0.0-beta.x

6.0.0-beta-0 (2018-02-12)

Bug Fixes

  • overlay: validate that ConnectedPositionStrategy positions are passed in correctly at runtime (#9466) (6a8ce02)

Features

5.2.4 ash-submarine (2018-03-06)

Bug Fixes

  • chips: Update chips in chip list, and add margin to chip input (#8579) (3074b45)
  • expansion-panel: entire body content being shown on animation start (#10138) (35b66f9), closes #10134
  • menu: detach lazily-rendered content when the menu is closed (#10005) (37b1a09), closes #9915
  • menu: Fix #10005 lint error (c8ca770)
  • overlay: hide overlay container when there are no attached overlays (#10139) (d0bc91d), closes #6882 #10033
  • paginator: first/last icons being thrown off on IE and Edge; simplify icon setup (#9776) (85f9491)
  • selection-list: improve accessibility of selection list (#10137) (cbe11d4), closes #9995

Bug Fixes

  • cdk-dialog: decorate dialog as an injectable (#10052) (07b4250)
  • datepicker: improve native adapter DST handling (#10068) (2837196)
  • avoid layout jumping on elements with ripples in RTL (#10026) (c93103b)
  • dialog: actions not being pulled down when trapping focus (#10007) (9a39e24), closes #9722
  • dialog: don't provide directionality if user injector has one already (#10004) (6ec0af1)
  • grid-list: default to LTR when Directionality value is empty (#10111) (65810bc)
  • grid-list: invalid style declaration during server-side rendering (#10131) (1576a99)
  • list: align avatar size in dense list with spec (#10028) (7d81b6f), closes #10019
  • list-key-manager: not ignoring vertical key events in horizontal-only mode (#10075) (f31a2f1)
  • selection-list: repeated preselected items not appearing as selected with OnPush parent (#10100) (f93d0f4), closes #10090
  • stepper: require users to visit non-optional steps (#10048) (d26aa6e)

5.2.2 cork-yacht (2018-02-21)

Bug Fixes

  • aria-describer: better handling of non-string values (#9959) (d351e33)
  • list: list-options require a parent selection list (#9899) (8cca2c2)
  • list-key-manager: infinite loop if all items are disabled (#9981) (775f560)
  • menu: not picking up indirect descendant items (#9971) (14b21e9), closes #9969
  • overlay: expose backdropClick mouse event in ConnectedOverlayDirective (#9845) (5a1e7fe)
  • platform: potential error if CSS object is undefined (#9968) (3212111), closes #9801
  • select: icons inside option not centered (#9982) (ecc7f53), closes #9978
  • select: lock dropdown position when scrolling (#9789) (30b90a2)
  • selection-list: incorrect cursor if disabled (#9963) (13e809a), closes #9952
  • tabs: ink bar not visible in high contrast mode (#9997) (1ba04eb)
  • theming: add aliases for alternate spelling of "grey" (#9903) (36e1bc0)
  • viewport-ruler: fix server-side rendering errors when attempting to measure the viewport (#9870) (ac4cd91)

5.2.1 ghillie-soup (2018-02-12)

Bug Fixes

  • autocomplete: escape key inconsistency on IE (#9777) (180750e)
  • button: better accessibility for flat buttons in high-contrast (#9783) (0d0c6d4)
  • datepicker: add max/min filter to multi year and year views (#9727) (0793142)
  • datepicker: changed after checked error if focused datepicker inputs turn disabled (#9717) (01ad7bd), closes #9559
  • global-position-strategy: ignoring width and height from OverlayConfig (#9774) (b425a46), closes #9715
  • overlay: dimension not updated after init (#8765) (c36b512)
  • select: options inside option group not being rendered when wrapped with ng-container (#9769) (38fddfe), closes #9736
  • selection-list: external changes to selection model not being reflected (#9846) (82df181), closes #9838
  • slider: invisible in high contrast mode (#9792) (94bbffc)
  • slider: unable to reset value by setting it back to undefined (#9768) (c2e2744), closes #9740
  • radio: add aria-describedby passthrough to radio button input (#9741) (cd159f5)

Features

  • autocomplete: add the ability to highlight the first option on open (#9495) (b42fcb9), closes #8423
  • button: create stroked and flat button variants (#9365) (b652683)
  • button: expose ripple instance (#9170) (17e36fe), closes #4179
  • checkbox: expose ripple instance (#9176) (e09c0a6)
  • datepicker: allow for mat-datepicker-toggle icon to be customized (#9487) (01867ad)
  • dialog: support using dialog content directives with template dialogs (#9379) (99b768e), closes #5412
  • drawer: expose CdkScrollable instance (#9183) (2d03af0), closes #9136
  • expansion-panel: support two-way binding for the expanded property (#9327) (a72085b), closes #9311
  • layout: add window breakpoints from spec (#9318) (1038950)
  • list-key-manager: add support for horizontal directions (#9122) (ab02367)
  • menu: support lazy rendering and passing in context data (#9271) (9fed87c), closes #9251
  • observe-content: allow for the MutationObserver to be disabled (#9025) (aa2e76c)
  • overlay: expose reference to the backdrop element (#9702) (959a8a1), closes #9689
  • overlay: make it easier to override backdrop color (#9114) (3d18006), closes #7855
  • paginator: Add functionality to jump to first and last page (#9603) (04cdb13), closes #9278
  • paginator: allow page size selection to be disabled (#8373) (c8743e7), closes #8359
  • portal: expose attached result in CdkPortalOutlet (#9326) (b626b13), closes #9304
  • ripple: support animation duration overwrites (#9253) (3bc4cd3)
  • ripple: support ripple fade-out on pointer up (#9694) (efb03c9), closes #9577
  • slider: add focus and blur methods do MatSlider (#9373) (2d592a5)
  • sort: fix animation; show on hover (#7608) (cde00df)
  • stepper: add proper type to stepper buttons (#9401) (b3d2e78)
  • stepper: add the ability to reset a stepper (#8623) (a6f9fc2)
  • stepper: allow for header icons to be customized (#7482) (adc251c), closes #7384
  • table: allow data input to be array, stream (#9489) (085d805)

Bug Fixes

  • aria-describer: exception when attempting to describe a non-element node (#9392) (4c7a4f3)
  • autocomplete: close panel using alt + up arrow (#9341) (2c192d0)
  • autocomplete: error when closing from a destroyed view (#7365) (2b05106), closes #7315
  • autocomplete: expose MatAutocompleteTrigger in template (#9703) (8997db0), closes #9687
  • autocomplete: handle optionSelections being accessed early (#8802) (4e1a6a8), closes #4616
  • autocomplete: handle attaching autocomplete to a number input (#9672) (f75fa15), closes #9628
  • autocomplete: panel not closing on IE when selecting an option with an empty string display value (#9506) (95ffe37), closes #9479
  • autocomplete: prevent opening using arrow keys on readonly input (#9229) (9d152c0), closes #9227
  • block-scroll-strategy: server-side rendering error (#9665) (3acbf26)
  • button: accent color not set on fab buttons with build optimizer (#9376) (b3f8a42), closes #9360
  • button: incorrect text color when no color is passed in on dark theme (#9234) (6824375), closes #9231
  • button-toggle: inaccurate name passed down to input if no name is assigned (#9017) (54d60df)
  • card: add camel-cased selectors to content projection (#6818) (d5a7cce), closes #6816
  • card,tabs,toolbar: Make media query breakpoints follow Material spec (#9284) (7672913)
  • checkbox: underlying native checkbox being rendered when parent uses css column layout (#9258) (eac1512), closes #9049
  • chips: chip list capturing keyboard events from input (#9651) (a48f75b)
  • collections: clean up UniqueSelectionDispatcher listeners on destroy (#9673) (26b0635)
  • datepicker: calendar controls not being inverted in rtl (#9219) (8a3e023)
  • datepicker: calendar keyboard controls not working if the user clicks on blank area (#9494) (0b8955b)
  • datepicker: gray out filtered years in multi-year view (#9563) (403ebbd)
  • datepicker: highlight datepicker toggle when calendar is open (#9426) (e3b5e3f)
  • datepicker: set border radius on calendar popup (#9509) (4e7c1a3)
  • dialog: server-side rendering error when attempting to trap focus (#9698) (acbf3c8)
  • divider: add inset styles for icons and lists in cards (#9242) (d587abe)
  • expansion: define default expansion header heights via css. (#9313) (c604834)
  • expansion-panel: expand animation jumping (#8779) (37575c9)
  • expansion-panel: improved accessibility labelling and keyboard default action not being prevented (#9174) (e62afdf)
  • focus-monitor: implement OnDestroy logic (#9305) (8972bf4)
  • focus-monitor: set up global listeners in root zone (#9542) (afcb3ea)
  • form-field: unable to override font-size through typography config (#9463) (66dc73a)
  • grid-list: tile being pulled outside the grid if no gap can be found (#9128) (c8127ed), closes #4515
  • icon: prevent parsing the same icon set multiple times (#9635) (e6e4c3c)
  • input: floating label not reacting when patching the value without emitting an event (#9260) (ec6678d), closes #8982
  • input: respect text-align value from form-field (#9397) (5136361)
  • interactivity-checker: carefully handle frame elements (#9340) (6f7332b), closes #3372
  • keycodes: incorrect key code for nine (#9568) (637e1b6), closes #9567
  • list: incorrect padding for list-items with avatars, icons (#9500) (39a5861), closes #9156
  • list-key-manager: maintain selected index when amount of items changes (#9164) (4f65276)
  • menu: always focus first menu item (#9383) (8430617), closes #9252
  • menu: inconsistent side padding for nested menu items in RTL (#9124) (cc24c7c)
  • menu: set appropriate origin when restoring focus (#9303) (278e25a), closes #9292
  • menu,toolbar: avoid potential server-side rendering errors (#9423) (dfa68db)
  • native-date-adapter: avoid error when formatting edge case dates in IE11 and Edge (#9523) (dd2fbc8)
  • overlay: attempting to position overlay if it was detached immediately after being attached (#9507) (c7ad145), closes #9406
  • overlay: ConnectedOverlayDirective not updating positions after first open (#9579) (d0011c4)
  • overlay: default options not being applied correctly (#9088) (b153947)
  • overlay: expose event object in backdropClick stream (#9716) (5611947), closes #9713
  • overlay: onPositionChange stream not being completed (#8562) (7fe651b)
  • overlay: OverlayKeyboardDispatcher not dispatching events when propagation is stopped (#9546) (e30852a)
  • overlay: server-side rendering error when creating backdrop element (#9448) (a1db4e4)
  • overlay: transparent overlay not blocking scroll on Firefox 57 (#9446) (d0ad3b7), closes #8924
  • overlay: unable to change CdkConnectedOverlay origin dynamically (#9358) (df44767), closes #9353
  • progress-bar: prevent users from tabbing into underlying SVG on IE (#9638) (0a1904d)
  • progress-bar: remove data url for CSP compliance (#8898) (0f2ac9b)
  • progress-spinner: element size not updated when diamater is changed (#8697) (6d4c7ae)
  • radio: add support for tabindex on radio-buttons (#9467) (f1c3e2c), closes #9427
  • scrolling: implement ngOnDestroy in ScrollDispatcher (#9608) (fd17cf2)
  • select: close panel on alt + arrow key presses (#9250) (7c78c93)
  • select: don't restore focus unless an option was selected (#8964) (9dc43de), closes #8915
  • select: handle async changes to the option label (#9159) (245caae), closes #7923
  • select: handle keyboard events from inside panel (#9361) (69270ef)
  • select: support changing the value using left/right arrow keys while closed (#9578) (83b369e)
  • selection-model: incorrect initial value when empty array is passed in single-selection mode (#9287) (075464f), closes #9273
  • slide-toggle: truncate label content with ellipsis (#9166) (68bb44c), closes #5212
  • slider: slider emiting changes on slide end when disabled (#9434) (1e2fe90)
  • snack-bar: indicate in afterDismissed whether dismissal was a result of an action (#9154) (829506d), closes #9147
  • stepper: header collapsing if box-sizing is set (#9505) (ffc5381), closes #9501
  • stepper: overriding default completed logic when resetting (#9650) (7e352ce)
  • stepper: support going to first/last steps via home/end keys (#9632) (834aecc)
  • stepper: throw when out-of-bounds value is assigned to selectedIndex (#9127) (f54377c)
  • stepper: unable to skip optional steps in linear stepper (#9245) (9dba30b), closes #9239
  • tab-link: preventDefault action when disabled tab link is clicked. (#9357) (8de5e83)
  • table: data source should sort empty values correctly (#8698) (f213f6c)
  • tabs: move focus to first/last tabs using home/end (#9171) (24f62eb)
  • theming: provide text color through mat-app-background (#9262) (1e7eeab)
  • tooltip: match mobile dimensions from spec (#9181) (63a5588), closes #9039

Performance Improvements

5.2.0-beta.0 (2018-01-30)

Features

  • autocomplete: add the ability automatically keep the first option active (#9495) (b42fcb9), closes #8423
  • button: expose ripple instance (#9170) (17e36fe), closes #4179
  • checkbox: expose ripple instance (#9176) (e09c0a6)
  • datepicker: allow for mat-datepicker-toggle icon to be customized (#9487) (01867ad)
  • dialog: support using dialog content directives with template dialogs (#9379) (99b768e), closes #5412
  • drawer: expose CdkScrollable instance (#9183) (2d03af0), closes #9136
  • expansion-panel: support two-way binding for the expanded property (#9327) (a72085b), closes #9311
  • layout: add window breakpoints from spec (#9318) (1038950)
  • list-key-manager: add support for horizontal directions (#9122) (ab02367)
  • menu: support lazy rendering and passing in context data (#9271) (9fed87c), closes #9251
  • observe-content: allow for the MutationObserver to be disabled (#9025) (aa2e76c)
  • overlay: make it easier to override backdrop color (#9114) (3d18006), closes #7855
  • paginator: allow page size selection to be disabled (#8373) (c8743e7), closes #8359
  • portal: expose attached result in CdkPortalOutlet (#9326) (b626b13), closes #9304
  • ripple: support animation duration overwrites (#9253) (3bc4cd3)
  • slider: add focus and blur methods do MatSlider (#9373) (2d592a5)
  • stepper: add proper type to stepper buttons (#9401) (b3d2e78)
  • stepper: add the ability to reset a stepper (#8623) (a6f9fc2)

Bug Fixes

  • aria-describer: exception when attempting to describe a non-element node (#9392) (4c7a4f3)
  • autocomplete: close panel using alt + up arrow (#9341) (2c192d0)
  • autocomplete: error when closing from a destroyed view (#7365) (2b05106), closes #7315
  • autocomplete: handle optionSelections being accessed early (#8802) (4e1a6a8), closes #4616
  • autocomplete: prevent opening using arrow keys on readonly input (#9229) (9d152c0), closes #9227
  • button: accent color not set on fab buttons with build optimizer (#9376) (b3f8a42), closes #9360
  • button: incorrect text color when no color is passed in on dark theme (#9234) (6824375), closes #9231
  • button-toggle: inaccurate name passed down to input if no name is assigned (#9017) (54d60df)
  • card: add camel-cased selectors to content projection (#6818) (d5a7cce), closes #6816
  • card,tabs,toolbar: Make media query breakpoints follow Material spec (#9284) (7672913)
  • checkbox: underlying native checkbox being rendered when parent uses css column layout (#9258) (eac1512), closes #9049
  • chips: chip list capturing keyboard events from input (#9651) (a48f75b)
  • datepicker: calendar controls not being inverted in rtl (#9219) (8a3e023)
  • datepicker: calendar keyboard controls not working if the user clicks on blank area (#9494) (0b8955b)
  • datepicker: gray out filtered years in multi-year view (#9563) (403ebbd)
  • datepicker: highlight datepicker toggle when calendar is open (#9426) (e3b5e3f)
  • datepicker: set border radius on calendar popup (#9509) (4e7c1a3)
  • expansion: define default expansion header heights via css. (#9313) (c604834)
  • expansion-panel: improved accessibility labelling and keyboard default action not being prevented (#9174) (e62afdf)
  • focus-monitor: implement OnDestroy logic (#9305) (8972bf4)
  • focus-monitor: set up global listeners in root zone (#9542) (afcb3ea)
  • form-field: unable to override font-size through typography config (#9463) (66dc73a)
  • grid-list: tile being pulled outside the grid if no gap can be found (#9128) (c8127ed), closes #4515
  • icon: prevent parsing the same icon set multiple times (#9635) (e6e4c3c)
  • input: floating label not reacting when patching the value without emitting an event (#9260) (ec6678d), closes #8982
  • input: respect text-align value from form-field (#9397) (5136361)
  • interactivity-checker: carefully handle frame elements (#9340) (6f7332b), closes #3372
  • keycodes: incorrect key code for nine (#9568) (637e1b6), closes #9567
  • list: incorrect padding for list-items with avatars, icons (#9500) (39a5861), closes #9156
  • list-key-manager: maintain selected index when amount of items changes (#9164) (4f65276)
  • menu: always focus first menu item (#9383) (8430617), closes #9252
  • menu: inconsistent side padding for nested menu items in RTL (#9124) (cc24c7c)
  • menu: set appropriate origin when restoring focus (#9303) (278e25a), closes #9292
  • menu,toolbar: avoid potential server-side rendering errors (#9423) (dfa68db)
  • native-date-adapter: avoid error when formatting edge case dates in IE11 and Edge (#9523) (dd2fbc8)
  • overlay: attempting to position overlay if it was detached immediately after being attached (#9507) (c7ad145), closes #9406
  • overlay: ConnectedOverlayDirective not updating positions after first open (#9579) (d0011c4)
  • overlay: default options not being applied correctly (#9088) (b153947)
  • overlay: server-side rendering error when creating backdrop element (#9448) (a1db4e4)
  • overlay: transparent overlay not blocking scroll on Firefox 57 (#9446) (d0ad3b7), closes #8924
  • overlay: unable to change CdkConnectedOverlay origin dynamically (#9358) (df44767), closes #9353
  • progress-bar: remove data url for CSP compliance (#8898) (0f2ac9b)
  • progress-spinner: element size not updated when diamater is changed (#8697) (6d4c7ae)
  • radio: add support for tabindex on radio-buttons (#9467) (f1c3e2c), closes #9427
  • scrolling: implement ngOnDestroy in ScrollDispatcher (#9608) (fd17cf2)
  • select: close panel on alt + arrow key presses (#9250) (7c78c93)
  • select: don't restore focus unless an option was selected (#8964) (9dc43de), closes #8915
  • select: handle async changes to the option label (#9159) (245caae), closes #7923
  • select: handle keyboard events from inside panel (#9361) (69270ef)
  • select: support changing the value using left/right arrow keys while closed (#9578) (83b369e)
  • selection-model: incorrect initial value when empty array is passed in single-selection mode (#9287) (075464f), closes #9273
  • slide-toggle: truncate label content with ellipsis (#9166) (68bb44c), closes #5212
  • slider: slider emiting changes on slide end when disabled (#9434) (1e2fe90)
  • snack-bar: indicate in afterDismissed whether dismissal was a result of an action (#9154) (829506d), closes #9147
  • stepper: header collapsing if box-sizing is set (#9505) (ffc5381), closes #9501
  • stepper: throw when out-of-bounds value is assigned to selectedIndex (#9127) (f54377c)
  • stepper: unable to skip optional steps in linear stepper (#9245) (9dba30b), closes #9239
  • tab-link: preventDefault action when disabled tab link is clicked. (#9357) (8de5e83)
  • table: data source should sort empty values correctly (#8698) (f213f6c)
  • tabs: move focus to first/last tabs using home/end (#9171) (24f62eb)
  • theming: provide text color through mat-app-background (#9262) (1e7eeab)

Performance Improvements

Bug Fixes

  • autocomplete: close panel using alt + up arrow (#9341) (a1ad82b)
  • autocomplete: error when closing from a destroyed view (#7365) (00820f7), closes #7315
  • autocomplete: handle optionSelections being accessed early (#8802) (ec6168b), closes #4616
  • autocomplete: prevent opening using arrow keys on readonly input (#9229) (f3b50b0), closes #9227
  • button: accent color not set on fab buttons with build optimizer (#9376) (f6a59cd), closes #9360
  • button-toggle: inaccurate name passed down to input if no name is assigned (#9017) (fda978a)
  • card: add camel-cased selectors to content projection (#6818) (6e4f90f), closes #6816
  • card,tabs,toolbar: Make media query breakpoints follow Material spec (#9284) (d6b3cc8)
  • checkbox: underlying native checkbox being rendered when parent uses css column layout (#9258) (58b665e), closes #9049
  • datepicker: calendar controls not being inverted in rtl (#9219) (af38b97)
  • datepicker: calendar keyboard controls not working if the user clicks on blank area (#9494) (7cea0b6)
  • datepicker: highlight datepicker toggle when calendar is open (#9426) (37d8716)
  • datepicker: set border radius on calendar popup (#9509) (3f87dc4)
  • expansion-panel: improved accessibility labelling and keyboard default action not being prevented (#9174) (444cee8)
  • focus-monitor: implement OnDestroy logic (#9305) (e6cdce5)
  • grid-list: tile being pulled outside the grid if no gap can be found (#9128) (5535325), closes #4515
  • input: floating label not reacting when patching the value without emitting an event (#9260) (4a00499), closes #8982
  • interactivity-checker: carefully handle frame elements (#9340) (305a81c), closes #3372
  • keycodes: incorrect key code for nine (#9568) (b489559), closes #9567
  • list: incorrect padding for list-items with avatars, icons (#9500) (db520cf), closes #9156
  • menu: inconsistent side padding for nested menu items in RTL (#9124) (53d48f6)
  • menu: set appropriate origin when restoring focus (#9303) (2bf9ad8), closes #9292
  • native-date-adapter: avoid error when formatting edge case dates in IE11 and Edge (#9523) (d25ab57)
  • overlay: default options not being applied correctly (#9088) (6f8f226)
  • overlay: server-side rendering error when creating backdrop element (#9448) (5c98185)
  • overlay: transparent overlay not blocking scroll on Firefox 57 (#9446) (e2999a8), closes #8924
  • progress-spinner: element size not updated when diamater is changed (#8697) (23f0c47)
  • select: close panel on alt + arrow key presses (#9250) (c3ec94d)
  • select: don't restore focus unless an option was selected (#8964) (960b7cf), closes #8915
  • select: handle async changes to the option label (#9159) (63a5184), closes #7923
  • select: handle keyboard events from inside panel (#9361) (0d233b2)
  • select: support changing the value using left/right arrow keys while closed (#9578) (b11523a)
  • selection-model: incorrect initial value when empty array is passed in single-selection mode (#9287) (5d0fb95), closes #9273
  • slide-toggle: truncate label content with ellipsis (#9166) (4bd96ce), closes #5212
  • stepper: header collapsing if box-sizing is set (#9505) (ccc8fbb), closes #9501
  • stepper: unable to skip optional steps in linear stepper (#9245) (517ea57), closes #9239
  • tab-link: preventDefault action when disabled tab link is clicked. (#9357) (0b5806b)
  • theming: provide text color through mat-app-background (#9262) (6d66a16)
  • overlay: make it easier to override backdrop color (#9114) (4ff1fd4), closes #7855

5.1.0 burlap-bezel (2018-01-17)

Bug Fixes

  • aria-describer: server-side rendering error during cleanup (#8903) (8a3b19e), closes #8901
  • autocomplete: not implementing setDisabledState from ControlValueAccessor (#8746) (92bc503), closes #8735
  • autocomplete: not resetting completely when overlay is detached externally (#8515) (a8cd033)
  • autocomplete: panelClosingActions emitting twice in some cases (#8998) (4f97232)
  • autocomplete: panelClosingActions emitting when tabbing away from a closed autocomplete (#8774) (92dcd76), closes #8763
  • chip,stepper: compile cleanly with "fullTemplateTypeCheck" (#8889) (50967b6)
  • chips: being able to focus disabled chip by clicking (#8892) (bfd513d), closes #8883
  • chips: event propagation not stopped by remove button (#8772) (c7e2d4e), closes #8771
  • connected-position-strategy: allow positions to be updated after init (#8800) (b7071ba)
  • datepicker: leaking backdropClick subscriptions (#8919) (3728555)
  • datepicker: not resetting when detached externally (#9133) (a0bd162)
  • datepicker: typo in MatMonthView export (#9055) (2250747)
  • datepicker: unable to close calendar when opened on focus in IE11 (#8918) (a411382), closes #8914
  • dialog: change order of button actions (#9021) (230b297)
  • dialog: hide all non-overlay content from assistive technology (#9016) (d82124d), closes #7787
  • dialog: improved type safety in dialog ref result (#8766) (571ef46), closes #8760
  • directionality: complete dir change observable (#8874) (41f5fe2)
  • drawer: infinite loop when two-way opened binding is toggled mid-animation (#8872) (7c84490), closes #8869
  • drawer: margins not being updated on direction changes (#9161) (ff1c5f1), closes #9158
  • drawer: unable to close using keyboard if there are no focusable elements (#8783) (fba3728)
  • expansion: accordion emitting closed event while closed (#9101) (92ded30), closes #9098
  • focus-trap: server-side rendering error (#9001) (c77f69f), closes #8981
  • form-field: hide required asterisk if control is disabled (#8799) (1c2f6b7), closes #8251
  • global-position-strategy: error if disposed before applied (#8761) (f565560), closes #8758
  • icon: handle values with unnecessary spaces being passed into fontIcon and fontSet (#9056) (1a735bc), closes #9054
  • icon: server-side error when registering icons (#8492) (b6da765), closes #6787
  • input: align caret color with spec (#8692) (b0449ab)
  • input: allow color inputs in mat-form-field (#8748) (982982b), closes #8686
  • layout: handle platforms that don't support matchMedia (#8775) (4846e4c), closes #8710
  • list: prevent list icon shrinking (#9211) (5737b9f), closes #8699
  • menu: not closing when overlay is detached externally (#8868) (4d8c712)
  • paginator: coerce string values (#8946) (0388202)
  • paginator: set default display value (#8455) (bd50fa6), closes #8454
  • progress-bar: animation tearing in Firefox 57 (#9123) (9e47d40), closes #7606
  • select: active item not being updated on click in multiple mode (#7808) (bc27fea)
  • select: alt + arrow key not opening in single-selection mode (#8910) (a4c042b)
  • select: change event emitted before data binding is updated (#8740) (5819385), closes #8739
  • select: complete state change event (#8777) (4f78613)
  • select: handle optionSelectionChanges being accessed early (#8830) (97ebd76)
  • select: not marked as touched when clicking away (#8784) (984dece), closes #8573
  • select: remove aria-owns when options aren't in the DOM (#9091) (d85c44b), closes #7023
  • select: support using shift + arrow key to toggle items in a multi-select (#9037) (f82bbae)
  • selection-list: allow jumping to first/last item using home/end (#9062) (bd36529)
  • selection-list: allow users to jump focus to a particular item by typing (#9026) (af44b9d)
  • selection-list: options not marked as selected if value is assigned too early (#9090) (bd7c751), closes #9085
  • selection-list: preselected options not being added to the model value (#9116) (91ea1a1)
  • selection-list: remove selected option from model value on destroy (#9106) (f8cd8eb)
  • selection-list: unable to select using the enter key (#8595) (9105302), closes #8589
  • slider: prevent slider thumb from getting cropped (#8061) (0b05a1f)
  • stepper: completed binding not being considered when moving from a step without a stepControl (#9126) (32d0dbb), closes #8110
  • stepper: use up/down arrows for navigating vertical stepper (#8920) (7b78b74)
  • table: inaccurate row height (#8303) (baa8a6e), closes #8299
  • too strict peer dependency of angular (#9355) (7187670), closes #9328
  • table: row content not centered in IE (#6820) (1b79e92), closes #6813
  • table: set height of mat-header-row to 56px (#8215) (0c4ee2e)
  • theming: light text on colored backgrounds should be opaque (#7421) (1701b98)
  • typography: deprecation warning if null font family is passed in (#9002) (d8c1392), closes #8973
  • typography: handle inherit being set as a typography value (#8721) (139c506), closes #8700

Features

  • autocomplete: allow option ripples to be disabled (#8851) (ff31ac8)
  • close-scroll-strategy: add scroll threshold option (#8656) (c0ff761)
  • datepicker: add animation to calendar popup (#8542) (c3e267f)
  • datepicker: add year selection mode (#8565) (cdbabf7)
  • dialog: allow default dialog options to be configurable (#9113) (05304f0)
  • dialog: allow for closing on navigation to be disabled (#9024) (c349c58), closes #8983
  • dialog: allow for single dialog scroll strategy to be overwritten (#8726) (c7de734), closes #8706
  • divider: move divider out of mat-list (#5862) (bd0ec64)
  • elevations: Allow tonal color elevations through mat-elevation mixin. (#8995) (21d004a)
  • expansion-panel: allow for content to be rendered lazily (#8243) (60ba0a7), closes #8230
  • table: support directly adding column, row, and header defs (#8744) (693c8e8)
  • tabs: add animation done event #5238 (#6811) (3a52624)
  • tooltip: add injection token for specifying the default delays (#8109) (3dcf4cd), closes #7928

Performance Improvements

  • ripple: do not register events if ripples are disabled initially (#8882) (58b93dc)
  • ripple: use passive event listeners (#8719) (12feff7)

Bug Fixes

  • chips: being able to focus disabled chip by clicking (#8892) (699b7c2), closes #8883
  • datepicker: typo in MatMonthView export (#9055) (3e99bcc)
  • dialog: hide all non-overlay content from assistive technology (#9016) (ef06a9c), closes #7787
  • directionality: complete dir change observable (#8874) (a2438fa)
  • drawer: margins not being updated on direction changes (#9161) (f64a857), closes #9158
  • expansion: accordion emitting closed event while closed (#9101) (50161ae), closes #9098
  • focus-trap: server-side rendering error (#9001) (7698193), closes #8981
  • icon: handle values with unnecessary spaces being passed into fontIcon and fontSet (#9056) (b71d954), closes #9054
  • icon: server-side error when registering icons (#8492) (61b12b6), closes #6787
  • input: align caret color with spec (#8692) (1eb8450)
  • layout: handle platforms that don't support matchMedia (#8775) (673a636), closes #8710
  • progress-bar: animation tearing in Firefox 57 (#9123) (255f9d8), closes #7606
  • select: active item not being updated on click in multiple mode (#7808) (ce2487e)
  • select: not marked as touched when clicking away (#8784) (c0209fc), closes #8573
  • select: remove aria-owns when options aren't in the DOM (#9091) (4a03497), closes #7023
  • select: support using shift + arrow key to toggle items in a multi-select (#9037) (76055a4)
  • selection-list: allow jumping to first/last item using home/end (#9062) (6d70f2c)
  • selection-list: allow users to jump focus to a particular item by typing (#9026) (7167113)
  • selection-list: options not marked as selected if value is assigned too early (#9090) (c61a289), closes #9085
  • selection-list: preselected options not being added to the model value (#9116) (2235239)
  • selection-list: remove selected option from model value on destroy (#9106) (02a1334)
  • stepper: completed binding not being considered when moving from a step without a stepControl (#9126) (9da4e71), closes #8110
  • stepper: use up/down arrows for navigating vertical stepper (#8920) (a6c7888)
  • typography: deprecation warning if null font family is passed in (#9002) (497816b), closes #8973

Performance Improvements

  • ripple: do not register events if ripples are disabled initially (#8882) (4838f02)

Bug Fixes

  • autocomplete: panelClosingActions emitting twice in some cases (#8998) (22c3259)
  • dialog: change order of button actions (#9021) (7b879a5)

Bug Fixes

Performance Improvements

5.0.1 ceramic-gravy (2017-12-11)

Bug Fixes

Bug Fixes

  • drawer: avoid initial animation when rendering on the server (#8828) (2b1f84e), closes #6865
  • tabs: hide tab body content after leaving the tab's view area (#8827) (05d726d)

Features

BREAKING CHANGES

  • overlay: OverlayRef.getConfig returns an immutable version of the config object.
  • overlay: OverlayRef.updateSize now accepts a OverlaySizeConfig rather than being based on the existing config object.

Features

Bug Fixes

  • checkbox: don't hide focus indicator on space press. (#8539) (9e35bf0)
  • chip-list: fix error state changes in chip list (#8425) (d2c11ca)
  • chip-list: stateChanges stream not being completed (#8636) (61dada8)
  • datepicker: calendar overlapping input when in a fallback position (#8099) (e5b7afe)
  • datepicker: keyboard fixes (enter matches click behavior & corre… (#7370) (0b2757c)
  • datepicker: placeholder not floating when an invalid value is typed in (#8603) (f0789eb), closes #8575
  • directionality: change event now emit the new value (#8424) (841f753)
  • drawer: allow for drawer container to auto-resize while open (#8488) (e7b412a), closes #6743
  • form-field: unable to tap on certain types of inputs on iOS (#8543) (74c1d01), closes #8001
  • input: Add pure-CSS floating label logic that will work on... (#8491) (1a7a61a)
  • input: stuck in focused state if disabled while in focus (#8637) (bec4cfe), closes #8634
  • list: fix role for list-item (#8767) (8f7c7cf)
  • menu: not closing when overlay is detached externally (#8654) (dd3094f)
  • menu: Set menu-item icon color only when not set on mat-icon (#8614) (d0cb077), closes #8594
  • overlay: add horizontal fallback positions to the connected overlay defaults (#8689) (e939ea7), closes #8318
  • overlay: make config immutable for existing refs (#7376) (2dbc766)
  • progress-spinner: value not updated while in indeterminate mode (#8269) (9b68b54)
  • radio: coerce checked input binding (#8556) (f41fa8c)
  • select: option not truncated correctly in multiple mode (#7857) (d04aa19)
  • selection-model: inaccurate selected value when accessed in change subscription (#8599) (0f7fbda), closes #8584
  • sidenav: remove min-width (#7748) (55a9f9a)
  • slide-toggle: height collapsing if component doesn't have a label (#8270) (8205cb2), closes #8264
  • snack-bar: not applying all panel classes in IE (#8578) (a6d0847)
  • stepper: block linear stepper for pending components (#8646) (53c94c7), closes #8645
  • stepper: set appropriate aria-orientation (#8657) (9582b8b)
  • tabs: pagination not enabled on init on some browsers (#8104) (2c34a7e), closes #7983
  • blurry ripples for slide-toggle, radio, checkbox in MS edge. (#8514) (8b7a3af), closes #8392
  • tooltip: close tooltip if message is cleared while open (#8544) (d66284d)
  • tooltip: unable to type in input with tooltip on iOS (#8534) (75c665a), closes #8331

5.0.0-rc.2 (2017-11-27)

Bug Fixes

  • overlay: disposed overlays not removed from the key event stack (#8226) (461dfaf)
  • tabs: fix accidentally setting top instead of width after removing Renderer use (#8602) (6e865b7)

Features

  • The examples on material.angular.io are now opened externally via StackBlitz instead of Plunker.

5.0.0-rc.1 (2017-11-20)

Bug Fixes

  • autosize: incorrect height with long placeholders (#8024) (ad7cb4a), closes #8013
  • cdk-observers: prevent attribute renaming in closure compilers advanced optimizations (#7894) (8dfe470)
  • checkbox: Set aria-checkbox to mixed for indeterminate checkbox (#8089) (3037a90)
  • chip: fix placeholder and text overlap (#8468) (81db650)
  • chips: remove chip bottom margin in sibling chips (#8198) (d79903a)
  • chips: use all available space for the input (#7462) (c725249)
  • datepicker: add missing exportAs (#7782) (d6d9ff8)
  • datepicker: correct DST issues on IE 11 (#7858) (2f2325a)
  • datepicker: correct overlay broad style selector (#8130) (f69c8e6)
  • datepicker: prevent matInput from clobbering date value (#7831) (4b59ca1)
  • drawer: invalid margin declaration when rendering server-side (#8324) (5600b80)
  • drawer: missing elevation shadow (#8387) (b0756a2), closes #8386
  • drawer: re-add openedStart and closedStart events (#7747) (7610c7c)
  • expansion: prevent memory leak by calling parent ngOnDestroy (#8410) (f6bd9b0)
  • fab-buttons: vertically align icons inside fab buttons (#8442) (43217ef)
  • form-field: jumping underline in Edge and Firefox (#8480) (c7ab877), closes #8395
  • icon: remove IDs from source icon set from rendered output (#8266) (76806e3)
  • input: add aria-required to inputs (#8034) (8178d6f)
  • input: remove native IE reveal icon (#8439) (47055a7), closes #8390
  • select: error when attempting to open before init (#8242) (ba36d3a)
  • progress-spinner: coerceNumber values (#7791) (b6712f8)
  • list: multi-line list item spacing (#8339) (bb504ad), closes #8333
  • menu: return focus to root trigger when closed by mouse (#8348) (b085dc6), closes #8290
  • overlay: better handling of server-side rendering (#8422) (0f83b20), closes #8412
  • overlay: complete key event stream on dispose (#8341) (b437b45)
  • overlay: remove global keydown listener when there are no open overlays (#8389) (131272a)
  • progress-spinner: default strokeWidth to 10% of the diameter (#7746) (b997353)
  • slide-toggle: drag not working in edge (#8421) (d6f287e), closes #8391
  • snack-bar: complete onAction observable on close (#8183) (bc8560e)
  • stepper: update state when steps change (#8398) (2bc0b41)
  • tabs: detach tab portal when tab hides from view (#8486) (fbf2987)
  • tooltip: allow toolip to reopen when closed by detaching overlay (#8232) (0719c38)
  • consistently coerce boolean and number properties (#7283) (3ca801a)
  • replace extendObject utility w/ object spread (#7372) (ea54edb)
  • using correct global name in rollup bundle (#8407) (40be1f2)
  • TypeScript interfaces are now documented on https://material.angular.io

Features

  • a11y: add autoCapture option to cdkTrapFocus (#7641) (20b47d7)
  • datepicker: dispatch events when datepicker is opened and closed (#7792) (998153a)
  • dialog: add ariaLabel and focusOnOpen config options (#6558) (dad5922)
  • gestures: add injection token for specifying Hammer.js options (#8106) (f2a0206), closes #7097
  • menu: allow disabling ripples on items (#8388) (ce23395), closes #8261
  • overlay: add option to re-use last preferred position when re-applying to open connected overlay (#7805) (f83beb8)
  • reposition-scroll-strategy: add option for closing once the user scrolls away (#8233) (58598c4)
  • slider: support specifying tabindex (#7848) (8e9dade)
  • tab-nav-bar: allow setting tabindex for links (#7809) (a041253)

Highlights

  • First release candidate for Angular Material and CDK! The team now believes that APIs and behaviors are stable and mature enough to exit beta. Please continue to file issues that help us eliminate more bugs from the forthcoming 5.0.0 release. Moving forward, the major version number of Angular Material and CDK will update alongside Angular itself.
  • A moment.js implementation of the DateAdapter for MatDatepicker is now available as @angular/material-moment-adapter
  • Based on Angular 5.0
  • More consistent naming conventions across the board
  • 60+ bug fixes

BREAKING CHANGES

  • Angular Material now requires Angular 5, which itself requires TypeScript 2.4+ and RxJS 5.5.2+
  • mat-icon now uses HttpClient from @angular/common/http instead of Http from @angular/http. Any unit tests that faked icon responses should be changed to use an HttpInterceptor.
  • @angular/cdk/rxjs has been removed in favor of RxJS 5.5's lettable operators.
  • toolbar: in previous versions, any content of mat-toolbar not wrapped in a mat-toolbar-row would be rendered inside of an implicitly created mat-toolbar-row. As of rc0, this implicit row will no longer be created. This means that any custom application CSS that targeted this implicitly created mat-toolbar-row will no longer apply. Users can re-add the mat-toolbar-row in their own templates to match the original output structure. This resolves a longstanding issue where display: flex styles were difficult to use on mat-toolbar.
  • accordion: move CdkAccordion to @angular/cdk/accordion
    • CdkAccordion and associated classes live in @angular/cdk/accordion
    • AccordionChild is renamed to CdkAccordionChild
    • CdkAccordion no longer has displayMode and hideToggle @Inputs
    • CdkAccordionItem is now a @Directive
  • table:
    • The argument order for the when property of matRowDef and cdkRowDef has been changed from (rowData, index) to (index, rowData) in order to match trackBy.
  • datepicker:
    • fromIso8601 method on DateAdapter removed in favor of deserialize
    • DateAdapter will return an invalid date instead of throwing an error
    • The userSelection @Output of mat-calendar has been made internal-only
  • cdk/scrolling:
    • ScrollDispatcher.getScrollContainers has been renamed to getAncestorScrollContainers to better match its behavior.
    • The ScrollDispatcher.scrollableReferences property has been renamed to scrollContainers.
    • The ScrollDispatcher.scrollableContainsElement method has been removed.
    • The Scrollable class has been renamed to CdkScrollable for consistency.
    • Any uses of the ScrollDispatcher.scrolled method have to be refactored to subscribe to the returned Observable, instead of passing in the callback. Example
      // Before
      scrollDispatcher.scrolled(50, () => ...);
      
      // After
      scrollDispatcher.scrolled(50).subscribe(() => ...);
  • unique-selection: move UniqueSelectionDispatcher to @angular/cdk/collections (UniqueSelectionDispatcher, UniqueSelectionDispatcherListener, and UNIQUE_SELECTION_DISPATCHER_PROVIDER)
  • MATERIAL_COMPATIBILITY_MODE, CompatibilityModule, NoConflictStyleCompatibilityMode, MatPrefixRejector, MdPrefixRejector symbols have been removed.
  • MAT_CONNECTED_OVERLAY_SCROLL_STRATEGY is renamed to CDK_CONNECTED_OVERLAY_SCROLL_STRATEGY

Deprecations

  • The following classes have been renamed. The old names are still available as deprecated: OverlayOrigin -> CdkOverlayOrigin ConnectedOverlayDirective -> CdkConnectedOverlay PortalDirective -> CdkPortal PortalHostDirective -> CdkPortalOutlet ObserveContent -> CdkObserveContent
  • The following @Output names have been renamed. The old names are still available as deprecated:
  • mat-select
    • onOpen -> opened
    • onClose -> closed
    • change -> selectionChange
  • mat-sidenav / mat-drawer
    • open -> opened
    • close -> closed
  • mat-menu
    • close -> closed
  • matMenuTriggerFor
    • onMenuOpen -> menuOpened
    • onMenuClose -> menuClosed
  • mat-chip
    • onSelectionChange -> selectionChange
    • remove -> removed
    • destroy -> destroyed
  • mat-tab-group
    • selectChange -> selectedTabChange

Features

  • table: add MatTableDataSource (#6747) (a9600e7)
  • dialog: support minWidth, minHeight, maxWidth and maxHeight (#7488) (57f19cd)
  • overlay: new keyboard dispatcher for targeting correct overlay (#6682) (a2ca4d6)
  • snack-bar: set snack bar to be responsive. (#7485) (5b7982f)
  • sort: use existing intl provider if one exists (#7988) (c8df2c1)
  • dialog: add optional generic param for config data (#7447) (b29ac45), closes #4398
  • Most directives / components now define an exportAs name (#7554) (fa441bc)

Bug Fixes

  • block-scroll-strategy: disable smooth scrolling before restoring scroll position (#8132) (75bccde), closes #7139
  • button: focus styles not applied to programmatically focused buttons (#5966) (a0bb1a3), closes #7510
  • button-toggle: support two-way binding of value (#7911) (ee4915c)
  • card: change image path to https in example (#7800) (65d3630)
  • chip-list: use role = listbox only if chip list is not empty (#7664) (dc76c09)
  • chips: programmatically selected chip stealing focus (#7978) (8168667)
  • datepicker: allow DateAdapter authors to have more control ove… (#7346) (9fa075e)
  • datepicker: use disabled state from FormControl (#7514) (66e71c8)
  • dialog: don't block other dialogs from opening while animating (#8051) (cc4fc11), closes #6560
  • drawer: not restoring focus on close (#7668) (3041124)
  • drawer: unable to toggle while drawer is animating (#6810) (085827f), closes #6376
  • expansion-panel: prevent content from being clipped (#7617) (aa77aa1)
  • focus-trap: server-side rendering error (#7635) (f7a12b6), closes #7633
  • focus-trap: update focus trap attrs to camel case #6799 (#6960) (c663fad)
  • form-field: fix underline at different zoom levels (#7567) (5cffd7c)
  • form-field: remove 200px width since it messes up flex layouts (#7083) (160a511)
  • form-field: remove specific mention of matInput in error (#7727) (f17cb99)
  • icon: use SafeResourceUrl in getSvgIconFromUrl (#7535) (291a87c)
  • input: remove IE clear icon (#8095) (2fa679b), closes #8076
  • menu: add typography mat-font-weight (7fe1b81)
  • menu: make @Output names consistent #6677 (#8053) (b2dd17a)
  • menu: not handling keyboard events when opened by mouse (#4843) (d822a39), closes #4991
  • menu: wrong offset for nested menu in a fallback position (#7562) (074f6ce), closes #7549
  • overlay: CloseScrollStrategy not triggering change detection on close (#7929) (c0ba25a), closes #7922
  • overlay: emitting to detachments stream when not attached (#7944) (6fdc237)
  • overlay: import BidiModule in OverlayModule (#7566) (4321f32)
  • overlay: overlay class audits #6372 (#8056) (cd05b54)
  • overlay: wait until after change detection to position overlays (#6527) (f299d25)
  • paginator: fix select baseline; support mobile (#7610) (c12e4b5)
  • progress-spinner: fallback animation not working (#7599) (4bb696e)
  • progress-spinner: inaccurate stroke width on really small spinners (#7725) (f52f078), closes #7686
  • progress-spinner: spinner with narrower stroke not taking up entire element (#7686) (2361983), closes #7674
  • scroll: Replace references to scrollableReferences (#7752) (9673f63)
  • select: errors not shown on submit (#7640) (d2f41a4), closes #7634
  • select: make @Output names consistent #6677 (#8052) (f59abdb)
  • select: not scrolling active option into view when typing (#7620) (717f252)
  • select: remove inert focus call (#7729) (70c349c)
  • select: support typing to select items on when closed (#7885) (8edb416)
  • select: unable to preselect array value in single selection mode (#7603) (d55aa0c), closes #7584
  • select: wrong cursor on disabled select (#7696) (9b4f435), closes #7695
  • selection-list: fix option value coercion and selection events (#6901) (80671bf), closes #6864
  • snack-bar: add content fade in animation (#7504) (2b9c470)
  • snackbar: swap enter and exit animation curves (#6791) (4f571b1)
  • sort: fix arrow on width-constrained headers (#7569) (147ae46)
  • spinner: set initial value for spinner to 0. (#8139) (9e4c636)
  • stepper: don't grey out non-linear steps (#7479) (60707b3), closes #7260
  • stepper: error when selectedIndex is pre-set (#8035) (cf11ff2), closes #8031
  • table: broaden abstraction for filtering (#8059) (d47b37a)
  • table: cell content should not stretch width (#7666) (bb424e2)
  • table: empty string should be sorted right (#8011) (58627c4)
  • table: render cells even if data is falsy (#7914) (f601e83)
  • table: switch when arguments (#7516) (a2129fc)
  • table: Provide a provider if exists. (#7895) (9a05ecd), closes #7344
  • table: throw error when missing row defs (#7751) (55476e2)
  • table: update implicit when using trackby (#7893) (f806286)
  • tabs: incorrect ripple color for tabs with background (#8123) (02d3eb6)
  • toolbar: no longer auto-generate toolbar rows (#6661) (c3405aa), closes #6004 #1718
  • tooltip: don't open from programmatic focus (#7258) (90a55fa), closes #7245
  • viewport-ruler: incorrectly caching viewport size (#7951) (0d6d9cc)
  • consistent names for all cdk directives (#8088) (f08b3f0)
  • don't show sanity check messages in tests (#8080) (d17f9d2)
  • user-select mixin ignores value (#7992) (eaa4a36)

Performance Improvements

Code Refactoring

Highlights

  • Progress spinner is now entirely css-based.
  • Fixed sidenav: the sidenav can now be configured to use fixed positioning. This resolves a longstanding issue where sidenav-container would always introduce a scrolling region.
  • mat-select is now used inside mat-form-field. This makes all of the existing form-field features available with mat-select, including hints, errors, prefixes, and suffixes. This also ensures that mat-select and matInput have a consistent presentation.
<mat-form-field>
  <mat-select placeholder="State">
    <mat-option *ngFor="let state of states" [value]="state">{{ state }}</mat-option>
  </mat-select>
</mat-form-field>
<a name="2.0.0-beta.12"></a>
# [2.0.0-beta.12 marble-mustache](https://github.com/angular/material2/compare/2.0.0-beta.11...2.0.0-beta.12) (2017-10-05)

Breaking Changes

  • All "md" prefixes have been removed. See the deprecation notice in the beta.11 notes for more information.
  • All cdk re-exports in @angular/material have been removed. See the the beta.10 notes for more information.
  • Previously the ScrollDispatcher.scrolled subscription would react both on scroll events and on window resize events. Now it only reacts to scroll events. To react to resize events, subscribe to the ViewportRuler.change() stream.
  • UniqueSelectionDispatcher, UniqueSelectionDispatcherListener and UNIQUE_SELECTION_DISPATCHER_PROVIDER are no longer available from @angular/material and instead must be imported from @angular/cdk/collections
  • isFocusTrapEnabled is now properly marked internal.
  • The OverlayRef.getState method has been renamed to OverlayRef.getConfig.
  • defaultErrorStateMatcher has been replaced by ErrorStateMatcher. For more info, see the input docs.

Features

  • autocomplete: add md-autocomplete classes to overlay panel (#7176) (f8cd790), closes #4196
  • dialog: add datepicker dialog and popup classes for easy styling (#7013) (0ff8d5d)
  • menu: support typeahead focus (#7385) (f0d20ca)
  • nav-tabs: add mat-tab-label-active class to active nav tab labels (#7508) (00e9338)
  • progress-spinner: switch to css-based animation (#6551) (630dfad)
  • select: add support for custom error state matcher (#7443) (a774688), closes #7419
  • select: make select work inside form-field (#6488) (d914cc4)
  • selection-model: de/select multiple values at the same time (#7001) (e52beeb)
  • sidenav: Add support for fixed sidenavs (#6712) (61579bc)
  • sort: add enter and leave arrow animations (#7180) (2d350a0)
  • table: add row when predicate (#6795) (0875b85)
  • viewport-ruler: add common window resize handler (#7113) (3b0915a)

Bug Fixes

  • add exportAs to missing components (#7392) (31e9775), closes #7361
  • remove all md prefixes (#7241) (20a23f1)
  • slide-toggle: report change to model before firing a change event (#7076) (c82fca8), closes #7074
  • remove cdk re-exports from @angular/material (#7112) (f9b5ccd)
  • autocomplete: don't open panel for readonly inputs (#7271) (5f8615f), closes #7269
  • autocomplete: emit closing action for escape keydown event (#6250) (f4673a5)
  • autocomplete: empty not cleaning up on tab (#7270) (6be0462), closes #7268
  • autocomplete: error if panel is added asynchronously (#7078) (504ba70), closes #7069
  • autocomplete: remove invalid aria markup (#7107) (6bd6b9f), closes #7100
  • button: allow for elevation to be overwritten (#7305) (92a868e), closes #7264
  • calendar: not reacting to min/max boundary changes (#7234) (eb012cc), closes #7202
  • checkbox: defaulting to invalid name and value attributes (#7130) (26788f1)
  • checkbox: support native tabindex attribute (#6793) (0270cf5)
  • chips: do not set chips value if there's no ngControl or value (#7285) (d9ba13f)
  • chips: fix chip list focus and keyboard behaviors (#7319) (f166468)
  • common: don't log doctype warning when rendering server-side (#6833) (f8ed442)
  • common-module: check if computed styles are available (#7003) (5da9e64), closes #7000
  • datepicker: make sure _datepickerInput exists before accessing its (#7033) (2129b7a)
  • dialog: directionality not injected into child components (#7111) (daa3880)
  • drawer: backdrop not transitioning on close (#6651) (80310a5)
  • drawer: drawer container animating when open by default (#7129) (4d278dd), closes #7007
  • drawer: drawer container not reacting to drawer removal (#7060) (b0b91f4), closes #6271
  • drawer: open event not firing on init (#7214) (ba5653d), closes #7208
  • input: apply readonly attribute when readonly (#7439) (01622b1)
  • input: don't highlight container when readonly input is focused (#7273) (f076390)
  • input: make autosize work inside tabs & stepper (#7341) (c6824d5)
  • list-key-manager: align matching logic with native listbox (#7212) (846cc13)
  • list-key-manager: don't focus disabled items in typeahead mode (#7382) (1823b2f)
  • menu: multiple close events for a single close (#7037) (2dcb76c)
  • menu: nested menu error when items are rendered in a repeater (#6766) (7a96570), closes #6765
  • overlay: detach method returns undefined (#7449) (0584cdf), closes #7408
  • paginator: page size selector not working (#7263) (2b3d795)
  • radio: defaulting to invalid name attribute (#7131) (c5e162b)
  • ripple: handle touch events (#7299) (fe0864b), closes #7062
  • ripple: remove unused ScrollDispatchModule (#7528) (4a1a68d)
  • ripple: use element coordinates instead of page coordinates (#7446) (7714a5c), closes #7436
  • select: losing focus when selecting values through binding (#7296) (86bea91), closes #7092
  • select: multiple change events emitted when changing options of a closed select (#7232) (c7ab828), closes #7227
  • select: prevent nbsp from getting butchered in AOT (#7363) (2e71cac)
  • select: theme not being transferred to the panel (#7342) (6b70ca6)
  • selection-list: model not updated when option is selected programmatically (#7334) (f40a7cc), closes #7318
  • selection-list: restore focus if active item is destroyed (#7125) (e05f939)
  • selection-list: tabIndex should respect disabled state (#7039) (c2a9516)
  • sidenav: change content from md- to mat- (#7307) (d05dcfa)
  • slider: change event is not being emitted (#7278) (39543a3), closes #7207
  • snack-bar: positioned snack bar animation not starting off-screen (#7453) (58d3bb8)
  • snack-bar: subsequent snack bars not opening; animation issues (#7086) (8e77261), closes #7063
  • sort: fix incorrect conditional grouping (#7427) (f5e916d)
  • sort: style changes to fix IE (#7375) (75f26e8)
  • sort: throw error on invalid direction (#7378) (cc6f39e)
  • stepper: align appearance with spec (#7279) (4122ae2), closes #7260
  • stepper: avoid blurry content on IE (#6992) (6f48710)
  • stepper: selected is always undefined (#7213) (217840c)
  • stepper: switch to OnPush change detection (#7119) (c2c6e04)
  • stepper: unable to internationalize labels (#7122) (6e3bbcb)
  • tabs: blurry content in IE (#6954) (7a354a0), closes #6944
  • tabs: update tab output names (#7134) (38268d3)
  • theming: incorrect green-500 contrast color (#7492) (c1f6ea1), closes #7490
  • tooltip: ensure tooltip stays within viewport (#6659) (c8ddd39), closes #5428
  • tooltip: minification issue (#7430) (b121e32)

Highlights

  • Each @angular/material component is now bundled into its own javascript file. This will allow tools like webpack to more easily load only the components being used in an application.
  • New stepper component! The base behavior lives in @angular/cdk with Material Design flavors in @angular/material.

Breaking changes

  • Angular Material now requires Angular 4.4.3 or greater
  • MaterialModule has been removed. (cf1ece0) (#6803) See the deprecation notice from beta.3 for more information.
  • MdCoreModule has been removed. Most of its functionality has been moved to @angular/cdk over the last few releases.
  • FocusOriginMonitor has been renamed to FocusMonitor and moved to @angular/cdk.
  • chip-list: The outputs select and deselect have been removed in favor of a single onSelectionChange output.
  • overlay: OverlayState has been renamed to OverlayConfig
  • overlay: Now that the Overlay is part of the cdk rather than Angular Material directly, the themeClass property has been removed. To add a class to the overlay for theming, you can do
overlayContainer.getContainerElement().classList.add('my-theme-class');
  • DateAdapter method getISODateString has been renamed to toIso8601 and a new method fromIso8601 has been added.
  • sort: The sort-change stream mdSortChange has been renamed to sortChange.

Deprecation of "md" prefix.

In earlier betas, we've had a compatibility mode that allowed people to use either "md" or "mat" as the selector for Angular Material components. This was created so that these components could live side-by-side with AngularJS Material without CSS from the two libraries colliding.

For beta.11, we've made the decision to deprecate the "md" prefix completely and use "mat" moving forward. This affects all class names, properties, inputs, outputs, and selectors (CSS classes were changed back in February). The "md" prefixes will be removed in the next beta release.

You can automatically update your projects with the angular-material-prefix-updater tool. Check out the tool's page for instructions on how to run.

Why are we doing this?

We like the "md" prefix too! We added compatibility mode in order to keep "md" around, but over time we found that there were too many downsides to continue supporting both prefixes at the same time:

  • Many users found the fact that the CSS used "mat" while templates used "md" confusing.
  • Users in compatibility mode found that having "mat" in their templates while TypeScript class names remained "Md" to be unfriendly.
  • Making both prefixes available consistently through templates required adding many getters/setters that aliased the "true" property. This ends up increasing payload size and complexity of the source code.
  • Compatiblity mode itself used broad directive selectors to enforce that only one prefix was used at a time. This causes a problem where this broad selector prevents Angular from throwing an error if an application uses a component without importing its NgModule.

Why not change the styles in AngularJS Material?

We explored this option early on (before creating compatibility mode). We found that changing the library's styles such that they wouldn't affect the Angular Material components would increase the specificity. This would have been a significant breaking change, as it would have potentially broken countless custom styles that relied on a particular specificity working.

Other deprecations

  • StyleModule is deprecated. FocusOriginMonitor (the only thing it contained) has been renamed to FocusMonitor and moved to @angular/cdk/a11y (A11yModule).

Bug Fixes

  • autocomplete,select: inconsistent disabled option coloring (#6640) (454781d), closes #6638
  • autosize: not resizing on programmatic changes (#6654) (89fea50), closes #5247
  • button-toggle: border radius ignored if option is selected (#6699) (82e14f8), closes #6689
  • checkbox: label content should not wrap (#6674) (9acab86), closes #6671
  • chips: set appropriate aria-orientation (#6464) (a37aa6a)
  • datepicker: allow date or datetime strings in fromIso8601 (#7220) (8436f8c)
  • datepicker: allow ISO 8601 strings as inputs (#7091) (d2ceb2c)
  • datepicker: backdrop class should be mat- (#7056) (2b61eb6)
  • datepicker: Create a new injection token to avoid overriding LOCALE_ID (#6708) (2635cad)
  • datepicker: fix wrong datepicker-input value for non MM/DD/YYYY locales (#6798) (29399b8)
  • datepicker: makes sure the datepickerInput is registered (#7049) (e4d48d7)
  • datepicker: toggle not reacting to disabled state changes in datepicker or input (#6964) (85993d3)
  • expansion-panel: dark theme header hover color (#6616) (21c68ad)
  • form-field: add aria-owns to label element (#6683) (4191b4d)
  • form-field: placeholder not floating if autofilled (#6839) (602a861), closes #6837
  • grid-list: avoid unnecessary calc declarations (#6745) (255611b)
  • grid-list: styles not cleared when switching to a different styling mode (#6660) (87d607e), closes #4047
  • input: remove resize handle from non-textarea inputs (#6768) (1272f03), closes #6757
  • list: subheader margin being overwritten by typography (#6735) (efe483a)
  • menu: multiple close events for a single close (#6961) (1cccd4b)
  • menu: nested menu hover not working when trigger is added lazily (#6807) (6b5100b), closes #6731
  • menu: nested trigger staying highlighted after click (#6853) (04bf3d1), closes #6838
  • overlay: rename OverlayState to OverlayConfig (#6972) (1cfce8d)
  • progress-bar: query mode not reversing direction in rtl (#6922) (8a21881)
  • select: extra whitespace around placeholder (#6955) (9fe6386), closes #6923
  • selection-list: do not coerece option value to boolean (#6983) (dfe01f2)
  • selection-list: proper style for disabled options (#6829) (547d11f)
  • slide-toggle: remove side-margin if slide-toggle label is empty (#6881) (a1ec81a), closes #6868
  • slide-toggle: support native tabindex attribute (#6613) (8f9f3c8)
  • slider: thumb disappearing on disabled element with thumb label (#6641) (8243b16), closes #6631
  • slider: update styles when focus and dir change (#6700) (8c49422)
  • slider, drawer: unsubscribe from directionaly change subject (#6907) (a7ce31e), closes #6892 #6903
  • snack-bar: animation not starting for subsequent snack bars (#6649) (730e7ae), closes #6222
  • sort: reverse directions and better animation (#6802) (6fa9e6f)
  • table: gracefully handle undefined/null columns (#6862) (3ddf65b)
  • tabs: fix infinite tab loop (#6663) (67e02b0), closes #4639
  • tabs: tab spacing on desktop incorrect (#6681) (b678119), closes #3347
  • tooltip: closing immediately when triggered on click (#6590) (bcd026f)
  • tooltip: ensure tooltip never passes undefined message to (#7018) (f6d1078)
  • add mat exportAs and class aliases (#7106) (a96b545)
  • tooltip: error on trigger escape presses while closed (#7028) (dcf3b27), closes #7009

Features

  • chip-list: implement FormFieldControl and ControlValueAccessor (#6686) (7a42706)
  • datepicker: Add Moment.js adapter (#6860) (9545427)
  • dialog: add afterOpen to MdDialogRef (#6887) (27cbe47)
  • expansion-panel: allow for the panel header height to be customized (#6643) (11e2239), closes #5641
  • overlay: replace OverlayContainer themeClass w/ addClass/removeClass methods (#6975) (a944f6e)
  • selection-list: add selectAll and deselectAll functions (#6971) (dc9679d), closes #6969
  • sort: add sorting indicator animation (#5831) (70bd5fc)
  • stepper: Add e2e test (#6776) (bef6271)
  • stepper: add moduleId to components (#6780) (f375f92)
  • stepper: Address previous comments + add directionality support (#6775) (c396596)
  • stepper: initial version of stepper (#6594) (87318bc)
  • viewport-ruler: add common window resize handler (#6680) (881630f)
  • add preserveWhitespaces: false to all components (#7115) (2b0315d)
  • move FocusMonitor into cdk (#6921) (6cfe5c4)

Performance Improvements

Highlights

  • Over 140 bug fixes
  • Nested menus
    • Nested menus
      • Nested menus!
  • Autocomplete supports md-optgroup
  • Overlay moved to @angular/cdk
  • New component MdSelectionList
  • md-input-container renamed to md-form-field (while still being backwards compatible)
  • Almost all components now use OnPush change detection (dialog being the exception)
  • You can now get back the EmbeddedViewRef when attaching a TemplatePortal
  • MdSidenav has been split into MdSidenav and MdDrawer. The MdSidenav is now meant to be used for top-level application navigation, while the drawer is meant to be used for more local split views. While there are no differences introduced between the two in this release, future releases will see different features added to each

Breaking changes

  • Imports from @angular/cdk are now scoped to a specific sub-package. For example, if you previously had:
import {LiveAnnouncer, Overlay, Directionality} from '@angular/cdk';

You will now need to write:

import {LiveAnnouncer} from '@angular/cdk/a11y';
import {Directionality} from '@angular/cdk/bidi';
import {Overlay} from '@angular/cdk/overlay';

This helps ensure you're only pulling in the pieces of the cdk being used as well as providing more context about what an imported symbol is being used for.

The current set of public @angular/cdk subpackages are: a11y, bidi, coercion, collections, keycodes, observers, overlay, platform, portal, rxjs, scrolling, table.

If you are using SystemJS, each package you use must be added to the SystemJS configuration.

  • All Overlay code has been moved from @angular/material to @angular/cdk. The symbols are still re-exported through @angular/material, but these re-exports will be removed in a subsequent release.
  • cdkScrollable, ScrollDispatcher, and ViewportRuler have been moved from overlay into its own scrolling subpackage in @angular/cdk.
  • input: Inputs have a width of 200px by default (similar to native input elements). The width can be overridden by via the mat-form-field css class.
  • input: CSS classes have changed from mat-input-container- to mat-form-field-.
  • input: md-prefix and md-suffix are now mdPrefix and mdSuffix.
  • portal: TemplatePortal now requires a generic type (C) to align with TemplateRef. This will usually be any.
  • portal: Attaching a template portal will now return an EmbeddedViewRef<C> instead of an empty Map.
  • observe-content: ObserveContentModule has been renamed to ObserversModule
  • overlay: PositionStrategy now has an attach method and no longer passes the overlay DOM element to apply.
  • datepicker: You must now use a date object (of whatever type your DateAdapter uses) rather than a string when setting the value of the datepicker programmatically (through value, ngModel, or formControl).
  • datepicker: mdDatepickerToggle is now an element <md-datepicker-toggle> with a for property that points to the MdDatepicker instance
  • datepicker: NativeDateAdapter will now use Angular's LOCALE_ID instead of the browser's locale.
  • sidenav: CSS classes have changed from mat-sidenav- to mat-drawer-
  • theming: The nonstandard 0 and 1000 hues have been removed from the mat-gray palette
  • chips: The selectable property of the md-chip-list has now been moved to md-chip to maintain consistency with the new removable option.

If you used the following code,

<md-chip-list [selectable]="selectable">
  <md-chip>My Chip</md-chip>
</md-chip-list>

you should switch it to

<md-chip-list>
  <md-chip [selectable]="selectable">My Chip</md-chip>
</md-chip-list>

Deprecations

  • All dash-case @Directive selectors are deprecated in favor of the camelCase equivalent. The dash-case selectors will be removed in a subsequent release. Some examples include:
Old New
md-line mdLine
md-tab-link mdTabLink
md-tab-label mdTabLabel
md-card-avatar mdCardAvatar
  • md-input-container has been renamed to md-form-field. The old selector will be removed in a subsequent release. This is in preparation to making md-select a child of md-form-field such that both select and input share the same features and appearance.
  • For camelCased directives, each corresponding @Input() is now also prefixed. For example, cdkConnectedOverlay now has inputs for cdkConnectedOverlayOrigin, cdkConnectedOverlayPositions, etc. The class members themselves are unchanged. The unprefixed inputs will be removed in a subsequent release. Affected directives are cdkPortalHost, cdkConnectedOverlay, mdTooltip, mdTextareaAutosize, and mdMenuTriggerFor.
  • MdCoreModule is deprecated and will be removed in a subsequent release now that most of its functionality has been moved to @angular/cdk
  • Reminder that MaterialModule is deprecated and will be removed in a subsequent release (see changelog from beta.3 for more information).

Features

  • autocomplete: emit event when an option is selected (#4187) (2dd5c7c), closes #4094 #3645
  • autocomplete: support for md-optgroup (#5604) (e41d0f3), closes #5581
  • cdk: move cdkScrollable, ScrollDispatcher, and ViewportRuler out of overlay (#6547) (0f6a2ec)
  • cdk: move overlay into cdk (#6100) (4d82f83)
  • chip: add aria-selected to chip (#5920) (281de25)
  • chips: Add removal functionality/styling. (#4912) (c82aca9), closes #3143
  • chips: add user defined tab index to chip list (#6073) (9eb9ddf)
  • datepicker: close calendar after choose the same date again (#6323) (9ba5d84)
  • datepicker: export unexported components for potential extension (#6314) (7bc648b)
  • dialog: add beforeClose method (#6377) (cdbf305)
  • dialog: expose backdrop clicks (#6511) (df28c3d)
  • dialog: open dialog API improvements (#6289) (8b54715), closes #6272
  • expansion-panel: add the ability to disable an expansion panel (#6529) (921432a), closes #6521
  • focus-trap: return whether shifting focus was successful (#6279) (7626c51)
  • menu: add indicator to menu items that trigger a sub-menu (#5995) (a51f82f)
  • menu: add injection token for overriding the default options (#5483) (3cb3945), closes #5479
  • menu: add nested menu functionality (#5493) (1e0c1fc)
  • menu: increase nested menu elevation based on depth (#5937) (91f7bf7)
  • native-date-adapter: use default locale from LOCALE_ID (#5419) (c09e8a7), closes #5393
  • option: support for disableRipple binding (#5915) (addf1ce)
  • overlay: add maxWidth and maxHeight (#6508) (9904e56)
  • overlay: add providers for overriding the scroll strategies per component (#5134) (184a6e4), closes #4093
  • overlay: support setting multiple panel classes (#6326) (a190de7), closes #6318
  • paginator: default page size to first option (#5822) (42c50b6)
  • portal: support context in TemplatePortal (#6408) (90a6ac9)
  • radio: add required attribute to radio-group (#5751) (f06fe11)
  • select: add ability to customize the select trigger (#3341) (72c5d39), closes #2275
  • select: allow disabling ripples for options (#5967) (34ec068)
  • select: allow focusing items by typing (#2907) (5ebca5e), closes #2668
  • select: implement compareWith for custom comparison (#4540) (054ea4d), closes #2250 #2785
  • select: support basic usage without @angular/forms (#5871) (9a90eaf)
  • selection-list: Selection-list initial version (#5562) (dccce1c)
  • snack-bar: inject data and MdSnackBarRef into custom snack-bar component (#5383) (baba6ef), closes #5371
  • tab-nav-bar: allow disabling ripples for links (#6273) (4ae1b0f), closes #6245
  • table: support dynamic column definitions (#5545) (66e222f)
  • tabs: add isActive flag on the individual tabs (#6424) (4d36ee0), closes #6422
  • add change emitters to the Intl providers (#5867) (0a5489f), closes #5738
  • tabs: add theming and ability to set background color (#5287) (374aaff)
  • typography: allow font-family to be set per typography level (#5905) (3b41c0c), closes #5563
  • typography: allow typography config to be passed via mat-core (#5625) (72148c0), closes #5589
  • expose version object in releases (#4962) (3bfe7f0)
  • rename cdk/keyboard -> keycodes & cdk/observe-content -> observers (#6039) (9df292f)
  • update to Angular 4.3 (#6483) (66da597)

Bug Fixes

  • autocomplete: attach overlay to a more accurate input element (#6282) (667a4e4)
  • autocomplete: don't darken select option (#6425) (67e91a3), closes #6407
  • autocomplete: don't prevent default enter action if panel is closed (#5977) (fdded66), closes #5976
  • autocomplete: error when closing destroyed panel (#5446) (880e6d5), closes #5413
  • autocomplete: highlighted option not reset when closed with escape or enter key (#6403) (bf59468), closes #6258
  • autocomplete: panel not resetting properly in certain scenarios (#5911) (ebb5e9e), closes #5910
  • autocomplete: placeholder not animating on focus (#3992) (ff54969), closes #5755
  • autocomplete: placeholder not resetting properly (#6141) (e4e7ee9)
  • autocomplete,datepicker,menu: closing parent dialog by pressing escape (#6226) (916d1f3), closes #6223
  • autosize: properly detect line-height in firefox (#6190) (3a766f1), closes #6179
  • bidi: make dir and changes readonly (#5645) (8c13325)
  • button-toggle: add aria-label for button-toggle (#5919) (eabe2cb)
  • button-toggle: button-toggle module depends on forms module (#5542) (9ab0c90)
  • button-toggle: remove emit change event when value changes (#6034) (f8c5be8)
  • card: prevent content from overlapping footer (#5583) (a394418), closes #5486
  • card: unable to bind to align attribute (#5495) (243b97d), closes #5490
  • checkbox: Add RequiredTrue validator for md-checkbox (#6006) (59319d0)
  • checkbox: remove checkmark from tab order (#6137) (735ffb5), closes #6125
  • checkbox: server-side rendering error when checking textContent (#5470) (0314bd8), closes #5453
  • checkbox, radio: setting id to null causes invalid id for input (#5398) (bcf4826), closes #5394
  • chips: add exportAs for chip and chip list (#6084) (e7da1e4), closes #6070
  • chips: cursor on remove button and box-shadow transition (#6019) (8253503)
  • chips: invalid aria-selected value for non-selectable chip (#6544) (90fc300)
  • chips: mark onFocus as internal (#6519) (449ed19)
  • chips: not visible in high contrast mode (#5338) (a5a8ff2)
  • chips: remove background from unstyled chip (#5777) (0f7be2e)
  • compat: add camelCase selectors to tab label wrapper (#5955) (a7e75da)
  • compat: add element selector for cdk-accordion (#5954) (3c46001)
  • connected-position-strategy: position change event not emitting for fallback positions (#5978) (63505dc)
  • datepicker: allow disabling calendar popup (#5305) (2294ea2)
  • datepicker: better support for input and change events (#4826) (35eb294)
  • datepicker: center date text properly on android (#5923) (bbadd01)
  • datepicker: deprecate selectedChanged output (#6025) (ee73d2c), closes #6000
  • datepicker: fix error when selecting month with fewer days in year (#6129) (9cff8c7)
  • datepicker: force Intl.DateTimeFormat to use UTC time zone ... (#5747) (76cc6f0)
  • datepicker: make height of calendar constant in non-touch mode (#5694) (5bcba85)
  • datepicker: make touch UI calendar use 80% of width in portrait (#5943) (641a38f)
  • datepicker: mark input tocuhed on calendar date selected (#6007) (21e9768)
  • datepicker: refactor datepicker toggle to support theming (#5317) (4255476)
  • datepicker: remove aria-expanded on datepicker input ... (#5746) (4ea4baa)
  • datepicker: remove toggle icon from tab order on IE (#6405) (ea17d3d)
  • datepicker: use 3 rows to display months of year (consistent with internal mocks) (#5427) (da1d1ca), closes #5202
  • datepicker: use correct viewContainerRef for dialog. (#6026) (08037f9)
  • datepicker: validate that input actually parses (#5711) (8bb54ca)
  • dialog: add config option for aria-describedby (#5365) (68241a8)
  • dialog: better handling of custom ViewContainerRef with OnPush change detection (#6164) (5967f6e)
  • dialog: move focus into container if no focusable elements are found (#6524) (4e12072), closes #6513
  • dialog: prevent dialog from opening while another dialog is animating (#5769) (36f708c), closes #5713
  • dialog: set margin on buttons inside md-dialog-actions (#5778) (643023d)
  • dialog: support passing in dialog result through all MdDialogClose selectors (#6293) (4a1f10e), closes #6278
  • expansion: use correct expanded line-height (#5744) (a921948)
  • expansion: animation not working in Angular 4.3 (#6442) (f9bd5d4)
  • expansion: only highlight keyboard-focused panel headers (#6148) (49a0d7b)
  • expansion: remove closed panel contents from tab order (#5441) (1efa594), closes #5432
  • expansion: remove margin from top and bottom panels in accordion (#6546) (7f0e58e)
  • expansion: set up typography styles (#5739) (e21b64c)
  • expansion: standalone panel shouldn't override margins (#5962) (81f1f97), closes #5949
  • expansion: toggle not being updated when set programmatically (#5650) (41c804b), closes #5549 #5623
  • expansion: wrong margins in rtl (#5800) (106ded4)
  • grid-list: figure not expanding to full width (#6578) (ea143a0), closes #6586
  • grid-list: invalid inline styles when rendering server-side (#6052) (22ce1da), closes #6048
  • icon: error when toggling icon with binding in IE11 (#6102) (0795432), closes #6093
  • icon: icon element not removed when svgIcon is reset (#6502) (5e3228f), closes #6495
  • input: add overflow:hidden when calculating autosize height (#5773) (e0fc526)
  • input: don't highlight container when readonly input is focused (#5776) (349121d), closes #5749
  • input: fix input/placeholder alignment on safari (#6072) (9ac5d13)
  • input: input module depends on forms module (#5579) (44ca46a)
  • input: invalid font declaration (#5154) (92d8368), closes #5262
  • input: make sure 1-line hint is fully contained by input container. (#5912) (ca3a3b8)
  • input: placeholder covering value when using OnPush (#5660) (219a8ae)
  • input: prevent input caret from sticking on iOS (#6128) (94bf5e9)
  • input: prevent textarea from resizing beyond input container (#5333) (36dc75a)
  • input: required asterisk being read out by screen readers (#6277) (0850981)
  • input: set default width of 200px on input-container (#5833) (e9ab9b4)
  • input: set proper role on md-error (#6259) (3df4d72)
  • input: underline should only be thicker if focused (#6152) (68e2f46)
  • input: update aria-describedby to also include errors (#6239) (2af284c)
  • input,select: align colors with spec (#5155) (266f237), closes #5114
  • list: :empty selector did not catch in mat-list-text (#6124) (846899d)
  • list: properly align contents in subheader (#6221) (4e6e42e), closes #6214
  • list: subheader margin being overwritten by typography (#5652) (5bc97ec), closes #5639
  • list-key-manager: increase typeahead range to include more characters (#6543) (1f4a962)
  • list-key-manager: typehead not handling non-English input (#6463) (08a6673)
  • live-announcer: remove announcer element on destroy (#5404) (b7efe48)
  • menu: align appearance with spec (#5361) (c20bec8)
  • menu: close child menus when parent is closed programmatically (#6329) (66b1ff5)
  • menu: complete close stream on destroy (#5368) (d810138)
  • menu: make it easier to override elevation (#5873) (6f5dcd5), closes #5870
  • menu: prevent user from accidentally opening a sub-menu while animating (#5996) (eaa6099)
  • menu: wrong animation in Angular 4.2+ (#5836) (39c3e42)
  • overlay: add prefixed inputs, deprecate old ones (#5957) (2bf6b57)
  • overlay: error when removing empty string theme (#6306) (faa7601)
  • overlay: remove overlay container on destroy (#5378) (154bb55)
  • paginator: add type button to next / prev buttons (5bd655b)
  • paginator: expose MdPaginatorIntl (#5716) (93789cf), closes #5715
  • paginator: remove dependency on @angular/forms (#6080) (953b38e), closes #5717
  • paginator: underlying select vertical alignment (#6354) (0d2ea10), closes #6338
  • progress-spinner: prevent users from tabbing into underlying SVG on IE (#6142) (235f664)
  • radio: animation looking off on IE (#5620) (d263ca2)
  • radio: forward focus to native input (#6274) (cea4d9f)
  • radio-group: coerce disabled property (#5837) (23ec30f)
  • select: bigger height for underline on focus (#5510) (78f0cec), closes #5499
  • select: consistent error behavior to md-input-container (#4754) (6f73b35), closes #4611
  • select: disabled select being set to touched state on click (#5328) (6b4f9c8)
  • select: don't shift option focus when multi-select value is changed programmatically (#5401) (6422640), closes #5381
  • select: error if triggerValue is accessed from an empty select (#6575) (0526689)
  • select: floating label overlapping elements above select (#6228) (a780052), closes #6171
  • select: lint issue (#6497) (1807c5b)
  • select: required asterisk should use warn color (#5498) (97494f7), closes #5496
  • select: server-side rendering error with preselected value (#6049) (2388d91), closes #6045
  • select: set aria-multiselectable for multi-select (#6110) (ce31113)
  • select: throwing additional errors if ngModel fails to initialize (#5405) (372549c), closes #5402
  • select: wrong option amount being read out by NVDA (#5181) (b8c900c)
  • select,autocomplete: darken selected option (#6302) (504b5df), closes #6229
  • sidenav: container not reacting to changes to sidenavs added after init (#6161) (0d80a77), closes #6127
  • sidenav: first animation not working in Angular 4.2+ (#5821) (804f4c0), closes #5673
  • slide-toggle: invalid model change event (#4220) (dfe10c3), closes #4124
  • slide-toggle: slide-toggle module depends on forms module (#5523) (d716b00)
  • slider: fix change & input emit logic. (#6234) (9d3c405)
  • slider: set proper font family on label (#5772) (1cba2dc)
  • slider: slider module depends on forms module (#5578) (c14978b)
  • slider: work around slidestart event sometimes not firing on iOS (#6009) (a87a000)
  • snack-bar: align theming with spec (#6506) (363562f)
  • snackbar: make closeWithAction public method (#5686) (f4f64ac)
  • table: column class names should be css friendly (#6173) (1748397)
  • table: eliminate need for second change detection (#5775) (388494f)
  • table: Fix change det issue with http example (#6169) (4afcc0a)
  • table: set font family (#5741) (5d5ce83)
  • tabs: add module dependency on MdCommonModule (#5304) (738b6be)
  • tabs: allow for tabs to be selected using the space key (#6426) (b5f4caf), closes #6406
  • tabs: check if the subscription is defined before unsubscribe (#5667) (0eedb5f)
  • tabs: improved vertical alignment of tab label (#5771) (b105039)
  • tabs: server-side rendering error when aligning ink bar (#5455) (448db8b)
  • add camelCase ng-content selectors (#5953) (f52c7f4)
  • theming: Light green 700 contrast should be white (#6346) (b4e2488)
  • deprecate CoreModule (#6588) (377a3bb)
  • improved key manager typings (#6443) (18c6dec)
  • remove ripples in high contrast mode (#6355) (fd5e5ff)
  • textarea: server-side rendering error when using mdTextareaAutosize (#6050) (05ca4a7), closes #6047
  • theming: remove non-standard grey palette hues (#6605) (3b46360)
  • tooltip: panel element blocks hover effects (#5514) (d04230c), closes #4691
  • tooltip: remove native event listener on component destroy (#5144) (32db2ba), closes #4499
  • tooltip: remove unnecessary tooltip whitespace (#6531) (6cdbf36)
  • xxx-intl: replace misused EventEmitter with Subject (#6313) (c20bcf9)

Performance Improvements

  • observe-content: run outside Angular zone (#6352) (5ccf25d)
  • sidenav: avoid recalculating the inline styles while sidenav is open (#6189) (57a2f29)
  • table: cell references not being cleaned up on destroy (#5809) (df1ddee)
  • tabs: avoid extra resize handler and reflow (#6434) (1df79e9)

Highlights

  • This version marks the release of @angular/cdk (component dev kit)! This package contains general building blocks for UI components decoupled from the visuals of Material Design. In the initial release, code from Angular Material's core/ have been moved for a11y/, bidi/, coercion/, observe-content/, platform/, portal/. The @angular/material package now re-exports these symbols, marked as deprecated. The re-exports will be removed in a subsequent release.
  • Initial version of data-table component. There is both a <cdk-table> (the core) and the <md-table> (with Material Design styles). See the documentation on material.angular.io for more information.
  • Initial version of <md-paginator> and <md-sort-header> components, which can be used either with <md-table> or any other table.
  • Both @angular/material and @angular/cdk are now strict null compliant.

Breaking changes

  • @angular/material now depends on @angular/cdk as a peer dependency.
  • Some types have expanded to include | null or | undefined for strict null compatibility. If your application uses strict null checks, you may have to update the types in your app to match up with the more accurate types coming from Angular Material.
  • Angular Material no longer adds RxJS operators to the prototype of Observable. If your app depended on these operators being added by Angular Material, you will need to import them explicitly.

Bug Fixes

  • autocomplete: allow number zero as value (#5364) (9137fd9), closes #5363
  • autocomplete: don't scroll panel when option is visible (#4905) (d3af57d)
  • autocomplete: not closing when tapping away on mobile (#5260) (1dcaca7)
  • autocomplete: reopening when clicking an option in IE (#5172) (fe31210), closes #5165
  • autosize: resize when form value changes. Fixes #4657 (#5315) (8c9c11a)
  • button-toggle: fix standalone button toggle style (#5121) (3d8c833)
  • datepicker: pass layout direction to touchUi dialog (#5052) (8b6efb1)
  • datepicker: use theme foreground color (#5290) (51bf26e)
  • dialog: set aria-labelledby based on the md-dialog-title (#5178) (aee984a)
  • directionality: error on platform-server (#5234) (49dfe60)
  • input: theming mixin error (#5254) (37efb54), closes #5232
  • input: underline showing at end if text-align is set (#5280) (5c9391d), closes #5272
  • memory: Unsubscribe event listeners when using Observable.fromEvent (#5325) (1b351cd)
  • menu: role being set on the wrong element (#5191) (2239668)
  • overlay: remove webkit tap highlight from backdrop (#5258) (8feddd4)
  • select: align first option to trigger when it is inside a group (#5153) (d39cb12)
  • select: expose focus method (#5255) (7b2d4ae), closes #5251
  • select: md-optgroup not using typography styles (#5193) (b5bf6f5)
  • select: page scrolling down when selecting option with space (#5192) (2361385)
  • snackbar: clear timeout upon dismiss (#4860) (146160c)
  • tabs: server-side rendering error (#5348) (0174377)
  • unique-selection-dispatcher: remove listeners on destroy (#5164) (f9bbbe7)

Features

  • data-table: initial version. Too many commits to list.
  • directionality: a provider to get directionality (#4044) (61d979e), closes #3600
  • input: add custom error state matcher (#4750) (f73cc97)
  • pagination: initial pagination component (#5156) (85fb00a)
  • sort: add ability to manage and display sorting (#5307) (b328d36)
  • tab-nav-bar: support disabling tab links (#5257) (fc809ed), closes #5208
  • add support for strict null checks (#5094) (2bf7024)
  • remove uses of rxjs patch operators (#5314) (e488e3f), closes #2622
  • move a11y, bidi, platform, rxjs, and portal to cdk (#5386) (fde35e4)
  • move observe-content to cdk (#5438) (b00f838)

Highlights

  • New md-expansion-panel and md-accordion components! Documentation for these will be coming soon.
  • New typography extension to the theming API!
  • Angular Material should generally work much better with @angular/platform-server. There are still a few bugs, but things should mostly work.

Bug Fixes

  • autocomplete: handle escape key (#4703) (9e2a66c)
  • autocomplete: show hover style on selected options (#4724) (b3b6fda)
  • autocomplete: throw better error when autocomplete doesn't have a panel (#4851) (70b31f1), closes #4844
  • button: remove webkit tap highlight (#4953) (3ad80e4)
  • button-toggle: remove redundant blocking touchstart listener (#4947) (1e92545), closes #4221
  • button, tabs: potential clash with typography styles (#4915) (615fa2a)
  • checkbox: margin for empty checkboxes incorrectly added (#4730) (8d9bbbf), closes #4720
  • checkbox, radio: fix checkbox label not read in JAWS (#4610) (5c48949)
  • datepicker: focus trap not working inside popup (#4839) (157bda1)
  • datepicker: generate api docs (#4756) (be8d3b2)
  • datepicker: inert calendar arrow direction in rtl (#4960) (22f0ea0)
  • datepicker: minValidator & maxValidation false errors (#4649) (b2c3ed0)
  • datepicker: restore focus to trigger element (#4804) (8860090)
  • datepicker: switch to typography api (#4950) (7f298f7)
  • dialog: add flex wrap to style (#4846) (9d4a34a)
  • dialog: blurry content and slow animation in IE (#4809) (c8b1e20)
  • dialog: componentInstance unavailable in afterClose (#4827) (cedf219), closes #4815
  • dialog: invalid text color in dark themes (#4849) (3e993b6)
  • dialog: partial keyframes animation error (#5020) (9c45865), closes #5019
  • focus-trap: focus initial element when zone stabilizes (#4867) (ce9d253), closes #4864
  • icon: remove automatic aria labelling and add a11y guidance (#4665) (657f0e8)
  • input: correct invalid colors (#4771) (2103907)
  • input: IE always adding scrollbar to textarea (#4917) (6aaddbf)
  • input: make input spacing match spec (#4788) (16b65e8)
  • input: set aria-invalid on mdInput element (#4757) (0c03946)
  • input: remove align input binding (#5141) (0aaeb69), closes #5140
  • input, cdk: a couple of server-side rendering errors (#5066) (97e35df)
  • list: set aria attributes to md-divider (#4925) (a240c9c)
  • menu: remove classes from inert element (#4800) (93a21c7), closes #4484
  • navbar: update ink bar when links change (#4897) (41c43cc)
  • overlay: emit attach and detach at appropriate times (#4880) (e98372e), closes #4871
  • portal: detect changes for portal hostview while before attaching. (#4370) (28d2ddd)
  • radio: label vertical alignment (#5120) (d3d6d26)
  • radio: make MdRadioButton change detection strategy OnPush (#2526) (97a9bdc)
  • select: consider value changes via arrow keys on closed select as user actions (#5112) (73aa43e), closes #5084
  • select: panel in multiple mode not overlapping trigger (#4952) (638a34a), closes #4943
  • select: unable to programmatically select falsy values (#4868) (2e3910c), closes #4854
  • sidenav: don't restore focus if focus isn't inside sidenav (#4578) (3bc82f6)
  • slide-toggle: switch typography level to body-1 (#5000) (436858e)
  • snack-bar: test error in IE (#5048) (79092bd)
  • tabs: fix tab translation animation in IE 11 (#4982) (#4986) (40f92c5)
  • tooltip: not rendering in IE and Edge without web animations polyfill (#4937) (22746ce), closes #4935
  • make material work with noUnusedParameters (#4946) (4b98f21), closes #4443

Features

BREAKING CHANGES

  • input: The align input from the <md-input-container> component has been removed. Developers instead should use plain CSS to achieve the same effect (using text-align: end for example).

Bug Fixes

  • autocomplete: error when clicking outside instance without mdInput (#4573) (e6f7ace), closes #4555
  • autocomplete: restore focus to input when click on option (#4702) (eecf897), closes #4645
  • block-scroll-strategy: collapsing root node when enabled (#4638) (f11d46e)
  • button: complete ripple when button becomes disabled (#4372) (fce2868)
  • button: ripples blocking mouse events on user content (#4526) (9c4d601)
  • checkbox, radio: make disabled label disabled match spec color (#4507) (8159fcc)
  • chips: unable to tab out of chip list (#4605) (07a82ed), closes #4593
  • datepicker: calendar toggle submitting parent form (#4531) (84ea8b2), closes #4530
  • datepicker: export MD_DATE_FORMATS and MD_NATIVE_DATE_FORMATS (#4541) (58c252f), closes #4534
  • datepicker: make datepicker work in compatibility mode (#4686) (b5b762a)
  • datepicker: set cursor on clickable elements (#4542) (d2d67f5), closes #4533
  • datepicker: use default cursor on toggle when disabled (#4604) (1319355)
  • dialog: enable smooth scrolling on md-dialog-content (#4608) (3ae0dc6)
  • focus-origin: missing rxjs of operator (#4497) (05dbb90)
  • icon: handle icons as nodes (#4699) (3212411), closes #4680
  • input: continue checking for input child after initialization (#4569) (73d6814), closes #4551
  • input: thicken underline in error state, add underline animation (#4506) (0666207)
  • list-key-manager: remove handling for home and end keys (#4544) (2d16345), closes #3496
  • menu: close menu panel on escape (#4666) (210e57c), closes #3601
  • overlay: overlays potentially being rendered behind browser UI (#4664) (96549e8), closes #4650
  • platform: don't shadow window (#4622) (e8ab0da)
  • progress-bar: buffer animation not working on user-generated themes (#4525) (61f3987)
  • select: allow option with undefined or null value to clear selection (#3141) (13524c1), closes #3110 #2634
  • select: deselect old options when programmatically setting value (#4658) (db72b06)
  • select: option text color blending in with background on dark theme (#4568) (43e207c), closes #4560
  • slider: add aria-orientation (#4602) (0b5b624)
  • slider: make slider work with dark themes (#4489) (af48bb0)
  • snack-bar: remove text-transform uppercase (#4567) (82e53c5)
  • tabs: dynamic tab scrollbar showing while animating (#4524) (2a15cd7)
  • tooltip: not using trigger's text direction (#4413) (d8aeeaa), closes #4411
  • universal: gate platform checks on being on browser (#4635) (e4c7601)

Features

Bug Fixes

  • list, option: fix ripples blocking mouse events on user content (#4503) (c4b3625), closes #4480

Breaking Changes

  • MdIconModule no longer imports HttpModule. If your application depended on Http being provided through MdIconModule, you should now directly import HttpModule into your application.
  • The forRoot method on all Angular Material modules has been removed. It was previously deprecated and a no-op. Importing the modules directly will have the same effect.
  • Angular Material now requires TypeScript 2.2, which adds support for mixins.

Highlights

  • New datepicker component! This is still very new, so please try it out and file any issues you encounter on Github.
  • You can now disable Material's global sanity checks (at your own risk). These checks include whether your theme file is included, that you have a doctype, and more. See the PR here.
  • Our support for Angular Universal should be much improved! Expect further improvements in subsequent releases.

Bug Fixes

Features

Performance Improvements

  • dialog: switch dialog animations to translate3d (#3905) (857c217)

Breaking changes

Package structure

The package structure for Angular Material has changed to match that of Angular itself. This has a few ramifications on applications consuming Angular Material:

  • Deep imports will no longer work, e.g., @angular/material/core/a11y. All public symbols should be imported directly from @angular/material. Deep imports have always been an anti-pattern, but our previous package structure inadvertently allowed them.
  • The imports for theming have changed. ** For prebuilt themes, you can now find the CSS files in the prebuilt-themes/ directory in the package root. For angular-cli projects, this will look something like
@import '~@angular/material/prebuilt-themes/deeppurple-amber.css';

** For custom themes, you can now import theming.scss directly from the package root. Again, with angular-cli, this will look something like:

@import '~@angular/material/theming';

Removal of deprecated symbols

  • The deprecated, Md-prefixed aliases for LiveAnnouncer, Platform, and UniqueSelectionDispacther have been removed.

MaterialModule

  • MaterialModule (and MaterialRootModule) have been marked as deprecated.

We've found that, with the current state of tree-shaking in the world, that using an aggregate NgModule like MaterialModule leads to tools not being able to eliminate code for components that aren't used.

In order to ensure that users end up with the smallest code size possible, we're deprecating MaterialModule, to be removed in the a subsequent release.

To replace MaterialModule, users can create their own "Material" module within their application (e.g., GmailMaterialModule) that imports only the set of components actually used in the application.

Angular 4

  • Angular Material now depends on Angular 4.
  • Now that animations have been refactored into a separate package, users of @angular/material need to explicitly import BrowserAnimationsModule (or NoopAnimationsModule) from @angular/platform-browser/animations as well as installing @angular/animations.

Other changes

  • The DomProjection service was removed. This was an experimental, undocumented service that we ultimately found did not provide a good approach to composing components.
  • The config property was removed from MdDialogRef. If you were using this to access the data property, you can instead inject that value using the MD_DIALOG_DATA of the opened component.

Bug Fixes

  • autocomplete: "undefined" being displayed on empty control with ngModel (#3535) (675c9df), closes #3529
  • autocomplete: aria-expanded should be updated when panel hides (#3494) (932b4a0)
  • autocomplete: do not trigger submit on ENTER (#3727) (bedf5a1), closes #3159
  • autocomplete: fix down arrow use with ngIf (#3493) (a4e2de7)
  • autocomplete: fix key manager instantiation (#3274) (c21ff40)
  • autocomplete: not showing panel on first focus in certain cases (#3775) (75996b5)
  • autocomplete: prevent opening on load in IE (#3190) (a4da08b), closes #3183
  • autocomplete: remove max width for autocomplete panel (#3297) (738e9bf), closes #3198
  • autocomplete: update overlay ref width on menu trigger (#3573) (6915e8a)
  • button: add transition to focus overlay (#2850) (6cdd8db)
  • button: persist theme color of button when leaving hover state (#3629) (3ad6ff0)
  • button: square ripple in compatibility mode (#3167) (ceb472b), closes #3164
  • button: use FocusOriginMonitor for focus styles (#3294) (5d6920d)
  • button-toggle: fix color for selected button toggle and selected disabled button toggle (#3418) (be167c9), closes #3382
  • button-toggle: only show focus style when focused via keyboard (#3232) (d744a5f)
  • card: removed header height (#3450) (17bf5e5), closes #3288
  • card: unable to override elevation (#3139) (4ee16a9), closes #3123
  • checkbox: add focus indication (#3403) (01188d9), closes #3102
  • checkbox: create ripple on label mousedown (#3206) (3edf105), closes #3030
  • checkbox: focus origin for focus method (#3763) (7a60489)
  • checkbox: show checkbox animation only if user click or indeterminate state (#3137) (f4323b2), closes #2783
  • checkbox: switch checkbox behaviors for click and change events (#3146) (8aa9857)
  • chips: Fix adding new chips on demo page (#3426) (2d16a24)
  • compatibility: remove ink bar from compatibility check (#3267) (c203589)
  • connected-overlay: direction not being updated (#3293) (817dcfd), closes #3241
  • connected-position: error if none of the initial positions fit in viewport (#3189) (a306a8e)
  • core: log warning if doctype is missing (#2849) (22b0660), closes #2351
  • demo: remove input route from demo app (#2922) (6bac315)
  • dialog: delay focus until animation is done (#3774) (d7d2b16), closes #3722
  • dialog: leaking component instance references (#2875) (e120e8d), closes #2734
  • dialog: leaking MdDialogContainer references (#2944) (8e6720b), closes #2876
  • docs: only rewrite relative links (#3339) (cb57660), closes #3147
  • focus-trap: avoid closure compiler issues when adding anchors (#3448) (8b2ae0d)
  • focus-trap: enabled property not being coerced (#3417) (d81445b)
  • focus-trap: exception when element contains SVG on IE (#3432) (d06ad75), closes #3410
  • input: baseline alignment on textarea (#3714) (7cff349)
  • input: change dividerColor to color (#3726) (2ccf0ae)
  • input: don't add empty prefix & suffix wrappers (#3724) (6d6c12d)
  • input: don't animate label when value is set programmatically (#3691) (dc5c869)
  • input: fix blank aria-describedBy (#3713) (cb85eeb)
  • input: fix chrome autofill style (#3366) (f40b1b2)
  • input: label animation shifting sibling labels (#3568) (f8cdd92), closes #3541
  • input: make all icons in input containers the correct size (#3489) (359c9bb)
  • input: make icons in prefix/suffix the right size (#3342) (63d4359)
  • input: make sure injected NgControl belongs to the input (#3700) (220163e)
  • input: overflow-y scrollbar is displayed (IE) (#3571) (7ffaf9e), closes #3570
  • input: remove jitter that occurs on focus (#3343) (eba7641)
  • interactivity-checker: cast node name to lowercase for isInputElement function (#3281) (8f76f96)
  • list: add font-family style to subheader (#3056) (3464011)
  • list-key-manager: exception when no initial active item (#3431) (842896b), closes #3317
  • menu: incorrect text alignment in IE/Edge (#3268) (5ef3084), closes #3254
  • menu: not emitting close event when closing via the backdrop (#3300) (0f28daf), closes #3295
  • menu,tooltip: Ensure subscription exists before unsubscribing. (#3078) (84b5c3b)
  • aot runtime issues (#3807) (f40296e)
  • change selectors for MdCardXlImage and MdCardAvatar (#3134) (6e1f50b)
  • coverage issue with saucelabs (#3540) (4d4a63e)
  • select: allow custom aria-label (#3765) (038a337), closes #3762
  • deprecate MaterialModule (#3840) (3f5894e)
  • overlay: ensure proper stacking order when attaching (#3581) (aa5925b), closes #3574
  • package.json: Fix failing npm run api command (#3462) (bf2b615)
  • portal-host: unable to clear and portal reference not being set (#3302) (7fcb93b)
  • progress-spinner: not redrawing when changing modes (#3672) (1ae81a4), closes #3648
  • pseudo-checkbox: alignment issue and border color (#3144) (1f19ef0)
  • radio: add focus indication (#3402) (c934753), closes #3102
  • ripple: different durations for ripple elements (#3136) (5c7a96b), closes #3109
  • ripple: fade-out-all should hide all ripples (#3400) (5cc50d2)
  • ripple: fix ripple color in dark theme (#3094) (a91ae72)
  • ripple: rename selector for the ripple (#3482) (58c5d17)
  • scripts: change all paths in docs pushing script to relative paths (#3091) (60aa9e9)
  • scroll-dispatcher: unable to unsubscribe from global listener (#3729) (68db6ba)
  • scrollable: check if scrollable exists before unregistering (#3050) (b358c6c)
  • select: animation jump in Chrome and blurry text in IE (#3328) (09c6386), closes #3327 #1953
  • select: exception if selected value is accessed on init (#3785) (e82457c), closes #3750
  • select: initial value not being displayed with FormControl and OnPush (#3434) (819fa0b)
  • select: show focus indicator even with validation errors (#3743) (e964734), closes #3742
  • select: unable to set a tabindex (#3479) (11dec36), closes #3474
  • select: wrong item order in label in rtl (#3567) (52ea7a3)
  • sidenav: throw error when sidenav has 2 sidenavs on the same side at the same time (#3369) (324da5b)
  • sidenav: use vw instead of percentage for sidenav min width (#3046) (c638e20)
  • slide-toggle: fix unavailable unmonitor call (#3862) (904c71e)
  • slide-toggle: input not updated after drag (#3067) (5cdeb75)
  • slide-toggle: invalid change events with no new value (#3555) (5346353), closes #3526
  • slide-toggle: occasional element jumping (#3311) (beb0edf)
  • slide-toggle: remove host element margin (#3761) (cd0b853)
  • slide-toggle: ripple fade-in too slow (#3170) (369931e)
  • slider: unable to reset tickInterval after it has been set (#3488) (b9b014a), closes #3452
  • tab: use MD_RIPPLE_GLOBAL_OPTIONS in tab (#3553) (ee853b9)
  • tab-nav: add constructor back for ripple (#3537) (f27617a)
  • tabs: change color for disabled tab label (#3483) (290f710), closes #3481
  • tabs: missing mat class on tab group (#3038) (d97debe)
  • tabs: re-align ink bar on direction change (#3622) (07793a4), closes #3615
  • tabs: remove body and header from compatibility (#3168) (b939cd8)
  • tabs: remove flex; bring ink into same parent as links (#3331) (00de2d7)
  • tabs: set tab body content to 100% (#3162) (cbd1ff9), closes #3153
  • toolbar: incorrect height for soft-keyboards (#3312) (d1abc9e), closes #3233
  • tooltip: avoid capturing the initial tap on mobile (#2423) (85ba82a), closes #2326

Features

Performance Improvements

  • ripple: avoid triggering change detection (#3066) (1a67107)
  • scroll-dispatcher: avoid triggering change detection on scroll (#3687) (5c2b449)
  • scroll-dispatcher: lazily subscribe to global events (#3270) (c1004cb), closes #3237

Breaking changes from beta.1

  • Styling is no longer prefixed by md-. All styling is now prefixed by mat- so that apps can upgrade from AngularJS Material to Angular Material without styling conflicts between the two library components. See (#2790) for the details on the code change and some useful regular expressions that can help migrate styles.

  • Checkbox tab index @Input has been changed from tabindex to tabIndex. (#2953)

  • Ripple no longer has the mdRippleBackgroundColor input to change the background color. (#2859)

  • The deprecated use of <md-input> and <md-textarea> has been removed. Use mdInput on an input or textarea within a md-input-container. md-prefix and md-suffix are now mdPrefix and mdSuffix. (#2788)

    <md-input-container>
      <input mdInput name="value" ngModel>
    </md-input-container>
  • The deprecated use of <md-sidenav-layout> has been removed. Use <md-sidenav-container> instead. (#2283)

  • Input floating placeholder @Input has changed from a boolean (true and false) to a state (always, never, and auto) and was renamed from floatingPlaceholder to floatPlaceholder. For details on when to use which state, see (#2585)

  • The use of Module forRoot has been deprecated and will be removed in the next release. Instead, just simply import MaterialModule directly:

@NgModule({
    imports: [
        ...
        MaterialModule,
        ...
    ]
...
});

Bug Fixes

  • autocomplete: add mat version of autocomplete @Input (#2928) (e5521a8)
  • autocomplete: allow basic use without forms directives (#2958) (4ee2980)
  • autocomplete: close panel when options list is empty (#2834) (8a3b6fd)
  • autocomplete: double-clicking input shouldnt close the panel (#2835) (18969f4)
  • autocomplete: hide instead of close when options empty (#2997) (a022035)
  • autocomplete: placeholder should float while panel is open (#2730) (eec4dc6)
  • autocomplete: scroll options below fold into view (#2728) (6c84603)
  • autocomplete: support rtl (#2648) (4f59ad0)
  • autocomplete: up arrow should set last item active (#2776) (fd5e4d9)
  • autosize: export md-autosize directive (#2432) (f2d73da), closes #2419
  • button: add default color for mat-raised-button (#3052) (6fe1d9a)
  • button: only flat button and icon buttons should inherit the color (#2561) (ac363df), closes #2539
  • button: raised buttons in dark theme (#3070) (87ab712)
  • button: reuse _getHostElement() to avoid redundant elementRef.nativeElement calls (#2625) (c7d1c17)
  • button-toggle: add the setDisabledState from ControlValueAccessor (#2430) (fb750b4)
  • button-toggle: conflict with radio component (#2343) (9e99374), closes #2274
  • button-toggle: make conform with design specs (#2570) (fed5d7b)
  • card: fix padding for md-card-actions in xs screens (#2567) (ad0df31)
  • checkbox: Emit event when checkbox's indeterminate value changes (#2130) (f11c5eb)
  • checkbox: rename tabindex to tabIndex (#2953) (b91964a)
  • checkbox: ripple color does not change (#2857) (7ac29f8)
  • checkbox, radio: not using theme border color (#2744) (07ec765)
  • compatibility: add missing mat- selectors (#2923) (f29f7ab)
  • connected-position-strategy: wrong logic when determining whether element is on screen (#2677) (e055d05), closes #2102 #2658
  • dialog: escape key not working once element loses focus (#3082) (a08dc55), closes #3009
  • dialog: prevent error when restoring focus on IE (#2771) (153fcd3), closes #2760
  • dialog: prevent the close button from submitting forms (#2659) (29f939a), closes #2599
  • dialog: use injector from viewContainerRef if provided (#2655) (be0da09)
  • docs: properly create links in guide files (#2770) (60f03ed)
  • icon: add caching of md-icon aria-label (#2649) (08e9d70), closes #2642
  • input: add more padding so that the hint doesn't overflow the container (#2246) (d7831d9)
  • input: camel-case md-prefix and md-suffix (#2639) (7562322), closes #2636
  • input: disable underline with reactive forms (#2565) (f9dd34f), closes #2558
  • input: disabled inputs should be grayed out (#2513) (ed3ffe0)
  • input: ensure that property bindings work (#2431) (b4b4224), closes #2428
  • input: fix chrome 56 warning (#2906) (62189a3)
  • input: fix placeholder for number input with bad input. (#2362) (52aa715)
  • input: hints not being read out by screen readers (#2856) (f899b5f), closes #2798
  • input: horizontal overflow in IE and Edge (#2784) (e0fe635)
  • input: properly determine input value (#2455) (3a11927), closes #2441 #2363
  • input: remove md-input and md-textarea in favor of md-input-container (#2788) (7b30fdc)
  • input: vendor-prefix ::placeholder (#2547) (3b16648)
  • input-container: prefix and suffix stretching together with parent (#2496) (64f6d1b), closes #2493 #1881 #1421
  • input-container: reduce redundancy when forwarding the NgControl classes (#2442) (8c0eef2)
  • option: revert duplicate prop (#3051) (516720f)
  • overlay: disable pointer events if overlay is detached (#2747) (453fa7f), closes #2739
  • overlay: fix pointer events for ie11 (#3023) (597e3de), closes #3022
  • progress-bar: buffer animation not working in IE (#2941) (ab8f98f), closes #2881
  • progress-bar: unable to apply visibility in indeterminate mode and reduce CSS (#2417) (eb96b0c), closes #2413
  • progress-spinner: fix color input on md-spinner (#2396) (6cb6576), closes #2393
  • radio: change radio button trigger element to input element (#2838) (2f10a95)
  • ripple: camel-cased CSS classes (#2340) (c67f4e5)
  • ripple: make ripples conform with specs (#2859) (6381948)
  • select: avoid going into infinite loop under certain conditions (#2955) (998a583), closes #2950
  • select: don't open menu if there are no options (#2924) (cc77ef4)
  • select: fix select panel animation (#2699) (15eb33a), closes #2695
  • select: fix selection color (#2697) (4e94da4), closes #2696
  • select: selected option not being highlighted when options are added asynchronously (#2499) (7fc38b9), closes #2497
  • select: set default font size (#2976) (40bc486)
  • select: set select value to trigger height and center text (#3021) (ac9c090)
  • select: support use inside a custom value accessor (#2704) (651440f), closes #2609
  • select: transparent background when overscrolling (#2117) (d9b2d85)
  • select: trim long labels inside md-option (#2444) (416f56f), closes #2440
  • select: view not updating when using OnPush detection strategy (#2894) (3bcb7c3), closes #2663 #2269
  • select: parent align affects placeholder (#2572) (a1c90b3)
  • sidenav: animate content resizing for side mode. (#2486) (4d33449)
  • sidenav: fix animation issue for initially open sidenav (#3045) (37e4bad)
  • slide-toggle: consistent naming of aria attributes (#2688) (10bd6da)
  • slider: fire change event on value change via keyboard. (#2807) (7f50d11)
  • slider: hide ticks when slider is disabled (#2687) (e9ec8ab)
  • apply font-family to text components (#2821) (d11673a)
  • slider: make disabled state look like mocks (#2604) (8263ffb)
  • slider: make min value style match mocks (#2641) (737b608)
  • slider: round decimals in the thumb label (#2527) (987897c), closes #2511
  • snack-bar: improper button styling and improved handling of long text (#2991) (93937e6), closes #2979
  • snack-bar: prevent error when opening multiple snack bars in fast succession (#2392) (161f319), closes #2390
  • snack-bar: SimpleSnackBar not being exported (#3016) (a7a3967), closes #3010
  • tabs: crashing on chrome under certain conditions (#2411) (727ce53), closes #2151
  • tabs: fix ink not showing on chrome 57 (#3041) (f24832c)
  • tabs: infinite loop when selectedIndex is set to NaN (#2389) (f4cfc2d)
  • toolbar: add toolbar role to host element (#2914) (67032ca), closes #2909
  • toolbar: correct font-weight (#2485) (1b44880)
  • toolbar: prevent content overflow and line-wrapping (#2454) (e728771), closes #2451
  • tooltip: better handling of multi-line text (#2472) (7863e38), closes #2205
  • tooltip: not working properly with ChangeDetectionStrategy.OnPush (#2721) (632b964), closes #2713
  • tooltip: provide a maximum width (#2678) (fb5e1d4), closes #2671

Features

  • autocomplete: add autocomplete panel toggling (#2452) (d4ab3d3)
  • autocomplete: add fallback positions (#2726) (8fc7706)
  • autocomplete: add keyboard events to autocomplete (#2723) (fcea9d4)
  • autocomplete: add screenreader support (#2729) (bd7f240)
  • autocomplete: add value support (#2516) (5def001)
  • autocomplete: allow use of obj values (#2792) (55e1847)
  • button-toggle: Show selected option when md-button-toggle is disabled (#3012) (1547440), closes #3007
  • compatibility: remove conflicts with material1 css styling (#2790) (210ff02)
  • dialog: add a config option for passing in data (#2266) (29cbe61), closes #2181
  • dialog: add events (observables) for open & closeAll (#2522) (23ab152)
  • dialog: add the ability to align the content of md-dialog-actions (#2557) (e18ab5d), closes #2483
  • dialog: support open with TemplateRef (#2910) (bf0f625)
  • focus-classes: expose focus origin changes through observable (#2974) (d4ba648)
  • FocusOriginMonitor: add support for touch events (#3020) (ec7e2e4)
  • input: option to imperatively float placeholder (#2585) (fb0cf8a), closes #2466
  • list-key-manager: active descendant support (#2606) (e2ad3a0)
  • menu: Added ability to show the menu overlay around the menu trigger (#1771) (592f33f)
  • overlay: add fullscreen-enabled overlay class (#1949) (0640302)
  • screenshot: Add screenshot function to e2e test (button and checkbox) (#2532) (8ba8deb)
  • scripts: push generated docs to material assets repo (#2720) (ba12f44)
  • select: emit change event (#2458) (e5bd15c), closes #2248
  • sidenav: add disableClose option (#2501) (52ade97), closes #2462
  • slide-toggle: add support for labelPosition (#2836) (68a0c90), closes #2820
  • slider: emit input event when slider thumb moves (#2325) (99963c4), closes #2296
  • snack-bar: allow addition of extra css classes (#2804) (e783494), closes #2664
  • style: add directive to determine how elements were focused. (#2646) (8a6d902)
  • tabs: add the ability to invert the header (#2391) (a494c92), closes #2387
  • theming: provide a content wrapper attribute (#2170) (4bf4b87), closes #1938 #2106
  • tooltip: reposition on scroll (#2703) (bc52298)
  • viewport-ruler: cache document client rect (#2538) (d0c8f18)
  • add a common class to be used when dealing with selection logic (#2562) (c295fa9)
  • add simplified checkbox component for usage in other components (#2619) (3b6cab0)
  • remove the need for forRoot on material NgModules (#2556) (b49bfce)

Performance Improvements

  • tabs: reduce amount of reflows when aligning the ink bar (#2372) (dab742f)

Bug Fixes

  • Remove MdAutocompleteModule that was accidentally included in beta.0
  • Correct path to umd bundle in package.json (#2368) (d286e6d), closes #2366

Breaking changes from alpha.11

  • The svgSrc propert of <md-icon> has been removed. All SVG URLs must now be explicitly marked as trusted using Angular's DomSanitizer service.
  • The <md-input> element is deprecated in favor of <md-input-container>. This new component allows for direct access to the native input element.
  • All @Input properties have been changed to use their camelCase names for binding. The old names are still available as deprecated but will be removed in the next release.
  • All @Directive selectors are now camelCase to be consistent with Angular core. For example, [md-tooltip] is now [mdTooltip] The old selectors are still available as deprecated but will be removed in the next release.
  • <md-progress-circle> has been renamed to <md-progress-spinner>. The old selector and symbols are still available as deprecated but will be removed in the next release.
  • <md-sidenav-layout> has been renamed to <md-sidenav-container>. The old selector is still available as deprecated but will be removed in the next release.
  • Several components in core/, such as Overlay, have had their prefix changed to cdk- (short for "component dev kit"). This signifies that these are general-purpose tools for building components that are not coupled to Material Design.The old selectors are still available as deprecated but will be removed in the next release. The CSS classes have been changed.
  • The align property for md-checkbox and md-radio-button has been changed to labelPosition with values before and after.
  • MdTooltip properties are now prefixed, e.g., mdTooltipPosition, mdTooltipHideDelay, etc.

Note on HammerJS

HammerJS is now optional. It is still necessary for gestures to work within certain components, but should no longer throw an error if it is missing.

Bug Fixes

  • a11y: add all providers to forRoot (#2222) (9272b4b), closes #2189
  • add re-exports for symbols needed by Aot (#2149) (c324142)
  • icon: remove svgSrc, only allow trusted urls (#1933) (4571561)
  • input: copy input state classes to md-input-container (#2191) (f0c4148)
  • input: fix underline color to match spec (#2167) (b850fed), closes #2126
  • input: label alignment in rtl (#2047) (7b3a059), closes #2034
  • input: treat number 0 as non-empty (#2245) (a818579)
  • input: unable to focus input in IE 11 (#2233) (8ec3a19)
  • overlay: proper backdrop stacking with multiple overlays (#2276) (b16031a), closes #2272
  • platform: Remove assumption of `window' in MdPlatform (#2221) (e436775)
  • positioning: fallback positions should work while scrolled (#2193) (8df30db)
  • progress-circle, progress-bar: bind color via [color] rather than [attr.color] (#2299) (e4d2bef)
  • progress-spinner: Rename ProgressCircle to ProgressSpinner (#2300) (221c234)
  • select: clear select if no option matches value (#2110) (2855cc3), closes #2109
  • select: make invalid selector more specific (#2166) (a7c88c5)
  • sidenav: make focus-trap occupy full height of sidenav (#2145) (13223df)
  • sidenav: Rename md-sidenav-layout to md-sidenav-container. (#2183) (8f1c5a9)
  • slider: prevent thumb from getting stuck on Mobile Safari (#2142) (4adee46)
  • snack-bar: clean up element when associated viewContainer is destroyed (#2219) (db9608f), closes #2190
  • tabs: observing tab header label changes to recalculate width (#2186) (7ab4430), closes #2155
  • TSError: ? Unable to compile TypeScript when running 'gulp:build' (#2132) (714c2a4)
  • tests: snackbar ref has unnecessary observable.of (#2298) (d076bd3)
  • tooltip: add missing rxjs import (#2288) (ba7053f)

Features

  • make hammerjs optional (#2280) (28691ca)
  • chips: initial version of md-chip-list. (#2242) (f45c315) (#2046) (ba85883) (#2332) (3f2db27)
  • dialog: add dialog content elements (#2090) (cac72aa), closes #1624 #2042
  • checkbox, radio: change align to labelPosition (inverted) (#2289) (a1f9028)
  • connected-position: apply the fallback position that shows the largest area of the element (#2102) (4f5b9c5), closes #2049
  • core: add scrollable view properties to connected pos strategy (#2259) (b60d33f)
  • input: create md-input-container to eventually replace md-input (#2052) (ca2046b)
  • scroll: provide directive and service to listen to scrolling (#2188) (9b68e68)
  • sidenav: close via escape key and restore focus to trigger element (#1990) (a1331ec)
  • tooltip: add input for delaying show and hide (#2101) (e85d108)
  • toolbar add responsive heights as per spec (#2157) (78d54fc)

Performance Improvements

  • sidenav: avoid extra repaints while scrolling (#2156) (b967712)

NOTE: Be sure to delete your previous install of @angular/material and install it fresh, as npm sometimes doesn't see that there is a more recent alpha release.

Bug Fixes

  • a11y: improved accessibility in high contrast mode (#1941) (5cf7d17), closes #421 #1769
  • button: ensure icons are aligned vertically. (#1736) (d3a50b3), closes #1093
  • button: improved tap responsiveness on mobile (#1792) (4183fbc), closes #1316
  • button: remove disabled attribute when disabled value is false for MdAnchor (#1789) (716372b)
  • checkbox: fix native checked not being checked when MdCheckbox initial checked value is true (#2055) (3fd3117)
  • checkbox, input, radio, slide-toggle: implement setDisabledState from ControlValueAccessor (#1750) (77a960c), closes #1171
  • dialog: add border radius (#1872) (6aa7e22), closes #1868
  • dialog: avoid subpixel rendering issues and refactor GlobalPositionStrategy (#1962) (1ea6d34), closes #932
  • dialog: backdrop not being removed if it doesn't have transitions (#1716) (accab20), closes #1607
  • elevation: change elevations to match spec (#1857) (c2597b6)
  • interactivity-checker: improve robustness of isTabbable (#1950) (4b7e52d)
  • list: prevent list item wrapper elements from collapsing (#2075) (27f9c99), closes #2012
  • list-key-manager: prevent the default keyboard actions (#2009) (a8355e4)
  • menu: reposition menu if it would open off screen (#1761) (7572e34)
  • overlay: prevent blurry connected overlays (#1784) (303dd69)
  • overlay-directives: update offsets if they change after overlay creation (#1981) (b36db15)
  • radio: fix radio group behavior on change (#1735) (bbc5f6a)
  • ripple: Always remove ripple after a certain period (#1915) (62cc830)
  • ripple: don't create background div until ripple becomes enabled (#1849) (d7a54ef)
  • ripple: Fix the ripple position when page is scrolled (#1907) (dd508ea)
  • sidenav: resolve promise as false rather than (#1930) (7816752)
  • slider: emit change event after updating value accessor (#1901) (8caf9a6)
  • slider: support for RTL and invert (#1794) (5ac29dd)
  • spinner: animation not being cleaned up when used with AoT (#1838) (83de14f), closes #1283
  • tab-link: avoid potential memory leak (#1877) (e332f15)
  • tabs: tabs should update when tabs are added or removed (#2014) (dfc580d)
  • tooltip: check tooltip disposed on animation hidden (#1816) (9c0d82a)
  • tooltip: don't show tooltip if message is empty or not present (#2081) (2701aae), closes #2078
  • tooltip: throw a better error when an invalid position is passed (#1986) (539e44e)

Features

  • select initial version of md-select (too many commits to list)
  • textarea: add md-autosize directive (this will be more useful once the md-input refactoring is complete) (#1846) (9ec17c0)
  • tabs: paginate tab header when exceeds width (#2084) (92e26d7)
  • tabs: add ripples to the tab group and nav bar links (#1700) (b9fe75a)
  • tabs: animate tab change, include optional dynamic height (#1788) (f6944e4)
  • tabs: md-stretch-tabs (#1909) (78464a2), closes #1353
  • button-toggle: add option for vertical toggle groups (#1936) (cb0d6fc), closes #1892
  • dialog: add configurable width, height and position (#1848) (bc6cf6e), closes #1698
  • dialog: add the ability to close all dialogs (#1965) (b2999c9)
  • focus-trap: add the ability to specify a focus target (#1752) (72ac7a0), closes #1468
  • icon: added color attribute to md-icon for icon theming (#1896) (da5febc)
  • overlay: emit position change event (#1832) (b79c953)
  • overlay: support min width and min height (#2063) (a695574)
  • overlay-directives: attach and detach events (#1972) (a5eab75)
  • overlay-directives: support fallback positions (#1865) (aa472a0)
  • sidenav: emit event when backdrop is clicked (#1638) (93807ed), closes #1427
  • sidenav: focus capturing (#1695) (b9c3304)
  • slider: keyboard support (#1759) (13b7dd0)
  • slider: vertical mode (#1878) (deb940f)
  • snackbar: add onAction to snackbar ref (#1826) (a40cae9)
  • snackbar: add timeout for snackbar (#1856) (6ce6396)
  • tooltip: show tooltip on longpress; remove delay on mouseleave (#1819) (1552d70)
  • a11y: add wrap mode to key manager (#1796) (3d4abac)

Breaking Changes

  • MdSnackbarConfig no longer takes a ViewContainerRef as a contructor argument because the ViewContainerRef is now optional.

  • Tabs no longer use an md-tab-content directive. Instead, the non-label content of the tab is used as its content. Labels can also be specified via attribute, so the tabs can now be given as:

    <md-tab-group>
      <md-tab label="Overview">
        This is the overview tab
      </md-tab>
      <md-tab label="Details">
        This is the details tab
      </md-tab>
    </md-tab-group>

    You can still use md-tab-label to provide a label template.

Features

Bug Fixes

Performance Improvements

  • progress-circle: improved rendering performance (#1635) (0883fb2)

Breaking Changes

Angular Material has changed from @angular2-material/... packages to a single package under @angular/material. Along with this change, there is a new NgModule, MaterialModule, that contains all of the components. Build tools such as rollup.js can perform tree-shaking to eliminate the code for components that you aren't using.

The addition of theming as also changed the directory structure for bringing the core css into your application. See the new theming guide for more information.

Features

Bug Fixes

Breaking Changes

  • all: we've updated our packaging to match angular/angular's packaging. If you're using SystemJS in your project, you will probably want to switch to using our UMD bundles. Example config:
'@angular2-material/core': {
    format: 'cjs',
    main: 'core.umd.js'
  }

You can see a more detailed example in our demo app's system config.

In addition to this, each component now has an index.js file, so you should now have imports like

import {MdButtonModule} from '@angular2-material/button'

Instead of

import {MdButtonModule} from '@angular2-material/button/button'
  • all: material modules must be included with forRoot() when bootstrapping. See the ngModules guide for more information.
@NgModule({
    imports: [
        MdCoreModule.forRoot(),
        MdRadioModule.forRoot(),
        MdIconModule.forRoot()
    ]
...
});
  • all: material now depends on TypeScript 2.0

  • input: md-input attributes now match the casing of native attributes. Previously they were camel-cased; now they are all lowercase. Example: autoComplete is now autocomplete. See #1066 for a full list.

  • overlay: overlays are now synchronous. This means actions like creating an overlay no longer return a promise.

Bug Fixes

  • button: hover styles no longer applied to disabled buttons (#909) (21e419d), closes #866
  • button: stop using Type from @angular (#991) (97d3ed3)
  • button-toggle: toggle group should not emit an initial change event. (#1144) (e5830d1)
  • card: remove unnecessary intermediate div (#1068) (b5e1e33)
  • checkbox: export TransitionCheckState enum (#1147) (cda90f3)
  • input: make attributes match native ones (#1066) (f3a7b91), closes #1065
  • ngc: _onDragStart/End are called with one param (#1113) (6e5d260), closes #1112
  • ngc: don't emit HTMLElement in JS files (#1061) (32eacd2)
  • rc6: add directives for custom elements that are part of the APIs. (#1121) (2c0dfcb)
  • sidenav: turn off view encapsulation and refactor css (#1114) (97fe211)
  • tabs: change missed md-active to md-tab-active (#1044) (87b6193)

Features

Bug Fixes

  • checkbox: wrong cursor when disabled (#908) (5251c27), closes #907
  • checkbox, slide-toggle: only emit change event if native input emitted one. (#820) (d52e6e0), closes #575
  • gestures: custom recognizers should not inherit twice. (#902) (c68efbd)
  • gestures: ensure drag and pan are recognized with slide (#901) (3179fec)
  • input: ensure all of label displays on safari (#871) (c8303b4), closes #795
  • overlay: lazily create container (#894) (1efbbb9)
  • progress-circle: correct elapsed time calculation (#927) (0b17cd3), closes #926
  • progress-circle: remove performance.now to support non browser envs (#857) (14c1765)
  • progress-circle: remove references to window (#838) (66ddd3a), closes #837
  • radio: only emit change event if native input does. (#911) (23a61ab), closes #791
  • slide-toggle: fix runtime exception for incorrect mousedown binding. (#828) (bbbc87f), closes #828
  • fix type mismatches when offline compiling. (#835) (4bb7790)

Features

Note that NgModules are now the supported way of including the Material components in your app. The MD_XXX_DIRECTIVES constants are now deprecated and will be removed in alpha.8.

  • tooltip: initial tooltip implementation (#799) (f5e2a81)
  • md-slider: initial version for md-slider (#779) (8354750)
  • md-menu initial version for md-menu (more features coming in alpha.8) (#893) (16eb6be) (#855) (e324e47) (#867) (9a32489)
  • ripple: initial mdInkRipple implementation (#681) (47448cb)
  • button: add ripple to md-button (32aa461)
  • input: support autocapitalize and autocorrect attributes (#858) (b2471f2)
  • slide-toggle: add drag functionality to thumb (#750) (25b4f21)

In-progress, not yet released

  • dialog: add styles and ability to close. (#862) (758b851)
  • dialog: initial framework for md-dialog (#761) (9552ed5)

Code health

BREAKING CHANGES

  • radio: radio-button will no longer emit change event on de-select.

Breaking changes

  • MdRadioDispatcher is now MdUniqueSelectionDispatcher and is imported from core
  • Form controls use the new @angular/forms package. To make migration easier, you can alternatively install alpha.5-3, which is the same as alpha.6 without the new forms package. Please see the docs for the new forms module.

Bug Fixes

  • button: add the focus() method to buttons. (#643) (a6e74ce), closes #510
  • button: focus state matches spec (#467) (b24d321)
  • checkbox: checkbox animation works in Safari (#594) (0a9fb83)
  • checkbox: prevent double click events (#672) (afed818), closes #671
  • core: resolve compilation errors for latest Typescript 1.9 (#624) (e366fa0), closes #624
  • demo-app: resolve mapping paths in relative. (#566) (421828a), closes #566
  • forms: update components to new forms module (#745) (653fcee)
  • grid-list: account for gutter in total list height (#545) (b47097d)
  • input: Fix floating label width (#689) (cf2703c), closes #689 #688
  • input: placeholder text is hidden by parent visibility (#680) (b407278), closes #670
  • overlay: add a z-index. (#615) (89ab2f5)
  • progress-bar: determinate state reflects value (#542) (6b86df0), closes #519
  • radio: fix the baseline of radio buttons (#642) (31f0c7f), closes #642
  • radio: model should update before change event is fired (#456) (c923f56), closes #448
  • radio: support aria-label(ledby) on md-radio (#586) (#596) (8ccc49b)
  • release: make resource-inlining regex non-greedy (#653) (e808452)
  • sidenav: md-content now fills height (#703) (e10172c), closes #606
  • sidenav: resolve compilation errors for latest Typescript 1.9 (#627) (f7f0b4a), closes #627
  • slide-toggle: apply typography styles to slide-toggle (#634) (bbd96e8), closes #633
  • slide-toggle: stop change event firing upon init (#713) (f21b2f4), closes #709
  • spinner: omit min/max/value for indeterminate and correctly set mode (#640) (a5944da)
  • tabs: adds support for async tabs (#639) (231467d), closes #574
  • tabs: removes minimum height (#641) (750a8e3), closes #570
  • theme: fix card and list colors for dark themes (#667) (ce27341), closes #667 #350
  • toolbar: disable view encapsulation. (#678) (5c4dc04), closes #676
  • add event object for slide-toggle and checkbox. (#554) (55cc197), closes #552
  • include scss sources in packages (#536) (fd02b10)
  • remove @internal where it would make tsc fail (#538) (efd1be2)
  • remove circular deps and ci check (#608) (fda5617)
  • remove duplicated typing. TS stdlib provides enough for e2e tests (#637) (a68597e)
  • resolve errors w/ Closure Compiler. (#659) (fbdb35b), closes #659
  • visually hidden inputs should not bubble change event (#551) (d037ed3), closes #544

Features

  • grid-list: add header and footer support (43806f6)
  • overlay: add connected overlay directive (#496) (3b527e8)
  • tabs: adds focus/select events (#649) (497a3c1), closes #569
  • tabs: adds support for two-way bindings on selectedIndex (#702) (8df3246), closes #687

Performance Improvements

  • progress-circle: clean up animation on destroy (#617) (63f43bd)

Bug Fixes

  • checkbox: change event should now fire on first change(7a9df1e), closes #481
  • gestures: ensure default gestures are not overwritten by custom gestures(523929c)
  • gestures: export gesture config as part of core (#488)(0d04e01)
  • input: adds blur and focus event support (#449)(f6f5af3), closes #337
  • input: adds support for name property for input element (#452)(f53ffdb), closes #446
  • input: input element should have a different id from outer element (#450)(be5e93a), closes #320
  • input: inputs now work in IE11 (#469)(de2a9f2), closes #336
  • input: make native input background transparent (#468)(d2c6cb8), closes #277
  • input: undo firefox invalid style, fix maxlength in IE (#393)(dfe683b), closes #393 #342 #388
  • input: use the right ID for the label. (#515)(06aa3f1), closes #512
  • list: adds focus state for nav-list items (#502)(34b210c), closes #323
  • list: removes outline from focus state (#511)(91ad1c8)
  • progress-circle: support IE11 (#375)(f22fa86), closes #295
  • radio: refactor tests and fix ngModel (#443)(a25a8da), closes #443
  • radio: remove event global so radio works in node(c32b06d), closes #425
  • radio: unsetting the model will deselect all radio buttons (#441)(8af16e8), closes #327
  • sidenav: add scrolling style to enable momentum scroll(c566242)
  • sidenav: fixes sidenav RTL listening for side mode (#465)(4e1d85e), closes #465 #411
  • sidenav: removes margin transitions (#460)(4b488e1), closes #404
  • sidenav: switches to translate3d() for content positioning (#484)(357ee4c)
  • sidenav: treat opened as boolean attribute. (#444)(e977984), closes #300
  • misc: adds directive constants to all components (#514)(fb89d4f), closes #513
  • misc: correct access-level on many APIs (#437)(358af3b)
  • misc: ensure custom error messages are set(4a25b7f)

Features

  • tabs: adds the md-tab-group component (#376)(ada285c)
  • grid-list: add grid-list component(0f89b8d)
  • slide-toggle add slide-toggle component. (#362)(e09a5bf)
  • checkbox: drive component with native checkbox (#415)(10ac2be), closes #250
  • input: add focus function on host element (#407)(0323844)
  • input: add support for more input attributes (#447)(911bfae)
  • overlay: add connected position strategy (#335)(7f3b1bd)

Bug Fixes

  • button: cleaned up button theming(0672356)
  • checkbox: fix horizontal spacing between checkboxes and radio buttons(f4a7266)
  • sidenav: add min width for empty navs(dbe3cc5)
  • sidenav: prevent content from scrolling when sidenav is open(fea5923)
  • theme: new, more delightful default theme(2f3e9db)
  • update to @angular 2.0.0-rc.0 (#384)(04c8a1f)

Features

  • icon: initial md-icon implementation (#281)(a094a33)
  • card: add alignment shortcuts for md-card-actions(77be2df)
  • grid-list: basic scaffold for grid list (unreleased)(a9e1fa5)
  • list: add icon support(7b3698c)
  • sidenav: add fullscreen mode(aa6c740)

Bug Fixes

  • button: remove ref to Event global (for node) (76e4f56)
  • input: convert values entered based on the type input (e7611ce)
  • progress-circle: actually render on Firefox & Edge (#283) (d24a5b3)
  • sidenav: do not throw when there's no sidenav. (#270) (cc2b223), closes #269

Features

  • progress-bar: initial progress-bar impl. (#130) (c640f0c), closes #40
  • gestures: add basic gesture demos (d4a3cde)
  • input: add support for spellcheck attribute (#316) (dfee018)
  • list: add nav list styles (22c1ea3)
  • list: syntactic sugar for simple nav lists (c21c336)
  • a11y: live-announcer supports using a provided live element (#273) (1a33a5b), closes #267

Bug Fixes

  • button: apply color classes correctly. (62265cc), closes #75 #89 #195
  • checkbox: Cancel spacebar keydown events when component focused (6db3511), closes #162 #181
  • checkbox: Ensure consistent mixedmark rendering across browsers (666cdba), closes #174 #190
  • checkbox: Handle transition when unset checkbox is interacted with (dde9359), closes #183 #227
  • checkbox: Reduce $md-checkbox-transition-duration to 90ms (87e3a32), closes #226 #230
  • checkbox: Remove GPU layer promotion for mark elements (82a22a7)
  • sidenav: Remove deprecated @View (a61e2e9), closes #213
  • radio: export the dispatcher in radio.ts (64cc406)

Features

  • input: add new input component (74d9bc0)
  • input: README.md improvements and autofill support. (b711c2b)
  • list: add list component (fb71eb1)
  • list: add dividers to lists (915dd9b)
  • list: support subheaders in lists (0a9c169)
  • elevation: Add elevation core styles (3e34f7a), closes #222
  • button: add md-icon-button styling. (208cd65), closes #188 #206
  • overlay: add basic core of overlay (f0e1273)
  • overlay: add global position strategy (c8f87a4)
  • overlay: add overlay container & styles (74e3edf)
  • portal: add DomPortalHost (358d923)
  • radio: support ngModel on md-radio-group (6aff4cc), closes #209
  • a11y: add aria live announcer (e99da66), closes #106

Features

  • radio: Radio button component. (d76465b), closes #125

First release of angular2-material!

This inaugural release includes 6 components:

As the alpha process continues, these components will continue to evolve. There will be breaking changes between alpha releases; the alpha releases are here for people that want an early look or who like to live on the edge and are very tolerant of breaking API and behavior changes.