@flodesk/grain 11.28.5 → 11.28.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,5 +1,5 @@
1
1
  import _styled from "@emotion/styled/base";
2
- const _excluded = ["cardPadding", "cardMaxWidth", "cardMaxHeight", "cardRadius", "cardHeight", "cardTop", "children", "onCloseClick", "closeButtonProps", "hasCloseButton"],
2
+ const _excluded = ["cardPadding", "cardMaxWidth", "cardMaxHeight", "cardRadius", "cardHeight", "cardTop", "children", "onCloseClick", "closeButtonProps", "hasCloseButton", "className"],
3
3
  _excluded2 = ["children"],
4
4
  _excluded3 = ["children", "cardTop"],
5
5
  _excluded4 = ["children"],
@@ -46,7 +46,7 @@ const Card = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ?
46
46
  top
47
47
  } = _ref2;
48
48
  return getSpace(top);
49
- }, ";height:100%;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/modal.jsx"],"names":[],"mappings":"AAmBuB","file":"../../src/components/modal.jsx","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Fragment, forwardRef } from 'react';\nimport { Dialog, Transition } from '@headlessui/react';\nimport { Box } from './box';\nimport { Text } from './text';\nimport { getColor, getRadius, getShadow, getSpace, getTransition } from '../utilities';\nimport { IconButton } from './icon-button';\nimport { IconCross } from '../icons';\nimport { types } from '../types';\nimport styled from '@emotion/styled';\n\nconst modalZIndex = 1099;\n\nconst cardMaxWidths = {\n  narrow: 55,\n  medium: 72,\n  wide: 130,\n};\n\nconst Card = styled.div`\n  position: relative;\n  border-radius: ${({ radius }) => getRadius(radius)};\n  overflow: hidden;\n  background-color: ${getColor('floatingBackground')};\n  box-shadow: ${getShadow('l')};\n  top: ${({ top }) => getSpace(top)};\n  height: 100%;\n`;\n\nconst ModalCard = forwardRef(\n  (\n    {\n      cardPadding,\n      cardMaxWidth,\n      cardMaxHeight,\n      cardRadius,\n      cardHeight,\n      cardTop,\n      children,\n      onCloseClick,\n      closeButtonProps,\n      hasCloseButton,\n      ...props\n    },\n    ref,\n  ) => {\n    return (\n      <Box\n        width=\"100%\"\n        maxWidth={cardMaxWidths[cardMaxWidth] || cardMaxWidth}\n        className=\"grn-card-container\"\n      >\n        <Card className=\"grn-card\" radius={cardRadius} ref={ref} top={cardTop} {...props}>\n          <Box padding={cardPadding} overflow=\"auto\" maxHeight={cardMaxHeight} height={cardHeight}>\n            {children}\n          </Box>\n          {hasCloseButton && (\n            <Box position=\"absolute\" right=\"xs\" top=\"xs\" zIndex={1}>\n              <IconButton icon={<IconCross />} onClick={onCloseClick} {...closeButtonProps} />\n            </Box>\n          )}\n        </Card>\n      </Box>\n    );\n  },\n);\n\nconst TitleRoot = styled(Text)`\n  margin: 0;\n`;\n\nconst Title = forwardRef(({ children, ...props }, ref) => (\n  <TitleRoot tag=\"h3\" ref={ref} size=\"xl\" weight=\"medium\" trimTop {...props}>\n    {children}\n  </TitleRoot>\n));\n\nconst ContainerRoot = styled.div`\n  z-index: ${({ zIndex }) => zIndex};\n  padding-left: ${({ paddingX }) => getSpace(paddingX)};\n  padding-right: ${({ paddingX }) => getSpace(paddingX)};\n  position: fixed;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  display: grid;\n  align-items: ${({ cardTop }) => (cardTop ? 'start' : 'center')};\n  justify-items: center;\n  .leaveTo,\n  .enterFrom {\n    opacity: 0;\n  }\n  .enterTo,\n  .leaveTo {\n    transition-duration: ${getTransition('fast')};\n  }\n`;\n\nconst Container = forwardRef(({ children, cardTop, ...props }, ref) => (\n  <ContainerRoot ref={ref} className=\"grn-context\" cardTop={cardTop} {...props}>\n    {children}\n  </ContainerRoot>\n));\n\nconst Backdrop = forwardRef(({ children, ...props }, ref) => (\n  <Box\n    ref={ref}\n    position=\"fixed\"\n    top=\"0\"\n    left=\"0\"\n    width=\"100%\"\n    height=\"100%\"\n    backgroundColor=\"backdrop\"\n    {...props}\n  >\n    {children}\n  </Box>\n));\n\nconst transitionChildProps = {\n  enter: 'enter',\n  enterFrom: 'enterFrom',\n  enterTo: 'enterTo',\n  leave: 'leave',\n  leaveFrom: 'leaveFrom',\n  leaveTo: 'leaveTo',\n};\n\nexport const Modal = ({\n  isOpen,\n  children,\n  onClose,\n  title,\n  description,\n  paddingX = 'l',\n  cardPadding = 'xl',\n  cardRadius = 'l',\n  cardMaxWidth = 68,\n  cardMaxHeight = '90vh',\n  cardHeight,\n  cardTop,\n  zIndex = modalZIndex,\n  initialFocus,\n  returnFocus,\n  closeButtonProps,\n  hasCloseButton = true,\n  disableCloseHandler = false,\n  ...props\n}) => {\n  const hasBackdrop = cardHeight !== '100vh';\n\n  const handleClose = () => {\n    if (disableCloseHandler) return;\n\n    if (Boolean(onClose)) {\n      onClose();\n    }\n    if (returnFocus) {\n      returnFocus.focus();\n    }\n  };\n\n  return (\n    <Transition appear show={isOpen} as={Fragment}>\n      <Dialog\n        as={Container}\n        onClose={handleClose}\n        zIndex={zIndex}\n        initialFocus={initialFocus}\n        paddingX={paddingX}\n        cardTop={cardTop}\n        {...props}\n      >\n        {hasBackdrop && <Transition.Child as={Backdrop} {...transitionChildProps} />}\n\n        <Transition.Child as={Fragment} {...transitionChildProps}>\n          <Dialog.Panel\n            as={ModalCard}\n            onCloseClick={onClose}\n            cardPadding={cardPadding}\n            cardMaxWidth={cardMaxWidth}\n            cardMaxHeight={cardMaxHeight}\n            cardHeight={cardHeight}\n            closeButtonProps={closeButtonProps}\n            cardRadius={cardRadius}\n            cardTop={cardTop}\n            hasCloseButton={hasCloseButton}\n          >\n            {title && <Dialog.Title as={Title}>{title}</Dialog.Title>}\n            {description && (\n              <Box marginTop=\"s\">\n                <Dialog.Description as=\"div\">{description}</Dialog.Description>\n              </Box>\n            )}\n            {children}\n          </Dialog.Panel>\n        </Transition.Child>\n      </Dialog>\n    </Transition>\n  );\n};\n\nModal.Title = Title;\n\nModal.propTypes = {\n  isOpen: PropTypes.bool,\n  children: PropTypes.node,\n  onClose: PropTypes.func,\n  hasCloseButton: PropTypes.bool,\n  title: PropTypes.oneOfType([PropTypes.string, PropTypes.node]),\n  description: PropTypes.oneOfType([PropTypes.string, PropTypes.node]),\n  cardPadding: types.dimension,\n  cardMaxWidth: PropTypes.oneOfType([\n    PropTypes.number,\n    PropTypes.string,\n    PropTypes.oneOf(['narrow', 'medium', 'wide']),\n  ]),\n  cardHeight: types.dimension,\n  cardMaxHeight: types.dimension,\n  cardRadius: types.radius,\n  cardTop: types.space,\n  zIndex: types.zIndex,\n  initialFocus: PropTypes.node,\n  returnFocus: PropTypes.node,\n  closeButtonProps: PropTypes.object,\n  paddingX: types.dimension,\n  disableCloseHandler: PropTypes.bool,\n};\n"]} */"));
49
+ }, ";height:100%;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/modal.jsx"],"names":[],"mappings":"AAmBuB","file":"../../src/components/modal.jsx","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Fragment, forwardRef } from 'react';\nimport { Dialog, Transition } from '@headlessui/react';\nimport { Box } from './box';\nimport { Text } from './text';\nimport { getColor, getRadius, getShadow, getSpace, getTransition } from '../utilities';\nimport { IconButton } from './icon-button';\nimport { IconCross } from '../icons';\nimport { types } from '../types';\nimport styled from '@emotion/styled';\n\nconst modalZIndex = 1099;\n\nconst cardMaxWidths = {\n  narrow: 55,\n  medium: 72,\n  wide: 130,\n};\n\nconst Card = styled.div`\n  position: relative;\n  border-radius: ${({ radius }) => getRadius(radius)};\n  overflow: hidden;\n  background-color: ${getColor('floatingBackground')};\n  box-shadow: ${getShadow('l')};\n  top: ${({ top }) => getSpace(top)};\n  height: 100%;\n`;\n\nconst ModalCard = forwardRef(\n  (\n    {\n      cardPadding,\n      cardMaxWidth,\n      cardMaxHeight,\n      cardRadius,\n      cardHeight,\n      cardTop,\n      children,\n      onCloseClick,\n      closeButtonProps,\n      hasCloseButton,\n      className,\n      ...props\n    },\n    ref,\n  ) => {\n    return (\n      <Box\n        width=\"100%\"\n        maxWidth={cardMaxWidths[cardMaxWidth] || cardMaxWidth}\n        className=\"grn-card-container\"\n      >\n        <Card\n          ref={ref}\n          className={`grn-card ${className || ''}`}\n          radius={cardRadius}\n          top={cardTop}\n          {...props}\n        >\n          <Box padding={cardPadding} overflow=\"auto\" maxHeight={cardMaxHeight} height={cardHeight}>\n            {children}\n          </Box>\n          {hasCloseButton && (\n            <Box position=\"absolute\" right=\"xs\" top=\"xs\" zIndex={1}>\n              <IconButton icon={<IconCross />} onClick={onCloseClick} {...closeButtonProps} />\n            </Box>\n          )}\n        </Card>\n      </Box>\n    );\n  },\n);\n\nconst TitleRoot = styled(Text)`\n  margin: 0;\n`;\n\nconst Title = forwardRef(({ children, ...props }, ref) => (\n  <TitleRoot tag=\"h3\" ref={ref} size=\"xl\" weight=\"medium\" trimTop {...props}>\n    {children}\n  </TitleRoot>\n));\n\nconst ContainerRoot = styled.div`\n  z-index: ${({ zIndex }) => zIndex};\n  padding-left: ${({ paddingX }) => getSpace(paddingX)};\n  padding-right: ${({ paddingX }) => getSpace(paddingX)};\n  position: fixed;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  display: grid;\n  align-items: ${({ cardTop }) => (cardTop ? 'start' : 'center')};\n  justify-items: center;\n  .leaveTo,\n  .enterFrom {\n    opacity: 0;\n  }\n  .enterTo,\n  .leaveTo {\n    transition-duration: ${getTransition('fast')};\n  }\n`;\n\nconst Container = forwardRef(({ children, cardTop, ...props }, ref) => (\n  <ContainerRoot ref={ref} className=\"grn-context\" cardTop={cardTop} {...props}>\n    {children}\n  </ContainerRoot>\n));\n\nconst Backdrop = forwardRef(({ children, ...props }, ref) => (\n  <Box\n    ref={ref}\n    position=\"fixed\"\n    top=\"0\"\n    left=\"0\"\n    width=\"100%\"\n    height=\"100%\"\n    backgroundColor=\"backdrop\"\n    {...props}\n  >\n    {children}\n  </Box>\n));\n\nconst transitionChildProps = {\n  enter: 'enter',\n  enterFrom: 'enterFrom',\n  enterTo: 'enterTo',\n  leave: 'leave',\n  leaveFrom: 'leaveFrom',\n  leaveTo: 'leaveTo',\n};\n\nexport const Modal = ({\n  isOpen,\n  children,\n  onClose,\n  title,\n  description,\n  paddingX = 'l',\n  cardPadding = 'xl',\n  cardRadius = 'l',\n  cardMaxWidth = 68,\n  cardMaxHeight = '90vh',\n  cardHeight,\n  cardTop,\n  zIndex = modalZIndex,\n  initialFocus,\n  returnFocus,\n  closeButtonProps,\n  hasCloseButton = true,\n  disableCloseHandler = false,\n  ...props\n}) => {\n  const hasBackdrop = cardHeight !== '100vh';\n\n  const handleClose = () => {\n    if (disableCloseHandler) return;\n\n    if (Boolean(onClose)) {\n      onClose();\n    }\n    if (returnFocus) {\n      returnFocus.focus();\n    }\n  };\n\n  return (\n    <Transition appear show={isOpen} as={Fragment}>\n      <Dialog\n        as={Container}\n        onClose={handleClose}\n        zIndex={zIndex}\n        initialFocus={initialFocus}\n        paddingX={paddingX}\n        cardTop={cardTop}\n        {...props}\n      >\n        {hasBackdrop && <Transition.Child as={Backdrop} {...transitionChildProps} />}\n\n        <Transition.Child as={Fragment} {...transitionChildProps}>\n          <Dialog.Panel\n            as={ModalCard}\n            onCloseClick={onClose}\n            cardPadding={cardPadding}\n            cardMaxWidth={cardMaxWidth}\n            cardMaxHeight={cardMaxHeight}\n            cardHeight={cardHeight}\n            closeButtonProps={closeButtonProps}\n            cardRadius={cardRadius}\n            cardTop={cardTop}\n            hasCloseButton={hasCloseButton}\n          >\n            {title && <Dialog.Title as={Title}>{title}</Dialog.Title>}\n            {description && (\n              <Box marginTop=\"s\">\n                <Dialog.Description as=\"div\">{description}</Dialog.Description>\n              </Box>\n            )}\n            {children}\n          </Dialog.Panel>\n        </Transition.Child>\n      </Dialog>\n    </Transition>\n  );\n};\n\nModal.Title = Title;\n\nModal.propTypes = {\n  isOpen: PropTypes.bool,\n  children: PropTypes.node,\n  onClose: PropTypes.func,\n  hasCloseButton: PropTypes.bool,\n  title: PropTypes.oneOfType([PropTypes.string, PropTypes.node]),\n  description: PropTypes.oneOfType([PropTypes.string, PropTypes.node]),\n  cardPadding: types.dimension,\n  cardMaxWidth: PropTypes.oneOfType([\n    PropTypes.number,\n    PropTypes.string,\n    PropTypes.oneOf(['narrow', 'medium', 'wide']),\n  ]),\n  cardHeight: types.dimension,\n  cardMaxHeight: types.dimension,\n  cardRadius: types.radius,\n  cardTop: types.space,\n  zIndex: types.zIndex,\n  initialFocus: PropTypes.node,\n  returnFocus: PropTypes.node,\n  closeButtonProps: PropTypes.object,\n  paddingX: types.dimension,\n  disableCloseHandler: PropTypes.bool,\n};\n"]} */"));
50
50
 
51
51
  const ModalCard = /*#__PURE__*/forwardRef((_ref3, ref) => {
52
52
  let {
@@ -59,7 +59,8 @@ const ModalCard = /*#__PURE__*/forwardRef((_ref3, ref) => {
59
59
  children,
60
60
  onCloseClick,
61
61
  closeButtonProps,
62
- hasCloseButton
62
+ hasCloseButton,
63
+ className
63
64
  } = _ref3,
64
65
  props = _objectWithoutProperties(_ref3, _excluded);
65
66
 
@@ -68,9 +69,9 @@ const ModalCard = /*#__PURE__*/forwardRef((_ref3, ref) => {
68
69
  maxWidth: cardMaxWidths[cardMaxWidth] || cardMaxWidth,
69
70
  className: "grn-card-container"
70
71
  }, ___EmotionJSX(Card, _extends({
71
- className: "grn-card",
72
- radius: cardRadius,
73
72
  ref: ref,
73
+ className: "grn-card ".concat(className || ''),
74
+ radius: cardRadius,
74
75
  top: cardTop
75
76
  }, props), ___EmotionJSX(Box, {
76
77
  padding: cardPadding,
@@ -99,7 +100,7 @@ const TitleRoot = /*#__PURE__*/_styled(Text, process.env.NODE_ENV === "productio
99
100
  } : {
100
101
  name: "ti75j2",
101
102
  styles: "margin:0",
102
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/modal.jsx"],"names":[],"mappings":"AAmE8B","file":"../../src/components/modal.jsx","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Fragment, forwardRef } from 'react';\nimport { Dialog, Transition } from '@headlessui/react';\nimport { Box } from './box';\nimport { Text } from './text';\nimport { getColor, getRadius, getShadow, getSpace, getTransition } from '../utilities';\nimport { IconButton } from './icon-button';\nimport { IconCross } from '../icons';\nimport { types } from '../types';\nimport styled from '@emotion/styled';\n\nconst modalZIndex = 1099;\n\nconst cardMaxWidths = {\n  narrow: 55,\n  medium: 72,\n  wide: 130,\n};\n\nconst Card = styled.div`\n  position: relative;\n  border-radius: ${({ radius }) => getRadius(radius)};\n  overflow: hidden;\n  background-color: ${getColor('floatingBackground')};\n  box-shadow: ${getShadow('l')};\n  top: ${({ top }) => getSpace(top)};\n  height: 100%;\n`;\n\nconst ModalCard = forwardRef(\n  (\n    {\n      cardPadding,\n      cardMaxWidth,\n      cardMaxHeight,\n      cardRadius,\n      cardHeight,\n      cardTop,\n      children,\n      onCloseClick,\n      closeButtonProps,\n      hasCloseButton,\n      ...props\n    },\n    ref,\n  ) => {\n    return (\n      <Box\n        width=\"100%\"\n        maxWidth={cardMaxWidths[cardMaxWidth] || cardMaxWidth}\n        className=\"grn-card-container\"\n      >\n        <Card className=\"grn-card\" radius={cardRadius} ref={ref} top={cardTop} {...props}>\n          <Box padding={cardPadding} overflow=\"auto\" maxHeight={cardMaxHeight} height={cardHeight}>\n            {children}\n          </Box>\n          {hasCloseButton && (\n            <Box position=\"absolute\" right=\"xs\" top=\"xs\" zIndex={1}>\n              <IconButton icon={<IconCross />} onClick={onCloseClick} {...closeButtonProps} />\n            </Box>\n          )}\n        </Card>\n      </Box>\n    );\n  },\n);\n\nconst TitleRoot = styled(Text)`\n  margin: 0;\n`;\n\nconst Title = forwardRef(({ children, ...props }, ref) => (\n  <TitleRoot tag=\"h3\" ref={ref} size=\"xl\" weight=\"medium\" trimTop {...props}>\n    {children}\n  </TitleRoot>\n));\n\nconst ContainerRoot = styled.div`\n  z-index: ${({ zIndex }) => zIndex};\n  padding-left: ${({ paddingX }) => getSpace(paddingX)};\n  padding-right: ${({ paddingX }) => getSpace(paddingX)};\n  position: fixed;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  display: grid;\n  align-items: ${({ cardTop }) => (cardTop ? 'start' : 'center')};\n  justify-items: center;\n  .leaveTo,\n  .enterFrom {\n    opacity: 0;\n  }\n  .enterTo,\n  .leaveTo {\n    transition-duration: ${getTransition('fast')};\n  }\n`;\n\nconst Container = forwardRef(({ children, cardTop, ...props }, ref) => (\n  <ContainerRoot ref={ref} className=\"grn-context\" cardTop={cardTop} {...props}>\n    {children}\n  </ContainerRoot>\n));\n\nconst Backdrop = forwardRef(({ children, ...props }, ref) => (\n  <Box\n    ref={ref}\n    position=\"fixed\"\n    top=\"0\"\n    left=\"0\"\n    width=\"100%\"\n    height=\"100%\"\n    backgroundColor=\"backdrop\"\n    {...props}\n  >\n    {children}\n  </Box>\n));\n\nconst transitionChildProps = {\n  enter: 'enter',\n  enterFrom: 'enterFrom',\n  enterTo: 'enterTo',\n  leave: 'leave',\n  leaveFrom: 'leaveFrom',\n  leaveTo: 'leaveTo',\n};\n\nexport const Modal = ({\n  isOpen,\n  children,\n  onClose,\n  title,\n  description,\n  paddingX = 'l',\n  cardPadding = 'xl',\n  cardRadius = 'l',\n  cardMaxWidth = 68,\n  cardMaxHeight = '90vh',\n  cardHeight,\n  cardTop,\n  zIndex = modalZIndex,\n  initialFocus,\n  returnFocus,\n  closeButtonProps,\n  hasCloseButton = true,\n  disableCloseHandler = false,\n  ...props\n}) => {\n  const hasBackdrop = cardHeight !== '100vh';\n\n  const handleClose = () => {\n    if (disableCloseHandler) return;\n\n    if (Boolean(onClose)) {\n      onClose();\n    }\n    if (returnFocus) {\n      returnFocus.focus();\n    }\n  };\n\n  return (\n    <Transition appear show={isOpen} as={Fragment}>\n      <Dialog\n        as={Container}\n        onClose={handleClose}\n        zIndex={zIndex}\n        initialFocus={initialFocus}\n        paddingX={paddingX}\n        cardTop={cardTop}\n        {...props}\n      >\n        {hasBackdrop && <Transition.Child as={Backdrop} {...transitionChildProps} />}\n\n        <Transition.Child as={Fragment} {...transitionChildProps}>\n          <Dialog.Panel\n            as={ModalCard}\n            onCloseClick={onClose}\n            cardPadding={cardPadding}\n            cardMaxWidth={cardMaxWidth}\n            cardMaxHeight={cardMaxHeight}\n            cardHeight={cardHeight}\n            closeButtonProps={closeButtonProps}\n            cardRadius={cardRadius}\n            cardTop={cardTop}\n            hasCloseButton={hasCloseButton}\n          >\n            {title && <Dialog.Title as={Title}>{title}</Dialog.Title>}\n            {description && (\n              <Box marginTop=\"s\">\n                <Dialog.Description as=\"div\">{description}</Dialog.Description>\n              </Box>\n            )}\n            {children}\n          </Dialog.Panel>\n        </Transition.Child>\n      </Dialog>\n    </Transition>\n  );\n};\n\nModal.Title = Title;\n\nModal.propTypes = {\n  isOpen: PropTypes.bool,\n  children: PropTypes.node,\n  onClose: PropTypes.func,\n  hasCloseButton: PropTypes.bool,\n  title: PropTypes.oneOfType([PropTypes.string, PropTypes.node]),\n  description: PropTypes.oneOfType([PropTypes.string, PropTypes.node]),\n  cardPadding: types.dimension,\n  cardMaxWidth: PropTypes.oneOfType([\n    PropTypes.number,\n    PropTypes.string,\n    PropTypes.oneOf(['narrow', 'medium', 'wide']),\n  ]),\n  cardHeight: types.dimension,\n  cardMaxHeight: types.dimension,\n  cardRadius: types.radius,\n  cardTop: types.space,\n  zIndex: types.zIndex,\n  initialFocus: PropTypes.node,\n  returnFocus: PropTypes.node,\n  closeButtonProps: PropTypes.object,\n  paddingX: types.dimension,\n  disableCloseHandler: PropTypes.bool,\n};\n"]} */",
103
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/modal.jsx"],"names":[],"mappings":"AA0E8B","file":"../../src/components/modal.jsx","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Fragment, forwardRef } from 'react';\nimport { Dialog, Transition } from '@headlessui/react';\nimport { Box } from './box';\nimport { Text } from './text';\nimport { getColor, getRadius, getShadow, getSpace, getTransition } from '../utilities';\nimport { IconButton } from './icon-button';\nimport { IconCross } from '../icons';\nimport { types } from '../types';\nimport styled from '@emotion/styled';\n\nconst modalZIndex = 1099;\n\nconst cardMaxWidths = {\n  narrow: 55,\n  medium: 72,\n  wide: 130,\n};\n\nconst Card = styled.div`\n  position: relative;\n  border-radius: ${({ radius }) => getRadius(radius)};\n  overflow: hidden;\n  background-color: ${getColor('floatingBackground')};\n  box-shadow: ${getShadow('l')};\n  top: ${({ top }) => getSpace(top)};\n  height: 100%;\n`;\n\nconst ModalCard = forwardRef(\n  (\n    {\n      cardPadding,\n      cardMaxWidth,\n      cardMaxHeight,\n      cardRadius,\n      cardHeight,\n      cardTop,\n      children,\n      onCloseClick,\n      closeButtonProps,\n      hasCloseButton,\n      className,\n      ...props\n    },\n    ref,\n  ) => {\n    return (\n      <Box\n        width=\"100%\"\n        maxWidth={cardMaxWidths[cardMaxWidth] || cardMaxWidth}\n        className=\"grn-card-container\"\n      >\n        <Card\n          ref={ref}\n          className={`grn-card ${className || ''}`}\n          radius={cardRadius}\n          top={cardTop}\n          {...props}\n        >\n          <Box padding={cardPadding} overflow=\"auto\" maxHeight={cardMaxHeight} height={cardHeight}>\n            {children}\n          </Box>\n          {hasCloseButton && (\n            <Box position=\"absolute\" right=\"xs\" top=\"xs\" zIndex={1}>\n              <IconButton icon={<IconCross />} onClick={onCloseClick} {...closeButtonProps} />\n            </Box>\n          )}\n        </Card>\n      </Box>\n    );\n  },\n);\n\nconst TitleRoot = styled(Text)`\n  margin: 0;\n`;\n\nconst Title = forwardRef(({ children, ...props }, ref) => (\n  <TitleRoot tag=\"h3\" ref={ref} size=\"xl\" weight=\"medium\" trimTop {...props}>\n    {children}\n  </TitleRoot>\n));\n\nconst ContainerRoot = styled.div`\n  z-index: ${({ zIndex }) => zIndex};\n  padding-left: ${({ paddingX }) => getSpace(paddingX)};\n  padding-right: ${({ paddingX }) => getSpace(paddingX)};\n  position: fixed;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  display: grid;\n  align-items: ${({ cardTop }) => (cardTop ? 'start' : 'center')};\n  justify-items: center;\n  .leaveTo,\n  .enterFrom {\n    opacity: 0;\n  }\n  .enterTo,\n  .leaveTo {\n    transition-duration: ${getTransition('fast')};\n  }\n`;\n\nconst Container = forwardRef(({ children, cardTop, ...props }, ref) => (\n  <ContainerRoot ref={ref} className=\"grn-context\" cardTop={cardTop} {...props}>\n    {children}\n  </ContainerRoot>\n));\n\nconst Backdrop = forwardRef(({ children, ...props }, ref) => (\n  <Box\n    ref={ref}\n    position=\"fixed\"\n    top=\"0\"\n    left=\"0\"\n    width=\"100%\"\n    height=\"100%\"\n    backgroundColor=\"backdrop\"\n    {...props}\n  >\n    {children}\n  </Box>\n));\n\nconst transitionChildProps = {\n  enter: 'enter',\n  enterFrom: 'enterFrom',\n  enterTo: 'enterTo',\n  leave: 'leave',\n  leaveFrom: 'leaveFrom',\n  leaveTo: 'leaveTo',\n};\n\nexport const Modal = ({\n  isOpen,\n  children,\n  onClose,\n  title,\n  description,\n  paddingX = 'l',\n  cardPadding = 'xl',\n  cardRadius = 'l',\n  cardMaxWidth = 68,\n  cardMaxHeight = '90vh',\n  cardHeight,\n  cardTop,\n  zIndex = modalZIndex,\n  initialFocus,\n  returnFocus,\n  closeButtonProps,\n  hasCloseButton = true,\n  disableCloseHandler = false,\n  ...props\n}) => {\n  const hasBackdrop = cardHeight !== '100vh';\n\n  const handleClose = () => {\n    if (disableCloseHandler) return;\n\n    if (Boolean(onClose)) {\n      onClose();\n    }\n    if (returnFocus) {\n      returnFocus.focus();\n    }\n  };\n\n  return (\n    <Transition appear show={isOpen} as={Fragment}>\n      <Dialog\n        as={Container}\n        onClose={handleClose}\n        zIndex={zIndex}\n        initialFocus={initialFocus}\n        paddingX={paddingX}\n        cardTop={cardTop}\n        {...props}\n      >\n        {hasBackdrop && <Transition.Child as={Backdrop} {...transitionChildProps} />}\n\n        <Transition.Child as={Fragment} {...transitionChildProps}>\n          <Dialog.Panel\n            as={ModalCard}\n            onCloseClick={onClose}\n            cardPadding={cardPadding}\n            cardMaxWidth={cardMaxWidth}\n            cardMaxHeight={cardMaxHeight}\n            cardHeight={cardHeight}\n            closeButtonProps={closeButtonProps}\n            cardRadius={cardRadius}\n            cardTop={cardTop}\n            hasCloseButton={hasCloseButton}\n          >\n            {title && <Dialog.Title as={Title}>{title}</Dialog.Title>}\n            {description && (\n              <Box marginTop=\"s\">\n                <Dialog.Description as=\"div\">{description}</Dialog.Description>\n              </Box>\n            )}\n            {children}\n          </Dialog.Panel>\n        </Transition.Child>\n      </Dialog>\n    </Transition>\n  );\n};\n\nModal.Title = Title;\n\nModal.propTypes = {\n  isOpen: PropTypes.bool,\n  children: PropTypes.node,\n  onClose: PropTypes.func,\n  hasCloseButton: PropTypes.bool,\n  title: PropTypes.oneOfType([PropTypes.string, PropTypes.node]),\n  description: PropTypes.oneOfType([PropTypes.string, PropTypes.node]),\n  cardPadding: types.dimension,\n  cardMaxWidth: PropTypes.oneOfType([\n    PropTypes.number,\n    PropTypes.string,\n    PropTypes.oneOf(['narrow', 'medium', 'wide']),\n  ]),\n  cardHeight: types.dimension,\n  cardMaxHeight: types.dimension,\n  cardRadius: types.radius,\n  cardTop: types.space,\n  zIndex: types.zIndex,\n  initialFocus: PropTypes.node,\n  returnFocus: PropTypes.node,\n  closeButtonProps: PropTypes.object,\n  paddingX: types.dimension,\n  disableCloseHandler: PropTypes.bool,\n};\n"]} */",
103
104
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
104
105
  });
105
106
 
@@ -143,7 +144,7 @@ const ContainerRoot = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "prod
143
144
  cardTop
144
145
  } = _ref8;
145
146
  return cardTop ? 'start' : 'center';
146
- }, ";justify-items:center;.leaveTo,.enterFrom{opacity:0;}.enterTo,.leaveTo{transition-duration:", getTransition('fast'), ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/modal.jsx"],"names":[],"mappings":"AA6EgC","file":"../../src/components/modal.jsx","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Fragment, forwardRef } from 'react';\nimport { Dialog, Transition } from '@headlessui/react';\nimport { Box } from './box';\nimport { Text } from './text';\nimport { getColor, getRadius, getShadow, getSpace, getTransition } from '../utilities';\nimport { IconButton } from './icon-button';\nimport { IconCross } from '../icons';\nimport { types } from '../types';\nimport styled from '@emotion/styled';\n\nconst modalZIndex = 1099;\n\nconst cardMaxWidths = {\n  narrow: 55,\n  medium: 72,\n  wide: 130,\n};\n\nconst Card = styled.div`\n  position: relative;\n  border-radius: ${({ radius }) => getRadius(radius)};\n  overflow: hidden;\n  background-color: ${getColor('floatingBackground')};\n  box-shadow: ${getShadow('l')};\n  top: ${({ top }) => getSpace(top)};\n  height: 100%;\n`;\n\nconst ModalCard = forwardRef(\n  (\n    {\n      cardPadding,\n      cardMaxWidth,\n      cardMaxHeight,\n      cardRadius,\n      cardHeight,\n      cardTop,\n      children,\n      onCloseClick,\n      closeButtonProps,\n      hasCloseButton,\n      ...props\n    },\n    ref,\n  ) => {\n    return (\n      <Box\n        width=\"100%\"\n        maxWidth={cardMaxWidths[cardMaxWidth] || cardMaxWidth}\n        className=\"grn-card-container\"\n      >\n        <Card className=\"grn-card\" radius={cardRadius} ref={ref} top={cardTop} {...props}>\n          <Box padding={cardPadding} overflow=\"auto\" maxHeight={cardMaxHeight} height={cardHeight}>\n            {children}\n          </Box>\n          {hasCloseButton && (\n            <Box position=\"absolute\" right=\"xs\" top=\"xs\" zIndex={1}>\n              <IconButton icon={<IconCross />} onClick={onCloseClick} {...closeButtonProps} />\n            </Box>\n          )}\n        </Card>\n      </Box>\n    );\n  },\n);\n\nconst TitleRoot = styled(Text)`\n  margin: 0;\n`;\n\nconst Title = forwardRef(({ children, ...props }, ref) => (\n  <TitleRoot tag=\"h3\" ref={ref} size=\"xl\" weight=\"medium\" trimTop {...props}>\n    {children}\n  </TitleRoot>\n));\n\nconst ContainerRoot = styled.div`\n  z-index: ${({ zIndex }) => zIndex};\n  padding-left: ${({ paddingX }) => getSpace(paddingX)};\n  padding-right: ${({ paddingX }) => getSpace(paddingX)};\n  position: fixed;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  display: grid;\n  align-items: ${({ cardTop }) => (cardTop ? 'start' : 'center')};\n  justify-items: center;\n  .leaveTo,\n  .enterFrom {\n    opacity: 0;\n  }\n  .enterTo,\n  .leaveTo {\n    transition-duration: ${getTransition('fast')};\n  }\n`;\n\nconst Container = forwardRef(({ children, cardTop, ...props }, ref) => (\n  <ContainerRoot ref={ref} className=\"grn-context\" cardTop={cardTop} {...props}>\n    {children}\n  </ContainerRoot>\n));\n\nconst Backdrop = forwardRef(({ children, ...props }, ref) => (\n  <Box\n    ref={ref}\n    position=\"fixed\"\n    top=\"0\"\n    left=\"0\"\n    width=\"100%\"\n    height=\"100%\"\n    backgroundColor=\"backdrop\"\n    {...props}\n  >\n    {children}\n  </Box>\n));\n\nconst transitionChildProps = {\n  enter: 'enter',\n  enterFrom: 'enterFrom',\n  enterTo: 'enterTo',\n  leave: 'leave',\n  leaveFrom: 'leaveFrom',\n  leaveTo: 'leaveTo',\n};\n\nexport const Modal = ({\n  isOpen,\n  children,\n  onClose,\n  title,\n  description,\n  paddingX = 'l',\n  cardPadding = 'xl',\n  cardRadius = 'l',\n  cardMaxWidth = 68,\n  cardMaxHeight = '90vh',\n  cardHeight,\n  cardTop,\n  zIndex = modalZIndex,\n  initialFocus,\n  returnFocus,\n  closeButtonProps,\n  hasCloseButton = true,\n  disableCloseHandler = false,\n  ...props\n}) => {\n  const hasBackdrop = cardHeight !== '100vh';\n\n  const handleClose = () => {\n    if (disableCloseHandler) return;\n\n    if (Boolean(onClose)) {\n      onClose();\n    }\n    if (returnFocus) {\n      returnFocus.focus();\n    }\n  };\n\n  return (\n    <Transition appear show={isOpen} as={Fragment}>\n      <Dialog\n        as={Container}\n        onClose={handleClose}\n        zIndex={zIndex}\n        initialFocus={initialFocus}\n        paddingX={paddingX}\n        cardTop={cardTop}\n        {...props}\n      >\n        {hasBackdrop && <Transition.Child as={Backdrop} {...transitionChildProps} />}\n\n        <Transition.Child as={Fragment} {...transitionChildProps}>\n          <Dialog.Panel\n            as={ModalCard}\n            onCloseClick={onClose}\n            cardPadding={cardPadding}\n            cardMaxWidth={cardMaxWidth}\n            cardMaxHeight={cardMaxHeight}\n            cardHeight={cardHeight}\n            closeButtonProps={closeButtonProps}\n            cardRadius={cardRadius}\n            cardTop={cardTop}\n            hasCloseButton={hasCloseButton}\n          >\n            {title && <Dialog.Title as={Title}>{title}</Dialog.Title>}\n            {description && (\n              <Box marginTop=\"s\">\n                <Dialog.Description as=\"div\">{description}</Dialog.Description>\n              </Box>\n            )}\n            {children}\n          </Dialog.Panel>\n        </Transition.Child>\n      </Dialog>\n    </Transition>\n  );\n};\n\nModal.Title = Title;\n\nModal.propTypes = {\n  isOpen: PropTypes.bool,\n  children: PropTypes.node,\n  onClose: PropTypes.func,\n  hasCloseButton: PropTypes.bool,\n  title: PropTypes.oneOfType([PropTypes.string, PropTypes.node]),\n  description: PropTypes.oneOfType([PropTypes.string, PropTypes.node]),\n  cardPadding: types.dimension,\n  cardMaxWidth: PropTypes.oneOfType([\n    PropTypes.number,\n    PropTypes.string,\n    PropTypes.oneOf(['narrow', 'medium', 'wide']),\n  ]),\n  cardHeight: types.dimension,\n  cardMaxHeight: types.dimension,\n  cardRadius: types.radius,\n  cardTop: types.space,\n  zIndex: types.zIndex,\n  initialFocus: PropTypes.node,\n  returnFocus: PropTypes.node,\n  closeButtonProps: PropTypes.object,\n  paddingX: types.dimension,\n  disableCloseHandler: PropTypes.bool,\n};\n"]} */"));
147
+ }, ";justify-items:center;.leaveTo,.enterFrom{opacity:0;}.enterTo,.leaveTo{transition-duration:", getTransition('fast'), ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/modal.jsx"],"names":[],"mappings":"AAoFgC","file":"../../src/components/modal.jsx","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Fragment, forwardRef } from 'react';\nimport { Dialog, Transition } from '@headlessui/react';\nimport { Box } from './box';\nimport { Text } from './text';\nimport { getColor, getRadius, getShadow, getSpace, getTransition } from '../utilities';\nimport { IconButton } from './icon-button';\nimport { IconCross } from '../icons';\nimport { types } from '../types';\nimport styled from '@emotion/styled';\n\nconst modalZIndex = 1099;\n\nconst cardMaxWidths = {\n  narrow: 55,\n  medium: 72,\n  wide: 130,\n};\n\nconst Card = styled.div`\n  position: relative;\n  border-radius: ${({ radius }) => getRadius(radius)};\n  overflow: hidden;\n  background-color: ${getColor('floatingBackground')};\n  box-shadow: ${getShadow('l')};\n  top: ${({ top }) => getSpace(top)};\n  height: 100%;\n`;\n\nconst ModalCard = forwardRef(\n  (\n    {\n      cardPadding,\n      cardMaxWidth,\n      cardMaxHeight,\n      cardRadius,\n      cardHeight,\n      cardTop,\n      children,\n      onCloseClick,\n      closeButtonProps,\n      hasCloseButton,\n      className,\n      ...props\n    },\n    ref,\n  ) => {\n    return (\n      <Box\n        width=\"100%\"\n        maxWidth={cardMaxWidths[cardMaxWidth] || cardMaxWidth}\n        className=\"grn-card-container\"\n      >\n        <Card\n          ref={ref}\n          className={`grn-card ${className || ''}`}\n          radius={cardRadius}\n          top={cardTop}\n          {...props}\n        >\n          <Box padding={cardPadding} overflow=\"auto\" maxHeight={cardMaxHeight} height={cardHeight}>\n            {children}\n          </Box>\n          {hasCloseButton && (\n            <Box position=\"absolute\" right=\"xs\" top=\"xs\" zIndex={1}>\n              <IconButton icon={<IconCross />} onClick={onCloseClick} {...closeButtonProps} />\n            </Box>\n          )}\n        </Card>\n      </Box>\n    );\n  },\n);\n\nconst TitleRoot = styled(Text)`\n  margin: 0;\n`;\n\nconst Title = forwardRef(({ children, ...props }, ref) => (\n  <TitleRoot tag=\"h3\" ref={ref} size=\"xl\" weight=\"medium\" trimTop {...props}>\n    {children}\n  </TitleRoot>\n));\n\nconst ContainerRoot = styled.div`\n  z-index: ${({ zIndex }) => zIndex};\n  padding-left: ${({ paddingX }) => getSpace(paddingX)};\n  padding-right: ${({ paddingX }) => getSpace(paddingX)};\n  position: fixed;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  display: grid;\n  align-items: ${({ cardTop }) => (cardTop ? 'start' : 'center')};\n  justify-items: center;\n  .leaveTo,\n  .enterFrom {\n    opacity: 0;\n  }\n  .enterTo,\n  .leaveTo {\n    transition-duration: ${getTransition('fast')};\n  }\n`;\n\nconst Container = forwardRef(({ children, cardTop, ...props }, ref) => (\n  <ContainerRoot ref={ref} className=\"grn-context\" cardTop={cardTop} {...props}>\n    {children}\n  </ContainerRoot>\n));\n\nconst Backdrop = forwardRef(({ children, ...props }, ref) => (\n  <Box\n    ref={ref}\n    position=\"fixed\"\n    top=\"0\"\n    left=\"0\"\n    width=\"100%\"\n    height=\"100%\"\n    backgroundColor=\"backdrop\"\n    {...props}\n  >\n    {children}\n  </Box>\n));\n\nconst transitionChildProps = {\n  enter: 'enter',\n  enterFrom: 'enterFrom',\n  enterTo: 'enterTo',\n  leave: 'leave',\n  leaveFrom: 'leaveFrom',\n  leaveTo: 'leaveTo',\n};\n\nexport const Modal = ({\n  isOpen,\n  children,\n  onClose,\n  title,\n  description,\n  paddingX = 'l',\n  cardPadding = 'xl',\n  cardRadius = 'l',\n  cardMaxWidth = 68,\n  cardMaxHeight = '90vh',\n  cardHeight,\n  cardTop,\n  zIndex = modalZIndex,\n  initialFocus,\n  returnFocus,\n  closeButtonProps,\n  hasCloseButton = true,\n  disableCloseHandler = false,\n  ...props\n}) => {\n  const hasBackdrop = cardHeight !== '100vh';\n\n  const handleClose = () => {\n    if (disableCloseHandler) return;\n\n    if (Boolean(onClose)) {\n      onClose();\n    }\n    if (returnFocus) {\n      returnFocus.focus();\n    }\n  };\n\n  return (\n    <Transition appear show={isOpen} as={Fragment}>\n      <Dialog\n        as={Container}\n        onClose={handleClose}\n        zIndex={zIndex}\n        initialFocus={initialFocus}\n        paddingX={paddingX}\n        cardTop={cardTop}\n        {...props}\n      >\n        {hasBackdrop && <Transition.Child as={Backdrop} {...transitionChildProps} />}\n\n        <Transition.Child as={Fragment} {...transitionChildProps}>\n          <Dialog.Panel\n            as={ModalCard}\n            onCloseClick={onClose}\n            cardPadding={cardPadding}\n            cardMaxWidth={cardMaxWidth}\n            cardMaxHeight={cardMaxHeight}\n            cardHeight={cardHeight}\n            closeButtonProps={closeButtonProps}\n            cardRadius={cardRadius}\n            cardTop={cardTop}\n            hasCloseButton={hasCloseButton}\n          >\n            {title && <Dialog.Title as={Title}>{title}</Dialog.Title>}\n            {description && (\n              <Box marginTop=\"s\">\n                <Dialog.Description as=\"div\">{description}</Dialog.Description>\n              </Box>\n            )}\n            {children}\n          </Dialog.Panel>\n        </Transition.Child>\n      </Dialog>\n    </Transition>\n  );\n};\n\nModal.Title = Title;\n\nModal.propTypes = {\n  isOpen: PropTypes.bool,\n  children: PropTypes.node,\n  onClose: PropTypes.func,\n  hasCloseButton: PropTypes.bool,\n  title: PropTypes.oneOfType([PropTypes.string, PropTypes.node]),\n  description: PropTypes.oneOfType([PropTypes.string, PropTypes.node]),\n  cardPadding: types.dimension,\n  cardMaxWidth: PropTypes.oneOfType([\n    PropTypes.number,\n    PropTypes.string,\n    PropTypes.oneOf(['narrow', 'medium', 'wide']),\n  ]),\n  cardHeight: types.dimension,\n  cardMaxHeight: types.dimension,\n  cardRadius: types.radius,\n  cardTop: types.space,\n  zIndex: types.zIndex,\n  initialFocus: PropTypes.node,\n  returnFocus: PropTypes.node,\n  closeButtonProps: PropTypes.object,\n  paddingX: types.dimension,\n  disableCloseHandler: PropTypes.bool,\n};\n"]} */"));
147
148
 
148
149
  const Container = /*#__PURE__*/forwardRef((_ref9, ref) => {
149
150
  let {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@flodesk/grain",
3
- "version": "11.28.5",
3
+ "version": "11.28.6",
4
4
  "description": "Flodesk design system",
5
5
  "module": "es/index.js",
6
6
  "author": "Flodesk",