@amboss/design-system 3.1.4 → 3.2.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.
Files changed (49) hide show
  1. package/build/cjs/components/BulkActionsToolbar/BulkActionsToolbar.d.ts +2 -1
  2. package/build/cjs/components/BulkActionsToolbar/BulkActionsToolbar.js +1 -1
  3. package/build/cjs/components/Column/Columns.d.ts +2 -0
  4. package/build/cjs/components/Column/Columns.js +1 -1
  5. package/build/cjs/components/Form/PasswordInput/PasswordInput.js +1 -1
  6. package/build/cjs/components/Grid/Grid.d.ts +36 -0
  7. package/build/cjs/components/Grid/Grid.js +1 -0
  8. package/build/cjs/components/Grid/GridItem.d.ts +32 -0
  9. package/build/cjs/components/Grid/GridItem.js +1 -0
  10. package/build/cjs/components/Sheet/Sheet.d.ts +2 -1
  11. package/build/cjs/components/Sheet/Sheet.js +1 -1
  12. package/build/cjs/components/Toggletip/BasePopover.d.ts +6 -1
  13. package/build/cjs/components/Toggletip/BasePopover.js +1 -1
  14. package/build/cjs/index.d.ts +1 -0
  15. package/build/cjs/index.js +1 -1
  16. package/build/cjs/shared/mediaQueries.d.ts +2 -2
  17. package/build/cjs/shared/mediaQueries.js +1 -1
  18. package/build/cjs/web-tokens/assets/icons16.json +1 -1
  19. package/build/esm/components/BulkActionsToolbar/BulkActionsToolbar.d.ts +2 -1
  20. package/build/esm/components/BulkActionsToolbar/BulkActionsToolbar.js +1 -1
  21. package/build/esm/components/Column/Columns.d.ts +2 -0
  22. package/build/esm/components/Column/Columns.js +1 -1
  23. package/build/esm/components/Form/PasswordInput/PasswordInput.js +1 -1
  24. package/build/esm/components/Grid/Grid.d.ts +36 -0
  25. package/build/esm/components/Grid/Grid.js +1 -0
  26. package/build/esm/components/Grid/GridItem.d.ts +32 -0
  27. package/build/esm/components/Grid/GridItem.js +1 -0
  28. package/build/esm/components/Sheet/Sheet.d.ts +2 -1
  29. package/build/esm/components/Sheet/Sheet.js +1 -1
  30. package/build/esm/components/Toggletip/BasePopover.d.ts +6 -1
  31. package/build/esm/components/Toggletip/BasePopover.js +1 -1
  32. package/build/esm/index.d.ts +1 -0
  33. package/build/esm/index.js +1 -1
  34. package/build/esm/shared/mediaQueries.d.ts +2 -2
  35. package/build/esm/shared/mediaQueries.js +1 -1
  36. package/build/esm/web-tokens/assets/icons16.json +1 -1
  37. package/package.json +1 -1
  38. package/build/cjs/components/Toolbar/Toolbar.d.ts +0 -7
  39. package/build/cjs/components/Toolbar/Toolbar.js +0 -1
  40. package/build/cjs/components/Toolbar/ToolbarGroup.d.ts +0 -5
  41. package/build/cjs/components/Toolbar/ToolbarGroup.js +0 -1
  42. package/build/cjs/components/Toolbar/index.d.ts +0 -4
  43. package/build/cjs/components/Toolbar/index.js +0 -1
  44. package/build/esm/components/Toolbar/Toolbar.d.ts +0 -7
  45. package/build/esm/components/Toolbar/Toolbar.js +0 -1
  46. package/build/esm/components/Toolbar/ToolbarGroup.d.ts +0 -5
  47. package/build/esm/components/Toolbar/ToolbarGroup.js +0 -1
  48. package/build/esm/components/Toolbar/index.d.ts +0 -4
  49. package/build/esm/components/Toolbar/index.js +0 -1
@@ -1 +1 @@
1
- import React,{useState,forwardRef}from"react";import styled from"@emotion/styled";import{Icon}from"../../Icon/Icon";import{FormField}from"../FormField/FormField";let handleBorderColor=(theme,hasError,readOnly)=>hasError?theme.values.color.border.error.default:readOnly?theme.values.color.border.primary.disabled:theme.values.color.border.primary.default,handleIconBorderColor=(theme,hasError)=>hasError?theme.values.color.icon.error.default:"transparent",handleIconLeftBorderColor=(theme,hasError)=>hasError?theme.values.color.border.error.default:theme.values.color.border.primary.default,StyledContainer=/*#__PURE__*/styled("div",{target:"ecgpf3y0",label:"StyledContainer"})(()=>({width:"100%",display:"flex",alignItems:"center",flexDirection:"row",position:"relative",zIndex:1}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/PasswordInput/PasswordInput.tsx","sources":["src/components/Form/PasswordInput/PasswordInput.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport type { RefObject } from \"react\";\nimport React, { useState, forwardRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { CSSObject, Theme } from \"@emotion/react\";\nimport { Icon } from \"../../Icon/Icon\";\nimport type { FormFieldProps } from \"../FormField/FormField\";\nimport { FormField } from \"../FormField/FormField\";\n\nexport type PasswordInputProps = {\n  iconAriaLabel: string;\n} & InputProps;\n\ntype InputProps = {\n  name: string;\n  value: string;\n  placeholder?: string;\n  /**\n   * Set to true to toggle error state\n   */\n  hasError?: boolean;\n  /**\n   * Set to true to disabled input\n   */\n  disabled?: boolean;\n  readOnly?: boolean;\n  onChange?: (e: React.ChangeEvent<HTMLInputElement>) => void;\n  onClick?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onIconClick?: (e: React.MouseEvent) => void;\n  onBlur?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onFocus?: (e: React.FormEvent<HTMLInputElement>) => void;\n  areaLabel?: string;\n  tabIndex?: number;\n  autoComplete?: string;\n} & FormFieldProps;\n\ntype IconProps = {\n  hasError?: boolean;\n  disabled?: boolean;\n  onChange?: (e: React.FormEvent<HTMLInputElement>) => void;\n  tabIndex?: number;\n};\n\nconst handleBorderColor = (\n  theme: Theme,\n  hasError: boolean,\n  readOnly: boolean\n) => {\n  if (hasError) return theme.values.color.border.error.default;\n  if (readOnly) return theme.values.color.border.primary.disabled;\n\n  return theme.values.color.border.primary.default;\n};\n\nconst handleIconBorderColor = (theme: Theme, hasError: boolean) => {\n  if (hasError) return theme.values.color.icon.error.default;\n  return \"transparent\";\n};\n\nconst handleIconLeftBorderColor = (theme: Theme, hasError: boolean) => {\n  if (hasError) return theme.values.color.border.error.default;\n  return theme.values.color.border.primary.default;\n};\n\nconst StyledContainer = styled.div(\n  () =>\n    ({\n      width: \"100%\",\n      display: \"flex\",\n      alignItems: \"center\",\n      flexDirection: \"row\",\n      position: \"relative\",\n      zIndex: 1,\n    } as CSSObject)\n);\n\nconst StyledIconBtn = styled.button<IconProps>(({ theme, hasError }) => ({\n  \"&[type='button']\": {\n    appearance: \"none\",\n    MozAppearance: \"none\",\n    WebkitAppearance: \"none\",\n  },\n  position: \"absolute\",\n  top: 0,\n  right: 0,\n  zIndex: 2,\n  border: \"1px solid\",\n  borderColor: handleIconBorderColor(theme, hasError),\n  borderLeftColor: handleIconLeftBorderColor(theme, hasError),\n  padding: theme.variables.size.spacing.s,\n  borderRadius: theme.variables.size.borderRadius.xs,\n  borderBottomLeftRadius: \"0\",\n  borderTopLeftRadius: \"0\",\n  color: theme.values.color.text.secondary.default,\n  backgroundColor: \"inherit\",\n  cursor: \"pointer\",\n  \"&:hover\": {\n    backgroundColor: theme.values.color.background.transparent.hover,\n    borderColor: theme.values.color.border.primary.default,\n  },\n  \"&:active\": {\n    color: theme.values.color.text.primary.default,\n    backgroundColor: theme.values.color.background.transparent.active,\n    borderColor: theme.values.color.border.primary.active,\n  },\n  \"&:disabled\": {\n    backgroundColor: theme.values.color.background.transparent.default,\n    borderLeftColor: theme.values.color.border.primary.disabled,\n    pointerEvents: \"none\",\n  },\n  ...(hasError && {\n    boxShadow: `0 0 0 1px inset ${theme.values.color.border.error.default}`,\n  }),\n  \"& svg\": {\n    pointerEvents: \"none\",\n  },\n}));\n\nconst StyledPasswordInput = styled.input<InputProps>(\n  ({ theme, hasError, readOnly }) => ({\n    fontFamily: theme.variables.fontFamily.lato,\n    fontSize: theme.variables.size.font.m,\n    lineHeight: theme.variables.size.lineHeight.xl,\n    borderRadius: theme.variables.size.borderRadius.xs,\n    borderWidth: \"1px\",\n    borderStyle: \"solid\",\n    width: \"100%\",\n    padding: `calc(${theme.variables.size.spacing.xs} - 1px) ${theme.variables.size.spacing.s}`,\n    paddingRight: theme.variables.size.spacing.xxl,\n    boxSizing: \"border-box\",\n    color: theme.values.color.text.secondary.default,\n    borderColor: handleBorderColor(theme, hasError, readOnly),\n    backgroundColor: theme.values.color.background.primary.default,\n    \"&.error\": {\n      borderColor: theme.values.color.border.error.default,\n    },\n    \"&.has-icon\": {\n      paddingRight:\n        theme.variables.size.spacing.xs + theme.variables.size.dimension.icon.m,\n    },\n    \"&::placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n      opacity: theme.variables.opacity.visible,\n    },\n    \"&:-ms-input-placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n    },\n    \"&::-ms-input-placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n    },\n    ...(hasError && {\n      boxShadow: `0 0 0 1px inset ${theme.values.color.border.error.default}`,\n    }),\n  })\n);\n\nexport const PasswordInputRaw = forwardRef(\n  (\n    {\n      name,\n      value,\n      placeholder,\n      hasError = false,\n      disabled,\n      onChange,\n      onClick,\n      onBlur,\n      onFocus,\n      onIconClick,\n      areaLabel,\n      tabIndex,\n      autoComplete,\n      iconAriaLabel,\n      readOnly,\n    }: PasswordInputProps,\n    ref: RefObject<HTMLInputElement>\n  ): React.ReactElement => {\n    const [inputType, setInputType] = useState(\"password\");\n    const currentType = inputType === \"password\" ? \"text\" : \"password\";\n    const eyeIcon = inputType === \"password\" ? \"eye-off\" : \"eye\";\n\n    return (\n      <StyledContainer>\n        <StyledPasswordInput\n          type={inputType}\n          value={value}\n          placeholder={!readOnly && placeholder}\n          name={name}\n          disabled={disabled}\n          onClick={onClick}\n          onChange={onChange}\n          onBlur={onBlur}\n          onFocus={onFocus}\n          aria-label={areaLabel}\n          ref={ref}\n          tabIndex={tabIndex}\n          autoComplete={autoComplete}\n          hasError={hasError}\n          readOnly={readOnly}\n        />\n        <StyledIconBtn\n          onClick={(e: React.MouseEvent) => {\n            if (disabled) {\n              e.preventDefault();\n            }\n            if (onIconClick) {\n              onIconClick(e);\n            }\n            setInputType(currentType);\n          }}\n          hasError={hasError}\n          disabled={readOnly || disabled}\n          aria-label={iconAriaLabel}\n          type=\"button\"\n        >\n          <Icon\n            name={eyeIcon}\n            size=\"s\"\n            color={readOnly ? \"quaternary\" : \"tertiary\"}\n          />\n        </StyledIconBtn>\n      </StyledContainer>\n    );\n  }\n);\n\nexport const PasswordInput = React.forwardRef(\n  (\n    {\n      name,\n      value,\n      placeholder = \"••••••••\",\n      hasError = false,\n      onChange,\n      onClick,\n      onBlur,\n      onFocus,\n      onIconClick,\n      tabIndex,\n      areaLabel,\n      autoComplete = \"on\",\n      iconAriaLabel,\n      disabled,\n      readOnly,\n      ...rest\n    }: PasswordInputProps,\n    ref: React.RefObject<HTMLInputElement>\n  ): React.ReactElement => (\n    <FormField\n      data-ds-id=\"PasswordInput\"\n      disabled={disabled}\n      {...(rest as FormFieldProps)}\n    >\n      <PasswordInputRaw\n        ref={ref}\n        name={name}\n        value={value}\n        placeholder={placeholder}\n        hasError={hasError}\n        disabled={disabled}\n        onChange={onChange}\n        onBlur={onBlur}\n        onFocus={onFocus}\n        onClick={onClick}\n        onIconClick={onIconClick}\n        tabIndex={tabIndex}\n        areaLabel={areaLabel}\n        autoComplete={autoComplete}\n        iconAriaLabel={iconAriaLabel}\n        readOnly={readOnly}\n      />\n    </FormField>\n  )\n);\n"],"names":[],"mappings":"AAiEwB"} */"),StyledIconBtn=/*#__PURE__*/styled("button",{target:"ecgpf3y1",label:"StyledIconBtn"})(({theme,hasError})=>({"&[type='button']":{appearance:"none",MozAppearance:"none",WebkitAppearance:"none"},position:"absolute",top:0,right:0,zIndex:2,border:"1px solid",borderColor:handleIconBorderColor(theme,hasError),borderLeftColor:handleIconLeftBorderColor(theme,hasError),padding:theme.variables.size.spacing.s,borderRadius:theme.variables.size.borderRadius.xs,borderBottomLeftRadius:"0",borderTopLeftRadius:"0",color:theme.values.color.text.secondary.default,backgroundColor:"inherit",cursor:"pointer","&:hover":{backgroundColor:theme.values.color.background.transparent.hover,borderColor:theme.values.color.border.primary.default},"&:active":{color:theme.values.color.text.primary.default,backgroundColor:theme.values.color.background.transparent.active,borderColor:theme.values.color.border.primary.active},"&:disabled":{backgroundColor:theme.values.color.background.transparent.default,borderLeftColor:theme.values.color.border.primary.disabled,pointerEvents:"none"},...hasError&&{boxShadow:`0 0 0 1px inset ${theme.values.color.border.error.default}`},"& svg":{pointerEvents:"none"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/PasswordInput/PasswordInput.tsx","sources":["src/components/Form/PasswordInput/PasswordInput.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport type { RefObject } from \"react\";\nimport React, { useState, forwardRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { CSSObject, Theme } from \"@emotion/react\";\nimport { Icon } from \"../../Icon/Icon\";\nimport type { FormFieldProps } from \"../FormField/FormField\";\nimport { FormField } from \"../FormField/FormField\";\n\nexport type PasswordInputProps = {\n  iconAriaLabel: string;\n} & InputProps;\n\ntype InputProps = {\n  name: string;\n  value: string;\n  placeholder?: string;\n  /**\n   * Set to true to toggle error state\n   */\n  hasError?: boolean;\n  /**\n   * Set to true to disabled input\n   */\n  disabled?: boolean;\n  readOnly?: boolean;\n  onChange?: (e: React.ChangeEvent<HTMLInputElement>) => void;\n  onClick?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onIconClick?: (e: React.MouseEvent) => void;\n  onBlur?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onFocus?: (e: React.FormEvent<HTMLInputElement>) => void;\n  areaLabel?: string;\n  tabIndex?: number;\n  autoComplete?: string;\n} & FormFieldProps;\n\ntype IconProps = {\n  hasError?: boolean;\n  disabled?: boolean;\n  onChange?: (e: React.FormEvent<HTMLInputElement>) => void;\n  tabIndex?: number;\n};\n\nconst handleBorderColor = (\n  theme: Theme,\n  hasError: boolean,\n  readOnly: boolean\n) => {\n  if (hasError) return theme.values.color.border.error.default;\n  if (readOnly) return theme.values.color.border.primary.disabled;\n\n  return theme.values.color.border.primary.default;\n};\n\nconst handleIconBorderColor = (theme: Theme, hasError: boolean) => {\n  if (hasError) return theme.values.color.icon.error.default;\n  return \"transparent\";\n};\n\nconst handleIconLeftBorderColor = (theme: Theme, hasError: boolean) => {\n  if (hasError) return theme.values.color.border.error.default;\n  return theme.values.color.border.primary.default;\n};\n\nconst StyledContainer = styled.div(\n  () =>\n    ({\n      width: \"100%\",\n      display: \"flex\",\n      alignItems: \"center\",\n      flexDirection: \"row\",\n      position: \"relative\",\n      zIndex: 1,\n    } as CSSObject)\n);\n\nconst StyledIconBtn = styled.button<IconProps>(({ theme, hasError }) => ({\n  \"&[type='button']\": {\n    appearance: \"none\",\n    MozAppearance: \"none\",\n    WebkitAppearance: \"none\",\n  },\n  position: \"absolute\",\n  top: 0,\n  right: 0,\n  zIndex: 2,\n  border: \"1px solid\",\n  borderColor: handleIconBorderColor(theme, hasError),\n  borderLeftColor: handleIconLeftBorderColor(theme, hasError),\n  padding: theme.variables.size.spacing.s,\n  borderRadius: theme.variables.size.borderRadius.xs,\n  borderBottomLeftRadius: \"0\",\n  borderTopLeftRadius: \"0\",\n  color: theme.values.color.text.secondary.default,\n  backgroundColor: \"inherit\",\n  cursor: \"pointer\",\n  \"&:hover\": {\n    backgroundColor: theme.values.color.background.transparent.hover,\n    borderColor: theme.values.color.border.primary.default,\n  },\n  \"&:active\": {\n    color: theme.values.color.text.primary.default,\n    backgroundColor: theme.values.color.background.transparent.active,\n    borderColor: theme.values.color.border.primary.active,\n  },\n  \"&:disabled\": {\n    backgroundColor: theme.values.color.background.transparent.default,\n    borderLeftColor: theme.values.color.border.primary.disabled,\n    pointerEvents: \"none\",\n  },\n  ...(hasError && {\n    boxShadow: `0 0 0 1px inset ${theme.values.color.border.error.default}`,\n  }),\n  \"& svg\": {\n    pointerEvents: \"none\",\n  },\n}));\n\nconst StyledPasswordInput = styled.input<InputProps>(\n  ({ theme, hasError, readOnly }) => ({\n    fontFamily: theme.variables.fontFamily.lato,\n    fontSize: theme.variables.size.font.m,\n    lineHeight: theme.variables.size.lineHeight.xl,\n    borderRadius: theme.variables.size.borderRadius.xs,\n    borderWidth: \"1px\",\n    borderStyle: \"solid\",\n    width: \"100%\",\n    padding: `calc(${theme.variables.size.spacing.xs} - 1px) ${theme.variables.size.spacing.s}`,\n    paddingRight: theme.variables.size.spacing.xxl,\n    boxSizing: \"border-box\",\n    color: theme.values.color.text.secondary.default,\n    borderColor: handleBorderColor(theme, hasError, readOnly),\n    backgroundColor: theme.values.color.background.primary.default,\n    \"&.error\": {\n      borderColor: theme.values.color.border.error.default,\n    },\n    \"&.has-icon\": {\n      paddingRight:\n        theme.variables.size.spacing.xs + theme.variables.size.dimension.icon.m,\n    },\n    \"&::placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n      opacity: theme.variables.opacity.visible,\n    },\n    \"&:-ms-input-placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n    },\n    \"&::-ms-input-placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n    },\n    ...(hasError && {\n      boxShadow: `0 0 0 1px inset ${theme.values.color.border.error.default}`,\n    }),\n  })\n);\n\nexport const PasswordInputRaw = forwardRef(\n  (\n    {\n      name,\n      value,\n      placeholder,\n      hasError = false,\n      disabled,\n      onChange,\n      onClick,\n      onBlur,\n      onFocus,\n      onIconClick,\n      areaLabel,\n      tabIndex,\n      autoComplete,\n      iconAriaLabel,\n      readOnly,\n    }: PasswordInputProps,\n    ref: RefObject<HTMLInputElement>\n  ): React.ReactElement => {\n    const [inputType, setInputType] = useState(\"password\");\n    const currentType = inputType === \"password\" ? \"text\" : \"password\";\n    const eyeIcon = inputType === \"password\" ? \"eye-off\" : \"eye\";\n\n    return (\n      <StyledContainer>\n        <StyledPasswordInput\n          type={inputType}\n          value={value}\n          placeholder={!readOnly && placeholder}\n          name={name}\n          disabled={disabled}\n          onClick={onClick}\n          onChange={onChange}\n          onBlur={onBlur}\n          onFocus={onFocus}\n          aria-label={areaLabel}\n          ref={ref}\n          tabIndex={tabIndex}\n          autoComplete={autoComplete}\n          hasError={hasError}\n          readOnly={readOnly}\n        />\n        <StyledIconBtn\n          onClick={(e: React.MouseEvent) => {\n            if (disabled) {\n              e.preventDefault();\n            }\n            if (onIconClick) {\n              onIconClick(e);\n            }\n            setInputType(currentType);\n          }}\n          hasError={hasError}\n          disabled={readOnly || disabled}\n          aria-label={iconAriaLabel}\n          type=\"button\"\n        >\n          <Icon\n            name={eyeIcon}\n            size=\"s\"\n            color={readOnly ? \"quaternary\" : \"tertiary\"}\n          />\n        </StyledIconBtn>\n      </StyledContainer>\n    );\n  }\n);\n\nexport const PasswordInput = React.forwardRef(\n  (\n    {\n      name,\n      value,\n      placeholder = \"••••••••\",\n      hasError = false,\n      onChange,\n      onClick,\n      onBlur,\n      onFocus,\n      onIconClick,\n      tabIndex,\n      areaLabel,\n      autoComplete = \"on\",\n      iconAriaLabel,\n      disabled,\n      readOnly,\n      ...rest\n    }: PasswordInputProps,\n    ref: React.RefObject<HTMLInputElement>\n  ): React.ReactElement => (\n    <FormField\n      data-ds-id=\"PasswordInput\"\n      disabled={disabled}\n      {...(rest as FormFieldProps)}\n    >\n      <PasswordInputRaw\n        ref={ref}\n        name={name}\n        value={value}\n        placeholder={placeholder}\n        hasError={hasError}\n        disabled={disabled}\n        onChange={onChange}\n        onBlur={onBlur}\n        onFocus={onFocus}\n        onClick={onClick}\n        onIconClick={onIconClick}\n        tabIndex={tabIndex}\n        areaLabel={areaLabel}\n        autoComplete={autoComplete}\n        iconAriaLabel={iconAriaLabel}\n        readOnly={readOnly}\n      />\n    </FormField>\n  )\n);\n"],"names":[],"mappings":"AA6EsB"} */"),StyledPasswordInput=/*#__PURE__*/styled("input",{target:"ecgpf3y2",label:"StyledPasswordInput"})(({theme,hasError,readOnly})=>({fontFamily:theme.variables.fontFamily.lato,fontSize:theme.variables.size.font.m,lineHeight:theme.variables.size.lineHeight.xl,borderRadius:theme.variables.size.borderRadius.xs,borderWidth:"1px",borderStyle:"solid",width:"100%",padding:`calc(${theme.variables.size.spacing.xs} - 1px) ${theme.variables.size.spacing.s}`,paddingRight:theme.variables.size.spacing.xxl,boxSizing:"border-box",color:theme.values.color.text.secondary.default,borderColor:handleBorderColor(theme,hasError,readOnly),backgroundColor:theme.values.color.background.primary.default,"&.error":{borderColor:theme.values.color.border.error.default},"&.has-icon":{paddingRight:theme.variables.size.spacing.xs+theme.variables.size.dimension.icon.m},"&::placeholder":{fontStyle:"italic",color:theme.values.color.text.tertiary.default,opacity:theme.variables.opacity.visible},"&:-ms-input-placeholder":{fontStyle:"italic",color:theme.values.color.text.tertiary.default},"&::-ms-input-placeholder":{fontStyle:"italic",color:theme.values.color.text.tertiary.default},...hasError&&{boxShadow:`0 0 0 1px inset ${theme.values.color.border.error.default}`}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/PasswordInput/PasswordInput.tsx","sources":["src/components/Form/PasswordInput/PasswordInput.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport type { RefObject } from \"react\";\nimport React, { useState, forwardRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { CSSObject, Theme } from \"@emotion/react\";\nimport { Icon } from \"../../Icon/Icon\";\nimport type { FormFieldProps } from \"../FormField/FormField\";\nimport { FormField } from \"../FormField/FormField\";\n\nexport type PasswordInputProps = {\n  iconAriaLabel: string;\n} & InputProps;\n\ntype InputProps = {\n  name: string;\n  value: string;\n  placeholder?: string;\n  /**\n   * Set to true to toggle error state\n   */\n  hasError?: boolean;\n  /**\n   * Set to true to disabled input\n   */\n  disabled?: boolean;\n  readOnly?: boolean;\n  onChange?: (e: React.ChangeEvent<HTMLInputElement>) => void;\n  onClick?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onIconClick?: (e: React.MouseEvent) => void;\n  onBlur?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onFocus?: (e: React.FormEvent<HTMLInputElement>) => void;\n  areaLabel?: string;\n  tabIndex?: number;\n  autoComplete?: string;\n} & FormFieldProps;\n\ntype IconProps = {\n  hasError?: boolean;\n  disabled?: boolean;\n  onChange?: (e: React.FormEvent<HTMLInputElement>) => void;\n  tabIndex?: number;\n};\n\nconst handleBorderColor = (\n  theme: Theme,\n  hasError: boolean,\n  readOnly: boolean\n) => {\n  if (hasError) return theme.values.color.border.error.default;\n  if (readOnly) return theme.values.color.border.primary.disabled;\n\n  return theme.values.color.border.primary.default;\n};\n\nconst handleIconBorderColor = (theme: Theme, hasError: boolean) => {\n  if (hasError) return theme.values.color.icon.error.default;\n  return \"transparent\";\n};\n\nconst handleIconLeftBorderColor = (theme: Theme, hasError: boolean) => {\n  if (hasError) return theme.values.color.border.error.default;\n  return theme.values.color.border.primary.default;\n};\n\nconst StyledContainer = styled.div(\n  () =>\n    ({\n      width: \"100%\",\n      display: \"flex\",\n      alignItems: \"center\",\n      flexDirection: \"row\",\n      position: \"relative\",\n      zIndex: 1,\n    } as CSSObject)\n);\n\nconst StyledIconBtn = styled.button<IconProps>(({ theme, hasError }) => ({\n  \"&[type='button']\": {\n    appearance: \"none\",\n    MozAppearance: \"none\",\n    WebkitAppearance: \"none\",\n  },\n  position: \"absolute\",\n  top: 0,\n  right: 0,\n  zIndex: 2,\n  border: \"1px solid\",\n  borderColor: handleIconBorderColor(theme, hasError),\n  borderLeftColor: handleIconLeftBorderColor(theme, hasError),\n  padding: theme.variables.size.spacing.s,\n  borderRadius: theme.variables.size.borderRadius.xs,\n  borderBottomLeftRadius: \"0\",\n  borderTopLeftRadius: \"0\",\n  color: theme.values.color.text.secondary.default,\n  backgroundColor: \"inherit\",\n  cursor: \"pointer\",\n  \"&:hover\": {\n    backgroundColor: theme.values.color.background.transparent.hover,\n    borderColor: theme.values.color.border.primary.default,\n  },\n  \"&:active\": {\n    color: theme.values.color.text.primary.default,\n    backgroundColor: theme.values.color.background.transparent.active,\n    borderColor: theme.values.color.border.primary.active,\n  },\n  \"&:disabled\": {\n    backgroundColor: theme.values.color.background.transparent.default,\n    borderLeftColor: theme.values.color.border.primary.disabled,\n    pointerEvents: \"none\",\n  },\n  ...(hasError && {\n    boxShadow: `0 0 0 1px inset ${theme.values.color.border.error.default}`,\n  }),\n  \"& svg\": {\n    pointerEvents: \"none\",\n  },\n}));\n\nconst StyledPasswordInput = styled.input<InputProps>(\n  ({ theme, hasError, readOnly }) => ({\n    fontFamily: theme.variables.fontFamily.lato,\n    fontSize: theme.variables.size.font.m,\n    lineHeight: theme.variables.size.lineHeight.xl,\n    borderRadius: theme.variables.size.borderRadius.xs,\n    borderWidth: \"1px\",\n    borderStyle: \"solid\",\n    width: \"100%\",\n    padding: `calc(${theme.variables.size.spacing.xs} - 1px) ${theme.variables.size.spacing.s}`,\n    paddingRight: theme.variables.size.spacing.xxl,\n    boxSizing: \"border-box\",\n    color: theme.values.color.text.secondary.default,\n    borderColor: handleBorderColor(theme, hasError, readOnly),\n    backgroundColor: theme.values.color.background.primary.default,\n    \"&.error\": {\n      borderColor: theme.values.color.border.error.default,\n    },\n    \"&.has-icon\": {\n      paddingRight:\n        theme.variables.size.spacing.xs + theme.variables.size.dimension.icon.m,\n    },\n    \"&::placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n      opacity: theme.variables.opacity.visible,\n    },\n    \"&:-ms-input-placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n    },\n    \"&::-ms-input-placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n    },\n    ...(hasError && {\n      boxShadow: `0 0 0 1px inset ${theme.values.color.border.error.default}`,\n    }),\n  })\n);\n\nexport const PasswordInputRaw = forwardRef(\n  (\n    {\n      name,\n      value,\n      placeholder,\n      hasError = false,\n      disabled,\n      onChange,\n      onClick,\n      onBlur,\n      onFocus,\n      onIconClick,\n      areaLabel,\n      tabIndex,\n      autoComplete,\n      iconAriaLabel,\n      readOnly,\n    }: PasswordInputProps,\n    ref: RefObject<HTMLInputElement>\n  ): React.ReactElement => {\n    const [inputType, setInputType] = useState(\"password\");\n    const currentType = inputType === \"password\" ? \"text\" : \"password\";\n    const eyeIcon = inputType === \"password\" ? \"eye-off\" : \"eye\";\n\n    return (\n      <StyledContainer>\n        <StyledPasswordInput\n          type={inputType}\n          value={value}\n          placeholder={!readOnly && placeholder}\n          name={name}\n          disabled={disabled}\n          onClick={onClick}\n          onChange={onChange}\n          onBlur={onBlur}\n          onFocus={onFocus}\n          aria-label={areaLabel}\n          ref={ref}\n          tabIndex={tabIndex}\n          autoComplete={autoComplete}\n          hasError={hasError}\n          readOnly={readOnly}\n        />\n        <StyledIconBtn\n          onClick={(e: React.MouseEvent) => {\n            if (disabled) {\n              e.preventDefault();\n            }\n            if (onIconClick) {\n              onIconClick(e);\n            }\n            setInputType(currentType);\n          }}\n          hasError={hasError}\n          disabled={readOnly || disabled}\n          aria-label={iconAriaLabel}\n          type=\"button\"\n        >\n          <Icon\n            name={eyeIcon}\n            size=\"s\"\n            color={readOnly ? \"quaternary\" : \"tertiary\"}\n          />\n        </StyledIconBtn>\n      </StyledContainer>\n    );\n  }\n);\n\nexport const PasswordInput = React.forwardRef(\n  (\n    {\n      name,\n      value,\n      placeholder = \"••••••••\",\n      hasError = false,\n      onChange,\n      onClick,\n      onBlur,\n      onFocus,\n      onIconClick,\n      tabIndex,\n      areaLabel,\n      autoComplete = \"on\",\n      iconAriaLabel,\n      disabled,\n      readOnly,\n      ...rest\n    }: PasswordInputProps,\n    ref: React.RefObject<HTMLInputElement>\n  ): React.ReactElement => (\n    <FormField\n      data-ds-id=\"PasswordInput\"\n      disabled={disabled}\n      {...(rest as FormFieldProps)}\n    >\n      <PasswordInputRaw\n        ref={ref}\n        name={name}\n        value={value}\n        placeholder={placeholder}\n        hasError={hasError}\n        disabled={disabled}\n        onChange={onChange}\n        onBlur={onBlur}\n        onFocus={onFocus}\n        onClick={onClick}\n        onIconClick={onIconClick}\n        tabIndex={tabIndex}\n        areaLabel={areaLabel}\n        autoComplete={autoComplete}\n        iconAriaLabel={iconAriaLabel}\n        readOnly={readOnly}\n      />\n    </FormField>\n  )\n);\n"],"names":[],"mappings":"AAuH4B"} */");export const PasswordInputRaw=/*#__PURE__*/forwardRef(({name,value,placeholder,hasError=!1,disabled,onChange,onClick,onBlur,onFocus,onIconClick,areaLabel,tabIndex,autoComplete,iconAriaLabel,readOnly},ref)=>{let[inputType,setInputType]=useState("password"),currentType="password"===inputType?"text":"password";return /*#__PURE__*/React.createElement(StyledContainer,null,/*#__PURE__*/React.createElement(StyledPasswordInput,{type:inputType,value:value,placeholder:!readOnly&&placeholder,name:name,disabled:disabled,onClick:onClick,onChange:onChange,onBlur:onBlur,onFocus:onFocus,"aria-label":areaLabel,ref:ref,tabIndex:tabIndex,autoComplete:autoComplete,hasError:hasError,readOnly:readOnly}),/*#__PURE__*/React.createElement(StyledIconBtn,{onClick:e=>{disabled&&e.preventDefault(),onIconClick&&onIconClick(e),setInputType(currentType)},hasError:hasError,disabled:readOnly||disabled,"aria-label":iconAriaLabel,type:"button"},/*#__PURE__*/React.createElement(Icon,{name:"password"===inputType?"eye-off":"eye",size:"s",color:readOnly?"quaternary":"tertiary"})))});export const PasswordInput=/*#__PURE__*/React.forwardRef(({name,value,placeholder="••••••••",hasError=!1,onChange,onClick,onBlur,onFocus,onIconClick,tabIndex,areaLabel,autoComplete="on",iconAriaLabel,disabled,readOnly,...rest},ref)=>/*#__PURE__*/React.createElement(FormField,{"data-ds-id":"PasswordInput",disabled:disabled,...rest},/*#__PURE__*/React.createElement(PasswordInputRaw,{ref:ref,name:name,value:value,placeholder:placeholder,hasError:hasError,disabled:disabled,onChange:onChange,onBlur:onBlur,onFocus:onFocus,onClick:onClick,onIconClick:onIconClick,tabIndex:tabIndex,areaLabel:areaLabel,autoComplete:autoComplete,iconAriaLabel:iconAriaLabel,readOnly:readOnly})));
1
+ import React,{useState,forwardRef}from"react";import styled from"@emotion/styled";import{Icon}from"../../Icon/Icon";import{FormField}from"../FormField/FormField";let handleBorderColor=(theme,hasError,readOnly)=>hasError?theme.values.color.border.error.default:readOnly?theme.values.color.border.primary.disabled:theme.values.color.border.primary.default,handleIconBorderColor=(theme,hasError)=>hasError?theme.values.color.icon.error.default:"transparent",handleIconLeftBorderColor=(theme,hasError)=>hasError?theme.values.color.border.error.default:theme.values.color.border.primary.default,StyledContainer=/*#__PURE__*/styled("div",{target:"e12olo7k0",label:"StyledContainer"})(()=>({width:"100%",display:"flex",alignItems:"center",flexDirection:"row",position:"relative",zIndex:1}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/PasswordInput/PasswordInput.tsx","sources":["src/components/Form/PasswordInput/PasswordInput.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport type { RefObject } from \"react\";\nimport React, { useState, forwardRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { CSSObject, Theme } from \"@emotion/react\";\nimport { Icon } from \"../../Icon/Icon\";\nimport type { FormFieldProps } from \"../FormField/FormField\";\nimport { FormField } from \"../FormField/FormField\";\n\nexport type PasswordInputProps = {\n  iconAriaLabel: string;\n} & InputProps;\n\ntype InputProps = {\n  name: string;\n  value: string;\n  placeholder?: string;\n  /**\n   * Set to true to toggle error state\n   */\n  hasError?: boolean;\n  /**\n   * Set to true to disabled input\n   */\n  disabled?: boolean;\n  readOnly?: boolean;\n  onChange?: (e: React.ChangeEvent<HTMLInputElement>) => void;\n  onClick?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onIconClick?: (e: React.MouseEvent) => void;\n  onBlur?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onFocus?: (e: React.FormEvent<HTMLInputElement>) => void;\n  areaLabel?: string;\n  tabIndex?: number;\n  autoComplete?: string;\n} & FormFieldProps;\n\ntype IconProps = {\n  hasError?: boolean;\n  disabled?: boolean;\n  onChange?: (e: React.FormEvent<HTMLInputElement>) => void;\n  tabIndex?: number;\n};\n\nconst handleBorderColor = (\n  theme: Theme,\n  hasError: boolean,\n  readOnly: boolean\n) => {\n  if (hasError) return theme.values.color.border.error.default;\n  if (readOnly) return theme.values.color.border.primary.disabled;\n\n  return theme.values.color.border.primary.default;\n};\n\nconst handleIconBorderColor = (theme: Theme, hasError: boolean) => {\n  if (hasError) return theme.values.color.icon.error.default;\n  return \"transparent\";\n};\n\nconst handleIconLeftBorderColor = (theme: Theme, hasError: boolean) => {\n  if (hasError) return theme.values.color.border.error.default;\n  return theme.values.color.border.primary.default;\n};\n\nconst StyledContainer = styled.div(\n  () =>\n    ({\n      width: \"100%\",\n      display: \"flex\",\n      alignItems: \"center\",\n      flexDirection: \"row\",\n      position: \"relative\",\n      zIndex: 1,\n    } as CSSObject)\n);\n\nconst StyledIconBtn = styled.button<IconProps>(({ theme, hasError }) => ({\n  \"&[type='button']\": {\n    appearance: \"none\",\n    MozAppearance: \"none\",\n    WebkitAppearance: \"none\",\n  },\n  position: \"absolute\",\n  top: 0,\n  right: 0,\n  zIndex: 2,\n  border: \"1px solid\",\n  borderColor: handleIconBorderColor(theme, hasError),\n  borderLeftColor: handleIconLeftBorderColor(theme, hasError),\n  padding: `calc(${theme.variables.size.spacing.s} - 1px) ${theme.variables.size.spacing.s}`,\n  borderRadius: theme.variables.size.borderRadius.xs,\n  borderBottomLeftRadius: \"0\",\n  borderTopLeftRadius: \"0\",\n  color: theme.values.color.text.secondary.default,\n  backgroundColor: \"inherit\",\n  cursor: \"pointer\",\n  \"&:hover\": {\n    backgroundColor: theme.values.color.background.transparent.hover,\n    borderColor: theme.values.color.border.primary.default,\n  },\n  \"&:active\": {\n    color: theme.values.color.text.primary.default,\n    backgroundColor: theme.values.color.background.transparent.active,\n    borderColor: theme.values.color.border.primary.active,\n  },\n  \"&:disabled\": {\n    backgroundColor: theme.values.color.background.transparent.default,\n    borderLeftColor: theme.values.color.border.primary.disabled,\n    pointerEvents: \"none\",\n  },\n  ...(hasError && {\n    boxShadow: `0 0 0 1px inset ${theme.values.color.border.error.default}`,\n  }),\n  \"& svg\": {\n    pointerEvents: \"none\",\n  },\n}));\n\nconst StyledPasswordInput = styled.input<InputProps>(\n  ({ theme, hasError, readOnly }) => ({\n    fontFamily: theme.variables.fontFamily.lato,\n    fontSize: theme.variables.size.font.m,\n    lineHeight: theme.variables.size.lineHeight.xl,\n    borderRadius: theme.variables.size.borderRadius.xs,\n    borderWidth: \"1px\",\n    borderStyle: \"solid\",\n    width: \"100%\",\n    padding: `calc(${theme.variables.size.spacing.xs} - 1px) ${theme.variables.size.spacing.s}`,\n    paddingRight: theme.variables.size.spacing.xxl,\n    boxSizing: \"border-box\",\n    color: theme.values.color.text.secondary.default,\n    borderColor: handleBorderColor(theme, hasError, readOnly),\n    backgroundColor: theme.values.color.background.primary.default,\n    \"&.error\": {\n      borderColor: theme.values.color.border.error.default,\n    },\n    \"&.has-icon\": {\n      paddingRight:\n        theme.variables.size.spacing.xs + theme.variables.size.dimension.icon.m,\n    },\n    \"&::placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n      opacity: theme.variables.opacity.visible,\n    },\n    \"&:-ms-input-placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n    },\n    \"&::-ms-input-placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n    },\n    ...(hasError && {\n      boxShadow: `0 0 0 1px inset ${theme.values.color.border.error.default}`,\n    }),\n  })\n);\n\nexport const PasswordInputRaw = forwardRef(\n  (\n    {\n      name,\n      value,\n      placeholder,\n      hasError = false,\n      disabled,\n      onChange,\n      onClick,\n      onBlur,\n      onFocus,\n      onIconClick,\n      areaLabel,\n      tabIndex,\n      autoComplete,\n      iconAriaLabel,\n      readOnly,\n    }: PasswordInputProps,\n    ref: RefObject<HTMLInputElement>\n  ): React.ReactElement => {\n    const [inputType, setInputType] = useState(\"password\");\n    const currentType = inputType === \"password\" ? \"text\" : \"password\";\n    const eyeIcon = inputType === \"password\" ? \"eye-off\" : \"eye\";\n\n    return (\n      <StyledContainer>\n        <StyledPasswordInput\n          type={inputType}\n          value={value}\n          placeholder={!readOnly && placeholder}\n          name={name}\n          disabled={disabled}\n          onClick={onClick}\n          onChange={onChange}\n          onBlur={onBlur}\n          onFocus={onFocus}\n          aria-label={areaLabel}\n          ref={ref}\n          tabIndex={tabIndex}\n          autoComplete={autoComplete}\n          hasError={hasError}\n          readOnly={readOnly}\n        />\n        <StyledIconBtn\n          onClick={(e: React.MouseEvent) => {\n            if (disabled) {\n              e.preventDefault();\n            }\n            if (onIconClick) {\n              onIconClick(e);\n            }\n            setInputType(currentType);\n          }}\n          hasError={hasError}\n          disabled={readOnly || disabled}\n          aria-label={iconAriaLabel}\n          type=\"button\"\n        >\n          <Icon\n            name={eyeIcon}\n            size=\"s\"\n            color={readOnly ? \"quaternary\" : \"tertiary\"}\n          />\n        </StyledIconBtn>\n      </StyledContainer>\n    );\n  }\n);\n\nexport const PasswordInput = React.forwardRef(\n  (\n    {\n      name,\n      value,\n      placeholder = \"••••••••\",\n      hasError = false,\n      onChange,\n      onClick,\n      onBlur,\n      onFocus,\n      onIconClick,\n      tabIndex,\n      areaLabel,\n      autoComplete = \"on\",\n      iconAriaLabel,\n      disabled,\n      readOnly,\n      ...rest\n    }: PasswordInputProps,\n    ref: React.RefObject<HTMLInputElement>\n  ): React.ReactElement => (\n    <FormField\n      data-ds-id=\"PasswordInput\"\n      disabled={disabled}\n      {...(rest as FormFieldProps)}\n    >\n      <PasswordInputRaw\n        ref={ref}\n        name={name}\n        value={value}\n        placeholder={placeholder}\n        hasError={hasError}\n        disabled={disabled}\n        onChange={onChange}\n        onBlur={onBlur}\n        onFocus={onFocus}\n        onClick={onClick}\n        onIconClick={onIconClick}\n        tabIndex={tabIndex}\n        areaLabel={areaLabel}\n        autoComplete={autoComplete}\n        iconAriaLabel={iconAriaLabel}\n        readOnly={readOnly}\n      />\n    </FormField>\n  )\n);\n"],"names":[],"mappings":"AAiEwB"} */"),StyledIconBtn=/*#__PURE__*/styled("button",{target:"e12olo7k1",label:"StyledIconBtn"})(({theme,hasError})=>({"&[type='button']":{appearance:"none",MozAppearance:"none",WebkitAppearance:"none"},position:"absolute",top:0,right:0,zIndex:2,border:"1px solid",borderColor:handleIconBorderColor(theme,hasError),borderLeftColor:handleIconLeftBorderColor(theme,hasError),padding:`calc(${theme.variables.size.spacing.s} - 1px) ${theme.variables.size.spacing.s}`,borderRadius:theme.variables.size.borderRadius.xs,borderBottomLeftRadius:"0",borderTopLeftRadius:"0",color:theme.values.color.text.secondary.default,backgroundColor:"inherit",cursor:"pointer","&:hover":{backgroundColor:theme.values.color.background.transparent.hover,borderColor:theme.values.color.border.primary.default},"&:active":{color:theme.values.color.text.primary.default,backgroundColor:theme.values.color.background.transparent.active,borderColor:theme.values.color.border.primary.active},"&:disabled":{backgroundColor:theme.values.color.background.transparent.default,borderLeftColor:theme.values.color.border.primary.disabled,pointerEvents:"none"},...hasError&&{boxShadow:`0 0 0 1px inset ${theme.values.color.border.error.default}`},"& svg":{pointerEvents:"none"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/PasswordInput/PasswordInput.tsx","sources":["src/components/Form/PasswordInput/PasswordInput.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport type { RefObject } from \"react\";\nimport React, { useState, forwardRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { CSSObject, Theme } from \"@emotion/react\";\nimport { Icon } from \"../../Icon/Icon\";\nimport type { FormFieldProps } from \"../FormField/FormField\";\nimport { FormField } from \"../FormField/FormField\";\n\nexport type PasswordInputProps = {\n  iconAriaLabel: string;\n} & InputProps;\n\ntype InputProps = {\n  name: string;\n  value: string;\n  placeholder?: string;\n  /**\n   * Set to true to toggle error state\n   */\n  hasError?: boolean;\n  /**\n   * Set to true to disabled input\n   */\n  disabled?: boolean;\n  readOnly?: boolean;\n  onChange?: (e: React.ChangeEvent<HTMLInputElement>) => void;\n  onClick?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onIconClick?: (e: React.MouseEvent) => void;\n  onBlur?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onFocus?: (e: React.FormEvent<HTMLInputElement>) => void;\n  areaLabel?: string;\n  tabIndex?: number;\n  autoComplete?: string;\n} & FormFieldProps;\n\ntype IconProps = {\n  hasError?: boolean;\n  disabled?: boolean;\n  onChange?: (e: React.FormEvent<HTMLInputElement>) => void;\n  tabIndex?: number;\n};\n\nconst handleBorderColor = (\n  theme: Theme,\n  hasError: boolean,\n  readOnly: boolean\n) => {\n  if (hasError) return theme.values.color.border.error.default;\n  if (readOnly) return theme.values.color.border.primary.disabled;\n\n  return theme.values.color.border.primary.default;\n};\n\nconst handleIconBorderColor = (theme: Theme, hasError: boolean) => {\n  if (hasError) return theme.values.color.icon.error.default;\n  return \"transparent\";\n};\n\nconst handleIconLeftBorderColor = (theme: Theme, hasError: boolean) => {\n  if (hasError) return theme.values.color.border.error.default;\n  return theme.values.color.border.primary.default;\n};\n\nconst StyledContainer = styled.div(\n  () =>\n    ({\n      width: \"100%\",\n      display: \"flex\",\n      alignItems: \"center\",\n      flexDirection: \"row\",\n      position: \"relative\",\n      zIndex: 1,\n    } as CSSObject)\n);\n\nconst StyledIconBtn = styled.button<IconProps>(({ theme, hasError }) => ({\n  \"&[type='button']\": {\n    appearance: \"none\",\n    MozAppearance: \"none\",\n    WebkitAppearance: \"none\",\n  },\n  position: \"absolute\",\n  top: 0,\n  right: 0,\n  zIndex: 2,\n  border: \"1px solid\",\n  borderColor: handleIconBorderColor(theme, hasError),\n  borderLeftColor: handleIconLeftBorderColor(theme, hasError),\n  padding: `calc(${theme.variables.size.spacing.s} - 1px) ${theme.variables.size.spacing.s}`,\n  borderRadius: theme.variables.size.borderRadius.xs,\n  borderBottomLeftRadius: \"0\",\n  borderTopLeftRadius: \"0\",\n  color: theme.values.color.text.secondary.default,\n  backgroundColor: \"inherit\",\n  cursor: \"pointer\",\n  \"&:hover\": {\n    backgroundColor: theme.values.color.background.transparent.hover,\n    borderColor: theme.values.color.border.primary.default,\n  },\n  \"&:active\": {\n    color: theme.values.color.text.primary.default,\n    backgroundColor: theme.values.color.background.transparent.active,\n    borderColor: theme.values.color.border.primary.active,\n  },\n  \"&:disabled\": {\n    backgroundColor: theme.values.color.background.transparent.default,\n    borderLeftColor: theme.values.color.border.primary.disabled,\n    pointerEvents: \"none\",\n  },\n  ...(hasError && {\n    boxShadow: `0 0 0 1px inset ${theme.values.color.border.error.default}`,\n  }),\n  \"& svg\": {\n    pointerEvents: \"none\",\n  },\n}));\n\nconst StyledPasswordInput = styled.input<InputProps>(\n  ({ theme, hasError, readOnly }) => ({\n    fontFamily: theme.variables.fontFamily.lato,\n    fontSize: theme.variables.size.font.m,\n    lineHeight: theme.variables.size.lineHeight.xl,\n    borderRadius: theme.variables.size.borderRadius.xs,\n    borderWidth: \"1px\",\n    borderStyle: \"solid\",\n    width: \"100%\",\n    padding: `calc(${theme.variables.size.spacing.xs} - 1px) ${theme.variables.size.spacing.s}`,\n    paddingRight: theme.variables.size.spacing.xxl,\n    boxSizing: \"border-box\",\n    color: theme.values.color.text.secondary.default,\n    borderColor: handleBorderColor(theme, hasError, readOnly),\n    backgroundColor: theme.values.color.background.primary.default,\n    \"&.error\": {\n      borderColor: theme.values.color.border.error.default,\n    },\n    \"&.has-icon\": {\n      paddingRight:\n        theme.variables.size.spacing.xs + theme.variables.size.dimension.icon.m,\n    },\n    \"&::placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n      opacity: theme.variables.opacity.visible,\n    },\n    \"&:-ms-input-placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n    },\n    \"&::-ms-input-placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n    },\n    ...(hasError && {\n      boxShadow: `0 0 0 1px inset ${theme.values.color.border.error.default}`,\n    }),\n  })\n);\n\nexport const PasswordInputRaw = forwardRef(\n  (\n    {\n      name,\n      value,\n      placeholder,\n      hasError = false,\n      disabled,\n      onChange,\n      onClick,\n      onBlur,\n      onFocus,\n      onIconClick,\n      areaLabel,\n      tabIndex,\n      autoComplete,\n      iconAriaLabel,\n      readOnly,\n    }: PasswordInputProps,\n    ref: RefObject<HTMLInputElement>\n  ): React.ReactElement => {\n    const [inputType, setInputType] = useState(\"password\");\n    const currentType = inputType === \"password\" ? \"text\" : \"password\";\n    const eyeIcon = inputType === \"password\" ? \"eye-off\" : \"eye\";\n\n    return (\n      <StyledContainer>\n        <StyledPasswordInput\n          type={inputType}\n          value={value}\n          placeholder={!readOnly && placeholder}\n          name={name}\n          disabled={disabled}\n          onClick={onClick}\n          onChange={onChange}\n          onBlur={onBlur}\n          onFocus={onFocus}\n          aria-label={areaLabel}\n          ref={ref}\n          tabIndex={tabIndex}\n          autoComplete={autoComplete}\n          hasError={hasError}\n          readOnly={readOnly}\n        />\n        <StyledIconBtn\n          onClick={(e: React.MouseEvent) => {\n            if (disabled) {\n              e.preventDefault();\n            }\n            if (onIconClick) {\n              onIconClick(e);\n            }\n            setInputType(currentType);\n          }}\n          hasError={hasError}\n          disabled={readOnly || disabled}\n          aria-label={iconAriaLabel}\n          type=\"button\"\n        >\n          <Icon\n            name={eyeIcon}\n            size=\"s\"\n            color={readOnly ? \"quaternary\" : \"tertiary\"}\n          />\n        </StyledIconBtn>\n      </StyledContainer>\n    );\n  }\n);\n\nexport const PasswordInput = React.forwardRef(\n  (\n    {\n      name,\n      value,\n      placeholder = \"••••••••\",\n      hasError = false,\n      onChange,\n      onClick,\n      onBlur,\n      onFocus,\n      onIconClick,\n      tabIndex,\n      areaLabel,\n      autoComplete = \"on\",\n      iconAriaLabel,\n      disabled,\n      readOnly,\n      ...rest\n    }: PasswordInputProps,\n    ref: React.RefObject<HTMLInputElement>\n  ): React.ReactElement => (\n    <FormField\n      data-ds-id=\"PasswordInput\"\n      disabled={disabled}\n      {...(rest as FormFieldProps)}\n    >\n      <PasswordInputRaw\n        ref={ref}\n        name={name}\n        value={value}\n        placeholder={placeholder}\n        hasError={hasError}\n        disabled={disabled}\n        onChange={onChange}\n        onBlur={onBlur}\n        onFocus={onFocus}\n        onClick={onClick}\n        onIconClick={onIconClick}\n        tabIndex={tabIndex}\n        areaLabel={areaLabel}\n        autoComplete={autoComplete}\n        iconAriaLabel={iconAriaLabel}\n        readOnly={readOnly}\n      />\n    </FormField>\n  )\n);\n"],"names":[],"mappings":"AA6EsB"} */"),StyledPasswordInput=/*#__PURE__*/styled("input",{target:"e12olo7k2",label:"StyledPasswordInput"})(({theme,hasError,readOnly})=>({fontFamily:theme.variables.fontFamily.lato,fontSize:theme.variables.size.font.m,lineHeight:theme.variables.size.lineHeight.xl,borderRadius:theme.variables.size.borderRadius.xs,borderWidth:"1px",borderStyle:"solid",width:"100%",padding:`calc(${theme.variables.size.spacing.xs} - 1px) ${theme.variables.size.spacing.s}`,paddingRight:theme.variables.size.spacing.xxl,boxSizing:"border-box",color:theme.values.color.text.secondary.default,borderColor:handleBorderColor(theme,hasError,readOnly),backgroundColor:theme.values.color.background.primary.default,"&.error":{borderColor:theme.values.color.border.error.default},"&.has-icon":{paddingRight:theme.variables.size.spacing.xs+theme.variables.size.dimension.icon.m},"&::placeholder":{fontStyle:"italic",color:theme.values.color.text.tertiary.default,opacity:theme.variables.opacity.visible},"&:-ms-input-placeholder":{fontStyle:"italic",color:theme.values.color.text.tertiary.default},"&::-ms-input-placeholder":{fontStyle:"italic",color:theme.values.color.text.tertiary.default},...hasError&&{boxShadow:`0 0 0 1px inset ${theme.values.color.border.error.default}`}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/PasswordInput/PasswordInput.tsx","sources":["src/components/Form/PasswordInput/PasswordInput.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n\nimport type { RefObject } from \"react\";\nimport React, { useState, forwardRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { CSSObject, Theme } from \"@emotion/react\";\nimport { Icon } from \"../../Icon/Icon\";\nimport type { FormFieldProps } from \"../FormField/FormField\";\nimport { FormField } from \"../FormField/FormField\";\n\nexport type PasswordInputProps = {\n  iconAriaLabel: string;\n} & InputProps;\n\ntype InputProps = {\n  name: string;\n  value: string;\n  placeholder?: string;\n  /**\n   * Set to true to toggle error state\n   */\n  hasError?: boolean;\n  /**\n   * Set to true to disabled input\n   */\n  disabled?: boolean;\n  readOnly?: boolean;\n  onChange?: (e: React.ChangeEvent<HTMLInputElement>) => void;\n  onClick?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onIconClick?: (e: React.MouseEvent) => void;\n  onBlur?: (e: React.FormEvent<HTMLInputElement>) => void;\n  onFocus?: (e: React.FormEvent<HTMLInputElement>) => void;\n  areaLabel?: string;\n  tabIndex?: number;\n  autoComplete?: string;\n} & FormFieldProps;\n\ntype IconProps = {\n  hasError?: boolean;\n  disabled?: boolean;\n  onChange?: (e: React.FormEvent<HTMLInputElement>) => void;\n  tabIndex?: number;\n};\n\nconst handleBorderColor = (\n  theme: Theme,\n  hasError: boolean,\n  readOnly: boolean\n) => {\n  if (hasError) return theme.values.color.border.error.default;\n  if (readOnly) return theme.values.color.border.primary.disabled;\n\n  return theme.values.color.border.primary.default;\n};\n\nconst handleIconBorderColor = (theme: Theme, hasError: boolean) => {\n  if (hasError) return theme.values.color.icon.error.default;\n  return \"transparent\";\n};\n\nconst handleIconLeftBorderColor = (theme: Theme, hasError: boolean) => {\n  if (hasError) return theme.values.color.border.error.default;\n  return theme.values.color.border.primary.default;\n};\n\nconst StyledContainer = styled.div(\n  () =>\n    ({\n      width: \"100%\",\n      display: \"flex\",\n      alignItems: \"center\",\n      flexDirection: \"row\",\n      position: \"relative\",\n      zIndex: 1,\n    } as CSSObject)\n);\n\nconst StyledIconBtn = styled.button<IconProps>(({ theme, hasError }) => ({\n  \"&[type='button']\": {\n    appearance: \"none\",\n    MozAppearance: \"none\",\n    WebkitAppearance: \"none\",\n  },\n  position: \"absolute\",\n  top: 0,\n  right: 0,\n  zIndex: 2,\n  border: \"1px solid\",\n  borderColor: handleIconBorderColor(theme, hasError),\n  borderLeftColor: handleIconLeftBorderColor(theme, hasError),\n  padding: `calc(${theme.variables.size.spacing.s} - 1px) ${theme.variables.size.spacing.s}`,\n  borderRadius: theme.variables.size.borderRadius.xs,\n  borderBottomLeftRadius: \"0\",\n  borderTopLeftRadius: \"0\",\n  color: theme.values.color.text.secondary.default,\n  backgroundColor: \"inherit\",\n  cursor: \"pointer\",\n  \"&:hover\": {\n    backgroundColor: theme.values.color.background.transparent.hover,\n    borderColor: theme.values.color.border.primary.default,\n  },\n  \"&:active\": {\n    color: theme.values.color.text.primary.default,\n    backgroundColor: theme.values.color.background.transparent.active,\n    borderColor: theme.values.color.border.primary.active,\n  },\n  \"&:disabled\": {\n    backgroundColor: theme.values.color.background.transparent.default,\n    borderLeftColor: theme.values.color.border.primary.disabled,\n    pointerEvents: \"none\",\n  },\n  ...(hasError && {\n    boxShadow: `0 0 0 1px inset ${theme.values.color.border.error.default}`,\n  }),\n  \"& svg\": {\n    pointerEvents: \"none\",\n  },\n}));\n\nconst StyledPasswordInput = styled.input<InputProps>(\n  ({ theme, hasError, readOnly }) => ({\n    fontFamily: theme.variables.fontFamily.lato,\n    fontSize: theme.variables.size.font.m,\n    lineHeight: theme.variables.size.lineHeight.xl,\n    borderRadius: theme.variables.size.borderRadius.xs,\n    borderWidth: \"1px\",\n    borderStyle: \"solid\",\n    width: \"100%\",\n    padding: `calc(${theme.variables.size.spacing.xs} - 1px) ${theme.variables.size.spacing.s}`,\n    paddingRight: theme.variables.size.spacing.xxl,\n    boxSizing: \"border-box\",\n    color: theme.values.color.text.secondary.default,\n    borderColor: handleBorderColor(theme, hasError, readOnly),\n    backgroundColor: theme.values.color.background.primary.default,\n    \"&.error\": {\n      borderColor: theme.values.color.border.error.default,\n    },\n    \"&.has-icon\": {\n      paddingRight:\n        theme.variables.size.spacing.xs + theme.variables.size.dimension.icon.m,\n    },\n    \"&::placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n      opacity: theme.variables.opacity.visible,\n    },\n    \"&:-ms-input-placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n    },\n    \"&::-ms-input-placeholder\": {\n      fontStyle: \"italic\",\n      color: theme.values.color.text.tertiary.default,\n    },\n    ...(hasError && {\n      boxShadow: `0 0 0 1px inset ${theme.values.color.border.error.default}`,\n    }),\n  })\n);\n\nexport const PasswordInputRaw = forwardRef(\n  (\n    {\n      name,\n      value,\n      placeholder,\n      hasError = false,\n      disabled,\n      onChange,\n      onClick,\n      onBlur,\n      onFocus,\n      onIconClick,\n      areaLabel,\n      tabIndex,\n      autoComplete,\n      iconAriaLabel,\n      readOnly,\n    }: PasswordInputProps,\n    ref: RefObject<HTMLInputElement>\n  ): React.ReactElement => {\n    const [inputType, setInputType] = useState(\"password\");\n    const currentType = inputType === \"password\" ? \"text\" : \"password\";\n    const eyeIcon = inputType === \"password\" ? \"eye-off\" : \"eye\";\n\n    return (\n      <StyledContainer>\n        <StyledPasswordInput\n          type={inputType}\n          value={value}\n          placeholder={!readOnly && placeholder}\n          name={name}\n          disabled={disabled}\n          onClick={onClick}\n          onChange={onChange}\n          onBlur={onBlur}\n          onFocus={onFocus}\n          aria-label={areaLabel}\n          ref={ref}\n          tabIndex={tabIndex}\n          autoComplete={autoComplete}\n          hasError={hasError}\n          readOnly={readOnly}\n        />\n        <StyledIconBtn\n          onClick={(e: React.MouseEvent) => {\n            if (disabled) {\n              e.preventDefault();\n            }\n            if (onIconClick) {\n              onIconClick(e);\n            }\n            setInputType(currentType);\n          }}\n          hasError={hasError}\n          disabled={readOnly || disabled}\n          aria-label={iconAriaLabel}\n          type=\"button\"\n        >\n          <Icon\n            name={eyeIcon}\n            size=\"s\"\n            color={readOnly ? \"quaternary\" : \"tertiary\"}\n          />\n        </StyledIconBtn>\n      </StyledContainer>\n    );\n  }\n);\n\nexport const PasswordInput = React.forwardRef(\n  (\n    {\n      name,\n      value,\n      placeholder = \"••••••••\",\n      hasError = false,\n      onChange,\n      onClick,\n      onBlur,\n      onFocus,\n      onIconClick,\n      tabIndex,\n      areaLabel,\n      autoComplete = \"on\",\n      iconAriaLabel,\n      disabled,\n      readOnly,\n      ...rest\n    }: PasswordInputProps,\n    ref: React.RefObject<HTMLInputElement>\n  ): React.ReactElement => (\n    <FormField\n      data-ds-id=\"PasswordInput\"\n      disabled={disabled}\n      {...(rest as FormFieldProps)}\n    >\n      <PasswordInputRaw\n        ref={ref}\n        name={name}\n        value={value}\n        placeholder={placeholder}\n        hasError={hasError}\n        disabled={disabled}\n        onChange={onChange}\n        onBlur={onBlur}\n        onFocus={onFocus}\n        onClick={onClick}\n        onIconClick={onIconClick}\n        tabIndex={tabIndex}\n        areaLabel={areaLabel}\n        autoComplete={autoComplete}\n        iconAriaLabel={iconAriaLabel}\n        readOnly={readOnly}\n      />\n    </FormField>\n  )\n);\n"],"names":[],"mappings":"AAuH4B"} */");export const PasswordInputRaw=/*#__PURE__*/forwardRef(({name,value,placeholder,hasError=!1,disabled,onChange,onClick,onBlur,onFocus,onIconClick,areaLabel,tabIndex,autoComplete,iconAriaLabel,readOnly},ref)=>{let[inputType,setInputType]=useState("password"),currentType="password"===inputType?"text":"password";return /*#__PURE__*/React.createElement(StyledContainer,null,/*#__PURE__*/React.createElement(StyledPasswordInput,{type:inputType,value:value,placeholder:!readOnly&&placeholder,name:name,disabled:disabled,onClick:onClick,onChange:onChange,onBlur:onBlur,onFocus:onFocus,"aria-label":areaLabel,ref:ref,tabIndex:tabIndex,autoComplete:autoComplete,hasError:hasError,readOnly:readOnly}),/*#__PURE__*/React.createElement(StyledIconBtn,{onClick:e=>{disabled&&e.preventDefault(),onIconClick&&onIconClick(e),setInputType(currentType)},hasError:hasError,disabled:readOnly||disabled,"aria-label":iconAriaLabel,type:"button"},/*#__PURE__*/React.createElement(Icon,{name:"password"===inputType?"eye-off":"eye",size:"s",color:readOnly?"quaternary":"tertiary"})))});export const PasswordInput=/*#__PURE__*/React.forwardRef(({name,value,placeholder="••••••••",hasError=!1,onChange,onClick,onBlur,onFocus,onIconClick,tabIndex,areaLabel,autoComplete="on",iconAriaLabel,disabled,readOnly,...rest},ref)=>/*#__PURE__*/React.createElement(FormField,{"data-ds-id":"PasswordInput",disabled:disabled,...rest},/*#__PURE__*/React.createElement(PasswordInputRaw,{ref:ref,name:name,value:value,placeholder:placeholder,hasError:hasError,disabled:disabled,onChange:onChange,onBlur:onBlur,onFocus:onFocus,onClick:onClick,onIconClick:onIconClick,tabIndex:tabIndex,areaLabel:areaLabel,autoComplete:autoComplete,iconAriaLabel:iconAriaLabel,readOnly:readOnly})));
@@ -0,0 +1,36 @@
1
+ import type { HTMLAttributes, ReactElement } from "react";
2
+ import React from "react";
3
+ import type { Property } from "csstype";
4
+ import type { MQ, SpaceSizes } from "../../types";
5
+ import type { GridItemProps } from "./GridItem";
6
+ import { GridItem } from "./GridItem";
7
+ export type GridProps = {
8
+ /** Define spacing between columns */
9
+ columnGap?: SpaceSizes | MQ<SpaceSizes>;
10
+ /** Define spacing between rows */
11
+ rowGap?: SpaceSizes | MQ<SpaceSizes>;
12
+ /** Define track sizing for explicit grid row tracks, see https://developer.mozilla.org/en-US/docs/Web/CSS/grid-template-rows */
13
+ templateRows?: Property.GridTemplateRows | MQ<Property.GridTemplateRows>;
14
+ /** Define track sizing for explicit grid column tracks, see https://developer.mozilla.org/en-US/docs/Web/CSS/grid-template-columns
15
+ * Overrides 12 column grid
16
+ */
17
+ templateColumns?: Property.GridTemplateColumns | MQ<Property.GridTemplateColumns>;
18
+ /** Define layout with areas, see https://developer.mozilla.org/en-US/docs/Web/CSS/grid-template-areas */
19
+ templateAreas?: Property.GridTemplateAreas | MQ<Property.GridTemplateAreas>;
20
+ /** Define row track size for implicit grid rows, see https://developer.mozilla.org/en-US/docs/Web/CSS/grid-auto-rows */
21
+ autoRows?: Property.GridAutoRows | MQ<Property.GridAutoRows>;
22
+ /** Aligns grid items along the block (column) axis, see https://developer.mozilla.org/en-US/docs/Web/CSS/align-items */
23
+ alignItems?: Property.AlignItems | MQ<Property.AlignItems>;
24
+ /** Aligns grid items along the inline (row) axis, see https://developer.mozilla.org/en-US/docs/Web/CSS/justify-items */
25
+ justifyItems?: Property.JustifyItems | MQ<Property.JustifyItems>;
26
+ /** Displays an inline grid */
27
+ inline?: boolean;
28
+ /** If set to true, it will share parent column tracks */
29
+ isSubgrid?: boolean;
30
+ "data-e2e-test-id"?: string;
31
+ children: ReactElement<GridItemProps>[];
32
+ } & HTMLAttributes<HTMLDivElement>;
33
+ export declare function Grid({ columnGap, rowGap, "data-e2e-test-id": dataE2eTestId, children, ...rest }: GridProps): React.ReactElement;
34
+ export declare namespace Grid {
35
+ var Item: typeof GridItem;
36
+ }
@@ -0,0 +1 @@
1
+ import React from"react";import styled from"@emotion/styled";import{mqValue,mq}from"../../shared/mediaQueries";import{GridItem}from"./GridItem";let StyledContainer=/*#__PURE__*/styled("div",{target:"eksqp4f0",label:"StyledContainer"})(({theme,templateColumns,templateRows,autoRows,templateAreas,inline,columnGap,alignItems,justifyItems,isSubgrid})=>{function getTrackSize(size){return`calc((100% - 11 * ${theme.variables.size.spacing[size]}) / 12)`}return{width:"100%",display:inline?"inline-grid":"grid",gridAutoFlow:"row",...mqValue({gridTemplateColumns:templateColumns||(isSubgrid?"subgrid":Array.isArray(columnGap)?columnGap.map(value=>`repeat(12, ${getTrackSize(value)})`):`repeat(12, ${getTrackSize(columnGap)})`),gridTemplateRows:templateRows,gridAutoRows:autoRows,gridTemplateAreas:templateAreas,alignItems,justifyItems})}},({theme,columnGap,rowGap})=>mq({gridColumnGap:[columnGap,theme.variables.size.spacing],gridRowGap:[rowGap,theme.variables.size.spacing]}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvR3JpZC9HcmlkLnRzeCIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvR3JpZC9HcmlkLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IEhUTUxBdHRyaWJ1dGVzLCBSZWFjdEVsZW1lbnQgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBSZWFjdCBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHR5cGUgeyBQcm9wZXJ0eSB9IGZyb20gXCJjc3N0eXBlXCI7XG5pbXBvcnQgeyBtcVZhbHVlLCBtcSB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5pbXBvcnQgdHlwZSB7IE1RLCBTcGFjZVNpemVzIH0gZnJvbSBcIi4uLy4uL3R5cGVzXCI7XG5pbXBvcnQgdHlwZSB7IEdyaWRJdGVtUHJvcHMgfSBmcm9tIFwiLi9HcmlkSXRlbVwiO1xuaW1wb3J0IHsgR3JpZEl0ZW0gfSBmcm9tIFwiLi9HcmlkSXRlbVwiO1xuXG5leHBvcnQgdHlwZSBHcmlkUHJvcHMgPSB7XG4gIC8qKiBEZWZpbmUgc3BhY2luZyBiZXR3ZWVuIGNvbHVtbnMgKi9cbiAgY29sdW1uR2FwPzogU3BhY2VTaXplcyB8IE1RPFNwYWNlU2l6ZXM+O1xuICAvKiogRGVmaW5lIHNwYWNpbmcgYmV0d2VlbiByb3dzICovXG4gIHJvd0dhcD86IFNwYWNlU2l6ZXMgfCBNUTxTcGFjZVNpemVzPjtcbiAgLyoqIERlZmluZSB0cmFjayBzaXppbmcgZm9yIGV4cGxpY2l0IGdyaWQgcm93IHRyYWNrcywgc2VlIGh0dHBzOi8vZGV2ZWxvcGVyLm1vemlsbGEub3JnL2VuLVVTL2RvY3MvV2ViL0NTUy9ncmlkLXRlbXBsYXRlLXJvd3MgKi9cbiAgdGVtcGxhdGVSb3dzPzogUHJvcGVydHkuR3JpZFRlbXBsYXRlUm93cyB8IE1RPFByb3BlcnR5LkdyaWRUZW1wbGF0ZVJvd3M+O1xuICAvKiogRGVmaW5lIHRyYWNrIHNpemluZyBmb3IgZXhwbGljaXQgZ3JpZCBjb2x1bW4gdHJhY2tzLCBzZWUgaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvQ1NTL2dyaWQtdGVtcGxhdGUtY29sdW1uc1xuICAgKiBPdmVycmlkZXMgMTIgY29sdW1uIGdyaWRcbiAgICovXG4gIHRlbXBsYXRlQ29sdW1ucz86XG4gICAgfCBQcm9wZXJ0eS5HcmlkVGVtcGxhdGVDb2x1bW5zXG4gICAgfCBNUTxQcm9wZXJ0eS5HcmlkVGVtcGxhdGVDb2x1bW5zPjtcbiAgLyoqIERlZmluZSBsYXlvdXQgd2l0aCBhcmVhcywgc2VlIGh0dHBzOi8vZGV2ZWxvcGVyLm1vemlsbGEub3JnL2VuLVVTL2RvY3MvV2ViL0NTUy9ncmlkLXRlbXBsYXRlLWFyZWFzICovXG4gIHRlbXBsYXRlQXJlYXM/OiBQcm9wZXJ0eS5HcmlkVGVtcGxhdGVBcmVhcyB8IE1RPFByb3BlcnR5LkdyaWRUZW1wbGF0ZUFyZWFzPjtcbiAgLyoqIERlZmluZSByb3cgdHJhY2sgc2l6ZSBmb3IgaW1wbGljaXQgZ3JpZCByb3dzLCBzZWUgaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvQ1NTL2dyaWQtYXV0by1yb3dzICovXG4gIGF1dG9Sb3dzPzogUHJvcGVydHkuR3JpZEF1dG9Sb3dzIHwgTVE8UHJvcGVydHkuR3JpZEF1dG9Sb3dzPjtcbiAgLyoqIEFsaWducyBncmlkIGl0ZW1zIGFsb25nIHRoZSBibG9jayAoY29sdW1uKSBheGlzLCBzZWUgaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvQ1NTL2FsaWduLWl0ZW1zICovXG4gIGFsaWduSXRlbXM/OiBQcm9wZXJ0eS5BbGlnbkl0ZW1zIHwgTVE8UHJvcGVydHkuQWxpZ25JdGVtcz47XG4gIC8qKiBBbGlnbnMgZ3JpZCBpdGVtcyBhbG9uZyB0aGUgaW5saW5lIChyb3cpIGF4aXMsIHNlZSBodHRwczovL2RldmVsb3Blci5tb3ppbGxhLm9yZy9lbi1VUy9kb2NzL1dlYi9DU1MvanVzdGlmeS1pdGVtcyAqL1xuICBqdXN0aWZ5SXRlbXM/OiBQcm9wZXJ0eS5KdXN0aWZ5SXRlbXMgfCBNUTxQcm9wZXJ0eS5KdXN0aWZ5SXRlbXM+O1xuICAvKiogRGlzcGxheXMgYW4gaW5saW5lIGdyaWQgKi9cbiAgaW5saW5lPzogYm9vbGVhbjtcbiAgLyoqIElmIHNldCB0byB0cnVlLCBpdCB3aWxsIHNoYXJlIHBhcmVudCBjb2x1bW4gdHJhY2tzICovXG4gIGlzU3ViZ3JpZD86IGJvb2xlYW47XG4gIFwiZGF0YS1lMmUtdGVzdC1pZFwiPzogc3RyaW5nO1xuICBjaGlsZHJlbjogUmVhY3RFbGVtZW50PEdyaWRJdGVtUHJvcHM+W107XG59ICYgSFRNTEF0dHJpYnV0ZXM8SFRNTERpdkVsZW1lbnQ+O1xuXG5jb25zdCBUT1RBTF9DT0xVTU5TID0gMTI7XG5cbmNvbnN0IFN0eWxlZENvbnRhaW5lciA9IHN0eWxlZC5kaXY8R3JpZFByb3BzPihcbiAgKHtcbiAgICB0aGVtZSxcbiAgICB0ZW1wbGF0ZUNvbHVtbnMsXG4gICAgdGVtcGxhdGVSb3dzLFxuICAgIGF1dG9Sb3dzLFxuICAgIHRlbXBsYXRlQXJlYXMsXG4gICAgaW5saW5lLFxuICAgIGNvbHVtbkdhcCxcbiAgICBhbGlnbkl0ZW1zLFxuICAgIGp1c3RpZnlJdGVtcyxcbiAgICBpc1N1YmdyaWQsXG4gIH0pID0+IHtcbiAgICBmdW5jdGlvbiBnZXRUcmFja1NpemUoc2l6ZTogU3BhY2VTaXplcykge1xuICAgICAgcmV0dXJuIGBjYWxjKCgxMDAlIC0gJHtUT1RBTF9DT0xVTU5TIC0gMX0gKiAke1xuICAgICAgICB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nW3NpemVdXG4gICAgICB9KSAvICR7VE9UQUxfQ09MVU1OU30pYDtcbiAgICB9XG5cbiAgICBmdW5jdGlvbiBnZXRUZW1wbGF0ZUNvbHVtbnNWYWx1ZXMoKSB7XG4gICAgICBpZiAodGVtcGxhdGVDb2x1bW5zKSB7XG4gICAgICAgIHJldHVybiB0ZW1wbGF0ZUNvbHVtbnM7XG4gICAgICB9XG5cbiAgICAgIGlmIChpc1N1YmdyaWQpIHtcbiAgICAgICAgcmV0dXJuIFwic3ViZ3JpZFwiO1xuICAgICAgfVxuXG4gICAgICBpZiAoQXJyYXkuaXNBcnJheShjb2x1bW5HYXApKSB7XG4gICAgICAgIHJldHVybiBjb2x1bW5HYXAubWFwKFxuICAgICAgICAgICh2YWx1ZSkgPT4gYHJlcGVhdCgke1RPVEFMX0NPTFVNTlN9LCAke2dldFRyYWNrU2l6ZSh2YWx1ZSl9KWBcbiAgICAgICAgKTtcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIGByZXBlYXQoJHtUT1RBTF9DT0xVTU5TfSwgJHtnZXRUcmFja1NpemUoXG4gICAgICAgIGNvbHVtbkdhcCBhcyBTcGFjZVNpemVzXG4gICAgICApfSlgO1xuICAgIH1cblxuICAgIHJldHVybiB7XG4gICAgICB3aWR0aDogXCIxMDAlXCIsXG4gICAgICBkaXNwbGF5OiBpbmxpbmUgPyBcImlubGluZS1ncmlkXCIgOiBcImdyaWRcIixcbiAgICAgIGdyaWRBdXRvRmxvdzogXCJyb3dcIixcblxuICAgICAgLi4ubXFWYWx1ZSh7XG4gICAgICAgIGdyaWRUZW1wbGF0ZUNvbHVtbnM6IGdldFRlbXBsYXRlQ29sdW1uc1ZhbHVlcygpLFxuICAgICAgICBncmlkVGVtcGxhdGVSb3dzOiB0ZW1wbGF0ZVJvd3MsXG4gICAgICAgIGdyaWRBdXRvUm93czogYXV0b1Jvd3MsXG4gICAgICAgIGdyaWRUZW1wbGF0ZUFyZWFzOiB0ZW1wbGF0ZUFyZWFzLFxuICAgICAgICBhbGlnbkl0ZW1zLFxuICAgICAgICBqdXN0aWZ5SXRlbXMsXG4gICAgICB9KSxcbiAgICB9O1xuICB9LFxuICAoeyB0aGVtZSwgY29sdW1uR2FwLCByb3dHYXAgfSkgPT5cbiAgICBtcSh7XG4gICAgICBncmlkQ29sdW1uR2FwOiBbY29sdW1uR2FwLCB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nXSxcbiAgICAgIGdyaWRSb3dHYXA6IFtyb3dHYXAsIHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmddLFxuICAgIH0pXG4pO1xuXG4vKiBlc2xpbnQtZGlzYWJsZSByZWFjdC9qc3gtcHJvcHMtbm8tc3ByZWFkaW5nICovXG5cbmV4cG9ydCBmdW5jdGlvbiBHcmlkKHtcbiAgY29sdW1uR2FwID0gXCJtXCIsXG4gIHJvd0dhcCA9IFwibVwiLFxuICBcImRhdGEtZTJlLXRlc3QtaWRcIjogZGF0YUUyZVRlc3RJZCxcbiAgY2hpbGRyZW4sXG4gIC4uLnJlc3Rcbn06IEdyaWRQcm9wcyk6IFJlYWN0LlJlYWN0RWxlbWVudCB7XG4gIHJldHVybiAoXG4gICAgPFN0eWxlZENvbnRhaW5lclxuICAgICAgZGF0YS1lMmUtdGVzdC1pZD17ZGF0YUUyZVRlc3RJZH1cbiAgICAgIGRhdGEtZHMtaWQ9XCJHcmlkXCJcbiAgICAgIGNvbHVtbkdhcD17Y29sdW1uR2FwfVxuICAgICAgcm93R2FwPXtyb3dHYXB9XG4gICAgICB7Li4ucmVzdH1cbiAgICA+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9TdHlsZWRDb250YWluZXI+XG4gICk7XG59XG4vKiBlc2xpbnQtZW5hYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cblxuR3JpZC5JdGVtID0gR3JpZEl0ZW07XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBd0N3QiJ9 */");export function Grid({columnGap="m",rowGap="m","data-e2e-test-id":dataE2eTestId,children,...rest}){return /*#__PURE__*/React.createElement(StyledContainer,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":"Grid",columnGap:columnGap,rowGap:rowGap,...rest},children)}Grid.Item=GridItem;
@@ -0,0 +1,32 @@
1
+ import type { ReactNode, HTMLAttributes } from "react";
2
+ import React from "react";
3
+ import type { Property } from "csstype";
4
+ import type { MQ } from "../../types";
5
+ type ColumnSpans = 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12;
6
+ export type GridItemProps = {
7
+ /** Size of grid area in columns */
8
+ columnSpan?: ColumnSpans | MQ<ColumnSpans>;
9
+ /** Starting column for item positioning, see https://developer.mozilla.org/en-US/docs/Web/CSS/grid-column-start */
10
+ columnStart?: Property.GridColumnStart | MQ<Property.GridColumnStart>;
11
+ /** Ending column for item positioning, see https://developer.mozilla.org/en-US/docs/Web/CSS/grid-column-end */
12
+ columnEnd?: Property.GridColumnEnd | MQ<Property.GridColumnEnd>;
13
+ /** Row position, see https://developer.mozilla.org/en-US/docs/Web/CSS/grid-row */
14
+ row?: Property.GridRow | MQ<Property.GridRow>;
15
+ /** Starting row for item positioning, see https://developer.mozilla.org/en-US/docs/Web/CSS/grid-row-start */
16
+ rowStart?: Property.GridRowStart | MQ<Property.GridRowStart>;
17
+ /** Ending row for item positioning, see https://developer.mozilla.org/en-US/docs/Web/CSS/grid-row-end */
18
+ rowEnd?: Property.GridRowEnd | MQ<Property.GridRowEnd>;
19
+ /** Define grid area, see https://developer.mozilla.org/en-US/docs/Web/CSS/grid-area */
20
+ area?: Property.GridArea | MQ<Property.GridArea>;
21
+ /** Align item in its grid area along block (column) axis, see https://developer.mozilla.org/en-US/docs/Web/CSS/align-self */
22
+ alignSelf?: Property.AlignSelf | MQ<Property.AlignSelf>;
23
+ /** Justify item in its grid area along inline (row) axis, see https://developer.mozilla.org/en-US/docs/Web/CSS/justify-self */
24
+ justifySelf?: Property.JustifySelf | MQ<Property.JustifySelf>;
25
+ order?: Property.Order | MQ<Property.Order>;
26
+ /** display item at given breakpoint */
27
+ show?: boolean | MQ<boolean>;
28
+ children: ReactNode;
29
+ "data-e2e-test-id"?: string;
30
+ } & HTMLAttributes<HTMLDivElement>;
31
+ export declare function GridItem({ "data-e2e-test-id": dataE2eTestId, children, ...rest }: GridItemProps): React.ReactElement;
32
+ export {};
@@ -0,0 +1 @@
1
+ import React from"react";import styled from"@emotion/styled";import{mqValue,mq}from"../../shared/mediaQueries";let StyledContainer=/*#__PURE__*/styled("div",{target:"e8rzzus0",label:"StyledContainer"})(({row,area,alignSelf,justifySelf,rowStart,rowEnd,order})=>({...mqValue({gridRow:row,gridArea:area,gridRowStart:rowStart,gridRowEnd:rowEnd,alignSelf,justifySelf,order})}),({columnSpan})=>({...columnSpan&&mqValue({gridColumn:Array.isArray(columnSpan)?columnSpan.map(value=>`auto / span ${value}`):`auto / span ${columnSpan}`})}),({columnStart,columnEnd})=>mqValue({gridColumnStart:columnStart,gridColumnEnd:columnEnd}),({show})=>mq({display:[show,value=>value?"block":"none"]}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvR3JpZC9HcmlkSXRlbS50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0dyaWQvR3JpZEl0ZW0udHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgUmVhY3ROb2RlLCBIVE1MQXR0cmlidXRlcyB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgdHlwZSB7IFByb3BlcnR5IH0gZnJvbSBcImNzc3R5cGVcIjtcbmltcG9ydCB7IG1xVmFsdWUsIG1xIH0gZnJvbSBcIi4uLy4uL3NoYXJlZC9tZWRpYVF1ZXJpZXNcIjtcbmltcG9ydCB0eXBlIHsgTVEgfSBmcm9tIFwiLi4vLi4vdHlwZXNcIjtcblxudHlwZSBDb2x1bW5TcGFucyA9IDEgfCAyIHwgMyB8IDQgfCA1IHwgNiB8IDcgfCA4IHwgOSB8IDEwIHwgMTEgfCAxMjtcblxuZXhwb3J0IHR5cGUgR3JpZEl0ZW1Qcm9wcyA9IHtcbiAgLyoqIFNpemUgb2YgZ3JpZCBhcmVhIGluIGNvbHVtbnMgKi9cbiAgY29sdW1uU3Bhbj86IENvbHVtblNwYW5zIHwgTVE8Q29sdW1uU3BhbnM+O1xuICAvKiogU3RhcnRpbmcgY29sdW1uIGZvciBpdGVtIHBvc2l0aW9uaW5nLCBzZWUgaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvQ1NTL2dyaWQtY29sdW1uLXN0YXJ0ICovXG4gIGNvbHVtblN0YXJ0PzogUHJvcGVydHkuR3JpZENvbHVtblN0YXJ0IHwgTVE8UHJvcGVydHkuR3JpZENvbHVtblN0YXJ0PjtcbiAgLyoqIEVuZGluZyBjb2x1bW4gZm9yIGl0ZW0gcG9zaXRpb25pbmcsIHNlZSBodHRwczovL2RldmVsb3Blci5tb3ppbGxhLm9yZy9lbi1VUy9kb2NzL1dlYi9DU1MvZ3JpZC1jb2x1bW4tZW5kICovXG4gIGNvbHVtbkVuZD86IFByb3BlcnR5LkdyaWRDb2x1bW5FbmQgfCBNUTxQcm9wZXJ0eS5HcmlkQ29sdW1uRW5kPjtcbiAgLyoqIFJvdyBwb3NpdGlvbiwgc2VlIGh0dHBzOi8vZGV2ZWxvcGVyLm1vemlsbGEub3JnL2VuLVVTL2RvY3MvV2ViL0NTUy9ncmlkLXJvdyAqL1xuICByb3c/OiBQcm9wZXJ0eS5HcmlkUm93IHwgTVE8UHJvcGVydHkuR3JpZFJvdz47XG4gIC8qKiBTdGFydGluZyByb3cgZm9yIGl0ZW0gcG9zaXRpb25pbmcsIHNlZSBodHRwczovL2RldmVsb3Blci5tb3ppbGxhLm9yZy9lbi1VUy9kb2NzL1dlYi9DU1MvZ3JpZC1yb3ctc3RhcnQgKi9cbiAgcm93U3RhcnQ/OiBQcm9wZXJ0eS5HcmlkUm93U3RhcnQgfCBNUTxQcm9wZXJ0eS5HcmlkUm93U3RhcnQ+O1xuICAvKiogRW5kaW5nIHJvdyBmb3IgaXRlbSBwb3NpdGlvbmluZywgc2VlIGh0dHBzOi8vZGV2ZWxvcGVyLm1vemlsbGEub3JnL2VuLVVTL2RvY3MvV2ViL0NTUy9ncmlkLXJvdy1lbmQgICovXG4gIHJvd0VuZD86IFByb3BlcnR5LkdyaWRSb3dFbmQgfCBNUTxQcm9wZXJ0eS5HcmlkUm93RW5kPjtcbiAgLyoqIERlZmluZSBncmlkIGFyZWEsIHNlZSBodHRwczovL2RldmVsb3Blci5tb3ppbGxhLm9yZy9lbi1VUy9kb2NzL1dlYi9DU1MvZ3JpZC1hcmVhICovXG4gIGFyZWE/OiBQcm9wZXJ0eS5HcmlkQXJlYSB8IE1RPFByb3BlcnR5LkdyaWRBcmVhPjtcbiAgLyoqIEFsaWduIGl0ZW0gaW4gaXRzIGdyaWQgYXJlYSBhbG9uZyBibG9jayAoY29sdW1uKSBheGlzLCBzZWUgaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvQ1NTL2FsaWduLXNlbGYgKi9cbiAgYWxpZ25TZWxmPzogUHJvcGVydHkuQWxpZ25TZWxmIHwgTVE8UHJvcGVydHkuQWxpZ25TZWxmPjtcbiAgLyoqIEp1c3RpZnkgaXRlbSBpbiBpdHMgZ3JpZCBhcmVhIGFsb25nIGlubGluZSAocm93KSBheGlzLCBzZWUgaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvQ1NTL2p1c3RpZnktc2VsZiAqL1xuICBqdXN0aWZ5U2VsZj86IFByb3BlcnR5Lkp1c3RpZnlTZWxmIHwgTVE8UHJvcGVydHkuSnVzdGlmeVNlbGY+O1xuICBvcmRlcj86IFByb3BlcnR5Lk9yZGVyIHwgTVE8UHJvcGVydHkuT3JkZXI+O1xuICAvKiogZGlzcGxheSBpdGVtIGF0IGdpdmVuIGJyZWFrcG9pbnQgKi9cbiAgc2hvdz86IGJvb2xlYW4gfCBNUTxib29sZWFuPjtcbiAgY2hpbGRyZW46IFJlYWN0Tm9kZTtcbiAgXCJkYXRhLWUyZS10ZXN0LWlkXCI/OiBzdHJpbmc7XG59ICYgSFRNTEF0dHJpYnV0ZXM8SFRNTERpdkVsZW1lbnQ+O1xuXG5mdW5jdGlvbiBnZXRDb2x1bW5TcGFuVmFsdWVzKFxuICBjb2x1bW5TcGFuOiBHcmlkSXRlbVByb3BzW1wiY29sdW1uU3BhblwiXVxuKTogc3RyaW5nIHwgc3RyaW5nW10ge1xuICBpZiAoQXJyYXkuaXNBcnJheShjb2x1bW5TcGFuKSkge1xuICAgIHJldHVybiBjb2x1bW5TcGFuLm1hcCgodmFsdWUpID0+IGBhdXRvIC8gc3BhbiAke3ZhbHVlfWApO1xuICB9XG5cbiAgcmV0dXJuIGBhdXRvIC8gc3BhbiAke2NvbHVtblNwYW59YDtcbn1cblxuY29uc3QgU3R5bGVkQ29udGFpbmVyID0gc3R5bGVkLmRpdjxHcmlkSXRlbVByb3BzPihcbiAgKHsgcm93LCBhcmVhLCBhbGlnblNlbGYsIGp1c3RpZnlTZWxmLCByb3dTdGFydCwgcm93RW5kLCBvcmRlciB9KSA9PiAoe1xuICAgIC4uLm1xVmFsdWUoe1xuICAgICAgZ3JpZFJvdzogcm93LFxuICAgICAgZ3JpZEFyZWE6IGFyZWEsXG4gICAgICBncmlkUm93U3RhcnQ6IHJvd1N0YXJ0LFxuICAgICAgZ3JpZFJvd0VuZDogcm93RW5kLFxuICAgICAgYWxpZ25TZWxmLFxuICAgICAganVzdGlmeVNlbGYsXG4gICAgICBvcmRlcixcbiAgICB9KSxcbiAgfSksXG4gICh7IGNvbHVtblNwYW4gfSkgPT4gKHtcbiAgICAuLi4oY29sdW1uU3BhbiAmJlxuICAgICAgbXFWYWx1ZSh7XG4gICAgICAgIGdyaWRDb2x1bW46IGdldENvbHVtblNwYW5WYWx1ZXMoY29sdW1uU3BhbiksXG4gICAgICB9KSksXG4gIH0pLFxuICAoeyBjb2x1bW5TdGFydCwgY29sdW1uRW5kIH0pID0+XG4gICAgbXFWYWx1ZSh7XG4gICAgICBncmlkQ29sdW1uU3RhcnQ6IGNvbHVtblN0YXJ0LFxuICAgICAgZ3JpZENvbHVtbkVuZDogY29sdW1uRW5kLFxuICAgIH0pLFxuICAoeyBzaG93IH0pID0+XG4gICAgbXEoe1xuICAgICAgZGlzcGxheTogW3Nob3csICh2YWx1ZTogYm9vbGVhbikgPT4gKHZhbHVlID8gXCJibG9ja1wiIDogXCJub25lXCIpXSxcbiAgICB9KVxuKTtcblxuLyogZXNsaW50LWRpc2FibGUgcmVhY3QvanN4LXByb3BzLW5vLXNwcmVhZGluZyAqL1xuXG5leHBvcnQgZnVuY3Rpb24gR3JpZEl0ZW0oe1xuICBcImRhdGEtZTJlLXRlc3QtaWRcIjogZGF0YUUyZVRlc3RJZCxcbiAgY2hpbGRyZW4sXG4gIC4uLnJlc3Rcbn06IEdyaWRJdGVtUHJvcHMpOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICByZXR1cm4gKFxuICAgIDxTdHlsZWRDb250YWluZXJcbiAgICAgIGRhdGEtZTJlLXRlc3QtaWQ9e2RhdGFFMmVUZXN0SWR9XG4gICAgICBkYXRhLWRzLWlkPVwiR3JpZEl0ZW1cIlxuICAgICAgey4uLnJlc3R9XG4gICAgPlxuICAgICAge2NoaWxkcmVufVxuICAgIDwvU3R5bGVkQ29udGFpbmVyPlxuICApO1xufVxuXG4vKiBlc2xpbnQtZW5hYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE2Q3dCIn0= */");export function GridItem({"data-e2e-test-id":dataE2eTestId,children,...rest}){return /*#__PURE__*/React.createElement(StyledContainer,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":"GridItem",...rest},children)}
@@ -3,6 +3,7 @@ export type SheetProps = {
3
3
  id?: string;
4
4
  /** contents */
5
5
  children: React.ReactNode;
6
+ hasBackdrop?: boolean;
6
7
  portalContainer?: HTMLElement;
7
8
  isVisible: boolean;
8
9
  "data-e2e-test-id"?: string;
@@ -13,4 +14,4 @@ export type SheetProps = {
13
14
  disableReturnFocusToTrigger?: boolean;
14
15
  onClickOutsideDeactivates?: (evt: MouseEvent) => boolean;
15
16
  };
16
- export declare function Sheet({ id, children, isVisible, onClose, onUnmount, portalContainer, dismissOnOutsideClick, disableInitialFocus, disableReturnFocusToTrigger, onClickOutsideDeactivates, "data-e2e-test-id": dataE2eTestId, }: SheetProps): React.ReactElement;
17
+ export declare function Sheet({ id, children, hasBackdrop, isVisible, onClose, onUnmount, portalContainer, dismissOnOutsideClick, disableInitialFocus, disableReturnFocusToTrigger, onClickOutsideDeactivates, "data-e2e-test-id": dataE2eTestId, }: SheetProps): React.ReactElement;