@amboss/design-system 1.16.0 → 1.16.1--canary2

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.
@@ -24,7 +24,7 @@ const StyledResultContainer = /*#__PURE__*/_styled__default.default("div", proce
24
24
  })(() => ({
25
25
  position: "relative",
26
26
  textDecoration: "none"
27
- }), 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"]} */");
27
+ }), 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  \"&:hover\": {\n    [`> span`]: {\n      textDecoration: \"underline\",\n      // this value controls text and its underline color\n      color: theme.values.color.text.primary.default,\n    },\n  },\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      // this value controls the bolt point color\n      color: theme.values.color.text.tertiary.default,\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"]} */");
28
28
  const StyledLinkTitle = /*#__PURE__*/_styled__default.default("div", process.env.NODE_ENV === "production" ? {
29
29
  target: "e1y5sw0i4"
30
30
  } : {
@@ -37,7 +37,7 @@ const StyledLinkTitle = /*#__PURE__*/_styled__default.default("div", process.env
37
37
  return {
38
38
  color: theme.values.color.text.accent.default
39
39
  };
40
- }, 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"]} */");
40
+ }, 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  \"&:hover\": {\n    [`> span`]: {\n      textDecoration: \"underline\",\n      // this value controls text and its underline color\n      color: theme.values.color.text.primary.default,\n    },\n  },\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      // this value controls the bolt point color\n      color: theme.values.color.text.tertiary.default,\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"]} */");
41
41
  const StyledLinkContainerOnHover = /*#__PURE__*/_styled__default.default("div", process.env.NODE_ENV === "production" ? {
42
42
  target: "e1y5sw0i3"
43
43
  } : {
@@ -58,7 +58,7 @@ const StyledLinkContainerOnHover = /*#__PURE__*/_styled__default.default("div",
58
58
  }
59
59
  }
60
60
  };
61
- }, 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"]} */");
61
+ }, 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  \"&:hover\": {\n    [`> span`]: {\n      textDecoration: \"underline\",\n      // this value controls text and its underline color\n      color: theme.values.color.text.primary.default,\n    },\n  },\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      // this value controls the bolt point color\n      color: theme.values.color.text.tertiary.default,\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"]} */");
62
62
  const StyledSecLinkTitle = /*#__PURE__*/_styled__default.default("span", process.env.NODE_ENV === "production" ? {
63
63
  target: "e1y5sw0i2"
64
64
  } : {
@@ -72,9 +72,16 @@ const StyledSecLinkTitle = /*#__PURE__*/_styled__default.default("span", process
72
72
  display: "list-item",
73
73
  marginLeft: theme.variables.size.spacing.m,
74
74
  paddingTop: theme.variables.size.spacing.xxxs,
75
- paddingBottom: theme.variables.size.spacing.xxxs
75
+ paddingBottom: theme.variables.size.spacing.xxxs,
76
+ "&:hover": {
77
+ [`> span`]: {
78
+ textDecoration: "underline",
79
+ // this value controls text and its underline color
80
+ color: theme.values.color.text.primary.default
81
+ }
82
+ }
76
83
  };
77
- }, 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"]} */");
84
+ }, 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  \"&:hover\": {\n    [`> span`]: {\n      textDecoration: \"underline\",\n      // this value controls text and its underline color\n      color: theme.values.color.text.primary.default,\n    },\n  },\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      // this value controls the bolt point color\n      color: theme.values.color.text.tertiary.default,\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"]} */");
78
85
  const StyledSecLinkContainerOnHover = /*#__PURE__*/_styled__default.default("div", process.env.NODE_ENV === "production" ? {
79
86
  target: "e1y5sw0i1"
80
87
  } : {
@@ -91,11 +98,12 @@ const StyledSecLinkContainerOnHover = /*#__PURE__*/_styled__default.default("div
91
98
  },
92
99
  "&:hover": {
93
100
  [`${StyledSecLinkTitle}`]: {
94
- textDecoration: "underline"
101
+ // this value controls the bolt point color
102
+ color: theme.values.color.text.tertiary.default
95
103
  }
96
104
  }
97
105
  };
98
- }, 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"]} */");
106
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchResult.tsx"],"names":[],"mappings":"AAyDsC","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  \"&:hover\": {\n    [`> span`]: {\n      textDecoration: \"underline\",\n      // this value controls text and its underline color\n      color: theme.values.color.text.primary.default,\n    },\n  },\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      // this value controls the bolt point color\n      color: theme.values.color.text.tertiary.default,\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"]} */");
99
107
  const SecondaryTargets = _ref5 => {
100
108
  let {
101
109
  data
@@ -144,7 +152,7 @@ const BadgeWithBottomPadding = /*#__PURE__*/_styled__default.default("div", proc
144
152
  return {
145
153
  paddingBottom: theme.variables.size.spacing.xxxs
146
154
  };
147
- }, 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"]} */");
155
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchResult.tsx"],"names":[],"mappings":"AAqI+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  \"&:hover\": {\n    [`> span`]: {\n      textDecoration: \"underline\",\n      // this value controls text and its underline color\n      color: theme.values.color.text.primary.default,\n    },\n  },\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      // this value controls the bolt point color\n      color: theme.values.color.text.tertiary.default,\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"]} */");
148
156
  function SearchResult(_ref8) {
149
157
  let {
150
158
  title,