Skip to content

Commit

Permalink
Merge pull request #1203 from securityscorecard/ajkl2533@UXD-1675
Browse files Browse the repository at this point in the history
feat(Modal): add new XL size UXD-1675
  • Loading branch information
ajkl2533 authored Nov 26, 2024
2 parents f00391a + e039f44 commit 0ed4061
Show file tree
Hide file tree
Showing 14 changed files with 129 additions and 107 deletions.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
1 change: 1 addition & 0 deletions src/components/Modal/Modal.enums.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,4 +3,5 @@ export const ModalSizes = {
sm: 'sm',
md: 'md',
lg: 'lg',
xl: 'xl',
} as const;
225 changes: 120 additions & 105 deletions src/components/Modal/Modal.stories.tsx
Original file line number Diff line number Diff line change
@@ -1,19 +1,15 @@
import { useState } from 'react';
import { Meta, StoryFn } from '@storybook/react';
import type { Meta, StoryObj } from '@storybook/react';
import { action } from '@storybook/addon-actions';

import Modal from './Modal';
import { ModalProps } from './Modal.types';
import { ModalSizes } from './Modal.enums';
import { H5 } from '../Heading';
import { Paragraph } from '../Paragraph';
import { Inline, Padbox } from '../layout';
import { Button } from '../Button';
import { generateControl } from '../../utils/tests/storybook';
import { SpaceSizes } from '../../index';
import { Tooltip } from '../Tooltip';

export default {
const meta = {
title: 'components/modals/Modal',
component: Modal,
parameters: {
Expand All @@ -24,124 +20,143 @@ export default {
},
argTypes: {
size: {
...generateControl('select', ModalSizes),
options: ['xs', 'sm', 'md', 'lg', 'xl'],
},
footer: {
control: { disable: true },
},
},
} as Meta;
} satisfies Meta<typeof Modal>;

export default meta;

type Story = StoryObj<typeof meta>;

function Footer() {
return (
<Inline gap={SpaceSizes.md} justify="flex-end">
<Inline gap="4x" justify="flex-end">
<Button variant="outline">Cancel</Button>
<Button>Confirm</Button>
</Inline>
);
}

export const Playground: StoryFn<ModalProps> = (args) => {
const [isShown, setIsShown] = useState(false);
export const Playground: Story = {
render: function Render(args) {
const [isShown, setIsShown] = useState(false);

return (
<Padbox paddingSize={SpaceSizes.xxl}>
<Inline justify="center">
<Button onClick={() => setIsShown(!isShown)}>Open modal</Button>
{isShown && (
<Modal
footer={<Footer />}
title="Title"
onClose={() => setIsShown(false)}
{...args}
>
<H5 style={{ margin: 0 }}>This is a placeholder</H5>
<Paragraph size="md" style={{ marginBottom: 0 }}>
You can replace this with a local component. You can also just
override the text, but{' '}
<Tooltip popup="I'm tooltip">keep in mind</Tooltip> that you might
lose content that way in case we happend to change the underlying
component. Lorem ipsum dolor sit amet, consectetur adipiscing
elit, sed do eiusmod tempor incididunt ut labore et dolore magna
aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco
laboris nisi ut aliquip ex ea commodo consequat.
</Paragraph>
</Modal>
)}
</Inline>
</Padbox>
);
return (
<Padbox paddingSize="32x">
<Inline justify="center">
<Button onClick={() => setIsShown(!isShown)}>Open modal</Button>
{isShown && <Modal {...args} onClose={() => setIsShown(false)} />}
</Inline>
</Padbox>
);
},
args: {
footer: <Footer />,
title: 'Title',
children: (
<>
<H5 style={{ margin: 0 }}>This is a placeholder</H5>
<Paragraph size="md" style={{ marginBottom: 0 }}>
You can replace this with a local component. You can also just
override the text, but{' '}
<Tooltip popup="I'm tooltip">keep in mind</Tooltip> that you might
lose content that way in case we happend to change the underlying
component. Lorem ipsum dolor sit amet, consectetur adipiscing elit,
sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut
enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi
ut aliquip ex ea commodo consequat.
</Paragraph>
</>
),
onClose: action('close-modal'),
},
parameters: {
screenshot: { skip: true },
},
};

Playground.parameters = {
screenshot: { skip: true },
export const WithTitle: Story = {
args: Playground.args,
};

export const WithTitle: StoryFn = () => (
<Modal footer={<Footer />} title="Title" onClose={action('close-modal')}>
<H5 style={{ margin: 0 }}>This is a placeholder</H5>
<Paragraph size="md" style={{ marginBottom: 0 }}>
You can replace this with a local component. You can also just override
the text, but keep in mind that you might lose content that way in case we
happend to change the underlying component. Lorem ipsum dolor sit amet,
consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et
dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation
ullamco laboris nisi ut aliquip ex ea commodo consequat.
</Paragraph>
</Modal>
);
export const WithLongContent: Story = {
args: {
...Playground.args,
children: (
<>
<H5 style={{ margin: 0 }}>This is a placeholder</H5>
<Paragraph size="md" style={{ marginBottom: 0 }}>
You can replace this with a local component. You can also just
override the text, but keep in mind that you might lose content that
way in case we happend to change the underlying component. Lorem ipsum
dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor
incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam,
quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea
commodo consequat. Lorem ipsum dolor sit amet, consectetur adipiscing
elit, sed do eiusmod tempor incididunt ut labore et dolore magna
aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco
laboris nisi ut aliquip ex ea commodo consequat. Lorem ipsum dolor sit
amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut
labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud
exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do
eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad
minim veniam, quis nostrud exercitation ullamco laboris nisi ut
aliquip ex ea commodo consequat. Lorem ipsum dolor sit amet,
consectetur adipiscing elit, sed do eiusmod tempor incididunt ut
labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud
exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.
</Paragraph>
</>
),
},
};

export const WithLongContent: StoryFn = () => (
<Modal footer={<Footer />} title="Title" onClose={action('close-modal')}>
<H5 style={{ margin: 0 }}>This is a placeholder</H5>
<Paragraph size="md" style={{ marginBottom: 0 }}>
You can replace this with a local component. You can also just override
the text, but keep in mind that you might lose content that way in case we
happend to change the underlying component. Lorem ipsum dolor sit amet,
consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et
dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation
ullamco laboris nisi ut aliquip ex ea commodo consequat. Lorem ipsum dolor
sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut
labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud
exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod
tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim
veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea
commodo consequat. Lorem ipsum dolor sit amet, consectetur adipiscing
elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.
Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut
aliquip ex ea commodo consequat. Lorem ipsum dolor sit amet, consectetur
adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore
magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco
laboris nisi ut aliquip ex ea commodo consequat.
</Paragraph>
</Modal>
);
export const WithoutTitle: Story = {
args: {
...Playground.args,
title: undefined,
},
};

export const WithoutTitle: StoryFn = () => (
<Modal footer={<Footer />} onClose={action('close-modal')}>
<H5 style={{ margin: 0 }}>This is a placeholder</H5>
<Paragraph size="md" style={{ marginBottom: 0 }}>
You can replace this with a local component. You can also just override
the text, but keep in mind that you might lose content that way in case we
happend to change the underlying component. Lorem ipsum dolor sit amet,
consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et
dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation
ullamco laboris nisi ut aliquip ex ea commodo consequat.
</Paragraph>
</Modal>
);
export const WithoutFooter: Story = {
args: {
...Playground.args,
footer: undefined,
},
};

export const WithoutFooter: StoryFn = () => (
<Modal title="Simple modal" onClose={action('close-modal')}>
<H5 style={{ margin: 0 }}>This is a placeholder</H5>
<Paragraph size="md" style={{ marginBottom: 0 }}>
You can replace this with a local component. You can also just override
the text, but keep in mind that you might lose content that way in case we
happend to change the underlying component. Lorem ipsum dolor sit amet,
consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et
dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation
ullamco laboris nisi ut aliquip ex ea commodo consequat.
</Paragraph>
</Modal>
);
export const SizeXs: Story = {
args: {
...Playground.args,
size: 'xs',
},
};
export const SizeSm: Story = {
args: {
...Playground.args,
size: 'sm',
},
};
export const SizeMd: Story = {
args: {
...Playground.args,
size: 'md',
},
};
export const SizeLg: Story = {
args: {
...Playground.args,
size: 'lg',
},
};
export const SizeXL: Story = {
args: {
...Playground.args,
size: 'xl',
},
};
5 changes: 3 additions & 2 deletions src/components/Modal/Modal.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -24,13 +24,14 @@ const widthVariants = {
[ModalSizes.sm]: 430,
[ModalSizes.md]: 600,
[ModalSizes.lg]: 900,
[ModalSizes.xl]: 1440,
};

const BaseModal = styled(Surface)<{ $maxWidth: number }>`
display: flex;
flex-direction: column;
max-height: 90vh;
width: 100%;
width: 90%;
max-width: ${({ $maxWidth }) => pxToRem($maxWidth)};
`;

Expand Down Expand Up @@ -63,7 +64,7 @@ const Modal = forwardRef<HTMLDivElement, ModalProps>(
children,
className,
...rest
},
}: ModalProps,
ref,
) => {
const { portalsContainerId } = useContext(DSContext);
Expand Down
5 changes: 5 additions & 0 deletions src/components/Modal/Modal.types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,10 +5,15 @@ import { ModalSizes } from './Modal.enums';
export type ModalSizes = (typeof ModalSizes)[keyof typeof ModalSizes];

export interface ModalProps {
/** Modal window content */
children: ReactNode;
/** Callback triggered by clicking on close button */
onClose?: MouseEventHandler<HTMLDivElement>;
/** Content of modal window footer */
footer?: ReactNode;
/** Modal window title displayed in header */
title?: string;
/** Maximal size of the modal window */
size?: ModalSizes;
className?: string;
}

0 comments on commit 0ed4061

Please sign in to comment.