@amboss/design-system 1.15.4 → 1.16.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (29) hide show
  1. package/build/cjs/scss/themes/dark.scss +1 -1
  2. package/build/cjs/scss/themes/light.scss +1 -1
  3. package/build/cjs/src/components/Card/Card.js +5 -35
  4. package/build/cjs/src/components/Container/Container.js +23 -7
  5. package/build/cjs/src/components/SearchResult/SearchResult.js +101 -62
  6. package/build/cjs/src/components/Tag/Tag.js +6 -4
  7. package/build/cjs/src/components/TagGroup/TagGroup.js +118 -0
  8. package/build/cjs/src/index.js +3 -0
  9. package/build/esm/build-tokens/_sizes.json +1 -1
  10. package/build/esm/scss/themes/dark.scss +1 -1
  11. package/build/esm/scss/themes/light.scss +1 -1
  12. package/build/esm/src/components/Card/Card.js +5 -34
  13. package/build/esm/src/components/Card/Card.js.map +1 -1
  14. package/build/esm/src/components/Container/Container.d.ts +4 -1
  15. package/build/esm/src/components/Container/Container.js +23 -7
  16. package/build/esm/src/components/Container/Container.js.map +1 -1
  17. package/build/esm/src/components/SearchResult/SearchResult.d.ts +0 -4
  18. package/build/esm/src/components/SearchResult/SearchResult.js +101 -62
  19. package/build/esm/src/components/SearchResult/SearchResult.js.map +1 -1
  20. package/build/esm/src/components/Tag/Tag.d.ts +1 -0
  21. package/build/esm/src/components/Tag/Tag.js +6 -5
  22. package/build/esm/src/components/Tag/Tag.js.map +1 -1
  23. package/build/esm/src/components/TagGroup/TagGroup.d.ts +17 -0
  24. package/build/esm/src/components/TagGroup/TagGroup.js +112 -0
  25. package/build/esm/src/components/TagGroup/TagGroup.js.map +1 -0
  26. package/build/esm/src/index.d.ts +1 -0
  27. package/build/esm/src/index.js +2 -1
  28. package/build/esm/src/index.js.map +1 -1
  29. package/package.json +1 -1
@@ -1,6 +1,6 @@
1
1
 
2
2
  // Do not edit directly
3
- // Generated on Wed, 20 Sep 2023 13:11:41 GMT
3
+ // Generated on Mon, 25 Sep 2023 19:07:33 GMT
4
4
 
5
5
  $dark-color-canvas: #1e2125;
6
6
  $dark-color-background-primary-default: #24282d;
@@ -1,6 +1,6 @@
1
1
 
2
2
  // Do not edit directly
3
- // Generated on Wed, 20 Sep 2023 13:11:41 GMT
3
+ // Generated on Mon, 25 Sep 2023 19:07:33 GMT
4
4
 
5
5
  $light-color-canvas: #eef2f5;
6
6
  $light-color-background-primary-default: #ffffff;
@@ -1,46 +1,15 @@
1
1
  'use strict';
2
2
 
3
- var _styled = require('@emotion/styled/base');
4
3
  var React = require('react');
5
4
  var CardHeader = require('./CardHeader/CardHeader.js');
6
5
  var informDeprecation = require('../../shared/informDeprecation.js');
6
+ var Container = require('../Container/Container.js');
7
7
 
8
8
  function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
9
9
 
10
- var _styled__default = /*#__PURE__*/_interopDefault(_styled);
11
10
  var React__default = /*#__PURE__*/_interopDefault(React);
12
11
 
13
- const StyledContainer = /*#__PURE__*/_styled__default.default("div", process.env.NODE_ENV === "production" ? {
14
- target: "eieabd00"
15
- } : {
16
- target: "eieabd00",
17
- label: "StyledContainer"
18
- })(_ref => {
19
- let {
20
- theme,
21
- overflow,
22
- squareCorners
23
- } = _ref;
24
- return {
25
- ...(squareCorners ? {
26
- borderRadius: 0
27
- } : {
28
- borderRadius: theme.variables.size.borderRadius.card.m,
29
- "& > *:last-child": {
30
- borderBottomLeftRadius: theme.variables.size.borderRadius.card.m,
31
- borderBottomRightRadius: theme.variables.size.borderRadius.card.m
32
- },
33
- "& > *:first-child": {
34
- borderTopLeftRadius: theme.variables.size.borderRadius.card.m,
35
- borderTopRightRadius: theme.variables.size.borderRadius.card.m
36
- }
37
- }),
38
- boxShadow: theme.variables.shadow.card.a,
39
- backgroundColor: theme.values.color.background.primary.default,
40
- overflow
41
- };
42
- }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNhcmQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTJCd0IiLCJmaWxlIjoiQ2FyZC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IENhcmRIZWFkZXIgfSBmcm9tIFwiLi9DYXJkSGVhZGVyL0NhcmRIZWFkZXJcIjtcbmltcG9ydCB7IGluZm9ybURlcHJlY2F0aW9uIH0gZnJvbSBcIi4uLy4uL3NoYXJlZC9pbmZvcm1EZXByZWNhdGlvblwiO1xuaW1wb3J0IHsgRHJvcGRvd25NZW51UHJvcHMgfSBmcm9tIFwiLi4vRHJvcGRvd25NZW51L0Ryb3Bkb3duTWVudVwiO1xuXG5leHBvcnQgdHlwZSBDYXJkUHJvcHMgPSB7XG4gIC8qKiBTcGVjaWZ5IHRpdGxlIGRpc3BsYXllZCBpbiBIZWFkZXIgKi9cbiAgdGl0bGU/OiBzdHJpbmc7XG5cbiAgLyoqIEBkZXByZWNhdGVkIFN1YnRpdGxlIGlzIG5vdyBkZXByZWNhdGVkICovXG4gIHN1YnRpdGxlPzogc3RyaW5nO1xuXG4gIC8qKiBAZGVwcmVjYXRlZCBidXR0b24gcHJvcGVydHkgaXMgZGVwcmVjYXRlZCBub3cuIFBsZWFzZSB1c2UgZHJvcGRvd24gcHJvcC4gKi9cbiAgYnV0dG9uPzogUmVhY3QuUmVhY3RFbGVtZW50O1xuXG4gIGRyb3Bkb3duPzogT21pdDxEcm9wZG93bk1lbnVQcm9wcywgXCJpY29uTmFtZVwiIHwgXCJzaXplXCI+O1xuXG4gIG92ZXJmbG93PzogXCJhdXRvXCIgfCBcImhpZGRlblwiIHwgXCJ2aXNpYmxlXCI7XG5cbiAgc3F1YXJlQ29ybmVycz86IGJvb2xlYW47XG5cbiAgY2hpbGRyZW4/OiBSZWFjdC5SZWFjdE5vZGU7XG5cbiAgXCJkYXRhLWUyZS10ZXN0LWlkXCI/OiBzdHJpbmc7XG59O1xuXG5jb25zdCBTdHlsZWRDb250YWluZXIgPSBzdHlsZWQuZGl2PFBhcnRpYWw8Q2FyZFByb3BzPj4oXG4gICh7IHRoZW1lLCBvdmVyZmxvdywgc3F1YXJlQ29ybmVycyB9KSA9PiAoe1xuICAgIC4uLihzcXVhcmVDb3JuZXJzXG4gICAgICA/IHtcbiAgICAgICAgICBib3JkZXJSYWRpdXM6IDAsXG4gICAgICAgIH1cbiAgICAgIDoge1xuICAgICAgICAgIGJvcmRlclJhZGl1czogdGhlbWUudmFyaWFibGVzLnNpemUuYm9yZGVyUmFkaXVzLmNhcmQubSxcbiAgICAgICAgICBcIiYgPiAqOmxhc3QtY2hpbGRcIjoge1xuICAgICAgICAgICAgYm9yZGVyQm90dG9tTGVmdFJhZGl1czogdGhlbWUudmFyaWFibGVzLnNpemUuYm9yZGVyUmFkaXVzLmNhcmQubSxcbiAgICAgICAgICAgIGJvcmRlckJvdHRvbVJpZ2h0UmFkaXVzOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5ib3JkZXJSYWRpdXMuY2FyZC5tLFxuICAgICAgICAgIH0sXG4gICAgICAgICAgXCImID4gKjpmaXJzdC1jaGlsZFwiOiB7XG4gICAgICAgICAgICBib3JkZXJUb3BMZWZ0UmFkaXVzOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5ib3JkZXJSYWRpdXMuY2FyZC5tLFxuICAgICAgICAgICAgYm9yZGVyVG9wUmlnaHRSYWRpdXM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmJvcmRlclJhZGl1cy5jYXJkLm0sXG4gICAgICAgICAgfSxcbiAgICAgICAgfSksXG4gICAgYm94U2hhZG93OiB0aGVtZS52YXJpYWJsZXMuc2hhZG93LmNhcmQuYSxcbiAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnByaW1hcnkuZGVmYXVsdCxcbiAgICBvdmVyZmxvdyxcbiAgfSlcbik7XG5cbmV4cG9ydCBmdW5jdGlvbiBDYXJkKHtcbiAgdGl0bGUsXG4gIHN1YnRpdGxlLFxuICBidXR0b24sXG4gIGRyb3Bkb3duLFxuICBjaGlsZHJlbixcbiAgb3ZlcmZsb3cgPSBcImhpZGRlblwiLFxuICBzcXVhcmVDb3JuZXJzID0gZmFsc2UsXG4gIFwiZGF0YS1lMmUtdGVzdC1pZFwiOiBkYXRhRTJlVGVzdElkLFxufTogQ2FyZFByb3BzKTogUmVhY3QuUmVhY3RFbGVtZW50IHtcbiAgaW5mb3JtRGVwcmVjYXRpb24oXG4gICAgc3VidGl0bGUsXG4gICAgc3VidGl0bGUsXG4gICAgXCJDYXJkXCIsXG4gICAgXCJTdWJ0aXRsZSBpcyBub3cgYSBkZXByaWNhdGVkIHByb3AsIHBsZWFzZSBkaXNjdXNzIGEgd29ya2Fyb3VuZCB3aXRoIGFueSBvZiBVWCBkZXNpZ25lcnNcIlxuICApO1xuXG4gIGluZm9ybURlcHJlY2F0aW9uKFxuICAgIGJ1dHRvbixcbiAgICBidXR0b24sXG4gICAgXCJDYXJkXCIsXG4gICAgXCJCdXR0b24gaXMgZGVwcmVjYXRlZCwgcGxlYXNlIHVzZSBkcm9wZG93biBwcm9wZXJ0eSBpbnN0ZWFkXCJcbiAgKTtcblxuICByZXR1cm4gKFxuICAgIDxTdHlsZWRDb250YWluZXJcbiAgICAgIGRhdGEtZTJlLXRlc3QtaWQ9e2RhdGFFMmVUZXN0SWR9XG4gICAgICBkYXRhLWRzLWlkPVwiQ2FyZFwiXG4gICAgICBvdmVyZmxvdz17b3ZlcmZsb3d9XG4gICAgICBzcXVhcmVDb3JuZXJzPXtzcXVhcmVDb3JuZXJzfVxuICAgID5cbiAgICAgIHsoYnV0dG9uIHx8IGRyb3Bkb3duIHx8IHN1YnRpdGxlIHx8IHRpdGxlKSAmJiAoXG4gICAgICAgIDxDYXJkSGVhZGVyXG4gICAgICAgICAgdGl0bGU9e3RpdGxlfVxuICAgICAgICAgIHN1YnRpdGxlPXtzdWJ0aXRsZX1cbiAgICAgICAgICBidXR0b249e2J1dHRvbn1cbiAgICAgICAgICBkcm9wZG93bj17ZHJvcGRvd259XG4gICAgICAgIC8+XG4gICAgICApfVxuICAgICAge2NoaWxkcmVufVxuICAgIDwvU3R5bGVkQ29udGFpbmVyPlxuICApO1xufVxuIl19 */");
43
- function Card(_ref2) {
12
+ function Card(_ref) {
44
13
  let {
45
14
  title,
46
15
  subtitle,
@@ -50,10 +19,11 @@ function Card(_ref2) {
50
19
  overflow = "hidden",
51
20
  squareCorners = false,
52
21
  "data-e2e-test-id": dataE2eTestId
53
- } = _ref2;
22
+ } = _ref;
54
23
  informDeprecation.informDeprecation(subtitle, subtitle, "Card", "Subtitle is now a depricated prop, please discuss a workaround with any of UX designers");
55
24
  informDeprecation.informDeprecation(button, button, "Card", "Button is deprecated, please use dropdown property instead");
56
- return /*#__PURE__*/React__default.default.createElement(StyledContainer, {
25
+ return /*#__PURE__*/React__default.default.createElement(Container.Container, {
26
+ elevation: 1,
57
27
  "data-e2e-test-id": dataE2eTestId,
58
28
  "data-ds-id": "Card",
59
29
  overflow: overflow,
@@ -34,29 +34,45 @@ const StyledContainer = /*#__PURE__*/_styled__default.default("div", process.env
34
34
  theme,
35
35
  elevation,
36
36
  borderRadius,
37
- overflow
37
+ overflow,
38
+ squareCorners
38
39
  } = _ref;
39
40
  return {
40
41
  boxShadow: handleElevationLevel(theme, elevation),
41
- borderRadius: theme.variables.size.borderRadius[borderRadius],
42
42
  backgroundColor: theme.values.color.background.primary.default,
43
- overflow
43
+ overflow,
44
+ ...(squareCorners ? {
45
+ borderRadius: 0
46
+ } : {
47
+ borderRadius: theme.variables.size.borderRadius[borderRadius],
48
+ "& > *:last-child": {
49
+ borderBottomLeftRadius: theme.variables.size.borderRadius[borderRadius],
50
+ borderBottomRightRadius: theme.variables.size.borderRadius[borderRadius]
51
+ },
52
+ "& > *:first-child": {
53
+ borderTopLeftRadius: theme.variables.size.borderRadius[borderRadius],
54
+ borderTopRightRadius: theme.variables.size.borderRadius[borderRadius]
55
+ }
56
+ })
44
57
  };
45
- }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBK0J3QiIsImZpbGUiOiJDb250YWluZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgeyBUaGVtZSB9IGZyb20gXCJAZW1vdGlvbi9yZWFjdFwiO1xuaW1wb3J0IHsgQm9yZGVyUmFkaXVzIH0gZnJvbSBcInNyYy90eXBlc1wiO1xuXG5leHBvcnQgdHlwZSBDb250YWluZXJQcm9wcyA9IHtcbiAgLyoqIDAgLSBiYXNlLCAxIC0gQ2FyZCwgMiAtIFRvb2x0aXBzLCAzIC0gRHJvcGRvd25zLCA0IC0gTW9kYWxzICovXG4gIGVsZXZhdGlvbjogMCB8IDEgfCAyIHwgMyB8IDQ7XG4gIGJvcmRlclJhZGl1cz86IEJvcmRlclJhZGl1cztcbiAgb3ZlcmZsb3c/OiBcImF1dG9cIiB8IFwiaGlkZGVuXCIgfCBcInZpc2libGVcIjtcbiAgY2hpbGRyZW4/OiBSZWFjdC5SZWFjdE5vZGU7XG4gIFwiZGF0YS1lMmUtdGVzdC1pZFwiPzogc3RyaW5nO1xufTtcblxuY29uc3QgaGFuZGxlRWxldmF0aW9uTGV2ZWwgPSAodGhlbWU6IFRoZW1lLCBlbGV2YXRpb246IG51bWJlcikgPT4ge1xuICAvKiBQYXJzaW5nIGVsZXZhdGlvbiBwcm9wZXJ0eSB0byBudW1iZXIgKi9cbiAgc3dpdGNoIChlbGV2YXRpb24gLSAwKSB7XG4gICAgY2FzZSAxOlxuICAgICAgcmV0dXJuIHRoZW1lLnZhcmlhYmxlcy5zaGFkb3cuY2FyZC5hO1xuICAgIGNhc2UgMjpcbiAgICAgIHJldHVybiB0aGVtZS52YXJpYWJsZXMuc2hhZG93LmNhcmQuYjtcbiAgICBjYXNlIDM6XG4gICAgICByZXR1cm4gdGhlbWUudmFyaWFibGVzLnNoYWRvdy5jYXJkLmM7XG4gICAgY2FzZSA0OlxuICAgICAgcmV0dXJuIHRoZW1lLnZhcmlhYmxlcy5zaGFkb3cuY2FyZC5kO1xuICAgIGNhc2UgMDpcbiAgICBkZWZhdWx0OlxuICAgICAgcmV0dXJuIFwiXCI7XG4gIH1cbn07XG5cbmNvbnN0IFN0eWxlZENvbnRhaW5lciA9IHN0eWxlZC5kaXY8UGFydGlhbDxDb250YWluZXJQcm9wcz4+KFxuICAoeyB0aGVtZSwgZWxldmF0aW9uLCBib3JkZXJSYWRpdXMsIG92ZXJmbG93IH0pID0+ICh7XG4gICAgYm94U2hhZG93OiBoYW5kbGVFbGV2YXRpb25MZXZlbCh0aGVtZSwgZWxldmF0aW9uKSxcbiAgICBib3JkZXJSYWRpdXM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmJvcmRlclJhZGl1c1tib3JkZXJSYWRpdXNdLFxuICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQucHJpbWFyeS5kZWZhdWx0LFxuICAgIG92ZXJmbG93LFxuICB9KVxuKTtcblxuZXhwb3J0IGZ1bmN0aW9uIENvbnRhaW5lcih7XG4gIGNoaWxkcmVuLFxuICBlbGV2YXRpb24gPSAxLFxuICBib3JkZXJSYWRpdXMgPSBcIm1cIixcbiAgb3ZlcmZsb3csXG4gIFwiZGF0YS1lMmUtdGVzdC1pZFwiOiBkYXRhRTJlVGVzdElkLFxufTogQ29udGFpbmVyUHJvcHMpOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICByZXR1cm4gKFxuICAgIDxTdHlsZWRDb250YWluZXJcbiAgICAgIGRhdGEtZTJlLXRlc3QtaWQ9e2RhdGFFMmVUZXN0SWR9XG4gICAgICBkYXRhLWRzLWlkPVwiQ29udGFpbmVyXCJcbiAgICAgIGVsZXZhdGlvbj17ZWxldmF0aW9ufVxuICAgICAgYm9yZGVyUmFkaXVzPXtib3JkZXJSYWRpdXN9XG4gICAgICBvdmVyZmxvdz17b3ZlcmZsb3d9XG4gICAgPlxuICAgICAge2NoaWxkcmVufVxuICAgIDwvU3R5bGVkQ29udGFpbmVyPlxuICApO1xufVxuIl19 */");
58
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBa0N3QiIsImZpbGUiOiJDb250YWluZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgeyBUaGVtZSB9IGZyb20gXCJAZW1vdGlvbi9yZWFjdFwiO1xuaW1wb3J0IHsgQm9yZGVyUmFkaXVzIH0gZnJvbSBcInNyYy90eXBlc1wiO1xuXG5leHBvcnQgdHlwZSBDb250YWluZXJQcm9wcyA9IHtcbiAgLyoqIDAgLSBiYXNlLCAxIC0gQ2FyZCwgMiAtIFRvb2x0aXBzLCAzIC0gRHJvcGRvd25zLCA0IC0gTW9kYWxzICovXG4gIGVsZXZhdGlvbjogMCB8IDEgfCAyIHwgMyB8IDQ7XG4gIGJvcmRlclJhZGl1cz86IEJvcmRlclJhZGl1cztcbiAgb3ZlcmZsb3c/OiBcImF1dG9cIiB8IFwiaGlkZGVuXCIgfCBcInZpc2libGVcIjtcbiAgY2hpbGRyZW4/OiBSZWFjdC5SZWFjdE5vZGU7XG4gIHNxdWFyZUNvcm5lcnM/OiBib29sZWFuO1xuICBcImRhdGEtZTJlLXRlc3QtaWRcIj86IHN0cmluZztcbiAgLyoqIEBpZ25vcmUgKi9cbiAgXCJkYXRhLWRzLWlkXCI/OiBzdHJpbmc7XG59O1xuXG5jb25zdCBoYW5kbGVFbGV2YXRpb25MZXZlbCA9ICh0aGVtZTogVGhlbWUsIGVsZXZhdGlvbjogbnVtYmVyKSA9PiB7XG4gIC8qIFBhcnNpbmcgZWxldmF0aW9uIHByb3BlcnR5IHRvIG51bWJlciAqL1xuICBzd2l0Y2ggKGVsZXZhdGlvbiAtIDApIHtcbiAgICBjYXNlIDE6XG4gICAgICByZXR1cm4gdGhlbWUudmFyaWFibGVzLnNoYWRvdy5jYXJkLmE7XG4gICAgY2FzZSAyOlxuICAgICAgcmV0dXJuIHRoZW1lLnZhcmlhYmxlcy5zaGFkb3cuY2FyZC5iO1xuICAgIGNhc2UgMzpcbiAgICAgIHJldHVybiB0aGVtZS52YXJpYWJsZXMuc2hhZG93LmNhcmQuYztcbiAgICBjYXNlIDQ6XG4gICAgICByZXR1cm4gdGhlbWUudmFyaWFibGVzLnNoYWRvdy5jYXJkLmQ7XG4gICAgY2FzZSAwOlxuICAgIGRlZmF1bHQ6XG4gICAgICByZXR1cm4gXCJcIjtcbiAgfVxufTtcblxuY29uc3QgU3R5bGVkQ29udGFpbmVyID0gc3R5bGVkLmRpdjxQYXJ0aWFsPENvbnRhaW5lclByb3BzPj4oXG4gICh7IHRoZW1lLCBlbGV2YXRpb24sIGJvcmRlclJhZGl1cywgb3ZlcmZsb3csIHNxdWFyZUNvcm5lcnMgfSkgPT4gKHtcbiAgICBib3hTaGFkb3c6IGhhbmRsZUVsZXZhdGlvbkxldmVsKHRoZW1lLCBlbGV2YXRpb24pLFxuICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQucHJpbWFyeS5kZWZhdWx0LFxuICAgIG92ZXJmbG93LFxuXG4gICAgLi4uKHNxdWFyZUNvcm5lcnNcbiAgICAgID8ge1xuICAgICAgICAgIGJvcmRlclJhZGl1czogMCxcbiAgICAgICAgfVxuICAgICAgOiB7XG4gICAgICAgICAgYm9yZGVyUmFkaXVzOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5ib3JkZXJSYWRpdXNbYm9yZGVyUmFkaXVzXSxcbiAgICAgICAgICBcIiYgPiAqOmxhc3QtY2hpbGRcIjoge1xuICAgICAgICAgICAgYm9yZGVyQm90dG9tTGVmdFJhZGl1czpcbiAgICAgICAgICAgICAgdGhlbWUudmFyaWFibGVzLnNpemUuYm9yZGVyUmFkaXVzW2JvcmRlclJhZGl1c10sXG4gICAgICAgICAgICBib3JkZXJCb3R0b21SaWdodFJhZGl1czpcbiAgICAgICAgICAgICAgdGhlbWUudmFyaWFibGVzLnNpemUuYm9yZGVyUmFkaXVzW2JvcmRlclJhZGl1c10sXG4gICAgICAgICAgfSxcbiAgICAgICAgICBcIiYgPiAqOmZpcnN0LWNoaWxkXCI6IHtcbiAgICAgICAgICAgIGJvcmRlclRvcExlZnRSYWRpdXM6XG4gICAgICAgICAgICAgIHRoZW1lLnZhcmlhYmxlcy5zaXplLmJvcmRlclJhZGl1c1tib3JkZXJSYWRpdXNdLFxuICAgICAgICAgICAgYm9yZGVyVG9wUmlnaHRSYWRpdXM6XG4gICAgICAgICAgICAgIHRoZW1lLnZhcmlhYmxlcy5zaXplLmJvcmRlclJhZGl1c1tib3JkZXJSYWRpdXNdLFxuICAgICAgICAgIH0sXG4gICAgICAgIH0pLFxuICB9KVxuKTtcblxuZXhwb3J0IGZ1bmN0aW9uIENvbnRhaW5lcih7XG4gIGNoaWxkcmVuLFxuICBlbGV2YXRpb24gPSAxLFxuICBib3JkZXJSYWRpdXMgPSBcIm1cIixcbiAgb3ZlcmZsb3csXG4gIHNxdWFyZUNvcm5lcnMgPSBmYWxzZSxcbiAgXCJkYXRhLWUyZS10ZXN0LWlkXCI6IGRhdGFFMmVUZXN0SWQsXG4gIFwiZGF0YS1kcy1pZFwiOiBkYXRhRHNJZCA9IFwiQ29udGFpbmVyXCIsXG59OiBDb250YWluZXJQcm9wcyk6IFJlYWN0LlJlYWN0RWxlbWVudCB7XG4gIHJldHVybiAoXG4gICAgPFN0eWxlZENvbnRhaW5lclxuICAgICAgZGF0YS1lMmUtdGVzdC1pZD17ZGF0YUUyZVRlc3RJZH1cbiAgICAgIGRhdGEtZHMtaWQ9e2RhdGFEc0lkfVxuICAgICAgZWxldmF0aW9uPXtlbGV2YXRpb259XG4gICAgICBib3JkZXJSYWRpdXM9e2JvcmRlclJhZGl1c31cbiAgICAgIG92ZXJmbG93PXtvdmVyZmxvd31cbiAgICAgIHNxdWFyZUNvcm5lcnM9e3NxdWFyZUNvcm5lcnN9XG4gICAgPlxuICAgICAge2NoaWxkcmVufVxuICAgIDwvU3R5bGVkQ29udGFpbmVyPlxuICApO1xufVxuIl19 */");
46
59
  function Container(_ref2) {
47
60
  let {
48
61
  children,
49
62
  elevation = 1,
50
63
  borderRadius = "m",
51
64
  overflow,
52
- "data-e2e-test-id": dataE2eTestId
65
+ squareCorners = false,
66
+ "data-e2e-test-id": dataE2eTestId,
67
+ "data-ds-id": dataDsId = "Container"
53
68
  } = _ref2;
54
69
  return /*#__PURE__*/React__default.default.createElement(StyledContainer, {
55
70
  "data-e2e-test-id": dataE2eTestId,
56
- "data-ds-id": "Container",
71
+ "data-ds-id": dataDsId,
57
72
  elevation: elevation,
58
73
  borderRadius: borderRadius,
59
- overflow: overflow
74
+ overflow: overflow,
75
+ squareCorners: squareCorners
60
76
  }, children);
61
77
  }
62
78
 
@@ -9,6 +9,7 @@ var Stack = require('../Stack/Stack.js');
9
9
  var StyledText = require('../Typography/StyledText/StyledText.js');
10
10
  var Badge = require('../Badge/Badge.js');
11
11
  var TextClamped = require('../Typography/TextClamped/TextClamped.js');
12
+ var Text = require('../Typography/Text/Text.js');
12
13
 
13
14
  function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
14
15
 
@@ -16,18 +17,18 @@ var _styled__default = /*#__PURE__*/_interopDefault(_styled);
16
17
  var React__default = /*#__PURE__*/_interopDefault(React);
17
18
 
18
19
  const StyledResultContainer = /*#__PURE__*/_styled__default.default("div", process.env.NODE_ENV === "production" ? {
19
- target: "e1y5sw0i2"
20
+ target: "e1y5sw0i5"
20
21
  } : {
21
- target: "e1y5sw0i2",
22
+ target: "e1y5sw0i5",
22
23
  label: "StyledResultContainer"
23
24
  })(() => ({
24
25
  position: "relative",
25
26
  textDecoration: "none"
26
- }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchResult.tsx"],"names":[],"mappings":"AAuB8B","file":"SearchResult.tsx","sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Columns, Column } from \"../Column/Columns\";\nimport { Icon, IconName } from \"../Icon/Icon\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Stack } from \"../Stack/Stack\";\nimport { StyledText } from \"../Typography/StyledText/StyledText\";\nimport { Badge } from \"../Badge/Badge\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\n\nexport type SecondaryTarget = {\n  title: string;\n  body?: string;\n  link: (props: { children: React.ReactNode }) => React.ReactElement;\n  \"data-e2e-test-id\"?: string;\n};\n\nexport type SecondaryTargetsProps = {\n  data: SecondaryTarget[];\n  renderItem: (item: SecondaryTarget) => React.ReactElement;\n  compact?: boolean;\n};\n\nconst StyledResultContainer = styled.div(() => ({\n  position: \"relative\",\n  textDecoration: \"none\",\n}));\n\nconst StyledLinkTitle = styled.div(({ theme }) => ({\n  color: theme.values.color.text.accent.default,\n}));\n\nconst StyledLinkContainerOnHover = styled.div(({ theme }) => ({\n  \"> a\": {\n    textDecoration: \"none\",\n    color: theme.values.color.text.accent.default,\n  },\n  \"&:hover\": {\n    [`${StyledLinkTitle}`]: {\n      textDecoration: \"underline\",\n    },\n  },\n}));\n\nconst SecondaryTargets = ({\n  data,\n  renderItem,\n  compact,\n}: SecondaryTargetsProps) =>\n  compact ? (\n    <Inline space=\"l\" vSpace=\"xs\">\n      {data && data.length && data.map((target) => renderItem(target))}\n    </Inline>\n  ) : (\n    <Columns gap=\"m\">\n      {data.map((target) => (\n        <Column\n          data-e2e-test-id={target[\"data-e2e-test-id\"]}\n          size={[12, 6, 6]}\n          key={target.title}\n        >\n          {renderItem(target)}\n        </Column>\n      ))}\n    </Columns>\n  );\n\nexport type SearchResultProps = {\n  /** The result title. Supports some nested HTML tags like <b> and <i>. Text gets clamped after 3 lines. */\n  title: string;\n  /** The subtitle that accompanies the title. Supports some nested HTML tags like <b> and <i>. Text gets clamped after 3 lines. */\n  subtitle?: string;\n  /** The primary AMBOSS target. */\n  link: (props: { children: React.ReactNode }) => React.ReactElement;\n  /** The left icon */\n  icon?: IconName;\n  /** List of details. Supports some nested HTML tags like <b> and <i>. */\n  details?: string[];\n  /** Usually a text content of the search result. Supports some nested HTML tags like <b> and <i>. Maximum 3 details items allowed where each test gets clamped after 3 lines. */\n  body?: string;\n  /** List of secondary AMBOSS targets with titles. Text gets clamped after 3 lines. */\n  secondaryTargets?: SecondaryTarget[];\n  /** Indicate an external link */\n  isExternal?: boolean;\n  /** List of labels. For example: preclinic, clinic, physician. */\n  labels?: string[];\n  /** The test id for the result's primary target. */\n  \"data-e2e-test-id\"?: string;\n};\n\nconst defaultProps: Partial<SearchResultProps> = {\n  icon: null,\n  details: [],\n  body: null,\n  secondaryTargets: [],\n  isExternal: false,\n  labels: [],\n  \"data-e2e-test-id\": undefined,\n};\n\nexport function SearchResult({\n  title,\n  subtitle,\n  icon,\n  details,\n  body,\n  secondaryTargets,\n  link,\n  labels,\n  \"data-e2e-test-id\": dataE2eTestId,\n}: SearchResultProps): React.ReactElement {\n  const containerRef = useRef(null);\n  const hasShallowSecondaryTargets =\n    secondaryTargets &&\n    secondaryTargets.reduce((prev, curr) => (curr.body ? false : prev), true);\n  const MainLink = link;\n\n  return (\n    <StyledResultContainer ref={containerRef} data-ds-id=\"SearchResult\">\n      <Columns gap=\"m\">\n        {icon && (\n          <Column size=\"narrow\">\n            <Icon name={icon} color=\"tertiary\" />\n          </Column>\n        )}\n        <Column size=\"fill\">\n          <Stack space=\"s\">\n            <StyledLinkContainerOnHover data-e2e-test-id={dataE2eTestId}>\n              <MainLink>\n                <Stack space=\"xxs\">\n                  <Columns gap=\"xxs\">\n                    <Column size={[12, 12, \"fill\"]}>\n                      <StyledLinkTitle>\n                        <Stack space=\"zero\">\n                          <TextClamped\n                            color=\"accent\"\n                            weight=\"bold\"\n                            lines={3}\n                            hyphens=\"auto\"\n                          >\n                            <StyledText>{title}</StyledText>\n                          </TextClamped>\n                          {subtitle && (\n                            <TextClamped color=\"accent\" lines={3} size=\"s\">\n                              <StyledText>{subtitle}</StyledText>\n                            </TextClamped>\n                          )}\n                        </Stack>\n                      </StyledLinkTitle>\n                    </Column>\n                    <Column size=\"narrow\">\n                      {labels && !!labels.length && (\n                        <Inline space=\"xs\">\n                          {labels.map((label, i) => (\n                            // eslint-disable-next-line react/no-array-index-key\n                            <Badge text={label} key={`${i}${label}`} />\n                          ))}\n                        </Inline>\n                      )}\n                    </Column>\n                  </Columns>\n                  {details && !!details.length && (\n                    <Stack space=\"zero\">\n                      {details.slice(0, 3).map((detail) => (\n                        <TextClamped\n                          color=\"primary\"\n                          size=\"s\"\n                          key={detail}\n                          lines={3}\n                        >\n                          <StyledText>{detail}</StyledText>\n                        </TextClamped>\n                      ))}\n                    </Stack>\n                  )}\n                  {body && (\n                    <TextClamped size=\"s\" lines={2}>\n                      <StyledText>{body}</StyledText>\n                    </TextClamped>\n                  )}\n                </Stack>\n              </MainLink>\n            </StyledLinkContainerOnHover>\n            {secondaryTargets && !!secondaryTargets.length && (\n              <SecondaryTargets\n                data={secondaryTargets}\n                compact={hasShallowSecondaryTargets}\n                renderItem={({\n                  title: secTitle,\n                  link: secLink,\n                  body: secBody,\n                  \"data-e2e-test-id\": secDataE2eTestId,\n                }) => {\n                  const SecLink = secLink;\n                  return (\n                    <StyledLinkContainerOnHover\n                      key={title}\n                      data-e2e-test-id={secDataE2eTestId}\n                    >\n                      <SecLink>\n                        <StyledLinkTitle>\n                          <TextClamped\n                            size=\"s\"\n                            color=\"accent\"\n                            weight=\"bold\"\n                            lines={3}\n                          >\n                            <StyledText>{secTitle}</StyledText>\n                          </TextClamped>\n                        </StyledLinkTitle>\n                        {secBody && (\n                          <TextClamped size=\"s\" color=\"primary\" lines={2}>\n                            <StyledText>{secBody}</StyledText>\n                          </TextClamped>\n                        )}\n                      </SecLink>\n                    </StyledLinkContainerOnHover>\n                  );\n                }}\n              />\n            )}\n          </Stack>\n        </Column>\n      </Columns>\n    </StyledResultContainer>\n  );\n}\n\nSearchResult.defaultProps = defaultProps;\n"]} */");
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
28
  const StyledLinkTitle = /*#__PURE__*/_styled__default.default("div", process.env.NODE_ENV === "production" ? {
28
- target: "e1y5sw0i1"
29
+ target: "e1y5sw0i4"
29
30
  } : {
30
- target: "e1y5sw0i1",
31
+ target: "e1y5sw0i4",
31
32
  label: "StyledLinkTitle"
32
33
  })(_ref => {
33
34
  let {
@@ -36,11 +37,11 @@ const StyledLinkTitle = /*#__PURE__*/_styled__default.default("div", process.env
36
37
  return {
37
38
  color: theme.values.color.text.accent.default
38
39
  };
39
- }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchResult.tsx"],"names":[],"mappings":"AA4BwB","file":"SearchResult.tsx","sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Columns, Column } from \"../Column/Columns\";\nimport { Icon, IconName } from \"../Icon/Icon\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Stack } from \"../Stack/Stack\";\nimport { StyledText } from \"../Typography/StyledText/StyledText\";\nimport { Badge } from \"../Badge/Badge\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\n\nexport type SecondaryTarget = {\n  title: string;\n  body?: string;\n  link: (props: { children: React.ReactNode }) => React.ReactElement;\n  \"data-e2e-test-id\"?: string;\n};\n\nexport type SecondaryTargetsProps = {\n  data: SecondaryTarget[];\n  renderItem: (item: SecondaryTarget) => React.ReactElement;\n  compact?: boolean;\n};\n\nconst StyledResultContainer = styled.div(() => ({\n  position: \"relative\",\n  textDecoration: \"none\",\n}));\n\nconst StyledLinkTitle = styled.div(({ theme }) => ({\n  color: theme.values.color.text.accent.default,\n}));\n\nconst StyledLinkContainerOnHover = styled.div(({ theme }) => ({\n  \"> a\": {\n    textDecoration: \"none\",\n    color: theme.values.color.text.accent.default,\n  },\n  \"&:hover\": {\n    [`${StyledLinkTitle}`]: {\n      textDecoration: \"underline\",\n    },\n  },\n}));\n\nconst SecondaryTargets = ({\n  data,\n  renderItem,\n  compact,\n}: SecondaryTargetsProps) =>\n  compact ? (\n    <Inline space=\"l\" vSpace=\"xs\">\n      {data && data.length && data.map((target) => renderItem(target))}\n    </Inline>\n  ) : (\n    <Columns gap=\"m\">\n      {data.map((target) => (\n        <Column\n          data-e2e-test-id={target[\"data-e2e-test-id\"]}\n          size={[12, 6, 6]}\n          key={target.title}\n        >\n          {renderItem(target)}\n        </Column>\n      ))}\n    </Columns>\n  );\n\nexport type SearchResultProps = {\n  /** The result title. Supports some nested HTML tags like <b> and <i>. Text gets clamped after 3 lines. */\n  title: string;\n  /** The subtitle that accompanies the title. Supports some nested HTML tags like <b> and <i>. Text gets clamped after 3 lines. */\n  subtitle?: string;\n  /** The primary AMBOSS target. */\n  link: (props: { children: React.ReactNode }) => React.ReactElement;\n  /** The left icon */\n  icon?: IconName;\n  /** List of details. Supports some nested HTML tags like <b> and <i>. */\n  details?: string[];\n  /** Usually a text content of the search result. Supports some nested HTML tags like <b> and <i>. Maximum 3 details items allowed where each test gets clamped after 3 lines. */\n  body?: string;\n  /** List of secondary AMBOSS targets with titles. Text gets clamped after 3 lines. */\n  secondaryTargets?: SecondaryTarget[];\n  /** Indicate an external link */\n  isExternal?: boolean;\n  /** List of labels. For example: preclinic, clinic, physician. */\n  labels?: string[];\n  /** The test id for the result's primary target. */\n  \"data-e2e-test-id\"?: string;\n};\n\nconst defaultProps: Partial<SearchResultProps> = {\n  icon: null,\n  details: [],\n  body: null,\n  secondaryTargets: [],\n  isExternal: false,\n  labels: [],\n  \"data-e2e-test-id\": undefined,\n};\n\nexport function SearchResult({\n  title,\n  subtitle,\n  icon,\n  details,\n  body,\n  secondaryTargets,\n  link,\n  labels,\n  \"data-e2e-test-id\": dataE2eTestId,\n}: SearchResultProps): React.ReactElement {\n  const containerRef = useRef(null);\n  const hasShallowSecondaryTargets =\n    secondaryTargets &&\n    secondaryTargets.reduce((prev, curr) => (curr.body ? false : prev), true);\n  const MainLink = link;\n\n  return (\n    <StyledResultContainer ref={containerRef} data-ds-id=\"SearchResult\">\n      <Columns gap=\"m\">\n        {icon && (\n          <Column size=\"narrow\">\n            <Icon name={icon} color=\"tertiary\" />\n          </Column>\n        )}\n        <Column size=\"fill\">\n          <Stack space=\"s\">\n            <StyledLinkContainerOnHover data-e2e-test-id={dataE2eTestId}>\n              <MainLink>\n                <Stack space=\"xxs\">\n                  <Columns gap=\"xxs\">\n                    <Column size={[12, 12, \"fill\"]}>\n                      <StyledLinkTitle>\n                        <Stack space=\"zero\">\n                          <TextClamped\n                            color=\"accent\"\n                            weight=\"bold\"\n                            lines={3}\n                            hyphens=\"auto\"\n                          >\n                            <StyledText>{title}</StyledText>\n                          </TextClamped>\n                          {subtitle && (\n                            <TextClamped color=\"accent\" lines={3} size=\"s\">\n                              <StyledText>{subtitle}</StyledText>\n                            </TextClamped>\n                          )}\n                        </Stack>\n                      </StyledLinkTitle>\n                    </Column>\n                    <Column size=\"narrow\">\n                      {labels && !!labels.length && (\n                        <Inline space=\"xs\">\n                          {labels.map((label, i) => (\n                            // eslint-disable-next-line react/no-array-index-key\n                            <Badge text={label} key={`${i}${label}`} />\n                          ))}\n                        </Inline>\n                      )}\n                    </Column>\n                  </Columns>\n                  {details && !!details.length && (\n                    <Stack space=\"zero\">\n                      {details.slice(0, 3).map((detail) => (\n                        <TextClamped\n                          color=\"primary\"\n                          size=\"s\"\n                          key={detail}\n                          lines={3}\n                        >\n                          <StyledText>{detail}</StyledText>\n                        </TextClamped>\n                      ))}\n                    </Stack>\n                  )}\n                  {body && (\n                    <TextClamped size=\"s\" lines={2}>\n                      <StyledText>{body}</StyledText>\n                    </TextClamped>\n                  )}\n                </Stack>\n              </MainLink>\n            </StyledLinkContainerOnHover>\n            {secondaryTargets && !!secondaryTargets.length && (\n              <SecondaryTargets\n                data={secondaryTargets}\n                compact={hasShallowSecondaryTargets}\n                renderItem={({\n                  title: secTitle,\n                  link: secLink,\n                  body: secBody,\n                  \"data-e2e-test-id\": secDataE2eTestId,\n                }) => {\n                  const SecLink = secLink;\n                  return (\n                    <StyledLinkContainerOnHover\n                      key={title}\n                      data-e2e-test-id={secDataE2eTestId}\n                    >\n                      <SecLink>\n                        <StyledLinkTitle>\n                          <TextClamped\n                            size=\"s\"\n                            color=\"accent\"\n                            weight=\"bold\"\n                            lines={3}\n                          >\n                            <StyledText>{secTitle}</StyledText>\n                          </TextClamped>\n                        </StyledLinkTitle>\n                        {secBody && (\n                          <TextClamped size=\"s\" color=\"primary\" lines={2}>\n                            <StyledText>{secBody}</StyledText>\n                          </TextClamped>\n                        )}\n                      </SecLink>\n                    </StyledLinkContainerOnHover>\n                  );\n                }}\n              />\n            )}\n          </Stack>\n        </Column>\n      </Columns>\n    </StyledResultContainer>\n  );\n}\n\nSearchResult.defaultProps = defaultProps;\n"]} */");
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
41
  const StyledLinkContainerOnHover = /*#__PURE__*/_styled__default.default("div", process.env.NODE_ENV === "production" ? {
41
- target: "e1y5sw0i0"
42
+ target: "e1y5sw0i3"
42
43
  } : {
43
- target: "e1y5sw0i0",
44
+ target: "e1y5sw0i3",
44
45
  label: "StyledLinkContainerOnHover"
45
46
  })(_ref2 => {
46
47
  let {
@@ -57,34 +58,94 @@ const StyledLinkContainerOnHover = /*#__PURE__*/_styled__default.default("div",
57
58
  }
58
59
  }
59
60
  };
60
- }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchResult.tsx"],"names":[],"mappings":"AAgCmC","file":"SearchResult.tsx","sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Columns, Column } from \"../Column/Columns\";\nimport { Icon, IconName } from \"../Icon/Icon\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Stack } from \"../Stack/Stack\";\nimport { StyledText } from \"../Typography/StyledText/StyledText\";\nimport { Badge } from \"../Badge/Badge\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\n\nexport type SecondaryTarget = {\n  title: string;\n  body?: string;\n  link: (props: { children: React.ReactNode }) => React.ReactElement;\n  \"data-e2e-test-id\"?: string;\n};\n\nexport type SecondaryTargetsProps = {\n  data: SecondaryTarget[];\n  renderItem: (item: SecondaryTarget) => React.ReactElement;\n  compact?: boolean;\n};\n\nconst StyledResultContainer = styled.div(() => ({\n  position: \"relative\",\n  textDecoration: \"none\",\n}));\n\nconst StyledLinkTitle = styled.div(({ theme }) => ({\n  color: theme.values.color.text.accent.default,\n}));\n\nconst StyledLinkContainerOnHover = styled.div(({ theme }) => ({\n  \"> a\": {\n    textDecoration: \"none\",\n    color: theme.values.color.text.accent.default,\n  },\n  \"&:hover\": {\n    [`${StyledLinkTitle}`]: {\n      textDecoration: \"underline\",\n    },\n  },\n}));\n\nconst SecondaryTargets = ({\n  data,\n  renderItem,\n  compact,\n}: SecondaryTargetsProps) =>\n  compact ? (\n    <Inline space=\"l\" vSpace=\"xs\">\n      {data && data.length && data.map((target) => renderItem(target))}\n    </Inline>\n  ) : (\n    <Columns gap=\"m\">\n      {data.map((target) => (\n        <Column\n          data-e2e-test-id={target[\"data-e2e-test-id\"]}\n          size={[12, 6, 6]}\n          key={target.title}\n        >\n          {renderItem(target)}\n        </Column>\n      ))}\n    </Columns>\n  );\n\nexport type SearchResultProps = {\n  /** The result title. Supports some nested HTML tags like <b> and <i>. Text gets clamped after 3 lines. */\n  title: string;\n  /** The subtitle that accompanies the title. Supports some nested HTML tags like <b> and <i>. Text gets clamped after 3 lines. */\n  subtitle?: string;\n  /** The primary AMBOSS target. */\n  link: (props: { children: React.ReactNode }) => React.ReactElement;\n  /** The left icon */\n  icon?: IconName;\n  /** List of details. Supports some nested HTML tags like <b> and <i>. */\n  details?: string[];\n  /** Usually a text content of the search result. Supports some nested HTML tags like <b> and <i>. Maximum 3 details items allowed where each test gets clamped after 3 lines. */\n  body?: string;\n  /** List of secondary AMBOSS targets with titles. Text gets clamped after 3 lines. */\n  secondaryTargets?: SecondaryTarget[];\n  /** Indicate an external link */\n  isExternal?: boolean;\n  /** List of labels. For example: preclinic, clinic, physician. */\n  labels?: string[];\n  /** The test id for the result's primary target. */\n  \"data-e2e-test-id\"?: string;\n};\n\nconst defaultProps: Partial<SearchResultProps> = {\n  icon: null,\n  details: [],\n  body: null,\n  secondaryTargets: [],\n  isExternal: false,\n  labels: [],\n  \"data-e2e-test-id\": undefined,\n};\n\nexport function SearchResult({\n  title,\n  subtitle,\n  icon,\n  details,\n  body,\n  secondaryTargets,\n  link,\n  labels,\n  \"data-e2e-test-id\": dataE2eTestId,\n}: SearchResultProps): React.ReactElement {\n  const containerRef = useRef(null);\n  const hasShallowSecondaryTargets =\n    secondaryTargets &&\n    secondaryTargets.reduce((prev, curr) => (curr.body ? false : prev), true);\n  const MainLink = link;\n\n  return (\n    <StyledResultContainer ref={containerRef} data-ds-id=\"SearchResult\">\n      <Columns gap=\"m\">\n        {icon && (\n          <Column size=\"narrow\">\n            <Icon name={icon} color=\"tertiary\" />\n          </Column>\n        )}\n        <Column size=\"fill\">\n          <Stack space=\"s\">\n            <StyledLinkContainerOnHover data-e2e-test-id={dataE2eTestId}>\n              <MainLink>\n                <Stack space=\"xxs\">\n                  <Columns gap=\"xxs\">\n                    <Column size={[12, 12, \"fill\"]}>\n                      <StyledLinkTitle>\n                        <Stack space=\"zero\">\n                          <TextClamped\n                            color=\"accent\"\n                            weight=\"bold\"\n                            lines={3}\n                            hyphens=\"auto\"\n                          >\n                            <StyledText>{title}</StyledText>\n                          </TextClamped>\n                          {subtitle && (\n                            <TextClamped color=\"accent\" lines={3} size=\"s\">\n                              <StyledText>{subtitle}</StyledText>\n                            </TextClamped>\n                          )}\n                        </Stack>\n                      </StyledLinkTitle>\n                    </Column>\n                    <Column size=\"narrow\">\n                      {labels && !!labels.length && (\n                        <Inline space=\"xs\">\n                          {labels.map((label, i) => (\n                            // eslint-disable-next-line react/no-array-index-key\n                            <Badge text={label} key={`${i}${label}`} />\n                          ))}\n                        </Inline>\n                      )}\n                    </Column>\n                  </Columns>\n                  {details && !!details.length && (\n                    <Stack space=\"zero\">\n                      {details.slice(0, 3).map((detail) => (\n                        <TextClamped\n                          color=\"primary\"\n                          size=\"s\"\n                          key={detail}\n                          lines={3}\n                        >\n                          <StyledText>{detail}</StyledText>\n                        </TextClamped>\n                      ))}\n                    </Stack>\n                  )}\n                  {body && (\n                    <TextClamped size=\"s\" lines={2}>\n                      <StyledText>{body}</StyledText>\n                    </TextClamped>\n                  )}\n                </Stack>\n              </MainLink>\n            </StyledLinkContainerOnHover>\n            {secondaryTargets && !!secondaryTargets.length && (\n              <SecondaryTargets\n                data={secondaryTargets}\n                compact={hasShallowSecondaryTargets}\n                renderItem={({\n                  title: secTitle,\n                  link: secLink,\n                  body: secBody,\n                  \"data-e2e-test-id\": secDataE2eTestId,\n                }) => {\n                  const SecLink = secLink;\n                  return (\n                    <StyledLinkContainerOnHover\n                      key={title}\n                      data-e2e-test-id={secDataE2eTestId}\n                    >\n                      <SecLink>\n                        <StyledLinkTitle>\n                          <TextClamped\n                            size=\"s\"\n                            color=\"accent\"\n                            weight=\"bold\"\n                            lines={3}\n                          >\n                            <StyledText>{secTitle}</StyledText>\n                          </TextClamped>\n                        </StyledLinkTitle>\n                        {secBody && (\n                          <TextClamped size=\"s\" color=\"primary\" lines={2}>\n                            <StyledText>{secBody}</StyledText>\n                          </TextClamped>\n                        )}\n                      </SecLink>\n                    </StyledLinkContainerOnHover>\n                  );\n                }}\n              />\n            )}\n          </Stack>\n        </Column>\n      </Columns>\n    </StyledResultContainer>\n  );\n}\n\nSearchResult.defaultProps = defaultProps;\n"]} */");
61
- const SecondaryTargets = _ref3 => {
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"]} */");
62
+ const StyledSecLinkTitle = /*#__PURE__*/_styled__default.default("span", process.env.NODE_ENV === "production" ? {
63
+ target: "e1y5sw0i2"
64
+ } : {
65
+ target: "e1y5sw0i2",
66
+ label: "StyledSecLinkTitle"
67
+ })(_ref3 => {
62
68
  let {
63
- data,
64
- renderItem,
65
- compact
69
+ theme
66
70
  } = _ref3;
67
- return compact ? /*#__PURE__*/React__default.default.createElement(Inline.Inline, {
68
- space: "l",
69
- vSpace: "xs"
70
- }, data && data.length && data.map(target => renderItem(target))) : /*#__PURE__*/React__default.default.createElement(Columns.Columns, {
71
- gap: "m"
72
- }, data.map(target => /*#__PURE__*/React__default.default.createElement(Columns.Column, {
73
- "data-e2e-test-id": target["data-e2e-test-id"],
74
- size: [12, 6, 6],
75
- key: target.title
76
- }, renderItem(target))));
71
+ return {
72
+ display: "list-item",
73
+ marginLeft: theme.variables.size.spacing.m,
74
+ paddingTop: theme.variables.size.spacing.xxxs,
75
+ paddingBottom: theme.variables.size.spacing.xxxs
76
+ };
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"]} */");
78
+ const StyledSecLinkContainerOnHover = /*#__PURE__*/_styled__default.default("div", process.env.NODE_ENV === "production" ? {
79
+ target: "e1y5sw0i1"
80
+ } : {
81
+ target: "e1y5sw0i1",
82
+ label: "StyledSecLinkContainerOnHover"
83
+ })(_ref4 => {
84
+ let {
85
+ theme
86
+ } = _ref4;
87
+ return {
88
+ "> a": {
89
+ textDecoration: "none",
90
+ color: theme.values.color.text.tertiary.default
91
+ },
92
+ "&:hover": {
93
+ [`${StyledSecLinkTitle}`]: {
94
+ textDecoration: "underline"
95
+ }
96
+ }
97
+ };
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"]} */");
99
+ const SecondaryTargets = _ref5 => {
100
+ let {
101
+ data
102
+ } = _ref5;
103
+ return /*#__PURE__*/React__default.default.createElement(React__default.default.Fragment, null, data.map((_ref6, i) => {
104
+ let {
105
+ title,
106
+ link: SecLink,
107
+ body,
108
+ "data-e2e-test-id": dataE2eTestId
109
+ } = _ref6;
110
+ const key = `${title}-${i}`;
111
+ return /*#__PURE__*/React__default.default.createElement(StyledSecLinkContainerOnHover, {
112
+ key: key,
113
+ "data-e2e-test-id": dataE2eTestId
114
+ }, /*#__PURE__*/React__default.default.createElement(SecLink, null, /*#__PURE__*/React__default.default.createElement(StyledSecLinkTitle, null, /*#__PURE__*/React__default.default.createElement(Text.Text, {
115
+ size: "m",
116
+ color: "primary",
117
+ as: "span"
118
+ }, /*#__PURE__*/React__default.default.createElement(StyledText.StyledText, null, title))), body && /*#__PURE__*/React__default.default.createElement(TextClamped.TextClamped, {
119
+ size: "s",
120
+ color: "tertiary",
121
+ lines: 2
122
+ }, /*#__PURE__*/React__default.default.createElement(StyledText.StyledText, null, body))));
123
+ }));
77
124
  };
78
125
  const defaultProps = {
79
126
  icon: null,
80
127
  details: [],
81
128
  body: null,
82
129
  secondaryTargets: [],
83
- isExternal: false,
84
130
  labels: [],
85
131
  "data-e2e-test-id": undefined
86
132
  };
87
- function SearchResult(_ref4) {
133
+ // this was a request by the designer to
134
+ // have the backwards compatibility with the old search result
135
+ const BadgeWithBottomPadding = /*#__PURE__*/_styled__default.default("div", process.env.NODE_ENV === "production" ? {
136
+ target: "e1y5sw0i0"
137
+ } : {
138
+ target: "e1y5sw0i0",
139
+ label: "BadgeWithBottomPadding"
140
+ })(_ref7 => {
141
+ let {
142
+ theme
143
+ } = _ref7;
144
+ return {
145
+ paddingBottom: theme.variables.size.spacing.xxxs
146
+ };
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"]} */");
148
+ function SearchResult(_ref8) {
88
149
  let {
89
150
  title,
90
151
  subtitle,
@@ -95,10 +156,10 @@ function SearchResult(_ref4) {
95
156
  link,
96
157
  labels,
97
158
  "data-e2e-test-id": dataE2eTestId
98
- } = _ref4;
159
+ } = _ref8;
99
160
  const containerRef = React.useRef(null);
100
- const hasShallowSecondaryTargets = secondaryTargets && secondaryTargets.reduce((prev, curr) => curr.body ? false : prev, true);
101
161
  const MainLink = link;
162
+ const spacing = subtitle || details.length || labels.length ? "xxs" : "zero";
102
163
  return /*#__PURE__*/React__default.default.createElement(StyledResultContainer, {
103
164
  ref: containerRef,
104
165
  "data-ds-id": "SearchResult"
@@ -112,11 +173,11 @@ function SearchResult(_ref4) {
112
173
  })), /*#__PURE__*/React__default.default.createElement(Columns.Column, {
113
174
  size: "fill"
114
175
  }, /*#__PURE__*/React__default.default.createElement(Stack.Stack, {
115
- space: "s"
176
+ space: "xxs"
116
177
  }, /*#__PURE__*/React__default.default.createElement(StyledLinkContainerOnHover, {
117
178
  "data-e2e-test-id": dataE2eTestId
118
179
  }, /*#__PURE__*/React__default.default.createElement(MainLink, null, /*#__PURE__*/React__default.default.createElement(Stack.Stack, {
119
- space: "xxs"
180
+ space: spacing
120
181
  }, /*#__PURE__*/React__default.default.createElement(Columns.Columns, {
121
182
  gap: "xxs"
122
183
  }, /*#__PURE__*/React__default.default.createElement(Columns.Column, {
@@ -132,17 +193,18 @@ function SearchResult(_ref4) {
132
193
  color: "accent",
133
194
  lines: 3,
134
195
  size: "s"
135
- }, /*#__PURE__*/React__default.default.createElement(StyledText.StyledText, null, subtitle))))), /*#__PURE__*/React__default.default.createElement(Columns.Column, {
196
+ }, /*#__PURE__*/React__default.default.createElement(StyledText.StyledText, null, subtitle))))), labels && !!labels.length && /*#__PURE__*/React__default.default.createElement(Columns.Column, {
136
197
  size: "narrow"
137
- }, labels && !!labels.length && /*#__PURE__*/React__default.default.createElement(Inline.Inline, {
198
+ }, /*#__PURE__*/React__default.default.createElement(Inline.Inline, {
138
199
  space: "xs"
139
- }, labels.map((label, i) =>
140
- /*#__PURE__*/
141
- // eslint-disable-next-line react/no-array-index-key
142
- React__default.default.createElement(Badge.Badge, {
143
- text: label,
144
- key: `${i}${label}`
145
- }))))), details && !!details.length && /*#__PURE__*/React__default.default.createElement(Stack.Stack, {
200
+ }, labels.map((label, i) => {
201
+ const key = `${i}${label}`;
202
+ return /*#__PURE__*/React__default.default.createElement(BadgeWithBottomPadding, {
203
+ key: key
204
+ }, /*#__PURE__*/React__default.default.createElement(Badge.Badge, {
205
+ text: label
206
+ }));
207
+ })))), details && !!details.length && /*#__PURE__*/React__default.default.createElement(Stack.Stack, {
146
208
  space: "zero"
147
209
  }, details.slice(0, 3).map(detail => /*#__PURE__*/React__default.default.createElement(TextClamped.TextClamped, {
148
210
  color: "primary",
@@ -153,30 +215,7 @@ function SearchResult(_ref4) {
153
215
  size: "s",
154
216
  lines: 2
155
217
  }, /*#__PURE__*/React__default.default.createElement(StyledText.StyledText, null, body))))), secondaryTargets && !!secondaryTargets.length && /*#__PURE__*/React__default.default.createElement(SecondaryTargets, {
156
- data: secondaryTargets,
157
- compact: hasShallowSecondaryTargets,
158
- renderItem: _ref5 => {
159
- let {
160
- title: secTitle,
161
- link: secLink,
162
- body: secBody,
163
- "data-e2e-test-id": secDataE2eTestId
164
- } = _ref5;
165
- const SecLink = secLink;
166
- return /*#__PURE__*/React__default.default.createElement(StyledLinkContainerOnHover, {
167
- key: title,
168
- "data-e2e-test-id": secDataE2eTestId
169
- }, /*#__PURE__*/React__default.default.createElement(SecLink, null, /*#__PURE__*/React__default.default.createElement(StyledLinkTitle, null, /*#__PURE__*/React__default.default.createElement(TextClamped.TextClamped, {
170
- size: "s",
171
- color: "accent",
172
- weight: "bold",
173
- lines: 3
174
- }, /*#__PURE__*/React__default.default.createElement(StyledText.StyledText, null, secTitle))), secBody && /*#__PURE__*/React__default.default.createElement(TextClamped.TextClamped, {
175
- size: "s",
176
- color: "primary",
177
- lines: 2
178
- }, /*#__PURE__*/React__default.default.createElement(StyledText.StyledText, null, secBody))));
179
- }
218
+ data: secondaryTargets
180
219
  })))));
181
220
  }
182
221
  SearchResult.defaultProps = defaultProps;