Skip to content

Commit

Permalink
fix(components/pages): constrain page sizing (#2832)
Browse files Browse the repository at this point in the history
  • Loading branch information
johnhwhite authored Oct 16, 2024
1 parent a5df333 commit e89fb87
Show file tree
Hide file tree
Showing 6 changed files with 55 additions and 52 deletions.
2 changes: 1 addition & 1 deletion apps/e2e/pages-storybook/src/app/app.module.ts
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@ if (routes.length > 0 && routes.findIndex((r) => r.path === '') === -1) {
bindToComponentInputs: true,
}),
],
providers: [provideInitialTheme('modern')],
providers: [provideInitialTheme('default')],
bootstrap: [AppComponent],
})
export class AppModule {}
Original file line number Diff line number Diff line change
@@ -1,19 +1,27 @@
import { provideLocationMocks } from '@angular/common/testing';
import { TestBed } from '@angular/core/testing';
import { RouterModule } from '@angular/router';
import { RouterTestingModule } from '@angular/router/testing';
import { provideRouter } from '@angular/router';
import { expect } from '@skyux-sdk/testing';
import { SkyMediaBreakpoints, SkyMediaQueryService } from '@skyux/core';
import { MockSkyMediaQueryService } from '@skyux/core/testing';

import { PageHeaderFixturesComponent } from './fixtures/page-header-fixtures.component';
import { SkyPageHeaderModule } from './page-header.module';

describe('Page header component', () => {
let mediaQueryService: MockSkyMediaQueryService;

beforeEach(() => {
mediaQueryService = new MockSkyMediaQueryService();
TestBed.configureTestingModule({
imports: [
PageHeaderFixturesComponent,
RouterModule,
SkyPageHeaderModule,
RouterTestingModule.withRoutes([]),
imports: [PageHeaderFixturesComponent, SkyPageHeaderModule],
providers: [
provideRouter([]),
provideLocationMocks(),
{
provide: SkyMediaQueryService,
useValue: mediaQueryService,
},
],
});
});
Expand All @@ -39,7 +47,7 @@ describe('Page header component', () => {
it('should render an avatar at size large when page is at a large breakpoint', () => {
const fixture = TestBed.createComponent(PageHeaderFixturesComponent);
fixture.componentInstance.showAvatar = true;
fixture.componentInstance.width = 900;
mediaQueryService.fire(SkyMediaBreakpoints.lg);
fixture.detectChanges();

const largeAvatar = fixture.nativeElement.querySelector(
Expand All @@ -52,6 +60,7 @@ describe('Page header component', () => {
it('should render an avatar at size small when page is at an xs breakpoint', () => {
const fixture = TestBed.createComponent(PageHeaderFixturesComponent);
fixture.componentInstance.showAvatar = true;
mediaQueryService.fire(SkyMediaBreakpoints.xs);
fixture.detectChanges();

const smallAvatar = fixture.nativeElement.querySelector(
Expand Down
Original file line number Diff line number Diff line change
@@ -1,58 +1,25 @@
import {
Component,
ElementRef,
Input,
OnDestroy,
OnInit,
inject,
} from '@angular/core';
import {
SkyMediaQueryService,
SkyResizeObserverMediaQueryService,
} from '@skyux/core';
import { Component, Input } from '@angular/core';

import { SkyPageLink } from '../action-hub/types/page-link';

let parentLink: SkyPageLink;

/**
* Displays page heading's contents using spacing that corresponds to the parent page's layout
*/
@Component({
selector: 'sky-page-header',
templateUrl: './page-header.component.html',
styleUrls: ['./page-header.component.scss'],
providers: [
SkyResizeObserverMediaQueryService,
{
provide: SkyMediaQueryService,
useExisting: SkyResizeObserverMediaQueryService,
},
],
})
export class SkyPageHeaderComponent implements OnInit, OnDestroy {
export class SkyPageHeaderComponent {
/**
* A link to the parent page of the current page.
*/
@Input()
public parentLink?: typeof parentLink;
public parentLink?: SkyPageLink;

/**
* The title of the current page.
*/
@Input()
public pageTitle!: string;

#elementRef = inject(ElementRef);
#mediaQueryService = inject(SkyResizeObserverMediaQueryService);

public ngOnInit(): void {
this.#mediaQueryService.observe(this.#elementRef, {
updateResponsiveClasses: true,
});
}

public ngOnDestroy(): void {
this.#mediaQueryService.unobserve();
}
public pageTitle?: string;
}
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,9 @@ import {
})
export class SkyPageContentComponent implements OnInit, OnDestroy {
#elementRef = inject(ElementRef);
#mediaQueryService = inject(SkyResizeObserverMediaQueryService);
#mediaQueryService = inject(SkyResizeObserverMediaQueryService, {
self: true,
});

public ngOnInit(): void {
this.#mediaQueryService.observe(this.#elementRef, {
Expand Down
20 changes: 19 additions & 1 deletion libs/components/pages/src/lib/modules/page/page.component.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
import {
Component,
ElementRef,
HostBinding,
Input,
OnDestroy,
Expand All @@ -10,6 +11,8 @@ import {
SkyHelpService,
SkyLayoutHostForChildArgs,
SkyLayoutHostService,
SkyMediaQueryService,
SkyResizeObserverMediaQueryService,
} from '@skyux/core';

import { Subject } from 'rxjs';
Expand All @@ -32,7 +35,15 @@ const LAYOUT_CLASS_DEFAULT = `${LAYOUT_CLASS_PREFIX}${LAYOUT_DEFAULT}`;
@Component({
selector: 'sky-page',
template: `<ng-content />`,
providers: [SkyPageThemeAdapterService, SkyLayoutHostService],
providers: [
SkyPageThemeAdapterService,
SkyLayoutHostService,
SkyResizeObserverMediaQueryService,
{
provide: SkyMediaQueryService,
useExisting: SkyResizeObserverMediaQueryService,
},
],
})
export class SkyPageComponent implements OnInit, OnDestroy {
/**
Expand Down Expand Up @@ -67,6 +78,10 @@ export class SkyPageComponent implements OnInit, OnDestroy {
#themeAdapter = inject(SkyPageThemeAdapterService);
#layoutHostSvc = inject(SkyLayoutHostService);
#helpSvc = inject(SkyHelpService, { optional: true });
readonly #elementRef = inject(ElementRef);
readonly #resizeObserverSvc = inject(SkyResizeObserverMediaQueryService, {
self: true,
});

public ngOnInit(): void {
this.#themeAdapter.addTheme();
Expand All @@ -77,10 +92,13 @@ export class SkyPageComponent implements OnInit, OnDestroy {
this.#layoutForChild = args.layout as SkyPageLayoutType;
this.#updateCssClass();
});

this.#resizeObserverSvc.observe(this.#elementRef);
}

public ngOnDestroy(): void {
this.#themeAdapter.removeTheme();
this.#resizeObserverSvc.destroy();

this.#ngUnsubscribe.next();
this.#ngUnsubscribe.complete();
Expand Down
15 changes: 11 additions & 4 deletions libs/components/theme/src/lib/styles/_layout-host.scss
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
@use 'mixins' as mixins;
@use './mixins' as mixins;
@use './variables' as variables;

// xs breakpoint
.sky-layout-host {
Expand Down Expand Up @@ -130,11 +131,17 @@
minmax(var(--sky-margin-stacked-xl), min-content)
minmax(var(--sky-margin-stacked-xl), min-content)
minmax(var(--sky-margin-stacked-xl), min-content)
1fr;
grid-template-columns: 0 auto 25%;
auto;
grid-template-columns: 0 75% 25%;

&:has(sky-page-header-avatar:not(:empty)) {
grid-template-columns: min-content auto 25%;
--sky-layout-host-header-avatar-size: calc(
120px + var(--sky-margin-inline-xl)
);
grid-template-columns:
var(--sky-layout-host-header-avatar-size)
calc(75% - var(--sky-layout-host-header-avatar-size))
25%;

h1.sky-page-header-text {
margin: 0;
Expand Down

0 comments on commit e89fb87

Please sign in to comment.