Skip to content

Commit

Permalink
Add modal support to Dialog, update Modal story
Browse files Browse the repository at this point in the history
  • Loading branch information
m0neysha committed Oct 19, 2023
1 parent 2601d78 commit 5acbbb1
Show file tree
Hide file tree
Showing 3 changed files with 151 additions and 9 deletions.
25 changes: 25 additions & 0 deletions src/dialog/Dialog.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,31 @@ const dialogCSS = css`
}
}
}
&.ac-dialog--modal {
display: flex;
flex-direction: column;
&.ac-dialog--small {
width: 500px;
}
&.ac-dialog--medium {
width: 700px;
}
&.ac-dialog--large {
width: 900px;
}
&.ac-dialog--extraLarge {
width: 1600px;
max-width: calc(100vw - var(--ac-global-dimension-static-size-1700));
}
&.ac-dialog--fullscreen {
width: calc(100vw - var(--ac-global-dimension-static-size-1700));
@media (min-width: var(--ac-global-dimension-static-breakpoint-medium)) {
width: calc(100vw - var(--ac-global-dimension-static-size-3400));
}
}
}
`;
const sizeMap: Record<NonNullable<DialogProps['size']>, string> = {
S: 'small',
Expand Down
32 changes: 30 additions & 2 deletions src/overlays/Modal.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -10,17 +10,23 @@ import { Underlay } from './Underlay';

const modalWrapperCSS = css`
box-sizing: border-box;
height: 100vh;
z-index: 2;
transition: visibility 0ms linear 130ms;
display: flex;
position: fixed;
pointer-events: none;
&.ac-modal-wrapper--slideOver {
height: 100vh;
top: 0;
right: 0;
bottom: 0;
}
&.ac-modal-wrapper--modal {
left: 50%;
top: 50%;
transform: translate(-50%, -50%);
}
`;

const exitTransitionAnimationTime = '0.1s';
Expand Down Expand Up @@ -49,6 +55,28 @@ const modalCSS = css`
transform: translateX(0);
}
}
&.ac-modal--modal {
border: 1px solid ${theme.colors.gray500};
border-radius: 5px;
box-shadow: -10px 0px 30px 10px rgba(0, 0, 0, 0.1);
/* Start offset by the animation distance */
transform: translateX(500px);
/* Exit animations */
transition: opacity ${exitTransitionAnimationTime}
cubic-bezier(0.5, 0, 1, 1),
transform ${exitTransitionAnimationTime} cubic-bezier(0, 0, 0.4, 1);
&.is-open {
/* Entry animations */
transition: transform ${enterTransitionAnimationTime}
cubic-bezier(0, 0, 0.4, 1),
opacity ${enterTransitionAnimationTime} cubic-bezier(0, 0, 0.4, 1);
opacity: 0.9999;
visibility: visible;
transform: translateX(0);
}
}
`;
interface ModalWrapperProps extends HTMLAttributes<HTMLElement> {
children: ReactNode;
Expand Down Expand Up @@ -98,7 +126,7 @@ const ModalWrapper = forwardRef<HTMLDivElement>(function(
});

function Modal(props: ModalProps, ref: DOMRef<HTMLElement>) {
const { children, onClose, type, ...otherProps } = props;
const { children, onClose, type = 'modal', ...otherProps } = props;
const domRef = useDOMRef(ref);

const { overlayProps, underlayProps } = useOverlay(props, domRef);
Expand Down
103 changes: 96 additions & 7 deletions stories/Modal.stories.tsx
Original file line number Diff line number Diff line change
@@ -1,7 +1,17 @@
import React from 'react';
import { Meta, Story } from '@storybook/react';
import { withDesign } from 'storybook-addon-designs';
import { Provider, Modal, ModalProps, Text, Button } from '../src';
import { css } from '@emotion/react';
import {
Provider,
Card,
Text,
Modal,
ModalProps,
DialogContainer,
Dialog,
Button,
} from '../src';

const meta: Meta = {
title: 'Modal',
Expand All @@ -20,16 +30,95 @@ const meta: Meta = {

export default meta;

const content = (
<div
css={css`
flex: 1 1 auto;
overflow-y: scroll;
`}
data-testid="scroll-container"
>
<div data-testid="scroll-content">
<Text>I'm a Modal</Text>
</div>
</div>
);

const Template: Story<ModalProps> = args => {
const [isOpen, setIsOpen] = React.useState(false);
const [isSmallOpen, setIsSmallOpen] = React.useState(false);
const [isMediumOpen, setIsMediumOpen] = React.useState(false);
const [isLargeOpen, setIsLargeOpen] = React.useState(false);
const [isXLargeOpen, setIsXLargelOpen] = React.useState(false);
const [isFullscreenOpen, setIsFullscreenOpen] = React.useState(false);

return (
<Provider>
<Button variant="primary" onClick={() => setIsOpen(true)}>
Open
<Button variant="primary" onClick={() => setIsSmallOpen(true)}>
(Default) Small Modal
</Button>
<DialogContainer
type="modal"
isDismissable
onDismiss={() => setIsSmallOpen(false)}
>
{isSmallOpen && <Dialog title="Example Modal">{content}</Dialog>}
</DialogContainer>
<Button variant="primary" onClick={() => setIsMediumOpen(true)}>
Medium Modal
</Button>
<DialogContainer
type="modal"
isDismissable
onDismiss={() => setIsMediumOpen(false)}
>
{isMediumOpen && (
<Dialog size="M" title="Example Medium Modal">
{content}
</Dialog>
)}
</DialogContainer>
<Button variant="primary" onClick={() => setIsLargeOpen(true)}>
Large Modal
</Button>
<DialogContainer
type="modal"
isDismissable
onDismiss={() => setIsLargeOpen(false)}
>
{isLargeOpen && (
<Dialog size="L" title="Example Large Modal">
{content}
</Dialog>
)}
</DialogContainer>
<Button variant="primary" onClick={() => setIsXLargelOpen(true)}>
XLarge Modal
</Button>
<DialogContainer
type="modal"
isDismissable
onDismiss={() => setIsXLargelOpen(false)}
>
{isXLargeOpen && (
<Dialog size="XL" title="Example X-Large Modal">
{content}
</Dialog>
)}
</DialogContainer>
<Button variant="primary" onClick={() => setIsFullscreenOpen(true)}>
Fullscreen Modal
</Button>
<Modal isOpen={isOpen}>
<Text>hello</Text>
</Modal>
<DialogContainer
type="modal"
isDismissable
onDismiss={() => setIsFullscreenOpen(false)}
>
{isFullscreenOpen && (
<Dialog size="fullscreen" title="Example FullScreen Modal">
{content}
</Dialog>
)}
</DialogContainer>
</Provider>
);
};
Expand Down

0 comments on commit 5acbbb1

Please sign in to comment.