@amboss/design-system 1.15.4 → 1.16.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (29) hide show
  1. package/build/cjs/scss/themes/dark.scss +1 -1
  2. package/build/cjs/scss/themes/light.scss +1 -1
  3. package/build/cjs/src/components/Card/Card.js +5 -35
  4. package/build/cjs/src/components/Container/Container.js +23 -7
  5. package/build/cjs/src/components/SearchResult/SearchResult.js +101 -62
  6. package/build/cjs/src/components/Tag/Tag.js +6 -4
  7. package/build/cjs/src/components/TagGroup/TagGroup.js +118 -0
  8. package/build/cjs/src/index.js +3 -0
  9. package/build/esm/build-tokens/_sizes.json +1 -1
  10. package/build/esm/scss/themes/dark.scss +1 -1
  11. package/build/esm/scss/themes/light.scss +1 -1
  12. package/build/esm/src/components/Card/Card.js +5 -34
  13. package/build/esm/src/components/Card/Card.js.map +1 -1
  14. package/build/esm/src/components/Container/Container.d.ts +4 -1
  15. package/build/esm/src/components/Container/Container.js +23 -7
  16. package/build/esm/src/components/Container/Container.js.map +1 -1
  17. package/build/esm/src/components/SearchResult/SearchResult.d.ts +0 -4
  18. package/build/esm/src/components/SearchResult/SearchResult.js +101 -62
  19. package/build/esm/src/components/SearchResult/SearchResult.js.map +1 -1
  20. package/build/esm/src/components/Tag/Tag.d.ts +1 -0
  21. package/build/esm/src/components/Tag/Tag.js +6 -5
  22. package/build/esm/src/components/Tag/Tag.js.map +1 -1
  23. package/build/esm/src/components/TagGroup/TagGroup.d.ts +17 -0
  24. package/build/esm/src/components/TagGroup/TagGroup.js +112 -0
  25. package/build/esm/src/components/TagGroup/TagGroup.js.map +1 -0
  26. package/build/esm/src/index.d.ts +1 -0
  27. package/build/esm/src/index.js +2 -1
  28. package/build/esm/src/index.js.map +1 -1
  29. package/package.json +1 -1
@@ -7,20 +7,21 @@ import { Stack } from '../Stack/Stack.js';
7
7
  import { StyledText } from '../Typography/StyledText/StyledText.js';
8
8
  import { Badge } from '../Badge/Badge.js';
9
9
  import { TextClamped } from '../Typography/TextClamped/TextClamped.js';
10
+ import { Text } from '../Typography/Text/Text.js';
10
11
 
11
12
  const StyledResultContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
12
- target: "e1y5sw0i2"
13
+ target: "e1y5sw0i5"
13
14
  } : {
14
- target: "e1y5sw0i2",
15
+ target: "e1y5sw0i5",
15
16
  label: "StyledResultContainer"
16
17
  })(() => ({
17
18
  position: "relative",
18
19
  textDecoration: "none"
19
- }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchResult.tsx"],"names":[],"mappings":"AAuB8B","file":"SearchResult.tsx","sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Columns, Column } from \"../Column/Columns\";\nimport { Icon, IconName } from \"../Icon/Icon\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Stack } from \"../Stack/Stack\";\nimport { StyledText } from \"../Typography/StyledText/StyledText\";\nimport { Badge } from \"../Badge/Badge\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\n\nexport type SecondaryTarget = {\n  title: string;\n  body?: string;\n  link: (props: { children: React.ReactNode }) => React.ReactElement;\n  \"data-e2e-test-id\"?: string;\n};\n\nexport type SecondaryTargetsProps = {\n  data: SecondaryTarget[];\n  renderItem: (item: SecondaryTarget) => React.ReactElement;\n  compact?: boolean;\n};\n\nconst StyledResultContainer = styled.div(() => ({\n  position: \"relative\",\n  textDecoration: \"none\",\n}));\n\nconst StyledLinkTitle = styled.div(({ theme }) => ({\n  color: theme.values.color.text.accent.default,\n}));\n\nconst StyledLinkContainerOnHover = styled.div(({ theme }) => ({\n  \"> a\": {\n    textDecoration: \"none\",\n    color: theme.values.color.text.accent.default,\n  },\n  \"&:hover\": {\n    [`${StyledLinkTitle}`]: {\n      textDecoration: \"underline\",\n    },\n  },\n}));\n\nconst SecondaryTargets = ({\n  data,\n  renderItem,\n  compact,\n}: SecondaryTargetsProps) =>\n  compact ? (\n    <Inline space=\"l\" vSpace=\"xs\">\n      {data && data.length && data.map((target) => renderItem(target))}\n    </Inline>\n  ) : (\n    <Columns gap=\"m\">\n      {data.map((target) => (\n        <Column\n          data-e2e-test-id={target[\"data-e2e-test-id\"]}\n          size={[12, 6, 6]}\n          key={target.title}\n        >\n          {renderItem(target)}\n        </Column>\n      ))}\n    </Columns>\n  );\n\nexport type SearchResultProps = {\n  /** The result title. Supports some nested HTML tags like <b> and <i>. Text gets clamped after 3 lines. */\n  title: string;\n  /** The subtitle that accompanies the title. Supports some nested HTML tags like <b> and <i>. Text gets clamped after 3 lines. */\n  subtitle?: string;\n  /** The primary AMBOSS target. */\n  link: (props: { children: React.ReactNode }) => React.ReactElement;\n  /** The left icon */\n  icon?: IconName;\n  /** List of details. Supports some nested HTML tags like <b> and <i>. */\n  details?: string[];\n  /** Usually a text content of the search result. Supports some nested HTML tags like <b> and <i>. Maximum 3 details items allowed where each test gets clamped after 3 lines. */\n  body?: string;\n  /** List of secondary AMBOSS targets with titles. Text gets clamped after 3 lines. */\n  secondaryTargets?: SecondaryTarget[];\n  /** Indicate an external link */\n  isExternal?: boolean;\n  /** List of labels. For example: preclinic, clinic, physician. */\n  labels?: string[];\n  /** The test id for the result's primary target. */\n  \"data-e2e-test-id\"?: string;\n};\n\nconst defaultProps: Partial<SearchResultProps> = {\n  icon: null,\n  details: [],\n  body: null,\n  secondaryTargets: [],\n  isExternal: false,\n  labels: [],\n  \"data-e2e-test-id\": undefined,\n};\n\nexport function SearchResult({\n  title,\n  subtitle,\n  icon,\n  details,\n  body,\n  secondaryTargets,\n  link,\n  labels,\n  \"data-e2e-test-id\": dataE2eTestId,\n}: SearchResultProps): React.ReactElement {\n  const containerRef = useRef(null);\n  const hasShallowSecondaryTargets =\n    secondaryTargets &&\n    secondaryTargets.reduce((prev, curr) => (curr.body ? false : prev), true);\n  const MainLink = link;\n\n  return (\n    <StyledResultContainer ref={containerRef} data-ds-id=\"SearchResult\">\n      <Columns gap=\"m\">\n        {icon && (\n          <Column size=\"narrow\">\n            <Icon name={icon} color=\"tertiary\" />\n          </Column>\n        )}\n        <Column size=\"fill\">\n          <Stack space=\"s\">\n            <StyledLinkContainerOnHover data-e2e-test-id={dataE2eTestId}>\n              <MainLink>\n                <Stack space=\"xxs\">\n                  <Columns gap=\"xxs\">\n                    <Column size={[12, 12, \"fill\"]}>\n                      <StyledLinkTitle>\n                        <Stack space=\"zero\">\n                          <TextClamped\n                            color=\"accent\"\n                            weight=\"bold\"\n                            lines={3}\n                            hyphens=\"auto\"\n                          >\n                            <StyledText>{title}</StyledText>\n                          </TextClamped>\n                          {subtitle && (\n                            <TextClamped color=\"accent\" lines={3} size=\"s\">\n                              <StyledText>{subtitle}</StyledText>\n                            </TextClamped>\n                          )}\n                        </Stack>\n                      </StyledLinkTitle>\n                    </Column>\n                    <Column size=\"narrow\">\n                      {labels && !!labels.length && (\n                        <Inline space=\"xs\">\n                          {labels.map((label, i) => (\n                            // eslint-disable-next-line react/no-array-index-key\n                            <Badge text={label} key={`${i}${label}`} />\n                          ))}\n                        </Inline>\n                      )}\n                    </Column>\n                  </Columns>\n                  {details && !!details.length && (\n                    <Stack space=\"zero\">\n                      {details.slice(0, 3).map((detail) => (\n                        <TextClamped\n                          color=\"primary\"\n                          size=\"s\"\n                          key={detail}\n                          lines={3}\n                        >\n                          <StyledText>{detail}</StyledText>\n                        </TextClamped>\n                      ))}\n                    </Stack>\n                  )}\n                  {body && (\n                    <TextClamped size=\"s\" lines={2}>\n                      <StyledText>{body}</StyledText>\n                    </TextClamped>\n                  )}\n                </Stack>\n              </MainLink>\n            </StyledLinkContainerOnHover>\n            {secondaryTargets && !!secondaryTargets.length && (\n              <SecondaryTargets\n                data={secondaryTargets}\n                compact={hasShallowSecondaryTargets}\n                renderItem={({\n                  title: secTitle,\n                  link: secLink,\n                  body: secBody,\n                  \"data-e2e-test-id\": secDataE2eTestId,\n                }) => {\n                  const SecLink = secLink;\n                  return (\n                    <StyledLinkContainerOnHover\n                      key={title}\n                      data-e2e-test-id={secDataE2eTestId}\n                    >\n                      <SecLink>\n                        <StyledLinkTitle>\n                          <TextClamped\n                            size=\"s\"\n                            color=\"accent\"\n                            weight=\"bold\"\n                            lines={3}\n                          >\n                            <StyledText>{secTitle}</StyledText>\n                          </TextClamped>\n                        </StyledLinkTitle>\n                        {secBody && (\n                          <TextClamped size=\"s\" color=\"primary\" lines={2}>\n                            <StyledText>{secBody}</StyledText>\n                          </TextClamped>\n                        )}\n                      </SecLink>\n                    </StyledLinkContainerOnHover>\n                  );\n                }}\n              />\n            )}\n          </Stack>\n        </Column>\n      </Columns>\n    </StyledResultContainer>\n  );\n}\n\nSearchResult.defaultProps = defaultProps;\n"]} */");
20
+ }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchResult.tsx"],"names":[],"mappings":"AAsB8B","file":"SearchResult.tsx","sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Columns, Column } from \"../Column/Columns\";\nimport { Icon, IconName } from \"../Icon/Icon\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Stack } from \"../Stack/Stack\";\nimport { StyledText } from \"../Typography/StyledText/StyledText\";\nimport { Badge } from \"../Badge/Badge\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport { Text } from \"../Typography/Text/Text\";\n\nexport type SecondaryTarget = {\n  title: string;\n  body?: string;\n  link: (props: { children: React.ReactNode }) => React.ReactElement;\n  \"data-e2e-test-id\"?: string;\n};\n\nexport type SecondaryTargetsProps = {\n  data: SecondaryTarget[];\n};\n\nconst StyledResultContainer = styled.div(() => ({\n  position: \"relative\",\n  textDecoration: \"none\",\n}));\n\nconst StyledLinkTitle = styled.div(({ theme }) => ({\n  color: theme.values.color.text.accent.default,\n}));\n\nconst StyledLinkContainerOnHover = styled.div(({ theme }) => ({\n  \"> a\": {\n    textDecoration: \"none\",\n    color: theme.values.color.text.accent.default,\n  },\n  \"&:hover\": {\n    [`${StyledLinkTitle}`]: {\n      textDecoration: \"underline\",\n    },\n  },\n}));\n\nconst StyledSecLinkTitle = styled.span(({ theme }) => ({\n  display: \"list-item\",\n  marginLeft: theme.variables.size.spacing.m,\n  paddingTop: theme.variables.size.spacing.xxxs,\n  paddingBottom: theme.variables.size.spacing.xxxs,\n}));\n\nconst StyledSecLinkContainerOnHover = styled.div(({ theme }) => ({\n  \"> a\": {\n    textDecoration: \"none\",\n    color: theme.values.color.text.tertiary.default,\n  },\n  \"&:hover\": {\n    [`${StyledSecLinkTitle}`]: {\n      textDecoration: \"underline\",\n    },\n  },\n}));\n\nconst SecondaryTargets = ({ data }: SecondaryTargetsProps) => (\n  <>\n    {data.map(\n      (\n        { title, link: SecLink, body, \"data-e2e-test-id\": dataE2eTestId },\n        i\n      ) => {\n        const key = `${title}-${i}`;\n        return (\n          <StyledSecLinkContainerOnHover\n            key={key}\n            data-e2e-test-id={dataE2eTestId}\n          >\n            <SecLink>\n              <StyledSecLinkTitle>\n                <Text size=\"m\" color=\"primary\" as=\"span\">\n                  <StyledText>{title}</StyledText>\n                </Text>\n              </StyledSecLinkTitle>\n              {body && (\n                <TextClamped size=\"s\" color=\"tertiary\" lines={2}>\n                  <StyledText>{body}</StyledText>\n                </TextClamped>\n              )}\n            </SecLink>\n          </StyledSecLinkContainerOnHover>\n        );\n      }\n    )}\n  </>\n);\n\nexport type SearchResultProps = {\n  /** The result title. Supports some nested HTML tags like <b> and <i>. Text gets clamped after 3 lines. */\n  title: string;\n  /** The subtitle that accompanies the title. Supports some nested HTML tags like <b> and <i>. Text gets clamped after 3 lines. */\n  subtitle?: string;\n  /** The primary AMBOSS target. */\n  link: (props: { children: React.ReactNode }) => React.ReactElement;\n  /** The left icon */\n  icon?: IconName;\n  /** List of details. Supports some nested HTML tags like <b> and <i>. */\n  details?: string[];\n  /** Usually a text content of the search result. Supports some nested HTML tags like <b> and <i>. Maximum 3 details items allowed where each test gets clamped after 3 lines. */\n  body?: string;\n  /** List of secondary AMBOSS targets with titles. Text gets clamped after 3 lines. */\n  secondaryTargets?: SecondaryTarget[];\n  /** List of labels. For example: preclinic, clinic, physician. */\n  labels?: string[];\n  /** The test id for the result's primary target. */\n  \"data-e2e-test-id\"?: string;\n};\n\nconst defaultProps: Partial<SearchResultProps> = {\n  icon: null,\n  details: [],\n  body: null,\n  secondaryTargets: [],\n  labels: [],\n  \"data-e2e-test-id\": undefined,\n};\n// this was a request by the designer to\n// have the backwards compatibility with the old search result\nconst BadgeWithBottomPadding = styled.div(({ theme }) => ({\n  paddingBottom: theme.variables.size.spacing.xxxs,\n}));\n\nexport function SearchResult({\n  title,\n  subtitle,\n  icon,\n  details,\n  body,\n  secondaryTargets,\n  link,\n  labels,\n  \"data-e2e-test-id\": dataE2eTestId,\n}: SearchResultProps): React.ReactElement {\n  const containerRef = useRef(null);\n\n  const MainLink = link;\n\n  const spacing = subtitle || details.length || labels.length ? \"xxs\" : \"zero\";\n\n  return (\n    <StyledResultContainer ref={containerRef} data-ds-id=\"SearchResult\">\n      <Columns gap=\"m\">\n        {icon && (\n          <Column size=\"narrow\">\n            <Icon name={icon} color=\"tertiary\" />\n          </Column>\n        )}\n        <Column size=\"fill\">\n          <Stack space=\"xxs\">\n            <StyledLinkContainerOnHover data-e2e-test-id={dataE2eTestId}>\n              <MainLink>\n                <Stack space={spacing}>\n                  <Columns gap=\"xxs\">\n                    <Column size={[12, 12, \"fill\"]}>\n                      <StyledLinkTitle>\n                        <Stack space=\"zero\">\n                          <TextClamped\n                            color=\"accent\"\n                            weight=\"bold\"\n                            lines={3}\n                            hyphens=\"auto\"\n                          >\n                            <StyledText>{title}</StyledText>\n                          </TextClamped>\n                          {subtitle && (\n                            <TextClamped color=\"accent\" lines={3} size=\"s\">\n                              <StyledText>{subtitle}</StyledText>\n                            </TextClamped>\n                          )}\n                        </Stack>\n                      </StyledLinkTitle>\n                    </Column>\n                    {labels && !!labels.length && (\n                      <Column size=\"narrow\">\n                        <Inline space=\"xs\">\n                          {labels.map((label, i) => {\n                            const key = `${i}${label}`;\n                            return (\n                              <BadgeWithBottomPadding key={key}>\n                                <Badge text={label} />\n                              </BadgeWithBottomPadding>\n                            );\n                          })}\n                        </Inline>\n                      </Column>\n                    )}\n                  </Columns>\n                  {details && !!details.length && (\n                    <Stack space=\"zero\">\n                      {details.slice(0, 3).map((detail) => (\n                        <TextClamped\n                          color=\"primary\"\n                          size=\"s\"\n                          key={detail}\n                          lines={3}\n                        >\n                          <StyledText>{detail}</StyledText>\n                        </TextClamped>\n                      ))}\n                    </Stack>\n                  )}\n                  {body && (\n                    <TextClamped size=\"s\" lines={2}>\n                      <StyledText>{body}</StyledText>\n                    </TextClamped>\n                  )}\n                </Stack>\n              </MainLink>\n            </StyledLinkContainerOnHover>\n            {secondaryTargets && !!secondaryTargets.length && (\n              <SecondaryTargets data={secondaryTargets} />\n            )}\n          </Stack>\n        </Column>\n      </Columns>\n    </StyledResultContainer>\n  );\n}\n\nSearchResult.defaultProps = defaultProps;\n"]} */");
20
21
  const StyledLinkTitle = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
21
- target: "e1y5sw0i1"
22
+ target: "e1y5sw0i4"
22
23
  } : {
23
- target: "e1y5sw0i1",
24
+ target: "e1y5sw0i4",
24
25
  label: "StyledLinkTitle"
25
26
  })(_ref => {
26
27
  let {
@@ -29,11 +30,11 @@ const StyledLinkTitle = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "pr
29
30
  return {
30
31
  color: theme.values.color.text.accent.default
31
32
  };
32
- }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchResult.tsx"],"names":[],"mappings":"AA4BwB","file":"SearchResult.tsx","sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Columns, Column } from \"../Column/Columns\";\nimport { Icon, IconName } from \"../Icon/Icon\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Stack } from \"../Stack/Stack\";\nimport { StyledText } from \"../Typography/StyledText/StyledText\";\nimport { Badge } from \"../Badge/Badge\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\n\nexport type SecondaryTarget = {\n  title: string;\n  body?: string;\n  link: (props: { children: React.ReactNode }) => React.ReactElement;\n  \"data-e2e-test-id\"?: string;\n};\n\nexport type SecondaryTargetsProps = {\n  data: SecondaryTarget[];\n  renderItem: (item: SecondaryTarget) => React.ReactElement;\n  compact?: boolean;\n};\n\nconst StyledResultContainer = styled.div(() => ({\n  position: \"relative\",\n  textDecoration: \"none\",\n}));\n\nconst StyledLinkTitle = styled.div(({ theme }) => ({\n  color: theme.values.color.text.accent.default,\n}));\n\nconst StyledLinkContainerOnHover = styled.div(({ theme }) => ({\n  \"> a\": {\n    textDecoration: \"none\",\n    color: theme.values.color.text.accent.default,\n  },\n  \"&:hover\": {\n    [`${StyledLinkTitle}`]: {\n      textDecoration: \"underline\",\n    },\n  },\n}));\n\nconst SecondaryTargets = ({\n  data,\n  renderItem,\n  compact,\n}: SecondaryTargetsProps) =>\n  compact ? (\n    <Inline space=\"l\" vSpace=\"xs\">\n      {data && data.length && data.map((target) => renderItem(target))}\n    </Inline>\n  ) : (\n    <Columns gap=\"m\">\n      {data.map((target) => (\n        <Column\n          data-e2e-test-id={target[\"data-e2e-test-id\"]}\n          size={[12, 6, 6]}\n          key={target.title}\n        >\n          {renderItem(target)}\n        </Column>\n      ))}\n    </Columns>\n  );\n\nexport type SearchResultProps = {\n  /** The result title. Supports some nested HTML tags like <b> and <i>. Text gets clamped after 3 lines. */\n  title: string;\n  /** The subtitle that accompanies the title. Supports some nested HTML tags like <b> and <i>. Text gets clamped after 3 lines. */\n  subtitle?: string;\n  /** The primary AMBOSS target. */\n  link: (props: { children: React.ReactNode }) => React.ReactElement;\n  /** The left icon */\n  icon?: IconName;\n  /** List of details. Supports some nested HTML tags like <b> and <i>. */\n  details?: string[];\n  /** Usually a text content of the search result. Supports some nested HTML tags like <b> and <i>. Maximum 3 details items allowed where each test gets clamped after 3 lines. */\n  body?: string;\n  /** List of secondary AMBOSS targets with titles. Text gets clamped after 3 lines. */\n  secondaryTargets?: SecondaryTarget[];\n  /** Indicate an external link */\n  isExternal?: boolean;\n  /** List of labels. For example: preclinic, clinic, physician. */\n  labels?: string[];\n  /** The test id for the result's primary target. */\n  \"data-e2e-test-id\"?: string;\n};\n\nconst defaultProps: Partial<SearchResultProps> = {\n  icon: null,\n  details: [],\n  body: null,\n  secondaryTargets: [],\n  isExternal: false,\n  labels: [],\n  \"data-e2e-test-id\": undefined,\n};\n\nexport function SearchResult({\n  title,\n  subtitle,\n  icon,\n  details,\n  body,\n  secondaryTargets,\n  link,\n  labels,\n  \"data-e2e-test-id\": dataE2eTestId,\n}: SearchResultProps): React.ReactElement {\n  const containerRef = useRef(null);\n  const hasShallowSecondaryTargets =\n    secondaryTargets &&\n    secondaryTargets.reduce((prev, curr) => (curr.body ? false : prev), true);\n  const MainLink = link;\n\n  return (\n    <StyledResultContainer ref={containerRef} data-ds-id=\"SearchResult\">\n      <Columns gap=\"m\">\n        {icon && (\n          <Column size=\"narrow\">\n            <Icon name={icon} color=\"tertiary\" />\n          </Column>\n        )}\n        <Column size=\"fill\">\n          <Stack space=\"s\">\n            <StyledLinkContainerOnHover data-e2e-test-id={dataE2eTestId}>\n              <MainLink>\n                <Stack space=\"xxs\">\n                  <Columns gap=\"xxs\">\n                    <Column size={[12, 12, \"fill\"]}>\n                      <StyledLinkTitle>\n                        <Stack space=\"zero\">\n                          <TextClamped\n                            color=\"accent\"\n                            weight=\"bold\"\n                            lines={3}\n                            hyphens=\"auto\"\n                          >\n                            <StyledText>{title}</StyledText>\n                          </TextClamped>\n                          {subtitle && (\n                            <TextClamped color=\"accent\" lines={3} size=\"s\">\n                              <StyledText>{subtitle}</StyledText>\n                            </TextClamped>\n                          )}\n                        </Stack>\n                      </StyledLinkTitle>\n                    </Column>\n                    <Column size=\"narrow\">\n                      {labels && !!labels.length && (\n                        <Inline space=\"xs\">\n                          {labels.map((label, i) => (\n                            // eslint-disable-next-line react/no-array-index-key\n                            <Badge text={label} key={`${i}${label}`} />\n                          ))}\n                        </Inline>\n                      )}\n                    </Column>\n                  </Columns>\n                  {details && !!details.length && (\n                    <Stack space=\"zero\">\n                      {details.slice(0, 3).map((detail) => (\n                        <TextClamped\n                          color=\"primary\"\n                          size=\"s\"\n                          key={detail}\n                          lines={3}\n                        >\n                          <StyledText>{detail}</StyledText>\n                        </TextClamped>\n                      ))}\n                    </Stack>\n                  )}\n                  {body && (\n                    <TextClamped size=\"s\" lines={2}>\n                      <StyledText>{body}</StyledText>\n                    </TextClamped>\n                  )}\n                </Stack>\n              </MainLink>\n            </StyledLinkContainerOnHover>\n            {secondaryTargets && !!secondaryTargets.length && (\n              <SecondaryTargets\n                data={secondaryTargets}\n                compact={hasShallowSecondaryTargets}\n                renderItem={({\n                  title: secTitle,\n                  link: secLink,\n                  body: secBody,\n                  \"data-e2e-test-id\": secDataE2eTestId,\n                }) => {\n                  const SecLink = secLink;\n                  return (\n                    <StyledLinkContainerOnHover\n                      key={title}\n                      data-e2e-test-id={secDataE2eTestId}\n                    >\n                      <SecLink>\n                        <StyledLinkTitle>\n                          <TextClamped\n                            size=\"s\"\n                            color=\"accent\"\n                            weight=\"bold\"\n                            lines={3}\n                          >\n                            <StyledText>{secTitle}</StyledText>\n                          </TextClamped>\n                        </StyledLinkTitle>\n                        {secBody && (\n                          <TextClamped size=\"s\" color=\"primary\" lines={2}>\n                            <StyledText>{secBody}</StyledText>\n                          </TextClamped>\n                        )}\n                      </SecLink>\n                    </StyledLinkContainerOnHover>\n                  );\n                }}\n              />\n            )}\n          </Stack>\n        </Column>\n      </Columns>\n    </StyledResultContainer>\n  );\n}\n\nSearchResult.defaultProps = defaultProps;\n"]} */");
33
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchResult.tsx"],"names":[],"mappings":"AA2BwB","file":"SearchResult.tsx","sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Columns, Column } from \"../Column/Columns\";\nimport { Icon, IconName } from \"../Icon/Icon\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Stack } from \"../Stack/Stack\";\nimport { StyledText } from \"../Typography/StyledText/StyledText\";\nimport { Badge } from \"../Badge/Badge\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport { Text } from \"../Typography/Text/Text\";\n\nexport type SecondaryTarget = {\n  title: string;\n  body?: string;\n  link: (props: { children: React.ReactNode }) => React.ReactElement;\n  \"data-e2e-test-id\"?: string;\n};\n\nexport type SecondaryTargetsProps = {\n  data: SecondaryTarget[];\n};\n\nconst StyledResultContainer = styled.div(() => ({\n  position: \"relative\",\n  textDecoration: \"none\",\n}));\n\nconst StyledLinkTitle = styled.div(({ theme }) => ({\n  color: theme.values.color.text.accent.default,\n}));\n\nconst StyledLinkContainerOnHover = styled.div(({ theme }) => ({\n  \"> a\": {\n    textDecoration: \"none\",\n    color: theme.values.color.text.accent.default,\n  },\n  \"&:hover\": {\n    [`${StyledLinkTitle}`]: {\n      textDecoration: \"underline\",\n    },\n  },\n}));\n\nconst StyledSecLinkTitle = styled.span(({ theme }) => ({\n  display: \"list-item\",\n  marginLeft: theme.variables.size.spacing.m,\n  paddingTop: theme.variables.size.spacing.xxxs,\n  paddingBottom: theme.variables.size.spacing.xxxs,\n}));\n\nconst StyledSecLinkContainerOnHover = styled.div(({ theme }) => ({\n  \"> a\": {\n    textDecoration: \"none\",\n    color: theme.values.color.text.tertiary.default,\n  },\n  \"&:hover\": {\n    [`${StyledSecLinkTitle}`]: {\n      textDecoration: \"underline\",\n    },\n  },\n}));\n\nconst SecondaryTargets = ({ data }: SecondaryTargetsProps) => (\n  <>\n    {data.map(\n      (\n        { title, link: SecLink, body, \"data-e2e-test-id\": dataE2eTestId },\n        i\n      ) => {\n        const key = `${title}-${i}`;\n        return (\n          <StyledSecLinkContainerOnHover\n            key={key}\n            data-e2e-test-id={dataE2eTestId}\n          >\n            <SecLink>\n              <StyledSecLinkTitle>\n                <Text size=\"m\" color=\"primary\" as=\"span\">\n                  <StyledText>{title}</StyledText>\n                </Text>\n              </StyledSecLinkTitle>\n              {body && (\n                <TextClamped size=\"s\" color=\"tertiary\" lines={2}>\n                  <StyledText>{body}</StyledText>\n                </TextClamped>\n              )}\n            </SecLink>\n          </StyledSecLinkContainerOnHover>\n        );\n      }\n    )}\n  </>\n);\n\nexport type SearchResultProps = {\n  /** The result title. Supports some nested HTML tags like <b> and <i>. Text gets clamped after 3 lines. */\n  title: string;\n  /** The subtitle that accompanies the title. Supports some nested HTML tags like <b> and <i>. Text gets clamped after 3 lines. */\n  subtitle?: string;\n  /** The primary AMBOSS target. */\n  link: (props: { children: React.ReactNode }) => React.ReactElement;\n  /** The left icon */\n  icon?: IconName;\n  /** List of details. Supports some nested HTML tags like <b> and <i>. */\n  details?: string[];\n  /** Usually a text content of the search result. Supports some nested HTML tags like <b> and <i>. Maximum 3 details items allowed where each test gets clamped after 3 lines. */\n  body?: string;\n  /** List of secondary AMBOSS targets with titles. Text gets clamped after 3 lines. */\n  secondaryTargets?: SecondaryTarget[];\n  /** List of labels. For example: preclinic, clinic, physician. */\n  labels?: string[];\n  /** The test id for the result's primary target. */\n  \"data-e2e-test-id\"?: string;\n};\n\nconst defaultProps: Partial<SearchResultProps> = {\n  icon: null,\n  details: [],\n  body: null,\n  secondaryTargets: [],\n  labels: [],\n  \"data-e2e-test-id\": undefined,\n};\n// this was a request by the designer to\n// have the backwards compatibility with the old search result\nconst BadgeWithBottomPadding = styled.div(({ theme }) => ({\n  paddingBottom: theme.variables.size.spacing.xxxs,\n}));\n\nexport function SearchResult({\n  title,\n  subtitle,\n  icon,\n  details,\n  body,\n  secondaryTargets,\n  link,\n  labels,\n  \"data-e2e-test-id\": dataE2eTestId,\n}: SearchResultProps): React.ReactElement {\n  const containerRef = useRef(null);\n\n  const MainLink = link;\n\n  const spacing = subtitle || details.length || labels.length ? \"xxs\" : \"zero\";\n\n  return (\n    <StyledResultContainer ref={containerRef} data-ds-id=\"SearchResult\">\n      <Columns gap=\"m\">\n        {icon && (\n          <Column size=\"narrow\">\n            <Icon name={icon} color=\"tertiary\" />\n          </Column>\n        )}\n        <Column size=\"fill\">\n          <Stack space=\"xxs\">\n            <StyledLinkContainerOnHover data-e2e-test-id={dataE2eTestId}>\n              <MainLink>\n                <Stack space={spacing}>\n                  <Columns gap=\"xxs\">\n                    <Column size={[12, 12, \"fill\"]}>\n                      <StyledLinkTitle>\n                        <Stack space=\"zero\">\n                          <TextClamped\n                            color=\"accent\"\n                            weight=\"bold\"\n                            lines={3}\n                            hyphens=\"auto\"\n                          >\n                            <StyledText>{title}</StyledText>\n                          </TextClamped>\n                          {subtitle && (\n                            <TextClamped color=\"accent\" lines={3} size=\"s\">\n                              <StyledText>{subtitle}</StyledText>\n                            </TextClamped>\n                          )}\n                        </Stack>\n                      </StyledLinkTitle>\n                    </Column>\n                    {labels && !!labels.length && (\n                      <Column size=\"narrow\">\n                        <Inline space=\"xs\">\n                          {labels.map((label, i) => {\n                            const key = `${i}${label}`;\n                            return (\n                              <BadgeWithBottomPadding key={key}>\n                                <Badge text={label} />\n                              </BadgeWithBottomPadding>\n                            );\n                          })}\n                        </Inline>\n                      </Column>\n                    )}\n                  </Columns>\n                  {details && !!details.length && (\n                    <Stack space=\"zero\">\n                      {details.slice(0, 3).map((detail) => (\n                        <TextClamped\n                          color=\"primary\"\n                          size=\"s\"\n                          key={detail}\n                          lines={3}\n                        >\n                          <StyledText>{detail}</StyledText>\n                        </TextClamped>\n                      ))}\n                    </Stack>\n                  )}\n                  {body && (\n                    <TextClamped size=\"s\" lines={2}>\n                      <StyledText>{body}</StyledText>\n                    </TextClamped>\n                  )}\n                </Stack>\n              </MainLink>\n            </StyledLinkContainerOnHover>\n            {secondaryTargets && !!secondaryTargets.length && (\n              <SecondaryTargets data={secondaryTargets} />\n            )}\n          </Stack>\n        </Column>\n      </Columns>\n    </StyledResultContainer>\n  );\n}\n\nSearchResult.defaultProps = defaultProps;\n"]} */");
33
34
  const StyledLinkContainerOnHover = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
34
- target: "e1y5sw0i0"
35
+ target: "e1y5sw0i3"
35
36
  } : {
36
- target: "e1y5sw0i0",
37
+ target: "e1y5sw0i3",
37
38
  label: "StyledLinkContainerOnHover"
38
39
  })(_ref2 => {
39
40
  let {
@@ -50,34 +51,94 @@ const StyledLinkContainerOnHover = /*#__PURE__*/_styled("div", process.env.NODE_
50
51
  }
51
52
  }
52
53
  };
53
- }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchResult.tsx"],"names":[],"mappings":"AAgCmC","file":"SearchResult.tsx","sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Columns, Column } from \"../Column/Columns\";\nimport { Icon, IconName } from \"../Icon/Icon\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Stack } from \"../Stack/Stack\";\nimport { StyledText } from \"../Typography/StyledText/StyledText\";\nimport { Badge } from \"../Badge/Badge\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\n\nexport type SecondaryTarget = {\n  title: string;\n  body?: string;\n  link: (props: { children: React.ReactNode }) => React.ReactElement;\n  \"data-e2e-test-id\"?: string;\n};\n\nexport type SecondaryTargetsProps = {\n  data: SecondaryTarget[];\n  renderItem: (item: SecondaryTarget) => React.ReactElement;\n  compact?: boolean;\n};\n\nconst StyledResultContainer = styled.div(() => ({\n  position: \"relative\",\n  textDecoration: \"none\",\n}));\n\nconst StyledLinkTitle = styled.div(({ theme }) => ({\n  color: theme.values.color.text.accent.default,\n}));\n\nconst StyledLinkContainerOnHover = styled.div(({ theme }) => ({\n  \"> a\": {\n    textDecoration: \"none\",\n    color: theme.values.color.text.accent.default,\n  },\n  \"&:hover\": {\n    [`${StyledLinkTitle}`]: {\n      textDecoration: \"underline\",\n    },\n  },\n}));\n\nconst SecondaryTargets = ({\n  data,\n  renderItem,\n  compact,\n}: SecondaryTargetsProps) =>\n  compact ? (\n    <Inline space=\"l\" vSpace=\"xs\">\n      {data && data.length && data.map((target) => renderItem(target))}\n    </Inline>\n  ) : (\n    <Columns gap=\"m\">\n      {data.map((target) => (\n        <Column\n          data-e2e-test-id={target[\"data-e2e-test-id\"]}\n          size={[12, 6, 6]}\n          key={target.title}\n        >\n          {renderItem(target)}\n        </Column>\n      ))}\n    </Columns>\n  );\n\nexport type SearchResultProps = {\n  /** The result title. Supports some nested HTML tags like <b> and <i>. Text gets clamped after 3 lines. */\n  title: string;\n  /** The subtitle that accompanies the title. Supports some nested HTML tags like <b> and <i>. Text gets clamped after 3 lines. */\n  subtitle?: string;\n  /** The primary AMBOSS target. */\n  link: (props: { children: React.ReactNode }) => React.ReactElement;\n  /** The left icon */\n  icon?: IconName;\n  /** List of details. Supports some nested HTML tags like <b> and <i>. */\n  details?: string[];\n  /** Usually a text content of the search result. Supports some nested HTML tags like <b> and <i>. Maximum 3 details items allowed where each test gets clamped after 3 lines. */\n  body?: string;\n  /** List of secondary AMBOSS targets with titles. Text gets clamped after 3 lines. */\n  secondaryTargets?: SecondaryTarget[];\n  /** Indicate an external link */\n  isExternal?: boolean;\n  /** List of labels. For example: preclinic, clinic, physician. */\n  labels?: string[];\n  /** The test id for the result's primary target. */\n  \"data-e2e-test-id\"?: string;\n};\n\nconst defaultProps: Partial<SearchResultProps> = {\n  icon: null,\n  details: [],\n  body: null,\n  secondaryTargets: [],\n  isExternal: false,\n  labels: [],\n  \"data-e2e-test-id\": undefined,\n};\n\nexport function SearchResult({\n  title,\n  subtitle,\n  icon,\n  details,\n  body,\n  secondaryTargets,\n  link,\n  labels,\n  \"data-e2e-test-id\": dataE2eTestId,\n}: SearchResultProps): React.ReactElement {\n  const containerRef = useRef(null);\n  const hasShallowSecondaryTargets =\n    secondaryTargets &&\n    secondaryTargets.reduce((prev, curr) => (curr.body ? false : prev), true);\n  const MainLink = link;\n\n  return (\n    <StyledResultContainer ref={containerRef} data-ds-id=\"SearchResult\">\n      <Columns gap=\"m\">\n        {icon && (\n          <Column size=\"narrow\">\n            <Icon name={icon} color=\"tertiary\" />\n          </Column>\n        )}\n        <Column size=\"fill\">\n          <Stack space=\"s\">\n            <StyledLinkContainerOnHover data-e2e-test-id={dataE2eTestId}>\n              <MainLink>\n                <Stack space=\"xxs\">\n                  <Columns gap=\"xxs\">\n                    <Column size={[12, 12, \"fill\"]}>\n                      <StyledLinkTitle>\n                        <Stack space=\"zero\">\n                          <TextClamped\n                            color=\"accent\"\n                            weight=\"bold\"\n                            lines={3}\n                            hyphens=\"auto\"\n                          >\n                            <StyledText>{title}</StyledText>\n                          </TextClamped>\n                          {subtitle && (\n                            <TextClamped color=\"accent\" lines={3} size=\"s\">\n                              <StyledText>{subtitle}</StyledText>\n                            </TextClamped>\n                          )}\n                        </Stack>\n                      </StyledLinkTitle>\n                    </Column>\n                    <Column size=\"narrow\">\n                      {labels && !!labels.length && (\n                        <Inline space=\"xs\">\n                          {labels.map((label, i) => (\n                            // eslint-disable-next-line react/no-array-index-key\n                            <Badge text={label} key={`${i}${label}`} />\n                          ))}\n                        </Inline>\n                      )}\n                    </Column>\n                  </Columns>\n                  {details && !!details.length && (\n                    <Stack space=\"zero\">\n                      {details.slice(0, 3).map((detail) => (\n                        <TextClamped\n                          color=\"primary\"\n                          size=\"s\"\n                          key={detail}\n                          lines={3}\n                        >\n                          <StyledText>{detail}</StyledText>\n                        </TextClamped>\n                      ))}\n                    </Stack>\n                  )}\n                  {body && (\n                    <TextClamped size=\"s\" lines={2}>\n                      <StyledText>{body}</StyledText>\n                    </TextClamped>\n                  )}\n                </Stack>\n              </MainLink>\n            </StyledLinkContainerOnHover>\n            {secondaryTargets && !!secondaryTargets.length && (\n              <SecondaryTargets\n                data={secondaryTargets}\n                compact={hasShallowSecondaryTargets}\n                renderItem={({\n                  title: secTitle,\n                  link: secLink,\n                  body: secBody,\n                  \"data-e2e-test-id\": secDataE2eTestId,\n                }) => {\n                  const SecLink = secLink;\n                  return (\n                    <StyledLinkContainerOnHover\n                      key={title}\n                      data-e2e-test-id={secDataE2eTestId}\n                    >\n                      <SecLink>\n                        <StyledLinkTitle>\n                          <TextClamped\n                            size=\"s\"\n                            color=\"accent\"\n                            weight=\"bold\"\n                            lines={3}\n                          >\n                            <StyledText>{secTitle}</StyledText>\n                          </TextClamped>\n                        </StyledLinkTitle>\n                        {secBody && (\n                          <TextClamped size=\"s\" color=\"primary\" lines={2}>\n                            <StyledText>{secBody}</StyledText>\n                          </TextClamped>\n                        )}\n                      </SecLink>\n                    </StyledLinkContainerOnHover>\n                  );\n                }}\n              />\n            )}\n          </Stack>\n        </Column>\n      </Columns>\n    </StyledResultContainer>\n  );\n}\n\nSearchResult.defaultProps = defaultProps;\n"]} */");
54
- const SecondaryTargets = _ref3 => {
54
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchResult.tsx"],"names":[],"mappings":"AA+BmC","file":"SearchResult.tsx","sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Columns, Column } from \"../Column/Columns\";\nimport { Icon, IconName } from \"../Icon/Icon\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Stack } from \"../Stack/Stack\";\nimport { StyledText } from \"../Typography/StyledText/StyledText\";\nimport { Badge } from \"../Badge/Badge\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport { Text } from \"../Typography/Text/Text\";\n\nexport type SecondaryTarget = {\n  title: string;\n  body?: string;\n  link: (props: { children: React.ReactNode }) => React.ReactElement;\n  \"data-e2e-test-id\"?: string;\n};\n\nexport type SecondaryTargetsProps = {\n  data: SecondaryTarget[];\n};\n\nconst StyledResultContainer = styled.div(() => ({\n  position: \"relative\",\n  textDecoration: \"none\",\n}));\n\nconst StyledLinkTitle = styled.div(({ theme }) => ({\n  color: theme.values.color.text.accent.default,\n}));\n\nconst StyledLinkContainerOnHover = styled.div(({ theme }) => ({\n  \"> a\": {\n    textDecoration: \"none\",\n    color: theme.values.color.text.accent.default,\n  },\n  \"&:hover\": {\n    [`${StyledLinkTitle}`]: {\n      textDecoration: \"underline\",\n    },\n  },\n}));\n\nconst StyledSecLinkTitle = styled.span(({ theme }) => ({\n  display: \"list-item\",\n  marginLeft: theme.variables.size.spacing.m,\n  paddingTop: theme.variables.size.spacing.xxxs,\n  paddingBottom: theme.variables.size.spacing.xxxs,\n}));\n\nconst StyledSecLinkContainerOnHover = styled.div(({ theme }) => ({\n  \"> a\": {\n    textDecoration: \"none\",\n    color: theme.values.color.text.tertiary.default,\n  },\n  \"&:hover\": {\n    [`${StyledSecLinkTitle}`]: {\n      textDecoration: \"underline\",\n    },\n  },\n}));\n\nconst SecondaryTargets = ({ data }: SecondaryTargetsProps) => (\n  <>\n    {data.map(\n      (\n        { title, link: SecLink, body, \"data-e2e-test-id\": dataE2eTestId },\n        i\n      ) => {\n        const key = `${title}-${i}`;\n        return (\n          <StyledSecLinkContainerOnHover\n            key={key}\n            data-e2e-test-id={dataE2eTestId}\n          >\n            <SecLink>\n              <StyledSecLinkTitle>\n                <Text size=\"m\" color=\"primary\" as=\"span\">\n                  <StyledText>{title}</StyledText>\n                </Text>\n              </StyledSecLinkTitle>\n              {body && (\n                <TextClamped size=\"s\" color=\"tertiary\" lines={2}>\n                  <StyledText>{body}</StyledText>\n                </TextClamped>\n              )}\n            </SecLink>\n          </StyledSecLinkContainerOnHover>\n        );\n      }\n    )}\n  </>\n);\n\nexport type SearchResultProps = {\n  /** The result title. Supports some nested HTML tags like <b> and <i>. Text gets clamped after 3 lines. */\n  title: string;\n  /** The subtitle that accompanies the title. Supports some nested HTML tags like <b> and <i>. Text gets clamped after 3 lines. */\n  subtitle?: string;\n  /** The primary AMBOSS target. */\n  link: (props: { children: React.ReactNode }) => React.ReactElement;\n  /** The left icon */\n  icon?: IconName;\n  /** List of details. Supports some nested HTML tags like <b> and <i>. */\n  details?: string[];\n  /** Usually a text content of the search result. Supports some nested HTML tags like <b> and <i>. Maximum 3 details items allowed where each test gets clamped after 3 lines. */\n  body?: string;\n  /** List of secondary AMBOSS targets with titles. Text gets clamped after 3 lines. */\n  secondaryTargets?: SecondaryTarget[];\n  /** List of labels. For example: preclinic, clinic, physician. */\n  labels?: string[];\n  /** The test id for the result's primary target. */\n  \"data-e2e-test-id\"?: string;\n};\n\nconst defaultProps: Partial<SearchResultProps> = {\n  icon: null,\n  details: [],\n  body: null,\n  secondaryTargets: [],\n  labels: [],\n  \"data-e2e-test-id\": undefined,\n};\n// this was a request by the designer to\n// have the backwards compatibility with the old search result\nconst BadgeWithBottomPadding = styled.div(({ theme }) => ({\n  paddingBottom: theme.variables.size.spacing.xxxs,\n}));\n\nexport function SearchResult({\n  title,\n  subtitle,\n  icon,\n  details,\n  body,\n  secondaryTargets,\n  link,\n  labels,\n  \"data-e2e-test-id\": dataE2eTestId,\n}: SearchResultProps): React.ReactElement {\n  const containerRef = useRef(null);\n\n  const MainLink = link;\n\n  const spacing = subtitle || details.length || labels.length ? \"xxs\" : \"zero\";\n\n  return (\n    <StyledResultContainer ref={containerRef} data-ds-id=\"SearchResult\">\n      <Columns gap=\"m\">\n        {icon && (\n          <Column size=\"narrow\">\n            <Icon name={icon} color=\"tertiary\" />\n          </Column>\n        )}\n        <Column size=\"fill\">\n          <Stack space=\"xxs\">\n            <StyledLinkContainerOnHover data-e2e-test-id={dataE2eTestId}>\n              <MainLink>\n                <Stack space={spacing}>\n                  <Columns gap=\"xxs\">\n                    <Column size={[12, 12, \"fill\"]}>\n                      <StyledLinkTitle>\n                        <Stack space=\"zero\">\n                          <TextClamped\n                            color=\"accent\"\n                            weight=\"bold\"\n                            lines={3}\n                            hyphens=\"auto\"\n                          >\n                            <StyledText>{title}</StyledText>\n                          </TextClamped>\n                          {subtitle && (\n                            <TextClamped color=\"accent\" lines={3} size=\"s\">\n                              <StyledText>{subtitle}</StyledText>\n                            </TextClamped>\n                          )}\n                        </Stack>\n                      </StyledLinkTitle>\n                    </Column>\n                    {labels && !!labels.length && (\n                      <Column size=\"narrow\">\n                        <Inline space=\"xs\">\n                          {labels.map((label, i) => {\n                            const key = `${i}${label}`;\n                            return (\n                              <BadgeWithBottomPadding key={key}>\n                                <Badge text={label} />\n                              </BadgeWithBottomPadding>\n                            );\n                          })}\n                        </Inline>\n                      </Column>\n                    )}\n                  </Columns>\n                  {details && !!details.length && (\n                    <Stack space=\"zero\">\n                      {details.slice(0, 3).map((detail) => (\n                        <TextClamped\n                          color=\"primary\"\n                          size=\"s\"\n                          key={detail}\n                          lines={3}\n                        >\n                          <StyledText>{detail}</StyledText>\n                        </TextClamped>\n                      ))}\n                    </Stack>\n                  )}\n                  {body && (\n                    <TextClamped size=\"s\" lines={2}>\n                      <StyledText>{body}</StyledText>\n                    </TextClamped>\n                  )}\n                </Stack>\n              </MainLink>\n            </StyledLinkContainerOnHover>\n            {secondaryTargets && !!secondaryTargets.length && (\n              <SecondaryTargets data={secondaryTargets} />\n            )}\n          </Stack>\n        </Column>\n      </Columns>\n    </StyledResultContainer>\n  );\n}\n\nSearchResult.defaultProps = defaultProps;\n"]} */");
55
+ const StyledSecLinkTitle = /*#__PURE__*/_styled("span", process.env.NODE_ENV === "production" ? {
56
+ target: "e1y5sw0i2"
57
+ } : {
58
+ target: "e1y5sw0i2",
59
+ label: "StyledSecLinkTitle"
60
+ })(_ref3 => {
55
61
  let {
56
- data,
57
- renderItem,
58
- compact
62
+ theme
59
63
  } = _ref3;
60
- return compact ? /*#__PURE__*/React.createElement(Inline, {
61
- space: "l",
62
- vSpace: "xs"
63
- }, data && data.length && data.map(target => renderItem(target))) : /*#__PURE__*/React.createElement(Columns, {
64
- gap: "m"
65
- }, data.map(target => /*#__PURE__*/React.createElement(Column, {
66
- "data-e2e-test-id": target["data-e2e-test-id"],
67
- size: [12, 6, 6],
68
- key: target.title
69
- }, renderItem(target))));
64
+ return {
65
+ display: "list-item",
66
+ marginLeft: theme.variables.size.spacing.m,
67
+ paddingTop: theme.variables.size.spacing.xxxs,
68
+ paddingBottom: theme.variables.size.spacing.xxxs
69
+ };
70
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchResult.tsx"],"names":[],"mappings":"AA2C2B","file":"SearchResult.tsx","sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Columns, Column } from \"../Column/Columns\";\nimport { Icon, IconName } from \"../Icon/Icon\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Stack } from \"../Stack/Stack\";\nimport { StyledText } from \"../Typography/StyledText/StyledText\";\nimport { Badge } from \"../Badge/Badge\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport { Text } from \"../Typography/Text/Text\";\n\nexport type SecondaryTarget = {\n  title: string;\n  body?: string;\n  link: (props: { children: React.ReactNode }) => React.ReactElement;\n  \"data-e2e-test-id\"?: string;\n};\n\nexport type SecondaryTargetsProps = {\n  data: SecondaryTarget[];\n};\n\nconst StyledResultContainer = styled.div(() => ({\n  position: \"relative\",\n  textDecoration: \"none\",\n}));\n\nconst StyledLinkTitle = styled.div(({ theme }) => ({\n  color: theme.values.color.text.accent.default,\n}));\n\nconst StyledLinkContainerOnHover = styled.div(({ theme }) => ({\n  \"> a\": {\n    textDecoration: \"none\",\n    color: theme.values.color.text.accent.default,\n  },\n  \"&:hover\": {\n    [`${StyledLinkTitle}`]: {\n      textDecoration: \"underline\",\n    },\n  },\n}));\n\nconst StyledSecLinkTitle = styled.span(({ theme }) => ({\n  display: \"list-item\",\n  marginLeft: theme.variables.size.spacing.m,\n  paddingTop: theme.variables.size.spacing.xxxs,\n  paddingBottom: theme.variables.size.spacing.xxxs,\n}));\n\nconst StyledSecLinkContainerOnHover = styled.div(({ theme }) => ({\n  \"> a\": {\n    textDecoration: \"none\",\n    color: theme.values.color.text.tertiary.default,\n  },\n  \"&:hover\": {\n    [`${StyledSecLinkTitle}`]: {\n      textDecoration: \"underline\",\n    },\n  },\n}));\n\nconst SecondaryTargets = ({ data }: SecondaryTargetsProps) => (\n  <>\n    {data.map(\n      (\n        { title, link: SecLink, body, \"data-e2e-test-id\": dataE2eTestId },\n        i\n      ) => {\n        const key = `${title}-${i}`;\n        return (\n          <StyledSecLinkContainerOnHover\n            key={key}\n            data-e2e-test-id={dataE2eTestId}\n          >\n            <SecLink>\n              <StyledSecLinkTitle>\n                <Text size=\"m\" color=\"primary\" as=\"span\">\n                  <StyledText>{title}</StyledText>\n                </Text>\n              </StyledSecLinkTitle>\n              {body && (\n                <TextClamped size=\"s\" color=\"tertiary\" lines={2}>\n                  <StyledText>{body}</StyledText>\n                </TextClamped>\n              )}\n            </SecLink>\n          </StyledSecLinkContainerOnHover>\n        );\n      }\n    )}\n  </>\n);\n\nexport type SearchResultProps = {\n  /** The result title. Supports some nested HTML tags like <b> and <i>. Text gets clamped after 3 lines. */\n  title: string;\n  /** The subtitle that accompanies the title. Supports some nested HTML tags like <b> and <i>. Text gets clamped after 3 lines. */\n  subtitle?: string;\n  /** The primary AMBOSS target. */\n  link: (props: { children: React.ReactNode }) => React.ReactElement;\n  /** The left icon */\n  icon?: IconName;\n  /** List of details. Supports some nested HTML tags like <b> and <i>. */\n  details?: string[];\n  /** Usually a text content of the search result. Supports some nested HTML tags like <b> and <i>. Maximum 3 details items allowed where each test gets clamped after 3 lines. */\n  body?: string;\n  /** List of secondary AMBOSS targets with titles. Text gets clamped after 3 lines. */\n  secondaryTargets?: SecondaryTarget[];\n  /** List of labels. For example: preclinic, clinic, physician. */\n  labels?: string[];\n  /** The test id for the result's primary target. */\n  \"data-e2e-test-id\"?: string;\n};\n\nconst defaultProps: Partial<SearchResultProps> = {\n  icon: null,\n  details: [],\n  body: null,\n  secondaryTargets: [],\n  labels: [],\n  \"data-e2e-test-id\": undefined,\n};\n// this was a request by the designer to\n// have the backwards compatibility with the old search result\nconst BadgeWithBottomPadding = styled.div(({ theme }) => ({\n  paddingBottom: theme.variables.size.spacing.xxxs,\n}));\n\nexport function SearchResult({\n  title,\n  subtitle,\n  icon,\n  details,\n  body,\n  secondaryTargets,\n  link,\n  labels,\n  \"data-e2e-test-id\": dataE2eTestId,\n}: SearchResultProps): React.ReactElement {\n  const containerRef = useRef(null);\n\n  const MainLink = link;\n\n  const spacing = subtitle || details.length || labels.length ? \"xxs\" : \"zero\";\n\n  return (\n    <StyledResultContainer ref={containerRef} data-ds-id=\"SearchResult\">\n      <Columns gap=\"m\">\n        {icon && (\n          <Column size=\"narrow\">\n            <Icon name={icon} color=\"tertiary\" />\n          </Column>\n        )}\n        <Column size=\"fill\">\n          <Stack space=\"xxs\">\n            <StyledLinkContainerOnHover data-e2e-test-id={dataE2eTestId}>\n              <MainLink>\n                <Stack space={spacing}>\n                  <Columns gap=\"xxs\">\n                    <Column size={[12, 12, \"fill\"]}>\n                      <StyledLinkTitle>\n                        <Stack space=\"zero\">\n                          <TextClamped\n                            color=\"accent\"\n                            weight=\"bold\"\n                            lines={3}\n                            hyphens=\"auto\"\n                          >\n                            <StyledText>{title}</StyledText>\n                          </TextClamped>\n                          {subtitle && (\n                            <TextClamped color=\"accent\" lines={3} size=\"s\">\n                              <StyledText>{subtitle}</StyledText>\n                            </TextClamped>\n                          )}\n                        </Stack>\n                      </StyledLinkTitle>\n                    </Column>\n                    {labels && !!labels.length && (\n                      <Column size=\"narrow\">\n                        <Inline space=\"xs\">\n                          {labels.map((label, i) => {\n                            const key = `${i}${label}`;\n                            return (\n                              <BadgeWithBottomPadding key={key}>\n                                <Badge text={label} />\n                              </BadgeWithBottomPadding>\n                            );\n                          })}\n                        </Inline>\n                      </Column>\n                    )}\n                  </Columns>\n                  {details && !!details.length && (\n                    <Stack space=\"zero\">\n                      {details.slice(0, 3).map((detail) => (\n                        <TextClamped\n                          color=\"primary\"\n                          size=\"s\"\n                          key={detail}\n                          lines={3}\n                        >\n                          <StyledText>{detail}</StyledText>\n                        </TextClamped>\n                      ))}\n                    </Stack>\n                  )}\n                  {body && (\n                    <TextClamped size=\"s\" lines={2}>\n                      <StyledText>{body}</StyledText>\n                    </TextClamped>\n                  )}\n                </Stack>\n              </MainLink>\n            </StyledLinkContainerOnHover>\n            {secondaryTargets && !!secondaryTargets.length && (\n              <SecondaryTargets data={secondaryTargets} />\n            )}\n          </Stack>\n        </Column>\n      </Columns>\n    </StyledResultContainer>\n  );\n}\n\nSearchResult.defaultProps = defaultProps;\n"]} */");
71
+ const StyledSecLinkContainerOnHover = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
72
+ target: "e1y5sw0i1"
73
+ } : {
74
+ target: "e1y5sw0i1",
75
+ label: "StyledSecLinkContainerOnHover"
76
+ })(_ref4 => {
77
+ let {
78
+ theme
79
+ } = _ref4;
80
+ return {
81
+ "> a": {
82
+ textDecoration: "none",
83
+ color: theme.values.color.text.tertiary.default
84
+ },
85
+ "&:hover": {
86
+ [`${StyledSecLinkTitle}`]: {
87
+ textDecoration: "underline"
88
+ }
89
+ }
90
+ };
91
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchResult.tsx"],"names":[],"mappings":"AAkDsC","file":"SearchResult.tsx","sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Columns, Column } from \"../Column/Columns\";\nimport { Icon, IconName } from \"../Icon/Icon\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Stack } from \"../Stack/Stack\";\nimport { StyledText } from \"../Typography/StyledText/StyledText\";\nimport { Badge } from \"../Badge/Badge\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport { Text } from \"../Typography/Text/Text\";\n\nexport type SecondaryTarget = {\n  title: string;\n  body?: string;\n  link: (props: { children: React.ReactNode }) => React.ReactElement;\n  \"data-e2e-test-id\"?: string;\n};\n\nexport type SecondaryTargetsProps = {\n  data: SecondaryTarget[];\n};\n\nconst StyledResultContainer = styled.div(() => ({\n  position: \"relative\",\n  textDecoration: \"none\",\n}));\n\nconst StyledLinkTitle = styled.div(({ theme }) => ({\n  color: theme.values.color.text.accent.default,\n}));\n\nconst StyledLinkContainerOnHover = styled.div(({ theme }) => ({\n  \"> a\": {\n    textDecoration: \"none\",\n    color: theme.values.color.text.accent.default,\n  },\n  \"&:hover\": {\n    [`${StyledLinkTitle}`]: {\n      textDecoration: \"underline\",\n    },\n  },\n}));\n\nconst StyledSecLinkTitle = styled.span(({ theme }) => ({\n  display: \"list-item\",\n  marginLeft: theme.variables.size.spacing.m,\n  paddingTop: theme.variables.size.spacing.xxxs,\n  paddingBottom: theme.variables.size.spacing.xxxs,\n}));\n\nconst StyledSecLinkContainerOnHover = styled.div(({ theme }) => ({\n  \"> a\": {\n    textDecoration: \"none\",\n    color: theme.values.color.text.tertiary.default,\n  },\n  \"&:hover\": {\n    [`${StyledSecLinkTitle}`]: {\n      textDecoration: \"underline\",\n    },\n  },\n}));\n\nconst SecondaryTargets = ({ data }: SecondaryTargetsProps) => (\n  <>\n    {data.map(\n      (\n        { title, link: SecLink, body, \"data-e2e-test-id\": dataE2eTestId },\n        i\n      ) => {\n        const key = `${title}-${i}`;\n        return (\n          <StyledSecLinkContainerOnHover\n            key={key}\n            data-e2e-test-id={dataE2eTestId}\n          >\n            <SecLink>\n              <StyledSecLinkTitle>\n                <Text size=\"m\" color=\"primary\" as=\"span\">\n                  <StyledText>{title}</StyledText>\n                </Text>\n              </StyledSecLinkTitle>\n              {body && (\n                <TextClamped size=\"s\" color=\"tertiary\" lines={2}>\n                  <StyledText>{body}</StyledText>\n                </TextClamped>\n              )}\n            </SecLink>\n          </StyledSecLinkContainerOnHover>\n        );\n      }\n    )}\n  </>\n);\n\nexport type SearchResultProps = {\n  /** The result title. Supports some nested HTML tags like <b> and <i>. Text gets clamped after 3 lines. */\n  title: string;\n  /** The subtitle that accompanies the title. Supports some nested HTML tags like <b> and <i>. Text gets clamped after 3 lines. */\n  subtitle?: string;\n  /** The primary AMBOSS target. */\n  link: (props: { children: React.ReactNode }) => React.ReactElement;\n  /** The left icon */\n  icon?: IconName;\n  /** List of details. Supports some nested HTML tags like <b> and <i>. */\n  details?: string[];\n  /** Usually a text content of the search result. Supports some nested HTML tags like <b> and <i>. Maximum 3 details items allowed where each test gets clamped after 3 lines. */\n  body?: string;\n  /** List of secondary AMBOSS targets with titles. Text gets clamped after 3 lines. */\n  secondaryTargets?: SecondaryTarget[];\n  /** List of labels. For example: preclinic, clinic, physician. */\n  labels?: string[];\n  /** The test id for the result's primary target. */\n  \"data-e2e-test-id\"?: string;\n};\n\nconst defaultProps: Partial<SearchResultProps> = {\n  icon: null,\n  details: [],\n  body: null,\n  secondaryTargets: [],\n  labels: [],\n  \"data-e2e-test-id\": undefined,\n};\n// this was a request by the designer to\n// have the backwards compatibility with the old search result\nconst BadgeWithBottomPadding = styled.div(({ theme }) => ({\n  paddingBottom: theme.variables.size.spacing.xxxs,\n}));\n\nexport function SearchResult({\n  title,\n  subtitle,\n  icon,\n  details,\n  body,\n  secondaryTargets,\n  link,\n  labels,\n  \"data-e2e-test-id\": dataE2eTestId,\n}: SearchResultProps): React.ReactElement {\n  const containerRef = useRef(null);\n\n  const MainLink = link;\n\n  const spacing = subtitle || details.length || labels.length ? \"xxs\" : \"zero\";\n\n  return (\n    <StyledResultContainer ref={containerRef} data-ds-id=\"SearchResult\">\n      <Columns gap=\"m\">\n        {icon && (\n          <Column size=\"narrow\">\n            <Icon name={icon} color=\"tertiary\" />\n          </Column>\n        )}\n        <Column size=\"fill\">\n          <Stack space=\"xxs\">\n            <StyledLinkContainerOnHover data-e2e-test-id={dataE2eTestId}>\n              <MainLink>\n                <Stack space={spacing}>\n                  <Columns gap=\"xxs\">\n                    <Column size={[12, 12, \"fill\"]}>\n                      <StyledLinkTitle>\n                        <Stack space=\"zero\">\n                          <TextClamped\n                            color=\"accent\"\n                            weight=\"bold\"\n                            lines={3}\n                            hyphens=\"auto\"\n                          >\n                            <StyledText>{title}</StyledText>\n                          </TextClamped>\n                          {subtitle && (\n                            <TextClamped color=\"accent\" lines={3} size=\"s\">\n                              <StyledText>{subtitle}</StyledText>\n                            </TextClamped>\n                          )}\n                        </Stack>\n                      </StyledLinkTitle>\n                    </Column>\n                    {labels && !!labels.length && (\n                      <Column size=\"narrow\">\n                        <Inline space=\"xs\">\n                          {labels.map((label, i) => {\n                            const key = `${i}${label}`;\n                            return (\n                              <BadgeWithBottomPadding key={key}>\n                                <Badge text={label} />\n                              </BadgeWithBottomPadding>\n                            );\n                          })}\n                        </Inline>\n                      </Column>\n                    )}\n                  </Columns>\n                  {details && !!details.length && (\n                    <Stack space=\"zero\">\n                      {details.slice(0, 3).map((detail) => (\n                        <TextClamped\n                          color=\"primary\"\n                          size=\"s\"\n                          key={detail}\n                          lines={3}\n                        >\n                          <StyledText>{detail}</StyledText>\n                        </TextClamped>\n                      ))}\n                    </Stack>\n                  )}\n                  {body && (\n                    <TextClamped size=\"s\" lines={2}>\n                      <StyledText>{body}</StyledText>\n                    </TextClamped>\n                  )}\n                </Stack>\n              </MainLink>\n            </StyledLinkContainerOnHover>\n            {secondaryTargets && !!secondaryTargets.length && (\n              <SecondaryTargets data={secondaryTargets} />\n            )}\n          </Stack>\n        </Column>\n      </Columns>\n    </StyledResultContainer>\n  );\n}\n\nSearchResult.defaultProps = defaultProps;\n"]} */");
92
+ const SecondaryTargets = _ref5 => {
93
+ let {
94
+ data
95
+ } = _ref5;
96
+ return /*#__PURE__*/React.createElement(React.Fragment, null, data.map((_ref6, i) => {
97
+ let {
98
+ title,
99
+ link: SecLink,
100
+ body,
101
+ "data-e2e-test-id": dataE2eTestId
102
+ } = _ref6;
103
+ const key = `${title}-${i}`;
104
+ return /*#__PURE__*/React.createElement(StyledSecLinkContainerOnHover, {
105
+ key: key,
106
+ "data-e2e-test-id": dataE2eTestId
107
+ }, /*#__PURE__*/React.createElement(SecLink, null, /*#__PURE__*/React.createElement(StyledSecLinkTitle, null, /*#__PURE__*/React.createElement(Text, {
108
+ size: "m",
109
+ color: "primary",
110
+ as: "span"
111
+ }, /*#__PURE__*/React.createElement(StyledText, null, title))), body && /*#__PURE__*/React.createElement(TextClamped, {
112
+ size: "s",
113
+ color: "tertiary",
114
+ lines: 2
115
+ }, /*#__PURE__*/React.createElement(StyledText, null, body))));
116
+ }));
70
117
  };
71
118
  const defaultProps = {
72
119
  icon: null,
73
120
  details: [],
74
121
  body: null,
75
122
  secondaryTargets: [],
76
- isExternal: false,
77
123
  labels: [],
78
124
  "data-e2e-test-id": undefined
79
125
  };
80
- function SearchResult(_ref4) {
126
+ // this was a request by the designer to
127
+ // have the backwards compatibility with the old search result
128
+ const BadgeWithBottomPadding = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
129
+ target: "e1y5sw0i0"
130
+ } : {
131
+ target: "e1y5sw0i0",
132
+ label: "BadgeWithBottomPadding"
133
+ })(_ref7 => {
134
+ let {
135
+ theme
136
+ } = _ref7;
137
+ return {
138
+ paddingBottom: theme.variables.size.spacing.xxxs
139
+ };
140
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchResult.tsx"],"names":[],"mappings":"AA6H+B","file":"SearchResult.tsx","sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Columns, Column } from \"../Column/Columns\";\nimport { Icon, IconName } from \"../Icon/Icon\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Stack } from \"../Stack/Stack\";\nimport { StyledText } from \"../Typography/StyledText/StyledText\";\nimport { Badge } from \"../Badge/Badge\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport { Text } from \"../Typography/Text/Text\";\n\nexport type SecondaryTarget = {\n  title: string;\n  body?: string;\n  link: (props: { children: React.ReactNode }) => React.ReactElement;\n  \"data-e2e-test-id\"?: string;\n};\n\nexport type SecondaryTargetsProps = {\n  data: SecondaryTarget[];\n};\n\nconst StyledResultContainer = styled.div(() => ({\n  position: \"relative\",\n  textDecoration: \"none\",\n}));\n\nconst StyledLinkTitle = styled.div(({ theme }) => ({\n  color: theme.values.color.text.accent.default,\n}));\n\nconst StyledLinkContainerOnHover = styled.div(({ theme }) => ({\n  \"> a\": {\n    textDecoration: \"none\",\n    color: theme.values.color.text.accent.default,\n  },\n  \"&:hover\": {\n    [`${StyledLinkTitle}`]: {\n      textDecoration: \"underline\",\n    },\n  },\n}));\n\nconst StyledSecLinkTitle = styled.span(({ theme }) => ({\n  display: \"list-item\",\n  marginLeft: theme.variables.size.spacing.m,\n  paddingTop: theme.variables.size.spacing.xxxs,\n  paddingBottom: theme.variables.size.spacing.xxxs,\n}));\n\nconst StyledSecLinkContainerOnHover = styled.div(({ theme }) => ({\n  \"> a\": {\n    textDecoration: \"none\",\n    color: theme.values.color.text.tertiary.default,\n  },\n  \"&:hover\": {\n    [`${StyledSecLinkTitle}`]: {\n      textDecoration: \"underline\",\n    },\n  },\n}));\n\nconst SecondaryTargets = ({ data }: SecondaryTargetsProps) => (\n  <>\n    {data.map(\n      (\n        { title, link: SecLink, body, \"data-e2e-test-id\": dataE2eTestId },\n        i\n      ) => {\n        const key = `${title}-${i}`;\n        return (\n          <StyledSecLinkContainerOnHover\n            key={key}\n            data-e2e-test-id={dataE2eTestId}\n          >\n            <SecLink>\n              <StyledSecLinkTitle>\n                <Text size=\"m\" color=\"primary\" as=\"span\">\n                  <StyledText>{title}</StyledText>\n                </Text>\n              </StyledSecLinkTitle>\n              {body && (\n                <TextClamped size=\"s\" color=\"tertiary\" lines={2}>\n                  <StyledText>{body}</StyledText>\n                </TextClamped>\n              )}\n            </SecLink>\n          </StyledSecLinkContainerOnHover>\n        );\n      }\n    )}\n  </>\n);\n\nexport type SearchResultProps = {\n  /** The result title. Supports some nested HTML tags like <b> and <i>. Text gets clamped after 3 lines. */\n  title: string;\n  /** The subtitle that accompanies the title. Supports some nested HTML tags like <b> and <i>. Text gets clamped after 3 lines. */\n  subtitle?: string;\n  /** The primary AMBOSS target. */\n  link: (props: { children: React.ReactNode }) => React.ReactElement;\n  /** The left icon */\n  icon?: IconName;\n  /** List of details. Supports some nested HTML tags like <b> and <i>. */\n  details?: string[];\n  /** Usually a text content of the search result. Supports some nested HTML tags like <b> and <i>. Maximum 3 details items allowed where each test gets clamped after 3 lines. */\n  body?: string;\n  /** List of secondary AMBOSS targets with titles. Text gets clamped after 3 lines. */\n  secondaryTargets?: SecondaryTarget[];\n  /** List of labels. For example: preclinic, clinic, physician. */\n  labels?: string[];\n  /** The test id for the result's primary target. */\n  \"data-e2e-test-id\"?: string;\n};\n\nconst defaultProps: Partial<SearchResultProps> = {\n  icon: null,\n  details: [],\n  body: null,\n  secondaryTargets: [],\n  labels: [],\n  \"data-e2e-test-id\": undefined,\n};\n// this was a request by the designer to\n// have the backwards compatibility with the old search result\nconst BadgeWithBottomPadding = styled.div(({ theme }) => ({\n  paddingBottom: theme.variables.size.spacing.xxxs,\n}));\n\nexport function SearchResult({\n  title,\n  subtitle,\n  icon,\n  details,\n  body,\n  secondaryTargets,\n  link,\n  labels,\n  \"data-e2e-test-id\": dataE2eTestId,\n}: SearchResultProps): React.ReactElement {\n  const containerRef = useRef(null);\n\n  const MainLink = link;\n\n  const spacing = subtitle || details.length || labels.length ? \"xxs\" : \"zero\";\n\n  return (\n    <StyledResultContainer ref={containerRef} data-ds-id=\"SearchResult\">\n      <Columns gap=\"m\">\n        {icon && (\n          <Column size=\"narrow\">\n            <Icon name={icon} color=\"tertiary\" />\n          </Column>\n        )}\n        <Column size=\"fill\">\n          <Stack space=\"xxs\">\n            <StyledLinkContainerOnHover data-e2e-test-id={dataE2eTestId}>\n              <MainLink>\n                <Stack space={spacing}>\n                  <Columns gap=\"xxs\">\n                    <Column size={[12, 12, \"fill\"]}>\n                      <StyledLinkTitle>\n                        <Stack space=\"zero\">\n                          <TextClamped\n                            color=\"accent\"\n                            weight=\"bold\"\n                            lines={3}\n                            hyphens=\"auto\"\n                          >\n                            <StyledText>{title}</StyledText>\n                          </TextClamped>\n                          {subtitle && (\n                            <TextClamped color=\"accent\" lines={3} size=\"s\">\n                              <StyledText>{subtitle}</StyledText>\n                            </TextClamped>\n                          )}\n                        </Stack>\n                      </StyledLinkTitle>\n                    </Column>\n                    {labels && !!labels.length && (\n                      <Column size=\"narrow\">\n                        <Inline space=\"xs\">\n                          {labels.map((label, i) => {\n                            const key = `${i}${label}`;\n                            return (\n                              <BadgeWithBottomPadding key={key}>\n                                <Badge text={label} />\n                              </BadgeWithBottomPadding>\n                            );\n                          })}\n                        </Inline>\n                      </Column>\n                    )}\n                  </Columns>\n                  {details && !!details.length && (\n                    <Stack space=\"zero\">\n                      {details.slice(0, 3).map((detail) => (\n                        <TextClamped\n                          color=\"primary\"\n                          size=\"s\"\n                          key={detail}\n                          lines={3}\n                        >\n                          <StyledText>{detail}</StyledText>\n                        </TextClamped>\n                      ))}\n                    </Stack>\n                  )}\n                  {body && (\n                    <TextClamped size=\"s\" lines={2}>\n                      <StyledText>{body}</StyledText>\n                    </TextClamped>\n                  )}\n                </Stack>\n              </MainLink>\n            </StyledLinkContainerOnHover>\n            {secondaryTargets && !!secondaryTargets.length && (\n              <SecondaryTargets data={secondaryTargets} />\n            )}\n          </Stack>\n        </Column>\n      </Columns>\n    </StyledResultContainer>\n  );\n}\n\nSearchResult.defaultProps = defaultProps;\n"]} */");
141
+ function SearchResult(_ref8) {
81
142
  let {
82
143
  title,
83
144
  subtitle,
@@ -88,10 +149,10 @@ function SearchResult(_ref4) {
88
149
  link,
89
150
  labels,
90
151
  "data-e2e-test-id": dataE2eTestId
91
- } = _ref4;
152
+ } = _ref8;
92
153
  const containerRef = useRef(null);
93
- const hasShallowSecondaryTargets = secondaryTargets && secondaryTargets.reduce((prev, curr) => curr.body ? false : prev, true);
94
154
  const MainLink = link;
155
+ const spacing = subtitle || details.length || labels.length ? "xxs" : "zero";
95
156
  return /*#__PURE__*/React.createElement(StyledResultContainer, {
96
157
  ref: containerRef,
97
158
  "data-ds-id": "SearchResult"
@@ -105,11 +166,11 @@ function SearchResult(_ref4) {
105
166
  })), /*#__PURE__*/React.createElement(Column, {
106
167
  size: "fill"
107
168
  }, /*#__PURE__*/React.createElement(Stack, {
108
- space: "s"
169
+ space: "xxs"
109
170
  }, /*#__PURE__*/React.createElement(StyledLinkContainerOnHover, {
110
171
  "data-e2e-test-id": dataE2eTestId
111
172
  }, /*#__PURE__*/React.createElement(MainLink, null, /*#__PURE__*/React.createElement(Stack, {
112
- space: "xxs"
173
+ space: spacing
113
174
  }, /*#__PURE__*/React.createElement(Columns, {
114
175
  gap: "xxs"
115
176
  }, /*#__PURE__*/React.createElement(Column, {
@@ -125,17 +186,18 @@ function SearchResult(_ref4) {
125
186
  color: "accent",
126
187
  lines: 3,
127
188
  size: "s"
128
- }, /*#__PURE__*/React.createElement(StyledText, null, subtitle))))), /*#__PURE__*/React.createElement(Column, {
189
+ }, /*#__PURE__*/React.createElement(StyledText, null, subtitle))))), labels && !!labels.length && /*#__PURE__*/React.createElement(Column, {
129
190
  size: "narrow"
130
- }, labels && !!labels.length && /*#__PURE__*/React.createElement(Inline, {
191
+ }, /*#__PURE__*/React.createElement(Inline, {
131
192
  space: "xs"
132
- }, labels.map((label, i) =>
133
- /*#__PURE__*/
134
- // eslint-disable-next-line react/no-array-index-key
135
- React.createElement(Badge, {
136
- text: label,
137
- key: `${i}${label}`
138
- }))))), details && !!details.length && /*#__PURE__*/React.createElement(Stack, {
193
+ }, labels.map((label, i) => {
194
+ const key = `${i}${label}`;
195
+ return /*#__PURE__*/React.createElement(BadgeWithBottomPadding, {
196
+ key: key
197
+ }, /*#__PURE__*/React.createElement(Badge, {
198
+ text: label
199
+ }));
200
+ })))), details && !!details.length && /*#__PURE__*/React.createElement(Stack, {
139
201
  space: "zero"
140
202
  }, details.slice(0, 3).map(detail => /*#__PURE__*/React.createElement(TextClamped, {
141
203
  color: "primary",
@@ -146,30 +208,7 @@ function SearchResult(_ref4) {
146
208
  size: "s",
147
209
  lines: 2
148
210
  }, /*#__PURE__*/React.createElement(StyledText, null, body))))), secondaryTargets && !!secondaryTargets.length && /*#__PURE__*/React.createElement(SecondaryTargets, {
149
- data: secondaryTargets,
150
- compact: hasShallowSecondaryTargets,
151
- renderItem: _ref5 => {
152
- let {
153
- title: secTitle,
154
- link: secLink,
155
- body: secBody,
156
- "data-e2e-test-id": secDataE2eTestId
157
- } = _ref5;
158
- const SecLink = secLink;
159
- return /*#__PURE__*/React.createElement(StyledLinkContainerOnHover, {
160
- key: title,
161
- "data-e2e-test-id": secDataE2eTestId
162
- }, /*#__PURE__*/React.createElement(SecLink, null, /*#__PURE__*/React.createElement(StyledLinkTitle, null, /*#__PURE__*/React.createElement(TextClamped, {
163
- size: "s",
164
- color: "accent",
165
- weight: "bold",
166
- lines: 3
167
- }, /*#__PURE__*/React.createElement(StyledText, null, secTitle))), secBody && /*#__PURE__*/React.createElement(TextClamped, {
168
- size: "s",
169
- color: "primary",
170
- lines: 2
171
- }, /*#__PURE__*/React.createElement(StyledText, null, secBody))));
172
- }
211
+ data: secondaryTargets
173
212
  })))));
174
213
  }
175
214
  SearchResult.defaultProps = defaultProps;
@@ -1 +1 @@
1
- {"version":3,"file":"SearchResult.js","sources":["../../../../../src/components/SearchResult/SearchResult.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Columns, Column } from \"../Column/Columns\";\nimport { Icon, IconName } from \"../Icon/Icon\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Stack } from \"../Stack/Stack\";\nimport { StyledText } from \"../Typography/StyledText/StyledText\";\nimport { Badge } from \"../Badge/Badge\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\n\nexport type SecondaryTarget = {\n title: string;\n body?: string;\n link: (props: { children: React.ReactNode }) => React.ReactElement;\n \"data-e2e-test-id\"?: string;\n};\n\nexport type SecondaryTargetsProps = {\n data: SecondaryTarget[];\n renderItem: (item: SecondaryTarget) => React.ReactElement;\n compact?: boolean;\n};\n\nconst StyledResultContainer = styled.div(() => ({\n position: \"relative\",\n textDecoration: \"none\",\n}));\n\nconst StyledLinkTitle = styled.div(({ theme }) => ({\n color: theme.values.color.text.accent.default,\n}));\n\nconst StyledLinkContainerOnHover = styled.div(({ theme }) => ({\n \"> a\": {\n textDecoration: \"none\",\n color: theme.values.color.text.accent.default,\n },\n \"&:hover\": {\n [`${StyledLinkTitle}`]: {\n textDecoration: \"underline\",\n },\n },\n}));\n\nconst SecondaryTargets = ({\n data,\n renderItem,\n compact,\n}: SecondaryTargetsProps) =>\n compact ? (\n <Inline space=\"l\" vSpace=\"xs\">\n {data && data.length && data.map((target) => renderItem(target))}\n </Inline>\n ) : (\n <Columns gap=\"m\">\n {data.map((target) => (\n <Column\n data-e2e-test-id={target[\"data-e2e-test-id\"]}\n size={[12, 6, 6]}\n key={target.title}\n >\n {renderItem(target)}\n </Column>\n ))}\n </Columns>\n );\n\nexport type SearchResultProps = {\n /** The result title. Supports some nested HTML tags like <b> and <i>. Text gets clamped after 3 lines. */\n title: string;\n /** The subtitle that accompanies the title. Supports some nested HTML tags like <b> and <i>. Text gets clamped after 3 lines. */\n subtitle?: string;\n /** The primary AMBOSS target. */\n link: (props: { children: React.ReactNode }) => React.ReactElement;\n /** The left icon */\n icon?: IconName;\n /** List of details. Supports some nested HTML tags like <b> and <i>. */\n details?: string[];\n /** Usually a text content of the search result. Supports some nested HTML tags like <b> and <i>. Maximum 3 details items allowed where each test gets clamped after 3 lines. */\n body?: string;\n /** List of secondary AMBOSS targets with titles. Text gets clamped after 3 lines. */\n secondaryTargets?: SecondaryTarget[];\n /** Indicate an external link */\n isExternal?: boolean;\n /** List of labels. For example: preclinic, clinic, physician. */\n labels?: string[];\n /** The test id for the result's primary target. */\n \"data-e2e-test-id\"?: string;\n};\n\nconst defaultProps: Partial<SearchResultProps> = {\n icon: null,\n details: [],\n body: null,\n secondaryTargets: [],\n isExternal: false,\n labels: [],\n \"data-e2e-test-id\": undefined,\n};\n\nexport function SearchResult({\n title,\n subtitle,\n icon,\n details,\n body,\n secondaryTargets,\n link,\n labels,\n \"data-e2e-test-id\": dataE2eTestId,\n}: SearchResultProps): React.ReactElement {\n const containerRef = useRef(null);\n const hasShallowSecondaryTargets =\n secondaryTargets &&\n secondaryTargets.reduce((prev, curr) => (curr.body ? false : prev), true);\n const MainLink = link;\n\n return (\n <StyledResultContainer ref={containerRef} data-ds-id=\"SearchResult\">\n <Columns gap=\"m\">\n {icon && (\n <Column size=\"narrow\">\n <Icon name={icon} color=\"tertiary\" />\n </Column>\n )}\n <Column size=\"fill\">\n <Stack space=\"s\">\n <StyledLinkContainerOnHover data-e2e-test-id={dataE2eTestId}>\n <MainLink>\n <Stack space=\"xxs\">\n <Columns gap=\"xxs\">\n <Column size={[12, 12, \"fill\"]}>\n <StyledLinkTitle>\n <Stack space=\"zero\">\n <TextClamped\n color=\"accent\"\n weight=\"bold\"\n lines={3}\n hyphens=\"auto\"\n >\n <StyledText>{title}</StyledText>\n </TextClamped>\n {subtitle && (\n <TextClamped color=\"accent\" lines={3} size=\"s\">\n <StyledText>{subtitle}</StyledText>\n </TextClamped>\n )}\n </Stack>\n </StyledLinkTitle>\n </Column>\n <Column size=\"narrow\">\n {labels && !!labels.length && (\n <Inline space=\"xs\">\n {labels.map((label, i) => (\n // eslint-disable-next-line react/no-array-index-key\n <Badge text={label} key={`${i}${label}`} />\n ))}\n </Inline>\n )}\n </Column>\n </Columns>\n {details && !!details.length && (\n <Stack space=\"zero\">\n {details.slice(0, 3).map((detail) => (\n <TextClamped\n color=\"primary\"\n size=\"s\"\n key={detail}\n lines={3}\n >\n <StyledText>{detail}</StyledText>\n </TextClamped>\n ))}\n </Stack>\n )}\n {body && (\n <TextClamped size=\"s\" lines={2}>\n <StyledText>{body}</StyledText>\n </TextClamped>\n )}\n </Stack>\n </MainLink>\n </StyledLinkContainerOnHover>\n {secondaryTargets && !!secondaryTargets.length && (\n <SecondaryTargets\n data={secondaryTargets}\n compact={hasShallowSecondaryTargets}\n renderItem={({\n title: secTitle,\n link: secLink,\n body: secBody,\n \"data-e2e-test-id\": secDataE2eTestId,\n }) => {\n const SecLink = secLink;\n return (\n <StyledLinkContainerOnHover\n key={title}\n data-e2e-test-id={secDataE2eTestId}\n >\n <SecLink>\n <StyledLinkTitle>\n <TextClamped\n size=\"s\"\n color=\"accent\"\n weight=\"bold\"\n lines={3}\n >\n <StyledText>{secTitle}</StyledText>\n </TextClamped>\n </StyledLinkTitle>\n {secBody && (\n <TextClamped size=\"s\" color=\"primary\" lines={2}>\n <StyledText>{secBody}</StyledText>\n </TextClamped>\n )}\n </SecLink>\n </StyledLinkContainerOnHover>\n );\n }}\n />\n )}\n </Stack>\n </Column>\n </Columns>\n </StyledResultContainer>\n );\n}\n\nSearchResult.defaultProps = defaultProps;\n"],"names":["StyledResultContainer","_styled","process","env","NODE_ENV","target","label","position","textDecoration","StyledLinkTitle","_ref","theme","color","values","text","accent","default","StyledLinkContainerOnHover","_ref2","SecondaryTargets","_ref3","data","renderItem","compact","React","createElement","Inline","space","vSpace","length","map","Columns","gap","Column","size","key","title","defaultProps","icon","details","body","secondaryTargets","isExternal","labels","undefined","SearchResult","_ref4","subtitle","link","dataE2eTestId","containerRef","useRef","hasShallowSecondaryTargets","reduce","prev","curr","MainLink","ref","Icon","name","Stack","TextClamped","weight","lines","hyphens","StyledText","i","Badge","slice","detail","_ref5","secTitle","secLink","secBody","secDataE2eTestId","SecLink"],"mappings":"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"}
1
+ {"version":3,"file":"SearchResult.js","sources":["../../../../../src/components/SearchResult/SearchResult.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Columns, Column } from \"../Column/Columns\";\nimport { Icon, IconName } from \"../Icon/Icon\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Stack } from \"../Stack/Stack\";\nimport { StyledText } from \"../Typography/StyledText/StyledText\";\nimport { Badge } from \"../Badge/Badge\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport { Text } from \"../Typography/Text/Text\";\n\nexport type SecondaryTarget = {\n title: string;\n body?: string;\n link: (props: { children: React.ReactNode }) => React.ReactElement;\n \"data-e2e-test-id\"?: string;\n};\n\nexport type SecondaryTargetsProps = {\n data: SecondaryTarget[];\n};\n\nconst StyledResultContainer = styled.div(() => ({\n position: \"relative\",\n textDecoration: \"none\",\n}));\n\nconst StyledLinkTitle = styled.div(({ theme }) => ({\n color: theme.values.color.text.accent.default,\n}));\n\nconst StyledLinkContainerOnHover = styled.div(({ theme }) => ({\n \"> a\": {\n textDecoration: \"none\",\n color: theme.values.color.text.accent.default,\n },\n \"&:hover\": {\n [`${StyledLinkTitle}`]: {\n textDecoration: \"underline\",\n },\n },\n}));\n\nconst StyledSecLinkTitle = styled.span(({ theme }) => ({\n display: \"list-item\",\n marginLeft: theme.variables.size.spacing.m,\n paddingTop: theme.variables.size.spacing.xxxs,\n paddingBottom: theme.variables.size.spacing.xxxs,\n}));\n\nconst StyledSecLinkContainerOnHover = styled.div(({ theme }) => ({\n \"> a\": {\n textDecoration: \"none\",\n color: theme.values.color.text.tertiary.default,\n },\n \"&:hover\": {\n [`${StyledSecLinkTitle}`]: {\n textDecoration: \"underline\",\n },\n },\n}));\n\nconst SecondaryTargets = ({ data }: SecondaryTargetsProps) => (\n <>\n {data.map(\n (\n { title, link: SecLink, body, \"data-e2e-test-id\": dataE2eTestId },\n i\n ) => {\n const key = `${title}-${i}`;\n return (\n <StyledSecLinkContainerOnHover\n key={key}\n data-e2e-test-id={dataE2eTestId}\n >\n <SecLink>\n <StyledSecLinkTitle>\n <Text size=\"m\" color=\"primary\" as=\"span\">\n <StyledText>{title}</StyledText>\n </Text>\n </StyledSecLinkTitle>\n {body && (\n <TextClamped size=\"s\" color=\"tertiary\" lines={2}>\n <StyledText>{body}</StyledText>\n </TextClamped>\n )}\n </SecLink>\n </StyledSecLinkContainerOnHover>\n );\n }\n )}\n </>\n);\n\nexport type SearchResultProps = {\n /** The result title. Supports some nested HTML tags like <b> and <i>. Text gets clamped after 3 lines. */\n title: string;\n /** The subtitle that accompanies the title. Supports some nested HTML tags like <b> and <i>. Text gets clamped after 3 lines. */\n subtitle?: string;\n /** The primary AMBOSS target. */\n link: (props: { children: React.ReactNode }) => React.ReactElement;\n /** The left icon */\n icon?: IconName;\n /** List of details. Supports some nested HTML tags like <b> and <i>. */\n details?: string[];\n /** Usually a text content of the search result. Supports some nested HTML tags like <b> and <i>. Maximum 3 details items allowed where each test gets clamped after 3 lines. */\n body?: string;\n /** List of secondary AMBOSS targets with titles. Text gets clamped after 3 lines. */\n secondaryTargets?: SecondaryTarget[];\n /** List of labels. For example: preclinic, clinic, physician. */\n labels?: string[];\n /** The test id for the result's primary target. */\n \"data-e2e-test-id\"?: string;\n};\n\nconst defaultProps: Partial<SearchResultProps> = {\n icon: null,\n details: [],\n body: null,\n secondaryTargets: [],\n labels: [],\n \"data-e2e-test-id\": undefined,\n};\n// this was a request by the designer to\n// have the backwards compatibility with the old search result\nconst BadgeWithBottomPadding = styled.div(({ theme }) => ({\n paddingBottom: theme.variables.size.spacing.xxxs,\n}));\n\nexport function SearchResult({\n title,\n subtitle,\n icon,\n details,\n body,\n secondaryTargets,\n link,\n labels,\n \"data-e2e-test-id\": dataE2eTestId,\n}: SearchResultProps): React.ReactElement {\n const containerRef = useRef(null);\n\n const MainLink = link;\n\n const spacing = subtitle || details.length || labels.length ? \"xxs\" : \"zero\";\n\n return (\n <StyledResultContainer ref={containerRef} data-ds-id=\"SearchResult\">\n <Columns gap=\"m\">\n {icon && (\n <Column size=\"narrow\">\n <Icon name={icon} color=\"tertiary\" />\n </Column>\n )}\n <Column size=\"fill\">\n <Stack space=\"xxs\">\n <StyledLinkContainerOnHover data-e2e-test-id={dataE2eTestId}>\n <MainLink>\n <Stack space={spacing}>\n <Columns gap=\"xxs\">\n <Column size={[12, 12, \"fill\"]}>\n <StyledLinkTitle>\n <Stack space=\"zero\">\n <TextClamped\n color=\"accent\"\n weight=\"bold\"\n lines={3}\n hyphens=\"auto\"\n >\n <StyledText>{title}</StyledText>\n </TextClamped>\n {subtitle && (\n <TextClamped color=\"accent\" lines={3} size=\"s\">\n <StyledText>{subtitle}</StyledText>\n </TextClamped>\n )}\n </Stack>\n </StyledLinkTitle>\n </Column>\n {labels && !!labels.length && (\n <Column size=\"narrow\">\n <Inline space=\"xs\">\n {labels.map((label, i) => {\n const key = `${i}${label}`;\n return (\n <BadgeWithBottomPadding key={key}>\n <Badge text={label} />\n </BadgeWithBottomPadding>\n );\n })}\n </Inline>\n </Column>\n )}\n </Columns>\n {details && !!details.length && (\n <Stack space=\"zero\">\n {details.slice(0, 3).map((detail) => (\n <TextClamped\n color=\"primary\"\n size=\"s\"\n key={detail}\n lines={3}\n >\n <StyledText>{detail}</StyledText>\n </TextClamped>\n ))}\n </Stack>\n )}\n {body && (\n <TextClamped size=\"s\" lines={2}>\n <StyledText>{body}</StyledText>\n </TextClamped>\n )}\n </Stack>\n </MainLink>\n </StyledLinkContainerOnHover>\n {secondaryTargets && !!secondaryTargets.length && (\n <SecondaryTargets data={secondaryTargets} />\n )}\n </Stack>\n </Column>\n </Columns>\n </StyledResultContainer>\n );\n}\n\nSearchResult.defaultProps = defaultProps;\n"],"names":["StyledResultContainer","_styled","process","env","NODE_ENV","target","label","position","textDecoration","StyledLinkTitle","_ref","theme","color","values","text","accent","default","StyledLinkContainerOnHover","_ref2","StyledSecLinkTitle","_ref3","display","marginLeft","variables","size","spacing","m","paddingTop","xxxs","paddingBottom","StyledSecLinkContainerOnHover","_ref4","tertiary","SecondaryTargets","_ref5","data","React","createElement","Fragment","map","_ref6","i","title","link","SecLink","body","dataE2eTestId","key","Text","as","StyledText","TextClamped","lines","defaultProps","icon","details","secondaryTargets","labels","undefined","BadgeWithBottomPadding","_ref7","SearchResult","_ref8","subtitle","containerRef","useRef","MainLink","length","ref","Columns","gap","Column","Icon","name","Stack","space","weight","hyphens","Inline","Badge","slice","detail"],"mappings":"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"}
@@ -1,4 +1,5 @@
1
1
  import React from "react";
2
+ export declare const MAX_TAG_WIDTH = 200;
2
3
  declare type BaseTagProps = {
3
4
  label: string;
4
5
  colorVariant?: "gray" | "blue";