Skip to content

Commit

Permalink
feat(internet-header): expose CSS custom properties (#3200)
Browse files Browse the repository at this point in the history
Co-authored-by: Philipp Gfeller <[email protected]>
  • Loading branch information
alizedebray and gfellerph authored Jul 11, 2024
1 parent 976c111 commit cf081ce
Show file tree
Hide file tree
Showing 13 changed files with 164 additions and 15 deletions.
6 changes: 6 additions & 0 deletions .changeset/flat-gifts-report.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
---
'@swisspost/internet-header': minor
'@swisspost/design-system-documentation': minor
---

Added a new stylesheet containing `:root` CSS custom properties to facilitate implementing styles relative to the header. This will allow putting sticky content right below the header.
1 change: 1 addition & 0 deletions packages/documentation/.storybook/styles/preview.scss
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@
@use '@swisspost/design-system-styles/intranet.scss';
@use '@swisspost/design-system-styles/core.scss' as post;
@use '@swisspost/design-system-styles/mixins/utilities';
@use '@swisspost/internet-header/dist/swisspost-internet-header/swisspost-internet-header.css';
@use './components';

#storybook-root,
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
import { Meta, Canvas, Controls } from '@storybook/blocks';
import * as HeaderStories from './header-css-variables.stories';
import '../header.scss';

<Meta of={HeaderStories} />

<div className="container">
<h1>Internet Header CSS Variables</h1>
<p className="lead">When you need to implement styling relative to the header.</p>
</div>

<Canvas sourceState='shown' of={HeaderStories.Default} />

## Style Imports

To access the CSS variables for the header, you need to install an optional stylesheet into your project.
Learn more in the <a href="/?path=/docs/cfa21cbc-5f8d-4a42-8165-7f6ed20bf133--docs#css-variables">header CSS variables stylesheet documentation</a>.
Original file line number Diff line number Diff line change
@@ -0,0 +1,32 @@
import meta from '@/stories/components/internet-header/header/header.stories';
import * as HeaderStories from '@/stories/components/internet-header/header/header.stories';
import { Args } from '@storybook/web-components';
import { html } from 'lit';

export default {
...HeaderStories.default,
id: 'bfdf4e7c-37d3-40f8-a5d0-734f3e6612b5',
title: 'Components/Internet Header/Header/CSS Variables',
};

export const Default = {
render: (args: Args, context: any) => {
return html`
<style>
#my-div {
z-index: 1000;
top: 0;
transition: var(--post-header-slide-in-transition);
}
swisspost-internet-header.scrolling-up + #my-div {
top: var(--post-header-height);
}
</style>
${meta.render && meta.render(args, context)}
<p id="my-div" class="position-sticky bg-nightblue p-regular">
I am sticky! I am always positioned right below the header when you scroll up and down.
</p>
`;
},
};
Original file line number Diff line number Diff line change
Expand Up @@ -21,9 +21,11 @@ import { SourceDarkMode } from '@/../.storybook/preview';
The header for client-facing applications.

<ul>
<li><a href="#configuration" target="_self">Configuration</a></li>
<li><a href="#preparation" target="_self">Preparation</a></li>
<li><a href="#installation" target="_self">Installation</a></li>
<li><a href="#migration-from-the-old-header" target="_self">Migration Guide</a></li>
<li><a href="#css-variables" target="_self">CSS Variables</a></li>
<li><a href="#usage-with-angular" target="_self">Usage with Angular</a></li>
<li><a href="#migration-from-the-old-header" target="_self">Migration from the old header</a></li>
</ul>

## Preparation
Expand Down Expand Up @@ -99,6 +101,22 @@ Available CDNs:
</PostTabPanel>
</PostTabs>

## CSS Variables

The internet header package provides a stylesheet aimed at facilitating the use of key CSS variables beyond the header itself.
This stylesheet allows you to access CSS variables to implement styling relative to the header as needed, but it is completely optional.

<PostTabs>
<PostTabHeader slot="tabs" panel="sass-import">Sass Import</PostTabHeader>
<PostTabPanel name="sass-import">
<Source code={`@use "@swisspost/internet-header/dist/siwsspost-internet-header/siwsspost-internet-header.css";`} dark={SourceDarkMode} language="scss" />
</PostTabPanel>
<PostTabHeader slot="tabs" panel="html-import">HTML Import</PostTabHeader>
<PostTabPanel name="html-import">
<Source code={`<link rel="stylesheet" href="@swisspost/internet-header/dist/siwsspost-internet-header/siwsspost-internet-header.css"/>`} dark={SourceDarkMode} language="html" />
</PostTabPanel>
</PostTabs>

## Usage with Angular

For Angular user, please have a look at [How to integrate Web Components inside Angular](/?path=/docs/8426deb2-3d6d-4fcc-90e6-1ca9737b2ed0--docs#usage-of-web-components)
Expand Down
2 changes: 1 addition & 1 deletion packages/internet-header/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@
"loader/"
],
"scripts": {
"dev": "stencil build --serve --port 9310 --watch --docs-readme --dev",
"dev": "stencil build --serve --port 9310 --watch --docs-readme --dev --config stencil.config.dev.ts",
"start": "stencil build --watch --docs-readme",
"build": "stencil build --docs-readme",
"clean": "rimraf www dist loader",
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@
@use '@swisspost/design-system-styles/placeholders/color' as color-ph;
@use '../../utils/utils.scss';
@use '../../utils/mixins.scss';
@use '../../utils/variables.scss';
@use './logo-animation/logo-animation.scss';

:host {
Expand All @@ -13,18 +14,10 @@
font-weight: 300;
z-index: var(--header-z-index, 10);

--header-height: 3.5rem; // 56px
--meta-header-height: 0px; // Not visible on mobile
--language-dropdown-margin-top: 0px;

@include mixins.min(lg) {
--meta-header-height: 3rem; // 48px
--header-height: 4rem; // 64px
}

@include mixins.min(xl) {
--header-height: 4.5rem; // 72px
}
@include mixins.set-custom-property(--meta-header-height, variables.$meta-header-height);
@include mixins.set-custom-property(--header-height, variables.$header-height);
}

// Set height to 0 if meta is never visible
Expand Down Expand Up @@ -62,7 +55,9 @@
:host(.stickyness-minimal.scrolling-up),
:host(.stickyness-minimal.dropdown-open) {
top: calc(var(--meta-header-height, 0px) * -1);
transition: top 200ms ease-out;

@include mixins.set-custom-property(--header-slide-in-transition, variables.$header-slide-in-transition);
transition: var(--header-slide-in-transition);
}
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -223,6 +223,12 @@ export class PostInternetHeader {
this.host.classList.add('header-loaded');
if (this.meta && this.metaNav) {
this.updateLogoAnimation = registerLogoAnimationObserver(this.metaNav, this.host);
} else {
// Set height to 0 if meta is never visible and global variables are defined
const rootStyles = window.getComputedStyle(document.documentElement);
if (rootStyles.getPropertyValue('--post-meta-header-height') !== '') {
document.documentElement.style.setProperty('--post-meta-header-height', '0px');
}
}
});

Expand Down
8 changes: 8 additions & 0 deletions packages/internet-header/src/root.scss
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
@use 'utils/mixins';
@use 'utils/variables';

:root {
@include mixins.set-custom-property(--post-meta-header-height, variables.$meta-header-height);
@include mixins.set-custom-property(--post-header-height, variables.$header-height);
@include mixins.set-custom-property(--post-header-slide-in-transition, variables.$header-slide-in-transition);
}
32 changes: 32 additions & 0 deletions packages/internet-header/src/utils/mixins.scss
Original file line number Diff line number Diff line change
@@ -1,4 +1,6 @@
@use "sass:map";
@use 'sass:selector';
@use 'sass:string';
@use "@swisspost/design-system-styles/variables/breakpoints";

@mixin min($point) {
Expand Down Expand Up @@ -45,3 +47,33 @@
padding-left: 40px;
}
}

@mixin set-custom-property($var, $value) {
@if (type-of($value) == 'map') {
@include _responsive-custom-property($var, $value);
} @else {
@include _custom-property($var, $value);
}
}

@mixin _responsive-custom-property($var, $values) {
$previous-value: null;
@each $breakpoint, $value in $values {
@if($value == $previous-value) {
// no styles
} @else if($breakpoint == xs) {
@include _custom-property($var, $value);
} @else {
@include min($breakpoint) {
@include _custom-property($var, $value);
}
}

$previous-value: $value;
}
}

@mixin _custom-property($var, $value) {
$is-root: selector.is-superselector(&, ':root');
#{$var}: if($is-root, $value, var(#{string.insert($var, "post-", 3)}, $value));
}
21 changes: 21 additions & 0 deletions packages/internet-header/src/utils/variables.scss
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
$meta-header-height: (
xs: 0px,
sm: 0px,
rg: 0px,
md: 0px,
lg: 3rem,
xl: 3rem,
xxl: 3rem,
);

$header-height: (
xs: 3.5rem,
sm: 3.5rem,
rg: 3.5rem,
md: 3.5rem,
lg: 4rem,
xl: 4.5rem,
xxl: 4.5rem,
);

$header-slide-in-transition: top 200ms ease-out;
13 changes: 13 additions & 0 deletions packages/internet-header/stencil.config.dev.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
import { Config } from '@stencil/core';
import { sass } from '@stencil/sass';
import { config as prodConfig } from './stencil.config';

export const config: Config = {
...prodConfig,
globalStyle: 'src/styles.scss',
plugins: [
sass({
includePaths: ['node_modules'],
}),
],
};
2 changes: 1 addition & 1 deletion packages/internet-header/stencil.config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ import scss from 'rollup-plugin-scss';

export const config: Config = {
namespace: 'swisspost-internet-header',
globalStyle: 'src/styles.scss',
globalStyle: 'src/root.scss',
buildEs5: 'prod',
sourceMap: false,
bundles: [
Expand Down

0 comments on commit cf081ce

Please sign in to comment.