Skip to content

Commit

Permalink
Add new banner component
Browse files Browse the repository at this point in the history
This component contains a required link and title. It can be used with a description and a background image to enhance visual appeal.

The title field is a `ReactNode` where the `<u>` (underlined) tag has a custom underline SVG placed beneath it.
  • Loading branch information
kasperbirch1 committed Jun 2, 2024
1 parent 26b6bb0 commit 2eac008
Show file tree
Hide file tree
Showing 5 changed files with 167 additions and 0 deletions.
1 change: 1 addition & 0 deletions base.scss
Original file line number Diff line number Diff line change
Expand Up @@ -142,6 +142,7 @@
@import "./src/stories/Library/opening-hours/opening-hours-skeleton";
@import "./src/stories/Library/filtered-event-list/filtered-event-list";
@import "./src/stories/Library/event-list-stacked/event-list-stacked";
@import "./src/stories/Library/banner/banner";

// Autosuggest block styling needs to be loaded before the rest of the scss for autosuggest
@import "./src/stories/Blocks/autosuggest/autosuggest";
Expand Down
3 changes: 3 additions & 0 deletions public/icons/basic/icon-underlined.svg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
53 changes: 53 additions & 0 deletions src/stories/Library/banner/Banner.stories.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,53 @@
import { ComponentStory, ComponentMeta } from "@storybook/react";
import { withDesign } from "storybook-addon-designs";
import Banner from "./Banner";
import ImageCredited from "../image-credited/ImageCredited";

export default {
title: "Library / Banner",
component: Banner,
decorators: [withDesign],
parameters: {
design: {
type: "figma",
url: "https://www.figma.com/design/Zx9GrkFA3l4ISvyZD2q0Qi/Designsystem?node-id=446-6957&t=IWAOniAbcjV2y2Hf-4",
},
},
argTypes: {
image: {
defaultValue: (
<ImageCredited
src="https://images.unsplash.com/photo-1531058020387-3be344556be6?crop=entropy&cs=tinysrgb&fit=max&fm=jpg&ixid=MnwxfDB8MXxyYW5kb218MHx8ZXZlbnR8fHx8fHwxNzAyOTEwMzE0&ixlib=rb-4.0.3&q=8
0&utm_campaign=api-credit&utm_medium=referral&utm_source=unsplash_source&w=1080"
/>
),
},
title: {
name: "Title",
defaultValue: "Hvad skal jeg <u>høre?</u>",
control: { type: "text" },
},
description: {
name: "Description",
defaultValue:
"Om du er dedikeret musiknørd eller moderat musikinteresseret, så er dette siden til dig. Her kan du finde anbefalinger, digitale musikmagasiner, nyheder, musiklitteratur og meget mere.",
control: { type: "text" },
},
},
} as ComponentMeta<typeof Banner>;

const Template: ComponentStory<typeof Banner> = (args) => <Banner {...args} />;

export const Default = Template.bind({});

export const NoImage = Template.bind({});
NoImage.args = {
title: "Title <u>uden</u> billede",
image: undefined,
};

export const NoDescription = Template.bind({});
NoDescription.args = {
title: "Banner <u>uden</u> beskrivelse",
description: undefined,
};
35 changes: 35 additions & 0 deletions src/stories/Library/banner/Banner.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
import { FC, ReactNode } from "react";
import MediaContainer from "../media-container/MediaContainer";
import { ReactComponent as ArrowLargeRight } from "../Arrows/icon-arrow-ui/icon-arrow-ui-large-right.svg";

type BannerType = {
title: string;
image?: ReactNode;
description?: string;
};

const Banner: FC<BannerType> = ({ image, title, description }) => {
return (
<a href="#" className="banner arrow__hover--right-large">
{image && (
<div className="banner-visual">
<MediaContainer media={image} />
</div>
)}
<div className="banner-content">
<h2
className="banner-content__title"
// We need to be able to replicate our WYSIWYG field in Drupal that makes it possible to underline (<u>) words.
// eslint-disable-next-line react/no-danger
dangerouslySetInnerHTML={{ __html: title }}
/>
{description && (
<p className="banner-content__description">{description}</p>
)}
<ArrowLargeRight />
</div>
</a>
);
};

export default Banner;
75 changes: 75 additions & 0 deletions src/stories/Library/banner/banner.scss
Original file line number Diff line number Diff line change
@@ -0,0 +1,75 @@
@mixin banner-height {
height: 500px;
@include media-query__medium {
height: 810px;
}
}

@mixin banner-text-margin {
margin-bottom: $s-md;
@include media-query__medium {
margin-bottom: $s-xl;
}
}

.banner {
@include layout-container($layout__max-width--large, 0);
@include banner-height;
display: grid;
grid-template-rows: 1fr auto 1fr;
text-decoration: none;
}

.banner-content {
padding: $s-xl;
max-width: 375px;
background-color: white;
grid-row: 2;
grid-column: 1;

@include media-query__medium {
padding: $s-2xl;
max-width: 575px;
margin-left: 250px;
}
}

.banner-content__title {
@include typography($typo__h1);
@include banner-text-margin;

u {
position: relative;
text-decoration: none;

&::after {
content: "";
position: absolute;
bottom: -5px;
left: 0;
width: 100%;
height: 10px;
background-size: 100% 100%;
// Underlined icon from public/icons/basic/icon-underlined.svg
background-image: url("data:image/svg+xml,%3Csvg width='101' height='7' viewBox='0 0 101 7' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1.88867 6C36.7022 -0.286878 63.0591 0.988901 99.1109 1.35819' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E%0A");
}
}
}

.banner-content__description {
@include typography($typo__body-medium);
@include banner-text-margin;
color: $color__global-grey;
}

.banner-visual {
grid-row: 1 / -1;
grid-column: 1;

// Todo: can this be done in drupal?
img {
@include banner-height;
object-fit: cover;
object-position: center;
}
}

0 comments on commit 2eac008

Please sign in to comment.