Skip to content

Commit

Permalink
Updates to headers alignment
Browse files Browse the repository at this point in the history
  • Loading branch information
Fercas123 committed Dec 16, 2024
1 parent 3d87e17 commit 74d9d3a
Show file tree
Hide file tree
Showing 9 changed files with 69 additions and 20 deletions.
5 changes: 5 additions & 0 deletions .changeset/poor-scissors-chew.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
"@salt-ds/lab": patch
---

fix alignment for titles spanning into multiple lines, wrap labs dialog header in H2 to avoid breaking change
1 change: 1 addition & 0 deletions packages/core/src/dialog/DialogHeader.css
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@
/* Styles applied to the status indicator icon overriding its default size */
.saltDialogHeader .saltStatusIndicator.saltIcon {
--icon-size: var(--salt-text-h2-lineHeight);
padding-top: calc((var(--salt-size-base) - var(--salt-text-h2-lineHeight)) / 2);
}

/* Styles applied to DialogHeader when accent={true} */
Expand Down
4 changes: 3 additions & 1 deletion packages/lab/src/dialog/DialogHeader.css
Original file line number Diff line number Diff line change
Expand Up @@ -3,12 +3,14 @@
padding-bottom: var(--salt-spacing-300);
padding-left: var(--salt-spacing-300);
padding-right: var(--salt-spacing-300);
align-items: center;
display: flex;
flex-direction: row;
gap: var(--salt-spacing-100);
box-sizing: border-box;
}
.saltDialogHeader-header {
margin: 0;
}

.saltDialogHeader-container {
flex-grow: 1;
Expand Down
3 changes: 2 additions & 1 deletion packages/lab/src/dialog/DialogHeader.tsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import {
H2,
StatusIndicator,
Text,
type ValidationStatus,
Expand Down Expand Up @@ -86,7 +87,7 @@ export const DialogHeader = forwardRef<HTMLDivElement, DialogHeaderProps>(
{preheader && (
<Text className={withBaseName("preheader")}>{preheader}</Text>
)}
{header}
<H2 className={withBaseName("header")}>{header}</H2>
</div>
{description && (
<Text color="secondary" className={withBaseName("description")}>
Expand Down
1 change: 0 additions & 1 deletion packages/lab/src/overlay/OverlayHeader.css
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
.saltOverlayHeader {
padding: var(--salt-spacing-100);
width: 100%;
align-items: center;
display: flex;
flex-direction: row;
justify-content: stretch;
Expand Down
28 changes: 18 additions & 10 deletions packages/lab/stories/dialog/dialog.qa.stories.tsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import { Dialog, H2 } from "@salt-ds/core";
import { Button, Dialog } from "@salt-ds/core";
import { CloseIcon } from "@salt-ds/icons";
import { DialogHeader } from "@salt-ds/lab";
import type { Meta, StoryFn } from "@storybook/react";
import { QAContainer, type QAContainerProps } from "docs/components";
Expand All @@ -11,7 +12,7 @@ export default {
export const DialogHeaders: StoryFn<QAContainerProps> = () => (
<QAContainer height={600} cols={1} itemPadding={5} width={1200}>
<DialogHeader
header={<H2>Terms and conditions</H2>}
header="Terms and conditions"
style={{
width: 600,
}}
Expand All @@ -20,40 +21,47 @@ export const DialogHeaders: StoryFn<QAContainerProps> = () => (
style={{
width: 600,
}}
header={<H2>Terms and conditions</H2>}
header="Terms and conditions"
preheader="Ensure you read and agree to these Terms"
/>
<DialogHeader
style={{
width: 600,
}}
header={<H2>Terms and conditions</H2>}
header="Terms and conditions"
preheader="Ensure you read and agree to these Terms"
description="Effective date: August 29, 2024"
/>
<DialogHeader
status="info"
header={<H2>Terms and conditions</H2>}
header="Terms and conditions"
style={{
width: 600,
}}
/>
<DialogHeader
actions={
<Button aria-label="Close dialog" appearance="transparent">
<CloseIcon aria-hidden />
</Button>
}
status="info"
style={{
width: 600,
}}
header={<H2>Terms and conditions</H2>}
preheader="Ensure you read and agree to these Terms"
header="Terms and conditions"
/>
<DialogHeader
actions={
<Button aria-label="Close dialog" appearance="transparent">
<CloseIcon aria-hidden />
</Button>
}
status="info"
style={{
width: 600,
}}
header={<H2>Terms and conditions</H2>}
preheader="Ensure you read and agree to these Terms"
description="Effective date: August 29, 2024"
header="Complete terms and conditions for using the services provided by our company"
/>
</QAContainer>
);
Expand Down
6 changes: 6 additions & 0 deletions packages/lab/stories/dialog/dialog.stories.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -145,6 +145,12 @@ export const Default = DialogTemplate.bind({});
Default.args = {
id: "Default",
};
export const LongTitle = DialogTemplate.bind({});
Default.args = {
id: "LongTitle",
header:
"Complete terms and conditions for using the services provided by our company",
};

const AlertDialogTemplate: StoryFn<
DialogProps & { header: ReactNode; content: ReactNode }
Expand Down
12 changes: 8 additions & 4 deletions packages/lab/stories/overlay/overlay.qa.stories.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -29,8 +29,8 @@ export const Default: StoryFn<QAContainerProps> = (props) => {
return (
<QAContainer
height={800}
cols={5}
itemPadding={50}
cols={1}
itemPadding={80}
itemWidthAuto
width={1200}
{...props}
Expand All @@ -39,11 +39,15 @@ export const Default: StoryFn<QAContainerProps> = (props) => {
<OverlayTrigger>
<Button>Show Overlay</Button>
</OverlayTrigger>
<OverlayPanel>
<OverlayPanel
style={{
width: "30ch",
}}
>
<OverlayHeader
preheader="Preheader"
description="Description"
header={<H4>Header block</H4>}
header={<H4>Guidelines for optimal use of our application</H4>}
actions={<CloseButton />}
/>
<OverlayPanelContent>
Expand Down
29 changes: 26 additions & 3 deletions packages/lab/stories/overlay/overlay.stories.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -13,14 +13,14 @@ import {
} from "@salt-ds/core";
import { CloseIcon } from "@salt-ds/icons";
import { OverlayHeader } from "@salt-ds/lab";
import type { Meta } from "@storybook/react";
import type { Meta, StoryFn } from "@storybook/react";
import { useState } from "react";

export default {
title: "Lab/Overlay Header",
} as Meta<typeof Overlay>;

export const Header = ({ onOpenChange }: OverlayProps) => {
const HeaderTemplate: StoryFn = ({ onOpenChange, ...props }: OverlayProps) => {
const [open, setOpen] = useState(false);
const id = useId();

Expand All @@ -40,7 +40,7 @@ export const Header = ({ onOpenChange }: OverlayProps) => {
width: 500,
}}
>
<OverlayHeader header={<H4 id={id}>Header block</H4>} />
<OverlayHeader header={<H4 id={id}>Header block</H4>} {...props} />
<OverlayPanelContent>
<StackLayout gap={1}>
<Text>
Expand All @@ -62,6 +62,29 @@ export const Header = ({ onOpenChange }: OverlayProps) => {
);
};

export const Header = HeaderTemplate.bind({});
Header.args = {};

export const LongHeader = HeaderTemplate.bind({});
LongHeader.args = {
header: (
<H4>
Comprehensive guidelines and detailed instructions for the optimal use and
application of our services to ensure maximum efficiency and user
satisfaction
</H4>
),
actions: (
<Button
aria-label="Close overlay"
appearance="transparent"
sentiment="neutral"
>
<CloseIcon aria-hidden />
</Button>
),
};

export const HeaderWithCloseButton = ({ onOpenChange }: OverlayProps) => {
const [open, setOpen] = useState(false);
const id = useId();
Expand Down

0 comments on commit 74d9d3a

Please sign in to comment.