@flodesk/grain 11.65.0 → 11.66.0

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,8 +1,7 @@
1
- const _excluded = ["children", "width", "minWidth", "maxWidth", "height", "minHeight", "maxHeight", "padding", "radius", "position", "zIndex"];
1
+ const _excluded = ["children", "width", "minWidth", "maxWidth", "height", "minHeight", "maxHeight", "padding", "radius", "position", "zIndex", "flex", "shadow", "shadowHover", "borderColor", "borderColorHover", "borderWidth", "borderSide", "backgroundColor", "backgroundColorHover", "transition", "transitionHover", "cursor"];
2
2
  function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); }
3
3
  function _objectWithoutProperties(e, t) { if (null == e) return {}; var o, r, i = _objectWithoutPropertiesLoose(e, t); if (Object.getOwnPropertySymbols) { var n = Object.getOwnPropertySymbols(e); for (r = 0; r < n.length; r++) o = n[r], -1 === t.indexOf(o) && {}.propertyIsEnumerable.call(e, o) && (i[o] = e[o]); } return i; }
4
4
  function _objectWithoutPropertiesLoose(r, e) { if (null == r) return {}; var t = {}; for (var n in r) if ({}.hasOwnProperty.call(r, n)) { if (-1 !== e.indexOf(n)) continue; t[n] = r[n]; } return t; }
5
- import React from 'react';
6
5
  import PropTypes from 'prop-types';
7
6
  import { Box } from './box';
8
7
  import { types } from '../types';
@@ -19,7 +18,19 @@ export const Card = _ref => {
19
18
  padding = 'var(--grn-card-padding)',
20
19
  radius = 'var(--grn-card-radius)',
21
20
  position,
22
- zIndex
21
+ zIndex,
22
+ flex,
23
+ shadow = 's',
24
+ shadowHover,
25
+ borderColor,
26
+ borderColorHover,
27
+ borderWidth,
28
+ borderSide,
29
+ backgroundColor,
30
+ backgroundColorHover,
31
+ transition,
32
+ transitionHover,
33
+ cursor
23
34
  } = _ref,
24
35
  props = _objectWithoutProperties(_ref, _excluded);
25
36
  return ___EmotionJSX(Box, {
@@ -28,64 +39,50 @@ export const Card = _ref => {
28
39
  minWidth: minWidth,
29
40
  maxWidth: maxWidth,
30
41
  position: position,
31
- top: 0,
32
- left: 0,
33
- right: 0,
34
- bottom: 0,
35
- zIndex: zIndex
42
+ zIndex: zIndex,
43
+ flex: flex
36
44
  }, ___EmotionJSX(Box, _extends({
37
45
  className: "grn-card",
38
46
  width: "100%",
39
47
  padding: padding,
40
48
  radius: radius,
49
+ shadow: shadow,
41
50
  height: height,
42
51
  minHeight: minHeight,
43
- maxHeight: maxHeight
52
+ maxHeight: maxHeight,
53
+ shadowHover: shadowHover,
54
+ borderColor: borderColor,
55
+ borderColorHover: borderColorHover,
56
+ borderWidth: borderWidth,
57
+ borderSide: borderSide,
58
+ backgroundColor: backgroundColor,
59
+ backgroundColorHover: backgroundColorHover,
60
+ transition: transition,
61
+ transitionHover: transitionHover,
62
+ cursor: cursor
44
63
  }, props), children));
45
64
  };
46
65
  Card.propTypes = {
47
- color: types.color,
48
- colorHover: types.color,
49
- backgroundColor: types.color,
50
- backgroundColorHover: types.color,
51
- borderColor: types.color,
52
- borderColorHover: types.color,
53
- borderWidth: types.borderWidth,
54
- borderSide: types.side,
55
66
  width: types.responsiveDimension,
56
67
  minWidth: types.responsiveDimension,
57
68
  maxWidth: types.responsiveDimension,
58
69
  height: types.responsiveDimension,
59
70
  minHeight: types.responsiveDimension,
60
71
  maxHeight: types.responsiveDimension,
61
- radius: types.radius,
62
- shadow: types.shadow,
63
- shadowHover: types.shadow,
64
72
  padding: types.responsiveSpace,
65
- margin: types.responsiveSpace,
66
- marginTop: types.responsiveSpace,
67
- marginBottom: types.responsiveSpace,
68
- marginLeft: types.responsiveSpace,
69
- marginRight: types.responsiveSpace,
70
- marginX: types.responsiveSpace,
71
- marginY: types.responsiveSpace,
73
+ radius: types.radius,
72
74
  position: types.position,
73
- top: types.responsiveSpace,
74
- bottom: types.responsiveSpace,
75
- left: types.responsiveSpace,
76
- right: types.responsiveSpace,
77
- overflow: types.overflow,
78
- overflowX: types.overflow,
79
- overflowY: types.overflow,
80
- aspectRatio: PropTypes.string,
81
75
  zIndex: types.zIndex,
82
- opacity: PropTypes.string,
83
- opacityHover: PropTypes.string,
84
- order: PropTypes.oneOfType([PropTypes.string, PropTypes.number, PropTypes.object]),
85
- alignSelf: types.alignSelf,
86
76
  flex: PropTypes.oneOfType([PropTypes.string, PropTypes.object]),
77
+ shadow: types.shadow,
78
+ shadowHover: types.shadow,
79
+ borderColor: types.color,
80
+ borderColorHover: types.color,
81
+ borderWidth: types.borderWidth,
82
+ borderSide: types.side,
83
+ backgroundColor: types.color,
84
+ backgroundColorHover: types.color,
87
85
  transition: types.transition,
88
86
  transitionHover: types.transition,
89
- cursor: types.cursor,
90
- tag: PropTypes.string
87
+ cursor: types.cursor
91
88
  };
@@ -3,7 +3,7 @@ const _excluded = ["cardPadding", "cardMaxWidth", "cardMaxHeight", "cardRadius",
3
3
  _excluded2 = ["children"],
4
4
  _excluded3 = ["children", "cardTop"],
5
5
  _excluded4 = ["children"],
6
- _excluded5 = ["isOpen", "children", "onClose", "title", "description", "paddingX", "cardPadding", "cardRadius", "cardMaxWidth", "cardMaxHeight", "cardHeight", "cardTop", "zIndex", "initialFocus", "returnFocus", "closeButtonProps", "hasCloseButton", "disableCloseHandler"];
6
+ _excluded5 = ["isOpen", "children", "onClose", "title", "titleWrap", "description", "paddingX", "cardPadding", "cardRadius", "cardMaxWidth", "cardMaxHeight", "cardHeight", "cardTop", "zIndex", "initialFocus", "returnFocus", "closeButtonProps", "hasCloseButton", "disableCloseHandler"];
7
7
  import "core-js/modules/es.symbol.description.js";
8
8
  function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); }
9
9
  function _objectWithoutProperties(e, t) { if (null == e) return {}; var o, r, i = _objectWithoutPropertiesLoose(e, t); if (Object.getOwnPropertySymbols) { var n = Object.getOwnPropertySymbols(e); for (r = 0; r < n.length; r++) o = n[r], -1 === t.indexOf(o) && {}.propertyIsEnumerable.call(e, o) && (i[o] = e[o]); } return i; }
@@ -80,7 +80,7 @@ const TitleRoot = /*#__PURE__*/_styled(Text, process.env.NODE_ENV === "productio
80
80
  } : {
81
81
  name: "ti75j2",
82
82
  styles: "margin:0",
83
- 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 { 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 ModalCard = forwardRef(function ModalCard(\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      <Box\n        className={`grn-card ${className || ''}`}\n        position=\"relative\"\n        radius={cardRadius}\n        overflow=\"hidden\"\n        ref={ref}\n        backgroundColor=\"floatingBackground\"\n        shadow=\"l\"\n        top={cardTop}\n        height=\"100%\"\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      </Box>\n    </Box>\n  );\n});\n\nconst TitleRoot = styled(Text)`\n  margin: 0;\n`;\n\nconst Title = forwardRef(function Title({ children, ...props }, ref) {\n  return (\n    <TitleRoot tag=\"h3\" ref={ref} size=\"xl\" weight=\"medium\" trimTop {...props}>\n      {children}\n    </TitleRoot>\n  );\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(function Container({ children, cardTop, ...props }, ref) {\n  return (\n    <ContainerRoot ref={ref} className=\"grn-context\" cardTop={cardTop} {...props}>\n      {children}\n    </ContainerRoot>\n  );\n});\n\nconst Backdrop = forwardRef(function Backdrop({ children, ...props }, ref) {\n  return (\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});\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"]} */",
83
+ 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 { 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 ModalCard = forwardRef(function ModalCard(\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      <Box\n        className={`grn-card ${className || ''}`}\n        position=\"relative\"\n        radius={cardRadius}\n        overflow=\"hidden\"\n        ref={ref}\n        backgroundColor=\"floatingBackground\"\n        shadow=\"l\"\n        top={cardTop}\n        height=\"100%\"\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      </Box>\n    </Box>\n  );\n});\n\nconst TitleRoot = styled(Text)`\n  margin: 0;\n`;\n\nconst Title = forwardRef(function Title({ children, ...props }, ref) {\n  return (\n    <TitleRoot\n      tag=\"h3\"\n      ref={ref}\n      size=\"var(--grn-card-title-size)\"\n      weight=\"medium\"\n      trimTop\n      {...props}\n    >\n      {children}\n    </TitleRoot>\n  );\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(function Container({ children, cardTop, ...props }, ref) {\n  return (\n    <ContainerRoot ref={ref} className=\"grn-context\" cardTop={cardTop} {...props}>\n      {children}\n    </ContainerRoot>\n  );\n});\n\nconst Backdrop = forwardRef(function Backdrop({ children, ...props }, ref) {\n  return (\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});\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  titleWrap,\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 && (\n              <Dialog.Title as={Title} wrap={titleWrap}>\n                {title}\n              </Dialog.Title>\n            )}\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  titleWrap: types.textWrap,\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"]} */",
84
84
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
85
85
  });
86
86
  const Title = /*#__PURE__*/forwardRef(function Title(_ref2, ref) {
@@ -91,7 +91,7 @@ const Title = /*#__PURE__*/forwardRef(function Title(_ref2, ref) {
91
91
  return ___EmotionJSX(TitleRoot, _extends({
92
92
  tag: "h3",
93
93
  ref: ref,
94
- size: "xl",
94
+ size: "var(--grn-card-title-size)",
95
95
  weight: "medium",
96
96
  trimTop: true
97
97
  }, props), children);
@@ -121,7 +121,7 @@ const ContainerRoot = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "prod
121
121
  cardTop
122
122
  } = _ref6;
123
123
  return cardTop ? 'start' : 'center';
124
- }, ";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":"AA+EgC","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 { 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 ModalCard = forwardRef(function ModalCard(\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      <Box\n        className={`grn-card ${className || ''}`}\n        position=\"relative\"\n        radius={cardRadius}\n        overflow=\"hidden\"\n        ref={ref}\n        backgroundColor=\"floatingBackground\"\n        shadow=\"l\"\n        top={cardTop}\n        height=\"100%\"\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      </Box>\n    </Box>\n  );\n});\n\nconst TitleRoot = styled(Text)`\n  margin: 0;\n`;\n\nconst Title = forwardRef(function Title({ children, ...props }, ref) {\n  return (\n    <TitleRoot tag=\"h3\" ref={ref} size=\"xl\" weight=\"medium\" trimTop {...props}>\n      {children}\n    </TitleRoot>\n  );\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(function Container({ children, cardTop, ...props }, ref) {\n  return (\n    <ContainerRoot ref={ref} className=\"grn-context\" cardTop={cardTop} {...props}>\n      {children}\n    </ContainerRoot>\n  );\n});\n\nconst Backdrop = forwardRef(function Backdrop({ children, ...props }, ref) {\n  return (\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});\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"]} */"));
124
+ }, ";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":"AAsFgC","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 { 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 ModalCard = forwardRef(function ModalCard(\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      <Box\n        className={`grn-card ${className || ''}`}\n        position=\"relative\"\n        radius={cardRadius}\n        overflow=\"hidden\"\n        ref={ref}\n        backgroundColor=\"floatingBackground\"\n        shadow=\"l\"\n        top={cardTop}\n        height=\"100%\"\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      </Box>\n    </Box>\n  );\n});\n\nconst TitleRoot = styled(Text)`\n  margin: 0;\n`;\n\nconst Title = forwardRef(function Title({ children, ...props }, ref) {\n  return (\n    <TitleRoot\n      tag=\"h3\"\n      ref={ref}\n      size=\"var(--grn-card-title-size)\"\n      weight=\"medium\"\n      trimTop\n      {...props}\n    >\n      {children}\n    </TitleRoot>\n  );\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(function Container({ children, cardTop, ...props }, ref) {\n  return (\n    <ContainerRoot ref={ref} className=\"grn-context\" cardTop={cardTop} {...props}>\n      {children}\n    </ContainerRoot>\n  );\n});\n\nconst Backdrop = forwardRef(function Backdrop({ children, ...props }, ref) {\n  return (\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});\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  titleWrap,\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 && (\n              <Dialog.Title as={Title} wrap={titleWrap}>\n                {title}\n              </Dialog.Title>\n            )}\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  titleWrap: types.textWrap,\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"]} */"));
125
125
  const Container = /*#__PURE__*/forwardRef(function Container(_ref7, ref) {
126
126
  let {
127
127
  children,
@@ -163,6 +163,7 @@ export const Modal = _ref9 => {
163
163
  children,
164
164
  onClose,
165
165
  title,
166
+ titleWrap,
166
167
  description,
167
168
  paddingX = 'l',
168
169
  cardPadding = 'xl',
@@ -216,7 +217,8 @@ export const Modal = _ref9 => {
216
217
  cardTop: cardTop,
217
218
  hasCloseButton: hasCloseButton
218
219
  }, title && ___EmotionJSX(Dialog.Title, {
219
- as: Title
220
+ as: Title,
221
+ wrap: titleWrap
220
222
  }, title), description && ___EmotionJSX(Box, {
221
223
  marginTop: "s"
222
224
  }, ___EmotionJSX(Dialog.Description, {
@@ -230,6 +232,7 @@ Modal.propTypes = {
230
232
  onClose: PropTypes.func,
231
233
  hasCloseButton: PropTypes.bool,
232
234
  title: PropTypes.oneOfType([PropTypes.string, PropTypes.node]),
235
+ titleWrap: types.textWrap,
233
236
  description: PropTypes.oneOfType([PropTypes.string, PropTypes.node]),
234
237
  cardPadding: types.dimension,
235
238
  cardMaxWidth: PropTypes.oneOfType([PropTypes.number, PropTypes.string, PropTypes.oneOf(['narrow', 'medium', 'wide'])]),
@@ -0,0 +1,13 @@
1
+ function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); }
2
+ import * as React from 'react';
3
+ import { jsx as ___EmotionJSX } from "@emotion/react";
4
+ const IconDiamond = props => ___EmotionJSX("svg", _extends({
5
+ viewBox: "0 0 32 36",
6
+ fill: "none",
7
+ xmlns: "http://www.w3.org/2000/svg"
8
+ }, props), ___EmotionJSX("path", {
9
+ fill: "currentColor",
10
+ d: "M24.653 4.5a1.5 1.5 0 0 1 1.263.692l5.348 8.366a1.5 1.5 0 0 1-.147 1.808l-14 15.635-.112.112a1.5 1.5 0 0 1-2.122-.112l-14-15.635a1.5 1.5 0 0 1-.146-1.808l5.347-8.366A1.5 1.5 0 0 1 7.348 4.5zM3.878 14.215 16 27.752l12.123-13.537L23.831 7.5H8.17zm4.096-1.31a1.5 1.5 0 0 1 2.121.069l6 6.399a1.501 1.501 0 0 1-2.19 2.053l-6-6.4a1.5 1.5 0 0 1 .069-2.12"
11
+ }));
12
+ IconDiamond.viewBoxWidth = 32;
13
+ export default IconDiamond;
@@ -0,0 +1,13 @@
1
+ function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); }
2
+ import * as React from 'react';
3
+ import { jsx as ___EmotionJSX } from "@emotion/react";
4
+ const IconStar = props => ___EmotionJSX("svg", _extends({
5
+ viewBox: "0 0 34 36",
6
+ fill: "none",
7
+ xmlns: "http://www.w3.org/2000/svg"
8
+ }, props), ___EmotionJSX("path", {
9
+ fill: "currentColor",
10
+ d: "M17 2a1.5 1.5 0 0 1 1.36.868l4.18 9.003 9.857 1.195a1.5 1.5 0 0 1 .841 2.588l-7.271 6.758 1.91 9.743a1.502 1.502 0 0 1-2.201 1.6L17 28.928l-8.676 4.827a1.5 1.5 0 0 1-2.201-1.6l1.909-9.743-7.27-6.758a1.501 1.501 0 0 1 .84-2.588l9.856-1.195 4.181-9.003.05-.097A1.5 1.5 0 0 1 16.998 2m-3.173 11.893a1.5 1.5 0 0 1-1.18.857l-7.477.906 5.516 5.128c.38.354.551.879.451 1.388l-1.449 7.39 6.582-3.66.175-.084a1.5 1.5 0 0 1 1.284.083l6.581 3.662-1.448-7.391c-.1-.51.071-1.035.451-1.388l5.516-5.128-7.477-.906a1.5 1.5 0 0 1-1.18-.857L17 7.06z"
11
+ }));
12
+ IconStar.viewBoxWidth = 34;
13
+ export default IconStar;
package/es/icons/index.js CHANGED
@@ -111,4 +111,6 @@ export { default as IconText } from './icon-text';
111
111
  export { default as IconNetwork } from './icon-network';
112
112
  export { default as IconBag } from './icon-bag';
113
113
  export { default as IconTwoBranches } from './icon-two-branches';
114
- export { default as IconThreeBranches } from './icon-three-branches';
114
+ export { default as IconThreeBranches } from './icon-three-branches';
115
+ export { default as IconDiamond } from './icon-diamond';
116
+ export { default as IconStar } from './icon-star';
package/es/styles/card.js CHANGED
@@ -1,34 +1,45 @@
1
- const bp = [120, 200, 320, 472, 648, 840];
1
+ const bp1 = 120;
2
+ const bp2 = bp1 + 8 * 10;
3
+ const bp3 = bp2 + 8 * 15;
4
+ const bp4 = bp3 + 8 * 19;
5
+ const bp5 = bp4 + 8 * 22;
6
+ const bp6 = bp5 + 8 * 24;
2
7
  export const cardRanges = [{
3
- min: bp[0],
4
- max: bp[1] - 1,
8
+ min: bp1,
9
+ max: bp2 - 1,
5
10
  padding: 'm',
6
- radius: 'm'
11
+ radius: 'm',
12
+ titleSize: 'l'
7
13
  }, {
8
- min: bp[1],
9
- max: bp[2] - 1,
14
+ min: bp2,
15
+ max: bp3 - 1,
10
16
  padding: 'l',
11
- radius: 'm'
17
+ radius: 'm',
18
+ titleSize: 'l'
12
19
  }, {
13
- min: bp[2],
14
- max: bp[3] - 1,
20
+ min: bp3,
21
+ max: bp4 - 1,
15
22
  padding: 'l2',
16
- radius: 'l'
23
+ radius: 'l',
24
+ titleSize: 'xl'
17
25
  }, {
18
- min: bp[3],
19
- max: bp[4] - 1,
26
+ min: bp4,
27
+ max: bp5 - 1,
20
28
  padding: 'xl',
21
- radius: 'l'
29
+ radius: 'l',
30
+ titleSize: 'xl'
22
31
  }, {
23
- min: bp[4],
24
- max: bp[5] - 1,
32
+ min: bp5,
33
+ max: bp6 - 1,
25
34
  padding: 'xl2',
26
- radius: 'l'
35
+ radius: 'l',
36
+ titleSize: 'xl'
27
37
  }, {
28
- min: bp[5],
38
+ min: bp6,
29
39
  max: 100000,
30
40
  padding: 'xxl',
31
- radius: 'l'
41
+ radius: 'l',
42
+ titleSize: 'xl'
32
43
  }];
33
44
  const fallback = "\n @supports not (container-type: inline-size) {\n .grn-card {\n --grn-card-radius: var(--grn-radius-".concat(cardRanges[2].radius, ");\n --grn-card-padding: var(--grn-space-").concat(cardRanges[2].padding, ");\n }\n }\n");
34
45
 
@@ -1,5 +1,5 @@
1
1
  import type { FC, ForwardRefExoticComponent, RefAttributes, HTMLAttributes } from 'react';
2
- import { DimensionPropType, RadiusPropType } from '../shared';
2
+ import { DimensionPropType, RadiusPropType, TextWrapType } from '../shared';
3
3
 
4
4
  export interface ModalProps extends HTMLAttributes<HTMLDivElement> {
5
5
  children?: React.ReactNode;
@@ -7,6 +7,7 @@ export interface ModalProps extends HTMLAttributes<HTMLDivElement> {
7
7
  onClose?: () => void;
8
8
  hasCloseButton?: boolean;
9
9
  title?: React.ReactNode;
10
+ titleWrap?: TextWrapType;
10
11
  description?: React.ReactNode;
11
12
  cardPadding?: DimensionPropType;
12
13
  cardMaxWidth?: number | string | 'narrow' | 'medium' | 'wide';
@@ -22,7 +22,7 @@ export interface TextProps extends HTMLAttributes<HTMLDivElement> {
22
22
  align?: TextAlignType;
23
23
  letterSpacing?: string;
24
24
  textTransform?: TextTransformType;
25
- textWrap?: TextWrapType;
25
+ wrap?: TextWrapType;
26
26
  variant?: 'caps';
27
27
  trimTop?: boolean;
28
28
  trimBottom?: boolean;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@flodesk/grain",
3
- "version": "11.65.0",
3
+ "version": "11.66.0",
4
4
  "description": "Flodesk design system",
5
5
  "module": "es/index.js",
6
6
  "types": "es/types/index.d.ts",