@amboss/design-system 3.1.5 → 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 (41) 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/index.d.ts +1 -0
  11. package/build/cjs/index.js +1 -1
  12. package/build/cjs/shared/mediaQueries.d.ts +2 -2
  13. package/build/cjs/shared/mediaQueries.js +1 -1
  14. package/build/cjs/web-tokens/assets/icons16.json +1 -1
  15. package/build/esm/components/BulkActionsToolbar/BulkActionsToolbar.d.ts +2 -1
  16. package/build/esm/components/BulkActionsToolbar/BulkActionsToolbar.js +1 -1
  17. package/build/esm/components/Column/Columns.d.ts +2 -0
  18. package/build/esm/components/Column/Columns.js +1 -1
  19. package/build/esm/components/Form/PasswordInput/PasswordInput.js +1 -1
  20. package/build/esm/components/Grid/Grid.d.ts +36 -0
  21. package/build/esm/components/Grid/Grid.js +1 -0
  22. package/build/esm/components/Grid/GridItem.d.ts +32 -0
  23. package/build/esm/components/Grid/GridItem.js +1 -0
  24. package/build/esm/index.d.ts +1 -0
  25. package/build/esm/index.js +1 -1
  26. package/build/esm/shared/mediaQueries.d.ts +2 -2
  27. package/build/esm/shared/mediaQueries.js +1 -1
  28. package/build/esm/web-tokens/assets/icons16.json +1 -1
  29. package/package.json +1 -1
  30. package/build/cjs/components/Toolbar/Toolbar.d.ts +0 -7
  31. package/build/cjs/components/Toolbar/Toolbar.js +0 -1
  32. package/build/cjs/components/Toolbar/ToolbarGroup.d.ts +0 -5
  33. package/build/cjs/components/Toolbar/ToolbarGroup.js +0 -1
  34. package/build/cjs/components/Toolbar/index.d.ts +0 -4
  35. package/build/cjs/components/Toolbar/index.js +0 -1
  36. package/build/esm/components/Toolbar/Toolbar.d.ts +0 -7
  37. package/build/esm/components/Toolbar/Toolbar.js +0 -1
  38. package/build/esm/components/Toolbar/ToolbarGroup.d.ts +0 -5
  39. package/build/esm/components/Toolbar/ToolbarGroup.js +0 -1
  40. package/build/esm/components/Toolbar/index.d.ts +0 -4
  41. 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)}
@@ -68,3 +68,4 @@ export * from "./components/EntityTree";
68
68
  export * from "./components/EntityList";
69
69
  export * from "./components/Form/Select";
70
70
  export * from "./components/BinaryFeedback/BinaryFeedback";
71
+ export * from "./components/Grid/Grid";
@@ -1 +1 @@
1
- import{ambossVisualConfiguration}from"./web-tokens/visualConfig";export const{dark,light}=ambossVisualConfiguration;export{ThemeProvider,CacheProvider}from"@emotion/react";export{default as createCache}from"@emotion/cache";export*from"./components/Card/Card";export*from"./components/Card/CardBox";export*from"./components/Box/Box";export*from"./components/Inline/Inline";export*from"./components/Stack/Stack";export*from"./components/Typography/Header/Header";export*from"./components/Typography/Text/Text";export*from"./components/Typography/TextClamped/TextClamped";export*from"./components/Typography/StyledText/StyledText";export*from"./components/Link/Link";export*from"./components/Icon/Icon";export*from"./components/Button/Button";export*from"./components/BulkActionsToolbar/BulkActionsToolbar";export*from"./components/Divider/Divider";export*from"./components/Column/Columns";export*from"./components/Form/SearchInput/SearchInput";export*from"./components/Tabs/Tabs";export*from"./components/Badge/Badge";export*from"./components/SearchResult/SearchResult";export*from"./components/Form/ToggleButton/ToggleButton";export*from"./components/DropdownMenu/DropdownMenu";export*from"./components/Form/FormFieldGroup/FormFieldGroup";export*from"./components/Form/Input";export*from"./components/Form/Checkbox/Checkbox";export*from"./components/Form/Toggle/Toggle";export*from"./components/Form/Radio/Radio";export*from"./components/Form/RadioButton/RadioButton";export*from"./components/Form/RangeInput/RangeInput";export*from"./components/Form/Textarea/Textarea";export*from"./components/Form/Combobox/Combobox";export*from"./components/SubThemeProvider/SubThemeProvider";export*from"./components/PictogramButton/PictogramButton";export*from"./components/MediaViewerBar/MediaViewerBar";export*from"./components/SegmentedProgressBar/SegmentedProgressBar";export*from"./components/ProgressBar/ProgressBar";export*from"./components/Container/Container";export*from"./components/Form/PasswordInput";export*from"./components/RoundButton/RoundButton";export*from"./components/Notification/Notification";export*from"./components/Logo/Logo";export*from"./components/MediaItem/MediaItem";export*from"./components/Callout/Callout";export*from"./components/Patterns/Modal/Modal";export*from"./components/Patterns/ButtonGroup/ButtonGroup";export*from"./components/Collapsible/Collapsible";export*from"./components/LoadingSpinner/LoadingSpinner";export*from"./components/Pagination/Pagination";export*from"./components/DataTable";export*from"./components/Form/SegmentedControl/SegmentedControl";export*from"./components/Tooltip/Tooltip";export*from"./components/Tag/Tag";export*from"./components/TagGroup/TagGroup";export*from"./components/Toggletip/Toggletip";export*from"./components/Popover/Popover";export*from"./components/UserHighlightTooltip/UserHighlightTooltip";export*from"./components/Sheet/Sheet";export*from"./components/Image/Image";export*from"./components/Form/MaskedInput/MaskedInput";export*from"./components/Utilities/Expandable/Expandable";export*from"./components/QBankRichText/QBankRichText";export*from"./components/Tutorialtip/Tutorialtip";export*from"./components/EntityTree";export*from"./components/EntityList";export*from"./components/Form/Select";export*from"./components/BinaryFeedback/BinaryFeedback";
1
+ import{ambossVisualConfiguration}from"./web-tokens/visualConfig";export const{dark,light}=ambossVisualConfiguration;export{ThemeProvider,CacheProvider}from"@emotion/react";export{default as createCache}from"@emotion/cache";export*from"./components/Card/Card";export*from"./components/Card/CardBox";export*from"./components/Box/Box";export*from"./components/Inline/Inline";export*from"./components/Stack/Stack";export*from"./components/Typography/Header/Header";export*from"./components/Typography/Text/Text";export*from"./components/Typography/TextClamped/TextClamped";export*from"./components/Typography/StyledText/StyledText";export*from"./components/Link/Link";export*from"./components/Icon/Icon";export*from"./components/Button/Button";export*from"./components/BulkActionsToolbar/BulkActionsToolbar";export*from"./components/Divider/Divider";export*from"./components/Column/Columns";export*from"./components/Form/SearchInput/SearchInput";export*from"./components/Tabs/Tabs";export*from"./components/Badge/Badge";export*from"./components/SearchResult/SearchResult";export*from"./components/Form/ToggleButton/ToggleButton";export*from"./components/DropdownMenu/DropdownMenu";export*from"./components/Form/FormFieldGroup/FormFieldGroup";export*from"./components/Form/Input";export*from"./components/Form/Checkbox/Checkbox";export*from"./components/Form/Toggle/Toggle";export*from"./components/Form/Radio/Radio";export*from"./components/Form/RadioButton/RadioButton";export*from"./components/Form/RangeInput/RangeInput";export*from"./components/Form/Textarea/Textarea";export*from"./components/Form/Combobox/Combobox";export*from"./components/SubThemeProvider/SubThemeProvider";export*from"./components/PictogramButton/PictogramButton";export*from"./components/MediaViewerBar/MediaViewerBar";export*from"./components/SegmentedProgressBar/SegmentedProgressBar";export*from"./components/ProgressBar/ProgressBar";export*from"./components/Container/Container";export*from"./components/Form/PasswordInput";export*from"./components/RoundButton/RoundButton";export*from"./components/Notification/Notification";export*from"./components/Logo/Logo";export*from"./components/MediaItem/MediaItem";export*from"./components/Callout/Callout";export*from"./components/Patterns/Modal/Modal";export*from"./components/Patterns/ButtonGroup/ButtonGroup";export*from"./components/Collapsible/Collapsible";export*from"./components/LoadingSpinner/LoadingSpinner";export*from"./components/Pagination/Pagination";export*from"./components/DataTable";export*from"./components/Form/SegmentedControl/SegmentedControl";export*from"./components/Tooltip/Tooltip";export*from"./components/Tag/Tag";export*from"./components/TagGroup/TagGroup";export*from"./components/Toggletip/Toggletip";export*from"./components/Popover/Popover";export*from"./components/UserHighlightTooltip/UserHighlightTooltip";export*from"./components/Sheet/Sheet";export*from"./components/Image/Image";export*from"./components/Form/MaskedInput/MaskedInput";export*from"./components/Utilities/Expandable/Expandable";export*from"./components/QBankRichText/QBankRichText";export*from"./components/Tutorialtip/Tutorialtip";export*from"./components/EntityTree";export*from"./components/EntityList";export*from"./components/Form/Select";export*from"./components/BinaryFeedback/BinaryFeedback";export*from"./components/Grid/Grid";
@@ -1,9 +1,9 @@
1
1
  import type { ColumnSizes, HorizontalAlignment, MQ, SpaceSizes, TextAlignment, VerticalAlignment, StackHorizontalAlignment, StackVerticalAlignment, Order, ColumnAlignment, Hyphens, BorderRadius } from "../types";
2
2
  type MqProp<T> = [
3
3
  T | MQ<T>,
4
- Record<T extends string ? T : never, string | number>
4
+ (Record<T extends string ? T : never, string | number> | ((value: T) => string | number))
5
5
  ];
6
- type MqRules = Record<string, MqProp<TextAlignment> | MqProp<SpaceSizes> | MqProp<HorizontalAlignment> | MqProp<VerticalAlignment> | MqProp<StackHorizontalAlignment> | MqProp<StackVerticalAlignment> | MqProp<ColumnSizes> | MqProp<Order> | MqProp<ColumnAlignment> | MqProp<Hyphens> | MqProp<BorderRadius>>;
6
+ type MqRules = Record<string, MqProp<TextAlignment> | MqProp<SpaceSizes> | MqProp<HorizontalAlignment> | MqProp<VerticalAlignment> | MqProp<StackHorizontalAlignment> | MqProp<StackVerticalAlignment> | MqProp<ColumnSizes> | MqProp<Order> | MqProp<ColumnAlignment> | MqProp<Hyphens> | MqProp<BorderRadius> | MqProp<boolean>>;
7
7
  type EmotionCssPropertyName = string;
8
8
  type EmotionCssValue = string | number;
9
9
  type EmotionCssDescription = Record<EmotionCssPropertyName, EmotionCssValue>;
@@ -1 +1 @@
1
- var breakpointRules,breakpointRules1;import breakpoints from"../web-tokens/_breakpoints.json";export const mq=(breakpointRules=[`@media (max-width: ${breakpoints.medium.value}px)`,`@media (min-width: ${breakpoints.medium.value}px) and (max-width: ${breakpoints.large.value}px)`,`@media (min-width: ${breakpoints.large.value}px)`],rules=>{let res={};return breakpointRules.forEach(key=>{res[key]={}}),res["@media screen"]={},Object.entries(rules).forEach(([cssProperty,[prop,map]])=>{if(Array.isArray(prop)){let sm=prop[0],md=prop[1]||prop[0],lg=prop[2]||prop[1]||prop[0],[s,m,l]=breakpointRules;res[s][cssProperty]=map[sm],res[m][cssProperty]=map[md],res[l][cssProperty]=map[lg]}else res["@media screen"][cssProperty]=map[prop]}),res});export const mqValue=(breakpointRules1=[`@media (max-width: ${breakpoints.medium.value}px)`,`@media (min-width: ${breakpoints.medium.value}px) and (max-width: ${breakpoints.large.value}px)`,`@media (min-width: ${breakpoints.large.value}px)`],rules=>{let res={};return breakpointRules1.forEach(key=>{res[key]={}}),res["@media screen"]={},Object.entries(rules).forEach(([cssProperty,cssValues])=>{Array.isArray(cssValues)?breakpointRules1.forEach((breakpoint,index)=>{let i=index;for(;!cssValues[i]&&0!==i;)i-=1;res[breakpoint][cssProperty]=cssValues[i]}):res["@media screen"][cssProperty]=cssValues}),res});export function getMediaQueryClasses(s,styles,prefix=""){let res;if(void 0===s)return[];if(Array.isArray(s)){let sm=s[0],md=s[1]||s[0],lg=s[2]||s[1]||s[0];res=[`${sm}-small`,`${md}-medium`,`${lg}-large`]}else res=[s];return res.map(cl=>`${prefix}${cl}`).map(cl=>styles[cl])}
1
+ var breakpointRules,breakpointRules1;import breakpoints from"../web-tokens/_breakpoints.json";export const mq=(breakpointRules=[`@media (max-width: ${breakpoints.medium.value}px)`,`@media (min-width: ${breakpoints.medium.value}px) and (max-width: ${breakpoints.large.value}px)`,`@media (min-width: ${breakpoints.large.value}px)`],rules=>{let res={};return breakpointRules.forEach(key=>{res[key]={}}),res["@media screen"]={},Object.entries(rules).forEach(([cssProperty,[prop,map]])=>{let getValue=value=>void 0!==value?map(value):value;if(Array.isArray(prop)){let sm=prop[0],md=prop[1]??prop[0],lg=prop[2]??prop[1]??prop[0],[s,m,l]=breakpointRules;res[s][cssProperty]="function"==typeof map?getValue(sm):map[sm],res[m][cssProperty]="function"==typeof map?getValue(md):map[md],res[l][cssProperty]="function"==typeof map?getValue(lg):map[lg]}else res["@media screen"][cssProperty]="function"==typeof map?getValue(prop):map[prop]}),res});export const mqValue=(breakpointRules1=[`@media (max-width: ${breakpoints.medium.value}px)`,`@media (min-width: ${breakpoints.medium.value}px) and (max-width: ${breakpoints.large.value}px)`,`@media (min-width: ${breakpoints.large.value}px)`],rules=>{let res={};return breakpointRules1.forEach(key=>{res[key]={}}),res["@media screen"]={},Object.entries(rules).forEach(([cssProperty,cssValues])=>{Array.isArray(cssValues)?breakpointRules1.forEach((breakpoint,index)=>{let i=index;for(;!cssValues[i]&&0!==i;)i-=1;res[breakpoint][cssProperty]=cssValues[i]}):res["@media screen"][cssProperty]=cssValues}),res});export function getMediaQueryClasses(s,styles,prefix=""){let res;if(void 0===s)return[];if(Array.isArray(s)){let sm=s[0],md=s[1]||s[0],lg=s[2]||s[1]||s[0];res=[`${sm}-small`,`${md}-medium`,`${lg}-large`]}else res=[s];return res.map(cl=>`${prefix}${cl}`).map(cl=>styles[cl])}
@@ -12,7 +12,7 @@
12
12
  "arrow-left": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\">\n <g stroke=\"currentColor\" stroke-linecap=\"round\" stroke-width=\"2\">\n <path stroke-linejoin=\"bevel\" d=\"M4 8h10\" />\n <path stroke-linejoin=\"round\" d=\"M6 12L2 8l4-4\" />\n </g>\n</svg>",
13
13
  "arrow-right": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\">\n <g stroke=\"currentColor\" stroke-linecap=\"round\" stroke-width=\"2\">\n <path stroke-linejoin=\"bevel\" d=\"M2 8h10\" />\n <path stroke-linejoin=\"round\" d=\"M10 4l4 4-4 4\" />\n </g>\n</svg>",
14
14
  "arrow-up": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" class=\"feather feather-arrow-up\"><line x1=\"12\" y1=\"19\" x2=\"12\" y2=\"5\"></line><polyline points=\"5 12 12 5 19 12\"></polyline></svg>",
15
- "article": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\">\n <g stroke=\"currentColor\" stroke-width=\"2\">\n <path d=\"M5 5h6M5 8h4M5 11h5\" />\n <rect width=\"12\" height=\"14\" x=\"2\" y=\"1\" rx=\"1\" />\n </g>\n</svg>",
15
+ "article": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\">\n <path fill=\"currentColor\" fill-rule=\"evenodd\" d=\"M3 2h10v12H3V2ZM1 2a2 2 0 0 1 2-2h10a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H3a2 2 0 0 1-2-2V2Zm10 4H5V4h6v2ZM5 9h4V7H5v2Zm0 3h5v-2H5v2Z\" clip-rule=\"evenodd\"/>\n</svg>",
16
16
  "auditor": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\">\n <circle cx=\"4\" cy=\"5\" r=\"3\" stroke=\"currentColor\" stroke-width=\"2\" />\n <circle cx=\"12\" cy=\"5\" r=\"3\" stroke=\"currentColor\" stroke-width=\"2\" />\n <g fill=\"currentColor\">\n <path\n d=\"M7 6h2V4H7zM14.807 10.79A.667.667 0 0116 11.2c0 2.205-1.953 4.067-4.267 4.067-1.562 0-2.957-.758-3.734-1.943-.78 1.188-2.172 1.943-3.732 1.943C1.954 15.267 0 13.405 0 11.2a.667.667 0 011.193-.41c.19.244.719.81 1.54.81.688 0 1.337-.343 1.615-.853.424-.742 1.2-1.214 1.985-1.214A2.32 2.32 0 018 10.25a2.322 2.322 0 011.667-.716c.785 0 1.562.472 1.978 1.204.286.52.935.863 1.622.863.822 0 1.351-.566 1.54-.81z\" />\n </g>\n</svg>",
17
17
  "bar-chart-2": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\">\n <path fill=\"currentColor\"\n d=\"M5 10a1 1 0 00-2 0zm4-7a1 1 0 00-2 0zm4 4a1 1 0 10-2 0zm-8 7v-4H3v4zm4 0V3H7v11zm4 0V7h-2v7z\" />\n</svg>",
18
18
  "bell": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\">\n <g stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\">\n <path\n d=\"M12 5.6c0-.955-.421-1.87-1.172-2.546C10.078 2.38 9.061 2 8 2s-2.078.38-2.828 1.054C4.422 3.73 4 4.645 4 5.6 4 9.8 2 11 2 11h12s-2-1.2-2-5.4zM9.153 14a1.333 1.333 0 01-2.306 0\" />\n </g>\n</svg>",
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@amboss/design-system",
3
- "version": "3.1.5",
3
+ "version": "3.2.0",
4
4
  "description": "the design system for AMBOSS products",
5
5
  "author": "AMBOSS",
6
6
  "license": "ISC",
@@ -1,7 +0,0 @@
1
- import React from "react";
2
- import { type ColumnsProps } from "../Column/Columns";
3
- export type ToolbarProps = {
4
- children: ColumnsProps["children"];
5
- "data-e2e-test-id"?: string;
6
- };
7
- export declare function Toolbar({ children, "data-e2e-test-id": dataE2eTestId, }: ToolbarProps): React.ReactElement;
@@ -1 +0,0 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"Toolbar",{enumerable:!0,get:function(){return Toolbar}});const _react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_default")._(require("react")),_Columns=require("../Column/Columns"),_Box=require("../Box/Box");function Toolbar({children,"data-e2e-test-id":dataE2eTestId}){return /*#__PURE__*/_react.default.createElement(_Box.Box,{space:"xs",lSpace:["xs","m"],"data-e2e-test-id":dataE2eTestId,"data-ds-id":"Toolbar"},/*#__PURE__*/_react.default.createElement(_Columns.Columns,{vAlignItems:"center",gap:["xs","m"],alignItems:"spaceBetween"},children))}
@@ -1,5 +0,0 @@
1
- import React from "react";
2
- import { type ColumnProps } from "../Column/Columns";
3
- import { type InlineProps } from "../Inline/Inline";
4
- export type ToolbarGroupProps = Partial<ColumnProps> & Pick<InlineProps, "children">;
5
- export declare function ToolbarGroup({ children, size, ...restColumnProps }: ToolbarGroupProps): React.ReactElement;
@@ -1 +0,0 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"ToolbarGroup",{enumerable:!0,get:function(){return ToolbarGroup}});const _react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_default")._(require("react")),_Columns=require("../Column/Columns"),_Inline=require("../Inline/Inline");function ToolbarGroup({children,size=[12,6],...restColumnProps}){return /*#__PURE__*/_react.default.createElement(_Columns.Column,{...restColumnProps,size:size},_react.default.Children.count(children)>1?/*#__PURE__*/_react.default.createElement(_Inline.Inline,{vAlignItems:"center",alignItems:["spaceBetween","left"],noWrap:!0},children):children)}
@@ -1,4 +0,0 @@
1
- export { Toolbar } from "./Toolbar";
2
- export type { ToolbarProps } from "./Toolbar";
3
- export { ToolbarGroup } from "./ToolbarGroup";
4
- export type { ToolbarGroupProps } from "./ToolbarGroup";
@@ -1 +0,0 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),function(target,all){for(var name in all)Object.defineProperty(target,name,{enumerable:!0,get:all[name]})}(exports,{Toolbar:function(){return _Toolbar.Toolbar},ToolbarGroup:function(){return _ToolbarGroup.ToolbarGroup}});const _Toolbar=require("./Toolbar"),_ToolbarGroup=require("./ToolbarGroup");
@@ -1,7 +0,0 @@
1
- import React from "react";
2
- import { type ColumnsProps } from "../Column/Columns";
3
- export type ToolbarProps = {
4
- children: ColumnsProps["children"];
5
- "data-e2e-test-id"?: string;
6
- };
7
- export declare function Toolbar({ children, "data-e2e-test-id": dataE2eTestId, }: ToolbarProps): React.ReactElement;
@@ -1 +0,0 @@
1
- import React from"react";import{Columns}from"../Column/Columns";import{Box}from"../Box/Box";export function Toolbar({children,"data-e2e-test-id":dataE2eTestId}){return /*#__PURE__*/React.createElement(Box,{space:"xs",lSpace:["xs","m"],"data-e2e-test-id":dataE2eTestId,"data-ds-id":"Toolbar"},/*#__PURE__*/React.createElement(Columns,{vAlignItems:"center",gap:["xs","m"],alignItems:"spaceBetween"},children))}
@@ -1,5 +0,0 @@
1
- import React from "react";
2
- import { type ColumnProps } from "../Column/Columns";
3
- import { type InlineProps } from "../Inline/Inline";
4
- export type ToolbarGroupProps = Partial<ColumnProps> & Pick<InlineProps, "children">;
5
- export declare function ToolbarGroup({ children, size, ...restColumnProps }: ToolbarGroupProps): React.ReactElement;
@@ -1 +0,0 @@
1
- import React from"react";import{Column}from"../Column/Columns";import{Inline}from"../Inline/Inline";export function ToolbarGroup({children,size=[12,6],...restColumnProps}){return /*#__PURE__*/React.createElement(Column,{...restColumnProps,size:size},React.Children.count(children)>1?/*#__PURE__*/React.createElement(Inline,{vAlignItems:"center",alignItems:["spaceBetween","left"],noWrap:!0},children):children)}
@@ -1,4 +0,0 @@
1
- export { Toolbar } from "./Toolbar";
2
- export type { ToolbarProps } from "./Toolbar";
3
- export { ToolbarGroup } from "./ToolbarGroup";
4
- export type { ToolbarGroupProps } from "./ToolbarGroup";
@@ -1 +0,0 @@
1
- export{Toolbar}from"./Toolbar";export{ToolbarGroup}from"./ToolbarGroup";