@ndla/ui 21.0.0 → 22.0.2

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 (94) hide show
  1. package/es/Breadcrumb/ActionBreadcrumb.js +4 -4
  2. package/es/ContentLoader/index.js +8 -3
  3. package/es/MyNdla/Resource/Folder.js +7 -6
  4. package/es/Resource/BlockResource.js +106 -18
  5. package/es/Resource/ListResource.js +125 -26
  6. package/es/ResourceGroup/ResourceGroup.js +3 -3
  7. package/es/ResourceGroup/ResourceItem.js +12 -12
  8. package/es/ResourceGroup/ResourceList.js +2 -2
  9. package/es/Search/ContentTypeResult.js +1 -2
  10. package/es/SearchTypeResult/SearchItem.js +8 -8
  11. package/es/SnackBar/DefaultSnackbar.js +56 -0
  12. package/es/SnackBar/SnackbarProvider.js +179 -0
  13. package/es/SnackBar/index.js +2 -2
  14. package/es/TopicMenu/TopicMenuButton.js +4 -2
  15. package/es/TreeStructure/FolderItem.js +64 -44
  16. package/es/TreeStructure/FolderItems.js +4 -4
  17. package/es/TreeStructure/TreeStructure.js +16 -9
  18. package/es/index.js +1 -1
  19. package/es/locale/messages-en.js +17 -2
  20. package/es/locale/messages-nb.js +17 -2
  21. package/es/locale/messages-nn.js +17 -2
  22. package/es/locale/messages-se.js +17 -2
  23. package/es/locale/messages-sma.js +17 -2
  24. package/lib/Breadcrumb/ActionBreadcrumb.js +4 -4
  25. package/lib/ContentLoader/index.d.ts +4 -8
  26. package/lib/ContentLoader/index.js +8 -3
  27. package/lib/MyNdla/Resource/Folder.js +7 -6
  28. package/lib/Resource/BlockResource.d.ts +2 -1
  29. package/lib/Resource/BlockResource.js +107 -18
  30. package/lib/Resource/ListResource.d.ts +2 -1
  31. package/lib/Resource/ListResource.js +126 -26
  32. package/lib/ResourceGroup/ResourceGroup.d.ts +1 -1
  33. package/lib/ResourceGroup/ResourceGroup.js +3 -3
  34. package/lib/ResourceGroup/ResourceItem.d.ts +1 -1
  35. package/lib/ResourceGroup/ResourceItem.js +12 -12
  36. package/lib/ResourceGroup/ResourceList.d.ts +1 -1
  37. package/lib/ResourceGroup/ResourceList.js +2 -2
  38. package/lib/Search/ContentTypeResult.js +1 -2
  39. package/lib/SearchTypeResult/SearchItem.js +8 -8
  40. package/lib/SnackBar/DefaultSnackbar.d.ts +11 -0
  41. package/lib/SnackBar/DefaultSnackbar.js +70 -0
  42. package/lib/SnackBar/SnackbarProvider.d.ts +32 -0
  43. package/lib/SnackBar/SnackbarProvider.js +197 -0
  44. package/lib/SnackBar/index.d.ts +3 -3
  45. package/lib/SnackBar/index.js +23 -3
  46. package/lib/TopicMenu/TopicMenuButton.js +3 -1
  47. package/lib/TreeStructure/FolderItem.d.ts +1 -1
  48. package/lib/TreeStructure/FolderItem.js +65 -44
  49. package/lib/TreeStructure/FolderItems.js +4 -4
  50. package/lib/TreeStructure/TreeStructure.d.ts +2 -2
  51. package/lib/TreeStructure/TreeStructure.js +16 -9
  52. package/lib/TreeStructure/types.d.ts +2 -1
  53. package/lib/index.d.ts +2 -2
  54. package/lib/index.js +24 -3
  55. package/lib/locale/messages-en.d.ts +15 -0
  56. package/lib/locale/messages-en.js +17 -2
  57. package/lib/locale/messages-nb.d.ts +15 -0
  58. package/lib/locale/messages-nb.js +17 -2
  59. package/lib/locale/messages-nn.d.ts +15 -0
  60. package/lib/locale/messages-nn.js +17 -2
  61. package/lib/locale/messages-se.d.ts +15 -0
  62. package/lib/locale/messages-se.js +17 -2
  63. package/lib/locale/messages-sma.d.ts +15 -0
  64. package/lib/locale/messages-sma.js +17 -2
  65. package/package.json +14 -14
  66. package/src/.DS_Store +0 -0
  67. package/src/Breadcrumb/ActionBreadcrumb.tsx +1 -1
  68. package/src/ContentLoader/index.tsx +9 -9
  69. package/src/MyNdla/Resource/Folder.tsx +1 -1
  70. package/src/Resource/BlockResource.tsx +66 -5
  71. package/src/Resource/ListResource.tsx +86 -11
  72. package/src/ResourceGroup/ResourceGroup.tsx +1 -1
  73. package/src/ResourceGroup/ResourceItem.tsx +2 -2
  74. package/src/ResourceGroup/ResourceList.tsx +1 -1
  75. package/src/Search/ContentTypeResult.tsx +0 -1
  76. package/src/SearchTypeResult/SearchItem.tsx +0 -1
  77. package/src/SnackBar/DefaultSnackbar.tsx +70 -0
  78. package/src/SnackBar/SnackbarProvider.tsx +147 -0
  79. package/src/SnackBar/index.ts +3 -5
  80. package/src/TopicMenu/TopicMenuButton.jsx +5 -1
  81. package/src/TreeStructure/FolderItem.tsx +56 -37
  82. package/src/TreeStructure/FolderItems.tsx +3 -2
  83. package/src/TreeStructure/TreeStructure.tsx +11 -6
  84. package/src/TreeStructure/types.ts +2 -1
  85. package/src/index.ts +2 -2
  86. package/src/locale/messages-en.ts +15 -0
  87. package/src/locale/messages-nb.ts +15 -0
  88. package/src/locale/messages-nn.ts +15 -0
  89. package/src/locale/messages-se.ts +15 -0
  90. package/src/locale/messages-sma.ts +15 -0
  91. package/es/SnackBar/SnackBar.js +0 -117
  92. package/lib/SnackBar/SnackBar.d.ts +0 -23
  93. package/lib/SnackBar/SnackBar.js +0 -127
  94. package/src/SnackBar/SnackBar.tsx +0 -183
@@ -13,7 +13,7 @@ export declare type ResourceListProps = {
13
13
  contentType?: string;
14
14
  title?: string;
15
15
  showAdditionalResources?: boolean;
16
- onToggleAddToFavorites: (id: string, add: boolean) => void;
16
+ onToggleAddToFavorites: (id: string) => void;
17
17
  showAddToFavoriteButton: boolean;
18
18
  };
19
19
  declare const ResourceList: ({ resources, onClick, onToggleAddToFavorites, contentType, title, showAdditionalResources, showAddToFavoriteButton, }: ResourceListProps) => JSX.Element;
@@ -45,8 +45,8 @@ var StyledResourceList = (0, _styledBase["default"])("ul", {
45
45
  label: "StyledResourceList"
46
46
  })("list-style:none;margin:0;padding:0;", function (_ref) {
47
47
  var showAdditionalResources = _ref.showAdditionalResources;
48
- return showAdditionalResources && /*#__PURE__*/(0, _css2["default"])("animation-name:", fakeLoadingAnimation, ";animation-duration:0.4s;;label:StyledResourceList;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlJlc291cmNlTGlzdC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBc0NPIiwiZmlsZSI6IlJlc291cmNlTGlzdC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxNy1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgY3NzIGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBrZXlmcmFtZXMgfSBmcm9tICdAZW1vdGlvbi9jb3JlJztcbmltcG9ydCB7IHVzZVRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgTm9Db250ZW50Qm94IGZyb20gJy4uL05vQ29udGVudEJveCc7XG5pbXBvcnQgUmVzb3VyY2VJdGVtIGZyb20gJy4vUmVzb3VyY2VJdGVtJztcbmltcG9ydCB7IFJlc291cmNlIH0gZnJvbSAnLi4vdHlwZXMnO1xuXG5jb25zdCBmYWtlTG9hZGluZ0FuaW1hdGlvbiA9IGtleWZyYW1lc2BcbiAgMCUge1xuICAgIG9wYWNpdHk6IDAuNTtcbiAgfVxuICA5OSUge1xuICAgIG9wYWNpdHk6IDAuNTtcbiAgfVxuICAxMDAlIHtcbiAgICBvcGFjaXR5OiAxO1xuICB9XG5gO1xuXG50eXBlIFN0eWxlZExpc3RQcm9wcyA9IHtcbiAgc2hvd0FkZGl0aW9uYWxSZXNvdXJjZXM/OiBib29sZWFuO1xufTtcbmNvbnN0IFN0eWxlZFJlc291cmNlTGlzdCA9IHN0eWxlZC51bDxTdHlsZWRMaXN0UHJvcHM+YFxuICBsaXN0LXN0eWxlOiBub25lO1xuICBtYXJnaW46IDA7XG4gIHBhZGRpbmc6IDA7XG4gICR7KHsgc2hvd0FkZGl0aW9uYWxSZXNvdXJjZXMgfSkgPT5cbiAgICBzaG93QWRkaXRpb25hbFJlc291cmNlcyAmJlxuICAgIGNzc2BcbiAgICAgIGFuaW1hdGlvbi1uYW1lOiAke2Zha2VMb2FkaW5nQW5pbWF0aW9ufTtcbiAgICAgIGFuaW1hdGlvbi1kdXJhdGlvbjogMC40cztcbiAgICBgfVxuYDtcblxuZXhwb3J0IHR5cGUgUmVzb3VyY2VMaXN0UHJvcHMgPSB7XG4gIHJlc291cmNlczogUmVzb3VyY2VbXTtcbiAgb25DbGljazogKCkgPT4gdm9pZDtcbiAgY29udGVudFR5cGU/OiBzdHJpbmc7XG4gIHRpdGxlPzogc3RyaW5nO1xuICBzaG93QWRkaXRpb25hbFJlc291cmNlcz86IGJvb2xlYW47XG4gIG9uVG9nZ2xlQWRkVG9GYXZvcml0ZXM6IChpZDogc3RyaW5nLCBhZGQ6IGJvb2xlYW4pID0+IHZvaWQ7XG4gIHNob3dBZGRUb0Zhdm9yaXRlQnV0dG9uOiBib29sZWFuO1xufTtcblxuY29uc3QgUmVzb3VyY2VMaXN0ID0gKHtcbiAgcmVzb3VyY2VzLFxuICBvbkNsaWNrLFxuICBvblRvZ2dsZUFkZFRvRmF2b3JpdGVzLFxuICBjb250ZW50VHlwZSxcbiAgdGl0bGUsXG4gIHNob3dBZGRpdGlvbmFsUmVzb3VyY2VzLFxuICBzaG93QWRkVG9GYXZvcml0ZUJ1dHRvbixcbn06IFJlc291cmNlTGlzdFByb3BzKSA9PiB7XG4gIGNvbnN0IHsgdCB9ID0gdXNlVHJhbnNsYXRpb24oKTtcbiAgY29uc3QgcmVuZGVyQWRkaXRpb25hbFJlc291cmNlVHJpZ2dlciA9XG4gICAgIXNob3dBZGRpdGlvbmFsUmVzb3VyY2VzICYmXG4gICAgcmVzb3VyY2VzLmZpbHRlcigocmVzKSA9PiByZXMuYWRkaXRpb25hbCkubGVuZ3RoID4gMCAmJlxuICAgIHJlc291cmNlcy5maWx0ZXIoKHJlcykgPT4gIXJlcy5hZGRpdGlvbmFsKS5sZW5ndGggPT09IDA7XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2PlxuICAgICAgPFN0eWxlZFJlc291cmNlTGlzdCBzaG93QWRkaXRpb25hbFJlc291cmNlcz17c2hvd0FkZGl0aW9uYWxSZXNvdXJjZXN9PlxuICAgICAgICB7cmVzb3VyY2VzLm1hcCgoeyBpZCwgLi4ucmVzb3VyY2UgfSkgPT4gKFxuICAgICAgICAgIDxSZXNvdXJjZUl0ZW1cbiAgICAgICAgICAgIGlkPXtpZH1cbiAgICAgICAgICAgIGtleT17aWR9XG4gICAgICAgICAgICBjb250ZW50VHlwZT17Y29udGVudFR5cGV9XG4gICAgICAgICAgICBzaG93QWRkaXRpb25hbFJlc291cmNlcz17c2hvd0FkZGl0aW9uYWxSZXNvdXJjZXN9XG4gICAgICAgICAgICBzaG93QWRkVG9GYXZvcml0ZUJ1dHRvbj17c2hvd0FkZFRvRmF2b3JpdGVCdXR0b259XG4gICAgICAgICAgICBvblRvZ2dsZUFkZFRvRmF2b3JpdGVzPXtvblRvZ2dsZUFkZFRvRmF2b3JpdGVzfVxuICAgICAgICAgICAgey4uLnJlc291cmNlfVxuICAgICAgICAgICAgY29udGVudFR5cGVEZXNjcmlwdGlvbj17XG4gICAgICAgICAgICAgIHJlc291cmNlLmFkZGl0aW9uYWwgPyB0KCdyZXNvdXJjZS50b29sdGlwQWRkaXRpb25hbFRvcGljJykgOiB0KCdyZXNvdXJjZS50b29sdGlwQ29yZVRvcGljJylcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAvPlxuICAgICAgICApKX1cbiAgICAgICAge3JlbmRlckFkZGl0aW9uYWxSZXNvdXJjZVRyaWdnZXIgJiYgKFxuICAgICAgICAgIDxsaT5cbiAgICAgICAgICAgIDxOb0NvbnRlbnRCb3hcbiAgICAgICAgICAgICAgb25DbGljaz17b25DbGlja31cbiAgICAgICAgICAgICAgYnV0dG9uVGV4dD17dCgncmVzb3VyY2UudG9nZ2xlRmlsdGVyTGFiZWwnKX1cbiAgICAgICAgICAgICAgdGV4dD17XG4gICAgICAgICAgICAgICAgdGl0bGVcbiAgICAgICAgICAgICAgICAgID8gdCgncmVzb3VyY2Uubm9Db3JlUmVzb3VyY2VzQXZhaWxhYmxlJywge1xuICAgICAgICAgICAgICAgICAgICAgIG5hbWU6IHRpdGxlLnRvTG93ZXJDYXNlKCksXG4gICAgICAgICAgICAgICAgICAgIH0pXG4gICAgICAgICAgICAgICAgICA6IHQoJ3Jlc291cmNlLm5vQ29yZVJlc291cmNlc0F2YWlsYWJsZVVuc3BlY2lmaWMnKVxuICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAvPlxuICAgICAgICAgIDwvbGk+XG4gICAgICAgICl9XG4gICAgICA8L1N0eWxlZFJlc291cmNlTGlzdD5cbiAgICA8L2Rpdj5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IFJlc291cmNlTGlzdDtcbiJdfQ== */"));
49
- }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlJlc291cmNlTGlzdC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZ0NxRCIsImZpbGUiOiJSZXNvdXJjZUxpc3QudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTctcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IGNzcyBmcm9tICdAZW1vdGlvbi9jc3MnO1xuaW1wb3J0IHsga2V5ZnJhbWVzIH0gZnJvbSAnQGVtb3Rpb24vY29yZSc7XG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gJ3JlYWN0LWkxOG5leHQnO1xuaW1wb3J0IE5vQ29udGVudEJveCBmcm9tICcuLi9Ob0NvbnRlbnRCb3gnO1xuaW1wb3J0IFJlc291cmNlSXRlbSBmcm9tICcuL1Jlc291cmNlSXRlbSc7XG5pbXBvcnQgeyBSZXNvdXJjZSB9IGZyb20gJy4uL3R5cGVzJztcblxuY29uc3QgZmFrZUxvYWRpbmdBbmltYXRpb24gPSBrZXlmcmFtZXNgXG4gIDAlIHtcbiAgICBvcGFjaXR5OiAwLjU7XG4gIH1cbiAgOTklIHtcbiAgICBvcGFjaXR5OiAwLjU7XG4gIH1cbiAgMTAwJSB7XG4gICAgb3BhY2l0eTogMTtcbiAgfVxuYDtcblxudHlwZSBTdHlsZWRMaXN0UHJvcHMgPSB7XG4gIHNob3dBZGRpdGlvbmFsUmVzb3VyY2VzPzogYm9vbGVhbjtcbn07XG5jb25zdCBTdHlsZWRSZXNvdXJjZUxpc3QgPSBzdHlsZWQudWw8U3R5bGVkTGlzdFByb3BzPmBcbiAgbGlzdC1zdHlsZTogbm9uZTtcbiAgbWFyZ2luOiAwO1xuICBwYWRkaW5nOiAwO1xuICAkeyh7IHNob3dBZGRpdGlvbmFsUmVzb3VyY2VzIH0pID0+XG4gICAgc2hvd0FkZGl0aW9uYWxSZXNvdXJjZXMgJiZcbiAgICBjc3NgXG4gICAgICBhbmltYXRpb24tbmFtZTogJHtmYWtlTG9hZGluZ0FuaW1hdGlvbn07XG4gICAgICBhbmltYXRpb24tZHVyYXRpb246IDAuNHM7XG4gICAgYH1cbmA7XG5cbmV4cG9ydCB0eXBlIFJlc291cmNlTGlzdFByb3BzID0ge1xuICByZXNvdXJjZXM6IFJlc291cmNlW107XG4gIG9uQ2xpY2s6ICgpID0+IHZvaWQ7XG4gIGNvbnRlbnRUeXBlPzogc3RyaW5nO1xuICB0aXRsZT86IHN0cmluZztcbiAgc2hvd0FkZGl0aW9uYWxSZXNvdXJjZXM/OiBib29sZWFuO1xuICBvblRvZ2dsZUFkZFRvRmF2b3JpdGVzOiAoaWQ6IHN0cmluZywgYWRkOiBib29sZWFuKSA9PiB2b2lkO1xuICBzaG93QWRkVG9GYXZvcml0ZUJ1dHRvbjogYm9vbGVhbjtcbn07XG5cbmNvbnN0IFJlc291cmNlTGlzdCA9ICh7XG4gIHJlc291cmNlcyxcbiAgb25DbGljayxcbiAgb25Ub2dnbGVBZGRUb0Zhdm9yaXRlcyxcbiAgY29udGVudFR5cGUsXG4gIHRpdGxlLFxuICBzaG93QWRkaXRpb25hbFJlc291cmNlcyxcbiAgc2hvd0FkZFRvRmF2b3JpdGVCdXR0b24sXG59OiBSZXNvdXJjZUxpc3RQcm9wcykgPT4ge1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIGNvbnN0IHJlbmRlckFkZGl0aW9uYWxSZXNvdXJjZVRyaWdnZXIgPVxuICAgICFzaG93QWRkaXRpb25hbFJlc291cmNlcyAmJlxuICAgIHJlc291cmNlcy5maWx0ZXIoKHJlcykgPT4gcmVzLmFkZGl0aW9uYWwpLmxlbmd0aCA+IDAgJiZcbiAgICByZXNvdXJjZXMuZmlsdGVyKChyZXMpID0+ICFyZXMuYWRkaXRpb25hbCkubGVuZ3RoID09PSAwO1xuXG4gIHJldHVybiAoXG4gICAgPGRpdj5cbiAgICAgIDxTdHlsZWRSZXNvdXJjZUxpc3Qgc2hvd0FkZGl0aW9uYWxSZXNvdXJjZXM9e3Nob3dBZGRpdGlvbmFsUmVzb3VyY2VzfT5cbiAgICAgICAge3Jlc291cmNlcy5tYXAoKHsgaWQsIC4uLnJlc291cmNlIH0pID0+IChcbiAgICAgICAgICA8UmVzb3VyY2VJdGVtXG4gICAgICAgICAgICBpZD17aWR9XG4gICAgICAgICAgICBrZXk9e2lkfVxuICAgICAgICAgICAgY29udGVudFR5cGU9e2NvbnRlbnRUeXBlfVxuICAgICAgICAgICAgc2hvd0FkZGl0aW9uYWxSZXNvdXJjZXM9e3Nob3dBZGRpdGlvbmFsUmVzb3VyY2VzfVxuICAgICAgICAgICAgc2hvd0FkZFRvRmF2b3JpdGVCdXR0b249e3Nob3dBZGRUb0Zhdm9yaXRlQnV0dG9ufVxuICAgICAgICAgICAgb25Ub2dnbGVBZGRUb0Zhdm9yaXRlcz17b25Ub2dnbGVBZGRUb0Zhdm9yaXRlc31cbiAgICAgICAgICAgIHsuLi5yZXNvdXJjZX1cbiAgICAgICAgICAgIGNvbnRlbnRUeXBlRGVzY3JpcHRpb249e1xuICAgICAgICAgICAgICByZXNvdXJjZS5hZGRpdGlvbmFsID8gdCgncmVzb3VyY2UudG9vbHRpcEFkZGl0aW9uYWxUb3BpYycpIDogdCgncmVzb3VyY2UudG9vbHRpcENvcmVUb3BpYycpXG4gICAgICAgICAgICB9XG4gICAgICAgICAgLz5cbiAgICAgICAgKSl9XG4gICAgICAgIHtyZW5kZXJBZGRpdGlvbmFsUmVzb3VyY2VUcmlnZ2VyICYmIChcbiAgICAgICAgICA8bGk+XG4gICAgICAgICAgICA8Tm9Db250ZW50Qm94XG4gICAgICAgICAgICAgIG9uQ2xpY2s9e29uQ2xpY2t9XG4gICAgICAgICAgICAgIGJ1dHRvblRleHQ9e3QoJ3Jlc291cmNlLnRvZ2dsZUZpbHRlckxhYmVsJyl9XG4gICAgICAgICAgICAgIHRleHQ9e1xuICAgICAgICAgICAgICAgIHRpdGxlXG4gICAgICAgICAgICAgICAgICA/IHQoJ3Jlc291cmNlLm5vQ29yZVJlc291cmNlc0F2YWlsYWJsZScsIHtcbiAgICAgICAgICAgICAgICAgICAgICBuYW1lOiB0aXRsZS50b0xvd2VyQ2FzZSgpLFxuICAgICAgICAgICAgICAgICAgICB9KVxuICAgICAgICAgICAgICAgICAgOiB0KCdyZXNvdXJjZS5ub0NvcmVSZXNvdXJjZXNBdmFpbGFibGVVbnNwZWNpZmljJylcbiAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgLz5cbiAgICAgICAgICA8L2xpPlxuICAgICAgICApfVxuICAgICAgPC9TdHlsZWRSZXNvdXJjZUxpc3Q+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBSZXNvdXJjZUxpc3Q7XG4iXX0= */");
48
+ return showAdditionalResources && /*#__PURE__*/(0, _css2["default"])("animation-name:", fakeLoadingAnimation, ";animation-duration:0.4s;;label:StyledResourceList;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlJlc291cmNlTGlzdC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBc0NPIiwiZmlsZSI6IlJlc291cmNlTGlzdC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxNy1wcmVzZW50LCBORExBLlxuICpcbiAqIFRoaXMgc291cmNlIGNvZGUgaXMgbGljZW5zZWQgdW5kZXIgdGhlIEdQTHYzIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKlxuICovXG5cbmltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgY3NzIGZyb20gJ0BlbW90aW9uL2Nzcyc7XG5pbXBvcnQgeyBrZXlmcmFtZXMgfSBmcm9tICdAZW1vdGlvbi9jb3JlJztcbmltcG9ydCB7IHVzZVRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCc7XG5pbXBvcnQgTm9Db250ZW50Qm94IGZyb20gJy4uL05vQ29udGVudEJveCc7XG5pbXBvcnQgUmVzb3VyY2VJdGVtIGZyb20gJy4vUmVzb3VyY2VJdGVtJztcbmltcG9ydCB7IFJlc291cmNlIH0gZnJvbSAnLi4vdHlwZXMnO1xuXG5jb25zdCBmYWtlTG9hZGluZ0FuaW1hdGlvbiA9IGtleWZyYW1lc2BcbiAgMCUge1xuICAgIG9wYWNpdHk6IDAuNTtcbiAgfVxuICA5OSUge1xuICAgIG9wYWNpdHk6IDAuNTtcbiAgfVxuICAxMDAlIHtcbiAgICBvcGFjaXR5OiAxO1xuICB9XG5gO1xuXG50eXBlIFN0eWxlZExpc3RQcm9wcyA9IHtcbiAgc2hvd0FkZGl0aW9uYWxSZXNvdXJjZXM/OiBib29sZWFuO1xufTtcbmNvbnN0IFN0eWxlZFJlc291cmNlTGlzdCA9IHN0eWxlZC51bDxTdHlsZWRMaXN0UHJvcHM+YFxuICBsaXN0LXN0eWxlOiBub25lO1xuICBtYXJnaW46IDA7XG4gIHBhZGRpbmc6IDA7XG4gICR7KHsgc2hvd0FkZGl0aW9uYWxSZXNvdXJjZXMgfSkgPT5cbiAgICBzaG93QWRkaXRpb25hbFJlc291cmNlcyAmJlxuICAgIGNzc2BcbiAgICAgIGFuaW1hdGlvbi1uYW1lOiAke2Zha2VMb2FkaW5nQW5pbWF0aW9ufTtcbiAgICAgIGFuaW1hdGlvbi1kdXJhdGlvbjogMC40cztcbiAgICBgfVxuYDtcblxuZXhwb3J0IHR5cGUgUmVzb3VyY2VMaXN0UHJvcHMgPSB7XG4gIHJlc291cmNlczogUmVzb3VyY2VbXTtcbiAgb25DbGljazogKCkgPT4gdm9pZDtcbiAgY29udGVudFR5cGU/OiBzdHJpbmc7XG4gIHRpdGxlPzogc3RyaW5nO1xuICBzaG93QWRkaXRpb25hbFJlc291cmNlcz86IGJvb2xlYW47XG4gIG9uVG9nZ2xlQWRkVG9GYXZvcml0ZXM6IChpZDogc3RyaW5nKSA9PiB2b2lkO1xuICBzaG93QWRkVG9GYXZvcml0ZUJ1dHRvbjogYm9vbGVhbjtcbn07XG5cbmNvbnN0IFJlc291cmNlTGlzdCA9ICh7XG4gIHJlc291cmNlcyxcbiAgb25DbGljayxcbiAgb25Ub2dnbGVBZGRUb0Zhdm9yaXRlcyxcbiAgY29udGVudFR5cGUsXG4gIHRpdGxlLFxuICBzaG93QWRkaXRpb25hbFJlc291cmNlcyxcbiAgc2hvd0FkZFRvRmF2b3JpdGVCdXR0b24sXG59OiBSZXNvdXJjZUxpc3RQcm9wcykgPT4ge1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIGNvbnN0IHJlbmRlckFkZGl0aW9uYWxSZXNvdXJjZVRyaWdnZXIgPVxuICAgICFzaG93QWRkaXRpb25hbFJlc291cmNlcyAmJlxuICAgIHJlc291cmNlcy5maWx0ZXIoKHJlcykgPT4gcmVzLmFkZGl0aW9uYWwpLmxlbmd0aCA+IDAgJiZcbiAgICByZXNvdXJjZXMuZmlsdGVyKChyZXMpID0+ICFyZXMuYWRkaXRpb25hbCkubGVuZ3RoID09PSAwO1xuXG4gIHJldHVybiAoXG4gICAgPGRpdj5cbiAgICAgIDxTdHlsZWRSZXNvdXJjZUxpc3Qgc2hvd0FkZGl0aW9uYWxSZXNvdXJjZXM9e3Nob3dBZGRpdGlvbmFsUmVzb3VyY2VzfT5cbiAgICAgICAge3Jlc291cmNlcy5tYXAoKHsgaWQsIC4uLnJlc291cmNlIH0pID0+IChcbiAgICAgICAgICA8UmVzb3VyY2VJdGVtXG4gICAgICAgICAgICBpZD17aWR9XG4gICAgICAgICAgICBrZXk9e2lkfVxuICAgICAgICAgICAgY29udGVudFR5cGU9e2NvbnRlbnRUeXBlfVxuICAgICAgICAgICAgc2hvd0FkZGl0aW9uYWxSZXNvdXJjZXM9e3Nob3dBZGRpdGlvbmFsUmVzb3VyY2VzfVxuICAgICAgICAgICAgc2hvd0FkZFRvRmF2b3JpdGVCdXR0b249e3Nob3dBZGRUb0Zhdm9yaXRlQnV0dG9ufVxuICAgICAgICAgICAgb25Ub2dnbGVBZGRUb0Zhdm9yaXRlcz17b25Ub2dnbGVBZGRUb0Zhdm9yaXRlc31cbiAgICAgICAgICAgIHsuLi5yZXNvdXJjZX1cbiAgICAgICAgICAgIGNvbnRlbnRUeXBlRGVzY3JpcHRpb249e1xuICAgICAgICAgICAgICByZXNvdXJjZS5hZGRpdGlvbmFsID8gdCgncmVzb3VyY2UudG9vbHRpcEFkZGl0aW9uYWxUb3BpYycpIDogdCgncmVzb3VyY2UudG9vbHRpcENvcmVUb3BpYycpXG4gICAgICAgICAgICB9XG4gICAgICAgICAgLz5cbiAgICAgICAgKSl9XG4gICAgICAgIHtyZW5kZXJBZGRpdGlvbmFsUmVzb3VyY2VUcmlnZ2VyICYmIChcbiAgICAgICAgICA8bGk+XG4gICAgICAgICAgICA8Tm9Db250ZW50Qm94XG4gICAgICAgICAgICAgIG9uQ2xpY2s9e29uQ2xpY2t9XG4gICAgICAgICAgICAgIGJ1dHRvblRleHQ9e3QoJ3Jlc291cmNlLnRvZ2dsZUZpbHRlckxhYmVsJyl9XG4gICAgICAgICAgICAgIHRleHQ9e1xuICAgICAgICAgICAgICAgIHRpdGxlXG4gICAgICAgICAgICAgICAgICA/IHQoJ3Jlc291cmNlLm5vQ29yZVJlc291cmNlc0F2YWlsYWJsZScsIHtcbiAgICAgICAgICAgICAgICAgICAgICBuYW1lOiB0aXRsZS50b0xvd2VyQ2FzZSgpLFxuICAgICAgICAgICAgICAgICAgICB9KVxuICAgICAgICAgICAgICAgICAgOiB0KCdyZXNvdXJjZS5ub0NvcmVSZXNvdXJjZXNBdmFpbGFibGVVbnNwZWNpZmljJylcbiAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgLz5cbiAgICAgICAgICA8L2xpPlxuICAgICAgICApfVxuICAgICAgPC9TdHlsZWRSZXNvdXJjZUxpc3Q+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBSZXNvdXJjZUxpc3Q7XG4iXX0= */"));
49
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlJlc291cmNlTGlzdC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZ0NxRCIsImZpbGUiOiJSZXNvdXJjZUxpc3QudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMTctcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IGNzcyBmcm9tICdAZW1vdGlvbi9jc3MnO1xuaW1wb3J0IHsga2V5ZnJhbWVzIH0gZnJvbSAnQGVtb3Rpb24vY29yZSc7XG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gJ3JlYWN0LWkxOG5leHQnO1xuaW1wb3J0IE5vQ29udGVudEJveCBmcm9tICcuLi9Ob0NvbnRlbnRCb3gnO1xuaW1wb3J0IFJlc291cmNlSXRlbSBmcm9tICcuL1Jlc291cmNlSXRlbSc7XG5pbXBvcnQgeyBSZXNvdXJjZSB9IGZyb20gJy4uL3R5cGVzJztcblxuY29uc3QgZmFrZUxvYWRpbmdBbmltYXRpb24gPSBrZXlmcmFtZXNgXG4gIDAlIHtcbiAgICBvcGFjaXR5OiAwLjU7XG4gIH1cbiAgOTklIHtcbiAgICBvcGFjaXR5OiAwLjU7XG4gIH1cbiAgMTAwJSB7XG4gICAgb3BhY2l0eTogMTtcbiAgfVxuYDtcblxudHlwZSBTdHlsZWRMaXN0UHJvcHMgPSB7XG4gIHNob3dBZGRpdGlvbmFsUmVzb3VyY2VzPzogYm9vbGVhbjtcbn07XG5jb25zdCBTdHlsZWRSZXNvdXJjZUxpc3QgPSBzdHlsZWQudWw8U3R5bGVkTGlzdFByb3BzPmBcbiAgbGlzdC1zdHlsZTogbm9uZTtcbiAgbWFyZ2luOiAwO1xuICBwYWRkaW5nOiAwO1xuICAkeyh7IHNob3dBZGRpdGlvbmFsUmVzb3VyY2VzIH0pID0+XG4gICAgc2hvd0FkZGl0aW9uYWxSZXNvdXJjZXMgJiZcbiAgICBjc3NgXG4gICAgICBhbmltYXRpb24tbmFtZTogJHtmYWtlTG9hZGluZ0FuaW1hdGlvbn07XG4gICAgICBhbmltYXRpb24tZHVyYXRpb246IDAuNHM7XG4gICAgYH1cbmA7XG5cbmV4cG9ydCB0eXBlIFJlc291cmNlTGlzdFByb3BzID0ge1xuICByZXNvdXJjZXM6IFJlc291cmNlW107XG4gIG9uQ2xpY2s6ICgpID0+IHZvaWQ7XG4gIGNvbnRlbnRUeXBlPzogc3RyaW5nO1xuICB0aXRsZT86IHN0cmluZztcbiAgc2hvd0FkZGl0aW9uYWxSZXNvdXJjZXM/OiBib29sZWFuO1xuICBvblRvZ2dsZUFkZFRvRmF2b3JpdGVzOiAoaWQ6IHN0cmluZykgPT4gdm9pZDtcbiAgc2hvd0FkZFRvRmF2b3JpdGVCdXR0b246IGJvb2xlYW47XG59O1xuXG5jb25zdCBSZXNvdXJjZUxpc3QgPSAoe1xuICByZXNvdXJjZXMsXG4gIG9uQ2xpY2ssXG4gIG9uVG9nZ2xlQWRkVG9GYXZvcml0ZXMsXG4gIGNvbnRlbnRUeXBlLFxuICB0aXRsZSxcbiAgc2hvd0FkZGl0aW9uYWxSZXNvdXJjZXMsXG4gIHNob3dBZGRUb0Zhdm9yaXRlQnV0dG9uLFxufTogUmVzb3VyY2VMaXN0UHJvcHMpID0+IHtcbiAgY29uc3QgeyB0IH0gPSB1c2VUcmFuc2xhdGlvbigpO1xuICBjb25zdCByZW5kZXJBZGRpdGlvbmFsUmVzb3VyY2VUcmlnZ2VyID1cbiAgICAhc2hvd0FkZGl0aW9uYWxSZXNvdXJjZXMgJiZcbiAgICByZXNvdXJjZXMuZmlsdGVyKChyZXMpID0+IHJlcy5hZGRpdGlvbmFsKS5sZW5ndGggPiAwICYmXG4gICAgcmVzb3VyY2VzLmZpbHRlcigocmVzKSA9PiAhcmVzLmFkZGl0aW9uYWwpLmxlbmd0aCA9PT0gMDtcblxuICByZXR1cm4gKFxuICAgIDxkaXY+XG4gICAgICA8U3R5bGVkUmVzb3VyY2VMaXN0IHNob3dBZGRpdGlvbmFsUmVzb3VyY2VzPXtzaG93QWRkaXRpb25hbFJlc291cmNlc30+XG4gICAgICAgIHtyZXNvdXJjZXMubWFwKCh7IGlkLCAuLi5yZXNvdXJjZSB9KSA9PiAoXG4gICAgICAgICAgPFJlc291cmNlSXRlbVxuICAgICAgICAgICAgaWQ9e2lkfVxuICAgICAgICAgICAga2V5PXtpZH1cbiAgICAgICAgICAgIGNvbnRlbnRUeXBlPXtjb250ZW50VHlwZX1cbiAgICAgICAgICAgIHNob3dBZGRpdGlvbmFsUmVzb3VyY2VzPXtzaG93QWRkaXRpb25hbFJlc291cmNlc31cbiAgICAgICAgICAgIHNob3dBZGRUb0Zhdm9yaXRlQnV0dG9uPXtzaG93QWRkVG9GYXZvcml0ZUJ1dHRvbn1cbiAgICAgICAgICAgIG9uVG9nZ2xlQWRkVG9GYXZvcml0ZXM9e29uVG9nZ2xlQWRkVG9GYXZvcml0ZXN9XG4gICAgICAgICAgICB7Li4ucmVzb3VyY2V9XG4gICAgICAgICAgICBjb250ZW50VHlwZURlc2NyaXB0aW9uPXtcbiAgICAgICAgICAgICAgcmVzb3VyY2UuYWRkaXRpb25hbCA/IHQoJ3Jlc291cmNlLnRvb2x0aXBBZGRpdGlvbmFsVG9waWMnKSA6IHQoJ3Jlc291cmNlLnRvb2x0aXBDb3JlVG9waWMnKVxuICAgICAgICAgICAgfVxuICAgICAgICAgIC8+XG4gICAgICAgICkpfVxuICAgICAgICB7cmVuZGVyQWRkaXRpb25hbFJlc291cmNlVHJpZ2dlciAmJiAoXG4gICAgICAgICAgPGxpPlxuICAgICAgICAgICAgPE5vQ29udGVudEJveFxuICAgICAgICAgICAgICBvbkNsaWNrPXtvbkNsaWNrfVxuICAgICAgICAgICAgICBidXR0b25UZXh0PXt0KCdyZXNvdXJjZS50b2dnbGVGaWx0ZXJMYWJlbCcpfVxuICAgICAgICAgICAgICB0ZXh0PXtcbiAgICAgICAgICAgICAgICB0aXRsZVxuICAgICAgICAgICAgICAgICAgPyB0KCdyZXNvdXJjZS5ub0NvcmVSZXNvdXJjZXNBdmFpbGFibGUnLCB7XG4gICAgICAgICAgICAgICAgICAgICAgbmFtZTogdGl0bGUudG9Mb3dlckNhc2UoKSxcbiAgICAgICAgICAgICAgICAgICAgfSlcbiAgICAgICAgICAgICAgICAgIDogdCgncmVzb3VyY2Uubm9Db3JlUmVzb3VyY2VzQXZhaWxhYmxlVW5zcGVjaWZpYycpXG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgPC9saT5cbiAgICAgICAgKX1cbiAgICAgIDwvU3R5bGVkUmVzb3VyY2VMaXN0PlxuICAgIDwvZGl2PlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgUmVzb3VyY2VMaXN0O1xuIl19 */");
50
50
 
51
51
  var ResourceList = function ResourceList(_ref2) {
52
52
  var resources = _ref2.resources,
@@ -135,7 +135,6 @@ var ContentTypeResult = function ContentTypeResult(_ref) {
135
135
  key: path,
136
136
  delayAnimation: delayAnimation
137
137
  }, (0, _core.jsx)(_safelink["default"], _extends({
138
- tabIndex: -1,
139
138
  css: shouldHighlight && _ContentTypeResultStyles.highlightStyle,
140
139
  "data-highlighted": shouldHighlight || false
141
140
  }, linkProps, {
@@ -154,7 +153,7 @@ var ContentTypeResult = function ContentTypeResult(_ref) {
154
153
  ref: showAllRef
155
154
  }, (0, _core.jsx)(_button["default"], {
156
155
  ghostPill: true,
157
- css: /*#__PURE__*/(0, _css2["default"])([_ContentTypeResultStyles.showAllButtonStyle, shouldHighlightShowAllButton && _ContentTypeResultStyles.noWidthhighlightStyle], ";label:ContentTypeResult;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContentTypeResult.tsx"],"names":[],"mappings":"AAyJgB","file":"ContentTypeResult.tsx","sourcesContent":["import Button from '@ndla/button';\nimport { Additional, ChevronDown, ChevronUp } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\nimport Tooltip from '@ndla/tooltip';\nimport React, { ReactElement, useEffect, useRef, useState } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport { ContentTypeResultType, Resource } from '../types';\nimport {\n  highlightStyle,\n  noWidthhighlightStyle,\n  showAllButtonStyle,\n  StyledHeader,\n  StyledList,\n  StyledListItem,\n  StyledNoHit,\n  StyledTag,\n  StyledWrapper,\n} from './ContentTypeResultStyles';\nimport { isPathToHighlight } from './IsPathToHighlight';\n\nconst renderAdditionalIcon = (label: string, isAdditional?: boolean): ReactElement | null => {\n  if (isAdditional && label) {\n    return (\n      <Tooltip tooltip={label}>\n        <Additional className=\"c-icon--20\" />\n      </Tooltip>\n    );\n  }\n  if (isAdditional) {\n    return <Additional className=\"c-icon--20\" />;\n  }\n  return null;\n};\n\ntype Props = {\n  contentTypeResult: ContentTypeResultType;\n  onNavigate?: VoidFunction;\n  defaultCount?: number;\n  resourceToLinkProps: (resource: Resource) => {\n    to: string;\n  };\n  showAdditionalResources?: boolean;\n  messages: {\n    allResultLabel?: string;\n    showLessResultLabel?: string;\n    noHit: string;\n  };\n  ignoreContentTypeBadge?: boolean;\n  keyboardPathNavigation?: HTMLElement | string | null;\n  inMenu?: boolean;\n  animateList?: number;\n  unGrouped?: boolean;\n};\n\nconst ContentTypeResult = ({\n  contentTypeResult,\n  onNavigate,\n  defaultCount,\n  resourceToLinkProps,\n  showAdditionalResources,\n  messages,\n  ignoreContentTypeBadge,\n  keyboardPathNavigation,\n  inMenu,\n  animateList,\n  unGrouped,\n}: Props) => {\n  const { t } = useTranslation();\n  const [showAll, toggleShowAll] = useState(false);\n  const showAllRef = useRef<HTMLLIElement>(null);\n\n  const results =\n    showAdditionalResources || !contentTypeResult.resources\n      ? contentTypeResult.resources\n      : contentTypeResult.resources.filter((items) => !items.additional);\n\n  const resources = showAll || !defaultCount ? results : results.slice(0, defaultCount);\n\n  const displayShowAllButton = defaultCount && results.length > defaultCount;\n  const shouldHighlightShowAllButton = showAllRef.current === keyboardPathNavigation;\n\n  useEffect(() => {\n    if (showAll && showAllRef.current) {\n      showAllRef.current.scrollIntoView({\n        behavior: 'smooth',\n        block: 'nearest',\n      });\n    }\n  }, [showAll]);\n\n  return (\n    <StyledWrapper>\n      {!unGrouped && (\n        <StyledHeader>\n          {!ignoreContentTypeBadge && contentTypeResult.contentType && (\n            <ContentTypeBadge type={contentTypeResult.contentType} size=\"x-small\" background border />\n          )}\n          <h1>\n            {contentTypeResult.title} <small>({results.length})</small>\n          </h1>\n        </StyledHeader>\n      )}\n      {resources.length > 0 ? (\n        <StyledList inMenu={inMenu} animateList={animateList} unGrouped={unGrouped}>\n          {resources.map((resource) => {\n            const { path, name, resourceTypes, subject, additional } = resource;\n\n            const linkProps = resourceToLinkProps(resource);\n            const linkContent = (\n              <>\n                <strong>{name}</strong>\n                {!inMenu && subject && <small>{subject}</small>}\n                {!inMenu &&\n                  resourceTypes &&\n                  resourceTypes.map((type) => <StyledTag key={type.name}>{type.name}</StyledTag>)}\n              </>\n            );\n            const delayAnimation = !!animateList && !!additional && animateList > 0 && !!showAdditionalResources;\n\n            // Figure out highlighting by comparing path of link with keyboard navigated anchor\n            const anchor =\n              keyboardPathNavigation instanceof HTMLElement &&\n              keyboardPathNavigation &&\n              keyboardPathNavigation.querySelector('a');\n            const anchorHref = anchor && anchor.getAttribute('href');\n            const shouldHighlight = isPathToHighlight(path, anchorHref);\n\n            return (\n              <StyledListItem key={path} delayAnimation={delayAnimation}>\n                <SafeLink\n                  tabIndex={-1}\n                  css={shouldHighlight && highlightStyle}\n                  data-highlighted={shouldHighlight || false}\n                  {...linkProps}\n                  onClick={() => {\n                    if (onNavigate) {\n                      onNavigate();\n                    }\n                  }}>\n                  {unGrouped && !ignoreContentTypeBadge && (\n                    <ContentTypeBadge type={resource.contentType ?? ''} size=\"x-small\" background border />\n                  )}\n                  {linkContent}\n                  {renderAdditionalIcon(t('resource.additionalTooltip'), additional)}\n                </SafeLink>\n              </StyledListItem>\n            );\n          })}\n          {displayShowAllButton && (\n            <StyledListItem ref={showAllRef}>\n              <Button\n                ghostPill\n                css={[showAllButtonStyle, shouldHighlightShowAllButton && noWidthhighlightStyle]}\n                data-highlighted={shouldHighlightShowAllButton}\n                onClick={() => toggleShowAll(!showAll)}\n                tabIndex={-1}>\n                {showAll ? messages.showLessResultLabel : messages.allResultLabel}\n                {showAll ? <ChevronUp /> : <ChevronDown />}\n              </Button>\n            </StyledListItem>\n          )}\n        </StyledList>\n      ) : (\n        <StyledNoHit inMenu={inMenu}>{messages.noHit}</StyledNoHit>\n      )}\n    </StyledWrapper>\n  );\n};\n\nexport default ContentTypeResult;\n"]} */")),
156
+ css: /*#__PURE__*/(0, _css2["default"])([_ContentTypeResultStyles.showAllButtonStyle, shouldHighlightShowAllButton && _ContentTypeResultStyles.noWidthhighlightStyle], ";label:ContentTypeResult;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["ContentTypeResult.tsx"],"names":[],"mappings":"AAwJgB","file":"ContentTypeResult.tsx","sourcesContent":["import Button from '@ndla/button';\nimport { Additional, ChevronDown, ChevronUp } from '@ndla/icons/common';\nimport SafeLink from '@ndla/safelink';\nimport Tooltip from '@ndla/tooltip';\nimport React, { ReactElement, useEffect, useRef, useState } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport ContentTypeBadge from '../ContentTypeBadge';\nimport { ContentTypeResultType, Resource } from '../types';\nimport {\n  highlightStyle,\n  noWidthhighlightStyle,\n  showAllButtonStyle,\n  StyledHeader,\n  StyledList,\n  StyledListItem,\n  StyledNoHit,\n  StyledTag,\n  StyledWrapper,\n} from './ContentTypeResultStyles';\nimport { isPathToHighlight } from './IsPathToHighlight';\n\nconst renderAdditionalIcon = (label: string, isAdditional?: boolean): ReactElement | null => {\n  if (isAdditional && label) {\n    return (\n      <Tooltip tooltip={label}>\n        <Additional className=\"c-icon--20\" />\n      </Tooltip>\n    );\n  }\n  if (isAdditional) {\n    return <Additional className=\"c-icon--20\" />;\n  }\n  return null;\n};\n\ntype Props = {\n  contentTypeResult: ContentTypeResultType;\n  onNavigate?: VoidFunction;\n  defaultCount?: number;\n  resourceToLinkProps: (resource: Resource) => {\n    to: string;\n  };\n  showAdditionalResources?: boolean;\n  messages: {\n    allResultLabel?: string;\n    showLessResultLabel?: string;\n    noHit: string;\n  };\n  ignoreContentTypeBadge?: boolean;\n  keyboardPathNavigation?: HTMLElement | string | null;\n  inMenu?: boolean;\n  animateList?: number;\n  unGrouped?: boolean;\n};\n\nconst ContentTypeResult = ({\n  contentTypeResult,\n  onNavigate,\n  defaultCount,\n  resourceToLinkProps,\n  showAdditionalResources,\n  messages,\n  ignoreContentTypeBadge,\n  keyboardPathNavigation,\n  inMenu,\n  animateList,\n  unGrouped,\n}: Props) => {\n  const { t } = useTranslation();\n  const [showAll, toggleShowAll] = useState(false);\n  const showAllRef = useRef<HTMLLIElement>(null);\n\n  const results =\n    showAdditionalResources || !contentTypeResult.resources\n      ? contentTypeResult.resources\n      : contentTypeResult.resources.filter((items) => !items.additional);\n\n  const resources = showAll || !defaultCount ? results : results.slice(0, defaultCount);\n\n  const displayShowAllButton = defaultCount && results.length > defaultCount;\n  const shouldHighlightShowAllButton = showAllRef.current === keyboardPathNavigation;\n\n  useEffect(() => {\n    if (showAll && showAllRef.current) {\n      showAllRef.current.scrollIntoView({\n        behavior: 'smooth',\n        block: 'nearest',\n      });\n    }\n  }, [showAll]);\n\n  return (\n    <StyledWrapper>\n      {!unGrouped && (\n        <StyledHeader>\n          {!ignoreContentTypeBadge && contentTypeResult.contentType && (\n            <ContentTypeBadge type={contentTypeResult.contentType} size=\"x-small\" background border />\n          )}\n          <h1>\n            {contentTypeResult.title} <small>({results.length})</small>\n          </h1>\n        </StyledHeader>\n      )}\n      {resources.length > 0 ? (\n        <StyledList inMenu={inMenu} animateList={animateList} unGrouped={unGrouped}>\n          {resources.map((resource) => {\n            const { path, name, resourceTypes, subject, additional } = resource;\n\n            const linkProps = resourceToLinkProps(resource);\n            const linkContent = (\n              <>\n                <strong>{name}</strong>\n                {!inMenu && subject && <small>{subject}</small>}\n                {!inMenu &&\n                  resourceTypes &&\n                  resourceTypes.map((type) => <StyledTag key={type.name}>{type.name}</StyledTag>)}\n              </>\n            );\n            const delayAnimation = !!animateList && !!additional && animateList > 0 && !!showAdditionalResources;\n\n            // Figure out highlighting by comparing path of link with keyboard navigated anchor\n            const anchor =\n              keyboardPathNavigation instanceof HTMLElement &&\n              keyboardPathNavigation &&\n              keyboardPathNavigation.querySelector('a');\n            const anchorHref = anchor && anchor.getAttribute('href');\n            const shouldHighlight = isPathToHighlight(path, anchorHref);\n\n            return (\n              <StyledListItem key={path} delayAnimation={delayAnimation}>\n                <SafeLink\n                  css={shouldHighlight && highlightStyle}\n                  data-highlighted={shouldHighlight || false}\n                  {...linkProps}\n                  onClick={() => {\n                    if (onNavigate) {\n                      onNavigate();\n                    }\n                  }}>\n                  {unGrouped && !ignoreContentTypeBadge && (\n                    <ContentTypeBadge type={resource.contentType ?? ''} size=\"x-small\" background border />\n                  )}\n                  {linkContent}\n                  {renderAdditionalIcon(t('resource.additionalTooltip'), additional)}\n                </SafeLink>\n              </StyledListItem>\n            );\n          })}\n          {displayShowAllButton && (\n            <StyledListItem ref={showAllRef}>\n              <Button\n                ghostPill\n                css={[showAllButtonStyle, shouldHighlightShowAllButton && noWidthhighlightStyle]}\n                data-highlighted={shouldHighlightShowAllButton}\n                onClick={() => toggleShowAll(!showAll)}\n                tabIndex={-1}>\n                {showAll ? messages.showLessResultLabel : messages.allResultLabel}\n                {showAll ? <ChevronUp /> : <ChevronDown />}\n              </Button>\n            </StyledListItem>\n          )}\n        </StyledList>\n      ) : (\n        <StyledNoHit inMenu={inMenu}>{messages.noHit}</StyledNoHit>\n      )}\n    </StyledWrapper>\n  );\n};\n\nexport default ContentTypeResult;\n"]} */")),
158
157
  "data-highlighted": shouldHighlightShowAllButton,
159
158
  onClick: function onClick() {
160
159
  return toggleShowAll(!showAll);
@@ -69,13 +69,13 @@ var Container = (0, _styledBase["default"])("div", {
69
69
  } : {
70
70
  name: "1f9iwsz",
71
71
  styles: "display:flex;height:400px;align-items:center;justify-content:center;",
72
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAiD4B","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport SafeLink from '@ndla/safelink';\nimport { animations, colors, fonts, spacing } from '@ndla/core';\n\nimport { ContentType } from './SearchTypeResult';\nimport constants from '../model';\nimport ItemContexts, { ItemContextsType } from './components/ItemContexts';\nimport ItemTopicHeader from './components/ItemTopicHeader';\nimport ItemResourceHeader from './components/ItemResourceHeader';\n\nconst { contentTypes } = constants;\n\nexport const resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return '';\n  }\n};\n\ntype ItemTypeProps = {\n  contentType?: ContentType;\n  isTopic?: boolean;\n};\n\nconst Container = styled.div`\n  display: flex;\n  height: 400px;\n  align-items: center;\n  justify-content: center;\n`;\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n  display: flex;\n  width: 100%;\n  height: 100%;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 5px;\n  transition: all ${animations.durations.fast} ease-in-out;\n  &:hover {\n    height: calc(100% + 4px);\n    width: calc(100% + 4px);\n    .topic-header-image {\n      height: calc(100% + 6px);\n      width: calc(100% + 6px);\n    }\n    .topic-label {\n      svg {\n        transform: scale(1.2);\n      }\n    }\n    .topic-label-list {\n      margin-left: 2px;\n    }\n    .resource-type-wrapper {\n      padding: 0 calc(${spacing.normal} + 2px);\n      .resource-icon-wrapper {\n        left: 19px;\n        svg {\n          transform: scale(1.2);\n        }\n      }\n    }\n    .resource-no-image {\n      background-color: ${colors.brand.greyLightest};\n      .c-content-type-badge {\n        width: 26px;\n        height: 26px;\n        left: 45px;\n        margin-left: 0;\n        top: 100%;\n        margin-top: -13px;\n        opacity: 1;\n      }\n    }\n  }\n`;\n\nconst ItemLink = styled(SafeLink)`\n  box-shadow: none;\n  color: unset;\n  text-decoration: none;\n  display: flex;\n  flex-direction: column;\n  position: relative;\n  min-height: 0;\n  flex: 1;\n`;\n\nconst TextWrapper = styled.div`\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n`;\n\nconst ItemTitleWrapper = styled.div<ItemTypeProps>`\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `${ItemWrapper}:hover & {\n    padding-left:2px; padding-right: 2px;}`};\n`;\n\nconst ItemTitle = styled.h3<ItemTypeProps>`\n  ${fonts.sizes('24px', '28px')};\n  color: ${colors.brand.primary};\n  ${(props) => props.isTopic && `margin-bottom: ${spacing.small};`};\n  font-weight: ${fonts.weight.semibold};\n  overflow-wrap: anywhere;\n  display: inline;\n  ${ItemWrapper}:hover & {\n    box-shadow: inset 0 -1px;\n    background-color: transparent;\n  }\n`;\nconst ItemText = styled.div<ItemTypeProps>`\n  overflow: hidden;\n  ${fonts.sizes('16px', '24px')};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `\n    ${fonts.sizes('18px', '28px')};\n    `};\n`;\n\nconst ContextWrapper = styled.div`\n  background: white;\n  z-index: 1;\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n    padding-bottom: calc(${spacing.small} + 2px);\n  }\n`;\n\nexport type SearchItemProps = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: ItemContextsType['contexts'];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  type?: ContentType;\n  children?: ReactNode;\n};\nexport type SearchItemType = {\n  item: SearchItemProps;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: SearchItemType) => {\n  const { title, url, ingress, contexts, img = null, labels = [], children } = item;\n\n  const isTopic = type === contentTypes.TOPIC || type === contentTypes.MULTIDISCIPLINARY_TOPIC;\n\n  return (\n    <Container>\n      <ItemWrapper>\n        <ItemLink to={url}>\n          {isTopic ? (\n            <ItemTopicHeader image={img} type={type}>\n              <ItemTitleWrapper isTopic>\n                <ItemTitle isTopic>{title}</ItemTitle>\n              </ItemTitleWrapper>\n              <ItemText isTopic>{parse(ingress)}</ItemText>\n            </ItemTopicHeader>\n          ) : (\n            <>\n              <ItemResourceHeader labels={labels} img={img} type={type} />\n              <TextWrapper>\n                <ItemTitleWrapper>\n                  <ItemTitle>{title}</ItemTitle>\n                </ItemTitleWrapper>\n                <ItemText>{parse(ingress)}</ItemText>\n              </TextWrapper>\n            </>\n          )}\n          <ContextWrapper>\n            {contexts && contexts.length > 0 && <ItemContexts contexts={contexts} id={item.id} title={item.title} />}\n          </ContextWrapper>\n        </ItemLink>\n        {children}\n      </ItemWrapper>\n    </Container>\n  );\n};\n\nexport default SearchItem;\n"]} */",
72
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAiD4B","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport SafeLink from '@ndla/safelink';\nimport { animations, colors, fonts, spacing } from '@ndla/core';\n\nimport { ContentType } from './SearchTypeResult';\nimport constants from '../model';\nimport ItemContexts, { ItemContextsType } from './components/ItemContexts';\nimport ItemTopicHeader from './components/ItemTopicHeader';\nimport ItemResourceHeader from './components/ItemResourceHeader';\n\nconst { contentTypes } = constants;\n\nexport const resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return '';\n  }\n};\n\ntype ItemTypeProps = {\n  contentType?: ContentType;\n  isTopic?: boolean;\n};\n\nconst Container = styled.div`\n  display: flex;\n  height: 400px;\n  align-items: center;\n  justify-content: center;\n`;\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n  display: flex;\n  width: 100%;\n  height: 100%;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 5px;\n  transition: all ${animations.durations.fast} ease-in-out;\n  &:hover {\n    height: calc(100% + 4px);\n    width: calc(100% + 4px);\n    .topic-header-image {\n      height: calc(100% + 6px);\n      width: calc(100% + 6px);\n    }\n    .topic-label {\n      svg {\n        transform: scale(1.2);\n      }\n    }\n    .topic-label-list {\n      margin-left: 2px;\n    }\n    .resource-type-wrapper {\n      padding: 0 calc(${spacing.normal} + 2px);\n      .resource-icon-wrapper {\n        left: 19px;\n        svg {\n          transform: scale(1.2);\n        }\n      }\n    }\n    .resource-no-image {\n      background-color: ${colors.brand.greyLightest};\n      .c-content-type-badge {\n        width: 26px;\n        height: 26px;\n        left: 45px;\n        margin-left: 0;\n        top: 100%;\n        margin-top: -13px;\n        opacity: 1;\n      }\n    }\n  }\n`;\n\nconst ItemLink = styled(SafeLink)`\n  box-shadow: none;\n  color: unset;\n  text-decoration: none;\n  display: flex;\n  flex-direction: column;\n  position: relative;\n  min-height: 0;\n  flex: 1;\n`;\n\nconst TextWrapper = styled.div`\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n`;\n\nconst ItemTitleWrapper = styled.div<ItemTypeProps>`\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `${ItemWrapper}:hover & {\n    padding-left:2px; padding-right: 2px;}`};\n`;\n\nconst ItemTitle = styled.h3<ItemTypeProps>`\n  ${fonts.sizes('24px', '28px')};\n  color: ${colors.brand.primary};\n  ${(props) => props.isTopic && `margin-bottom: ${spacing.small};`};\n  font-weight: ${fonts.weight.semibold};\n  overflow-wrap: anywhere;\n  display: inline;\n  ${ItemWrapper}:hover & {\n    box-shadow: inset 0 -1px;\n    background-color: transparent;\n  }\n`;\nconst ItemText = styled.div<ItemTypeProps>`\n  overflow: hidden;\n  ${fonts.sizes('16px', '24px')};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `\n    ${fonts.sizes('18px', '28px')};\n    `};\n`;\n\nconst ContextWrapper = styled.div`\n  background: white;\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n    padding-bottom: calc(${spacing.small} + 2px);\n  }\n`;\n\nexport type SearchItemProps = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: ItemContextsType['contexts'];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  type?: ContentType;\n  children?: ReactNode;\n};\nexport type SearchItemType = {\n  item: SearchItemProps;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: SearchItemType) => {\n  const { title, url, ingress, contexts, img = null, labels = [], children } = item;\n\n  const isTopic = type === contentTypes.TOPIC || type === contentTypes.MULTIDISCIPLINARY_TOPIC;\n\n  return (\n    <Container>\n      <ItemWrapper>\n        <ItemLink to={url}>\n          {isTopic ? (\n            <ItemTopicHeader image={img} type={type}>\n              <ItemTitleWrapper isTopic>\n                <ItemTitle isTopic>{title}</ItemTitle>\n              </ItemTitleWrapper>\n              <ItemText isTopic>{parse(ingress)}</ItemText>\n            </ItemTopicHeader>\n          ) : (\n            <>\n              <ItemResourceHeader labels={labels} img={img} type={type} />\n              <TextWrapper>\n                <ItemTitleWrapper>\n                  <ItemTitle>{title}</ItemTitle>\n                </ItemTitleWrapper>\n                <ItemText>{parse(ingress)}</ItemText>\n              </TextWrapper>\n            </>\n          )}\n          <ContextWrapper>\n            {contexts && contexts.length > 0 && <ItemContexts contexts={contexts} id={item.id} title={item.title} />}\n          </ContextWrapper>\n        </ItemLink>\n        {children}\n      </ItemWrapper>\n    </Container>\n  );\n};\n\nexport default SearchItem;\n"]} */",
73
73
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
74
74
  });
75
75
  var ItemWrapper = (0, _styledBase["default"])("div", {
76
76
  target: "e1hz9lam1",
77
77
  label: "ItemWrapper"
78
- })("flex-direction:column;display:flex;width:100%;height:100%;border:1px solid ", _core.colors.brand.neutral7, ";border-radius:5px;transition:all ", _core.animations.durations.fast, " ease-in-out;&:hover{height:calc(100% + 4px);width:calc(100% + 4px);.topic-header-image{height:calc(100% + 6px);width:calc(100% + 6px);}.topic-label{svg{transform:scale(1.2);}}.topic-label-list{margin-left:2px;}.resource-type-wrapper{padding:0 calc(", _core.spacing.normal, " + 2px);.resource-icon-wrapper{left:19px;svg{transform:scale(1.2);}}}.resource-no-image{background-color:", _core.colors.brand.greyLightest, ";.c-content-type-badge{width:26px;height:26px;left:45px;margin-left:0;top:100%;margin-top:-13px;opacity:1;}}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAwD8B","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport SafeLink from '@ndla/safelink';\nimport { animations, colors, fonts, spacing } from '@ndla/core';\n\nimport { ContentType } from './SearchTypeResult';\nimport constants from '../model';\nimport ItemContexts, { ItemContextsType } from './components/ItemContexts';\nimport ItemTopicHeader from './components/ItemTopicHeader';\nimport ItemResourceHeader from './components/ItemResourceHeader';\n\nconst { contentTypes } = constants;\n\nexport const resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return '';\n  }\n};\n\ntype ItemTypeProps = {\n  contentType?: ContentType;\n  isTopic?: boolean;\n};\n\nconst Container = styled.div`\n  display: flex;\n  height: 400px;\n  align-items: center;\n  justify-content: center;\n`;\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n  display: flex;\n  width: 100%;\n  height: 100%;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 5px;\n  transition: all ${animations.durations.fast} ease-in-out;\n  &:hover {\n    height: calc(100% + 4px);\n    width: calc(100% + 4px);\n    .topic-header-image {\n      height: calc(100% + 6px);\n      width: calc(100% + 6px);\n    }\n    .topic-label {\n      svg {\n        transform: scale(1.2);\n      }\n    }\n    .topic-label-list {\n      margin-left: 2px;\n    }\n    .resource-type-wrapper {\n      padding: 0 calc(${spacing.normal} + 2px);\n      .resource-icon-wrapper {\n        left: 19px;\n        svg {\n          transform: scale(1.2);\n        }\n      }\n    }\n    .resource-no-image {\n      background-color: ${colors.brand.greyLightest};\n      .c-content-type-badge {\n        width: 26px;\n        height: 26px;\n        left: 45px;\n        margin-left: 0;\n        top: 100%;\n        margin-top: -13px;\n        opacity: 1;\n      }\n    }\n  }\n`;\n\nconst ItemLink = styled(SafeLink)`\n  box-shadow: none;\n  color: unset;\n  text-decoration: none;\n  display: flex;\n  flex-direction: column;\n  position: relative;\n  min-height: 0;\n  flex: 1;\n`;\n\nconst TextWrapper = styled.div`\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n`;\n\nconst ItemTitleWrapper = styled.div<ItemTypeProps>`\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `${ItemWrapper}:hover & {\n    padding-left:2px; padding-right: 2px;}`};\n`;\n\nconst ItemTitle = styled.h3<ItemTypeProps>`\n  ${fonts.sizes('24px', '28px')};\n  color: ${colors.brand.primary};\n  ${(props) => props.isTopic && `margin-bottom: ${spacing.small};`};\n  font-weight: ${fonts.weight.semibold};\n  overflow-wrap: anywhere;\n  display: inline;\n  ${ItemWrapper}:hover & {\n    box-shadow: inset 0 -1px;\n    background-color: transparent;\n  }\n`;\nconst ItemText = styled.div<ItemTypeProps>`\n  overflow: hidden;\n  ${fonts.sizes('16px', '24px')};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `\n    ${fonts.sizes('18px', '28px')};\n    `};\n`;\n\nconst ContextWrapper = styled.div`\n  background: white;\n  z-index: 1;\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n    padding-bottom: calc(${spacing.small} + 2px);\n  }\n`;\n\nexport type SearchItemProps = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: ItemContextsType['contexts'];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  type?: ContentType;\n  children?: ReactNode;\n};\nexport type SearchItemType = {\n  item: SearchItemProps;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: SearchItemType) => {\n  const { title, url, ingress, contexts, img = null, labels = [], children } = item;\n\n  const isTopic = type === contentTypes.TOPIC || type === contentTypes.MULTIDISCIPLINARY_TOPIC;\n\n  return (\n    <Container>\n      <ItemWrapper>\n        <ItemLink to={url}>\n          {isTopic ? (\n            <ItemTopicHeader image={img} type={type}>\n              <ItemTitleWrapper isTopic>\n                <ItemTitle isTopic>{title}</ItemTitle>\n              </ItemTitleWrapper>\n              <ItemText isTopic>{parse(ingress)}</ItemText>\n            </ItemTopicHeader>\n          ) : (\n            <>\n              <ItemResourceHeader labels={labels} img={img} type={type} />\n              <TextWrapper>\n                <ItemTitleWrapper>\n                  <ItemTitle>{title}</ItemTitle>\n                </ItemTitleWrapper>\n                <ItemText>{parse(ingress)}</ItemText>\n              </TextWrapper>\n            </>\n          )}\n          <ContextWrapper>\n            {contexts && contexts.length > 0 && <ItemContexts contexts={contexts} id={item.id} title={item.title} />}\n          </ContextWrapper>\n        </ItemLink>\n        {children}\n      </ItemWrapper>\n    </Container>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
78
+ })("flex-direction:column;display:flex;width:100%;height:100%;border:1px solid ", _core.colors.brand.neutral7, ";border-radius:5px;transition:all ", _core.animations.durations.fast, " ease-in-out;&:hover{height:calc(100% + 4px);width:calc(100% + 4px);.topic-header-image{height:calc(100% + 6px);width:calc(100% + 6px);}.topic-label{svg{transform:scale(1.2);}}.topic-label-list{margin-left:2px;}.resource-type-wrapper{padding:0 calc(", _core.spacing.normal, " + 2px);.resource-icon-wrapper{left:19px;svg{transform:scale(1.2);}}}.resource-no-image{background-color:", _core.colors.brand.greyLightest, ";.c-content-type-badge{width:26px;height:26px;left:45px;margin-left:0;top:100%;margin-top:-13px;opacity:1;}}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAwD8B","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport SafeLink from '@ndla/safelink';\nimport { animations, colors, fonts, spacing } from '@ndla/core';\n\nimport { ContentType } from './SearchTypeResult';\nimport constants from '../model';\nimport ItemContexts, { ItemContextsType } from './components/ItemContexts';\nimport ItemTopicHeader from './components/ItemTopicHeader';\nimport ItemResourceHeader from './components/ItemResourceHeader';\n\nconst { contentTypes } = constants;\n\nexport const resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return '';\n  }\n};\n\ntype ItemTypeProps = {\n  contentType?: ContentType;\n  isTopic?: boolean;\n};\n\nconst Container = styled.div`\n  display: flex;\n  height: 400px;\n  align-items: center;\n  justify-content: center;\n`;\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n  display: flex;\n  width: 100%;\n  height: 100%;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 5px;\n  transition: all ${animations.durations.fast} ease-in-out;\n  &:hover {\n    height: calc(100% + 4px);\n    width: calc(100% + 4px);\n    .topic-header-image {\n      height: calc(100% + 6px);\n      width: calc(100% + 6px);\n    }\n    .topic-label {\n      svg {\n        transform: scale(1.2);\n      }\n    }\n    .topic-label-list {\n      margin-left: 2px;\n    }\n    .resource-type-wrapper {\n      padding: 0 calc(${spacing.normal} + 2px);\n      .resource-icon-wrapper {\n        left: 19px;\n        svg {\n          transform: scale(1.2);\n        }\n      }\n    }\n    .resource-no-image {\n      background-color: ${colors.brand.greyLightest};\n      .c-content-type-badge {\n        width: 26px;\n        height: 26px;\n        left: 45px;\n        margin-left: 0;\n        top: 100%;\n        margin-top: -13px;\n        opacity: 1;\n      }\n    }\n  }\n`;\n\nconst ItemLink = styled(SafeLink)`\n  box-shadow: none;\n  color: unset;\n  text-decoration: none;\n  display: flex;\n  flex-direction: column;\n  position: relative;\n  min-height: 0;\n  flex: 1;\n`;\n\nconst TextWrapper = styled.div`\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n`;\n\nconst ItemTitleWrapper = styled.div<ItemTypeProps>`\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `${ItemWrapper}:hover & {\n    padding-left:2px; padding-right: 2px;}`};\n`;\n\nconst ItemTitle = styled.h3<ItemTypeProps>`\n  ${fonts.sizes('24px', '28px')};\n  color: ${colors.brand.primary};\n  ${(props) => props.isTopic && `margin-bottom: ${spacing.small};`};\n  font-weight: ${fonts.weight.semibold};\n  overflow-wrap: anywhere;\n  display: inline;\n  ${ItemWrapper}:hover & {\n    box-shadow: inset 0 -1px;\n    background-color: transparent;\n  }\n`;\nconst ItemText = styled.div<ItemTypeProps>`\n  overflow: hidden;\n  ${fonts.sizes('16px', '24px')};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `\n    ${fonts.sizes('18px', '28px')};\n    `};\n`;\n\nconst ContextWrapper = styled.div`\n  background: white;\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n    padding-bottom: calc(${spacing.small} + 2px);\n  }\n`;\n\nexport type SearchItemProps = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: ItemContextsType['contexts'];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  type?: ContentType;\n  children?: ReactNode;\n};\nexport type SearchItemType = {\n  item: SearchItemProps;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: SearchItemType) => {\n  const { title, url, ingress, contexts, img = null, labels = [], children } = item;\n\n  const isTopic = type === contentTypes.TOPIC || type === contentTypes.MULTIDISCIPLINARY_TOPIC;\n\n  return (\n    <Container>\n      <ItemWrapper>\n        <ItemLink to={url}>\n          {isTopic ? (\n            <ItemTopicHeader image={img} type={type}>\n              <ItemTitleWrapper isTopic>\n                <ItemTitle isTopic>{title}</ItemTitle>\n              </ItemTitleWrapper>\n              <ItemText isTopic>{parse(ingress)}</ItemText>\n            </ItemTopicHeader>\n          ) : (\n            <>\n              <ItemResourceHeader labels={labels} img={img} type={type} />\n              <TextWrapper>\n                <ItemTitleWrapper>\n                  <ItemTitle>{title}</ItemTitle>\n                </ItemTitleWrapper>\n                <ItemText>{parse(ingress)}</ItemText>\n              </TextWrapper>\n            </>\n          )}\n          <ContextWrapper>\n            {contexts && contexts.length > 0 && <ItemContexts contexts={contexts} id={item.id} title={item.title} />}\n          </ContextWrapper>\n        </ItemLink>\n        {children}\n      </ItemWrapper>\n    </Container>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
79
79
  var ItemLink = ( /*#__PURE__*/0, _styledBase["default"])(_safelink["default"], {
80
80
  target: "e1hz9lam2",
81
81
  label: "ItemLink"
@@ -85,35 +85,35 @@ var ItemLink = ( /*#__PURE__*/0, _styledBase["default"])(_safelink["default"], {
85
85
  } : {
86
86
  name: "lqgaa6",
87
87
  styles: "box-shadow:none;color:unset;text-decoration:none;display:flex;flex-direction:column;position:relative;min-height:0;flex:1;",
88
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAuGiC","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport SafeLink from '@ndla/safelink';\nimport { animations, colors, fonts, spacing } from '@ndla/core';\n\nimport { ContentType } from './SearchTypeResult';\nimport constants from '../model';\nimport ItemContexts, { ItemContextsType } from './components/ItemContexts';\nimport ItemTopicHeader from './components/ItemTopicHeader';\nimport ItemResourceHeader from './components/ItemResourceHeader';\n\nconst { contentTypes } = constants;\n\nexport const resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return '';\n  }\n};\n\ntype ItemTypeProps = {\n  contentType?: ContentType;\n  isTopic?: boolean;\n};\n\nconst Container = styled.div`\n  display: flex;\n  height: 400px;\n  align-items: center;\n  justify-content: center;\n`;\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n  display: flex;\n  width: 100%;\n  height: 100%;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 5px;\n  transition: all ${animations.durations.fast} ease-in-out;\n  &:hover {\n    height: calc(100% + 4px);\n    width: calc(100% + 4px);\n    .topic-header-image {\n      height: calc(100% + 6px);\n      width: calc(100% + 6px);\n    }\n    .topic-label {\n      svg {\n        transform: scale(1.2);\n      }\n    }\n    .topic-label-list {\n      margin-left: 2px;\n    }\n    .resource-type-wrapper {\n      padding: 0 calc(${spacing.normal} + 2px);\n      .resource-icon-wrapper {\n        left: 19px;\n        svg {\n          transform: scale(1.2);\n        }\n      }\n    }\n    .resource-no-image {\n      background-color: ${colors.brand.greyLightest};\n      .c-content-type-badge {\n        width: 26px;\n        height: 26px;\n        left: 45px;\n        margin-left: 0;\n        top: 100%;\n        margin-top: -13px;\n        opacity: 1;\n      }\n    }\n  }\n`;\n\nconst ItemLink = styled(SafeLink)`\n  box-shadow: none;\n  color: unset;\n  text-decoration: none;\n  display: flex;\n  flex-direction: column;\n  position: relative;\n  min-height: 0;\n  flex: 1;\n`;\n\nconst TextWrapper = styled.div`\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n`;\n\nconst ItemTitleWrapper = styled.div<ItemTypeProps>`\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `${ItemWrapper}:hover & {\n    padding-left:2px; padding-right: 2px;}`};\n`;\n\nconst ItemTitle = styled.h3<ItemTypeProps>`\n  ${fonts.sizes('24px', '28px')};\n  color: ${colors.brand.primary};\n  ${(props) => props.isTopic && `margin-bottom: ${spacing.small};`};\n  font-weight: ${fonts.weight.semibold};\n  overflow-wrap: anywhere;\n  display: inline;\n  ${ItemWrapper}:hover & {\n    box-shadow: inset 0 -1px;\n    background-color: transparent;\n  }\n`;\nconst ItemText = styled.div<ItemTypeProps>`\n  overflow: hidden;\n  ${fonts.sizes('16px', '24px')};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `\n    ${fonts.sizes('18px', '28px')};\n    `};\n`;\n\nconst ContextWrapper = styled.div`\n  background: white;\n  z-index: 1;\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n    padding-bottom: calc(${spacing.small} + 2px);\n  }\n`;\n\nexport type SearchItemProps = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: ItemContextsType['contexts'];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  type?: ContentType;\n  children?: ReactNode;\n};\nexport type SearchItemType = {\n  item: SearchItemProps;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: SearchItemType) => {\n  const { title, url, ingress, contexts, img = null, labels = [], children } = item;\n\n  const isTopic = type === contentTypes.TOPIC || type === contentTypes.MULTIDISCIPLINARY_TOPIC;\n\n  return (\n    <Container>\n      <ItemWrapper>\n        <ItemLink to={url}>\n          {isTopic ? (\n            <ItemTopicHeader image={img} type={type}>\n              <ItemTitleWrapper isTopic>\n                <ItemTitle isTopic>{title}</ItemTitle>\n              </ItemTitleWrapper>\n              <ItemText isTopic>{parse(ingress)}</ItemText>\n            </ItemTopicHeader>\n          ) : (\n            <>\n              <ItemResourceHeader labels={labels} img={img} type={type} />\n              <TextWrapper>\n                <ItemTitleWrapper>\n                  <ItemTitle>{title}</ItemTitle>\n                </ItemTitleWrapper>\n                <ItemText>{parse(ingress)}</ItemText>\n              </TextWrapper>\n            </>\n          )}\n          <ContextWrapper>\n            {contexts && contexts.length > 0 && <ItemContexts contexts={contexts} id={item.id} title={item.title} />}\n          </ContextWrapper>\n        </ItemLink>\n        {children}\n      </ItemWrapper>\n    </Container>\n  );\n};\n\nexport default SearchItem;\n"]} */",
88
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAuGiC","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport SafeLink from '@ndla/safelink';\nimport { animations, colors, fonts, spacing } from '@ndla/core';\n\nimport { ContentType } from './SearchTypeResult';\nimport constants from '../model';\nimport ItemContexts, { ItemContextsType } from './components/ItemContexts';\nimport ItemTopicHeader from './components/ItemTopicHeader';\nimport ItemResourceHeader from './components/ItemResourceHeader';\n\nconst { contentTypes } = constants;\n\nexport const resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return '';\n  }\n};\n\ntype ItemTypeProps = {\n  contentType?: ContentType;\n  isTopic?: boolean;\n};\n\nconst Container = styled.div`\n  display: flex;\n  height: 400px;\n  align-items: center;\n  justify-content: center;\n`;\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n  display: flex;\n  width: 100%;\n  height: 100%;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 5px;\n  transition: all ${animations.durations.fast} ease-in-out;\n  &:hover {\n    height: calc(100% + 4px);\n    width: calc(100% + 4px);\n    .topic-header-image {\n      height: calc(100% + 6px);\n      width: calc(100% + 6px);\n    }\n    .topic-label {\n      svg {\n        transform: scale(1.2);\n      }\n    }\n    .topic-label-list {\n      margin-left: 2px;\n    }\n    .resource-type-wrapper {\n      padding: 0 calc(${spacing.normal} + 2px);\n      .resource-icon-wrapper {\n        left: 19px;\n        svg {\n          transform: scale(1.2);\n        }\n      }\n    }\n    .resource-no-image {\n      background-color: ${colors.brand.greyLightest};\n      .c-content-type-badge {\n        width: 26px;\n        height: 26px;\n        left: 45px;\n        margin-left: 0;\n        top: 100%;\n        margin-top: -13px;\n        opacity: 1;\n      }\n    }\n  }\n`;\n\nconst ItemLink = styled(SafeLink)`\n  box-shadow: none;\n  color: unset;\n  text-decoration: none;\n  display: flex;\n  flex-direction: column;\n  position: relative;\n  min-height: 0;\n  flex: 1;\n`;\n\nconst TextWrapper = styled.div`\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n`;\n\nconst ItemTitleWrapper = styled.div<ItemTypeProps>`\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `${ItemWrapper}:hover & {\n    padding-left:2px; padding-right: 2px;}`};\n`;\n\nconst ItemTitle = styled.h3<ItemTypeProps>`\n  ${fonts.sizes('24px', '28px')};\n  color: ${colors.brand.primary};\n  ${(props) => props.isTopic && `margin-bottom: ${spacing.small};`};\n  font-weight: ${fonts.weight.semibold};\n  overflow-wrap: anywhere;\n  display: inline;\n  ${ItemWrapper}:hover & {\n    box-shadow: inset 0 -1px;\n    background-color: transparent;\n  }\n`;\nconst ItemText = styled.div<ItemTypeProps>`\n  overflow: hidden;\n  ${fonts.sizes('16px', '24px')};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `\n    ${fonts.sizes('18px', '28px')};\n    `};\n`;\n\nconst ContextWrapper = styled.div`\n  background: white;\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n    padding-bottom: calc(${spacing.small} + 2px);\n  }\n`;\n\nexport type SearchItemProps = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: ItemContextsType['contexts'];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  type?: ContentType;\n  children?: ReactNode;\n};\nexport type SearchItemType = {\n  item: SearchItemProps;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: SearchItemType) => {\n  const { title, url, ingress, contexts, img = null, labels = [], children } = item;\n\n  const isTopic = type === contentTypes.TOPIC || type === contentTypes.MULTIDISCIPLINARY_TOPIC;\n\n  return (\n    <Container>\n      <ItemWrapper>\n        <ItemLink to={url}>\n          {isTopic ? (\n            <ItemTopicHeader image={img} type={type}>\n              <ItemTitleWrapper isTopic>\n                <ItemTitle isTopic>{title}</ItemTitle>\n              </ItemTitleWrapper>\n              <ItemText isTopic>{parse(ingress)}</ItemText>\n            </ItemTopicHeader>\n          ) : (\n            <>\n              <ItemResourceHeader labels={labels} img={img} type={type} />\n              <TextWrapper>\n                <ItemTitleWrapper>\n                  <ItemTitle>{title}</ItemTitle>\n                </ItemTitleWrapper>\n                <ItemText>{parse(ingress)}</ItemText>\n              </TextWrapper>\n            </>\n          )}\n          <ContextWrapper>\n            {contexts && contexts.length > 0 && <ItemContexts contexts={contexts} id={item.id} title={item.title} />}\n          </ContextWrapper>\n        </ItemLink>\n        {children}\n      </ItemWrapper>\n    </Container>\n  );\n};\n\nexport default SearchItem;\n"]} */",
89
89
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
90
90
  });
91
91
  var TextWrapper = (0, _styledBase["default"])("div", {
92
92
  target: "e1hz9lam3",
93
93
  label: "TextWrapper"
94
- })("padding:0 ", _core.spacing.normal, " ", _core.spacing.small, ";transition:all ", _core.animations.durations.fast, " ease-in-out;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAkH8B","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport SafeLink from '@ndla/safelink';\nimport { animations, colors, fonts, spacing } from '@ndla/core';\n\nimport { ContentType } from './SearchTypeResult';\nimport constants from '../model';\nimport ItemContexts, { ItemContextsType } from './components/ItemContexts';\nimport ItemTopicHeader from './components/ItemTopicHeader';\nimport ItemResourceHeader from './components/ItemResourceHeader';\n\nconst { contentTypes } = constants;\n\nexport const resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return '';\n  }\n};\n\ntype ItemTypeProps = {\n  contentType?: ContentType;\n  isTopic?: boolean;\n};\n\nconst Container = styled.div`\n  display: flex;\n  height: 400px;\n  align-items: center;\n  justify-content: center;\n`;\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n  display: flex;\n  width: 100%;\n  height: 100%;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 5px;\n  transition: all ${animations.durations.fast} ease-in-out;\n  &:hover {\n    height: calc(100% + 4px);\n    width: calc(100% + 4px);\n    .topic-header-image {\n      height: calc(100% + 6px);\n      width: calc(100% + 6px);\n    }\n    .topic-label {\n      svg {\n        transform: scale(1.2);\n      }\n    }\n    .topic-label-list {\n      margin-left: 2px;\n    }\n    .resource-type-wrapper {\n      padding: 0 calc(${spacing.normal} + 2px);\n      .resource-icon-wrapper {\n        left: 19px;\n        svg {\n          transform: scale(1.2);\n        }\n      }\n    }\n    .resource-no-image {\n      background-color: ${colors.brand.greyLightest};\n      .c-content-type-badge {\n        width: 26px;\n        height: 26px;\n        left: 45px;\n        margin-left: 0;\n        top: 100%;\n        margin-top: -13px;\n        opacity: 1;\n      }\n    }\n  }\n`;\n\nconst ItemLink = styled(SafeLink)`\n  box-shadow: none;\n  color: unset;\n  text-decoration: none;\n  display: flex;\n  flex-direction: column;\n  position: relative;\n  min-height: 0;\n  flex: 1;\n`;\n\nconst TextWrapper = styled.div`\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n`;\n\nconst ItemTitleWrapper = styled.div<ItemTypeProps>`\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `${ItemWrapper}:hover & {\n    padding-left:2px; padding-right: 2px;}`};\n`;\n\nconst ItemTitle = styled.h3<ItemTypeProps>`\n  ${fonts.sizes('24px', '28px')};\n  color: ${colors.brand.primary};\n  ${(props) => props.isTopic && `margin-bottom: ${spacing.small};`};\n  font-weight: ${fonts.weight.semibold};\n  overflow-wrap: anywhere;\n  display: inline;\n  ${ItemWrapper}:hover & {\n    box-shadow: inset 0 -1px;\n    background-color: transparent;\n  }\n`;\nconst ItemText = styled.div<ItemTypeProps>`\n  overflow: hidden;\n  ${fonts.sizes('16px', '24px')};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `\n    ${fonts.sizes('18px', '28px')};\n    `};\n`;\n\nconst ContextWrapper = styled.div`\n  background: white;\n  z-index: 1;\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n    padding-bottom: calc(${spacing.small} + 2px);\n  }\n`;\n\nexport type SearchItemProps = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: ItemContextsType['contexts'];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  type?: ContentType;\n  children?: ReactNode;\n};\nexport type SearchItemType = {\n  item: SearchItemProps;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: SearchItemType) => {\n  const { title, url, ingress, contexts, img = null, labels = [], children } = item;\n\n  const isTopic = type === contentTypes.TOPIC || type === contentTypes.MULTIDISCIPLINARY_TOPIC;\n\n  return (\n    <Container>\n      <ItemWrapper>\n        <ItemLink to={url}>\n          {isTopic ? (\n            <ItemTopicHeader image={img} type={type}>\n              <ItemTitleWrapper isTopic>\n                <ItemTitle isTopic>{title}</ItemTitle>\n              </ItemTitleWrapper>\n              <ItemText isTopic>{parse(ingress)}</ItemText>\n            </ItemTopicHeader>\n          ) : (\n            <>\n              <ItemResourceHeader labels={labels} img={img} type={type} />\n              <TextWrapper>\n                <ItemTitleWrapper>\n                  <ItemTitle>{title}</ItemTitle>\n                </ItemTitleWrapper>\n                <ItemText>{parse(ingress)}</ItemText>\n              </TextWrapper>\n            </>\n          )}\n          <ContextWrapper>\n            {contexts && contexts.length > 0 && <ItemContexts contexts={contexts} id={item.id} title={item.title} />}\n          </ContextWrapper>\n        </ItemLink>\n        {children}\n      </ItemWrapper>\n    </Container>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
94
+ })("padding:0 ", _core.spacing.normal, " ", _core.spacing.small, ";transition:all ", _core.animations.durations.fast, " ease-in-out;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAkH8B","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport SafeLink from '@ndla/safelink';\nimport { animations, colors, fonts, spacing } from '@ndla/core';\n\nimport { ContentType } from './SearchTypeResult';\nimport constants from '../model';\nimport ItemContexts, { ItemContextsType } from './components/ItemContexts';\nimport ItemTopicHeader from './components/ItemTopicHeader';\nimport ItemResourceHeader from './components/ItemResourceHeader';\n\nconst { contentTypes } = constants;\n\nexport const resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return '';\n  }\n};\n\ntype ItemTypeProps = {\n  contentType?: ContentType;\n  isTopic?: boolean;\n};\n\nconst Container = styled.div`\n  display: flex;\n  height: 400px;\n  align-items: center;\n  justify-content: center;\n`;\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n  display: flex;\n  width: 100%;\n  height: 100%;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 5px;\n  transition: all ${animations.durations.fast} ease-in-out;\n  &:hover {\n    height: calc(100% + 4px);\n    width: calc(100% + 4px);\n    .topic-header-image {\n      height: calc(100% + 6px);\n      width: calc(100% + 6px);\n    }\n    .topic-label {\n      svg {\n        transform: scale(1.2);\n      }\n    }\n    .topic-label-list {\n      margin-left: 2px;\n    }\n    .resource-type-wrapper {\n      padding: 0 calc(${spacing.normal} + 2px);\n      .resource-icon-wrapper {\n        left: 19px;\n        svg {\n          transform: scale(1.2);\n        }\n      }\n    }\n    .resource-no-image {\n      background-color: ${colors.brand.greyLightest};\n      .c-content-type-badge {\n        width: 26px;\n        height: 26px;\n        left: 45px;\n        margin-left: 0;\n        top: 100%;\n        margin-top: -13px;\n        opacity: 1;\n      }\n    }\n  }\n`;\n\nconst ItemLink = styled(SafeLink)`\n  box-shadow: none;\n  color: unset;\n  text-decoration: none;\n  display: flex;\n  flex-direction: column;\n  position: relative;\n  min-height: 0;\n  flex: 1;\n`;\n\nconst TextWrapper = styled.div`\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n`;\n\nconst ItemTitleWrapper = styled.div<ItemTypeProps>`\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `${ItemWrapper}:hover & {\n    padding-left:2px; padding-right: 2px;}`};\n`;\n\nconst ItemTitle = styled.h3<ItemTypeProps>`\n  ${fonts.sizes('24px', '28px')};\n  color: ${colors.brand.primary};\n  ${(props) => props.isTopic && `margin-bottom: ${spacing.small};`};\n  font-weight: ${fonts.weight.semibold};\n  overflow-wrap: anywhere;\n  display: inline;\n  ${ItemWrapper}:hover & {\n    box-shadow: inset 0 -1px;\n    background-color: transparent;\n  }\n`;\nconst ItemText = styled.div<ItemTypeProps>`\n  overflow: hidden;\n  ${fonts.sizes('16px', '24px')};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `\n    ${fonts.sizes('18px', '28px')};\n    `};\n`;\n\nconst ContextWrapper = styled.div`\n  background: white;\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n    padding-bottom: calc(${spacing.small} + 2px);\n  }\n`;\n\nexport type SearchItemProps = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: ItemContextsType['contexts'];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  type?: ContentType;\n  children?: ReactNode;\n};\nexport type SearchItemType = {\n  item: SearchItemProps;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: SearchItemType) => {\n  const { title, url, ingress, contexts, img = null, labels = [], children } = item;\n\n  const isTopic = type === contentTypes.TOPIC || type === contentTypes.MULTIDISCIPLINARY_TOPIC;\n\n  return (\n    <Container>\n      <ItemWrapper>\n        <ItemLink to={url}>\n          {isTopic ? (\n            <ItemTopicHeader image={img} type={type}>\n              <ItemTitleWrapper isTopic>\n                <ItemTitle isTopic>{title}</ItemTitle>\n              </ItemTitleWrapper>\n              <ItemText isTopic>{parse(ingress)}</ItemText>\n            </ItemTopicHeader>\n          ) : (\n            <>\n              <ItemResourceHeader labels={labels} img={img} type={type} />\n              <TextWrapper>\n                <ItemTitleWrapper>\n                  <ItemTitle>{title}</ItemTitle>\n                </ItemTitleWrapper>\n                <ItemText>{parse(ingress)}</ItemText>\n              </TextWrapper>\n            </>\n          )}\n          <ContextWrapper>\n            {contexts && contexts.length > 0 && <ItemContexts contexts={contexts} id={item.id} title={item.title} />}\n          </ContextWrapper>\n        </ItemLink>\n        {children}\n      </ItemWrapper>\n    </Container>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
95
95
  var ItemTitleWrapper = (0, _styledBase["default"])("div", {
96
96
  target: "e1hz9lam4",
97
97
  label: "ItemTitleWrapper"
98
98
  })("transition:all ", _core.animations.durations.fast, " ease-in-out;margin-top:", _core.spacing.small, ";", function (props) {
99
99
  return props.isTopic && "".concat(ItemWrapper, ":hover & {\n padding-left:2px; padding-right: 2px;}");
100
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAuHkD","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport SafeLink from '@ndla/safelink';\nimport { animations, colors, fonts, spacing } from '@ndla/core';\n\nimport { ContentType } from './SearchTypeResult';\nimport constants from '../model';\nimport ItemContexts, { ItemContextsType } from './components/ItemContexts';\nimport ItemTopicHeader from './components/ItemTopicHeader';\nimport ItemResourceHeader from './components/ItemResourceHeader';\n\nconst { contentTypes } = constants;\n\nexport const resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return '';\n  }\n};\n\ntype ItemTypeProps = {\n  contentType?: ContentType;\n  isTopic?: boolean;\n};\n\nconst Container = styled.div`\n  display: flex;\n  height: 400px;\n  align-items: center;\n  justify-content: center;\n`;\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n  display: flex;\n  width: 100%;\n  height: 100%;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 5px;\n  transition: all ${animations.durations.fast} ease-in-out;\n  &:hover {\n    height: calc(100% + 4px);\n    width: calc(100% + 4px);\n    .topic-header-image {\n      height: calc(100% + 6px);\n      width: calc(100% + 6px);\n    }\n    .topic-label {\n      svg {\n        transform: scale(1.2);\n      }\n    }\n    .topic-label-list {\n      margin-left: 2px;\n    }\n    .resource-type-wrapper {\n      padding: 0 calc(${spacing.normal} + 2px);\n      .resource-icon-wrapper {\n        left: 19px;\n        svg {\n          transform: scale(1.2);\n        }\n      }\n    }\n    .resource-no-image {\n      background-color: ${colors.brand.greyLightest};\n      .c-content-type-badge {\n        width: 26px;\n        height: 26px;\n        left: 45px;\n        margin-left: 0;\n        top: 100%;\n        margin-top: -13px;\n        opacity: 1;\n      }\n    }\n  }\n`;\n\nconst ItemLink = styled(SafeLink)`\n  box-shadow: none;\n  color: unset;\n  text-decoration: none;\n  display: flex;\n  flex-direction: column;\n  position: relative;\n  min-height: 0;\n  flex: 1;\n`;\n\nconst TextWrapper = styled.div`\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n`;\n\nconst ItemTitleWrapper = styled.div<ItemTypeProps>`\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `${ItemWrapper}:hover & {\n    padding-left:2px; padding-right: 2px;}`};\n`;\n\nconst ItemTitle = styled.h3<ItemTypeProps>`\n  ${fonts.sizes('24px', '28px')};\n  color: ${colors.brand.primary};\n  ${(props) => props.isTopic && `margin-bottom: ${spacing.small};`};\n  font-weight: ${fonts.weight.semibold};\n  overflow-wrap: anywhere;\n  display: inline;\n  ${ItemWrapper}:hover & {\n    box-shadow: inset 0 -1px;\n    background-color: transparent;\n  }\n`;\nconst ItemText = styled.div<ItemTypeProps>`\n  overflow: hidden;\n  ${fonts.sizes('16px', '24px')};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `\n    ${fonts.sizes('18px', '28px')};\n    `};\n`;\n\nconst ContextWrapper = styled.div`\n  background: white;\n  z-index: 1;\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n    padding-bottom: calc(${spacing.small} + 2px);\n  }\n`;\n\nexport type SearchItemProps = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: ItemContextsType['contexts'];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  type?: ContentType;\n  children?: ReactNode;\n};\nexport type SearchItemType = {\n  item: SearchItemProps;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: SearchItemType) => {\n  const { title, url, ingress, contexts, img = null, labels = [], children } = item;\n\n  const isTopic = type === contentTypes.TOPIC || type === contentTypes.MULTIDISCIPLINARY_TOPIC;\n\n  return (\n    <Container>\n      <ItemWrapper>\n        <ItemLink to={url}>\n          {isTopic ? (\n            <ItemTopicHeader image={img} type={type}>\n              <ItemTitleWrapper isTopic>\n                <ItemTitle isTopic>{title}</ItemTitle>\n              </ItemTitleWrapper>\n              <ItemText isTopic>{parse(ingress)}</ItemText>\n            </ItemTopicHeader>\n          ) : (\n            <>\n              <ItemResourceHeader labels={labels} img={img} type={type} />\n              <TextWrapper>\n                <ItemTitleWrapper>\n                  <ItemTitle>{title}</ItemTitle>\n                </ItemTitleWrapper>\n                <ItemText>{parse(ingress)}</ItemText>\n              </TextWrapper>\n            </>\n          )}\n          <ContextWrapper>\n            {contexts && contexts.length > 0 && <ItemContexts contexts={contexts} id={item.id} title={item.title} />}\n          </ContextWrapper>\n        </ItemLink>\n        {children}\n      </ItemWrapper>\n    </Container>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
100
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAuHkD","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport SafeLink from '@ndla/safelink';\nimport { animations, colors, fonts, spacing } from '@ndla/core';\n\nimport { ContentType } from './SearchTypeResult';\nimport constants from '../model';\nimport ItemContexts, { ItemContextsType } from './components/ItemContexts';\nimport ItemTopicHeader from './components/ItemTopicHeader';\nimport ItemResourceHeader from './components/ItemResourceHeader';\n\nconst { contentTypes } = constants;\n\nexport const resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return '';\n  }\n};\n\ntype ItemTypeProps = {\n  contentType?: ContentType;\n  isTopic?: boolean;\n};\n\nconst Container = styled.div`\n  display: flex;\n  height: 400px;\n  align-items: center;\n  justify-content: center;\n`;\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n  display: flex;\n  width: 100%;\n  height: 100%;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 5px;\n  transition: all ${animations.durations.fast} ease-in-out;\n  &:hover {\n    height: calc(100% + 4px);\n    width: calc(100% + 4px);\n    .topic-header-image {\n      height: calc(100% + 6px);\n      width: calc(100% + 6px);\n    }\n    .topic-label {\n      svg {\n        transform: scale(1.2);\n      }\n    }\n    .topic-label-list {\n      margin-left: 2px;\n    }\n    .resource-type-wrapper {\n      padding: 0 calc(${spacing.normal} + 2px);\n      .resource-icon-wrapper {\n        left: 19px;\n        svg {\n          transform: scale(1.2);\n        }\n      }\n    }\n    .resource-no-image {\n      background-color: ${colors.brand.greyLightest};\n      .c-content-type-badge {\n        width: 26px;\n        height: 26px;\n        left: 45px;\n        margin-left: 0;\n        top: 100%;\n        margin-top: -13px;\n        opacity: 1;\n      }\n    }\n  }\n`;\n\nconst ItemLink = styled(SafeLink)`\n  box-shadow: none;\n  color: unset;\n  text-decoration: none;\n  display: flex;\n  flex-direction: column;\n  position: relative;\n  min-height: 0;\n  flex: 1;\n`;\n\nconst TextWrapper = styled.div`\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n`;\n\nconst ItemTitleWrapper = styled.div<ItemTypeProps>`\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `${ItemWrapper}:hover & {\n    padding-left:2px; padding-right: 2px;}`};\n`;\n\nconst ItemTitle = styled.h3<ItemTypeProps>`\n  ${fonts.sizes('24px', '28px')};\n  color: ${colors.brand.primary};\n  ${(props) => props.isTopic && `margin-bottom: ${spacing.small};`};\n  font-weight: ${fonts.weight.semibold};\n  overflow-wrap: anywhere;\n  display: inline;\n  ${ItemWrapper}:hover & {\n    box-shadow: inset 0 -1px;\n    background-color: transparent;\n  }\n`;\nconst ItemText = styled.div<ItemTypeProps>`\n  overflow: hidden;\n  ${fonts.sizes('16px', '24px')};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `\n    ${fonts.sizes('18px', '28px')};\n    `};\n`;\n\nconst ContextWrapper = styled.div`\n  background: white;\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n    padding-bottom: calc(${spacing.small} + 2px);\n  }\n`;\n\nexport type SearchItemProps = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: ItemContextsType['contexts'];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  type?: ContentType;\n  children?: ReactNode;\n};\nexport type SearchItemType = {\n  item: SearchItemProps;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: SearchItemType) => {\n  const { title, url, ingress, contexts, img = null, labels = [], children } = item;\n\n  const isTopic = type === contentTypes.TOPIC || type === contentTypes.MULTIDISCIPLINARY_TOPIC;\n\n  return (\n    <Container>\n      <ItemWrapper>\n        <ItemLink to={url}>\n          {isTopic ? (\n            <ItemTopicHeader image={img} type={type}>\n              <ItemTitleWrapper isTopic>\n                <ItemTitle isTopic>{title}</ItemTitle>\n              </ItemTitleWrapper>\n              <ItemText isTopic>{parse(ingress)}</ItemText>\n            </ItemTopicHeader>\n          ) : (\n            <>\n              <ItemResourceHeader labels={labels} img={img} type={type} />\n              <TextWrapper>\n                <ItemTitleWrapper>\n                  <ItemTitle>{title}</ItemTitle>\n                </ItemTitleWrapper>\n                <ItemText>{parse(ingress)}</ItemText>\n              </TextWrapper>\n            </>\n          )}\n          <ContextWrapper>\n            {contexts && contexts.length > 0 && <ItemContexts contexts={contexts} id={item.id} title={item.title} />}\n          </ContextWrapper>\n        </ItemLink>\n        {children}\n      </ItemWrapper>\n    </Container>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
101
101
  var ItemTitle = (0, _styledBase["default"])("h3", {
102
102
  target: "e1hz9lam5",
103
103
  label: "ItemTitle"
104
104
  })(_core.fonts.sizes('24px', '28px'), ";color:", _core.colors.brand.primary, ";", function (props) {
105
105
  return props.isTopic && "margin-bottom: ".concat(_core.spacing.small, ";");
106
- }, ";font-weight:", _core.fonts.weight.semibold, ";overflow-wrap:anywhere;display:inline;", ItemWrapper, ":hover &{box-shadow:inset 0 -1px;background-color:transparent;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAgI0C","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport SafeLink from '@ndla/safelink';\nimport { animations, colors, fonts, spacing } from '@ndla/core';\n\nimport { ContentType } from './SearchTypeResult';\nimport constants from '../model';\nimport ItemContexts, { ItemContextsType } from './components/ItemContexts';\nimport ItemTopicHeader from './components/ItemTopicHeader';\nimport ItemResourceHeader from './components/ItemResourceHeader';\n\nconst { contentTypes } = constants;\n\nexport const resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return '';\n  }\n};\n\ntype ItemTypeProps = {\n  contentType?: ContentType;\n  isTopic?: boolean;\n};\n\nconst Container = styled.div`\n  display: flex;\n  height: 400px;\n  align-items: center;\n  justify-content: center;\n`;\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n  display: flex;\n  width: 100%;\n  height: 100%;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 5px;\n  transition: all ${animations.durations.fast} ease-in-out;\n  &:hover {\n    height: calc(100% + 4px);\n    width: calc(100% + 4px);\n    .topic-header-image {\n      height: calc(100% + 6px);\n      width: calc(100% + 6px);\n    }\n    .topic-label {\n      svg {\n        transform: scale(1.2);\n      }\n    }\n    .topic-label-list {\n      margin-left: 2px;\n    }\n    .resource-type-wrapper {\n      padding: 0 calc(${spacing.normal} + 2px);\n      .resource-icon-wrapper {\n        left: 19px;\n        svg {\n          transform: scale(1.2);\n        }\n      }\n    }\n    .resource-no-image {\n      background-color: ${colors.brand.greyLightest};\n      .c-content-type-badge {\n        width: 26px;\n        height: 26px;\n        left: 45px;\n        margin-left: 0;\n        top: 100%;\n        margin-top: -13px;\n        opacity: 1;\n      }\n    }\n  }\n`;\n\nconst ItemLink = styled(SafeLink)`\n  box-shadow: none;\n  color: unset;\n  text-decoration: none;\n  display: flex;\n  flex-direction: column;\n  position: relative;\n  min-height: 0;\n  flex: 1;\n`;\n\nconst TextWrapper = styled.div`\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n`;\n\nconst ItemTitleWrapper = styled.div<ItemTypeProps>`\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `${ItemWrapper}:hover & {\n    padding-left:2px; padding-right: 2px;}`};\n`;\n\nconst ItemTitle = styled.h3<ItemTypeProps>`\n  ${fonts.sizes('24px', '28px')};\n  color: ${colors.brand.primary};\n  ${(props) => props.isTopic && `margin-bottom: ${spacing.small};`};\n  font-weight: ${fonts.weight.semibold};\n  overflow-wrap: anywhere;\n  display: inline;\n  ${ItemWrapper}:hover & {\n    box-shadow: inset 0 -1px;\n    background-color: transparent;\n  }\n`;\nconst ItemText = styled.div<ItemTypeProps>`\n  overflow: hidden;\n  ${fonts.sizes('16px', '24px')};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `\n    ${fonts.sizes('18px', '28px')};\n    `};\n`;\n\nconst ContextWrapper = styled.div`\n  background: white;\n  z-index: 1;\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n    padding-bottom: calc(${spacing.small} + 2px);\n  }\n`;\n\nexport type SearchItemProps = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: ItemContextsType['contexts'];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  type?: ContentType;\n  children?: ReactNode;\n};\nexport type SearchItemType = {\n  item: SearchItemProps;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: SearchItemType) => {\n  const { title, url, ingress, contexts, img = null, labels = [], children } = item;\n\n  const isTopic = type === contentTypes.TOPIC || type === contentTypes.MULTIDISCIPLINARY_TOPIC;\n\n  return (\n    <Container>\n      <ItemWrapper>\n        <ItemLink to={url}>\n          {isTopic ? (\n            <ItemTopicHeader image={img} type={type}>\n              <ItemTitleWrapper isTopic>\n                <ItemTitle isTopic>{title}</ItemTitle>\n              </ItemTitleWrapper>\n              <ItemText isTopic>{parse(ingress)}</ItemText>\n            </ItemTopicHeader>\n          ) : (\n            <>\n              <ItemResourceHeader labels={labels} img={img} type={type} />\n              <TextWrapper>\n                <ItemTitleWrapper>\n                  <ItemTitle>{title}</ItemTitle>\n                </ItemTitleWrapper>\n                <ItemText>{parse(ingress)}</ItemText>\n              </TextWrapper>\n            </>\n          )}\n          <ContextWrapper>\n            {contexts && contexts.length > 0 && <ItemContexts contexts={contexts} id={item.id} title={item.title} />}\n          </ContextWrapper>\n        </ItemLink>\n        {children}\n      </ItemWrapper>\n    </Container>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
106
+ }, ";font-weight:", _core.fonts.weight.semibold, ";overflow-wrap:anywhere;display:inline;", ItemWrapper, ":hover &{box-shadow:inset 0 -1px;background-color:transparent;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AAgI0C","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport SafeLink from '@ndla/safelink';\nimport { animations, colors, fonts, spacing } from '@ndla/core';\n\nimport { ContentType } from './SearchTypeResult';\nimport constants from '../model';\nimport ItemContexts, { ItemContextsType } from './components/ItemContexts';\nimport ItemTopicHeader from './components/ItemTopicHeader';\nimport ItemResourceHeader from './components/ItemResourceHeader';\n\nconst { contentTypes } = constants;\n\nexport const resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return '';\n  }\n};\n\ntype ItemTypeProps = {\n  contentType?: ContentType;\n  isTopic?: boolean;\n};\n\nconst Container = styled.div`\n  display: flex;\n  height: 400px;\n  align-items: center;\n  justify-content: center;\n`;\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n  display: flex;\n  width: 100%;\n  height: 100%;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 5px;\n  transition: all ${animations.durations.fast} ease-in-out;\n  &:hover {\n    height: calc(100% + 4px);\n    width: calc(100% + 4px);\n    .topic-header-image {\n      height: calc(100% + 6px);\n      width: calc(100% + 6px);\n    }\n    .topic-label {\n      svg {\n        transform: scale(1.2);\n      }\n    }\n    .topic-label-list {\n      margin-left: 2px;\n    }\n    .resource-type-wrapper {\n      padding: 0 calc(${spacing.normal} + 2px);\n      .resource-icon-wrapper {\n        left: 19px;\n        svg {\n          transform: scale(1.2);\n        }\n      }\n    }\n    .resource-no-image {\n      background-color: ${colors.brand.greyLightest};\n      .c-content-type-badge {\n        width: 26px;\n        height: 26px;\n        left: 45px;\n        margin-left: 0;\n        top: 100%;\n        margin-top: -13px;\n        opacity: 1;\n      }\n    }\n  }\n`;\n\nconst ItemLink = styled(SafeLink)`\n  box-shadow: none;\n  color: unset;\n  text-decoration: none;\n  display: flex;\n  flex-direction: column;\n  position: relative;\n  min-height: 0;\n  flex: 1;\n`;\n\nconst TextWrapper = styled.div`\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n`;\n\nconst ItemTitleWrapper = styled.div<ItemTypeProps>`\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `${ItemWrapper}:hover & {\n    padding-left:2px; padding-right: 2px;}`};\n`;\n\nconst ItemTitle = styled.h3<ItemTypeProps>`\n  ${fonts.sizes('24px', '28px')};\n  color: ${colors.brand.primary};\n  ${(props) => props.isTopic && `margin-bottom: ${spacing.small};`};\n  font-weight: ${fonts.weight.semibold};\n  overflow-wrap: anywhere;\n  display: inline;\n  ${ItemWrapper}:hover & {\n    box-shadow: inset 0 -1px;\n    background-color: transparent;\n  }\n`;\nconst ItemText = styled.div<ItemTypeProps>`\n  overflow: hidden;\n  ${fonts.sizes('16px', '24px')};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `\n    ${fonts.sizes('18px', '28px')};\n    `};\n`;\n\nconst ContextWrapper = styled.div`\n  background: white;\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n    padding-bottom: calc(${spacing.small} + 2px);\n  }\n`;\n\nexport type SearchItemProps = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: ItemContextsType['contexts'];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  type?: ContentType;\n  children?: ReactNode;\n};\nexport type SearchItemType = {\n  item: SearchItemProps;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: SearchItemType) => {\n  const { title, url, ingress, contexts, img = null, labels = [], children } = item;\n\n  const isTopic = type === contentTypes.TOPIC || type === contentTypes.MULTIDISCIPLINARY_TOPIC;\n\n  return (\n    <Container>\n      <ItemWrapper>\n        <ItemLink to={url}>\n          {isTopic ? (\n            <ItemTopicHeader image={img} type={type}>\n              <ItemTitleWrapper isTopic>\n                <ItemTitle isTopic>{title}</ItemTitle>\n              </ItemTitleWrapper>\n              <ItemText isTopic>{parse(ingress)}</ItemText>\n            </ItemTopicHeader>\n          ) : (\n            <>\n              <ItemResourceHeader labels={labels} img={img} type={type} />\n              <TextWrapper>\n                <ItemTitleWrapper>\n                  <ItemTitle>{title}</ItemTitle>\n                </ItemTitleWrapper>\n                <ItemText>{parse(ingress)}</ItemText>\n              </TextWrapper>\n            </>\n          )}\n          <ContextWrapper>\n            {contexts && contexts.length > 0 && <ItemContexts contexts={contexts} id={item.id} title={item.title} />}\n          </ContextWrapper>\n        </ItemLink>\n        {children}\n      </ItemWrapper>\n    </Container>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
107
107
  var ItemText = (0, _styledBase["default"])("div", {
108
108
  target: "e1hz9lam6",
109
109
  label: "ItemText"
110
110
  })("overflow:hidden;", _core.fonts.sizes('16px', '24px'), ";word-break:break-word;overflow-wrap:anywhere;transition:all ", _core.animations.durations.fast, " ease-in-out;margin-top:", _core.spacing.small, ";", function (props) {
111
111
  return props.isTopic && "\n ".concat(_core.fonts.sizes('18px', '28px'), ";\n ");
112
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AA4I0C","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport SafeLink from '@ndla/safelink';\nimport { animations, colors, fonts, spacing } from '@ndla/core';\n\nimport { ContentType } from './SearchTypeResult';\nimport constants from '../model';\nimport ItemContexts, { ItemContextsType } from './components/ItemContexts';\nimport ItemTopicHeader from './components/ItemTopicHeader';\nimport ItemResourceHeader from './components/ItemResourceHeader';\n\nconst { contentTypes } = constants;\n\nexport const resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return '';\n  }\n};\n\ntype ItemTypeProps = {\n  contentType?: ContentType;\n  isTopic?: boolean;\n};\n\nconst Container = styled.div`\n  display: flex;\n  height: 400px;\n  align-items: center;\n  justify-content: center;\n`;\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n  display: flex;\n  width: 100%;\n  height: 100%;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 5px;\n  transition: all ${animations.durations.fast} ease-in-out;\n  &:hover {\n    height: calc(100% + 4px);\n    width: calc(100% + 4px);\n    .topic-header-image {\n      height: calc(100% + 6px);\n      width: calc(100% + 6px);\n    }\n    .topic-label {\n      svg {\n        transform: scale(1.2);\n      }\n    }\n    .topic-label-list {\n      margin-left: 2px;\n    }\n    .resource-type-wrapper {\n      padding: 0 calc(${spacing.normal} + 2px);\n      .resource-icon-wrapper {\n        left: 19px;\n        svg {\n          transform: scale(1.2);\n        }\n      }\n    }\n    .resource-no-image {\n      background-color: ${colors.brand.greyLightest};\n      .c-content-type-badge {\n        width: 26px;\n        height: 26px;\n        left: 45px;\n        margin-left: 0;\n        top: 100%;\n        margin-top: -13px;\n        opacity: 1;\n      }\n    }\n  }\n`;\n\nconst ItemLink = styled(SafeLink)`\n  box-shadow: none;\n  color: unset;\n  text-decoration: none;\n  display: flex;\n  flex-direction: column;\n  position: relative;\n  min-height: 0;\n  flex: 1;\n`;\n\nconst TextWrapper = styled.div`\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n`;\n\nconst ItemTitleWrapper = styled.div<ItemTypeProps>`\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `${ItemWrapper}:hover & {\n    padding-left:2px; padding-right: 2px;}`};\n`;\n\nconst ItemTitle = styled.h3<ItemTypeProps>`\n  ${fonts.sizes('24px', '28px')};\n  color: ${colors.brand.primary};\n  ${(props) => props.isTopic && `margin-bottom: ${spacing.small};`};\n  font-weight: ${fonts.weight.semibold};\n  overflow-wrap: anywhere;\n  display: inline;\n  ${ItemWrapper}:hover & {\n    box-shadow: inset 0 -1px;\n    background-color: transparent;\n  }\n`;\nconst ItemText = styled.div<ItemTypeProps>`\n  overflow: hidden;\n  ${fonts.sizes('16px', '24px')};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `\n    ${fonts.sizes('18px', '28px')};\n    `};\n`;\n\nconst ContextWrapper = styled.div`\n  background: white;\n  z-index: 1;\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n    padding-bottom: calc(${spacing.small} + 2px);\n  }\n`;\n\nexport type SearchItemProps = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: ItemContextsType['contexts'];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  type?: ContentType;\n  children?: ReactNode;\n};\nexport type SearchItemType = {\n  item: SearchItemProps;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: SearchItemType) => {\n  const { title, url, ingress, contexts, img = null, labels = [], children } = item;\n\n  const isTopic = type === contentTypes.TOPIC || type === contentTypes.MULTIDISCIPLINARY_TOPIC;\n\n  return (\n    <Container>\n      <ItemWrapper>\n        <ItemLink to={url}>\n          {isTopic ? (\n            <ItemTopicHeader image={img} type={type}>\n              <ItemTitleWrapper isTopic>\n                <ItemTitle isTopic>{title}</ItemTitle>\n              </ItemTitleWrapper>\n              <ItemText isTopic>{parse(ingress)}</ItemText>\n            </ItemTopicHeader>\n          ) : (\n            <>\n              <ItemResourceHeader labels={labels} img={img} type={type} />\n              <TextWrapper>\n                <ItemTitleWrapper>\n                  <ItemTitle>{title}</ItemTitle>\n                </ItemTitleWrapper>\n                <ItemText>{parse(ingress)}</ItemText>\n              </TextWrapper>\n            </>\n          )}\n          <ContextWrapper>\n            {contexts && contexts.length > 0 && <ItemContexts contexts={contexts} id={item.id} title={item.title} />}\n          </ContextWrapper>\n        </ItemLink>\n        {children}\n      </ItemWrapper>\n    </Container>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
112
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AA4I0C","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport SafeLink from '@ndla/safelink';\nimport { animations, colors, fonts, spacing } from '@ndla/core';\n\nimport { ContentType } from './SearchTypeResult';\nimport constants from '../model';\nimport ItemContexts, { ItemContextsType } from './components/ItemContexts';\nimport ItemTopicHeader from './components/ItemTopicHeader';\nimport ItemResourceHeader from './components/ItemResourceHeader';\n\nconst { contentTypes } = constants;\n\nexport const resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return '';\n  }\n};\n\ntype ItemTypeProps = {\n  contentType?: ContentType;\n  isTopic?: boolean;\n};\n\nconst Container = styled.div`\n  display: flex;\n  height: 400px;\n  align-items: center;\n  justify-content: center;\n`;\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n  display: flex;\n  width: 100%;\n  height: 100%;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 5px;\n  transition: all ${animations.durations.fast} ease-in-out;\n  &:hover {\n    height: calc(100% + 4px);\n    width: calc(100% + 4px);\n    .topic-header-image {\n      height: calc(100% + 6px);\n      width: calc(100% + 6px);\n    }\n    .topic-label {\n      svg {\n        transform: scale(1.2);\n      }\n    }\n    .topic-label-list {\n      margin-left: 2px;\n    }\n    .resource-type-wrapper {\n      padding: 0 calc(${spacing.normal} + 2px);\n      .resource-icon-wrapper {\n        left: 19px;\n        svg {\n          transform: scale(1.2);\n        }\n      }\n    }\n    .resource-no-image {\n      background-color: ${colors.brand.greyLightest};\n      .c-content-type-badge {\n        width: 26px;\n        height: 26px;\n        left: 45px;\n        margin-left: 0;\n        top: 100%;\n        margin-top: -13px;\n        opacity: 1;\n      }\n    }\n  }\n`;\n\nconst ItemLink = styled(SafeLink)`\n  box-shadow: none;\n  color: unset;\n  text-decoration: none;\n  display: flex;\n  flex-direction: column;\n  position: relative;\n  min-height: 0;\n  flex: 1;\n`;\n\nconst TextWrapper = styled.div`\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n`;\n\nconst ItemTitleWrapper = styled.div<ItemTypeProps>`\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `${ItemWrapper}:hover & {\n    padding-left:2px; padding-right: 2px;}`};\n`;\n\nconst ItemTitle = styled.h3<ItemTypeProps>`\n  ${fonts.sizes('24px', '28px')};\n  color: ${colors.brand.primary};\n  ${(props) => props.isTopic && `margin-bottom: ${spacing.small};`};\n  font-weight: ${fonts.weight.semibold};\n  overflow-wrap: anywhere;\n  display: inline;\n  ${ItemWrapper}:hover & {\n    box-shadow: inset 0 -1px;\n    background-color: transparent;\n  }\n`;\nconst ItemText = styled.div<ItemTypeProps>`\n  overflow: hidden;\n  ${fonts.sizes('16px', '24px')};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `\n    ${fonts.sizes('18px', '28px')};\n    `};\n`;\n\nconst ContextWrapper = styled.div`\n  background: white;\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n    padding-bottom: calc(${spacing.small} + 2px);\n  }\n`;\n\nexport type SearchItemProps = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: ItemContextsType['contexts'];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  type?: ContentType;\n  children?: ReactNode;\n};\nexport type SearchItemType = {\n  item: SearchItemProps;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: SearchItemType) => {\n  const { title, url, ingress, contexts, img = null, labels = [], children } = item;\n\n  const isTopic = type === contentTypes.TOPIC || type === contentTypes.MULTIDISCIPLINARY_TOPIC;\n\n  return (\n    <Container>\n      <ItemWrapper>\n        <ItemLink to={url}>\n          {isTopic ? (\n            <ItemTopicHeader image={img} type={type}>\n              <ItemTitleWrapper isTopic>\n                <ItemTitle isTopic>{title}</ItemTitle>\n              </ItemTitleWrapper>\n              <ItemText isTopic>{parse(ingress)}</ItemText>\n            </ItemTopicHeader>\n          ) : (\n            <>\n              <ItemResourceHeader labels={labels} img={img} type={type} />\n              <TextWrapper>\n                <ItemTitleWrapper>\n                  <ItemTitle>{title}</ItemTitle>\n                </ItemTitleWrapper>\n                <ItemText>{parse(ingress)}</ItemText>\n              </TextWrapper>\n            </>\n          )}\n          <ContextWrapper>\n            {contexts && contexts.length > 0 && <ItemContexts contexts={contexts} id={item.id} title={item.title} />}\n          </ContextWrapper>\n        </ItemLink>\n        {children}\n      </ItemWrapper>\n    </Container>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
113
113
  var ContextWrapper = (0, _styledBase["default"])("div", {
114
114
  target: "e1hz9lam7",
115
115
  label: "ContextWrapper"
116
- })("background:white;z-index:1;padding:0 ", _core.spacing.normal, " ", _core.spacing.small, ";transition:all ", _core.animations.durations.fast, " ease-in-out;", ItemWrapper, ":hover &{padding-left:calc(", _core.spacing.normal, " + 2px);padding-right:calc(", _core.spacing.normal, " + 2px);padding-bottom:calc(", _core.spacing.small, " + 2px);}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AA0JiC","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport SafeLink from '@ndla/safelink';\nimport { animations, colors, fonts, spacing } from '@ndla/core';\n\nimport { ContentType } from './SearchTypeResult';\nimport constants from '../model';\nimport ItemContexts, { ItemContextsType } from './components/ItemContexts';\nimport ItemTopicHeader from './components/ItemTopicHeader';\nimport ItemResourceHeader from './components/ItemResourceHeader';\n\nconst { contentTypes } = constants;\n\nexport const resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return '';\n  }\n};\n\ntype ItemTypeProps = {\n  contentType?: ContentType;\n  isTopic?: boolean;\n};\n\nconst Container = styled.div`\n  display: flex;\n  height: 400px;\n  align-items: center;\n  justify-content: center;\n`;\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n  display: flex;\n  width: 100%;\n  height: 100%;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 5px;\n  transition: all ${animations.durations.fast} ease-in-out;\n  &:hover {\n    height: calc(100% + 4px);\n    width: calc(100% + 4px);\n    .topic-header-image {\n      height: calc(100% + 6px);\n      width: calc(100% + 6px);\n    }\n    .topic-label {\n      svg {\n        transform: scale(1.2);\n      }\n    }\n    .topic-label-list {\n      margin-left: 2px;\n    }\n    .resource-type-wrapper {\n      padding: 0 calc(${spacing.normal} + 2px);\n      .resource-icon-wrapper {\n        left: 19px;\n        svg {\n          transform: scale(1.2);\n        }\n      }\n    }\n    .resource-no-image {\n      background-color: ${colors.brand.greyLightest};\n      .c-content-type-badge {\n        width: 26px;\n        height: 26px;\n        left: 45px;\n        margin-left: 0;\n        top: 100%;\n        margin-top: -13px;\n        opacity: 1;\n      }\n    }\n  }\n`;\n\nconst ItemLink = styled(SafeLink)`\n  box-shadow: none;\n  color: unset;\n  text-decoration: none;\n  display: flex;\n  flex-direction: column;\n  position: relative;\n  min-height: 0;\n  flex: 1;\n`;\n\nconst TextWrapper = styled.div`\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n`;\n\nconst ItemTitleWrapper = styled.div<ItemTypeProps>`\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `${ItemWrapper}:hover & {\n    padding-left:2px; padding-right: 2px;}`};\n`;\n\nconst ItemTitle = styled.h3<ItemTypeProps>`\n  ${fonts.sizes('24px', '28px')};\n  color: ${colors.brand.primary};\n  ${(props) => props.isTopic && `margin-bottom: ${spacing.small};`};\n  font-weight: ${fonts.weight.semibold};\n  overflow-wrap: anywhere;\n  display: inline;\n  ${ItemWrapper}:hover & {\n    box-shadow: inset 0 -1px;\n    background-color: transparent;\n  }\n`;\nconst ItemText = styled.div<ItemTypeProps>`\n  overflow: hidden;\n  ${fonts.sizes('16px', '24px')};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `\n    ${fonts.sizes('18px', '28px')};\n    `};\n`;\n\nconst ContextWrapper = styled.div`\n  background: white;\n  z-index: 1;\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n    padding-bottom: calc(${spacing.small} + 2px);\n  }\n`;\n\nexport type SearchItemProps = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: ItemContextsType['contexts'];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  type?: ContentType;\n  children?: ReactNode;\n};\nexport type SearchItemType = {\n  item: SearchItemProps;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: SearchItemType) => {\n  const { title, url, ingress, contexts, img = null, labels = [], children } = item;\n\n  const isTopic = type === contentTypes.TOPIC || type === contentTypes.MULTIDISCIPLINARY_TOPIC;\n\n  return (\n    <Container>\n      <ItemWrapper>\n        <ItemLink to={url}>\n          {isTopic ? (\n            <ItemTopicHeader image={img} type={type}>\n              <ItemTitleWrapper isTopic>\n                <ItemTitle isTopic>{title}</ItemTitle>\n              </ItemTitleWrapper>\n              <ItemText isTopic>{parse(ingress)}</ItemText>\n            </ItemTopicHeader>\n          ) : (\n            <>\n              <ItemResourceHeader labels={labels} img={img} type={type} />\n              <TextWrapper>\n                <ItemTitleWrapper>\n                  <ItemTitle>{title}</ItemTitle>\n                </ItemTitleWrapper>\n                <ItemText>{parse(ingress)}</ItemText>\n              </TextWrapper>\n            </>\n          )}\n          <ContextWrapper>\n            {contexts && contexts.length > 0 && <ItemContexts contexts={contexts} id={item.id} title={item.title} />}\n          </ContextWrapper>\n        </ItemLink>\n        {children}\n      </ItemWrapper>\n    </Container>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
116
+ })("background:white;padding:0 ", _core.spacing.normal, " ", _core.spacing.small, ";transition:all ", _core.animations.durations.fast, " ease-in-out;", ItemWrapper, ":hover &{padding-left:calc(", _core.spacing.normal, " + 2px);padding-right:calc(", _core.spacing.normal, " + 2px);padding-bottom:calc(", _core.spacing.small, " + 2px);}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SearchItem.tsx"],"names":[],"mappings":"AA0JiC","file":"SearchItem.tsx","sourcesContent":["/**\n * Copyright (c) 2020-present, NDLA.\n *\n * This source code is licensed under the GPLv3 license found in the\n * LICENSE file in the root directory of this source tree.\n *\n */\n\nimport React, { ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport parse from 'html-react-parser';\n\nimport SafeLink from '@ndla/safelink';\nimport { animations, colors, fonts, spacing } from '@ndla/core';\n\nimport { ContentType } from './SearchTypeResult';\nimport constants from '../model';\nimport ItemContexts, { ItemContextsType } from './components/ItemContexts';\nimport ItemTopicHeader from './components/ItemTopicHeader';\nimport ItemResourceHeader from './components/ItemResourceHeader';\n\nconst { contentTypes } = constants;\n\nexport const resourceTypeColor = (type: string) => {\n  switch (type) {\n    case contentTypes.SUBJECT_MATERIAL:\n      return colors.subjectMaterial.light;\n    case contentTypes.TOPIC:\n      return colors.subject.light;\n    case contentTypes.TASKS_AND_ACTIVITIES:\n      return colors.tasksAndActivities.light;\n    case contentTypes.ASSESSMENT_RESOURCES:\n      return colors.assessmentResource.light;\n    case contentTypes.EXTERNAL_LEARNING_RESOURCES:\n      return colors.externalLearningResource.light;\n    case contentTypes.SOURCE_MATERIAL:\n      return colors.sourceMaterial.light;\n    case contentTypes.LEARNING_PATH:\n      return colors.learningPath.light;\n    default:\n      return '';\n  }\n};\n\ntype ItemTypeProps = {\n  contentType?: ContentType;\n  isTopic?: boolean;\n};\n\nconst Container = styled.div`\n  display: flex;\n  height: 400px;\n  align-items: center;\n  justify-content: center;\n`;\n\nconst ItemWrapper = styled.div`\n  flex-direction: column;\n  display: flex;\n  width: 100%;\n  height: 100%;\n  border: 1px solid ${colors.brand.neutral7};\n  border-radius: 5px;\n  transition: all ${animations.durations.fast} ease-in-out;\n  &:hover {\n    height: calc(100% + 4px);\n    width: calc(100% + 4px);\n    .topic-header-image {\n      height: calc(100% + 6px);\n      width: calc(100% + 6px);\n    }\n    .topic-label {\n      svg {\n        transform: scale(1.2);\n      }\n    }\n    .topic-label-list {\n      margin-left: 2px;\n    }\n    .resource-type-wrapper {\n      padding: 0 calc(${spacing.normal} + 2px);\n      .resource-icon-wrapper {\n        left: 19px;\n        svg {\n          transform: scale(1.2);\n        }\n      }\n    }\n    .resource-no-image {\n      background-color: ${colors.brand.greyLightest};\n      .c-content-type-badge {\n        width: 26px;\n        height: 26px;\n        left: 45px;\n        margin-left: 0;\n        top: 100%;\n        margin-top: -13px;\n        opacity: 1;\n      }\n    }\n  }\n`;\n\nconst ItemLink = styled(SafeLink)`\n  box-shadow: none;\n  color: unset;\n  text-decoration: none;\n  display: flex;\n  flex-direction: column;\n  position: relative;\n  min-height: 0;\n  flex: 1;\n`;\n\nconst TextWrapper = styled.div`\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n`;\n\nconst ItemTitleWrapper = styled.div<ItemTypeProps>`\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `${ItemWrapper}:hover & {\n    padding-left:2px; padding-right: 2px;}`};\n`;\n\nconst ItemTitle = styled.h3<ItemTypeProps>`\n  ${fonts.sizes('24px', '28px')};\n  color: ${colors.brand.primary};\n  ${(props) => props.isTopic && `margin-bottom: ${spacing.small};`};\n  font-weight: ${fonts.weight.semibold};\n  overflow-wrap: anywhere;\n  display: inline;\n  ${ItemWrapper}:hover & {\n    box-shadow: inset 0 -1px;\n    background-color: transparent;\n  }\n`;\nconst ItemText = styled.div<ItemTypeProps>`\n  overflow: hidden;\n  ${fonts.sizes('16px', '24px')};\n  word-break: break-word;\n  overflow-wrap: anywhere;\n  transition: all ${animations.durations.fast} ease-in-out;\n  margin-top: ${spacing.small};\n  ${(props) =>\n    props.isTopic &&\n    `\n    ${fonts.sizes('18px', '28px')};\n    `};\n`;\n\nconst ContextWrapper = styled.div`\n  background: white;\n  padding: 0 ${spacing.normal} ${spacing.small};\n  transition: all ${animations.durations.fast} ease-in-out;\n  ${ItemWrapper}:hover & {\n    padding-left: calc(${spacing.normal} + 2px);\n    padding-right: calc(${spacing.normal} + 2px);\n    padding-bottom: calc(${spacing.small} + 2px);\n  }\n`;\n\nexport type SearchItemProps = {\n  id: string | number;\n  title: string;\n  url: string;\n  ingress: string;\n  contexts?: ItemContextsType['contexts'];\n  img?: { url: string; alt: string };\n  labels?: string[];\n  type?: ContentType;\n  children?: ReactNode;\n};\nexport type SearchItemType = {\n  item: SearchItemProps;\n  type?: ContentType;\n};\nconst SearchItem = ({ item, type }: SearchItemType) => {\n  const { title, url, ingress, contexts, img = null, labels = [], children } = item;\n\n  const isTopic = type === contentTypes.TOPIC || type === contentTypes.MULTIDISCIPLINARY_TOPIC;\n\n  return (\n    <Container>\n      <ItemWrapper>\n        <ItemLink to={url}>\n          {isTopic ? (\n            <ItemTopicHeader image={img} type={type}>\n              <ItemTitleWrapper isTopic>\n                <ItemTitle isTopic>{title}</ItemTitle>\n              </ItemTitleWrapper>\n              <ItemText isTopic>{parse(ingress)}</ItemText>\n            </ItemTopicHeader>\n          ) : (\n            <>\n              <ItemResourceHeader labels={labels} img={img} type={type} />\n              <TextWrapper>\n                <ItemTitleWrapper>\n                  <ItemTitle>{title}</ItemTitle>\n                </ItemTitleWrapper>\n                <ItemText>{parse(ingress)}</ItemText>\n              </TextWrapper>\n            </>\n          )}\n          <ContextWrapper>\n            {contexts && contexts.length > 0 && <ItemContexts contexts={contexts} id={item.id} title={item.title} />}\n          </ContextWrapper>\n        </ItemLink>\n        {children}\n      </ItemWrapper>\n    </Container>\n  );\n};\n\nexport default SearchItem;\n"]} */"));
117
117
 
118
118
  var SearchItem = function SearchItem(_ref) {
119
119
  var item = _ref.item,
@@ -0,0 +1,11 @@
1
+ /**
2
+ * Copyright (c) 2022-present, NDLA.
3
+ *
4
+ * This source code is licensed under the GPLv3 license found in the
5
+ * LICENSE file in the root directory of this source tree.
6
+ *
7
+ */
8
+ /// <reference types="react" />
9
+ import { Snack } from './SnackbarProvider';
10
+ declare const DefaultSnack: (snack: Snack) => JSX.Element;
11
+ export default DefaultSnack;
@@ -0,0 +1,70 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports["default"] = void 0;
7
+
8
+ var _styledBase = _interopRequireDefault(require("@emotion/styled-base"));
9
+
10
+ var _react = _interopRequireDefault(require("react"));
11
+
12
+ var _reactI18next = require("react-i18next");
13
+
14
+ var _button = require("@ndla/button");
15
+
16
+ var _core = require("@ndla/core");
17
+
18
+ var _action = require("@ndla/icons/action");
19
+
20
+ var _SnackbarProvider = require("./SnackbarProvider");
21
+
22
+ var _core2 = require("@emotion/core");
23
+
24
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
25
+
26
+ /**
27
+ * Copyright (c) 2022-present, NDLA.
28
+ *
29
+ * This source code is licensed under the GPLv3 license found in the
30
+ * LICENSE file in the root directory of this source tree.
31
+ *
32
+ */
33
+ var DefaultSnackContainer = (0, _styledBase["default"])("div", {
34
+ target: "e1s2vq9x0",
35
+ label: "DefaultSnackContainer"
36
+ })("display:flex;gap:", _core.spacing.small, ";padding:", _core.spacing.small, ";background-color:", _core.colors.text.primary, ";color:", _core.colors.white, ";border-radius:", _core.misc.borderRadius, ";margin:0 ", _core.spacing.large, ";pointer-events:all;box-shadow:", _core.shadows.levitate1, ";font-family:", _core.fonts.sans, ";font-size:18px;align-items:center;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkRlZmF1bHRTbmFja2Jhci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZ0J3QyIsImZpbGUiOiJEZWZhdWx0U25hY2tiYXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjItcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IEljb25CdXR0b24gfSBmcm9tICdAbmRsYS9idXR0b24nO1xuaW1wb3J0IHsgYnJlYWtwb2ludHMsIGNvbG9ycywgZm9udHMsIG1pc2MsIG1xLCBzaGFkb3dzLCBzcGFjaW5nIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgeyBDcm9zcyB9IGZyb20gJ0BuZGxhL2ljb25zL2FjdGlvbic7XG5pbXBvcnQgeyBTbmFjaywgdXNlU25hY2sgfSBmcm9tICcuL1NuYWNrYmFyUHJvdmlkZXInO1xuXG5jb25zdCBEZWZhdWx0U25hY2tDb250YWluZXIgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBnYXA6ICR7c3BhY2luZy5zbWFsbH07XG4gIHBhZGRpbmc6ICR7c3BhY2luZy5zbWFsbH07XG4gIGJhY2tncm91bmQtY29sb3I6ICR7Y29sb3JzLnRleHQucHJpbWFyeX07XG4gIGNvbG9yOiAke2NvbG9ycy53aGl0ZX07XG4gIGJvcmRlci1yYWRpdXM6ICR7bWlzYy5ib3JkZXJSYWRpdXN9O1xuICBtYXJnaW46IDAgJHtzcGFjaW5nLmxhcmdlfTtcbiAgcG9pbnRlci1ldmVudHM6IGFsbDtcbiAgYm94LXNoYWRvdzogJHtzaGFkb3dzLmxldml0YXRlMX07XG4gIGZvbnQtZmFtaWx5OiAke2ZvbnRzLnNhbnN9O1xuICBmb250LXNpemU6IDE4cHg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5gO1xuXG5jb25zdCBTdHlsZWRDbG9zZUJ1dHRvbiA9IHN0eWxlZChJY29uQnV0dG9uKWBcbiAgc3ZnIHtcbiAgICBjb2xvcjogJHtjb2xvcnMuYnJhbmQuZ3JleU1lZGl1bX07XG4gIH1cbiAgJjpob3ZlcixcbiAgJjpmb2N1cyB7XG4gICAgYmFja2dyb3VuZDogJHtjb2xvcnMuYnJhbmQuZ3JleURhcmt9O1xuICAgIHN2ZyB7XG4gICAgICBjb2xvcjogJHtjb2xvcnMuYnJhbmQuZ3JleUxpZ2h0ZXN0fTtcbiAgICB9XG4gIH1cbmA7XG5cbmNvbnN0IEJ1dHRvbldyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICAke21xLnJhbmdlKHsgZnJvbTogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgZ2FwOiAke3NwYWNpbmcueHhzbWFsbH07XG4gIH1cbmA7XG5cbmNvbnN0IERlZmF1bHRTbmFjayA9IChzbmFjazogU25hY2spID0+IHtcbiAgY29uc3QgeyBjbG9zYWJsZSA9IHRydWUsIGljb24gfSA9IHNuYWNrO1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIGNvbnN0IHsgY2xvc2VTbmFjayB9ID0gdXNlU25hY2soKTtcbiAgcmV0dXJuIChcbiAgICA8RGVmYXVsdFNuYWNrQ29udGFpbmVyPlxuICAgICAge2ljb259XG4gICAgICB7c25hY2suY29udGVudH1cbiAgICAgIDxCdXR0b25XcmFwcGVyPlxuICAgICAgICB7Y2xvc2FibGUgJiYgKFxuICAgICAgICAgIDxTdHlsZWRDbG9zZUJ1dHRvbiBzaXplPVwieHNtYWxsXCIgb3V0bGluZSBvbkNsaWNrPXsoKSA9PiBjbG9zZVNuYWNrKHNuYWNrKX0gYXJpYS1sYWJlbD17dCgnc25hY2tiYXIuY2xvc2UnKX0+XG4gICAgICAgICAgICA8Q3Jvc3MgLz5cbiAgICAgICAgICA8L1N0eWxlZENsb3NlQnV0dG9uPlxuICAgICAgICApfVxuICAgICAgPC9CdXR0b25XcmFwcGVyPlxuICAgIDwvRGVmYXVsdFNuYWNrQ29udGFpbmVyPlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgRGVmYXVsdFNuYWNrO1xuIl19 */"));
37
+ var StyledCloseButton = ( /*#__PURE__*/0, _styledBase["default"])(_button.IconButton, {
38
+ target: "e1s2vq9x1",
39
+ label: "StyledCloseButton"
40
+ })("svg{color:", _core.colors.brand.greyMedium, ";}&:hover,&:focus{background:", _core.colors.brand.greyDark, ";svg{color:", _core.colors.brand.greyLightest, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkRlZmF1bHRTbmFja2Jhci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBK0I0QyIsImZpbGUiOiJEZWZhdWx0U25hY2tiYXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjItcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IEljb25CdXR0b24gfSBmcm9tICdAbmRsYS9idXR0b24nO1xuaW1wb3J0IHsgYnJlYWtwb2ludHMsIGNvbG9ycywgZm9udHMsIG1pc2MsIG1xLCBzaGFkb3dzLCBzcGFjaW5nIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgeyBDcm9zcyB9IGZyb20gJ0BuZGxhL2ljb25zL2FjdGlvbic7XG5pbXBvcnQgeyBTbmFjaywgdXNlU25hY2sgfSBmcm9tICcuL1NuYWNrYmFyUHJvdmlkZXInO1xuXG5jb25zdCBEZWZhdWx0U25hY2tDb250YWluZXIgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBnYXA6ICR7c3BhY2luZy5zbWFsbH07XG4gIHBhZGRpbmc6ICR7c3BhY2luZy5zbWFsbH07XG4gIGJhY2tncm91bmQtY29sb3I6ICR7Y29sb3JzLnRleHQucHJpbWFyeX07XG4gIGNvbG9yOiAke2NvbG9ycy53aGl0ZX07XG4gIGJvcmRlci1yYWRpdXM6ICR7bWlzYy5ib3JkZXJSYWRpdXN9O1xuICBtYXJnaW46IDAgJHtzcGFjaW5nLmxhcmdlfTtcbiAgcG9pbnRlci1ldmVudHM6IGFsbDtcbiAgYm94LXNoYWRvdzogJHtzaGFkb3dzLmxldml0YXRlMX07XG4gIGZvbnQtZmFtaWx5OiAke2ZvbnRzLnNhbnN9O1xuICBmb250LXNpemU6IDE4cHg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5gO1xuXG5jb25zdCBTdHlsZWRDbG9zZUJ1dHRvbiA9IHN0eWxlZChJY29uQnV0dG9uKWBcbiAgc3ZnIHtcbiAgICBjb2xvcjogJHtjb2xvcnMuYnJhbmQuZ3JleU1lZGl1bX07XG4gIH1cbiAgJjpob3ZlcixcbiAgJjpmb2N1cyB7XG4gICAgYmFja2dyb3VuZDogJHtjb2xvcnMuYnJhbmQuZ3JleURhcmt9O1xuICAgIHN2ZyB7XG4gICAgICBjb2xvcjogJHtjb2xvcnMuYnJhbmQuZ3JleUxpZ2h0ZXN0fTtcbiAgICB9XG4gIH1cbmA7XG5cbmNvbnN0IEJ1dHRvbldyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICAke21xLnJhbmdlKHsgZnJvbTogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgZ2FwOiAke3NwYWNpbmcueHhzbWFsbH07XG4gIH1cbmA7XG5cbmNvbnN0IERlZmF1bHRTbmFjayA9IChzbmFjazogU25hY2spID0+IHtcbiAgY29uc3QgeyBjbG9zYWJsZSA9IHRydWUsIGljb24gfSA9IHNuYWNrO1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIGNvbnN0IHsgY2xvc2VTbmFjayB9ID0gdXNlU25hY2soKTtcbiAgcmV0dXJuIChcbiAgICA8RGVmYXVsdFNuYWNrQ29udGFpbmVyPlxuICAgICAge2ljb259XG4gICAgICB7c25hY2suY29udGVudH1cbiAgICAgIDxCdXR0b25XcmFwcGVyPlxuICAgICAgICB7Y2xvc2FibGUgJiYgKFxuICAgICAgICAgIDxTdHlsZWRDbG9zZUJ1dHRvbiBzaXplPVwieHNtYWxsXCIgb3V0bGluZSBvbkNsaWNrPXsoKSA9PiBjbG9zZVNuYWNrKHNuYWNrKX0gYXJpYS1sYWJlbD17dCgnc25hY2tiYXIuY2xvc2UnKX0+XG4gICAgICAgICAgICA8Q3Jvc3MgLz5cbiAgICAgICAgICA8L1N0eWxlZENsb3NlQnV0dG9uPlxuICAgICAgICApfVxuICAgICAgPC9CdXR0b25XcmFwcGVyPlxuICAgIDwvRGVmYXVsdFNuYWNrQ29udGFpbmVyPlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgRGVmYXVsdFNuYWNrO1xuIl19 */"));
41
+ var ButtonWrapper = (0, _styledBase["default"])("div", {
42
+ target: "e1s2vq9x2",
43
+ label: "ButtonWrapper"
44
+ })(_core.mq.range({
45
+ from: _core.breakpoints.tablet
46
+ }), "{gap:", _core.spacing.xxsmall, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkRlZmF1bHRTbmFja2Jhci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNENnQyIsImZpbGUiOiJEZWZhdWx0U25hY2tiYXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjItcHJlc2VudCwgTkRMQS5cbiAqXG4gKiBUaGlzIHNvdXJjZSBjb2RlIGlzIGxpY2Vuc2VkIHVuZGVyIHRoZSBHUEx2MyBsaWNlbnNlIGZvdW5kIGluIHRoZVxuICogTElDRU5TRSBmaWxlIGluIHRoZSByb290IGRpcmVjdG9yeSBvZiB0aGlzIHNvdXJjZSB0cmVlLlxuICpcbiAqL1xuXG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdyZWFjdC1pMThuZXh0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IEljb25CdXR0b24gfSBmcm9tICdAbmRsYS9idXR0b24nO1xuaW1wb3J0IHsgYnJlYWtwb2ludHMsIGNvbG9ycywgZm9udHMsIG1pc2MsIG1xLCBzaGFkb3dzLCBzcGFjaW5nIH0gZnJvbSAnQG5kbGEvY29yZSc7XG5pbXBvcnQgeyBDcm9zcyB9IGZyb20gJ0BuZGxhL2ljb25zL2FjdGlvbic7XG5pbXBvcnQgeyBTbmFjaywgdXNlU25hY2sgfSBmcm9tICcuL1NuYWNrYmFyUHJvdmlkZXInO1xuXG5jb25zdCBEZWZhdWx0U25hY2tDb250YWluZXIgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBnYXA6ICR7c3BhY2luZy5zbWFsbH07XG4gIHBhZGRpbmc6ICR7c3BhY2luZy5zbWFsbH07XG4gIGJhY2tncm91bmQtY29sb3I6ICR7Y29sb3JzLnRleHQucHJpbWFyeX07XG4gIGNvbG9yOiAke2NvbG9ycy53aGl0ZX07XG4gIGJvcmRlci1yYWRpdXM6ICR7bWlzYy5ib3JkZXJSYWRpdXN9O1xuICBtYXJnaW46IDAgJHtzcGFjaW5nLmxhcmdlfTtcbiAgcG9pbnRlci1ldmVudHM6IGFsbDtcbiAgYm94LXNoYWRvdzogJHtzaGFkb3dzLmxldml0YXRlMX07XG4gIGZvbnQtZmFtaWx5OiAke2ZvbnRzLnNhbnN9O1xuICBmb250LXNpemU6IDE4cHg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5gO1xuXG5jb25zdCBTdHlsZWRDbG9zZUJ1dHRvbiA9IHN0eWxlZChJY29uQnV0dG9uKWBcbiAgc3ZnIHtcbiAgICBjb2xvcjogJHtjb2xvcnMuYnJhbmQuZ3JleU1lZGl1bX07XG4gIH1cbiAgJjpob3ZlcixcbiAgJjpmb2N1cyB7XG4gICAgYmFja2dyb3VuZDogJHtjb2xvcnMuYnJhbmQuZ3JleURhcmt9O1xuICAgIHN2ZyB7XG4gICAgICBjb2xvcjogJHtjb2xvcnMuYnJhbmQuZ3JleUxpZ2h0ZXN0fTtcbiAgICB9XG4gIH1cbmA7XG5cbmNvbnN0IEJ1dHRvbldyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICAke21xLnJhbmdlKHsgZnJvbTogYnJlYWtwb2ludHMudGFibGV0IH0pfSB7XG4gICAgZ2FwOiAke3NwYWNpbmcueHhzbWFsbH07XG4gIH1cbmA7XG5cbmNvbnN0IERlZmF1bHRTbmFjayA9IChzbmFjazogU25hY2spID0+IHtcbiAgY29uc3QgeyBjbG9zYWJsZSA9IHRydWUsIGljb24gfSA9IHNuYWNrO1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCk7XG4gIGNvbnN0IHsgY2xvc2VTbmFjayB9ID0gdXNlU25hY2soKTtcbiAgcmV0dXJuIChcbiAgICA8RGVmYXVsdFNuYWNrQ29udGFpbmVyPlxuICAgICAge2ljb259XG4gICAgICB7c25hY2suY29udGVudH1cbiAgICAgIDxCdXR0b25XcmFwcGVyPlxuICAgICAgICB7Y2xvc2FibGUgJiYgKFxuICAgICAgICAgIDxTdHlsZWRDbG9zZUJ1dHRvbiBzaXplPVwieHNtYWxsXCIgb3V0bGluZSBvbkNsaWNrPXsoKSA9PiBjbG9zZVNuYWNrKHNuYWNrKX0gYXJpYS1sYWJlbD17dCgnc25hY2tiYXIuY2xvc2UnKX0+XG4gICAgICAgICAgICA8Q3Jvc3MgLz5cbiAgICAgICAgICA8L1N0eWxlZENsb3NlQnV0dG9uPlxuICAgICAgICApfVxuICAgICAgPC9CdXR0b25XcmFwcGVyPlxuICAgIDwvRGVmYXVsdFNuYWNrQ29udGFpbmVyPlxuICApO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgRGVmYXVsdFNuYWNrO1xuIl19 */"));
47
+
48
+ var DefaultSnack = function DefaultSnack(snack) {
49
+ var _snack$closable = snack.closable,
50
+ closable = _snack$closable === void 0 ? true : _snack$closable,
51
+ icon = snack.icon;
52
+
53
+ var _useTranslation = (0, _reactI18next.useTranslation)(),
54
+ t = _useTranslation.t;
55
+
56
+ var _useSnack = (0, _SnackbarProvider.useSnack)(),
57
+ closeSnack = _useSnack.closeSnack;
58
+
59
+ return (0, _core2.jsx)(DefaultSnackContainer, null, icon, snack.content, (0, _core2.jsx)(ButtonWrapper, null, closable && (0, _core2.jsx)(StyledCloseButton, {
60
+ size: "xsmall",
61
+ outline: true,
62
+ onClick: function onClick() {
63
+ return closeSnack(snack);
64
+ },
65
+ "aria-label": t('snackbar.close')
66
+ }, (0, _core2.jsx)(_action.Cross, null))));
67
+ };
68
+
69
+ var _default = DefaultSnack;
70
+ exports["default"] = _default;