From 0517fd037a9734b7740128d48d4d0b8426dc32a3 Mon Sep 17 00:00:00 2001 From: Kristiyan Kostadinov Date: Fri, 12 Mar 2021 08:02:14 +0100 Subject: [PATCH] fix(material-experimental/mdc-select): float label on focus if there's a placeholder This is the equivalent of #19517 for the MDC-based select. Historically we've only floated the `mat-select` label if a value is selected or the panel is open, because we wouldn't otherwise have anything to show. These changes make it so that we also float it on focus, if there's `placeholder` text that can be shown. This behavior is consistent with `MatInput`. --- scripts/check-mdc-tests-config.ts | 3 --- .../mdc-select/select.spec.ts | 21 +++++++++++++++++-- .../mdc-select/select.ts | 2 +- 3 files changed, 20 insertions(+), 6 deletions(-) diff --git a/scripts/check-mdc-tests-config.ts b/scripts/check-mdc-tests-config.ts index bccb7185e851..3d8a32cb8a2b 100644 --- a/scripts/check-mdc-tests-config.ts +++ b/scripts/check-mdc-tests-config.ts @@ -140,9 +140,6 @@ export const config = { 'element is inside an ngIf' ], 'mdc-select': [ - // TODO(crisbeto): remove this exception once #22187 lands. - 'should float the label on focus if it has a placeholder', - // These tests are excluded, because they're verifying the functionality that positions // the select panel over the trigger which isn't supported in the MDC select. 'should set the width of the overlay based on a larger trigger width', diff --git a/src/material-experimental/mdc-select/select.spec.ts b/src/material-experimental/mdc-select/select.spec.ts index cc06b75dd543..b78ff66f9f82 100644 --- a/src/material-experimental/mdc-select/select.spec.ts +++ b/src/material-experimental/mdc-select/select.spec.ts @@ -2340,6 +2340,22 @@ describe('MDC-based MatSelect', () => { expect(label.classList.contains('mdc-floating-label--float-above')) .toBe(true, 'Label should be floating'); })); + + it('should float the label on focus if it has a placeholder', fakeAsync(() => { + const fixture = TestBed.createComponent(FloatLabelSelect); + fixture.detectChanges(); + expect(fixture.componentInstance.placeholder).toBeTruthy(); + + fixture.componentInstance.floatLabel = 'auto'; + fixture.detectChanges(); + + dispatchFakeEvent(fixture.nativeElement.querySelector('.mat-mdc-select'), 'focus'); + fixture.detectChanges(); + + const label = fixture.nativeElement.querySelector('.mat-mdc-form-field label'); + expect(label.classList.contains('mdc-floating-label--float-above')) + .toBe(true, 'Label should be floating'); + })); }); describe('with a sibling component that throws an error', () => { @@ -4098,7 +4114,7 @@ class BasicSelectOnPushPreselected { template: ` Select a food - + {{ food.viewValue }} @@ -4109,6 +4125,7 @@ class BasicSelectOnPushPreselected { class FloatLabelSelect { floatLabel: FloatLabelType | null = 'auto'; control = new FormControl(); + placeholder = 'Food I want to eat right now'; foods: any[] = [ { value: 'steak-0', viewValue: 'Steak' }, { value: 'pizza-1', viewValue: 'Pizza' }, @@ -4213,7 +4230,7 @@ class BasicSelectWithTheming { template: ` Select a food - + {{ food.viewValue }} diff --git a/src/material-experimental/mdc-select/select.ts b/src/material-experimental/mdc-select/select.ts index 15d1c2162a92..56c3add73428 100644 --- a/src/material-experimental/mdc-select/select.ts +++ b/src/material-experimental/mdc-select/select.ts @@ -116,7 +116,7 @@ export class MatSelect extends _MatSelectBase implements OnInit get shouldLabelFloat(): boolean { // Since the panel doesn't overlap the trigger, we // want the label to only float when there's a value. - return !this.empty; + return !this.empty || (this.focused && !!this.placeholder); } ngOnInit() {