@ultraviolet/ui 3.0.0-beta.2 → 3.0.0-beta.4

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 (36) hide show
  1. package/dist/components/ActionBar/index.cjs +5 -30
  2. package/dist/components/ActionBar/index.js +5 -28
  3. package/dist/components/ActionBar/styles.css.cjs +8 -0
  4. package/dist/components/ActionBar/styles.css.d.ts +2 -0
  5. package/dist/components/ActionBar/styles.css.js +8 -0
  6. package/dist/components/Badge/constant.cjs +8 -0
  7. package/dist/components/Badge/constant.d.ts +14 -0
  8. package/dist/components/Badge/constant.js +8 -0
  9. package/dist/components/Badge/index.cjs +10 -88
  10. package/dist/components/Badge/index.d.ts +2 -20
  11. package/dist/components/Badge/index.js +8 -84
  12. package/dist/components/Badge/styles.css.cjs +6 -0
  13. package/dist/components/Badge/styles.css.d.ts +43 -0
  14. package/dist/components/Badge/styles.css.js +6 -0
  15. package/dist/components/Button/index.cjs +1 -1
  16. package/dist/components/Button/index.js +1 -1
  17. package/dist/components/Button/styles.css.d.ts +4 -4
  18. package/dist/components/Chip/index.d.ts +1 -1
  19. package/dist/components/ExpandableCard/index.cjs +10 -9
  20. package/dist/components/ExpandableCard/index.d.ts +3 -1
  21. package/dist/components/ExpandableCard/index.js +10 -9
  22. package/dist/components/NumberInput/index.d.ts +1 -1
  23. package/dist/components/Popup/index.cjs +21 -7
  24. package/dist/components/Popup/index.js +21 -7
  25. package/dist/components/Slider/styles.d.ts +1 -1
  26. package/dist/components/Snippet/index.cjs +15 -14
  27. package/dist/components/Snippet/index.js +15 -14
  28. package/dist/components/Tabs/index.d.ts +1 -1
  29. package/dist/components/TextArea/index.cjs +6 -6
  30. package/dist/components/TextArea/index.js +6 -6
  31. package/dist/components/TextInput/index.d.ts +1 -1
  32. package/dist/components/Tooltip/index.d.ts +1 -1
  33. package/dist/ui.css +1 -1
  34. package/dist/utils/animationVanillaExtract.css.d.ts +1 -0
  35. package/dist/utils/index.d.ts +1 -0
  36. package/package.json +3 -3
@@ -33,7 +33,7 @@ const PreText = /* @__PURE__ */ _styled(Text, process.env.NODE_ENV === "producti
33
33
  }) => noExpandable ? `
34
34
  max-height: calc(${theme.typography.code.lineHeight} * ${rows} + ${theme.space["3"]});
35
35
  overflow-y: scroll;` : `overflow-y: hidden;
36
- `, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx"],"names":[],"mappings":"AAwBE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx","sourcesContent":["'use client'\n\nimport { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon } from '@ultraviolet/icons'\nimport type { ComponentProps } from 'react'\nimport { Children, useReducer } from 'react'\nimport { CopyButton } from '../CopyButton'\nimport { Expandable } from '../Expandable'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst LINES_BREAK_REGEX = /\\r\\n|\\r|\\n/\n\ntype Prefixes = 'lines' | 'command'\n\nconst PreText = styled(Text, {\n  shouldForwardProp: prop =>\n    !['hasShowMoreButton', 'showMore', 'rows', 'noExpandable'].includes(prop),\n})<{\n  hasShowMoreButton?: boolean\n  showMore?: boolean\n  rows: number\n  noExpandable: boolean\n}>`\n  margin: 0;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-right: ${({ theme }) => theme.space['9']};\n  overflow-x: ${({ hasShowMoreButton, showMore }) =>\n    hasShowMoreButton && !showMore ? 'hidden' : 'auto'};\n  height: auto;\n  counter-reset: section;\n\n\n  ${({ theme, noExpandable, rows }) =>\n    noExpandable\n      ? `\n    max-height: calc(${theme.typography.code.lineHeight} * ${rows} + ${theme.space['3']});\n    overflow-y: scroll;`\n      : `overflow-y: hidden;\n`}\n`\n\nconst StyledSpan = styled('span', {\n  shouldForwardProp: prop =>\n    !['linePrefix', 'multiline', 'prefix'].includes(prop),\n})<{ linePrefix?: string; multiline?: boolean; prefix?: Prefixes }>`\n  display: block;\n\n\n  &:after {\n    content: \"\";\n    ${({ theme, multiline }) =>\n      multiline\n        ? `padding: ${theme.space['4']}`\n        : `padding-right: ${theme.space['8']}`};\n  }\n\n  ${({ prefix, theme }) =>\n    prefix\n      ? `\n    &:before {\n      color: ${theme.colors.neutral.textWeak};\n      width: ${prefix === 'lines' ? '35px' : ''};\n      display: inline-flex;\n      justify-content: flex-end;\n      counter-increment: section;\n      content: ${prefix === 'lines' ? 'counter(section)' : \"'$'\"};\n      padding-right: ${theme.space['1']};\n    }\n  `\n      : null}\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: relative;\n  display: flex;\n  justify-content: start;\n  max-width: 100%;\n  ${({ multiline }) => (multiline ? 'width: 100%;' : '')}\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n`\n\nconst StyledStack = styled(Stack)`\n  width: 100%;\n`\n\nconst ButtonContainer = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: absolute;\n  top: 0;\n  right: 0;\n  padding: ${({ theme, multiline }) =>\n    `${theme.space[multiline ? '2' : '1']} ${theme.space['2']} 0 0`};\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n  border: 2px solid transparent;\n  ${({ multiline, theme }) =>\n    !multiline\n      ? `box-shadow: -27px 0 19px -11px ${theme.colors.neutral.backgroundWeak}`\n      : ''};\n`\n\nconst ShowMoreContainer = styled('div', {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  width: 100%;\n  box-shadow: ${({ theme, showMore }) =>\n    !showMore\n      ? `0px -22px 19px -6px\n    ${theme.colors.neutral.backgroundWeak}`\n      : 'none'};\n`\n\nconst StyledButton = styled.button`\n  width: 100%;\n  background: none;\n  border: none;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-top: ${({ theme }) => theme.space['1']};\n  cursor: pointer;\n`\n\nconst AlignCenterText = styled(Text)`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n`\n\nconst AnimatedArrowIcon = styled(ArrowDownIcon, {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  transform: ${({ showMore }) => (showMore ? 'rotate(180deg)' : 'rotate(0deg)')};\n  transform-origin: center;\n  transition: transform 300ms ease-in-out;\n`\n\ntype CodeContentProps = {\n  children: string\n  prefix?: Prefixes\n  multiline?: boolean\n  showMore?: boolean\n  hasShowMoreButton?: boolean\n  lines?: string[]\n  noExpandable: boolean\n  rows: number\n}\n\nconst CodeContent = ({\n  children,\n  prefix,\n  multiline,\n  showMore,\n  hasShowMoreButton,\n  lines,\n  noExpandable,\n  rows,\n}: CodeContentProps) => (\n  <PreText\n    as=\"pre\"\n    hasShowMoreButton={hasShowMoreButton}\n    noExpandable={noExpandable}\n    rows={rows}\n    showMore={showMore}\n    variant=\"code\"\n    whiteSpace={!multiline ? 'nowrap' : undefined}\n  >\n    {multiline ? (\n      Children.map(lines, child => (\n        <StyledSpan key={child} multiline prefix={prefix}>\n          {child}\n        </StyledSpan>\n      ))\n    ) : (\n      <StyledSpan prefix={prefix}>{children}</StyledSpan>\n    )}\n  </PreText>\n)\n\ntype SnippetProps = {\n  className?: string\n  children: string\n  /**\n   * prefix display an element at the beginning of the snippet that is not copiable or selectable.\n   * For `lines` prefix it will display the line number.\n   * For `command` prefix it will display a `$` sign.\n   */\n  prefix?: Prefixes\n  showText?: string\n  hideText?: string\n  'data-testid'?: string\n  initiallyExpanded?: boolean\n  rows?: number\n  noExpandable?: boolean\n  onCopy?: () => void\n} & Pick<ComponentProps<typeof CopyButton>, 'copyText' | 'copiedText'>\n\n/**\n * Snippet component is used to display code snippets with the ability to copy the code.\n * It also has the ability to show/hide the code snippet if it has more than 4 lines.\n */\nexport const Snippet = ({\n  children,\n  copyText,\n  copiedText,\n  showText = 'Show',\n  hideText = 'Hide',\n  prefix,\n  className,\n  'data-testid': dataTestId,\n  initiallyExpanded,\n  rows = 4,\n  noExpandable = false,\n  onCopy,\n}: SnippetProps) => {\n  const theme = useTheme()\n  const [showMore, setShowMore] = useReducer(\n    value => !value,\n    initiallyExpanded ?? false,\n  )\n  const lines = children.split(LINES_BREAK_REGEX)\n\n  const numberOfLines = lines.length\n  const multiline = numberOfLines > 1\n  const hasShowMoreButton = numberOfLines > rows && multiline && !noExpandable\n  // Height of the expandable (when needed) = number of rows * height of a line (from rem to px) + padding (from rem to px)\n  const minHeight =\n    rows * Number.parseFloat(theme.typography.code.lineHeight) * 16 +\n    Number.parseFloat(theme.space[4]) * 16\n\n  return (\n    <Container\n      className={className}\n      data-testid={dataTestId}\n      multiline={multiline}\n    >\n      <StyledStack>\n        {hasShowMoreButton ? (\n          <Expandable minHeight={minHeight} opened={showMore}>\n            <CodeContent\n              lines={lines}\n              multiline={multiline}\n              noExpandable={noExpandable}\n              prefix={prefix}\n              rows={rows}\n            >\n              {children}\n            </CodeContent>\n          </Expandable>\n        ) : (\n          <CodeContent\n            lines={lines}\n            multiline={multiline}\n            noExpandable={noExpandable}\n            prefix={prefix}\n            rows={rows}\n          >\n            {children}\n          </CodeContent>\n        )}\n        <ButtonContainer multiline={multiline && numberOfLines > 1}>\n          <CopyButton\n            copiedText={copiedText}\n            copyText={copyText}\n            onCopy={onCopy}\n            sentiment=\"neutral\"\n            value={children}\n          />\n        </ButtonContainer>\n        {hasShowMoreButton ? (\n          <ShowMoreContainer showMore={showMore}>\n            <StyledButton\n              aria-expanded={showMore}\n              onClick={setShowMore}\n              type=\"button\"\n            >\n              <AlignCenterText\n                as=\"span\"\n                sentiment=\"neutral\"\n                variant=\"bodySmallStrong\"\n              >\n                {showMore ? hideText : showText}\n                &nbsp;\n                <AnimatedArrowIcon showMore={showMore} />\n              </AlignCenterText>\n            </StyledButton>\n          </ShowMoreContainer>\n        ) : null}\n      </StyledStack>\n    </Container>\n  )\n}\n"]} */"));
36
+ `, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx"],"names":[],"mappings":"AAwBE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx","sourcesContent":["'use client'\n\nimport { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon } from '@ultraviolet/icons'\nimport type { ComponentProps } from 'react'\nimport { Children, useReducer } from 'react'\nimport { CopyButton } from '../CopyButton'\nimport { Expandable } from '../Expandable'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst LINES_BREAK_REGEX = /\\r\\n|\\r|\\n/\n\ntype Prefixes = 'lines' | 'command'\n\nconst PreText = styled(Text, {\n  shouldForwardProp: prop =>\n    !['hasShowMoreButton', 'showMore', 'rows', 'noExpandable'].includes(prop),\n})<{\n  hasShowMoreButton?: boolean\n  showMore?: boolean\n  rows: number\n  noExpandable: boolean\n}>`\n  margin: 0;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-right: ${({ theme }) => theme.space['9']};\n  overflow-x: ${({ hasShowMoreButton, showMore }) =>\n    hasShowMoreButton && !showMore ? 'hidden' : 'auto'};\n  height: auto;\n  counter-reset: section;\n\n\n  ${({ theme, noExpandable, rows }) =>\n    noExpandable\n      ? `\n    max-height: calc(${theme.typography.code.lineHeight} * ${rows} + ${theme.space['3']});\n    overflow-y: scroll;`\n      : `overflow-y: hidden;\n`}\n`\n\nconst StyledSpan = styled('span', {\n  shouldForwardProp: prop =>\n    !['linePrefix', 'multiline', 'prefix'].includes(prop),\n})<{ linePrefix?: string; multiline?: boolean; prefix?: Prefixes }>`\n  display: block;\n\n\n  &:not([data-multiline]):after {\n    content: \"\";\n    ${({ theme }) => `padding-right: ${theme.space['8']}`};\n  }\n\n  &[data-multiline=\"true\"]:nth-child(-n+2):after {\n    content: \"\";\n    ${({ theme }) => `padding-right: ${theme.space['8']}`};\n  }\n\n  ${({ prefix, theme }) =>\n    prefix\n      ? `\n    &:before {\n      color: ${theme.colors.neutral.textWeak};\n      width: ${prefix === 'lines' ? '35px' : ''};\n      display: inline-flex;\n      justify-content: flex-end;\n      counter-increment: section;\n      content: ${prefix === 'lines' ? 'counter(section)' : \"'$'\"};\n      padding-right: ${theme.space['1']};\n    }\n  `\n      : null}\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: relative;\n  display: flex;\n  justify-content: start;\n  max-width: 100%;\n  ${({ multiline }) => (multiline ? 'width: 100%;' : '')}\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n`\n\nconst StyledStack = styled(Stack)`\n  width: 100%;\n`\n\nconst ButtonContainer = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: absolute;\n  top: 0;\n  right: 0;\n  padding: ${({ theme, multiline }) =>\n    `${theme.space[multiline ? '2' : '1']} ${theme.space['2']} 0 0`};\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n  border: 2px solid transparent;\n  ${({ multiline, theme }) =>\n    !multiline\n      ? `box-shadow: -27px 0 19px -11px ${theme.colors.neutral.backgroundWeak}`\n      : ''};\n`\n\nconst ShowMoreContainer = styled('div', {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  width: 100%;\n  box-shadow: ${({ theme, showMore }) =>\n    !showMore\n      ? `0px -22px 19px -6px\n    ${theme.colors.neutral.backgroundWeak}`\n      : 'none'};\n`\n\nconst StyledButton = styled.button`\n  width: 100%;\n  background: none;\n  border: none;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-top: ${({ theme }) => theme.space['1']};\n  cursor: pointer;\n`\n\nconst AlignCenterText = styled(Text)`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n`\n\nconst AnimatedArrowIcon = styled(ArrowDownIcon, {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  transform: ${({ showMore }) => (showMore ? 'rotate(180deg)' : 'rotate(0deg)')};\n  transform-origin: center;\n  transition: transform 300ms ease-in-out;\n`\n\ntype CodeContentProps = {\n  children: string\n  prefix?: Prefixes\n  multiline?: boolean\n  showMore?: boolean\n  hasShowMoreButton?: boolean\n  lines?: string[]\n  noExpandable: boolean\n  rows: number\n}\n\nconst CodeContent = ({\n  children,\n  prefix,\n  multiline,\n  showMore,\n  hasShowMoreButton,\n  lines,\n  noExpandable,\n  rows,\n}: CodeContentProps) => (\n  <PreText\n    as=\"pre\"\n    hasShowMoreButton={hasShowMoreButton}\n    noExpandable={noExpandable}\n    rows={rows}\n    showMore={showMore}\n    variant=\"code\"\n    whiteSpace={!multiline ? 'nowrap' : undefined}\n  >\n    {multiline ? (\n      Children.map(lines, child => (\n        <StyledSpan data-multiline=\"true\" key={child} prefix={prefix}>\n          {child}\n        </StyledSpan>\n      ))\n    ) : (\n      <StyledSpan prefix={prefix}>{children}</StyledSpan>\n    )}\n  </PreText>\n)\n\ntype SnippetProps = {\n  className?: string\n  children: string\n  /**\n   * prefix display an element at the beginning of the snippet that is not copiable or selectable.\n   * For `lines` prefix it will display the line number.\n   * For `command` prefix it will display a `$` sign.\n   */\n  prefix?: Prefixes\n  showText?: string\n  hideText?: string\n  'data-testid'?: string\n  initiallyExpanded?: boolean\n  rows?: number\n  noExpandable?: boolean\n  onCopy?: () => void\n} & Pick<ComponentProps<typeof CopyButton>, 'copyText' | 'copiedText'>\n\n/**\n * Snippet component is used to display code snippets with the ability to copy the code.\n * It also has the ability to show/hide the code snippet if it has more than 4 lines.\n */\nexport const Snippet = ({\n  children,\n  copyText,\n  copiedText,\n  showText = 'Show',\n  hideText = 'Hide',\n  prefix,\n  className,\n  'data-testid': dataTestId,\n  initiallyExpanded,\n  rows = 4,\n  noExpandable = false,\n  onCopy,\n}: SnippetProps) => {\n  const theme = useTheme()\n  const [showMore, setShowMore] = useReducer(\n    value => !value,\n    initiallyExpanded ?? false,\n  )\n  const lines = children.split(LINES_BREAK_REGEX)\n\n  const numberOfLines = lines.length\n  const multiline = numberOfLines > 1\n  const hasShowMoreButton = numberOfLines > rows && multiline && !noExpandable\n  // Height of the expandable (when needed) = number of rows * height of a line (from rem to px) + padding (from rem to px)\n  const minHeight =\n    rows * Number.parseFloat(theme.typography.code.lineHeight) * 16 +\n    Number.parseFloat(theme.space[4]) * 16\n\n  return (\n    <Container\n      className={className}\n      data-testid={dataTestId}\n      multiline={multiline}\n    >\n      <StyledStack>\n        {hasShowMoreButton ? (\n          <Expandable minHeight={minHeight} opened={showMore}>\n            <CodeContent\n              lines={lines}\n              multiline={multiline}\n              noExpandable={noExpandable}\n              prefix={prefix}\n              rows={rows}\n            >\n              {children}\n            </CodeContent>\n          </Expandable>\n        ) : (\n          <CodeContent\n            lines={lines}\n            multiline={multiline}\n            noExpandable={noExpandable}\n            prefix={prefix}\n            rows={rows}\n          >\n            {children}\n          </CodeContent>\n        )}\n        <ButtonContainer multiline={multiline && numberOfLines > 1}>\n          <CopyButton\n            copiedText={copiedText}\n            copyText={copyText}\n            onCopy={onCopy}\n            sentiment=\"neutral\"\n            value={children}\n          />\n        </ButtonContainer>\n        {hasShowMoreButton ? (\n          <ShowMoreContainer showMore={showMore}>\n            <StyledButton\n              aria-expanded={showMore}\n              onClick={setShowMore}\n              type=\"button\"\n            >\n              <AlignCenterText\n                as=\"span\"\n                sentiment=\"neutral\"\n                variant=\"bodySmallStrong\"\n              >\n                {showMore ? hideText : showText}\n                &nbsp;\n                <AnimatedArrowIcon showMore={showMore} />\n              </AlignCenterText>\n            </StyledButton>\n          </ShowMoreContainer>\n        ) : null}\n      </StyledStack>\n    </Container>\n  )\n}\n"]} */"));
37
37
  const StyledSpan = /* @__PURE__ */ _styled("span", process.env.NODE_ENV === "production" ? {
38
38
  shouldForwardProp: (prop) => !["linePrefix", "multiline", "prefix"].includes(prop),
39
39
  target: "e1q0gj907"
@@ -41,10 +41,11 @@ const StyledSpan = /* @__PURE__ */ _styled("span", process.env.NODE_ENV === "pro
41
41
  shouldForwardProp: (prop) => !["linePrefix", "multiline", "prefix"].includes(prop),
42
42
  target: "e1q0gj907",
43
43
  label: "StyledSpan"
44
- })('display:block;&:after{content:"";', ({
45
- theme,
46
- multiline
47
- }) => multiline ? `padding: ${theme.space["4"]}` : `padding-right: ${theme.space["8"]}`, ";}", ({
44
+ })('display:block;&:not([data-multiline]):after{content:"";', ({
45
+ theme
46
+ }) => `padding-right: ${theme.space["8"]}`, ';}&[data-multiline="true"]:nth-child(-n+2):after{content:"";', ({
47
+ theme
48
+ }) => `padding-right: ${theme.space["8"]}`, ";}", ({
48
49
  prefix,
49
50
  theme
50
51
  }) => prefix ? `
@@ -57,7 +58,7 @@ const StyledSpan = /* @__PURE__ */ _styled("span", process.env.NODE_ENV === "pro
57
58
  content: ${prefix === "lines" ? "counter(section)" : "'$'"};
58
59
  padding-right: ${theme.space["1"]};
59
60
  }
60
- ` : null, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx"],"names":[],"mappings":"AA8CmE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx","sourcesContent":["'use client'\n\nimport { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon } from '@ultraviolet/icons'\nimport type { ComponentProps } from 'react'\nimport { Children, useReducer } from 'react'\nimport { CopyButton } from '../CopyButton'\nimport { Expandable } from '../Expandable'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst LINES_BREAK_REGEX = /\\r\\n|\\r|\\n/\n\ntype Prefixes = 'lines' | 'command'\n\nconst PreText = styled(Text, {\n  shouldForwardProp: prop =>\n    !['hasShowMoreButton', 'showMore', 'rows', 'noExpandable'].includes(prop),\n})<{\n  hasShowMoreButton?: boolean\n  showMore?: boolean\n  rows: number\n  noExpandable: boolean\n}>`\n  margin: 0;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-right: ${({ theme }) => theme.space['9']};\n  overflow-x: ${({ hasShowMoreButton, showMore }) =>\n    hasShowMoreButton && !showMore ? 'hidden' : 'auto'};\n  height: auto;\n  counter-reset: section;\n\n\n  ${({ theme, noExpandable, rows }) =>\n    noExpandable\n      ? `\n    max-height: calc(${theme.typography.code.lineHeight} * ${rows} + ${theme.space['3']});\n    overflow-y: scroll;`\n      : `overflow-y: hidden;\n`}\n`\n\nconst StyledSpan = styled('span', {\n  shouldForwardProp: prop =>\n    !['linePrefix', 'multiline', 'prefix'].includes(prop),\n})<{ linePrefix?: string; multiline?: boolean; prefix?: Prefixes }>`\n  display: block;\n\n\n  &:after {\n    content: \"\";\n    ${({ theme, multiline }) =>\n      multiline\n        ? `padding: ${theme.space['4']}`\n        : `padding-right: ${theme.space['8']}`};\n  }\n\n  ${({ prefix, theme }) =>\n    prefix\n      ? `\n    &:before {\n      color: ${theme.colors.neutral.textWeak};\n      width: ${prefix === 'lines' ? '35px' : ''};\n      display: inline-flex;\n      justify-content: flex-end;\n      counter-increment: section;\n      content: ${prefix === 'lines' ? 'counter(section)' : \"'$'\"};\n      padding-right: ${theme.space['1']};\n    }\n  `\n      : null}\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: relative;\n  display: flex;\n  justify-content: start;\n  max-width: 100%;\n  ${({ multiline }) => (multiline ? 'width: 100%;' : '')}\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n`\n\nconst StyledStack = styled(Stack)`\n  width: 100%;\n`\n\nconst ButtonContainer = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: absolute;\n  top: 0;\n  right: 0;\n  padding: ${({ theme, multiline }) =>\n    `${theme.space[multiline ? '2' : '1']} ${theme.space['2']} 0 0`};\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n  border: 2px solid transparent;\n  ${({ multiline, theme }) =>\n    !multiline\n      ? `box-shadow: -27px 0 19px -11px ${theme.colors.neutral.backgroundWeak}`\n      : ''};\n`\n\nconst ShowMoreContainer = styled('div', {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  width: 100%;\n  box-shadow: ${({ theme, showMore }) =>\n    !showMore\n      ? `0px -22px 19px -6px\n    ${theme.colors.neutral.backgroundWeak}`\n      : 'none'};\n`\n\nconst StyledButton = styled.button`\n  width: 100%;\n  background: none;\n  border: none;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-top: ${({ theme }) => theme.space['1']};\n  cursor: pointer;\n`\n\nconst AlignCenterText = styled(Text)`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n`\n\nconst AnimatedArrowIcon = styled(ArrowDownIcon, {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  transform: ${({ showMore }) => (showMore ? 'rotate(180deg)' : 'rotate(0deg)')};\n  transform-origin: center;\n  transition: transform 300ms ease-in-out;\n`\n\ntype CodeContentProps = {\n  children: string\n  prefix?: Prefixes\n  multiline?: boolean\n  showMore?: boolean\n  hasShowMoreButton?: boolean\n  lines?: string[]\n  noExpandable: boolean\n  rows: number\n}\n\nconst CodeContent = ({\n  children,\n  prefix,\n  multiline,\n  showMore,\n  hasShowMoreButton,\n  lines,\n  noExpandable,\n  rows,\n}: CodeContentProps) => (\n  <PreText\n    as=\"pre\"\n    hasShowMoreButton={hasShowMoreButton}\n    noExpandable={noExpandable}\n    rows={rows}\n    showMore={showMore}\n    variant=\"code\"\n    whiteSpace={!multiline ? 'nowrap' : undefined}\n  >\n    {multiline ? (\n      Children.map(lines, child => (\n        <StyledSpan key={child} multiline prefix={prefix}>\n          {child}\n        </StyledSpan>\n      ))\n    ) : (\n      <StyledSpan prefix={prefix}>{children}</StyledSpan>\n    )}\n  </PreText>\n)\n\ntype SnippetProps = {\n  className?: string\n  children: string\n  /**\n   * prefix display an element at the beginning of the snippet that is not copiable or selectable.\n   * For `lines` prefix it will display the line number.\n   * For `command` prefix it will display a `$` sign.\n   */\n  prefix?: Prefixes\n  showText?: string\n  hideText?: string\n  'data-testid'?: string\n  initiallyExpanded?: boolean\n  rows?: number\n  noExpandable?: boolean\n  onCopy?: () => void\n} & Pick<ComponentProps<typeof CopyButton>, 'copyText' | 'copiedText'>\n\n/**\n * Snippet component is used to display code snippets with the ability to copy the code.\n * It also has the ability to show/hide the code snippet if it has more than 4 lines.\n */\nexport const Snippet = ({\n  children,\n  copyText,\n  copiedText,\n  showText = 'Show',\n  hideText = 'Hide',\n  prefix,\n  className,\n  'data-testid': dataTestId,\n  initiallyExpanded,\n  rows = 4,\n  noExpandable = false,\n  onCopy,\n}: SnippetProps) => {\n  const theme = useTheme()\n  const [showMore, setShowMore] = useReducer(\n    value => !value,\n    initiallyExpanded ?? false,\n  )\n  const lines = children.split(LINES_BREAK_REGEX)\n\n  const numberOfLines = lines.length\n  const multiline = numberOfLines > 1\n  const hasShowMoreButton = numberOfLines > rows && multiline && !noExpandable\n  // Height of the expandable (when needed) = number of rows * height of a line (from rem to px) + padding (from rem to px)\n  const minHeight =\n    rows * Number.parseFloat(theme.typography.code.lineHeight) * 16 +\n    Number.parseFloat(theme.space[4]) * 16\n\n  return (\n    <Container\n      className={className}\n      data-testid={dataTestId}\n      multiline={multiline}\n    >\n      <StyledStack>\n        {hasShowMoreButton ? (\n          <Expandable minHeight={minHeight} opened={showMore}>\n            <CodeContent\n              lines={lines}\n              multiline={multiline}\n              noExpandable={noExpandable}\n              prefix={prefix}\n              rows={rows}\n            >\n              {children}\n            </CodeContent>\n          </Expandable>\n        ) : (\n          <CodeContent\n            lines={lines}\n            multiline={multiline}\n            noExpandable={noExpandable}\n            prefix={prefix}\n            rows={rows}\n          >\n            {children}\n          </CodeContent>\n        )}\n        <ButtonContainer multiline={multiline && numberOfLines > 1}>\n          <CopyButton\n            copiedText={copiedText}\n            copyText={copyText}\n            onCopy={onCopy}\n            sentiment=\"neutral\"\n            value={children}\n          />\n        </ButtonContainer>\n        {hasShowMoreButton ? (\n          <ShowMoreContainer showMore={showMore}>\n            <StyledButton\n              aria-expanded={showMore}\n              onClick={setShowMore}\n              type=\"button\"\n            >\n              <AlignCenterText\n                as=\"span\"\n                sentiment=\"neutral\"\n                variant=\"bodySmallStrong\"\n              >\n                {showMore ? hideText : showText}\n                &nbsp;\n                <AnimatedArrowIcon showMore={showMore} />\n              </AlignCenterText>\n            </StyledButton>\n          </ShowMoreContainer>\n        ) : null}\n      </StyledStack>\n    </Container>\n  )\n}\n"]} */"));
61
+ ` : null, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx"],"names":[],"mappings":"AA8CmE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx","sourcesContent":["'use client'\n\nimport { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon } from '@ultraviolet/icons'\nimport type { ComponentProps } from 'react'\nimport { Children, useReducer } from 'react'\nimport { CopyButton } from '../CopyButton'\nimport { Expandable } from '../Expandable'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst LINES_BREAK_REGEX = /\\r\\n|\\r|\\n/\n\ntype Prefixes = 'lines' | 'command'\n\nconst PreText = styled(Text, {\n  shouldForwardProp: prop =>\n    !['hasShowMoreButton', 'showMore', 'rows', 'noExpandable'].includes(prop),\n})<{\n  hasShowMoreButton?: boolean\n  showMore?: boolean\n  rows: number\n  noExpandable: boolean\n}>`\n  margin: 0;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-right: ${({ theme }) => theme.space['9']};\n  overflow-x: ${({ hasShowMoreButton, showMore }) =>\n    hasShowMoreButton && !showMore ? 'hidden' : 'auto'};\n  height: auto;\n  counter-reset: section;\n\n\n  ${({ theme, noExpandable, rows }) =>\n    noExpandable\n      ? `\n    max-height: calc(${theme.typography.code.lineHeight} * ${rows} + ${theme.space['3']});\n    overflow-y: scroll;`\n      : `overflow-y: hidden;\n`}\n`\n\nconst StyledSpan = styled('span', {\n  shouldForwardProp: prop =>\n    !['linePrefix', 'multiline', 'prefix'].includes(prop),\n})<{ linePrefix?: string; multiline?: boolean; prefix?: Prefixes }>`\n  display: block;\n\n\n  &:not([data-multiline]):after {\n    content: \"\";\n    ${({ theme }) => `padding-right: ${theme.space['8']}`};\n  }\n\n  &[data-multiline=\"true\"]:nth-child(-n+2):after {\n    content: \"\";\n    ${({ theme }) => `padding-right: ${theme.space['8']}`};\n  }\n\n  ${({ prefix, theme }) =>\n    prefix\n      ? `\n    &:before {\n      color: ${theme.colors.neutral.textWeak};\n      width: ${prefix === 'lines' ? '35px' : ''};\n      display: inline-flex;\n      justify-content: flex-end;\n      counter-increment: section;\n      content: ${prefix === 'lines' ? 'counter(section)' : \"'$'\"};\n      padding-right: ${theme.space['1']};\n    }\n  `\n      : null}\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: relative;\n  display: flex;\n  justify-content: start;\n  max-width: 100%;\n  ${({ multiline }) => (multiline ? 'width: 100%;' : '')}\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n`\n\nconst StyledStack = styled(Stack)`\n  width: 100%;\n`\n\nconst ButtonContainer = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: absolute;\n  top: 0;\n  right: 0;\n  padding: ${({ theme, multiline }) =>\n    `${theme.space[multiline ? '2' : '1']} ${theme.space['2']} 0 0`};\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n  border: 2px solid transparent;\n  ${({ multiline, theme }) =>\n    !multiline\n      ? `box-shadow: -27px 0 19px -11px ${theme.colors.neutral.backgroundWeak}`\n      : ''};\n`\n\nconst ShowMoreContainer = styled('div', {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  width: 100%;\n  box-shadow: ${({ theme, showMore }) =>\n    !showMore\n      ? `0px -22px 19px -6px\n    ${theme.colors.neutral.backgroundWeak}`\n      : 'none'};\n`\n\nconst StyledButton = styled.button`\n  width: 100%;\n  background: none;\n  border: none;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-top: ${({ theme }) => theme.space['1']};\n  cursor: pointer;\n`\n\nconst AlignCenterText = styled(Text)`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n`\n\nconst AnimatedArrowIcon = styled(ArrowDownIcon, {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  transform: ${({ showMore }) => (showMore ? 'rotate(180deg)' : 'rotate(0deg)')};\n  transform-origin: center;\n  transition: transform 300ms ease-in-out;\n`\n\ntype CodeContentProps = {\n  children: string\n  prefix?: Prefixes\n  multiline?: boolean\n  showMore?: boolean\n  hasShowMoreButton?: boolean\n  lines?: string[]\n  noExpandable: boolean\n  rows: number\n}\n\nconst CodeContent = ({\n  children,\n  prefix,\n  multiline,\n  showMore,\n  hasShowMoreButton,\n  lines,\n  noExpandable,\n  rows,\n}: CodeContentProps) => (\n  <PreText\n    as=\"pre\"\n    hasShowMoreButton={hasShowMoreButton}\n    noExpandable={noExpandable}\n    rows={rows}\n    showMore={showMore}\n    variant=\"code\"\n    whiteSpace={!multiline ? 'nowrap' : undefined}\n  >\n    {multiline ? (\n      Children.map(lines, child => (\n        <StyledSpan data-multiline=\"true\" key={child} prefix={prefix}>\n          {child}\n        </StyledSpan>\n      ))\n    ) : (\n      <StyledSpan prefix={prefix}>{children}</StyledSpan>\n    )}\n  </PreText>\n)\n\ntype SnippetProps = {\n  className?: string\n  children: string\n  /**\n   * prefix display an element at the beginning of the snippet that is not copiable or selectable.\n   * For `lines` prefix it will display the line number.\n   * For `command` prefix it will display a `$` sign.\n   */\n  prefix?: Prefixes\n  showText?: string\n  hideText?: string\n  'data-testid'?: string\n  initiallyExpanded?: boolean\n  rows?: number\n  noExpandable?: boolean\n  onCopy?: () => void\n} & Pick<ComponentProps<typeof CopyButton>, 'copyText' | 'copiedText'>\n\n/**\n * Snippet component is used to display code snippets with the ability to copy the code.\n * It also has the ability to show/hide the code snippet if it has more than 4 lines.\n */\nexport const Snippet = ({\n  children,\n  copyText,\n  copiedText,\n  showText = 'Show',\n  hideText = 'Hide',\n  prefix,\n  className,\n  'data-testid': dataTestId,\n  initiallyExpanded,\n  rows = 4,\n  noExpandable = false,\n  onCopy,\n}: SnippetProps) => {\n  const theme = useTheme()\n  const [showMore, setShowMore] = useReducer(\n    value => !value,\n    initiallyExpanded ?? false,\n  )\n  const lines = children.split(LINES_BREAK_REGEX)\n\n  const numberOfLines = lines.length\n  const multiline = numberOfLines > 1\n  const hasShowMoreButton = numberOfLines > rows && multiline && !noExpandable\n  // Height of the expandable (when needed) = number of rows * height of a line (from rem to px) + padding (from rem to px)\n  const minHeight =\n    rows * Number.parseFloat(theme.typography.code.lineHeight) * 16 +\n    Number.parseFloat(theme.space[4]) * 16\n\n  return (\n    <Container\n      className={className}\n      data-testid={dataTestId}\n      multiline={multiline}\n    >\n      <StyledStack>\n        {hasShowMoreButton ? (\n          <Expandable minHeight={minHeight} opened={showMore}>\n            <CodeContent\n              lines={lines}\n              multiline={multiline}\n              noExpandable={noExpandable}\n              prefix={prefix}\n              rows={rows}\n            >\n              {children}\n            </CodeContent>\n          </Expandable>\n        ) : (\n          <CodeContent\n            lines={lines}\n            multiline={multiline}\n            noExpandable={noExpandable}\n            prefix={prefix}\n            rows={rows}\n          >\n            {children}\n          </CodeContent>\n        )}\n        <ButtonContainer multiline={multiline && numberOfLines > 1}>\n          <CopyButton\n            copiedText={copiedText}\n            copyText={copyText}\n            onCopy={onCopy}\n            sentiment=\"neutral\"\n            value={children}\n          />\n        </ButtonContainer>\n        {hasShowMoreButton ? (\n          <ShowMoreContainer showMore={showMore}>\n            <StyledButton\n              aria-expanded={showMore}\n              onClick={setShowMore}\n              type=\"button\"\n            >\n              <AlignCenterText\n                as=\"span\"\n                sentiment=\"neutral\"\n                variant=\"bodySmallStrong\"\n              >\n                {showMore ? hideText : showText}\n                &nbsp;\n                <AnimatedArrowIcon showMore={showMore} />\n              </AlignCenterText>\n            </StyledButton>\n          </ShowMoreContainer>\n        ) : null}\n      </StyledStack>\n    </Container>\n  )\n}\n"]} */"));
61
62
  const Container = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
62
63
  shouldForwardProp: (prop) => !["multiline"].includes(prop),
63
64
  target: "e1q0gj906"
@@ -71,7 +72,7 @@ const Container = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "produ
71
72
  theme
72
73
  }) => theme.colors.neutral.backgroundWeak, ";border-radius:", ({
73
74
  theme
74
- }) => theme.radii.default, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx"],"names":[],"mappings":"AA4E2B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx","sourcesContent":["'use client'\n\nimport { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon } from '@ultraviolet/icons'\nimport type { ComponentProps } from 'react'\nimport { Children, useReducer } from 'react'\nimport { CopyButton } from '../CopyButton'\nimport { Expandable } from '../Expandable'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst LINES_BREAK_REGEX = /\\r\\n|\\r|\\n/\n\ntype Prefixes = 'lines' | 'command'\n\nconst PreText = styled(Text, {\n  shouldForwardProp: prop =>\n    !['hasShowMoreButton', 'showMore', 'rows', 'noExpandable'].includes(prop),\n})<{\n  hasShowMoreButton?: boolean\n  showMore?: boolean\n  rows: number\n  noExpandable: boolean\n}>`\n  margin: 0;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-right: ${({ theme }) => theme.space['9']};\n  overflow-x: ${({ hasShowMoreButton, showMore }) =>\n    hasShowMoreButton && !showMore ? 'hidden' : 'auto'};\n  height: auto;\n  counter-reset: section;\n\n\n  ${({ theme, noExpandable, rows }) =>\n    noExpandable\n      ? `\n    max-height: calc(${theme.typography.code.lineHeight} * ${rows} + ${theme.space['3']});\n    overflow-y: scroll;`\n      : `overflow-y: hidden;\n`}\n`\n\nconst StyledSpan = styled('span', {\n  shouldForwardProp: prop =>\n    !['linePrefix', 'multiline', 'prefix'].includes(prop),\n})<{ linePrefix?: string; multiline?: boolean; prefix?: Prefixes }>`\n  display: block;\n\n\n  &:after {\n    content: \"\";\n    ${({ theme, multiline }) =>\n      multiline\n        ? `padding: ${theme.space['4']}`\n        : `padding-right: ${theme.space['8']}`};\n  }\n\n  ${({ prefix, theme }) =>\n    prefix\n      ? `\n    &:before {\n      color: ${theme.colors.neutral.textWeak};\n      width: ${prefix === 'lines' ? '35px' : ''};\n      display: inline-flex;\n      justify-content: flex-end;\n      counter-increment: section;\n      content: ${prefix === 'lines' ? 'counter(section)' : \"'$'\"};\n      padding-right: ${theme.space['1']};\n    }\n  `\n      : null}\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: relative;\n  display: flex;\n  justify-content: start;\n  max-width: 100%;\n  ${({ multiline }) => (multiline ? 'width: 100%;' : '')}\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n`\n\nconst StyledStack = styled(Stack)`\n  width: 100%;\n`\n\nconst ButtonContainer = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: absolute;\n  top: 0;\n  right: 0;\n  padding: ${({ theme, multiline }) =>\n    `${theme.space[multiline ? '2' : '1']} ${theme.space['2']} 0 0`};\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n  border: 2px solid transparent;\n  ${({ multiline, theme }) =>\n    !multiline\n      ? `box-shadow: -27px 0 19px -11px ${theme.colors.neutral.backgroundWeak}`\n      : ''};\n`\n\nconst ShowMoreContainer = styled('div', {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  width: 100%;\n  box-shadow: ${({ theme, showMore }) =>\n    !showMore\n      ? `0px -22px 19px -6px\n    ${theme.colors.neutral.backgroundWeak}`\n      : 'none'};\n`\n\nconst StyledButton = styled.button`\n  width: 100%;\n  background: none;\n  border: none;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-top: ${({ theme }) => theme.space['1']};\n  cursor: pointer;\n`\n\nconst AlignCenterText = styled(Text)`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n`\n\nconst AnimatedArrowIcon = styled(ArrowDownIcon, {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  transform: ${({ showMore }) => (showMore ? 'rotate(180deg)' : 'rotate(0deg)')};\n  transform-origin: center;\n  transition: transform 300ms ease-in-out;\n`\n\ntype CodeContentProps = {\n  children: string\n  prefix?: Prefixes\n  multiline?: boolean\n  showMore?: boolean\n  hasShowMoreButton?: boolean\n  lines?: string[]\n  noExpandable: boolean\n  rows: number\n}\n\nconst CodeContent = ({\n  children,\n  prefix,\n  multiline,\n  showMore,\n  hasShowMoreButton,\n  lines,\n  noExpandable,\n  rows,\n}: CodeContentProps) => (\n  <PreText\n    as=\"pre\"\n    hasShowMoreButton={hasShowMoreButton}\n    noExpandable={noExpandable}\n    rows={rows}\n    showMore={showMore}\n    variant=\"code\"\n    whiteSpace={!multiline ? 'nowrap' : undefined}\n  >\n    {multiline ? (\n      Children.map(lines, child => (\n        <StyledSpan key={child} multiline prefix={prefix}>\n          {child}\n        </StyledSpan>\n      ))\n    ) : (\n      <StyledSpan prefix={prefix}>{children}</StyledSpan>\n    )}\n  </PreText>\n)\n\ntype SnippetProps = {\n  className?: string\n  children: string\n  /**\n   * prefix display an element at the beginning of the snippet that is not copiable or selectable.\n   * For `lines` prefix it will display the line number.\n   * For `command` prefix it will display a `$` sign.\n   */\n  prefix?: Prefixes\n  showText?: string\n  hideText?: string\n  'data-testid'?: string\n  initiallyExpanded?: boolean\n  rows?: number\n  noExpandable?: boolean\n  onCopy?: () => void\n} & Pick<ComponentProps<typeof CopyButton>, 'copyText' | 'copiedText'>\n\n/**\n * Snippet component is used to display code snippets with the ability to copy the code.\n * It also has the ability to show/hide the code snippet if it has more than 4 lines.\n */\nexport const Snippet = ({\n  children,\n  copyText,\n  copiedText,\n  showText = 'Show',\n  hideText = 'Hide',\n  prefix,\n  className,\n  'data-testid': dataTestId,\n  initiallyExpanded,\n  rows = 4,\n  noExpandable = false,\n  onCopy,\n}: SnippetProps) => {\n  const theme = useTheme()\n  const [showMore, setShowMore] = useReducer(\n    value => !value,\n    initiallyExpanded ?? false,\n  )\n  const lines = children.split(LINES_BREAK_REGEX)\n\n  const numberOfLines = lines.length\n  const multiline = numberOfLines > 1\n  const hasShowMoreButton = numberOfLines > rows && multiline && !noExpandable\n  // Height of the expandable (when needed) = number of rows * height of a line (from rem to px) + padding (from rem to px)\n  const minHeight =\n    rows * Number.parseFloat(theme.typography.code.lineHeight) * 16 +\n    Number.parseFloat(theme.space[4]) * 16\n\n  return (\n    <Container\n      className={className}\n      data-testid={dataTestId}\n      multiline={multiline}\n    >\n      <StyledStack>\n        {hasShowMoreButton ? (\n          <Expandable minHeight={minHeight} opened={showMore}>\n            <CodeContent\n              lines={lines}\n              multiline={multiline}\n              noExpandable={noExpandable}\n              prefix={prefix}\n              rows={rows}\n            >\n              {children}\n            </CodeContent>\n          </Expandable>\n        ) : (\n          <CodeContent\n            lines={lines}\n            multiline={multiline}\n            noExpandable={noExpandable}\n            prefix={prefix}\n            rows={rows}\n          >\n            {children}\n          </CodeContent>\n        )}\n        <ButtonContainer multiline={multiline && numberOfLines > 1}>\n          <CopyButton\n            copiedText={copiedText}\n            copyText={copyText}\n            onCopy={onCopy}\n            sentiment=\"neutral\"\n            value={children}\n          />\n        </ButtonContainer>\n        {hasShowMoreButton ? (\n          <ShowMoreContainer showMore={showMore}>\n            <StyledButton\n              aria-expanded={showMore}\n              onClick={setShowMore}\n              type=\"button\"\n            >\n              <AlignCenterText\n                as=\"span\"\n                sentiment=\"neutral\"\n                variant=\"bodySmallStrong\"\n              >\n                {showMore ? hideText : showText}\n                &nbsp;\n                <AnimatedArrowIcon showMore={showMore} />\n              </AlignCenterText>\n            </StyledButton>\n          </ShowMoreContainer>\n        ) : null}\n      </StyledStack>\n    </Container>\n  )\n}\n"]} */"));
75
+ }) => theme.radii.default, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx"],"names":[],"mappings":"AA8E2B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx","sourcesContent":["'use client'\n\nimport { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon } from '@ultraviolet/icons'\nimport type { ComponentProps } from 'react'\nimport { Children, useReducer } from 'react'\nimport { CopyButton } from '../CopyButton'\nimport { Expandable } from '../Expandable'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst LINES_BREAK_REGEX = /\\r\\n|\\r|\\n/\n\ntype Prefixes = 'lines' | 'command'\n\nconst PreText = styled(Text, {\n  shouldForwardProp: prop =>\n    !['hasShowMoreButton', 'showMore', 'rows', 'noExpandable'].includes(prop),\n})<{\n  hasShowMoreButton?: boolean\n  showMore?: boolean\n  rows: number\n  noExpandable: boolean\n}>`\n  margin: 0;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-right: ${({ theme }) => theme.space['9']};\n  overflow-x: ${({ hasShowMoreButton, showMore }) =>\n    hasShowMoreButton && !showMore ? 'hidden' : 'auto'};\n  height: auto;\n  counter-reset: section;\n\n\n  ${({ theme, noExpandable, rows }) =>\n    noExpandable\n      ? `\n    max-height: calc(${theme.typography.code.lineHeight} * ${rows} + ${theme.space['3']});\n    overflow-y: scroll;`\n      : `overflow-y: hidden;\n`}\n`\n\nconst StyledSpan = styled('span', {\n  shouldForwardProp: prop =>\n    !['linePrefix', 'multiline', 'prefix'].includes(prop),\n})<{ linePrefix?: string; multiline?: boolean; prefix?: Prefixes }>`\n  display: block;\n\n\n  &:not([data-multiline]):after {\n    content: \"\";\n    ${({ theme }) => `padding-right: ${theme.space['8']}`};\n  }\n\n  &[data-multiline=\"true\"]:nth-child(-n+2):after {\n    content: \"\";\n    ${({ theme }) => `padding-right: ${theme.space['8']}`};\n  }\n\n  ${({ prefix, theme }) =>\n    prefix\n      ? `\n    &:before {\n      color: ${theme.colors.neutral.textWeak};\n      width: ${prefix === 'lines' ? '35px' : ''};\n      display: inline-flex;\n      justify-content: flex-end;\n      counter-increment: section;\n      content: ${prefix === 'lines' ? 'counter(section)' : \"'$'\"};\n      padding-right: ${theme.space['1']};\n    }\n  `\n      : null}\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: relative;\n  display: flex;\n  justify-content: start;\n  max-width: 100%;\n  ${({ multiline }) => (multiline ? 'width: 100%;' : '')}\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n`\n\nconst StyledStack = styled(Stack)`\n  width: 100%;\n`\n\nconst ButtonContainer = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: absolute;\n  top: 0;\n  right: 0;\n  padding: ${({ theme, multiline }) =>\n    `${theme.space[multiline ? '2' : '1']} ${theme.space['2']} 0 0`};\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n  border: 2px solid transparent;\n  ${({ multiline, theme }) =>\n    !multiline\n      ? `box-shadow: -27px 0 19px -11px ${theme.colors.neutral.backgroundWeak}`\n      : ''};\n`\n\nconst ShowMoreContainer = styled('div', {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  width: 100%;\n  box-shadow: ${({ theme, showMore }) =>\n    !showMore\n      ? `0px -22px 19px -6px\n    ${theme.colors.neutral.backgroundWeak}`\n      : 'none'};\n`\n\nconst StyledButton = styled.button`\n  width: 100%;\n  background: none;\n  border: none;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-top: ${({ theme }) => theme.space['1']};\n  cursor: pointer;\n`\n\nconst AlignCenterText = styled(Text)`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n`\n\nconst AnimatedArrowIcon = styled(ArrowDownIcon, {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  transform: ${({ showMore }) => (showMore ? 'rotate(180deg)' : 'rotate(0deg)')};\n  transform-origin: center;\n  transition: transform 300ms ease-in-out;\n`\n\ntype CodeContentProps = {\n  children: string\n  prefix?: Prefixes\n  multiline?: boolean\n  showMore?: boolean\n  hasShowMoreButton?: boolean\n  lines?: string[]\n  noExpandable: boolean\n  rows: number\n}\n\nconst CodeContent = ({\n  children,\n  prefix,\n  multiline,\n  showMore,\n  hasShowMoreButton,\n  lines,\n  noExpandable,\n  rows,\n}: CodeContentProps) => (\n  <PreText\n    as=\"pre\"\n    hasShowMoreButton={hasShowMoreButton}\n    noExpandable={noExpandable}\n    rows={rows}\n    showMore={showMore}\n    variant=\"code\"\n    whiteSpace={!multiline ? 'nowrap' : undefined}\n  >\n    {multiline ? (\n      Children.map(lines, child => (\n        <StyledSpan data-multiline=\"true\" key={child} prefix={prefix}>\n          {child}\n        </StyledSpan>\n      ))\n    ) : (\n      <StyledSpan prefix={prefix}>{children}</StyledSpan>\n    )}\n  </PreText>\n)\n\ntype SnippetProps = {\n  className?: string\n  children: string\n  /**\n   * prefix display an element at the beginning of the snippet that is not copiable or selectable.\n   * For `lines` prefix it will display the line number.\n   * For `command` prefix it will display a `$` sign.\n   */\n  prefix?: Prefixes\n  showText?: string\n  hideText?: string\n  'data-testid'?: string\n  initiallyExpanded?: boolean\n  rows?: number\n  noExpandable?: boolean\n  onCopy?: () => void\n} & Pick<ComponentProps<typeof CopyButton>, 'copyText' | 'copiedText'>\n\n/**\n * Snippet component is used to display code snippets with the ability to copy the code.\n * It also has the ability to show/hide the code snippet if it has more than 4 lines.\n */\nexport const Snippet = ({\n  children,\n  copyText,\n  copiedText,\n  showText = 'Show',\n  hideText = 'Hide',\n  prefix,\n  className,\n  'data-testid': dataTestId,\n  initiallyExpanded,\n  rows = 4,\n  noExpandable = false,\n  onCopy,\n}: SnippetProps) => {\n  const theme = useTheme()\n  const [showMore, setShowMore] = useReducer(\n    value => !value,\n    initiallyExpanded ?? false,\n  )\n  const lines = children.split(LINES_BREAK_REGEX)\n\n  const numberOfLines = lines.length\n  const multiline = numberOfLines > 1\n  const hasShowMoreButton = numberOfLines > rows && multiline && !noExpandable\n  // Height of the expandable (when needed) = number of rows * height of a line (from rem to px) + padding (from rem to px)\n  const minHeight =\n    rows * Number.parseFloat(theme.typography.code.lineHeight) * 16 +\n    Number.parseFloat(theme.space[4]) * 16\n\n  return (\n    <Container\n      className={className}\n      data-testid={dataTestId}\n      multiline={multiline}\n    >\n      <StyledStack>\n        {hasShowMoreButton ? (\n          <Expandable minHeight={minHeight} opened={showMore}>\n            <CodeContent\n              lines={lines}\n              multiline={multiline}\n              noExpandable={noExpandable}\n              prefix={prefix}\n              rows={rows}\n            >\n              {children}\n            </CodeContent>\n          </Expandable>\n        ) : (\n          <CodeContent\n            lines={lines}\n            multiline={multiline}\n            noExpandable={noExpandable}\n            prefix={prefix}\n            rows={rows}\n          >\n            {children}\n          </CodeContent>\n        )}\n        <ButtonContainer multiline={multiline && numberOfLines > 1}>\n          <CopyButton\n            copiedText={copiedText}\n            copyText={copyText}\n            onCopy={onCopy}\n            sentiment=\"neutral\"\n            value={children}\n          />\n        </ButtonContainer>\n        {hasShowMoreButton ? (\n          <ShowMoreContainer showMore={showMore}>\n            <StyledButton\n              aria-expanded={showMore}\n              onClick={setShowMore}\n              type=\"button\"\n            >\n              <AlignCenterText\n                as=\"span\"\n                sentiment=\"neutral\"\n                variant=\"bodySmallStrong\"\n              >\n                {showMore ? hideText : showText}\n                &nbsp;\n                <AnimatedArrowIcon showMore={showMore} />\n              </AlignCenterText>\n            </StyledButton>\n          </ShowMoreContainer>\n        ) : null}\n      </StyledStack>\n    </Container>\n  )\n}\n"]} */"));
75
76
  const StyledStack = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
76
77
  target: "e1q0gj905"
77
78
  } : {
@@ -82,7 +83,7 @@ const StyledStack = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "pro
82
83
  styles: "width:100%"
83
84
  } : {
84
85
  name: "1d3w5wq",
85
- styles: "width:100%/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx"],"names":[],"mappings":"AAsFiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx","sourcesContent":["'use client'\n\nimport { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon } from '@ultraviolet/icons'\nimport type { ComponentProps } from 'react'\nimport { Children, useReducer } from 'react'\nimport { CopyButton } from '../CopyButton'\nimport { Expandable } from '../Expandable'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst LINES_BREAK_REGEX = /\\r\\n|\\r|\\n/\n\ntype Prefixes = 'lines' | 'command'\n\nconst PreText = styled(Text, {\n  shouldForwardProp: prop =>\n    !['hasShowMoreButton', 'showMore', 'rows', 'noExpandable'].includes(prop),\n})<{\n  hasShowMoreButton?: boolean\n  showMore?: boolean\n  rows: number\n  noExpandable: boolean\n}>`\n  margin: 0;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-right: ${({ theme }) => theme.space['9']};\n  overflow-x: ${({ hasShowMoreButton, showMore }) =>\n    hasShowMoreButton && !showMore ? 'hidden' : 'auto'};\n  height: auto;\n  counter-reset: section;\n\n\n  ${({ theme, noExpandable, rows }) =>\n    noExpandable\n      ? `\n    max-height: calc(${theme.typography.code.lineHeight} * ${rows} + ${theme.space['3']});\n    overflow-y: scroll;`\n      : `overflow-y: hidden;\n`}\n`\n\nconst StyledSpan = styled('span', {\n  shouldForwardProp: prop =>\n    !['linePrefix', 'multiline', 'prefix'].includes(prop),\n})<{ linePrefix?: string; multiline?: boolean; prefix?: Prefixes }>`\n  display: block;\n\n\n  &:after {\n    content: \"\";\n    ${({ theme, multiline }) =>\n      multiline\n        ? `padding: ${theme.space['4']}`\n        : `padding-right: ${theme.space['8']}`};\n  }\n\n  ${({ prefix, theme }) =>\n    prefix\n      ? `\n    &:before {\n      color: ${theme.colors.neutral.textWeak};\n      width: ${prefix === 'lines' ? '35px' : ''};\n      display: inline-flex;\n      justify-content: flex-end;\n      counter-increment: section;\n      content: ${prefix === 'lines' ? 'counter(section)' : \"'$'\"};\n      padding-right: ${theme.space['1']};\n    }\n  `\n      : null}\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: relative;\n  display: flex;\n  justify-content: start;\n  max-width: 100%;\n  ${({ multiline }) => (multiline ? 'width: 100%;' : '')}\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n`\n\nconst StyledStack = styled(Stack)`\n  width: 100%;\n`\n\nconst ButtonContainer = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: absolute;\n  top: 0;\n  right: 0;\n  padding: ${({ theme, multiline }) =>\n    `${theme.space[multiline ? '2' : '1']} ${theme.space['2']} 0 0`};\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n  border: 2px solid transparent;\n  ${({ multiline, theme }) =>\n    !multiline\n      ? `box-shadow: -27px 0 19px -11px ${theme.colors.neutral.backgroundWeak}`\n      : ''};\n`\n\nconst ShowMoreContainer = styled('div', {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  width: 100%;\n  box-shadow: ${({ theme, showMore }) =>\n    !showMore\n      ? `0px -22px 19px -6px\n    ${theme.colors.neutral.backgroundWeak}`\n      : 'none'};\n`\n\nconst StyledButton = styled.button`\n  width: 100%;\n  background: none;\n  border: none;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-top: ${({ theme }) => theme.space['1']};\n  cursor: pointer;\n`\n\nconst AlignCenterText = styled(Text)`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n`\n\nconst AnimatedArrowIcon = styled(ArrowDownIcon, {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  transform: ${({ showMore }) => (showMore ? 'rotate(180deg)' : 'rotate(0deg)')};\n  transform-origin: center;\n  transition: transform 300ms ease-in-out;\n`\n\ntype CodeContentProps = {\n  children: string\n  prefix?: Prefixes\n  multiline?: boolean\n  showMore?: boolean\n  hasShowMoreButton?: boolean\n  lines?: string[]\n  noExpandable: boolean\n  rows: number\n}\n\nconst CodeContent = ({\n  children,\n  prefix,\n  multiline,\n  showMore,\n  hasShowMoreButton,\n  lines,\n  noExpandable,\n  rows,\n}: CodeContentProps) => (\n  <PreText\n    as=\"pre\"\n    hasShowMoreButton={hasShowMoreButton}\n    noExpandable={noExpandable}\n    rows={rows}\n    showMore={showMore}\n    variant=\"code\"\n    whiteSpace={!multiline ? 'nowrap' : undefined}\n  >\n    {multiline ? (\n      Children.map(lines, child => (\n        <StyledSpan key={child} multiline prefix={prefix}>\n          {child}\n        </StyledSpan>\n      ))\n    ) : (\n      <StyledSpan prefix={prefix}>{children}</StyledSpan>\n    )}\n  </PreText>\n)\n\ntype SnippetProps = {\n  className?: string\n  children: string\n  /**\n   * prefix display an element at the beginning of the snippet that is not copiable or selectable.\n   * For `lines` prefix it will display the line number.\n   * For `command` prefix it will display a `$` sign.\n   */\n  prefix?: Prefixes\n  showText?: string\n  hideText?: string\n  'data-testid'?: string\n  initiallyExpanded?: boolean\n  rows?: number\n  noExpandable?: boolean\n  onCopy?: () => void\n} & Pick<ComponentProps<typeof CopyButton>, 'copyText' | 'copiedText'>\n\n/**\n * Snippet component is used to display code snippets with the ability to copy the code.\n * It also has the ability to show/hide the code snippet if it has more than 4 lines.\n */\nexport const Snippet = ({\n  children,\n  copyText,\n  copiedText,\n  showText = 'Show',\n  hideText = 'Hide',\n  prefix,\n  className,\n  'data-testid': dataTestId,\n  initiallyExpanded,\n  rows = 4,\n  noExpandable = false,\n  onCopy,\n}: SnippetProps) => {\n  const theme = useTheme()\n  const [showMore, setShowMore] = useReducer(\n    value => !value,\n    initiallyExpanded ?? false,\n  )\n  const lines = children.split(LINES_BREAK_REGEX)\n\n  const numberOfLines = lines.length\n  const multiline = numberOfLines > 1\n  const hasShowMoreButton = numberOfLines > rows && multiline && !noExpandable\n  // Height of the expandable (when needed) = number of rows * height of a line (from rem to px) + padding (from rem to px)\n  const minHeight =\n    rows * Number.parseFloat(theme.typography.code.lineHeight) * 16 +\n    Number.parseFloat(theme.space[4]) * 16\n\n  return (\n    <Container\n      className={className}\n      data-testid={dataTestId}\n      multiline={multiline}\n    >\n      <StyledStack>\n        {hasShowMoreButton ? (\n          <Expandable minHeight={minHeight} opened={showMore}>\n            <CodeContent\n              lines={lines}\n              multiline={multiline}\n              noExpandable={noExpandable}\n              prefix={prefix}\n              rows={rows}\n            >\n              {children}\n            </CodeContent>\n          </Expandable>\n        ) : (\n          <CodeContent\n            lines={lines}\n            multiline={multiline}\n            noExpandable={noExpandable}\n            prefix={prefix}\n            rows={rows}\n          >\n            {children}\n          </CodeContent>\n        )}\n        <ButtonContainer multiline={multiline && numberOfLines > 1}>\n          <CopyButton\n            copiedText={copiedText}\n            copyText={copyText}\n            onCopy={onCopy}\n            sentiment=\"neutral\"\n            value={children}\n          />\n        </ButtonContainer>\n        {hasShowMoreButton ? (\n          <ShowMoreContainer showMore={showMore}>\n            <StyledButton\n              aria-expanded={showMore}\n              onClick={setShowMore}\n              type=\"button\"\n            >\n              <AlignCenterText\n                as=\"span\"\n                sentiment=\"neutral\"\n                variant=\"bodySmallStrong\"\n              >\n                {showMore ? hideText : showText}\n                &nbsp;\n                <AnimatedArrowIcon showMore={showMore} />\n              </AlignCenterText>\n            </StyledButton>\n          </ShowMoreContainer>\n        ) : null}\n      </StyledStack>\n    </Container>\n  )\n}\n"]} */",
86
+ styles: "width:100%/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx"],"names":[],"mappings":"AAwFiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx","sourcesContent":["'use client'\n\nimport { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon } from '@ultraviolet/icons'\nimport type { ComponentProps } from 'react'\nimport { Children, useReducer } from 'react'\nimport { CopyButton } from '../CopyButton'\nimport { Expandable } from '../Expandable'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst LINES_BREAK_REGEX = /\\r\\n|\\r|\\n/\n\ntype Prefixes = 'lines' | 'command'\n\nconst PreText = styled(Text, {\n  shouldForwardProp: prop =>\n    !['hasShowMoreButton', 'showMore', 'rows', 'noExpandable'].includes(prop),\n})<{\n  hasShowMoreButton?: boolean\n  showMore?: boolean\n  rows: number\n  noExpandable: boolean\n}>`\n  margin: 0;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-right: ${({ theme }) => theme.space['9']};\n  overflow-x: ${({ hasShowMoreButton, showMore }) =>\n    hasShowMoreButton && !showMore ? 'hidden' : 'auto'};\n  height: auto;\n  counter-reset: section;\n\n\n  ${({ theme, noExpandable, rows }) =>\n    noExpandable\n      ? `\n    max-height: calc(${theme.typography.code.lineHeight} * ${rows} + ${theme.space['3']});\n    overflow-y: scroll;`\n      : `overflow-y: hidden;\n`}\n`\n\nconst StyledSpan = styled('span', {\n  shouldForwardProp: prop =>\n    !['linePrefix', 'multiline', 'prefix'].includes(prop),\n})<{ linePrefix?: string; multiline?: boolean; prefix?: Prefixes }>`\n  display: block;\n\n\n  &:not([data-multiline]):after {\n    content: \"\";\n    ${({ theme }) => `padding-right: ${theme.space['8']}`};\n  }\n\n  &[data-multiline=\"true\"]:nth-child(-n+2):after {\n    content: \"\";\n    ${({ theme }) => `padding-right: ${theme.space['8']}`};\n  }\n\n  ${({ prefix, theme }) =>\n    prefix\n      ? `\n    &:before {\n      color: ${theme.colors.neutral.textWeak};\n      width: ${prefix === 'lines' ? '35px' : ''};\n      display: inline-flex;\n      justify-content: flex-end;\n      counter-increment: section;\n      content: ${prefix === 'lines' ? 'counter(section)' : \"'$'\"};\n      padding-right: ${theme.space['1']};\n    }\n  `\n      : null}\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: relative;\n  display: flex;\n  justify-content: start;\n  max-width: 100%;\n  ${({ multiline }) => (multiline ? 'width: 100%;' : '')}\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n`\n\nconst StyledStack = styled(Stack)`\n  width: 100%;\n`\n\nconst ButtonContainer = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: absolute;\n  top: 0;\n  right: 0;\n  padding: ${({ theme, multiline }) =>\n    `${theme.space[multiline ? '2' : '1']} ${theme.space['2']} 0 0`};\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n  border: 2px solid transparent;\n  ${({ multiline, theme }) =>\n    !multiline\n      ? `box-shadow: -27px 0 19px -11px ${theme.colors.neutral.backgroundWeak}`\n      : ''};\n`\n\nconst ShowMoreContainer = styled('div', {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  width: 100%;\n  box-shadow: ${({ theme, showMore }) =>\n    !showMore\n      ? `0px -22px 19px -6px\n    ${theme.colors.neutral.backgroundWeak}`\n      : 'none'};\n`\n\nconst StyledButton = styled.button`\n  width: 100%;\n  background: none;\n  border: none;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-top: ${({ theme }) => theme.space['1']};\n  cursor: pointer;\n`\n\nconst AlignCenterText = styled(Text)`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n`\n\nconst AnimatedArrowIcon = styled(ArrowDownIcon, {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  transform: ${({ showMore }) => (showMore ? 'rotate(180deg)' : 'rotate(0deg)')};\n  transform-origin: center;\n  transition: transform 300ms ease-in-out;\n`\n\ntype CodeContentProps = {\n  children: string\n  prefix?: Prefixes\n  multiline?: boolean\n  showMore?: boolean\n  hasShowMoreButton?: boolean\n  lines?: string[]\n  noExpandable: boolean\n  rows: number\n}\n\nconst CodeContent = ({\n  children,\n  prefix,\n  multiline,\n  showMore,\n  hasShowMoreButton,\n  lines,\n  noExpandable,\n  rows,\n}: CodeContentProps) => (\n  <PreText\n    as=\"pre\"\n    hasShowMoreButton={hasShowMoreButton}\n    noExpandable={noExpandable}\n    rows={rows}\n    showMore={showMore}\n    variant=\"code\"\n    whiteSpace={!multiline ? 'nowrap' : undefined}\n  >\n    {multiline ? (\n      Children.map(lines, child => (\n        <StyledSpan data-multiline=\"true\" key={child} prefix={prefix}>\n          {child}\n        </StyledSpan>\n      ))\n    ) : (\n      <StyledSpan prefix={prefix}>{children}</StyledSpan>\n    )}\n  </PreText>\n)\n\ntype SnippetProps = {\n  className?: string\n  children: string\n  /**\n   * prefix display an element at the beginning of the snippet that is not copiable or selectable.\n   * For `lines` prefix it will display the line number.\n   * For `command` prefix it will display a `$` sign.\n   */\n  prefix?: Prefixes\n  showText?: string\n  hideText?: string\n  'data-testid'?: string\n  initiallyExpanded?: boolean\n  rows?: number\n  noExpandable?: boolean\n  onCopy?: () => void\n} & Pick<ComponentProps<typeof CopyButton>, 'copyText' | 'copiedText'>\n\n/**\n * Snippet component is used to display code snippets with the ability to copy the code.\n * It also has the ability to show/hide the code snippet if it has more than 4 lines.\n */\nexport const Snippet = ({\n  children,\n  copyText,\n  copiedText,\n  showText = 'Show',\n  hideText = 'Hide',\n  prefix,\n  className,\n  'data-testid': dataTestId,\n  initiallyExpanded,\n  rows = 4,\n  noExpandable = false,\n  onCopy,\n}: SnippetProps) => {\n  const theme = useTheme()\n  const [showMore, setShowMore] = useReducer(\n    value => !value,\n    initiallyExpanded ?? false,\n  )\n  const lines = children.split(LINES_BREAK_REGEX)\n\n  const numberOfLines = lines.length\n  const multiline = numberOfLines > 1\n  const hasShowMoreButton = numberOfLines > rows && multiline && !noExpandable\n  // Height of the expandable (when needed) = number of rows * height of a line (from rem to px) + padding (from rem to px)\n  const minHeight =\n    rows * Number.parseFloat(theme.typography.code.lineHeight) * 16 +\n    Number.parseFloat(theme.space[4]) * 16\n\n  return (\n    <Container\n      className={className}\n      data-testid={dataTestId}\n      multiline={multiline}\n    >\n      <StyledStack>\n        {hasShowMoreButton ? (\n          <Expandable minHeight={minHeight} opened={showMore}>\n            <CodeContent\n              lines={lines}\n              multiline={multiline}\n              noExpandable={noExpandable}\n              prefix={prefix}\n              rows={rows}\n            >\n              {children}\n            </CodeContent>\n          </Expandable>\n        ) : (\n          <CodeContent\n            lines={lines}\n            multiline={multiline}\n            noExpandable={noExpandable}\n            prefix={prefix}\n            rows={rows}\n          >\n            {children}\n          </CodeContent>\n        )}\n        <ButtonContainer multiline={multiline && numberOfLines > 1}>\n          <CopyButton\n            copiedText={copiedText}\n            copyText={copyText}\n            onCopy={onCopy}\n            sentiment=\"neutral\"\n            value={children}\n          />\n        </ButtonContainer>\n        {hasShowMoreButton ? (\n          <ShowMoreContainer showMore={showMore}>\n            <StyledButton\n              aria-expanded={showMore}\n              onClick={setShowMore}\n              type=\"button\"\n            >\n              <AlignCenterText\n                as=\"span\"\n                sentiment=\"neutral\"\n                variant=\"bodySmallStrong\"\n              >\n                {showMore ? hideText : showText}\n                &nbsp;\n                <AnimatedArrowIcon showMore={showMore} />\n              </AlignCenterText>\n            </StyledButton>\n          </ShowMoreContainer>\n        ) : null}\n      </StyledStack>\n    </Container>\n  )\n}\n"]} */",
86
87
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
87
88
  });
88
89
  const ButtonContainer = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
@@ -102,7 +103,7 @@ const ButtonContainer = /* @__PURE__ */ _styled("div", process.env.NODE_ENV ===
102
103
  }) => theme.radii.default, ";border:2px solid transparent;", ({
103
104
  multiline,
104
105
  theme
105
- }) => !multiline ? `box-shadow: -27px 0 19px -11px ${theme.colors.neutral.backgroundWeak}` : "", ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx"],"names":[],"mappings":"AA4F2B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx","sourcesContent":["'use client'\n\nimport { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon } from '@ultraviolet/icons'\nimport type { ComponentProps } from 'react'\nimport { Children, useReducer } from 'react'\nimport { CopyButton } from '../CopyButton'\nimport { Expandable } from '../Expandable'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst LINES_BREAK_REGEX = /\\r\\n|\\r|\\n/\n\ntype Prefixes = 'lines' | 'command'\n\nconst PreText = styled(Text, {\n  shouldForwardProp: prop =>\n    !['hasShowMoreButton', 'showMore', 'rows', 'noExpandable'].includes(prop),\n})<{\n  hasShowMoreButton?: boolean\n  showMore?: boolean\n  rows: number\n  noExpandable: boolean\n}>`\n  margin: 0;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-right: ${({ theme }) => theme.space['9']};\n  overflow-x: ${({ hasShowMoreButton, showMore }) =>\n    hasShowMoreButton && !showMore ? 'hidden' : 'auto'};\n  height: auto;\n  counter-reset: section;\n\n\n  ${({ theme, noExpandable, rows }) =>\n    noExpandable\n      ? `\n    max-height: calc(${theme.typography.code.lineHeight} * ${rows} + ${theme.space['3']});\n    overflow-y: scroll;`\n      : `overflow-y: hidden;\n`}\n`\n\nconst StyledSpan = styled('span', {\n  shouldForwardProp: prop =>\n    !['linePrefix', 'multiline', 'prefix'].includes(prop),\n})<{ linePrefix?: string; multiline?: boolean; prefix?: Prefixes }>`\n  display: block;\n\n\n  &:after {\n    content: \"\";\n    ${({ theme, multiline }) =>\n      multiline\n        ? `padding: ${theme.space['4']}`\n        : `padding-right: ${theme.space['8']}`};\n  }\n\n  ${({ prefix, theme }) =>\n    prefix\n      ? `\n    &:before {\n      color: ${theme.colors.neutral.textWeak};\n      width: ${prefix === 'lines' ? '35px' : ''};\n      display: inline-flex;\n      justify-content: flex-end;\n      counter-increment: section;\n      content: ${prefix === 'lines' ? 'counter(section)' : \"'$'\"};\n      padding-right: ${theme.space['1']};\n    }\n  `\n      : null}\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: relative;\n  display: flex;\n  justify-content: start;\n  max-width: 100%;\n  ${({ multiline }) => (multiline ? 'width: 100%;' : '')}\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n`\n\nconst StyledStack = styled(Stack)`\n  width: 100%;\n`\n\nconst ButtonContainer = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: absolute;\n  top: 0;\n  right: 0;\n  padding: ${({ theme, multiline }) =>\n    `${theme.space[multiline ? '2' : '1']} ${theme.space['2']} 0 0`};\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n  border: 2px solid transparent;\n  ${({ multiline, theme }) =>\n    !multiline\n      ? `box-shadow: -27px 0 19px -11px ${theme.colors.neutral.backgroundWeak}`\n      : ''};\n`\n\nconst ShowMoreContainer = styled('div', {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  width: 100%;\n  box-shadow: ${({ theme, showMore }) =>\n    !showMore\n      ? `0px -22px 19px -6px\n    ${theme.colors.neutral.backgroundWeak}`\n      : 'none'};\n`\n\nconst StyledButton = styled.button`\n  width: 100%;\n  background: none;\n  border: none;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-top: ${({ theme }) => theme.space['1']};\n  cursor: pointer;\n`\n\nconst AlignCenterText = styled(Text)`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n`\n\nconst AnimatedArrowIcon = styled(ArrowDownIcon, {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  transform: ${({ showMore }) => (showMore ? 'rotate(180deg)' : 'rotate(0deg)')};\n  transform-origin: center;\n  transition: transform 300ms ease-in-out;\n`\n\ntype CodeContentProps = {\n  children: string\n  prefix?: Prefixes\n  multiline?: boolean\n  showMore?: boolean\n  hasShowMoreButton?: boolean\n  lines?: string[]\n  noExpandable: boolean\n  rows: number\n}\n\nconst CodeContent = ({\n  children,\n  prefix,\n  multiline,\n  showMore,\n  hasShowMoreButton,\n  lines,\n  noExpandable,\n  rows,\n}: CodeContentProps) => (\n  <PreText\n    as=\"pre\"\n    hasShowMoreButton={hasShowMoreButton}\n    noExpandable={noExpandable}\n    rows={rows}\n    showMore={showMore}\n    variant=\"code\"\n    whiteSpace={!multiline ? 'nowrap' : undefined}\n  >\n    {multiline ? (\n      Children.map(lines, child => (\n        <StyledSpan key={child} multiline prefix={prefix}>\n          {child}\n        </StyledSpan>\n      ))\n    ) : (\n      <StyledSpan prefix={prefix}>{children}</StyledSpan>\n    )}\n  </PreText>\n)\n\ntype SnippetProps = {\n  className?: string\n  children: string\n  /**\n   * prefix display an element at the beginning of the snippet that is not copiable or selectable.\n   * For `lines` prefix it will display the line number.\n   * For `command` prefix it will display a `$` sign.\n   */\n  prefix?: Prefixes\n  showText?: string\n  hideText?: string\n  'data-testid'?: string\n  initiallyExpanded?: boolean\n  rows?: number\n  noExpandable?: boolean\n  onCopy?: () => void\n} & Pick<ComponentProps<typeof CopyButton>, 'copyText' | 'copiedText'>\n\n/**\n * Snippet component is used to display code snippets with the ability to copy the code.\n * It also has the ability to show/hide the code snippet if it has more than 4 lines.\n */\nexport const Snippet = ({\n  children,\n  copyText,\n  copiedText,\n  showText = 'Show',\n  hideText = 'Hide',\n  prefix,\n  className,\n  'data-testid': dataTestId,\n  initiallyExpanded,\n  rows = 4,\n  noExpandable = false,\n  onCopy,\n}: SnippetProps) => {\n  const theme = useTheme()\n  const [showMore, setShowMore] = useReducer(\n    value => !value,\n    initiallyExpanded ?? false,\n  )\n  const lines = children.split(LINES_BREAK_REGEX)\n\n  const numberOfLines = lines.length\n  const multiline = numberOfLines > 1\n  const hasShowMoreButton = numberOfLines > rows && multiline && !noExpandable\n  // Height of the expandable (when needed) = number of rows * height of a line (from rem to px) + padding (from rem to px)\n  const minHeight =\n    rows * Number.parseFloat(theme.typography.code.lineHeight) * 16 +\n    Number.parseFloat(theme.space[4]) * 16\n\n  return (\n    <Container\n      className={className}\n      data-testid={dataTestId}\n      multiline={multiline}\n    >\n      <StyledStack>\n        {hasShowMoreButton ? (\n          <Expandable minHeight={minHeight} opened={showMore}>\n            <CodeContent\n              lines={lines}\n              multiline={multiline}\n              noExpandable={noExpandable}\n              prefix={prefix}\n              rows={rows}\n            >\n              {children}\n            </CodeContent>\n          </Expandable>\n        ) : (\n          <CodeContent\n            lines={lines}\n            multiline={multiline}\n            noExpandable={noExpandable}\n            prefix={prefix}\n            rows={rows}\n          >\n            {children}\n          </CodeContent>\n        )}\n        <ButtonContainer multiline={multiline && numberOfLines > 1}>\n          <CopyButton\n            copiedText={copiedText}\n            copyText={copyText}\n            onCopy={onCopy}\n            sentiment=\"neutral\"\n            value={children}\n          />\n        </ButtonContainer>\n        {hasShowMoreButton ? (\n          <ShowMoreContainer showMore={showMore}>\n            <StyledButton\n              aria-expanded={showMore}\n              onClick={setShowMore}\n              type=\"button\"\n            >\n              <AlignCenterText\n                as=\"span\"\n                sentiment=\"neutral\"\n                variant=\"bodySmallStrong\"\n              >\n                {showMore ? hideText : showText}\n                &nbsp;\n                <AnimatedArrowIcon showMore={showMore} />\n              </AlignCenterText>\n            </StyledButton>\n          </ShowMoreContainer>\n        ) : null}\n      </StyledStack>\n    </Container>\n  )\n}\n"]} */"));
106
+ }) => !multiline ? `box-shadow: -27px 0 19px -11px ${theme.colors.neutral.backgroundWeak}` : "", ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx"],"names":[],"mappings":"AA8F2B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx","sourcesContent":["'use client'\n\nimport { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon } from '@ultraviolet/icons'\nimport type { ComponentProps } from 'react'\nimport { Children, useReducer } from 'react'\nimport { CopyButton } from '../CopyButton'\nimport { Expandable } from '../Expandable'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst LINES_BREAK_REGEX = /\\r\\n|\\r|\\n/\n\ntype Prefixes = 'lines' | 'command'\n\nconst PreText = styled(Text, {\n  shouldForwardProp: prop =>\n    !['hasShowMoreButton', 'showMore', 'rows', 'noExpandable'].includes(prop),\n})<{\n  hasShowMoreButton?: boolean\n  showMore?: boolean\n  rows: number\n  noExpandable: boolean\n}>`\n  margin: 0;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-right: ${({ theme }) => theme.space['9']};\n  overflow-x: ${({ hasShowMoreButton, showMore }) =>\n    hasShowMoreButton && !showMore ? 'hidden' : 'auto'};\n  height: auto;\n  counter-reset: section;\n\n\n  ${({ theme, noExpandable, rows }) =>\n    noExpandable\n      ? `\n    max-height: calc(${theme.typography.code.lineHeight} * ${rows} + ${theme.space['3']});\n    overflow-y: scroll;`\n      : `overflow-y: hidden;\n`}\n`\n\nconst StyledSpan = styled('span', {\n  shouldForwardProp: prop =>\n    !['linePrefix', 'multiline', 'prefix'].includes(prop),\n})<{ linePrefix?: string; multiline?: boolean; prefix?: Prefixes }>`\n  display: block;\n\n\n  &:not([data-multiline]):after {\n    content: \"\";\n    ${({ theme }) => `padding-right: ${theme.space['8']}`};\n  }\n\n  &[data-multiline=\"true\"]:nth-child(-n+2):after {\n    content: \"\";\n    ${({ theme }) => `padding-right: ${theme.space['8']}`};\n  }\n\n  ${({ prefix, theme }) =>\n    prefix\n      ? `\n    &:before {\n      color: ${theme.colors.neutral.textWeak};\n      width: ${prefix === 'lines' ? '35px' : ''};\n      display: inline-flex;\n      justify-content: flex-end;\n      counter-increment: section;\n      content: ${prefix === 'lines' ? 'counter(section)' : \"'$'\"};\n      padding-right: ${theme.space['1']};\n    }\n  `\n      : null}\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: relative;\n  display: flex;\n  justify-content: start;\n  max-width: 100%;\n  ${({ multiline }) => (multiline ? 'width: 100%;' : '')}\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n`\n\nconst StyledStack = styled(Stack)`\n  width: 100%;\n`\n\nconst ButtonContainer = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: absolute;\n  top: 0;\n  right: 0;\n  padding: ${({ theme, multiline }) =>\n    `${theme.space[multiline ? '2' : '1']} ${theme.space['2']} 0 0`};\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n  border: 2px solid transparent;\n  ${({ multiline, theme }) =>\n    !multiline\n      ? `box-shadow: -27px 0 19px -11px ${theme.colors.neutral.backgroundWeak}`\n      : ''};\n`\n\nconst ShowMoreContainer = styled('div', {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  width: 100%;\n  box-shadow: ${({ theme, showMore }) =>\n    !showMore\n      ? `0px -22px 19px -6px\n    ${theme.colors.neutral.backgroundWeak}`\n      : 'none'};\n`\n\nconst StyledButton = styled.button`\n  width: 100%;\n  background: none;\n  border: none;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-top: ${({ theme }) => theme.space['1']};\n  cursor: pointer;\n`\n\nconst AlignCenterText = styled(Text)`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n`\n\nconst AnimatedArrowIcon = styled(ArrowDownIcon, {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  transform: ${({ showMore }) => (showMore ? 'rotate(180deg)' : 'rotate(0deg)')};\n  transform-origin: center;\n  transition: transform 300ms ease-in-out;\n`\n\ntype CodeContentProps = {\n  children: string\n  prefix?: Prefixes\n  multiline?: boolean\n  showMore?: boolean\n  hasShowMoreButton?: boolean\n  lines?: string[]\n  noExpandable: boolean\n  rows: number\n}\n\nconst CodeContent = ({\n  children,\n  prefix,\n  multiline,\n  showMore,\n  hasShowMoreButton,\n  lines,\n  noExpandable,\n  rows,\n}: CodeContentProps) => (\n  <PreText\n    as=\"pre\"\n    hasShowMoreButton={hasShowMoreButton}\n    noExpandable={noExpandable}\n    rows={rows}\n    showMore={showMore}\n    variant=\"code\"\n    whiteSpace={!multiline ? 'nowrap' : undefined}\n  >\n    {multiline ? (\n      Children.map(lines, child => (\n        <StyledSpan data-multiline=\"true\" key={child} prefix={prefix}>\n          {child}\n        </StyledSpan>\n      ))\n    ) : (\n      <StyledSpan prefix={prefix}>{children}</StyledSpan>\n    )}\n  </PreText>\n)\n\ntype SnippetProps = {\n  className?: string\n  children: string\n  /**\n   * prefix display an element at the beginning of the snippet that is not copiable or selectable.\n   * For `lines` prefix it will display the line number.\n   * For `command` prefix it will display a `$` sign.\n   */\n  prefix?: Prefixes\n  showText?: string\n  hideText?: string\n  'data-testid'?: string\n  initiallyExpanded?: boolean\n  rows?: number\n  noExpandable?: boolean\n  onCopy?: () => void\n} & Pick<ComponentProps<typeof CopyButton>, 'copyText' | 'copiedText'>\n\n/**\n * Snippet component is used to display code snippets with the ability to copy the code.\n * It also has the ability to show/hide the code snippet if it has more than 4 lines.\n */\nexport const Snippet = ({\n  children,\n  copyText,\n  copiedText,\n  showText = 'Show',\n  hideText = 'Hide',\n  prefix,\n  className,\n  'data-testid': dataTestId,\n  initiallyExpanded,\n  rows = 4,\n  noExpandable = false,\n  onCopy,\n}: SnippetProps) => {\n  const theme = useTheme()\n  const [showMore, setShowMore] = useReducer(\n    value => !value,\n    initiallyExpanded ?? false,\n  )\n  const lines = children.split(LINES_BREAK_REGEX)\n\n  const numberOfLines = lines.length\n  const multiline = numberOfLines > 1\n  const hasShowMoreButton = numberOfLines > rows && multiline && !noExpandable\n  // Height of the expandable (when needed) = number of rows * height of a line (from rem to px) + padding (from rem to px)\n  const minHeight =\n    rows * Number.parseFloat(theme.typography.code.lineHeight) * 16 +\n    Number.parseFloat(theme.space[4]) * 16\n\n  return (\n    <Container\n      className={className}\n      data-testid={dataTestId}\n      multiline={multiline}\n    >\n      <StyledStack>\n        {hasShowMoreButton ? (\n          <Expandable minHeight={minHeight} opened={showMore}>\n            <CodeContent\n              lines={lines}\n              multiline={multiline}\n              noExpandable={noExpandable}\n              prefix={prefix}\n              rows={rows}\n            >\n              {children}\n            </CodeContent>\n          </Expandable>\n        ) : (\n          <CodeContent\n            lines={lines}\n            multiline={multiline}\n            noExpandable={noExpandable}\n            prefix={prefix}\n            rows={rows}\n          >\n            {children}\n          </CodeContent>\n        )}\n        <ButtonContainer multiline={multiline && numberOfLines > 1}>\n          <CopyButton\n            copiedText={copiedText}\n            copyText={copyText}\n            onCopy={onCopy}\n            sentiment=\"neutral\"\n            value={children}\n          />\n        </ButtonContainer>\n        {hasShowMoreButton ? (\n          <ShowMoreContainer showMore={showMore}>\n            <StyledButton\n              aria-expanded={showMore}\n              onClick={setShowMore}\n              type=\"button\"\n            >\n              <AlignCenterText\n                as=\"span\"\n                sentiment=\"neutral\"\n                variant=\"bodySmallStrong\"\n              >\n                {showMore ? hideText : showText}\n                &nbsp;\n                <AnimatedArrowIcon showMore={showMore} />\n              </AlignCenterText>\n            </StyledButton>\n          </ShowMoreContainer>\n        ) : null}\n      </StyledStack>\n    </Container>\n  )\n}\n"]} */"));
106
107
  const ShowMoreContainer = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
107
108
  shouldForwardProp: (prop) => !["showMore"].includes(prop),
108
109
  target: "e1q0gj903"
@@ -114,7 +115,7 @@ const ShowMoreContainer = /* @__PURE__ */ _styled("div", process.env.NODE_ENV ==
114
115
  theme,
115
116
  showMore
116
117
  }) => !showMore ? `0px -22px 19px -6px
117
- ${theme.colors.neutral.backgroundWeak}` : "none", ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx"],"names":[],"mappings":"AA6G0B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx","sourcesContent":["'use client'\n\nimport { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon } from '@ultraviolet/icons'\nimport type { ComponentProps } from 'react'\nimport { Children, useReducer } from 'react'\nimport { CopyButton } from '../CopyButton'\nimport { Expandable } from '../Expandable'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst LINES_BREAK_REGEX = /\\r\\n|\\r|\\n/\n\ntype Prefixes = 'lines' | 'command'\n\nconst PreText = styled(Text, {\n  shouldForwardProp: prop =>\n    !['hasShowMoreButton', 'showMore', 'rows', 'noExpandable'].includes(prop),\n})<{\n  hasShowMoreButton?: boolean\n  showMore?: boolean\n  rows: number\n  noExpandable: boolean\n}>`\n  margin: 0;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-right: ${({ theme }) => theme.space['9']};\n  overflow-x: ${({ hasShowMoreButton, showMore }) =>\n    hasShowMoreButton && !showMore ? 'hidden' : 'auto'};\n  height: auto;\n  counter-reset: section;\n\n\n  ${({ theme, noExpandable, rows }) =>\n    noExpandable\n      ? `\n    max-height: calc(${theme.typography.code.lineHeight} * ${rows} + ${theme.space['3']});\n    overflow-y: scroll;`\n      : `overflow-y: hidden;\n`}\n`\n\nconst StyledSpan = styled('span', {\n  shouldForwardProp: prop =>\n    !['linePrefix', 'multiline', 'prefix'].includes(prop),\n})<{ linePrefix?: string; multiline?: boolean; prefix?: Prefixes }>`\n  display: block;\n\n\n  &:after {\n    content: \"\";\n    ${({ theme, multiline }) =>\n      multiline\n        ? `padding: ${theme.space['4']}`\n        : `padding-right: ${theme.space['8']}`};\n  }\n\n  ${({ prefix, theme }) =>\n    prefix\n      ? `\n    &:before {\n      color: ${theme.colors.neutral.textWeak};\n      width: ${prefix === 'lines' ? '35px' : ''};\n      display: inline-flex;\n      justify-content: flex-end;\n      counter-increment: section;\n      content: ${prefix === 'lines' ? 'counter(section)' : \"'$'\"};\n      padding-right: ${theme.space['1']};\n    }\n  `\n      : null}\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: relative;\n  display: flex;\n  justify-content: start;\n  max-width: 100%;\n  ${({ multiline }) => (multiline ? 'width: 100%;' : '')}\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n`\n\nconst StyledStack = styled(Stack)`\n  width: 100%;\n`\n\nconst ButtonContainer = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: absolute;\n  top: 0;\n  right: 0;\n  padding: ${({ theme, multiline }) =>\n    `${theme.space[multiline ? '2' : '1']} ${theme.space['2']} 0 0`};\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n  border: 2px solid transparent;\n  ${({ multiline, theme }) =>\n    !multiline\n      ? `box-shadow: -27px 0 19px -11px ${theme.colors.neutral.backgroundWeak}`\n      : ''};\n`\n\nconst ShowMoreContainer = styled('div', {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  width: 100%;\n  box-shadow: ${({ theme, showMore }) =>\n    !showMore\n      ? `0px -22px 19px -6px\n    ${theme.colors.neutral.backgroundWeak}`\n      : 'none'};\n`\n\nconst StyledButton = styled.button`\n  width: 100%;\n  background: none;\n  border: none;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-top: ${({ theme }) => theme.space['1']};\n  cursor: pointer;\n`\n\nconst AlignCenterText = styled(Text)`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n`\n\nconst AnimatedArrowIcon = styled(ArrowDownIcon, {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  transform: ${({ showMore }) => (showMore ? 'rotate(180deg)' : 'rotate(0deg)')};\n  transform-origin: center;\n  transition: transform 300ms ease-in-out;\n`\n\ntype CodeContentProps = {\n  children: string\n  prefix?: Prefixes\n  multiline?: boolean\n  showMore?: boolean\n  hasShowMoreButton?: boolean\n  lines?: string[]\n  noExpandable: boolean\n  rows: number\n}\n\nconst CodeContent = ({\n  children,\n  prefix,\n  multiline,\n  showMore,\n  hasShowMoreButton,\n  lines,\n  noExpandable,\n  rows,\n}: CodeContentProps) => (\n  <PreText\n    as=\"pre\"\n    hasShowMoreButton={hasShowMoreButton}\n    noExpandable={noExpandable}\n    rows={rows}\n    showMore={showMore}\n    variant=\"code\"\n    whiteSpace={!multiline ? 'nowrap' : undefined}\n  >\n    {multiline ? (\n      Children.map(lines, child => (\n        <StyledSpan key={child} multiline prefix={prefix}>\n          {child}\n        </StyledSpan>\n      ))\n    ) : (\n      <StyledSpan prefix={prefix}>{children}</StyledSpan>\n    )}\n  </PreText>\n)\n\ntype SnippetProps = {\n  className?: string\n  children: string\n  /**\n   * prefix display an element at the beginning of the snippet that is not copiable or selectable.\n   * For `lines` prefix it will display the line number.\n   * For `command` prefix it will display a `$` sign.\n   */\n  prefix?: Prefixes\n  showText?: string\n  hideText?: string\n  'data-testid'?: string\n  initiallyExpanded?: boolean\n  rows?: number\n  noExpandable?: boolean\n  onCopy?: () => void\n} & Pick<ComponentProps<typeof CopyButton>, 'copyText' | 'copiedText'>\n\n/**\n * Snippet component is used to display code snippets with the ability to copy the code.\n * It also has the ability to show/hide the code snippet if it has more than 4 lines.\n */\nexport const Snippet = ({\n  children,\n  copyText,\n  copiedText,\n  showText = 'Show',\n  hideText = 'Hide',\n  prefix,\n  className,\n  'data-testid': dataTestId,\n  initiallyExpanded,\n  rows = 4,\n  noExpandable = false,\n  onCopy,\n}: SnippetProps) => {\n  const theme = useTheme()\n  const [showMore, setShowMore] = useReducer(\n    value => !value,\n    initiallyExpanded ?? false,\n  )\n  const lines = children.split(LINES_BREAK_REGEX)\n\n  const numberOfLines = lines.length\n  const multiline = numberOfLines > 1\n  const hasShowMoreButton = numberOfLines > rows && multiline && !noExpandable\n  // Height of the expandable (when needed) = number of rows * height of a line (from rem to px) + padding (from rem to px)\n  const minHeight =\n    rows * Number.parseFloat(theme.typography.code.lineHeight) * 16 +\n    Number.parseFloat(theme.space[4]) * 16\n\n  return (\n    <Container\n      className={className}\n      data-testid={dataTestId}\n      multiline={multiline}\n    >\n      <StyledStack>\n        {hasShowMoreButton ? (\n          <Expandable minHeight={minHeight} opened={showMore}>\n            <CodeContent\n              lines={lines}\n              multiline={multiline}\n              noExpandable={noExpandable}\n              prefix={prefix}\n              rows={rows}\n            >\n              {children}\n            </CodeContent>\n          </Expandable>\n        ) : (\n          <CodeContent\n            lines={lines}\n            multiline={multiline}\n            noExpandable={noExpandable}\n            prefix={prefix}\n            rows={rows}\n          >\n            {children}\n          </CodeContent>\n        )}\n        <ButtonContainer multiline={multiline && numberOfLines > 1}>\n          <CopyButton\n            copiedText={copiedText}\n            copyText={copyText}\n            onCopy={onCopy}\n            sentiment=\"neutral\"\n            value={children}\n          />\n        </ButtonContainer>\n        {hasShowMoreButton ? (\n          <ShowMoreContainer showMore={showMore}>\n            <StyledButton\n              aria-expanded={showMore}\n              onClick={setShowMore}\n              type=\"button\"\n            >\n              <AlignCenterText\n                as=\"span\"\n                sentiment=\"neutral\"\n                variant=\"bodySmallStrong\"\n              >\n                {showMore ? hideText : showText}\n                &nbsp;\n                <AnimatedArrowIcon showMore={showMore} />\n              </AlignCenterText>\n            </StyledButton>\n          </ShowMoreContainer>\n        ) : null}\n      </StyledStack>\n    </Container>\n  )\n}\n"]} */"));
118
+ ${theme.colors.neutral.backgroundWeak}` : "none", ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx"],"names":[],"mappings":"AA+G0B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx","sourcesContent":["'use client'\n\nimport { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon } from '@ultraviolet/icons'\nimport type { ComponentProps } from 'react'\nimport { Children, useReducer } from 'react'\nimport { CopyButton } from '../CopyButton'\nimport { Expandable } from '../Expandable'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst LINES_BREAK_REGEX = /\\r\\n|\\r|\\n/\n\ntype Prefixes = 'lines' | 'command'\n\nconst PreText = styled(Text, {\n  shouldForwardProp: prop =>\n    !['hasShowMoreButton', 'showMore', 'rows', 'noExpandable'].includes(prop),\n})<{\n  hasShowMoreButton?: boolean\n  showMore?: boolean\n  rows: number\n  noExpandable: boolean\n}>`\n  margin: 0;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-right: ${({ theme }) => theme.space['9']};\n  overflow-x: ${({ hasShowMoreButton, showMore }) =>\n    hasShowMoreButton && !showMore ? 'hidden' : 'auto'};\n  height: auto;\n  counter-reset: section;\n\n\n  ${({ theme, noExpandable, rows }) =>\n    noExpandable\n      ? `\n    max-height: calc(${theme.typography.code.lineHeight} * ${rows} + ${theme.space['3']});\n    overflow-y: scroll;`\n      : `overflow-y: hidden;\n`}\n`\n\nconst StyledSpan = styled('span', {\n  shouldForwardProp: prop =>\n    !['linePrefix', 'multiline', 'prefix'].includes(prop),\n})<{ linePrefix?: string; multiline?: boolean; prefix?: Prefixes }>`\n  display: block;\n\n\n  &:not([data-multiline]):after {\n    content: \"\";\n    ${({ theme }) => `padding-right: ${theme.space['8']}`};\n  }\n\n  &[data-multiline=\"true\"]:nth-child(-n+2):after {\n    content: \"\";\n    ${({ theme }) => `padding-right: ${theme.space['8']}`};\n  }\n\n  ${({ prefix, theme }) =>\n    prefix\n      ? `\n    &:before {\n      color: ${theme.colors.neutral.textWeak};\n      width: ${prefix === 'lines' ? '35px' : ''};\n      display: inline-flex;\n      justify-content: flex-end;\n      counter-increment: section;\n      content: ${prefix === 'lines' ? 'counter(section)' : \"'$'\"};\n      padding-right: ${theme.space['1']};\n    }\n  `\n      : null}\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: relative;\n  display: flex;\n  justify-content: start;\n  max-width: 100%;\n  ${({ multiline }) => (multiline ? 'width: 100%;' : '')}\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n`\n\nconst StyledStack = styled(Stack)`\n  width: 100%;\n`\n\nconst ButtonContainer = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: absolute;\n  top: 0;\n  right: 0;\n  padding: ${({ theme, multiline }) =>\n    `${theme.space[multiline ? '2' : '1']} ${theme.space['2']} 0 0`};\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n  border: 2px solid transparent;\n  ${({ multiline, theme }) =>\n    !multiline\n      ? `box-shadow: -27px 0 19px -11px ${theme.colors.neutral.backgroundWeak}`\n      : ''};\n`\n\nconst ShowMoreContainer = styled('div', {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  width: 100%;\n  box-shadow: ${({ theme, showMore }) =>\n    !showMore\n      ? `0px -22px 19px -6px\n    ${theme.colors.neutral.backgroundWeak}`\n      : 'none'};\n`\n\nconst StyledButton = styled.button`\n  width: 100%;\n  background: none;\n  border: none;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-top: ${({ theme }) => theme.space['1']};\n  cursor: pointer;\n`\n\nconst AlignCenterText = styled(Text)`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n`\n\nconst AnimatedArrowIcon = styled(ArrowDownIcon, {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  transform: ${({ showMore }) => (showMore ? 'rotate(180deg)' : 'rotate(0deg)')};\n  transform-origin: center;\n  transition: transform 300ms ease-in-out;\n`\n\ntype CodeContentProps = {\n  children: string\n  prefix?: Prefixes\n  multiline?: boolean\n  showMore?: boolean\n  hasShowMoreButton?: boolean\n  lines?: string[]\n  noExpandable: boolean\n  rows: number\n}\n\nconst CodeContent = ({\n  children,\n  prefix,\n  multiline,\n  showMore,\n  hasShowMoreButton,\n  lines,\n  noExpandable,\n  rows,\n}: CodeContentProps) => (\n  <PreText\n    as=\"pre\"\n    hasShowMoreButton={hasShowMoreButton}\n    noExpandable={noExpandable}\n    rows={rows}\n    showMore={showMore}\n    variant=\"code\"\n    whiteSpace={!multiline ? 'nowrap' : undefined}\n  >\n    {multiline ? (\n      Children.map(lines, child => (\n        <StyledSpan data-multiline=\"true\" key={child} prefix={prefix}>\n          {child}\n        </StyledSpan>\n      ))\n    ) : (\n      <StyledSpan prefix={prefix}>{children}</StyledSpan>\n    )}\n  </PreText>\n)\n\ntype SnippetProps = {\n  className?: string\n  children: string\n  /**\n   * prefix display an element at the beginning of the snippet that is not copiable or selectable.\n   * For `lines` prefix it will display the line number.\n   * For `command` prefix it will display a `$` sign.\n   */\n  prefix?: Prefixes\n  showText?: string\n  hideText?: string\n  'data-testid'?: string\n  initiallyExpanded?: boolean\n  rows?: number\n  noExpandable?: boolean\n  onCopy?: () => void\n} & Pick<ComponentProps<typeof CopyButton>, 'copyText' | 'copiedText'>\n\n/**\n * Snippet component is used to display code snippets with the ability to copy the code.\n * It also has the ability to show/hide the code snippet if it has more than 4 lines.\n */\nexport const Snippet = ({\n  children,\n  copyText,\n  copiedText,\n  showText = 'Show',\n  hideText = 'Hide',\n  prefix,\n  className,\n  'data-testid': dataTestId,\n  initiallyExpanded,\n  rows = 4,\n  noExpandable = false,\n  onCopy,\n}: SnippetProps) => {\n  const theme = useTheme()\n  const [showMore, setShowMore] = useReducer(\n    value => !value,\n    initiallyExpanded ?? false,\n  )\n  const lines = children.split(LINES_BREAK_REGEX)\n\n  const numberOfLines = lines.length\n  const multiline = numberOfLines > 1\n  const hasShowMoreButton = numberOfLines > rows && multiline && !noExpandable\n  // Height of the expandable (when needed) = number of rows * height of a line (from rem to px) + padding (from rem to px)\n  const minHeight =\n    rows * Number.parseFloat(theme.typography.code.lineHeight) * 16 +\n    Number.parseFloat(theme.space[4]) * 16\n\n  return (\n    <Container\n      className={className}\n      data-testid={dataTestId}\n      multiline={multiline}\n    >\n      <StyledStack>\n        {hasShowMoreButton ? (\n          <Expandable minHeight={minHeight} opened={showMore}>\n            <CodeContent\n              lines={lines}\n              multiline={multiline}\n              noExpandable={noExpandable}\n              prefix={prefix}\n              rows={rows}\n            >\n              {children}\n            </CodeContent>\n          </Expandable>\n        ) : (\n          <CodeContent\n            lines={lines}\n            multiline={multiline}\n            noExpandable={noExpandable}\n            prefix={prefix}\n            rows={rows}\n          >\n            {children}\n          </CodeContent>\n        )}\n        <ButtonContainer multiline={multiline && numberOfLines > 1}>\n          <CopyButton\n            copiedText={copiedText}\n            copyText={copyText}\n            onCopy={onCopy}\n            sentiment=\"neutral\"\n            value={children}\n          />\n        </ButtonContainer>\n        {hasShowMoreButton ? (\n          <ShowMoreContainer showMore={showMore}>\n            <StyledButton\n              aria-expanded={showMore}\n              onClick={setShowMore}\n              type=\"button\"\n            >\n              <AlignCenterText\n                as=\"span\"\n                sentiment=\"neutral\"\n                variant=\"bodySmallStrong\"\n              >\n                {showMore ? hideText : showText}\n                &nbsp;\n                <AnimatedArrowIcon showMore={showMore} />\n              </AlignCenterText>\n            </StyledButton>\n          </ShowMoreContainer>\n        ) : null}\n      </StyledStack>\n    </Container>\n  )\n}\n"]} */"));
118
119
  const StyledButton = /* @__PURE__ */ _styled("button", process.env.NODE_ENV === "production" ? {
119
120
  target: "e1q0gj902"
120
121
  } : {
@@ -124,7 +125,7 @@ const StyledButton = /* @__PURE__ */ _styled("button", process.env.NODE_ENV ===
124
125
  theme
125
126
  }) => theme.space["2"], ";padding-top:", ({
126
127
  theme
127
- }) => theme.space["1"], ";cursor:pointer;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx"],"names":[],"mappings":"AAsHkC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx","sourcesContent":["'use client'\n\nimport { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon } from '@ultraviolet/icons'\nimport type { ComponentProps } from 'react'\nimport { Children, useReducer } from 'react'\nimport { CopyButton } from '../CopyButton'\nimport { Expandable } from '../Expandable'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst LINES_BREAK_REGEX = /\\r\\n|\\r|\\n/\n\ntype Prefixes = 'lines' | 'command'\n\nconst PreText = styled(Text, {\n  shouldForwardProp: prop =>\n    !['hasShowMoreButton', 'showMore', 'rows', 'noExpandable'].includes(prop),\n})<{\n  hasShowMoreButton?: boolean\n  showMore?: boolean\n  rows: number\n  noExpandable: boolean\n}>`\n  margin: 0;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-right: ${({ theme }) => theme.space['9']};\n  overflow-x: ${({ hasShowMoreButton, showMore }) =>\n    hasShowMoreButton && !showMore ? 'hidden' : 'auto'};\n  height: auto;\n  counter-reset: section;\n\n\n  ${({ theme, noExpandable, rows }) =>\n    noExpandable\n      ? `\n    max-height: calc(${theme.typography.code.lineHeight} * ${rows} + ${theme.space['3']});\n    overflow-y: scroll;`\n      : `overflow-y: hidden;\n`}\n`\n\nconst StyledSpan = styled('span', {\n  shouldForwardProp: prop =>\n    !['linePrefix', 'multiline', 'prefix'].includes(prop),\n})<{ linePrefix?: string; multiline?: boolean; prefix?: Prefixes }>`\n  display: block;\n\n\n  &:after {\n    content: \"\";\n    ${({ theme, multiline }) =>\n      multiline\n        ? `padding: ${theme.space['4']}`\n        : `padding-right: ${theme.space['8']}`};\n  }\n\n  ${({ prefix, theme }) =>\n    prefix\n      ? `\n    &:before {\n      color: ${theme.colors.neutral.textWeak};\n      width: ${prefix === 'lines' ? '35px' : ''};\n      display: inline-flex;\n      justify-content: flex-end;\n      counter-increment: section;\n      content: ${prefix === 'lines' ? 'counter(section)' : \"'$'\"};\n      padding-right: ${theme.space['1']};\n    }\n  `\n      : null}\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: relative;\n  display: flex;\n  justify-content: start;\n  max-width: 100%;\n  ${({ multiline }) => (multiline ? 'width: 100%;' : '')}\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n`\n\nconst StyledStack = styled(Stack)`\n  width: 100%;\n`\n\nconst ButtonContainer = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: absolute;\n  top: 0;\n  right: 0;\n  padding: ${({ theme, multiline }) =>\n    `${theme.space[multiline ? '2' : '1']} ${theme.space['2']} 0 0`};\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n  border: 2px solid transparent;\n  ${({ multiline, theme }) =>\n    !multiline\n      ? `box-shadow: -27px 0 19px -11px ${theme.colors.neutral.backgroundWeak}`\n      : ''};\n`\n\nconst ShowMoreContainer = styled('div', {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  width: 100%;\n  box-shadow: ${({ theme, showMore }) =>\n    !showMore\n      ? `0px -22px 19px -6px\n    ${theme.colors.neutral.backgroundWeak}`\n      : 'none'};\n`\n\nconst StyledButton = styled.button`\n  width: 100%;\n  background: none;\n  border: none;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-top: ${({ theme }) => theme.space['1']};\n  cursor: pointer;\n`\n\nconst AlignCenterText = styled(Text)`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n`\n\nconst AnimatedArrowIcon = styled(ArrowDownIcon, {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  transform: ${({ showMore }) => (showMore ? 'rotate(180deg)' : 'rotate(0deg)')};\n  transform-origin: center;\n  transition: transform 300ms ease-in-out;\n`\n\ntype CodeContentProps = {\n  children: string\n  prefix?: Prefixes\n  multiline?: boolean\n  showMore?: boolean\n  hasShowMoreButton?: boolean\n  lines?: string[]\n  noExpandable: boolean\n  rows: number\n}\n\nconst CodeContent = ({\n  children,\n  prefix,\n  multiline,\n  showMore,\n  hasShowMoreButton,\n  lines,\n  noExpandable,\n  rows,\n}: CodeContentProps) => (\n  <PreText\n    as=\"pre\"\n    hasShowMoreButton={hasShowMoreButton}\n    noExpandable={noExpandable}\n    rows={rows}\n    showMore={showMore}\n    variant=\"code\"\n    whiteSpace={!multiline ? 'nowrap' : undefined}\n  >\n    {multiline ? (\n      Children.map(lines, child => (\n        <StyledSpan key={child} multiline prefix={prefix}>\n          {child}\n        </StyledSpan>\n      ))\n    ) : (\n      <StyledSpan prefix={prefix}>{children}</StyledSpan>\n    )}\n  </PreText>\n)\n\ntype SnippetProps = {\n  className?: string\n  children: string\n  /**\n   * prefix display an element at the beginning of the snippet that is not copiable or selectable.\n   * For `lines` prefix it will display the line number.\n   * For `command` prefix it will display a `$` sign.\n   */\n  prefix?: Prefixes\n  showText?: string\n  hideText?: string\n  'data-testid'?: string\n  initiallyExpanded?: boolean\n  rows?: number\n  noExpandable?: boolean\n  onCopy?: () => void\n} & Pick<ComponentProps<typeof CopyButton>, 'copyText' | 'copiedText'>\n\n/**\n * Snippet component is used to display code snippets with the ability to copy the code.\n * It also has the ability to show/hide the code snippet if it has more than 4 lines.\n */\nexport const Snippet = ({\n  children,\n  copyText,\n  copiedText,\n  showText = 'Show',\n  hideText = 'Hide',\n  prefix,\n  className,\n  'data-testid': dataTestId,\n  initiallyExpanded,\n  rows = 4,\n  noExpandable = false,\n  onCopy,\n}: SnippetProps) => {\n  const theme = useTheme()\n  const [showMore, setShowMore] = useReducer(\n    value => !value,\n    initiallyExpanded ?? false,\n  )\n  const lines = children.split(LINES_BREAK_REGEX)\n\n  const numberOfLines = lines.length\n  const multiline = numberOfLines > 1\n  const hasShowMoreButton = numberOfLines > rows && multiline && !noExpandable\n  // Height of the expandable (when needed) = number of rows * height of a line (from rem to px) + padding (from rem to px)\n  const minHeight =\n    rows * Number.parseFloat(theme.typography.code.lineHeight) * 16 +\n    Number.parseFloat(theme.space[4]) * 16\n\n  return (\n    <Container\n      className={className}\n      data-testid={dataTestId}\n      multiline={multiline}\n    >\n      <StyledStack>\n        {hasShowMoreButton ? (\n          <Expandable minHeight={minHeight} opened={showMore}>\n            <CodeContent\n              lines={lines}\n              multiline={multiline}\n              noExpandable={noExpandable}\n              prefix={prefix}\n              rows={rows}\n            >\n              {children}\n            </CodeContent>\n          </Expandable>\n        ) : (\n          <CodeContent\n            lines={lines}\n            multiline={multiline}\n            noExpandable={noExpandable}\n            prefix={prefix}\n            rows={rows}\n          >\n            {children}\n          </CodeContent>\n        )}\n        <ButtonContainer multiline={multiline && numberOfLines > 1}>\n          <CopyButton\n            copiedText={copiedText}\n            copyText={copyText}\n            onCopy={onCopy}\n            sentiment=\"neutral\"\n            value={children}\n          />\n        </ButtonContainer>\n        {hasShowMoreButton ? (\n          <ShowMoreContainer showMore={showMore}>\n            <StyledButton\n              aria-expanded={showMore}\n              onClick={setShowMore}\n              type=\"button\"\n            >\n              <AlignCenterText\n                as=\"span\"\n                sentiment=\"neutral\"\n                variant=\"bodySmallStrong\"\n              >\n                {showMore ? hideText : showText}\n                &nbsp;\n                <AnimatedArrowIcon showMore={showMore} />\n              </AlignCenterText>\n            </StyledButton>\n          </ShowMoreContainer>\n        ) : null}\n      </StyledStack>\n    </Container>\n  )\n}\n"]} */"));
128
+ }) => theme.space["1"], ";cursor:pointer;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx"],"names":[],"mappings":"AAwHkC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx","sourcesContent":["'use client'\n\nimport { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon } from '@ultraviolet/icons'\nimport type { ComponentProps } from 'react'\nimport { Children, useReducer } from 'react'\nimport { CopyButton } from '../CopyButton'\nimport { Expandable } from '../Expandable'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst LINES_BREAK_REGEX = /\\r\\n|\\r|\\n/\n\ntype Prefixes = 'lines' | 'command'\n\nconst PreText = styled(Text, {\n  shouldForwardProp: prop =>\n    !['hasShowMoreButton', 'showMore', 'rows', 'noExpandable'].includes(prop),\n})<{\n  hasShowMoreButton?: boolean\n  showMore?: boolean\n  rows: number\n  noExpandable: boolean\n}>`\n  margin: 0;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-right: ${({ theme }) => theme.space['9']};\n  overflow-x: ${({ hasShowMoreButton, showMore }) =>\n    hasShowMoreButton && !showMore ? 'hidden' : 'auto'};\n  height: auto;\n  counter-reset: section;\n\n\n  ${({ theme, noExpandable, rows }) =>\n    noExpandable\n      ? `\n    max-height: calc(${theme.typography.code.lineHeight} * ${rows} + ${theme.space['3']});\n    overflow-y: scroll;`\n      : `overflow-y: hidden;\n`}\n`\n\nconst StyledSpan = styled('span', {\n  shouldForwardProp: prop =>\n    !['linePrefix', 'multiline', 'prefix'].includes(prop),\n})<{ linePrefix?: string; multiline?: boolean; prefix?: Prefixes }>`\n  display: block;\n\n\n  &:not([data-multiline]):after {\n    content: \"\";\n    ${({ theme }) => `padding-right: ${theme.space['8']}`};\n  }\n\n  &[data-multiline=\"true\"]:nth-child(-n+2):after {\n    content: \"\";\n    ${({ theme }) => `padding-right: ${theme.space['8']}`};\n  }\n\n  ${({ prefix, theme }) =>\n    prefix\n      ? `\n    &:before {\n      color: ${theme.colors.neutral.textWeak};\n      width: ${prefix === 'lines' ? '35px' : ''};\n      display: inline-flex;\n      justify-content: flex-end;\n      counter-increment: section;\n      content: ${prefix === 'lines' ? 'counter(section)' : \"'$'\"};\n      padding-right: ${theme.space['1']};\n    }\n  `\n      : null}\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: relative;\n  display: flex;\n  justify-content: start;\n  max-width: 100%;\n  ${({ multiline }) => (multiline ? 'width: 100%;' : '')}\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n`\n\nconst StyledStack = styled(Stack)`\n  width: 100%;\n`\n\nconst ButtonContainer = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: absolute;\n  top: 0;\n  right: 0;\n  padding: ${({ theme, multiline }) =>\n    `${theme.space[multiline ? '2' : '1']} ${theme.space['2']} 0 0`};\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n  border: 2px solid transparent;\n  ${({ multiline, theme }) =>\n    !multiline\n      ? `box-shadow: -27px 0 19px -11px ${theme.colors.neutral.backgroundWeak}`\n      : ''};\n`\n\nconst ShowMoreContainer = styled('div', {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  width: 100%;\n  box-shadow: ${({ theme, showMore }) =>\n    !showMore\n      ? `0px -22px 19px -6px\n    ${theme.colors.neutral.backgroundWeak}`\n      : 'none'};\n`\n\nconst StyledButton = styled.button`\n  width: 100%;\n  background: none;\n  border: none;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-top: ${({ theme }) => theme.space['1']};\n  cursor: pointer;\n`\n\nconst AlignCenterText = styled(Text)`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n`\n\nconst AnimatedArrowIcon = styled(ArrowDownIcon, {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  transform: ${({ showMore }) => (showMore ? 'rotate(180deg)' : 'rotate(0deg)')};\n  transform-origin: center;\n  transition: transform 300ms ease-in-out;\n`\n\ntype CodeContentProps = {\n  children: string\n  prefix?: Prefixes\n  multiline?: boolean\n  showMore?: boolean\n  hasShowMoreButton?: boolean\n  lines?: string[]\n  noExpandable: boolean\n  rows: number\n}\n\nconst CodeContent = ({\n  children,\n  prefix,\n  multiline,\n  showMore,\n  hasShowMoreButton,\n  lines,\n  noExpandable,\n  rows,\n}: CodeContentProps) => (\n  <PreText\n    as=\"pre\"\n    hasShowMoreButton={hasShowMoreButton}\n    noExpandable={noExpandable}\n    rows={rows}\n    showMore={showMore}\n    variant=\"code\"\n    whiteSpace={!multiline ? 'nowrap' : undefined}\n  >\n    {multiline ? (\n      Children.map(lines, child => (\n        <StyledSpan data-multiline=\"true\" key={child} prefix={prefix}>\n          {child}\n        </StyledSpan>\n      ))\n    ) : (\n      <StyledSpan prefix={prefix}>{children}</StyledSpan>\n    )}\n  </PreText>\n)\n\ntype SnippetProps = {\n  className?: string\n  children: string\n  /**\n   * prefix display an element at the beginning of the snippet that is not copiable or selectable.\n   * For `lines` prefix it will display the line number.\n   * For `command` prefix it will display a `$` sign.\n   */\n  prefix?: Prefixes\n  showText?: string\n  hideText?: string\n  'data-testid'?: string\n  initiallyExpanded?: boolean\n  rows?: number\n  noExpandable?: boolean\n  onCopy?: () => void\n} & Pick<ComponentProps<typeof CopyButton>, 'copyText' | 'copiedText'>\n\n/**\n * Snippet component is used to display code snippets with the ability to copy the code.\n * It also has the ability to show/hide the code snippet if it has more than 4 lines.\n */\nexport const Snippet = ({\n  children,\n  copyText,\n  copiedText,\n  showText = 'Show',\n  hideText = 'Hide',\n  prefix,\n  className,\n  'data-testid': dataTestId,\n  initiallyExpanded,\n  rows = 4,\n  noExpandable = false,\n  onCopy,\n}: SnippetProps) => {\n  const theme = useTheme()\n  const [showMore, setShowMore] = useReducer(\n    value => !value,\n    initiallyExpanded ?? false,\n  )\n  const lines = children.split(LINES_BREAK_REGEX)\n\n  const numberOfLines = lines.length\n  const multiline = numberOfLines > 1\n  const hasShowMoreButton = numberOfLines > rows && multiline && !noExpandable\n  // Height of the expandable (when needed) = number of rows * height of a line (from rem to px) + padding (from rem to px)\n  const minHeight =\n    rows * Number.parseFloat(theme.typography.code.lineHeight) * 16 +\n    Number.parseFloat(theme.space[4]) * 16\n\n  return (\n    <Container\n      className={className}\n      data-testid={dataTestId}\n      multiline={multiline}\n    >\n      <StyledStack>\n        {hasShowMoreButton ? (\n          <Expandable minHeight={minHeight} opened={showMore}>\n            <CodeContent\n              lines={lines}\n              multiline={multiline}\n              noExpandable={noExpandable}\n              prefix={prefix}\n              rows={rows}\n            >\n              {children}\n            </CodeContent>\n          </Expandable>\n        ) : (\n          <CodeContent\n            lines={lines}\n            multiline={multiline}\n            noExpandable={noExpandable}\n            prefix={prefix}\n            rows={rows}\n          >\n            {children}\n          </CodeContent>\n        )}\n        <ButtonContainer multiline={multiline && numberOfLines > 1}>\n          <CopyButton\n            copiedText={copiedText}\n            copyText={copyText}\n            onCopy={onCopy}\n            sentiment=\"neutral\"\n            value={children}\n          />\n        </ButtonContainer>\n        {hasShowMoreButton ? (\n          <ShowMoreContainer showMore={showMore}>\n            <StyledButton\n              aria-expanded={showMore}\n              onClick={setShowMore}\n              type=\"button\"\n            >\n              <AlignCenterText\n                as=\"span\"\n                sentiment=\"neutral\"\n                variant=\"bodySmallStrong\"\n              >\n                {showMore ? hideText : showText}\n                &nbsp;\n                <AnimatedArrowIcon showMore={showMore} />\n              </AlignCenterText>\n            </StyledButton>\n          </ShowMoreContainer>\n        ) : null}\n      </StyledStack>\n    </Container>\n  )\n}\n"]} */"));
128
129
  const AlignCenterText = /* @__PURE__ */ _styled(Text, process.env.NODE_ENV === "production" ? {
129
130
  target: "e1q0gj901"
130
131
  } : {
@@ -135,7 +136,7 @@ const AlignCenterText = /* @__PURE__ */ _styled(Text, process.env.NODE_ENV === "
135
136
  styles: "display:flex;justify-content:center;align-items:center"
136
137
  } : {
137
138
  name: "1vcob1d",
138
- styles: "display:flex;justify-content:center;align-items:center/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx"],"names":[],"mappings":"AA+HoC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx","sourcesContent":["'use client'\n\nimport { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon } from '@ultraviolet/icons'\nimport type { ComponentProps } from 'react'\nimport { Children, useReducer } from 'react'\nimport { CopyButton } from '../CopyButton'\nimport { Expandable } from '../Expandable'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst LINES_BREAK_REGEX = /\\r\\n|\\r|\\n/\n\ntype Prefixes = 'lines' | 'command'\n\nconst PreText = styled(Text, {\n  shouldForwardProp: prop =>\n    !['hasShowMoreButton', 'showMore', 'rows', 'noExpandable'].includes(prop),\n})<{\n  hasShowMoreButton?: boolean\n  showMore?: boolean\n  rows: number\n  noExpandable: boolean\n}>`\n  margin: 0;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-right: ${({ theme }) => theme.space['9']};\n  overflow-x: ${({ hasShowMoreButton, showMore }) =>\n    hasShowMoreButton && !showMore ? 'hidden' : 'auto'};\n  height: auto;\n  counter-reset: section;\n\n\n  ${({ theme, noExpandable, rows }) =>\n    noExpandable\n      ? `\n    max-height: calc(${theme.typography.code.lineHeight} * ${rows} + ${theme.space['3']});\n    overflow-y: scroll;`\n      : `overflow-y: hidden;\n`}\n`\n\nconst StyledSpan = styled('span', {\n  shouldForwardProp: prop =>\n    !['linePrefix', 'multiline', 'prefix'].includes(prop),\n})<{ linePrefix?: string; multiline?: boolean; prefix?: Prefixes }>`\n  display: block;\n\n\n  &:after {\n    content: \"\";\n    ${({ theme, multiline }) =>\n      multiline\n        ? `padding: ${theme.space['4']}`\n        : `padding-right: ${theme.space['8']}`};\n  }\n\n  ${({ prefix, theme }) =>\n    prefix\n      ? `\n    &:before {\n      color: ${theme.colors.neutral.textWeak};\n      width: ${prefix === 'lines' ? '35px' : ''};\n      display: inline-flex;\n      justify-content: flex-end;\n      counter-increment: section;\n      content: ${prefix === 'lines' ? 'counter(section)' : \"'$'\"};\n      padding-right: ${theme.space['1']};\n    }\n  `\n      : null}\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: relative;\n  display: flex;\n  justify-content: start;\n  max-width: 100%;\n  ${({ multiline }) => (multiline ? 'width: 100%;' : '')}\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n`\n\nconst StyledStack = styled(Stack)`\n  width: 100%;\n`\n\nconst ButtonContainer = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: absolute;\n  top: 0;\n  right: 0;\n  padding: ${({ theme, multiline }) =>\n    `${theme.space[multiline ? '2' : '1']} ${theme.space['2']} 0 0`};\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n  border: 2px solid transparent;\n  ${({ multiline, theme }) =>\n    !multiline\n      ? `box-shadow: -27px 0 19px -11px ${theme.colors.neutral.backgroundWeak}`\n      : ''};\n`\n\nconst ShowMoreContainer = styled('div', {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  width: 100%;\n  box-shadow: ${({ theme, showMore }) =>\n    !showMore\n      ? `0px -22px 19px -6px\n    ${theme.colors.neutral.backgroundWeak}`\n      : 'none'};\n`\n\nconst StyledButton = styled.button`\n  width: 100%;\n  background: none;\n  border: none;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-top: ${({ theme }) => theme.space['1']};\n  cursor: pointer;\n`\n\nconst AlignCenterText = styled(Text)`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n`\n\nconst AnimatedArrowIcon = styled(ArrowDownIcon, {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  transform: ${({ showMore }) => (showMore ? 'rotate(180deg)' : 'rotate(0deg)')};\n  transform-origin: center;\n  transition: transform 300ms ease-in-out;\n`\n\ntype CodeContentProps = {\n  children: string\n  prefix?: Prefixes\n  multiline?: boolean\n  showMore?: boolean\n  hasShowMoreButton?: boolean\n  lines?: string[]\n  noExpandable: boolean\n  rows: number\n}\n\nconst CodeContent = ({\n  children,\n  prefix,\n  multiline,\n  showMore,\n  hasShowMoreButton,\n  lines,\n  noExpandable,\n  rows,\n}: CodeContentProps) => (\n  <PreText\n    as=\"pre\"\n    hasShowMoreButton={hasShowMoreButton}\n    noExpandable={noExpandable}\n    rows={rows}\n    showMore={showMore}\n    variant=\"code\"\n    whiteSpace={!multiline ? 'nowrap' : undefined}\n  >\n    {multiline ? (\n      Children.map(lines, child => (\n        <StyledSpan key={child} multiline prefix={prefix}>\n          {child}\n        </StyledSpan>\n      ))\n    ) : (\n      <StyledSpan prefix={prefix}>{children}</StyledSpan>\n    )}\n  </PreText>\n)\n\ntype SnippetProps = {\n  className?: string\n  children: string\n  /**\n   * prefix display an element at the beginning of the snippet that is not copiable or selectable.\n   * For `lines` prefix it will display the line number.\n   * For `command` prefix it will display a `$` sign.\n   */\n  prefix?: Prefixes\n  showText?: string\n  hideText?: string\n  'data-testid'?: string\n  initiallyExpanded?: boolean\n  rows?: number\n  noExpandable?: boolean\n  onCopy?: () => void\n} & Pick<ComponentProps<typeof CopyButton>, 'copyText' | 'copiedText'>\n\n/**\n * Snippet component is used to display code snippets with the ability to copy the code.\n * It also has the ability to show/hide the code snippet if it has more than 4 lines.\n */\nexport const Snippet = ({\n  children,\n  copyText,\n  copiedText,\n  showText = 'Show',\n  hideText = 'Hide',\n  prefix,\n  className,\n  'data-testid': dataTestId,\n  initiallyExpanded,\n  rows = 4,\n  noExpandable = false,\n  onCopy,\n}: SnippetProps) => {\n  const theme = useTheme()\n  const [showMore, setShowMore] = useReducer(\n    value => !value,\n    initiallyExpanded ?? false,\n  )\n  const lines = children.split(LINES_BREAK_REGEX)\n\n  const numberOfLines = lines.length\n  const multiline = numberOfLines > 1\n  const hasShowMoreButton = numberOfLines > rows && multiline && !noExpandable\n  // Height of the expandable (when needed) = number of rows * height of a line (from rem to px) + padding (from rem to px)\n  const minHeight =\n    rows * Number.parseFloat(theme.typography.code.lineHeight) * 16 +\n    Number.parseFloat(theme.space[4]) * 16\n\n  return (\n    <Container\n      className={className}\n      data-testid={dataTestId}\n      multiline={multiline}\n    >\n      <StyledStack>\n        {hasShowMoreButton ? (\n          <Expandable minHeight={minHeight} opened={showMore}>\n            <CodeContent\n              lines={lines}\n              multiline={multiline}\n              noExpandable={noExpandable}\n              prefix={prefix}\n              rows={rows}\n            >\n              {children}\n            </CodeContent>\n          </Expandable>\n        ) : (\n          <CodeContent\n            lines={lines}\n            multiline={multiline}\n            noExpandable={noExpandable}\n            prefix={prefix}\n            rows={rows}\n          >\n            {children}\n          </CodeContent>\n        )}\n        <ButtonContainer multiline={multiline && numberOfLines > 1}>\n          <CopyButton\n            copiedText={copiedText}\n            copyText={copyText}\n            onCopy={onCopy}\n            sentiment=\"neutral\"\n            value={children}\n          />\n        </ButtonContainer>\n        {hasShowMoreButton ? (\n          <ShowMoreContainer showMore={showMore}>\n            <StyledButton\n              aria-expanded={showMore}\n              onClick={setShowMore}\n              type=\"button\"\n            >\n              <AlignCenterText\n                as=\"span\"\n                sentiment=\"neutral\"\n                variant=\"bodySmallStrong\"\n              >\n                {showMore ? hideText : showText}\n                &nbsp;\n                <AnimatedArrowIcon showMore={showMore} />\n              </AlignCenterText>\n            </StyledButton>\n          </ShowMoreContainer>\n        ) : null}\n      </StyledStack>\n    </Container>\n  )\n}\n"]} */",
139
+ styles: "display:flex;justify-content:center;align-items:center/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx"],"names":[],"mappings":"AAiIoC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx","sourcesContent":["'use client'\n\nimport { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon } from '@ultraviolet/icons'\nimport type { ComponentProps } from 'react'\nimport { Children, useReducer } from 'react'\nimport { CopyButton } from '../CopyButton'\nimport { Expandable } from '../Expandable'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst LINES_BREAK_REGEX = /\\r\\n|\\r|\\n/\n\ntype Prefixes = 'lines' | 'command'\n\nconst PreText = styled(Text, {\n  shouldForwardProp: prop =>\n    !['hasShowMoreButton', 'showMore', 'rows', 'noExpandable'].includes(prop),\n})<{\n  hasShowMoreButton?: boolean\n  showMore?: boolean\n  rows: number\n  noExpandable: boolean\n}>`\n  margin: 0;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-right: ${({ theme }) => theme.space['9']};\n  overflow-x: ${({ hasShowMoreButton, showMore }) =>\n    hasShowMoreButton && !showMore ? 'hidden' : 'auto'};\n  height: auto;\n  counter-reset: section;\n\n\n  ${({ theme, noExpandable, rows }) =>\n    noExpandable\n      ? `\n    max-height: calc(${theme.typography.code.lineHeight} * ${rows} + ${theme.space['3']});\n    overflow-y: scroll;`\n      : `overflow-y: hidden;\n`}\n`\n\nconst StyledSpan = styled('span', {\n  shouldForwardProp: prop =>\n    !['linePrefix', 'multiline', 'prefix'].includes(prop),\n})<{ linePrefix?: string; multiline?: boolean; prefix?: Prefixes }>`\n  display: block;\n\n\n  &:not([data-multiline]):after {\n    content: \"\";\n    ${({ theme }) => `padding-right: ${theme.space['8']}`};\n  }\n\n  &[data-multiline=\"true\"]:nth-child(-n+2):after {\n    content: \"\";\n    ${({ theme }) => `padding-right: ${theme.space['8']}`};\n  }\n\n  ${({ prefix, theme }) =>\n    prefix\n      ? `\n    &:before {\n      color: ${theme.colors.neutral.textWeak};\n      width: ${prefix === 'lines' ? '35px' : ''};\n      display: inline-flex;\n      justify-content: flex-end;\n      counter-increment: section;\n      content: ${prefix === 'lines' ? 'counter(section)' : \"'$'\"};\n      padding-right: ${theme.space['1']};\n    }\n  `\n      : null}\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: relative;\n  display: flex;\n  justify-content: start;\n  max-width: 100%;\n  ${({ multiline }) => (multiline ? 'width: 100%;' : '')}\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n`\n\nconst StyledStack = styled(Stack)`\n  width: 100%;\n`\n\nconst ButtonContainer = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: absolute;\n  top: 0;\n  right: 0;\n  padding: ${({ theme, multiline }) =>\n    `${theme.space[multiline ? '2' : '1']} ${theme.space['2']} 0 0`};\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n  border: 2px solid transparent;\n  ${({ multiline, theme }) =>\n    !multiline\n      ? `box-shadow: -27px 0 19px -11px ${theme.colors.neutral.backgroundWeak}`\n      : ''};\n`\n\nconst ShowMoreContainer = styled('div', {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  width: 100%;\n  box-shadow: ${({ theme, showMore }) =>\n    !showMore\n      ? `0px -22px 19px -6px\n    ${theme.colors.neutral.backgroundWeak}`\n      : 'none'};\n`\n\nconst StyledButton = styled.button`\n  width: 100%;\n  background: none;\n  border: none;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-top: ${({ theme }) => theme.space['1']};\n  cursor: pointer;\n`\n\nconst AlignCenterText = styled(Text)`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n`\n\nconst AnimatedArrowIcon = styled(ArrowDownIcon, {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  transform: ${({ showMore }) => (showMore ? 'rotate(180deg)' : 'rotate(0deg)')};\n  transform-origin: center;\n  transition: transform 300ms ease-in-out;\n`\n\ntype CodeContentProps = {\n  children: string\n  prefix?: Prefixes\n  multiline?: boolean\n  showMore?: boolean\n  hasShowMoreButton?: boolean\n  lines?: string[]\n  noExpandable: boolean\n  rows: number\n}\n\nconst CodeContent = ({\n  children,\n  prefix,\n  multiline,\n  showMore,\n  hasShowMoreButton,\n  lines,\n  noExpandable,\n  rows,\n}: CodeContentProps) => (\n  <PreText\n    as=\"pre\"\n    hasShowMoreButton={hasShowMoreButton}\n    noExpandable={noExpandable}\n    rows={rows}\n    showMore={showMore}\n    variant=\"code\"\n    whiteSpace={!multiline ? 'nowrap' : undefined}\n  >\n    {multiline ? (\n      Children.map(lines, child => (\n        <StyledSpan data-multiline=\"true\" key={child} prefix={prefix}>\n          {child}\n        </StyledSpan>\n      ))\n    ) : (\n      <StyledSpan prefix={prefix}>{children}</StyledSpan>\n    )}\n  </PreText>\n)\n\ntype SnippetProps = {\n  className?: string\n  children: string\n  /**\n   * prefix display an element at the beginning of the snippet that is not copiable or selectable.\n   * For `lines` prefix it will display the line number.\n   * For `command` prefix it will display a `$` sign.\n   */\n  prefix?: Prefixes\n  showText?: string\n  hideText?: string\n  'data-testid'?: string\n  initiallyExpanded?: boolean\n  rows?: number\n  noExpandable?: boolean\n  onCopy?: () => void\n} & Pick<ComponentProps<typeof CopyButton>, 'copyText' | 'copiedText'>\n\n/**\n * Snippet component is used to display code snippets with the ability to copy the code.\n * It also has the ability to show/hide the code snippet if it has more than 4 lines.\n */\nexport const Snippet = ({\n  children,\n  copyText,\n  copiedText,\n  showText = 'Show',\n  hideText = 'Hide',\n  prefix,\n  className,\n  'data-testid': dataTestId,\n  initiallyExpanded,\n  rows = 4,\n  noExpandable = false,\n  onCopy,\n}: SnippetProps) => {\n  const theme = useTheme()\n  const [showMore, setShowMore] = useReducer(\n    value => !value,\n    initiallyExpanded ?? false,\n  )\n  const lines = children.split(LINES_BREAK_REGEX)\n\n  const numberOfLines = lines.length\n  const multiline = numberOfLines > 1\n  const hasShowMoreButton = numberOfLines > rows && multiline && !noExpandable\n  // Height of the expandable (when needed) = number of rows * height of a line (from rem to px) + padding (from rem to px)\n  const minHeight =\n    rows * Number.parseFloat(theme.typography.code.lineHeight) * 16 +\n    Number.parseFloat(theme.space[4]) * 16\n\n  return (\n    <Container\n      className={className}\n      data-testid={dataTestId}\n      multiline={multiline}\n    >\n      <StyledStack>\n        {hasShowMoreButton ? (\n          <Expandable minHeight={minHeight} opened={showMore}>\n            <CodeContent\n              lines={lines}\n              multiline={multiline}\n              noExpandable={noExpandable}\n              prefix={prefix}\n              rows={rows}\n            >\n              {children}\n            </CodeContent>\n          </Expandable>\n        ) : (\n          <CodeContent\n            lines={lines}\n            multiline={multiline}\n            noExpandable={noExpandable}\n            prefix={prefix}\n            rows={rows}\n          >\n            {children}\n          </CodeContent>\n        )}\n        <ButtonContainer multiline={multiline && numberOfLines > 1}>\n          <CopyButton\n            copiedText={copiedText}\n            copyText={copyText}\n            onCopy={onCopy}\n            sentiment=\"neutral\"\n            value={children}\n          />\n        </ButtonContainer>\n        {hasShowMoreButton ? (\n          <ShowMoreContainer showMore={showMore}>\n            <StyledButton\n              aria-expanded={showMore}\n              onClick={setShowMore}\n              type=\"button\"\n            >\n              <AlignCenterText\n                as=\"span\"\n                sentiment=\"neutral\"\n                variant=\"bodySmallStrong\"\n              >\n                {showMore ? hideText : showText}\n                &nbsp;\n                <AnimatedArrowIcon showMore={showMore} />\n              </AlignCenterText>\n            </StyledButton>\n          </ShowMoreContainer>\n        ) : null}\n      </StyledStack>\n    </Container>\n  )\n}\n"]} */",
139
140
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
140
141
  });
141
142
  const AnimatedArrowIcon = /* @__PURE__ */ _styled(ArrowDownIcon, process.env.NODE_ENV === "production" ? {
@@ -147,7 +148,7 @@ const AnimatedArrowIcon = /* @__PURE__ */ _styled(ArrowDownIcon, process.env.NOD
147
148
  label: "AnimatedArrowIcon"
148
149
  })("transform:", ({
149
150
  showMore
150
- }) => showMore ? "rotate(180deg)" : "rotate(0deg)", ";transform-origin:center;transition:transform 300ms ease-in-out;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx"],"names":[],"mappings":"AAuI0B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx","sourcesContent":["'use client'\n\nimport { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon } from '@ultraviolet/icons'\nimport type { ComponentProps } from 'react'\nimport { Children, useReducer } from 'react'\nimport { CopyButton } from '../CopyButton'\nimport { Expandable } from '../Expandable'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst LINES_BREAK_REGEX = /\\r\\n|\\r|\\n/\n\ntype Prefixes = 'lines' | 'command'\n\nconst PreText = styled(Text, {\n  shouldForwardProp: prop =>\n    !['hasShowMoreButton', 'showMore', 'rows', 'noExpandable'].includes(prop),\n})<{\n  hasShowMoreButton?: boolean\n  showMore?: boolean\n  rows: number\n  noExpandable: boolean\n}>`\n  margin: 0;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-right: ${({ theme }) => theme.space['9']};\n  overflow-x: ${({ hasShowMoreButton, showMore }) =>\n    hasShowMoreButton && !showMore ? 'hidden' : 'auto'};\n  height: auto;\n  counter-reset: section;\n\n\n  ${({ theme, noExpandable, rows }) =>\n    noExpandable\n      ? `\n    max-height: calc(${theme.typography.code.lineHeight} * ${rows} + ${theme.space['3']});\n    overflow-y: scroll;`\n      : `overflow-y: hidden;\n`}\n`\n\nconst StyledSpan = styled('span', {\n  shouldForwardProp: prop =>\n    !['linePrefix', 'multiline', 'prefix'].includes(prop),\n})<{ linePrefix?: string; multiline?: boolean; prefix?: Prefixes }>`\n  display: block;\n\n\n  &:after {\n    content: \"\";\n    ${({ theme, multiline }) =>\n      multiline\n        ? `padding: ${theme.space['4']}`\n        : `padding-right: ${theme.space['8']}`};\n  }\n\n  ${({ prefix, theme }) =>\n    prefix\n      ? `\n    &:before {\n      color: ${theme.colors.neutral.textWeak};\n      width: ${prefix === 'lines' ? '35px' : ''};\n      display: inline-flex;\n      justify-content: flex-end;\n      counter-increment: section;\n      content: ${prefix === 'lines' ? 'counter(section)' : \"'$'\"};\n      padding-right: ${theme.space['1']};\n    }\n  `\n      : null}\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: relative;\n  display: flex;\n  justify-content: start;\n  max-width: 100%;\n  ${({ multiline }) => (multiline ? 'width: 100%;' : '')}\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n`\n\nconst StyledStack = styled(Stack)`\n  width: 100%;\n`\n\nconst ButtonContainer = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: absolute;\n  top: 0;\n  right: 0;\n  padding: ${({ theme, multiline }) =>\n    `${theme.space[multiline ? '2' : '1']} ${theme.space['2']} 0 0`};\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n  border: 2px solid transparent;\n  ${({ multiline, theme }) =>\n    !multiline\n      ? `box-shadow: -27px 0 19px -11px ${theme.colors.neutral.backgroundWeak}`\n      : ''};\n`\n\nconst ShowMoreContainer = styled('div', {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  width: 100%;\n  box-shadow: ${({ theme, showMore }) =>\n    !showMore\n      ? `0px -22px 19px -6px\n    ${theme.colors.neutral.backgroundWeak}`\n      : 'none'};\n`\n\nconst StyledButton = styled.button`\n  width: 100%;\n  background: none;\n  border: none;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-top: ${({ theme }) => theme.space['1']};\n  cursor: pointer;\n`\n\nconst AlignCenterText = styled(Text)`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n`\n\nconst AnimatedArrowIcon = styled(ArrowDownIcon, {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  transform: ${({ showMore }) => (showMore ? 'rotate(180deg)' : 'rotate(0deg)')};\n  transform-origin: center;\n  transition: transform 300ms ease-in-out;\n`\n\ntype CodeContentProps = {\n  children: string\n  prefix?: Prefixes\n  multiline?: boolean\n  showMore?: boolean\n  hasShowMoreButton?: boolean\n  lines?: string[]\n  noExpandable: boolean\n  rows: number\n}\n\nconst CodeContent = ({\n  children,\n  prefix,\n  multiline,\n  showMore,\n  hasShowMoreButton,\n  lines,\n  noExpandable,\n  rows,\n}: CodeContentProps) => (\n  <PreText\n    as=\"pre\"\n    hasShowMoreButton={hasShowMoreButton}\n    noExpandable={noExpandable}\n    rows={rows}\n    showMore={showMore}\n    variant=\"code\"\n    whiteSpace={!multiline ? 'nowrap' : undefined}\n  >\n    {multiline ? (\n      Children.map(lines, child => (\n        <StyledSpan key={child} multiline prefix={prefix}>\n          {child}\n        </StyledSpan>\n      ))\n    ) : (\n      <StyledSpan prefix={prefix}>{children}</StyledSpan>\n    )}\n  </PreText>\n)\n\ntype SnippetProps = {\n  className?: string\n  children: string\n  /**\n   * prefix display an element at the beginning of the snippet that is not copiable or selectable.\n   * For `lines` prefix it will display the line number.\n   * For `command` prefix it will display a `$` sign.\n   */\n  prefix?: Prefixes\n  showText?: string\n  hideText?: string\n  'data-testid'?: string\n  initiallyExpanded?: boolean\n  rows?: number\n  noExpandable?: boolean\n  onCopy?: () => void\n} & Pick<ComponentProps<typeof CopyButton>, 'copyText' | 'copiedText'>\n\n/**\n * Snippet component is used to display code snippets with the ability to copy the code.\n * It also has the ability to show/hide the code snippet if it has more than 4 lines.\n */\nexport const Snippet = ({\n  children,\n  copyText,\n  copiedText,\n  showText = 'Show',\n  hideText = 'Hide',\n  prefix,\n  className,\n  'data-testid': dataTestId,\n  initiallyExpanded,\n  rows = 4,\n  noExpandable = false,\n  onCopy,\n}: SnippetProps) => {\n  const theme = useTheme()\n  const [showMore, setShowMore] = useReducer(\n    value => !value,\n    initiallyExpanded ?? false,\n  )\n  const lines = children.split(LINES_BREAK_REGEX)\n\n  const numberOfLines = lines.length\n  const multiline = numberOfLines > 1\n  const hasShowMoreButton = numberOfLines > rows && multiline && !noExpandable\n  // Height of the expandable (when needed) = number of rows * height of a line (from rem to px) + padding (from rem to px)\n  const minHeight =\n    rows * Number.parseFloat(theme.typography.code.lineHeight) * 16 +\n    Number.parseFloat(theme.space[4]) * 16\n\n  return (\n    <Container\n      className={className}\n      data-testid={dataTestId}\n      multiline={multiline}\n    >\n      <StyledStack>\n        {hasShowMoreButton ? (\n          <Expandable minHeight={minHeight} opened={showMore}>\n            <CodeContent\n              lines={lines}\n              multiline={multiline}\n              noExpandable={noExpandable}\n              prefix={prefix}\n              rows={rows}\n            >\n              {children}\n            </CodeContent>\n          </Expandable>\n        ) : (\n          <CodeContent\n            lines={lines}\n            multiline={multiline}\n            noExpandable={noExpandable}\n            prefix={prefix}\n            rows={rows}\n          >\n            {children}\n          </CodeContent>\n        )}\n        <ButtonContainer multiline={multiline && numberOfLines > 1}>\n          <CopyButton\n            copiedText={copiedText}\n            copyText={copyText}\n            onCopy={onCopy}\n            sentiment=\"neutral\"\n            value={children}\n          />\n        </ButtonContainer>\n        {hasShowMoreButton ? (\n          <ShowMoreContainer showMore={showMore}>\n            <StyledButton\n              aria-expanded={showMore}\n              onClick={setShowMore}\n              type=\"button\"\n            >\n              <AlignCenterText\n                as=\"span\"\n                sentiment=\"neutral\"\n                variant=\"bodySmallStrong\"\n              >\n                {showMore ? hideText : showText}\n                &nbsp;\n                <AnimatedArrowIcon showMore={showMore} />\n              </AlignCenterText>\n            </StyledButton>\n          </ShowMoreContainer>\n        ) : null}\n      </StyledStack>\n    </Container>\n  )\n}\n"]} */"));
151
+ }) => showMore ? "rotate(180deg)" : "rotate(0deg)", ";transform-origin:center;transition:transform 300ms ease-in-out;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx"],"names":[],"mappings":"AAyI0B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Snippet/index.tsx","sourcesContent":["'use client'\n\nimport { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { ArrowDownIcon } from '@ultraviolet/icons'\nimport type { ComponentProps } from 'react'\nimport { Children, useReducer } from 'react'\nimport { CopyButton } from '../CopyButton'\nimport { Expandable } from '../Expandable'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\n\nconst LINES_BREAK_REGEX = /\\r\\n|\\r|\\n/\n\ntype Prefixes = 'lines' | 'command'\n\nconst PreText = styled(Text, {\n  shouldForwardProp: prop =>\n    !['hasShowMoreButton', 'showMore', 'rows', 'noExpandable'].includes(prop),\n})<{\n  hasShowMoreButton?: boolean\n  showMore?: boolean\n  rows: number\n  noExpandable: boolean\n}>`\n  margin: 0;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-right: ${({ theme }) => theme.space['9']};\n  overflow-x: ${({ hasShowMoreButton, showMore }) =>\n    hasShowMoreButton && !showMore ? 'hidden' : 'auto'};\n  height: auto;\n  counter-reset: section;\n\n\n  ${({ theme, noExpandable, rows }) =>\n    noExpandable\n      ? `\n    max-height: calc(${theme.typography.code.lineHeight} * ${rows} + ${theme.space['3']});\n    overflow-y: scroll;`\n      : `overflow-y: hidden;\n`}\n`\n\nconst StyledSpan = styled('span', {\n  shouldForwardProp: prop =>\n    !['linePrefix', 'multiline', 'prefix'].includes(prop),\n})<{ linePrefix?: string; multiline?: boolean; prefix?: Prefixes }>`\n  display: block;\n\n\n  &:not([data-multiline]):after {\n    content: \"\";\n    ${({ theme }) => `padding-right: ${theme.space['8']}`};\n  }\n\n  &[data-multiline=\"true\"]:nth-child(-n+2):after {\n    content: \"\";\n    ${({ theme }) => `padding-right: ${theme.space['8']}`};\n  }\n\n  ${({ prefix, theme }) =>\n    prefix\n      ? `\n    &:before {\n      color: ${theme.colors.neutral.textWeak};\n      width: ${prefix === 'lines' ? '35px' : ''};\n      display: inline-flex;\n      justify-content: flex-end;\n      counter-increment: section;\n      content: ${prefix === 'lines' ? 'counter(section)' : \"'$'\"};\n      padding-right: ${theme.space['1']};\n    }\n  `\n      : null}\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: relative;\n  display: flex;\n  justify-content: start;\n  max-width: 100%;\n  ${({ multiline }) => (multiline ? 'width: 100%;' : '')}\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n`\n\nconst StyledStack = styled(Stack)`\n  width: 100%;\n`\n\nconst ButtonContainer = styled('div', {\n  shouldForwardProp: prop => !['multiline'].includes(prop),\n})<{ multiline?: boolean }>`\n  position: absolute;\n  top: 0;\n  right: 0;\n  padding: ${({ theme, multiline }) =>\n    `${theme.space[multiline ? '2' : '1']} ${theme.space['2']} 0 0`};\n  background: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  border-radius: ${({ theme }) => theme.radii.default};\n  border: 2px solid transparent;\n  ${({ multiline, theme }) =>\n    !multiline\n      ? `box-shadow: -27px 0 19px -11px ${theme.colors.neutral.backgroundWeak}`\n      : ''};\n`\n\nconst ShowMoreContainer = styled('div', {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  width: 100%;\n  box-shadow: ${({ theme, showMore }) =>\n    !showMore\n      ? `0px -22px 19px -6px\n    ${theme.colors.neutral.backgroundWeak}`\n      : 'none'};\n`\n\nconst StyledButton = styled.button`\n  width: 100%;\n  background: none;\n  border: none;\n  padding: ${({ theme }) => theme.space['2']};\n  padding-top: ${({ theme }) => theme.space['1']};\n  cursor: pointer;\n`\n\nconst AlignCenterText = styled(Text)`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n`\n\nconst AnimatedArrowIcon = styled(ArrowDownIcon, {\n  shouldForwardProp: prop => !['showMore'].includes(prop),\n})<{ showMore?: boolean }>`\n  transform: ${({ showMore }) => (showMore ? 'rotate(180deg)' : 'rotate(0deg)')};\n  transform-origin: center;\n  transition: transform 300ms ease-in-out;\n`\n\ntype CodeContentProps = {\n  children: string\n  prefix?: Prefixes\n  multiline?: boolean\n  showMore?: boolean\n  hasShowMoreButton?: boolean\n  lines?: string[]\n  noExpandable: boolean\n  rows: number\n}\n\nconst CodeContent = ({\n  children,\n  prefix,\n  multiline,\n  showMore,\n  hasShowMoreButton,\n  lines,\n  noExpandable,\n  rows,\n}: CodeContentProps) => (\n  <PreText\n    as=\"pre\"\n    hasShowMoreButton={hasShowMoreButton}\n    noExpandable={noExpandable}\n    rows={rows}\n    showMore={showMore}\n    variant=\"code\"\n    whiteSpace={!multiline ? 'nowrap' : undefined}\n  >\n    {multiline ? (\n      Children.map(lines, child => (\n        <StyledSpan data-multiline=\"true\" key={child} prefix={prefix}>\n          {child}\n        </StyledSpan>\n      ))\n    ) : (\n      <StyledSpan prefix={prefix}>{children}</StyledSpan>\n    )}\n  </PreText>\n)\n\ntype SnippetProps = {\n  className?: string\n  children: string\n  /**\n   * prefix display an element at the beginning of the snippet that is not copiable or selectable.\n   * For `lines` prefix it will display the line number.\n   * For `command` prefix it will display a `$` sign.\n   */\n  prefix?: Prefixes\n  showText?: string\n  hideText?: string\n  'data-testid'?: string\n  initiallyExpanded?: boolean\n  rows?: number\n  noExpandable?: boolean\n  onCopy?: () => void\n} & Pick<ComponentProps<typeof CopyButton>, 'copyText' | 'copiedText'>\n\n/**\n * Snippet component is used to display code snippets with the ability to copy the code.\n * It also has the ability to show/hide the code snippet if it has more than 4 lines.\n */\nexport const Snippet = ({\n  children,\n  copyText,\n  copiedText,\n  showText = 'Show',\n  hideText = 'Hide',\n  prefix,\n  className,\n  'data-testid': dataTestId,\n  initiallyExpanded,\n  rows = 4,\n  noExpandable = false,\n  onCopy,\n}: SnippetProps) => {\n  const theme = useTheme()\n  const [showMore, setShowMore] = useReducer(\n    value => !value,\n    initiallyExpanded ?? false,\n  )\n  const lines = children.split(LINES_BREAK_REGEX)\n\n  const numberOfLines = lines.length\n  const multiline = numberOfLines > 1\n  const hasShowMoreButton = numberOfLines > rows && multiline && !noExpandable\n  // Height of the expandable (when needed) = number of rows * height of a line (from rem to px) + padding (from rem to px)\n  const minHeight =\n    rows * Number.parseFloat(theme.typography.code.lineHeight) * 16 +\n    Number.parseFloat(theme.space[4]) * 16\n\n  return (\n    <Container\n      className={className}\n      data-testid={dataTestId}\n      multiline={multiline}\n    >\n      <StyledStack>\n        {hasShowMoreButton ? (\n          <Expandable minHeight={minHeight} opened={showMore}>\n            <CodeContent\n              lines={lines}\n              multiline={multiline}\n              noExpandable={noExpandable}\n              prefix={prefix}\n              rows={rows}\n            >\n              {children}\n            </CodeContent>\n          </Expandable>\n        ) : (\n          <CodeContent\n            lines={lines}\n            multiline={multiline}\n            noExpandable={noExpandable}\n            prefix={prefix}\n            rows={rows}\n          >\n            {children}\n          </CodeContent>\n        )}\n        <ButtonContainer multiline={multiline && numberOfLines > 1}>\n          <CopyButton\n            copiedText={copiedText}\n            copyText={copyText}\n            onCopy={onCopy}\n            sentiment=\"neutral\"\n            value={children}\n          />\n        </ButtonContainer>\n        {hasShowMoreButton ? (\n          <ShowMoreContainer showMore={showMore}>\n            <StyledButton\n              aria-expanded={showMore}\n              onClick={setShowMore}\n              type=\"button\"\n            >\n              <AlignCenterText\n                as=\"span\"\n                sentiment=\"neutral\"\n                variant=\"bodySmallStrong\"\n              >\n                {showMore ? hideText : showText}\n                &nbsp;\n                <AnimatedArrowIcon showMore={showMore} />\n              </AlignCenterText>\n            </StyledButton>\n          </ShowMoreContainer>\n        ) : null}\n      </StyledStack>\n    </Container>\n  )\n}\n"]} */"));
151
152
  const CodeContent = ({
152
153
  children,
153
154
  prefix,
@@ -157,7 +158,7 @@ const CodeContent = ({
157
158
  lines,
158
159
  noExpandable,
159
160
  rows
160
- }) => /* @__PURE__ */ jsx(PreText, { as: "pre", hasShowMoreButton, noExpandable, rows, showMore, variant: "code", whiteSpace: !multiline ? "nowrap" : void 0, children: multiline ? Children.map(lines, (child) => /* @__PURE__ */ jsx(StyledSpan, { multiline: true, prefix, children: child }, child)) : /* @__PURE__ */ jsx(StyledSpan, { prefix, children }) });
161
+ }) => /* @__PURE__ */ jsx(PreText, { as: "pre", hasShowMoreButton, noExpandable, rows, showMore, variant: "code", whiteSpace: !multiline ? "nowrap" : void 0, children: multiline ? Children.map(lines, (child) => /* @__PURE__ */ jsx(StyledSpan, { "data-multiline": "true", prefix, children: child }, child)) : /* @__PURE__ */ jsx(StyledSpan, { prefix, children }) });
161
162
  const Snippet = ({
162
163
  children,
163
164
  copyText,
@@ -23,7 +23,7 @@ export declare const Tabs: {
23
23
  subtitle?: string;
24
24
  tooltip?: string;
25
25
  value?: string | number;
26
- } & Omit<any, "children" | "className" | "value" | "tooltip" | "role" | "as" | "disabled" | "badge" | "counter">, "ref"> & import("react").RefAttributes<HTMLElement>>;
26
+ } & Omit<any, "children" | "className" | "value" | "tooltip" | "role" | "disabled" | "as" | "badge" | "counter">, "ref"> & import("react").RefAttributes<HTMLElement>>;
27
27
  Menu: import("react").ForwardRefExoticComponent<{
28
28
  children: ReactNode;
29
29
  disclosure: ReactNode;