Skip to content
This repository has been archived by the owner on Jan 6, 2025. It is now read-only.

Commit

Permalink
fix(show-hide): use initial value as fallback isntead of parent
Browse files Browse the repository at this point in the history
When SSR creates media screen styles, it sets the default `display`
CSS property to `parent.display`. However, if the parent has its
`display` property unset, it results in an empty display that breaks
the correct functionality as the next closest match is made.

This is fixed by setting `display` to `initial` as default instead
of an empty value.

Credit to @vmasek

Fixes #1163
  • Loading branch information
CaerusKaru committed May 8, 2020
1 parent e8ded3e commit e4bb7ef
Show file tree
Hide file tree
Showing 2 changed files with 11 additions and 25 deletions.
2 changes: 1 addition & 1 deletion src/lib/extended/show-hide/show-hide.ts
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,7 @@ export interface ShowHideParent {
export class ShowHideStyleBuilder extends StyleBuilder {
buildStyles(show: string, parent: ShowHideParent) {
const shouldShow = show === 'true';
return {'display': shouldShow ? parent.display : 'none'};
return {'display': shouldShow ? parent.display || 'initial' : 'none'};
}
}

Expand Down
34 changes: 10 additions & 24 deletions src/lib/extended/show-hide/show.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,8 +5,8 @@
* Use of this source code is governed by an MIT-style license that can be
* found in the LICENSE file at https://angular.io/license
*/
import {Component, Directive, OnInit, PLATFORM_ID} from '@angular/core';
import {CommonModule, isPlatformBrowser} from '@angular/common';
import {Component, Directive, OnInit} from '@angular/core';
import {CommonModule} from '@angular/common';
import {ComponentFixture, TestBed, inject} from '@angular/core/testing';
import {
ɵMatchMedia as MatchMedia,
Expand Down Expand Up @@ -35,17 +35,15 @@ describe('show directive', () => {
let fixture: ComponentFixture<any>;
let mediaController: MockMatchMedia;
let styler: StyleUtils;
let platformId: Object;
let createTestComponent = (template: string) => {
fixture = makeCreateTestComponent(() => TestShowComponent)(template);

// Can only Inject() AFTER TestBed.override(...)
inject(
[MatchMedia, StyleUtils, PLATFORM_ID],
(_matchMedia: MockMatchMedia, _styler: StyleUtils, _platformId: Object) => {
[MatchMedia, StyleUtils],
(_matchMedia: MockMatchMedia, _styler: StyleUtils) => {
mediaController = _matchMedia;
styler = _styler;
platformId = _platformId;
})();

return fixture;
Expand Down Expand Up @@ -294,15 +292,9 @@ describe('show directive', () => {
fixture.detectChanges();

// NOTE: platform-server can't compute display for unknown elements
if (isPlatformBrowser(platformId)) {
expectEl(queryFor(fixture, elSelector)[0]).toHaveCSS({
'display': 'inline'
}, styler);
} else {
expectEl(queryFor(fixture, elSelector)[0]).not.toHaveStyle({
'display': '*'
}, styler);
}
expectEl(queryFor(fixture, elSelector)[0]).toHaveCSS({
'display': 'initial'
}, styler);

mediaController.activate('xs');
fixture.detectChanges();
Expand All @@ -313,15 +305,9 @@ describe('show directive', () => {
mediaController.activate('lg');
fixture.detectChanges();
// NOTE: platform-server can't compute display for unknown elements
if (isPlatformBrowser(platformId)) {
expectEl(queryFor(fixture, elSelector)[0]).toHaveCSS({
'display': 'inline'
}, styler);
} else {
expectEl(queryFor(fixture, elSelector)[0]).not.toHaveStyle({
'display': '*'
}, styler);
}
expectEl(queryFor(fixture, elSelector)[0]).toHaveCSS({
'display': 'initial'
}, styler);
});
});

Expand Down

0 comments on commit e4bb7ef

Please sign in to comment.