Skip to content

Commit

Permalink
feat: add helpText to the Sidebar
Browse files Browse the repository at this point in the history
  • Loading branch information
haideralsh committed Oct 31, 2023
1 parent f17c118 commit c9d6e77
Show file tree
Hide file tree
Showing 2 changed files with 77 additions and 18 deletions.
42 changes: 42 additions & 0 deletions src/Layout/Sidebar.story.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,9 @@ import {
Select,
PrimaryButton,
Box,
Textarea,
Text,
Flex,
} from "..";

const primaryMenu = [
Expand Down Expand Up @@ -439,3 +442,42 @@ export const WithDifferentWidths = () => {
</Sidebar>
);
};

export const WithHelpText = () => {
const [helpText, setHelpText] = useState(
"Lorem ipsum dolor sit amet, consectetur adipiscing elit. Phasellus tempor lacus nec finibus egestas."
);

return (
<Sidebar hideCloseButton top={0} height="100%" isOpen title="With help text" helpText={helpText}>
<Textarea
value={helpText}
labelText="Help Text"
placeholder="Enter some text..."
onChange={(event) => {
setHelpText(event.target.value);
}}
/>
</Sidebar>
);
};

export const WithARenderedHelpText = () => {
return (
<Sidebar
hideCloseButton
top={0}
height="100%"
isOpen
title="With help text"
renderHelpText={() => (
<Text color="red" fontWeight="bold">
This is a custom Text{" "}
<Link href="/" underline={false}>
Learn more
</Link>
</Text>
)}
></Sidebar>
);
};
53 changes: 35 additions & 18 deletions src/Layout/Sidebar.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -4,10 +4,11 @@ import { useTranslation } from "react-i18next";
import { Box } from "../Box";
import { Flex } from "../Flex";
import { IconicButton } from "../Button";
import { Heading3 } from "../Type";
import { Heading3, Text } from "../Type";
import { AnimatedBoxProps, AnimatedBox } from "../Box/Box";
import { NAVBAR_HEIGHT } from "../BrandedNavBar/NavBar";
import { PreventBodyElementScrolling } from "../utils";
import { Divider } from "../Divider";

type PredefinedSidebarWidth = "xs" | "s" | "m" | "l" | "xl";

Expand Down Expand Up @@ -41,6 +42,8 @@ type SidebarProps = Omit<AnimatedBoxProps, "width"> & {
disableScroll?: boolean;
hideCloseButton?: boolean;
width?: SidebarWidth;
helpText?: string;
renderHelpText?: () => React.ReactNode;
};

const focusFirstElement = () => {
Expand Down Expand Up @@ -87,6 +90,8 @@ function Sidebar({
disableScroll = true,
hideCloseButton = false,
zIndex = "sidebar" as any,
helpText,
renderHelpText,
...props
}: SidebarProps) {
const closeButton = useRef(null);
Expand Down Expand Up @@ -191,24 +196,36 @@ function Sidebar({
flexDirection="column"
style={{ overflowBehaviour: "contain" } as any}
>
<Flex justifyContent="space-between" alignItems="flex-start" pb="x3">
{title && (
<Flex alignItems="center" height="100%">
<Heading3 mb={0}>{title}</Heading3>
<Flex flexDirection="column" pb="x3">
<Flex flexDirection="column" pb="x2">
<Flex justifyContent="space-between" alignItems="flex-start">
{title && (
<Flex alignItems="center" height="100%">
<Heading3 mb={0}>{title}</Heading3>
</Flex>
)}
{!hideCloseButton && (
<Box marginLeft="x2">
<IconicButton
type="button"
ref={closeButton}
icon="close"
onClick={onClose}
data-testid={closeButtonTestId}
aria-label={closeButtonAriaLabel || t("close")}
/>
</Box>
)}
</Flex>
)}
{!hideCloseButton && (
<Box marginLeft="x2">
<IconicButton
type="button"
ref={closeButton}
icon="close"
onClick={onClose}
data-testid={closeButtonTestId}
aria-label={closeButtonAriaLabel || t("close")}
/>
</Box>
)}
{renderHelpText
? renderHelpText()
: helpText && (
<Text pt="x1" color="midGrey">
{helpText}
</Text>
)}
</Flex>
<Divider margin={0} width="100%" />
</Flex>
<AnimatedBox
variants={childVariants}
Expand Down

0 comments on commit c9d6e77

Please sign in to comment.